{"version":3,"file":"apiInterceptors-cd5d4bf5.js","sources":["../../node_modules/@js-joda/core/dist/js-joda.esm.js","../../node_modules/@js-joda/timezone/dist/js-joda-timezone.js","../../node_modules/vue/dist/vue.runtime.esm.js","../../node_modules/vue-i18n/dist/vue-i18n.esm.js","../../src/app/types/common/key.ts","../../src/app/services/generated/enums/enumFeatureFlag.generated.ts","../../src/locales/langLocales.ts","../../src/locales/unexpectedTranslationKeys.ts","../../src/environment.ts","../../src/app/eventlogging/eventCollectorEventLogger.ts","../../src/app/eventlogging/eventLogger.ts","../../src/app/eventlogging/assertLogger.ts","../../src/plugins/i18n.ts","../../src/app/services/generated/enums/enumDateFormat.generated.ts","../../src/app/types/common/guid.ts","../../node_modules/lodash-es/_listCacheClear.js","../../node_modules/lodash-es/eq.js","../../node_modules/lodash-es/_assocIndexOf.js","../../node_modules/lodash-es/_listCacheDelete.js","../../node_modules/lodash-es/_listCacheGet.js","../../node_modules/lodash-es/_listCacheHas.js","../../node_modules/lodash-es/_listCacheSet.js","../../node_modules/lodash-es/_ListCache.js","../../node_modules/lodash-es/_stackClear.js","../../node_modules/lodash-es/_stackDelete.js","../../node_modules/lodash-es/_stackGet.js","../../node_modules/lodash-es/_stackHas.js","../../node_modules/lodash-es/_freeGlobal.js","../../node_modules/lodash-es/_root.js","../../node_modules/lodash-es/_Symbol.js","../../node_modules/lodash-es/_getRawTag.js","../../node_modules/lodash-es/_objectToString.js","../../node_modules/lodash-es/_baseGetTag.js","../../node_modules/lodash-es/isObject.js","../../node_modules/lodash-es/isFunction.js","../../node_modules/lodash-es/_coreJsData.js","../../node_modules/lodash-es/_isMasked.js","../../node_modules/lodash-es/_toSource.js","../../node_modules/lodash-es/_baseIsNative.js","../../node_modules/lodash-es/_getValue.js","../../node_modules/lodash-es/_getNative.js","../../node_modules/lodash-es/_Map.js","../../node_modules/lodash-es/_nativeCreate.js","../../node_modules/lodash-es/_hashClear.js","../../node_modules/lodash-es/_hashDelete.js","../../node_modules/lodash-es/_hashGet.js","../../node_modules/lodash-es/_hashHas.js","../../node_modules/lodash-es/_hashSet.js","../../node_modules/lodash-es/_Hash.js","../../node_modules/lodash-es/_mapCacheClear.js","../../node_modules/lodash-es/_isKeyable.js","../../node_modules/lodash-es/_getMapData.js","../../node_modules/lodash-es/_mapCacheDelete.js","../../node_modules/lodash-es/_mapCacheGet.js","../../node_modules/lodash-es/_mapCacheHas.js","../../node_modules/lodash-es/_mapCacheSet.js","../../node_modules/lodash-es/_MapCache.js","../../node_modules/lodash-es/_stackSet.js","../../node_modules/lodash-es/_Stack.js","../../node_modules/lodash-es/_setCacheAdd.js","../../node_modules/lodash-es/_setCacheHas.js","../../node_modules/lodash-es/_SetCache.js","../../node_modules/lodash-es/_arraySome.js","../../node_modules/lodash-es/_cacheHas.js","../../node_modules/lodash-es/_equalArrays.js","../../node_modules/lodash-es/_Uint8Array.js","../../node_modules/lodash-es/_mapToArray.js","../../node_modules/lodash-es/_setToArray.js","../../node_modules/lodash-es/_equalByTag.js","../../node_modules/lodash-es/_arrayPush.js","../../node_modules/lodash-es/isArray.js","../../node_modules/lodash-es/_baseGetAllKeys.js","../../node_modules/lodash-es/_arrayFilter.js","../../node_modules/lodash-es/stubArray.js","../../node_modules/lodash-es/_getSymbols.js","../../node_modules/lodash-es/_baseTimes.js","../../node_modules/lodash-es/isObjectLike.js","../../node_modules/lodash-es/_baseIsArguments.js","../../node_modules/lodash-es/isArguments.js","../../node_modules/lodash-es/stubFalse.js","../../node_modules/lodash-es/isBuffer.js","../../node_modules/lodash-es/_isIndex.js","../../node_modules/lodash-es/isLength.js","../../node_modules/lodash-es/_baseIsTypedArray.js","../../node_modules/lodash-es/_baseUnary.js","../../node_modules/lodash-es/_nodeUtil.js","../../node_modules/lodash-es/isTypedArray.js","../../node_modules/lodash-es/_arrayLikeKeys.js","../../node_modules/lodash-es/_isPrototype.js","../../node_modules/lodash-es/_overArg.js","../../node_modules/lodash-es/_nativeKeys.js","../../node_modules/lodash-es/_baseKeys.js","../../node_modules/lodash-es/isArrayLike.js","../../node_modules/lodash-es/keys.js","../../node_modules/lodash-es/_getAllKeys.js","../../node_modules/lodash-es/_equalObjects.js","../../node_modules/lodash-es/_DataView.js","../../node_modules/lodash-es/_Promise.js","../../node_modules/lodash-es/_Set.js","../../node_modules/lodash-es/_WeakMap.js","../../node_modules/lodash-es/_getTag.js","../../node_modules/lodash-es/_baseIsEqualDeep.js","../../node_modules/lodash-es/_baseIsEqual.js","../../node_modules/lodash-es/isEqual.js","../../src/app/services/modelObject.ts","../../src/app/api.ts","../../src/app/tracing.ts","../../src/app/errors/index.ts","../../src/app/services/generated/constants.ts","../../src/store/modules/versionManager.ts","../../src/components/controls/snackbar/SnackbarTypes.ts","../../src/app/services/generated/enums/enumUserPermission.generated.ts","../../src/store/modules/appStore.ts","../../src/app/services/generated/enums/enumBillingPlanStatus.generated.ts","../../src/app/services/generated/enums/enumStockLevelDisplay.generated.ts","../../src/tradeportal/tpSessionData.ts","../../src/app/services/serviceBase.ts","../../src/app/services/generated/enums/enumTransportationDistanceUnit.generated.ts","../../src/app/services/generated/enums/enumVolumeUnit.generated.ts","../../src/app/services/generated/enums/enumWeightUnit.generated.ts","../../src/app/services/generated/tenantService.ts","../../src/utils/dateTimes.ts","../../src/app/services/extensions/tenantServiceExtended.ts","../../src/app/services/generated/enums/enumBrewmanBarcodeType.generated.ts","../../src/plugins/bmBarcodeValidator.ts","../../src/plugins/validation.ts","../../node_modules/portal-vue/dist/portal-vue.esm.js","../../src/plugins/portalVue.ts","../../node_modules/signature_pad/dist/signature_pad.js","../../node_modules/merge-images/dist/index.es2015.js","../../node_modules/vue-signature-pad/dist/vue-signature-pad.esm.js","../../src/plugins/signaturePad.ts","../../src/components/composables/root.ts","../../src/plugins/commonImports.ts","../../node_modules/vuetify/lib/mixins/themeable/index.js","../../node_modules/vuetify/lib/util/mixins.js","../../node_modules/vuetify/lib/components/VApp/VApp.js","../../node_modules/vuetify/lib/mixins/binds-attrs/index.js","../../node_modules/vuetify/lib/install.js","../../node_modules/vuetify/lib/services/service/index.js","../../node_modules/vuetify/lib/services/application/index.js","../../node_modules/vuetify/lib/services/breakpoint/index.js","../../node_modules/vuetify/lib/services/goto/easing-patterns.js","../../node_modules/vuetify/lib/services/goto/util.js","../../node_modules/vuetify/lib/services/goto/index.js","../../node_modules/vuetify/lib/util/helpers.js","../../node_modules/vuetify/lib/services/icons/presets/mdi-svg.js","../../node_modules/vuetify/lib/services/icons/presets/md.js","../../node_modules/vuetify/lib/services/icons/presets/mdi.js","../../node_modules/vuetify/lib/services/icons/presets/fa.js","../../node_modules/vuetify/lib/services/icons/presets/fa4.js","../../node_modules/vuetify/lib/services/icons/presets/fa-svg.js","../../node_modules/vuetify/lib/services/icons/presets/index.js","../../node_modules/vuetify/lib/services/icons/index.js","../../node_modules/vuetify/lib/services/lang/index.js","../../node_modules/vuetify/lib/locale/en.js","../../node_modules/vuetify/lib/presets/default/index.js","../../node_modules/vuetify/lib/services/presets/index.js","../../node_modules/vuetify/lib/util/color/transformSRGB.js","../../node_modules/vuetify/lib/util/colorUtils.js","../../node_modules/vuetify/lib/util/color/transformCIELAB.js","../../node_modules/vuetify/lib/services/theme/utils.js","../../node_modules/vuetify/lib/services/theme/index.js","../../node_modules/vuetify/lib/framework.js","../../node_modules/vuetify/lib/util/console.js","../../node_modules/vuetify/lib/mixins/colorable/index.js","../../node_modules/vuetify/lib/mixins/elevatable/index.js","../../node_modules/vuetify/lib/mixins/measurable/index.js","../../node_modules/vuetify/lib/mixins/roundable/index.js","../../node_modules/vuetify/lib/components/VSheet/VSheet.js","../../node_modules/vuetify/lib/directives/intersect/index.js","../../node_modules/vuetify/lib/components/VResponsive/VResponsive.js","../../node_modules/vuetify/lib/util/mergeData.js","../../node_modules/vuetify/lib/components/VImg/VImg.js","../../node_modules/vuetify/lib/components/VToolbar/VToolbar.js","../../node_modules/vuetify/lib/directives/scroll/index.js","../../node_modules/vuetify/lib/mixins/positionable/index.js","../../node_modules/vuetify/lib/mixins/applicationable/index.js","../../node_modules/vuetify/lib/util/dom.js","../../node_modules/vuetify/lib/directives/click-outside/index.js","../../node_modules/vuetify/lib/directives/resize/index.js","../../node_modules/vuetify/lib/directives/ripple/index.js","../../node_modules/vuetify/lib/directives/touch/index.js","../../node_modules/vuetify/lib/mixins/scrollable/index.js","../../node_modules/vuetify/lib/mixins/ssr-bootable/index.js","../../node_modules/vuetify/lib/mixins/toggleable/index.js","../../node_modules/vuetify/lib/components/VAppBar/VAppBar.js","../../node_modules/vuetify/lib/mixins/sizeable/index.js","../../node_modules/vuetify/lib/components/VIcon/VIcon.js","../../node_modules/vuetify/lib/components/VProgressCircular/VProgressCircular.js","../../node_modules/vuetify/lib/mixins/registrable/index.js","../../node_modules/vuetify/lib/mixins/groupable/index.js","../../node_modules/vuetify/lib/mixins/routable/index.js","../../node_modules/vuetify/lib/components/VBtn/VBtn.js","../../node_modules/vuetify/lib/components/VAppBar/VAppBarNavIcon.js","../../node_modules/vuetify/lib/mixins/transitionable/index.js","../../node_modules/vuetify/lib/components/VAlert/VAlert.js","../../node_modules/vuetify/lib/components/transitions/createTransition.js","../../node_modules/vuetify/lib/components/transitions/expand-transition.js","../../node_modules/vuetify/lib/components/transitions/index.js","../../node_modules/vuetify/lib/components/VChip/VChip.js","../../node_modules/vuetify/lib/components/VThemeProvider/VThemeProvider.js","../../node_modules/vuetify/lib/mixins/delayable/index.js","../../node_modules/vuetify/lib/mixins/activatable/index.js","../../node_modules/vuetify/lib/mixins/dependent/index.js","../../node_modules/vuetify/lib/mixins/stackable/index.js","../../node_modules/vuetify/lib/mixins/bootable/index.js","../../node_modules/vuetify/lib/mixins/detachable/index.js","../../node_modules/vuetify/lib/mixins/menuable/index.js","../../node_modules/vuetify/lib/mixins/returnable/index.js","../../node_modules/vuetify/lib/components/VMenu/VMenu.js","../../node_modules/vuetify/lib/components/VCheckbox/VSimpleCheckbox.js","../../node_modules/vuetify/lib/components/VDivider/VDivider.js","../../node_modules/vuetify/lib/components/VSubheader/VSubheader.js","../../node_modules/vuetify/lib/components/VList/VList.js","../../node_modules/vuetify/lib/components/VList/VListItem.js","../../node_modules/vuetify/lib/components/VList/VListItemIcon.js","../../node_modules/vuetify/lib/components/VList/VListGroup.js","../../node_modules/vuetify/lib/mixins/comparable/index.js","../../node_modules/vuetify/lib/mixins/proxyable/index.js","../../node_modules/vuetify/lib/components/VItemGroup/VItemGroup.js","../../node_modules/vuetify/lib/components/VList/VListItemGroup.js","../../node_modules/vuetify/lib/components/VList/VListItemAction.js","../../node_modules/vuetify/lib/components/VAvatar/VAvatar.js","../../node_modules/vuetify/lib/components/VList/index.js","../../node_modules/vuetify/lib/components/VSelect/VSelectList.js","../../node_modules/vuetify/lib/components/VLabel/VLabel.js","../../node_modules/vuetify/lib/components/VMessages/VMessages.js","../../node_modules/vuetify/lib/mixins/validatable/index.js","../../node_modules/vuetify/lib/components/VInput/VInput.js","../../node_modules/vuetify/lib/components/VCounter/VCounter.js","../../node_modules/vuetify/lib/mixins/intersectable/index.js","../../node_modules/vuetify/lib/components/VProgressLinear/VProgressLinear.js","../../node_modules/vuetify/lib/mixins/loadable/index.js","../../node_modules/vuetify/lib/components/VTextField/VTextField.js","../../node_modules/vuetify/lib/mixins/filterable/index.js","../../node_modules/vuetify/lib/components/VSelect/VSelect.js","../../node_modules/vuetify/lib/components/VAutocomplete/VAutocomplete.js","../../node_modules/vuetify/lib/components/VBadge/VBadge.js","../../node_modules/vuetify/lib/mixins/mobile/index.js","../../node_modules/vuetify/lib/mixins/button-group/index.js","../../node_modules/vuetify/lib/components/VOverlay/VOverlay.js","../../node_modules/vuetify/lib/mixins/overlayable/index.js","../../node_modules/vuetify/lib/components/VDialog/VDialog.js","../../node_modules/vuetify/lib/components/VBottomSheet/VBottomSheet.js","../../node_modules/vuetify/lib/mixins/localable/index.js","../../node_modules/vuetify/lib/components/VCalendar/mixins/mouse.js","../../node_modules/vuetify/lib/util/dateTimeUtils.js","../../node_modules/vuetify/lib/components/VCalendar/util/timestamp.js","../../node_modules/vuetify/lib/components/VCalendar/mixins/times.js","../../node_modules/vuetify/lib/components/VCalendar/modes/common.js","../../node_modules/vuetify/lib/components/VCalendar/modes/stack.js","../../node_modules/vuetify/lib/components/VCalendar/modes/column.js","../../node_modules/vuetify/lib/components/VCalendar/modes/index.js","../../node_modules/vuetify/lib/components/VCalendar/util/props.js","../../node_modules/vuetify/lib/components/VCalendar/mixins/calendar-base.js","../../node_modules/vuetify/lib/components/VCalendar/util/events.js","../../node_modules/vuetify/lib/components/VCalendar/mixins/calendar-with-events.js","../../node_modules/vuetify/lib/components/VCalendar/VCalendarWeekly.js","../../node_modules/vuetify/lib/components/VCalendar/VCalendarMonthly.js","../../node_modules/vuetify/lib/components/VCalendar/mixins/calendar-with-intervals.js","../../node_modules/vuetify/lib/components/VCalendar/VCalendarDaily.js","../../node_modules/vuetify/lib/components/VCalendar/util/parser.js","../../node_modules/vuetify/lib/components/VCalendar/VCalendarCategory.js","../../node_modules/vuetify/lib/components/VCalendar/VCalendar.js","../../node_modules/vuetify/lib/components/VCard/VCard.js","../../node_modules/vuetify/lib/components/VCard/index.js","../../node_modules/vuetify/lib/components/VWindow/VWindow.js","../../node_modules/vuetify/lib/components/VCarousel/VCarousel.js","../../node_modules/vuetify/lib/components/VWindow/VWindowItem.js","../../node_modules/vuetify/lib/components/VCarousel/VCarouselItem.js","../../node_modules/vuetify/lib/mixins/rippleable/index.js","../../node_modules/vuetify/lib/mixins/selectable/index.js","../../node_modules/vuetify/lib/components/VCheckbox/VCheckbox.js","../../node_modules/vuetify/lib/components/VSlideGroup/VSlideGroup.js","../../node_modules/vuetify/lib/components/VSlider/VSlider.js","../../node_modules/vuetify/lib/components/VColorPicker/util/index.js","../../node_modules/vuetify/lib/components/VColorPicker/VColorPickerPreview.js","../../node_modules/vuetify/lib/components/VColorPicker/VColorPickerCanvas.js","../../node_modules/vuetify/lib/components/VColorPicker/VColorPickerEdit.js","../../node_modules/vuetify/lib/util/colors.js","../../node_modules/vuetify/lib/components/VColorPicker/VColorPickerSwatches.js","../../node_modules/vuetify/lib/components/VColorPicker/VColorPicker.js","../../node_modules/vuetify/lib/components/VMain/VMain.js","../../node_modules/vuetify/lib/components/VCombobox/VCombobox.js","../../node_modules/vuetify/lib/mixins/picker-button/index.js","../../node_modules/vuetify/lib/components/VDatePicker/VDatePickerTitle.js","../../node_modules/vuetify/lib/components/VDatePicker/util/eventHelpers.js","../../node_modules/vuetify/lib/components/VDatePicker/util/pad.js","../../node_modules/vuetify/lib/components/VDatePicker/util/createNativeLocaleFormatter.js","../../node_modules/vuetify/lib/components/VDatePicker/util/monthChange.js","../../node_modules/vuetify/lib/components/VDatePicker/util/sanitizeDateString.js","../../node_modules/vuetify/lib/components/VDatePicker/VDatePickerHeader.js","../../node_modules/vuetify/lib/components/VDatePicker/util/isDateAllowed.js","../../node_modules/vuetify/lib/components/VDatePicker/mixins/date-picker-table.js","../../node_modules/vuetify/lib/components/VDatePicker/VDatePickerDateTable.js","../../node_modules/vuetify/lib/components/VDatePicker/VDatePickerMonthTable.js","../../node_modules/vuetify/lib/components/VDatePicker/VDatePickerYears.js","../../node_modules/vuetify/lib/components/VPicker/VPicker.js","../../node_modules/vuetify/lib/mixins/picker/index.js","../../node_modules/vuetify/lib/components/VDatePicker/VDatePicker.js","../../node_modules/vuetify/lib/components/VExpansionPanel/VExpansionPanels.js","../../node_modules/vuetify/lib/components/VExpansionPanel/VExpansionPanel.js","../../node_modules/vuetify/lib/components/VExpansionPanel/VExpansionPanelContent.js","../../node_modules/vuetify/lib/components/VExpansionPanel/VExpansionPanelHeader.js","../../node_modules/vuetify/lib/components/VFileInput/VFileInput.js","../../node_modules/vuetify/lib/components/VFooter/VFooter.js","../../node_modules/vuetify/lib/components/VForm/VForm.js","../../node_modules/vuetify/lib/components/VGrid/grid.js","../../node_modules/vuetify/lib/components/VGrid/VContainer.js","../../node_modules/vuetify/lib/components/VGrid/VCol.js","../../node_modules/vuetify/lib/components/VGrid/VRow.js","../../node_modules/vuetify/lib/components/VGrid/VSpacer.js","../../node_modules/vuetify/lib/components/VGrid/VLayout.js","../../node_modules/vuetify/lib/components/VGrid/VFlex.js","../../node_modules/vuetify/lib/components/VItemGroup/VItem.js","../../node_modules/vuetify/lib/components/VNavigationDrawer/VNavigationDrawer.js","../../node_modules/vuetify/lib/components/VRadioGroup/VRadioGroup.js","../../node_modules/vuetify/lib/components/VRadioGroup/VRadio.js","../../node_modules/vuetify/lib/components/VSkeletonLoader/VSkeletonLoader.js","../../node_modules/vuetify/lib/components/VSnackbar/VSnackbar.js","../../node_modules/vuetify/lib/components/VSpeedDial/VSpeedDial.js","../../node_modules/vuetify/lib/components/VStepper/VStepper.js","../../node_modules/vuetify/lib/components/VStepper/VStepperStep.js","../../node_modules/vuetify/lib/components/VStepper/VStepperContent.js","../../node_modules/vuetify/lib/components/VStepper/index.js","../../node_modules/vuetify/lib/components/VSwitch/VSwitch.js","../../node_modules/vuetify/lib/components/VTabs/VTabsBar.js","../../node_modules/vuetify/lib/components/VTabs/VTabsItems.js","../../node_modules/vuetify/lib/components/VTabs/VTabsSlider.js","../../node_modules/vuetify/lib/components/VTabs/VTabs.js","../../node_modules/vuetify/lib/components/VTabs/VTab.js","../../node_modules/vuetify/lib/components/VTextarea/VTextarea.js","../../node_modules/vuetify/lib/components/VTimeline/VTimeline.js","../../node_modules/vuetify/lib/components/VTimeline/VTimelineItem.js","../../node_modules/vuetify/lib/components/VTimePicker/SelectingTimes.js","../../node_modules/vuetify/lib/components/VTimePicker/VTimePickerTitle.js","../../node_modules/vuetify/lib/components/VTimePicker/VTimePickerClock.js","../../node_modules/vuetify/lib/components/VTimePicker/VTimePicker.js","../../node_modules/vuetify/lib/components/VToolbar/index.js","../../node_modules/vuetify/lib/components/VTooltip/VTooltip.js","../../node_modules/vuetify/lib/components/VVirtualScroll/VVirtualScroll.js","../../src/components/controls/input/BmTooltip.vue","../../src/components/controls/input/mixins/BmLabelled.ts","../../src/components/controls/input/BmBtn.vue","../../src/components/controls/input/mixins/BmInputField.ts","../../src/components/controls/input/BmCheckbox.vue","../../src/components/controls/BetaIcon.vue","../../src/app/types/common/guidcollections.ts","../../src/app/errors/errorLoggerService.ts","../../src/components/composables/reactivityTypes.ts","../../src/components/composables/componentTools.ts","../../src/app/apiutils.ts","../../src/components/mixins/DisplayHelpers.ts","../../src/components/controls/input/BmControl.vue","../../src/components/controls/input/BmCheckboxGroup.vue","../../node_modules/js-cookie/dist/js.cookie.mjs","../../src/app/services/generated/enums/enumUserTenantGroupLevel.generated.ts","../../src/app/services/generated/billingplanService.ts","../../src/app/services/generated/authenticationService.ts","../../src/app/services/generated/usersessionService.ts","../../src/app/services/generated/enums/enumDayOfWeek.generated.ts","../../src/app/services/generated/enums/enumGetUserByCredentialStatus.generated.ts","../../src/app/services/generated/userService.ts","../../src/app/services/extensions/userServiceExtended.ts","../../src/app/services/generated/enums/enumDiscountBasis.generated.ts","../../src/app/services/generated/enums/enumDiscountTierBasis.generated.ts","../../src/app/services/generated/enums/enumBogofQuantityBasis.generated.ts","../../src/app/services/extensions/localisationServiceExtended.ts","../../src/components/composables/localisation.ts","../../node_modules/@firebase/util/dist/index.esm2017.js","../../node_modules/@firebase/component/dist/esm/index.esm2017.js","../../node_modules/@firebase/logger/dist/esm/index.esm2017.js","../../node_modules/@firebase/app/node_modules/idb/build/wrap-idb-value.js","../../node_modules/@firebase/app/node_modules/idb/build/index.js","../../node_modules/@firebase/app/dist/esm/index.esm2017.js","../../node_modules/firebase/app/dist/index.esm.js","../../node_modules/tslib/tslib.es6.mjs","../../node_modules/@firebase/auth/dist/esm2017/index-4dc22a28.js","../../src/components/pages/account/composables/authentication.ts","../../src/store/modules/browserIdentityManager.ts","../../src/app/eventlogging/eventCollectorShipper.ts","../../src/app/eventlogging/eventShipper.ts","../../src/store/modules/userStore.ts","../../src/components/controls/input/BmDate.vue","../../src/components/controls/input/BmTime.vue","../../src/components/controls/input/BmDateTime.vue","../../src/components/controls/daterange/dateRangePresets.ts","../../node_modules/lodash-es/isSymbol.js","../../node_modules/lodash-es/_isKey.js","../../node_modules/lodash-es/memoize.js","../../node_modules/lodash-es/_memoizeCapped.js","../../node_modules/lodash-es/_stringToPath.js","../../node_modules/lodash-es/_arrayMap.js","../../node_modules/lodash-es/_baseToString.js","../../node_modules/lodash-es/toString.js","../../node_modules/lodash-es/_castPath.js","../../node_modules/lodash-es/_toKey.js","../../node_modules/lodash-es/_baseGet.js","../../node_modules/lodash-es/get.js","../../src/components/utils/vuetifyHelpers.ts","../../src/components/controls/DataComponentAttrs.ts","../../src/components/controls/input/BmDropdown.vue","../../src/components/controls/daterange/BmDateRange.vue","../../src/components/controls/input/BmRadio.vue","../../src/components/controls/input/BmReadOnlyField.vue","../../src/components/controls/input/BmRadioGroup.vue","../../src/components/controls/input/BmSlider.vue","../../src/components/controls/input/BmSwitch.vue","../../node_modules/lodash-es/_baseSlice.js","../../node_modules/lodash-es/_castSlice.js","../../node_modules/lodash-es/_hasUnicode.js","../../node_modules/lodash-es/_baseIsRegExp.js","../../node_modules/lodash-es/isRegExp.js","../../node_modules/lodash-es/_baseProperty.js","../../node_modules/lodash-es/_asciiSize.js","../../node_modules/lodash-es/_unicodeSize.js","../../node_modules/lodash-es/_stringSize.js","../../node_modules/lodash-es/_asciiToArray.js","../../node_modules/lodash-es/_unicodeToArray.js","../../node_modules/lodash-es/_stringToArray.js","../../node_modules/lodash-es/_trimmedEndIndex.js","../../node_modules/lodash-es/_baseTrim.js","../../node_modules/lodash-es/toNumber.js","../../node_modules/lodash-es/toFinite.js","../../node_modules/lodash-es/toInteger.js","../../node_modules/lodash-es/truncate.js","../../src/components/controls/input/BmText.vue","../../src/components/controls/input/BmNumber.vue","../../src/components/controls/input/BmTextArea.vue","../../src/components/controls/input/BmEnumDdl.vue","../../src/components/controls/card/BmCard.vue","../../src/app/services/generated/suppliermanufacturerService.ts","../../src/app/services/extensions/suppliermanufacturerServiceExtended.ts","../../src/app/services/generated/enums/enumAccountPostingLineType.generated.ts","../../src/app/services/generated/enums/enumAccountPostingStatus.generated.ts","../../src/app/services/generated/enums/enumAccountsPackageType.generated.ts","../../src/app/services/generated/enums/enumActivityLogType.generated.ts","../../src/app/services/generated/enums/enumAggregatingOperation.generated.ts","../../src/app/services/generated/enums/enumAlcoholType.generated.ts","../../src/app/services/generated/enums/enumAssemblyIngredientSource.generated.ts","../../src/app/services/generated/enums/enumAssemblyOutputTarget.generated.ts","../../src/app/services/generated/enums/enumAssemblyRecipeType.generated.ts","../../src/app/services/generated/enums/enumAssemblyStatus.generated.ts","../../src/app/services/generated/enums/enumAssemblyType.generated.ts","../../src/app/services/generated/enums/enumAustralianAlcoholTariff.generated.ts","../../src/app/services/generated/enums/enumBeerflexOrderConfirmationStatus.generated.ts","../../src/app/services/generated/enums/enumBeerflexOrderType.generated.ts","../../src/app/services/generated/enums/enumBmEntityType.generated.ts","../../src/app/services/generated/enums/enumBottleDepositBalanceChangeReason.generated.ts","../../src/app/services/generated/enums/enumCacheEntityType.generated.ts","../../src/app/services/generated/enums/enumCaseLabelWeightType.generated.ts","../../src/app/services/generated/enums/enumChangeLogLineType.generated.ts","../../src/app/services/generated/enums/enumChangeSection.generated.ts","../../src/app/services/generated/enums/enumChangeType.generated.ts","../../src/app/services/generated/enums/enumColumnType.generated.ts","../../src/app/services/generated/enums/enumConsumableType.generated.ts","../../src/app/services/generated/enums/enumContainerStatus.generated.ts","../../src/app/services/generated/enums/enumCountry.generated.ts","../../src/app/services/generated/enums/enumCreditCalculationType.generated.ts","../../src/app/services/generated/enums/enumCreditType.generated.ts","../../src/app/services/generated/enums/enumCtVirtualNo.generated.ts","../../src/app/services/generated/enums/enumCustomerHappinessRating.generated.ts","../../src/app/services/generated/enums/enumDashboardComponent.generated.ts","../../src/app/services/generated/enums/enumDataImportAction.generated.ts","../../src/app/services/generated/enums/enumDataImportDateFormat.generated.ts","../../src/app/services/generated/enums/enumDataImportTimestampFormat.generated.ts","../../src/app/services/generated/enums/enumDataImportType.generated.ts","../../src/app/services/generated/enums/enumDateType.generated.ts","../../src/app/services/generated/enums/enumDeliveryNotificationSetting.generated.ts","../../src/app/services/generated/enums/enumDiscountParent.generated.ts","../../src/app/services/generated/enums/enumDistributionType.generated.ts","../../src/app/services/generated/enums/enumDocumentContextType.generated.ts","../../src/app/services/generated/enums/enumDocumentEmailTag.generated.ts","../../src/app/services/generated/enums/enumDocumentFileType.generated.ts","../../src/app/services/generated/enums/enumDocumentGenerationOutputFileType.generated.ts","../../src/app/services/generated/enums/enumImageFormat.generated.ts","../../src/app/services/generated/enums/enumDocumentTagType.generated.ts","../../src/app/services/generated/enums/enumDocumentType.generated.ts","../../src/app/services/generated/enums/enumDocumentTypeGroup.generated.ts","../../src/app/services/generated/enums/enumDutyHslsRate.generated.ts","../../src/app/services/generated/enums/enumDutyRateBasis.generated.ts","../../src/app/services/generated/enums/enumDutyScheme.generated.ts","../../src/app/services/generated/enums/enumDutySource.generated.ts","../../src/app/services/generated/enums/enumEcommerceConnectionStatus.generated.ts","../../src/app/services/generated/enums/enumEcommerceOrderOriginType.generated.ts","../../src/app/services/generated/enums/enumEdiSource.generated.ts","../../src/app/services/generated/enums/enumEireAlcoholCategory.generated.ts","../../src/app/services/generated/enums/enumEireDutyRateBand.generated.ts","../../src/app/services/generated/enums/enumEireMovementType.generated.ts","../../src/app/services/generated/enums/enumEmailContext.generated.ts","../../src/app/services/generated/enums/enumEmailDocumentGrouping.generated.ts","../../src/app/services/generated/enums/enumEmailType.generated.ts","../../src/app/services/generated/enums/enumExportIncotermCode.generated.ts","../../src/app/services/generated/enums/enumExternalCalendarProvider.generated.ts","../../src/app/services/generated/enums/enumExternalOrderStatus.generated.ts","../../src/app/services/generated/enums/enumFileType.generated.ts","../../src/app/services/generated/enums/enumFilteringOperation.generated.ts","../../src/app/services/generated/enums/enumGermanBeerDutyMovementType.generated.ts","../../src/app/services/generated/enums/enumGermanBeerDutyProductType.generated.ts","../../src/app/services/generated/enums/enumGermanBeerDutyReturnCellProductType.generated.ts","../../src/app/services/generated/enums/enumGroupingOperation.generated.ts","../../src/app/services/generated/enums/enumHistoryDateRangePick.generated.ts","../../src/app/services/generated/enums/enumIntegrationType.generated.ts","../../src/app/services/generated/enums/enumInvoicesOrCredits.generated.ts","../../src/app/services/generated/enums/enumItemMainPurpose.generated.ts","../../src/app/services/generated/enums/enumJourneyLabelStatus.generated.ts","../../src/app/services/generated/enums/enumJourneyStopPlanningStatus.generated.ts","../../src/app/services/generated/enums/enumKegstarContainerType.generated.ts","../../src/app/services/generated/enums/enumLeadStatus.generated.ts","../../src/app/services/generated/enums/enumLocationBondedStatus.generated.ts","../../src/app/services/generated/enums/enumMetricType.generated.ts","../../src/app/services/generated/enums/enumNatureOfTransactionCode.generated.ts","../../src/app/services/generated/enums/enumNumberingType.generated.ts","../../src/app/services/generated/enums/enumOneFreePeriod.generated.ts","../../src/app/services/generated/enums/enumOrderSortBy.generated.ts","../../src/app/services/generated/enums/enumOrderSource.generated.ts","../../src/app/services/generated/enums/enumOrderStatus.generated.ts","../../src/app/services/generated/enums/enumOutletRatingExclusions.generated.ts","../../src/app/services/generated/enums/enumPackageTypeCategoryType.generated.ts","../../src/app/services/generated/enums/enumPalletStatus.generated.ts","../../src/app/services/generated/enums/enumPlannedStockAction.generated.ts","../../src/app/services/generated/enums/enumPlannedStockFollowUpAction.generated.ts","../../src/app/services/generated/enums/enumPlannedStockStatus.generated.ts","../../src/app/services/generated/enums/enumPriceListGroupSortBy.generated.ts","../../src/app/services/generated/enums/enumPriceListLineSortBy.generated.ts","../../src/app/services/generated/enums/enumPriceListSubGroup.generated.ts","../../src/app/services/generated/enums/enumPrinterPreference.generated.ts","../../src/app/services/generated/enums/enumProcessIngredientSource.generated.ts","../../src/app/services/generated/enums/enumProcessOutputTarget.generated.ts","../../src/app/services/generated/enums/enumPurchaseOrderDeliveryDisbursement.generated.ts","../../src/app/services/generated/enums/enumPurchaseOrderDeliveryStatus.generated.ts","../../src/app/services/generated/enums/enumPurchaseOrderStatus.generated.ts","../../src/app/services/generated/enums/enumQcProbeProvider.generated.ts","../../src/app/services/generated/enums/enumQueuedJobType.generated.ts","../../src/app/services/generated/enums/enumRecurringJobType.generated.ts","../../src/app/services/generated/enums/enumReportBuilder.generated.ts","../../src/app/services/generated/enums/enumRetailPaymentMethod.generated.ts","../../src/app/services/generated/enums/enumSalesTextType.generated.ts","../../src/app/services/generated/enums/enumSalesVisitAssociatedEntityType.generated.ts","../../src/app/services/generated/enums/enumScannerInputType.generated.ts","../../src/app/services/generated/enums/enumScannerType.generated.ts","../../src/app/services/generated/enums/enumSecurityProduct.generated.ts","../../src/app/services/generated/enums/enumSessionStatus.generated.ts","../../src/app/services/generated/enums/enumShopifyOrderTag.generated.ts","../../src/app/services/generated/enums/enumSmsContext.generated.ts","../../src/app/services/generated/enums/enumSmsStatus.generated.ts","../../src/app/services/generated/enums/enumSouthAfricanDutyTariff.generated.ts","../../src/app/services/generated/enums/enumSpiritDutyExemptionReason.generated.ts","../../src/app/services/generated/enums/enumStandardOrder.generated.ts","../../src/app/services/generated/enums/enumStockAdjustDutyImplication.generated.ts","../../src/app/services/generated/enums/enumStockChangeReason.generated.ts","../../src/app/services/generated/enums/enumStockItemType.generated.ts","../../src/app/services/generated/enums/enumStockMovementReferenceSource.generated.ts","../../src/app/services/generated/enums/enumStockTakeStatus.generated.ts","../../src/app/services/generated/enums/enumStockTransferStatus.generated.ts","../../src/app/services/generated/enums/enumStockUom.generated.ts","../../src/app/services/generated/enums/enumStripePaymentMethod.generated.ts","../../src/app/services/generated/enums/enumSwedishDutyTariff.generated.ts","../../src/app/services/generated/enums/enumTaskRepeatBasis.generated.ts","../../src/app/services/generated/enums/enumTaskStatus.generated.ts","../../src/app/services/generated/enums/enumTpPaymentMethod.generated.ts","../../src/app/services/generated/enums/enumTpProductListSortOption.generated.ts","../../src/app/services/generated/enums/enumTpSessionErrorReason.generated.ts","../../src/app/services/generated/enums/enumTransactionType.generated.ts","../../src/app/services/generated/enums/enumUkBeerDutySection.generated.ts","../../src/app/services/generated/enums/enumUkDutyRate.generated.ts","../../src/app/services/generated/enums/enumUkDutyReturnType.generated.ts","../../src/app/services/generated/enums/enumUkNewDutyAbvRange.generated.ts","../../src/app/services/generated/enums/enumUkNewDutyProductType.generated.ts","../../src/app/services/generated/enums/enumUkNewDutyRate.generated.ts","../../src/app/services/generated/enums/enumUllageReturnMethod.generated.ts","../../src/app/services/generated/enums/enumUllageStatus.generated.ts","../../src/app/services/generated/enums/enumUsageType.generated.ts","../../src/app/services/generated/enums/enumUserTenantRole.generated.ts","../../src/app/services/generated/enums/enumVehicleProfile.generated.ts","../../src/app/services/generated/enums/enumVesselAvailability.generated.ts","../../src/app/services/generated/enums/enumVesselMainPurpose.generated.ts","../../src/app/services/generated/enums/enumVesselMaintenancePeriodBasis.generated.ts","../../src/app/services/generated/enums/enumVesselMovementSourceType.generated.ts","../../src/app/services/generated/enums/enumVesselMovementTargetType.generated.ts","../../src/app/services/generated/enums/enumVesselStateIcon.generated.ts","../../src/app/services/generated/enums/enumVesselSummaryField.generated.ts","../../src/app/services/generated/enums/enumVesselTypeIcon.generated.ts","../../src/app/services/generated/enums/enumWidgetDragType.generated.ts","../../src/app/services/generated/enums/enumWidgetSize.generated.ts","../../src/app/services/generated/enums/enumYesNoEither.generated.ts","../../src/app/services/generated/enums/registerEnumValues.generated.ts","../../src/app/types/common/distribution.ts","../../src/components/controls/listselector/BmListTypes.ts","../../src/components/dialogs/DialogTypes.ts","../../src/components/pages/administration/user_roles/EnumUserPermissionAccess.ts","../../src/components/pages/batches/composables/processOutputMovementType.ts","../../src/components/pages/distribution/types.ts","../../src/components/pages/integrations/types.ts","../../src/components/pages/news/enumChangelogEntryType.ts","../../src/components/pages/outlet/communications/types.ts","../../src/app/services/generated/bmtaskService.ts","../../src/app/base64.ts","../../src/app/services/converters.ts","../../src/app/services/generated/creditService.ts","../../src/app/services/generated/outletcommunicationlogService.ts","../../src/app/ui/navigation/types.ts","../../src/app/services/generated/purchaseorderService.ts","../../src/app/services/generated/stocktakeService.ts","../../src/app/services/generated/ullageService.ts","../../src/app/services/generated/assemblyService.ts","../../src/app/services/generated/orderService.ts","../../src/components/pages/administration/user_roles/UserAccessHandler.ts","../../src/app/ui/navigation/contactsMenu.ts","../../src/app/ui/navigation/routeBuilder.ts","../../src/app/ui/navigation/pricingMenu.ts","../../src/app/services/generated/accountslinkService.ts","../../src/app/services/generated/bottledepositsettingsService.ts","../../src/app/services/generated/companysettingsService.ts","../../src/app/services/generated/deliverynotificationService.ts","../../src/app/services/generated/kegstarlinkService.ts","../../src/app/services/generated/tenantsettingsService.ts","../../src/store/modules/tenantStore.ts","../../src/app/featureFlags.ts","../../src/app/ui/navigation/productionMenu.ts","../../src/app/ui/navigation/salesMenu.ts","../../src/app/types/common/enumNoun.ts","../../src/app/ui/navigation/stockMenu.ts","../../src/app/services/generated/dutyrulesService.ts","../../src/app/services/generated/dutyService.ts","../../src/store/modules/dutyConfigurationStore.ts","../../src/components/pages/duty/composables/dutyConfiguration.ts","../../src/app/ui/navigation/ullagesMenu.ts","../../src/app/services/generated/outletService.ts","../../src/app/services/generated/itematlocationService.ts","../../src/app/services/extensions/orderServiceExtended.ts","../../src/app/services/generated/leadService.ts","../../src/app/services/generated/modifiedtypev1Service.ts","../../src/app/caching/apiCache.ts","../../src/app/services/generated/palletService.ts","../../src/app/ui/navigation/queryHelpers.ts","../../src/app/ui/navigation/distributionMenu.ts","../../src/app/services/generated/stocktransferService.ts","../../src/app/services/generated/stockadjustmentService.ts","../../src/app/services/generated/batchService.ts","../../src/app/ui/navigation/batchMenu.ts","../../src/app/services/generated/groupService.ts","../../src/app/caching/caches/groupsCache.ts","../../src/app/services/generated/itemService.ts","../../src/app/caching/caches/itemCache.ts","../../src/app/services/generated/credittermService.ts","../../src/app/caching/caches/creditTermsCache.ts","../../src/app/services/generated/deliveryareaService.ts","../../src/app/caching/caches/deliveryAreasCache.ts","../../src/app/services/generated/outletratingService.ts","../../src/app/caching/caches/outletRatingsCache.ts","../../src/app/services/generated/salesareaService.ts","../../src/app/caching/caches/salesAreasCache.ts","../../src/app/services/generated/salescodeService.ts","../../src/app/caching/caches/salesCodeCache.ts","../../src/app/services/generated/tasktypeService.ts","../../src/app/caching/caches/taskTypesCache.ts","../../src/app/services/generated/taskqueueService.ts","../../src/app/caching/caches/taskQueuesCache.ts","../../src/app/services/generated/unitofmeasureService.ts","../../src/app/caching/caches/unitsOfMeasureCache.ts","../../src/app/services/generated/packagetypeService.ts","../../src/app/services/extensions/packageTypeServiceExtended.ts","../../src/app/caching/caches/packageTypesCache.ts","../../src/app/services/extensions/outletServiceExtended.ts","../../src/app/caching/caches/outletSummariesCache.ts","../../src/app/services/generated/outlettypeService.ts","../../src/app/caching/caches/outletTypesCache.ts","../../src/app/services/generated/stocklocationService.ts","../../src/app/caching/caches/stockLocationsCache.ts","../../src/app/services/generated/vatcodeService.ts","../../src/app/caching/caches/vatCodesCache.ts","../../src/app/services/generated/courierService.ts","../../src/app/caching/caches/couriersCache.ts","../../src/app/services/generated/outletsubtypeService.ts","../../src/app/caching/caches/outletSubTypesCache.ts","../../src/app/services/generated/pricelistService.ts","../../src/app/caching/caches/priceListsCache.ts","../../src/app/caching/caches/leadsCache.ts","../../src/app/services/generated/pallettypeService.ts","../../src/app/caching/caches/palletTypesCache.ts","../../src/app/services/generated/vesselv2Service.ts","../../src/app/caching/caches/vesselsCache.ts","../../src/app/services/generated/vesseltypeService.ts","../../src/app/caching/caches/vesselTypesCache.ts","../../src/app/services/generated/vesselstateService.ts","../../src/app/caching/caches/vesselStatesCache.ts","../../src/app/services/generated/collectiontimeService.ts","../../src/app/caching/caches/collectionTimesCache.ts","../../src/app/services/generated/glcodeService.ts","../../src/app/caching/caches/glCodesCache.ts","../../src/app/services/generated/stockgroupService.ts","../../src/app/caching/caches/stockGroupsCache.ts","../../src/app/services/generated/pricingcategoryService.ts","../../src/app/caching/caches/pricingCategoriesCache.ts","../../src/app/caching/caches/supplierManufacturersCache.ts","../../src/app/services/generated/productbrandService.ts","../../src/app/caching/caches/productBrandsCache.ts","../../src/app/services/generated/recipev2Service.ts","../../src/app/caching/caches/recipesCache.ts","../../src/app/caching/buildCache.ts","../../src/components/pages/tasks/composables/taskAssociations.ts","../../node_modules/lodash-es/identity.js","../../node_modules/lodash-es/_baseCreate.js","../../node_modules/lodash-es/_copyArray.js","../../node_modules/lodash-es/_defineProperty.js","../../node_modules/lodash-es/_arrayEach.js","../../node_modules/lodash-es/_baseAssignValue.js","../../node_modules/lodash-es/_assignValue.js","../../node_modules/lodash-es/_copyObject.js","../../node_modules/lodash-es/_nativeKeysIn.js","../../node_modules/lodash-es/_baseKeysIn.js","../../node_modules/lodash-es/keysIn.js","../../node_modules/lodash-es/_getPrototype.js","../../node_modules/lodash-es/_baseAssign.js","../../node_modules/lodash-es/_baseAssignIn.js","../../node_modules/lodash-es/_cloneBuffer.js","../../node_modules/lodash-es/_copySymbols.js","../../node_modules/lodash-es/_getSymbolsIn.js","../../node_modules/lodash-es/_copySymbolsIn.js","../../node_modules/lodash-es/_getAllKeysIn.js","../../node_modules/lodash-es/_initCloneArray.js","../../node_modules/lodash-es/_cloneArrayBuffer.js","../../node_modules/lodash-es/_cloneDataView.js","../../node_modules/lodash-es/_cloneRegExp.js","../../node_modules/lodash-es/_cloneSymbol.js","../../node_modules/lodash-es/_cloneTypedArray.js","../../node_modules/lodash-es/_initCloneByTag.js","../../node_modules/lodash-es/_initCloneObject.js","../../node_modules/lodash-es/_baseIsMap.js","../../node_modules/lodash-es/isMap.js","../../node_modules/lodash-es/_baseIsSet.js","../../node_modules/lodash-es/isSet.js","../../node_modules/lodash-es/_baseClone.js","../../node_modules/lodash-es/cloneDeep.js","../../node_modules/lodash-es/cloneDeepWith.js","../../node_modules/lodash-es/_baseIsMatch.js","../../node_modules/lodash-es/_isStrictComparable.js","../../node_modules/lodash-es/_getMatchData.js","../../node_modules/lodash-es/_matchesStrictComparable.js","../../node_modules/lodash-es/_baseMatches.js","../../node_modules/lodash-es/_baseHasIn.js","../../node_modules/lodash-es/_hasPath.js","../../node_modules/lodash-es/hasIn.js","../../node_modules/lodash-es/_baseMatchesProperty.js","../../node_modules/lodash-es/_basePropertyDeep.js","../../node_modules/lodash-es/property.js","../../node_modules/lodash-es/_baseIteratee.js","../../node_modules/lodash-es/_arrayAggregator.js","../../node_modules/lodash-es/_createBaseFor.js","../../node_modules/lodash-es/_baseFor.js","../../node_modules/lodash-es/_baseForOwn.js","../../node_modules/lodash-es/_createBaseEach.js","../../node_modules/lodash-es/_baseEach.js","../../node_modules/lodash-es/_baseAggregator.js","../../node_modules/lodash-es/_createAggregator.js","../../node_modules/lodash-es/now.js","../../node_modules/lodash-es/debounce.js","../../node_modules/lodash-es/groupBy.js","../../src/components/composables/dataUtils.ts","../../src/app/services/generated/activitylogService.ts","../../src/components/pages/tasks/composables/tasks.ts","../../src/store/modules/tasksStore.ts","../../src/components/controls/tasks/TasksMenuItem.vue","../../src/app/ui/navigation/mainMenu.ts","../../src/app/services/generated/leadcommunicationlogService.ts","../../src/app/services/generated/communicationtypeService.ts","../../src/app/caching/caches/communicationTypesCache.ts","../../src/app/services/generated/communicationsubjectService.ts","../../src/app/caching/caches/communicationSubjectsCache.ts","../../src/components/pages/outlet/crm/subcomponents/activityLogEntryCard.ts","../../src/components/pages/production/assemblies/composables/enumOutputMovementType.ts","../../src/components/pages/production/vessels/enumVesselSummaryView.ts","../../src/app/services/generated/vesselmovementService.ts","../../src/components/pages/production/vessels/logs/composables/vesselMovementState.ts","../../src/components/pages/stock/costpriceupdater/enumCostPriceUpdateStrategyType.ts","../../src/components/pages/stock/stocktake/enumStockType.ts","../../src-da/state/companyFeaturesEnum.ts","../../src-da/state/daStopListTypes.ts","../../src/app/services/baseEnumType.ts","../../src/app/storageReplacerReviverUtils.ts","../../node_modules/vue-router/dist/vue-router.esm.js","../../src/app/ui/navigation/containerTrackingMenu.ts","../../src/app/ui/navigation/dutyMenuGerman.ts","../../src/app/ui/navigation/dutyMenuAustralian.ts","../../src/app/ui/navigation/dutyMenuSouthAfrican.ts","../../src/app/ui/navigation/dutyMenuUk.ts","../../src/app/ui/navigation/dutyMenuSwedish.ts","../../src/app/ui/navigation/dutyMenuUs.ts","../../src/app/ui/navigation/dutyMenuEire.ts","../../src/app/ui/navigation/dutyMenuNz.ts","../../src/app/ui/navigation/dutyMenu.ts","../../src/app/ui/navigation/reportingMenu.ts","../../src/assets/images/app/integrations/amazon_logo.png","../../src/app/services/generated/amazonsettingsService.ts","../../src/components/pages/integrations/amazon/integrationsAmazon.ts","../../src/app/ui/navigation/integrationsMenu.ts","../../src/app/ui/navigation/administrationMenu.ts","../../src/app/ui/navigation/supportMenu.ts","../../src/app/ui/navigation/galleryMenu.ts","../../src/app/ui/navigation/distributionAppMenu.ts","../../src/app/ui/navigation/accountManagement.ts","../../src/app/ui/navigation/unauthorisedMenu.ts","../../src/app/ui/navigation/multiTenantMenu.ts","../../src/app/ui/navigation/menuItems.ts","../../src/assets/images/banner.png","../../src/components/pages/NotFound.vue","../../src/components/dialogs/BmDialogControls.vue","../../src/components/mixins/dialogs.ts","../../src/components/mixins/validatable.ts","../../src/components/dialogs/BmDialog.vue","../../src/components/dialogs/BmConfirmationDialog.vue","../../src/components/dialogs/BmInformationDialog.vue","../../src/plugins/vueErrorHandler.ts","../../src/components/platform/common/showModalDialog.ts","../../src/components/pages/UnauthorisedComponent.vue","../../src/components/dialogs/BmUnauthorisedDialog.vue","../../src/components/composables/promptDialogs.ts","../../src/router/router.ts","../../src/components/controls/input/state/BmUIStateRepository.ts","../../src/components/controls/card/BmCollapsibleCard.vue","../../src/components/controls/card/BmEditCard.vue","../../src/components/controls/card/BmCardSubtitle.vue","../../src/components/controls/subpage/BmSubpageHeading.vue","../../src/components/controls/subpage/BmSubpageDescription.vue","../../src/components/controls/BmField.vue","../../src/components/controls/BmFieldList.vue","../../src/components/controls/app/BmBreadcrumbs.vue","../../src/components/pages/BmPage.vue","../../src/components/pages/BmPageFooter.vue","../../node_modules/lodash/lodash.js","../../src/components/controls/grid/renderers/rendererUtilities.ts","../../src/components/controls/grid/renderers/DataCellText.vue","../../src/components/controls/grid/BmGridComparers.ts","../../src/components/controls/grid/BmGridMatchers.ts","../../src/components/controls/grid/BmGridAggregators.ts","../../src/components/controls/grid/state/BmGridState.ts","../../src/components/controls/grid/state/BmGridStateRepository.ts","../../src/components/controls/grid/BmGridData.ts","../../src/components/controls/input/BmBtnExpand.vue","../../node_modules/reflect-metadata/Reflect.js","../../node_modules/vue-class-component/dist/vue-class-component.esm.js","../../node_modules/vue-easy-dnd/node_modules/vue-property-decorator/lib/vue-property-decorator.js","../../node_modules/vue-easy-dnd/dist/vue-easy-dnd.esm.js","../../src/app/services/generated/documentgenerationService.ts","../../node_modules/vue-property-decorator/lib/decorators/Emit.js","../../node_modules/vue-property-decorator/lib/helpers/metadata.js","../../node_modules/vue-property-decorator/lib/decorators/Prop.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/generic.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/columns/columnKeyCreator.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/object.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/function.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/context/context.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/eventService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/constants/constants.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/modules/moduleNames.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/modules/moduleRegistry.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/entities/column.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/array.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/entities/columnGroup.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/entities/providedColumnGroup.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/entities/defaultColumnTypes.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/event.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/context/beanStub.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/columns/columnFactory.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/eventKeys.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/columns/groupInstanceIdCreator.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/string.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/map.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/components/colDefUtil.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/propertyKeys.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/components/componentUtil.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/entities/sideBar.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/browser.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/fuzzyMatch.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/number.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridOptionsWrapper.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/columns/columnModel.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/columns/columnUtils.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/columns/displayedGroupCreator.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/components/agStackComponentsRegistry.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/color.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/csv.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/dom.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/general.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/aria.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/date.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/icon.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/constants/keyCode.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/keyboard.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/mouse.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/rowNode.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/set.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/utils.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/numberSequence.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/promise.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/customTooltipFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/cssClassManager.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/component.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/componentAnnotations.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/filter/floating/provided/readOnlyFloatingFilter.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/filter/provided/date/dateCompWrapper.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/filter/provided/optionsFactory.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/filter/filterLocaleText.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/managedFocusFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/filter/provided/providedFilter.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agAbstractLabel.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agAbstractField.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agPickerField.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agList.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agSelect.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agAbstractInputField.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/filter/provided/simpleFilter.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/filter/provided/scalarFilter.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/filter/provided/date/dateFilter.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/filter/floating/provided/simpleFloatingFilter.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/filter/provided/date/dateFloatingFilter.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/filter/provided/date/defaultDateComponent.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/filter/provided/number/numberFilter.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/filter/provided/text/textFilter.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/filter/floating/provided/textInputFloatingFilter.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/filter/provided/number/numberFloatingFilter.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/filter/provided/text/textFloatingFilter.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/touchListener.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/cells/column/sortIndicatorComp.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/cells/column/headerComp.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/cells/columnGroup/headerGroupComp.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/popupComponent.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/cellEditors/largeTextCellEditor.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/cellEditors/selectCellEditor.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/cellEditors/popupSelectCellEditor.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/cellEditors/textCellEditor.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/cellEditors/popupTextCellEditor.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/cellRenderers/animateShowChangeCellRenderer.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/cellRenderers/animateSlideCellRenderer.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/entities/rowNode.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/checkboxSelectionComponent.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/dragAndDrop/dragAndDropService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/row/rowDragComp.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/cellRenderers/groupCellRendererCtrl.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/cellRenderers/groupCellRenderer.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/cellRenderers/loadingCellRenderer.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/overlays/loadingOverlayComponent.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/overlays/noRowsOverlayComponent.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/tooltipComponent.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/components/framework/userComponentRegistry.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/components/framework/componentTypes.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/filter/floating/floatingFilterMapper.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/components/framework/userComponentFactory.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/interfaces/iExcelCreator.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/dragAndDrop/dragService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/filter/filterManager.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/cells/abstractCell/abstractHeaderCellComp.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/cells/floatingFilter/headerFilterCellComp.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/styling/layoutFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridBodyComp/gridBodyScrollFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/autoScrollService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridBodyComp/rowDragFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridBodyComp/gridBodyCtrl.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/interfaces/IRangeService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/cell/cellRangeFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/cell/cellPositionFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/cell/cellCustomStyleFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/tooltipFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/beans.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/cell/cellMouseListenerFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/cell/cellKeyboardListenerFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/dndSourceComp.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/cell/cellCtrl.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/row/rowCtrl.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridBodyComp/rowContainer/rowContainerEventsFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridBodyComp/viewportSizeFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridBodyComp/rowContainer/setPinnedLeftWidthFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridBodyComp/rowContainer/setPinnedRightWidthFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridBodyComp/rowContainer/setHeightFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridBodyComp/rowContainer/dragListenerFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridBodyComp/centerWidthFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridBodyComp/rowContainer/rowContainerCtrl.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridBodyComp/gridBodyComp.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridBodyComp/scrollVisibleService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridBodyComp/mouseEventService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridBodyComp/navigationService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/cellEditors/popupEditorWrapper.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/cell/cellComp.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/row/rowComp.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridBodyComp/rowContainer/rowContainerComp.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/columnDrag/bodyDropPivotTarget.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/columnDrag/moveColumnFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/columnDrag/bodyDropTarget.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/cells/cssClassApplier.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/cells/column/headerCellComp.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/cells/columnGroup/headerGroupCellComp.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/row/headerRowComp.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/cells/abstractCell/abstractHeaderCellCtrl.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/interfaces/iClientSideRowModel.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridApi.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/features/setLeftFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/cells/hoverFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/cells/floatingFilter/headerFilterCellCtrl.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/cells/column/resizeFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agCheckbox.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/cells/column/selectAllFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/cells/column/headerCellCtrl.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/cells/columnGroup/groupResizeFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/cells/columnGroup/groupWidthFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/cells/columnGroup/headerGroupCellCtrl.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/row/headerRowCtrl.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/rowContainer/headerRowContainerCtrl.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/rowContainer/headerRowContainerComp.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/common/headerNavigationService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/gridHeaderCtrl.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/gridHeaderComp.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/common/horizontalResizeService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/cells/column/standardMenu.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/layout/tabbedLayout.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/misc/resizeObserverService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/misc/animationFrameService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/features/positionableFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/autoWidthCalculator.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/features/stickyRowFeature.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/rowRenderer.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/valueFormatterService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/pinnedRowModel/pinnedRowModel.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/interfaces/serverSideTransaction.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/utils/changedPath.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rowNodeCache/rowNodeBlock.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rowNodeCache/rowNodeBlockLoader.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/pagination/paginationProxy.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/styling/stylingService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agRadioButton.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agToggleButton.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agInputTextField.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agInputTextArea.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agInputNumberField.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agInputRange.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agSlider.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agAngleSelect.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agColorPanel.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agPanel.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agDialog.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agColorPicker.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agGroupComponent.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/tabGuardCtrl.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/tabGuardComp.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agMenuList.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agMenuPanel.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/agMenuItemComponent.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/focusService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/popupService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/widgets/virtualList.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/vanillaFrameworkOverrides.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/cellNavigationService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/alignedGridsService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/selectionService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/columns/columnApi.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/valueService/valueService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/valueService/expressionService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/templateService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/logger.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridComp/gridCtrl.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridComp/gridComp.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/sortController.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/columnHoverService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/columnAnimationService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/columns/autoGroupColService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/pagination/paginationAutoPageSizeService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/valueService/valueCache.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/valueService/changeDetectionService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/components/framework/agComponentUtils.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/components/framework/componentMetadataProvider.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/environment.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/rowContainerHeightService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rowNodes/selectableService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/pagination/paginationComp.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/overlays/overlayWrapperComponent.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/entities/rowPosition.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/entities/cellPosition.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/undoRedo/undoRedoStack.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/undoRedo/undoRedoService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/headerRendering/common/headerPosition.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/columns/columnDefFactory.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rendering/row/rowCssClassCalculator.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/rowNodes/rowNodeSorter.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/ctrlsService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/ctrlsFactory.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridBodyComp/fakeHScrollCtrl.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridBodyComp/fakeHScrollComp.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/gridBodyComp/pinnedWidthService.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/entities/rowNodeEventThrottle.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/grid.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/components/framework/frameworkComponentWrapper.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/interfaces/iSparklineCellRendererParams.js","../../node_modules/@ag-grid-community/core/dist/esm/es5/main.js","../../node_modules/@ag-grid-community/vue/lib/VueComponentFactory.js","../../node_modules/@ag-grid-community/vue/lib/VueFrameworkComponentWrapper.js","../../node_modules/@ag-grid-community/vue/lib/Utils.js","../../node_modules/@ag-grid-community/vue/lib/AgGridColumn.js","../../node_modules/@ag-grid-community/vue/lib/VueFrameworkOverrides.js","../../node_modules/@ag-grid-community/vue/lib/AgGridVue.js","../../node_modules/@ag-grid-community/vue/main.js","../../node_modules/@ag-grid-community/client-side-row-model/dist/esm/es5/clientSideRowModel/clientSideNodeManager.js","../../node_modules/@ag-grid-community/client-side-row-model/dist/esm/es5/clientSideRowModel/clientSideRowModel.js","../../node_modules/@ag-grid-community/client-side-row-model/dist/esm/es5/clientSideRowModel/filterStage.js","../../node_modules/@ag-grid-community/client-side-row-model/dist/esm/es5/clientSideRowModel/sortStage.js","../../node_modules/@ag-grid-community/client-side-row-model/dist/esm/es5/clientSideRowModel/flattenStage.js","../../node_modules/@ag-grid-community/client-side-row-model/dist/esm/es5/clientSideRowModel/sortService.js","../../node_modules/@ag-grid-community/client-side-row-model/dist/esm/es5/clientSideRowModel/filterService.js","../../node_modules/@ag-grid-community/client-side-row-model/dist/esm/es5/clientSideRowModel/immutableService.js","../../node_modules/@ag-grid-community/client-side-row-model/dist/esm/es5/clientSideRowModelModule.js","../../src/components/controls/grid/BmGridCellRendererWrapper.ts","../../src/components/composables/mediaPrintingEvents.ts","../../src/app/ui/utilities.ts","../../node_modules/@ag-grid-enterprise/core/dist/esm/es5/licenseManager.js","../../node_modules/@ag-grid-enterprise/core/dist/esm/es5/license/md5.js","../../node_modules/@ag-grid-enterprise/core/dist/esm/es5/license/watermark.js","../../node_modules/@ag-grid-enterprise/core/dist/esm/es5/agGridEnterpriseModule.js","../../node_modules/@ag-grid-enterprise/row-grouping/dist/esm/es5/rowGrouping/aggregationStage.js","../../node_modules/@ag-grid-enterprise/row-grouping/dist/esm/es5/rowGrouping/batchRemover.js","../../node_modules/@ag-grid-enterprise/row-grouping/dist/esm/es5/rowGrouping/groupStage.js","../../node_modules/@ag-grid-enterprise/row-grouping/dist/esm/es5/rowGrouping/pivotColDefService.js","../../node_modules/@ag-grid-enterprise/row-grouping/dist/esm/es5/rowGrouping/pivotStage.js","../../node_modules/@ag-grid-enterprise/row-grouping/dist/esm/es5/rowGrouping/aggFuncService.js","../../node_modules/@ag-grid-enterprise/row-grouping/dist/esm/es5/rowGrouping/columnDropZones/dropZoneColumnComp.js","../../node_modules/@ag-grid-enterprise/row-grouping/dist/esm/es5/rowGrouping/columnDropZones/baseDropZonePanel.js","../../node_modules/@ag-grid-enterprise/row-grouping/dist/esm/es5/rowGrouping/columnDropZones/rowGroupDropZonePanel.js","../../node_modules/@ag-grid-enterprise/row-grouping/dist/esm/es5/rowGrouping/columnDropZones/pivotDropZonePanel.js","../../node_modules/@ag-grid-enterprise/row-grouping/dist/esm/es5/rowGrouping/columnDropZones/gridHeaderDropZones.js","../../node_modules/@ag-grid-enterprise/row-grouping/dist/esm/es5/rowGrouping/filterAggregatesStage.js","../../node_modules/@ag-grid-enterprise/row-grouping/dist/esm/es5/rowGroupingModule.js","../../node_modules/@ag-grid-enterprise/row-grouping/dist/esm/es5/rowGrouping/columnDropZones/valueDropZonePanel.js","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/generic.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/columns/columnKeyCreator.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/object.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/function.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/modules/moduleNames.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/modules/moduleRegistry.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/context/context.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/eventService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/entities/column.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/entities/providedColumnGroup.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/entities/defaultColumnTypes.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/array.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/event.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/context/beanStub.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/columns/columnFactory.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/entities/columnGroup.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/eventKeys.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/columns/groupInstanceIdCreator.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/columns/autoGroupColService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/string.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/map.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/components/colDefUtil.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/propertyKeys.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/components/componentUtil.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/fuzzyMatch.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridOptionsValidator.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/columns/columnModel.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/columns/columnUtils.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/columns/displayedGroupCreator.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/components/agStackComponentsRegistry.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/aria.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/browser.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/number.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/date.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/dom.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/icon.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/constants/keyCode.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/keyboard.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/mouse.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/rowNode.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/set.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/utils.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/numberSequence.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/promise.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/customTooltipFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cssClassManager.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/component.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/componentAnnotations.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/filter/floating/provided/readOnlyFloatingFilter.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/filter/provided/date/dateCompWrapper.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/filter/provided/optionsFactory.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/filter/filterLocaleText.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/managedFocusFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/features/positionableFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/filter/provided/providedFilter.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agAbstractLabel.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agAbstractField.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agPickerField.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agList.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agSelect.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agAbstractInputField.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agCheckbox.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agRadioButton.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/filter/provided/simpleFilter.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/filter/provided/scalarFilter.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/filter/provided/date/dateFilter.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/filter/floating/provided/simpleFloatingFilter.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/filter/provided/date/dateFloatingFilter.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/filter/provided/date/defaultDateComponent.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agInputTextField.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agInputNumberField.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/filter/provided/number/numberFilter.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/filter/provided/text/textFilter.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/filter/floating/provided/textInputFloatingFilter.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/filter/provided/number/numberFloatingFilter.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/filter/provided/text/textFloatingFilter.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/touchListener.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/cells/column/sortIndicatorComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/cells/column/headerComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/cells/columnGroup/headerGroupComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/popupComponent.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cellEditors/largeTextCellEditor.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cellEditors/selectCellEditor.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cellEditors/simpleCellEditor.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cellEditors/textCellEditor.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cellRenderers/animateShowChangeCellRenderer.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cellRenderers/animateSlideCellRenderer.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/entities/rowNode.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/checkboxSelectionComponent.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/dragAndDrop/dragAndDropService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/row/rowDragComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cellRenderers/groupCellRendererCtrl.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cellRenderers/groupCellRenderer.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cellRenderers/loadingCellRenderer.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/overlays/loadingOverlayComponent.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/overlays/noRowsOverlayComponent.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/tooltipComponent.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cellEditors/numberCellEditor.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cellEditors/dateCellEditor.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cellEditors/dateStringCellEditor.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cellRenderers/checkboxCellRenderer.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cellEditors/checkboxCellEditor.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/components/framework/userComponentRegistry.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/components/framework/componentTypes.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/filter/floating/floatingFilterMapper.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/components/framework/userComponentFactory.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/interfaces/iExcelCreator.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/dragAndDrop/dragService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/autoScrollService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/dragAndDrop/virtualListDragFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/interfaces/iRowNode.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/interfaces/iClientSideRowModel.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridApi.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/filter/quickFilterService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/filter/filterManager.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/cells/abstractCell/abstractHeaderCellComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/cells/floatingFilter/headerFilterCellComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/styling/layoutFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridBodyComp/gridBodyScrollFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridBodyComp/rowDragFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridBodyComp/gridBodyCtrl.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/interfaces/IRangeService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cell/cellRangeFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cell/cellPositionFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cell/cellCustomStyleFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/tooltipFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/beans.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cell/cellMouseListenerFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cell/cellKeyboardListenerFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/dndSourceComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cell/cellCtrl.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/row/rowCtrl.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridBodyComp/rowContainer/rowContainerEventsFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridBodyComp/viewportSizeFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridBodyComp/rowContainer/setPinnedLeftWidthFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridBodyComp/rowContainer/setPinnedRightWidthFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridBodyComp/rowContainer/setHeightFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridBodyComp/rowContainer/dragListenerFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridBodyComp/centerWidthFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridBodyComp/rowContainer/rowContainerCtrl.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridBodyComp/gridBodyComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridBodyComp/scrollVisibleService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridBodyComp/mouseEventService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridBodyComp/navigationService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cellEditors/popupEditorWrapper.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/cell/cellComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/row/rowComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridBodyComp/rowContainer/rowContainerComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/columnDrag/bodyDropPivotTarget.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/columnDrag/moveColumnFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/columnDrag/bodyDropTarget.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/cells/cssClassApplier.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/cells/column/headerCellComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/cells/columnGroup/headerGroupCellComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/row/headerRowComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/cells/abstractCell/abstractHeaderCellCtrl.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/features/setLeftFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/cells/hoverFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/cells/floatingFilter/headerFilterCellCtrl.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/cells/column/resizeFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/cells/column/selectAllFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/tabGuardCtrl.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/focusService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/cells/column/headerCellCtrl.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/cells/columnGroup/groupResizeFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/cells/columnGroup/groupWidthFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/cells/columnGroup/headerGroupCellCtrl.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/row/headerRowCtrl.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/rowContainer/headerRowContainerCtrl.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/rowContainer/headerRowContainerComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/common/headerNavigationService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/gridHeaderCtrl.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/gridHeaderComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/common/horizontalResizeService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/cells/column/standardMenu.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/layout/tabbedLayout.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/misc/resizeObserverService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/misc/animationFrameService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/autoWidthCalculator.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/features/stickyRowFeature.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/rowRenderer.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/valueFormatterService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/pinnedRowModel/pinnedRowModel.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/interfaces/serverSideTransaction.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/utils/changedPath.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rowNodeCache/rowNodeBlock.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rowNodeCache/rowNodeBlockLoader.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/pagination/paginationProxy.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/styling/stylingService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agToggleButton.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agInputTextArea.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agInputDateField.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agInputRange.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agRichSelectRow.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/tabGuardComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/virtualList.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agRichSelect.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agSlider.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agGroupComponent.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agMenuList.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agMenuPanel.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agMenuItemComponent.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agPanel.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agDialog.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/popupService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agAutocompleteRow.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agAutocompleteList.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/widgets/agAutocomplete.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/vanillaFrameworkOverrides.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/cellNavigationService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/alignedGridsService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/selectionService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/columns/columnApi.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/valueService/valueService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/valueService/expressionService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/templateService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/logger.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridComp/gridCtrl.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridComp/gridComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/sortController.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/columnHoverService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/columnAnimationService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/pagination/paginationAutoPageSizeService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/valueService/valueCache.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/valueService/changeDetectionService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/components/framework/agComponentUtils.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/components/framework/componentMetadataProvider.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/environment.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/rowContainerHeightService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rowNodes/selectableService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/pagination/paginationComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/overlays/overlayWrapperComponent.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/entities/rowPositionUtils.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/entities/cellPositionUtils.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/undoRedo/undoRedoStack.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/undoRedo/undoRedoService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/headerRendering/common/headerPosition.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/columns/columnDefFactory.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rendering/row/rowCssClassCalculator.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/rowNodes/rowNodeSorter.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/ctrlsService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/ctrlsFactory.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridBodyComp/abstractFakeScrollComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridBodyComp/fakeHScrollComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridBodyComp/pinnedWidthService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/entities/rowNodeEventThrottle.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridOptionsService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/localeService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/gridBodyComp/fakeVScrollComp.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/columns/dataTypeService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/valueService/valueParserService.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/grid.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/interfaces/iSparklineCellRendererParams.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-community/core/dist/esm/es6/main.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-enterprise/core/dist/esm/es6/license/shared/md5.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-enterprise/core/dist/esm/es6/license/shared/licenseManager.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-enterprise/core/dist/esm/es6/license/gridLicenseManager.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-enterprise/core/dist/esm/es6/license/watermark.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-enterprise/core/dist/esm/es6/version.mjs","../../node_modules/@ag-grid-enterprise/master-detail/node_modules/@ag-grid-enterprise/core/dist/esm/es6/agGridEnterpriseModule.mjs","../../node_modules/@ag-grid-enterprise/master-detail/dist/esm/es6/masterDetail/detailCellRendererCtrl.mjs","../../node_modules/@ag-grid-enterprise/master-detail/dist/esm/es6/masterDetail/detailCellRenderer.mjs","../../node_modules/@ag-grid-enterprise/master-detail/dist/esm/es6/version.mjs","../../node_modules/@ag-grid-enterprise/master-detail/dist/esm/es6/masterDetailModule.mjs","../../src/components/controls/grid/DetailCellRendererWrapper.ts","../../src/components/controls/grid/AgGrid.ts","../../src/components/controls/grid/BmGrid.vue","../../src/components/controls/grid/renderers/DataCellActions.vue","../../src/components/controls/grid/renderers/DataCellControl.vue","../../src/components/controls/grid/columnfilters/ColumnFilterComponent.vue","../../src/components/controls/grid/columnfilters/ColumnFilters.ts","../../src/components/controls/grid/columnfilters/NumberColumnFilter.ts","../../src/components/controls/grid/renderers/info/DataCellInfoDialog.vue","../../src/components/controls/grid/renderers/info/DataCellTextInfo.vue","../../src/components/controls/grid/builder/ColumnBuilders.ts","../../src/components/controls/grid/builder/SummaryBuilders.ts","../../src/components/controls/grid/renderers/DataCellIcon.vue","../../src/components/controls/grid/columnfilters/TextColumnFilter.ts","../../src/components/controls/grid/columnfilters/DateColumnFilter.ts","../../src/components/controls/grid/columnfilters/DateTimeColumnFilter.ts","../../src/components/controls/grid/columnfilters/EnumColumnFilter.ts","../../src/components/controls/grid/columnfilters/BooleanColumnFilter.ts","../../src/components/controls/grid/renderers/DataCellBoolean.vue","../../src/components/controls/grid/builder/GridConfigurationBuilder.ts","../../src/components/controls/grid/renderers/editors/DataCellEditDialog.vue","../../src/components/controls/grid/renderers/editors/DataCellNumberEdit.vue","../../src/components/platform/common/configurationUtils.ts","../../src/components/composables/dragDropUtils.ts","../../src/components/controls/quantitygrid/BmQuantityGrid.vue","../../src/components/controls/controllist/BmControlList.vue","../../src/app/services/dirtyChecker.ts","../../src/components/controls/editbox/BmEditBox.vue","../../src/app/services/generated/fileService.ts","../../src/app/imageUtils.ts","../../src/components/controls/input/BmImageUploaderById.vue","../../src/components/controls/listselector/BmList.vue","../../src/components/controls/listselector/BmListSelector.vue","../../src/components/controls/tabs/BmTabs.vue","../../src/components/controls/wizard/BmColumnHint.vue","../../src/components/controls/wizard/WizardEvents.ts","../../src/store/modules/wizardStore.ts","../../src/components/controls/wizard/BmWizard.vue","../../src/components/controls/wizard/BmWizardFooter.vue","../../src/components/controls/wizard/BmWizardFormElement.vue","../../src/components/platform/hybrid/forms.ts","../../src/components/controls/BmForm.vue","../../src/components/controls/wizard/BmWizardStep.vue","../../src/components/controls/BmAlert.vue","../../src/components/pages/BmPageStatusSelect.vue","../../src/components/controls/grid/BmGridControlPanel.vue","../../src/app/ui/colourUtils.ts","../../src/components/controls/map/maps.ts","../../node_modules/fast-deep-equal/index.js","../../node_modules/kdbush/index.js","../../node_modules/supercluster/index.js","../../node_modules/@googlemaps/markerclusterer/dist/index.esm.js","../../src/components/controls/map/BmMapLoader.vue","../../src/components/pages/BmGridPage.vue","../../src/components/controls/input/specialised/BmCurrency.vue","../../src/components/controls/input/specialised/BmUnitBase.vue","../../src/components/controls/input/specialised/BmVolumeGeneral.vue","../../src/components/controls/input/specialised/BmVolumeVessels.vue","../../src/components/controls/input/specialised/BmWeight.vue","../../src/components/controls/input/specialised/BmPercentage.vue","../../src/components/controls/input/specialised/BmAlcoholContent.vue","../../src/components/dialogs/BmBottomSheet.vue","../../node_modules/diacritics/index.js","../../node_modules/i18n-iso-countries/index.js","../../src/plugins/i18nCountries.ts","../../src/components/controls/input/specialised/BmCountry.vue","../../src/components/controls/input/specialised/BmTelephone.vue","../../src/components/controls/BmChip.vue","../../node_modules/html5-qrcode/esm/core.js","../../node_modules/html5-qrcode/esm/strings.js","../../node_modules/html5-qrcode/esm/utils.js","../../node_modules/html5-qrcode/third_party/zxing-js.umd.js","../../node_modules/html5-qrcode/esm/zxing-html5-qrcode-decoder.js","../../node_modules/html5-qrcode/esm/native-bar-code-detector.js","../../node_modules/html5-qrcode/esm/code-decoder.js","../../node_modules/html5-qrcode/esm/camera/core-impl.js","../../node_modules/html5-qrcode/esm/camera/factories.js","../../node_modules/html5-qrcode/esm/camera/retriever.js","../../node_modules/html5-qrcode/esm/state-manager.js","../../node_modules/html5-qrcode/esm/html5-qrcode.js","../../node_modules/html5-qrcode/esm/camera/permissions.js","../../node_modules/html5-qrcode/esm/ui/scanner/torch-button.js","../../node_modules/html5-qrcode/esm/html5-qrcode-scanner.js","../../src/components/controls/device/barcodes/Html5QrStream.vue","../../src/components/controls/device/barcodes/BarcodeScannerErrorDialog.vue","../../src/assets/sounds/barcodeSounds.ts","../../src/components/controls/device/barcodes/BarcodeScanner2d.vue","../../src/components/controls/device/barcodes/BmBarcodeCamera.vue","../../src/components/controls/device/barcodes/BmBarcodeLaser.vue","../../src/components/controls/device/barcodes/BmBarcodeTextInput.vue","../../src/components/controls/device/BmBarcodeInput.vue","../../src/components/controls/input/specialised/BmSignature.vue","../../src/components/controls/input/specialised/BmPlato.vue","../../src/components/controls/timeline/BmTimeline.vue","../../src/components/controls/input/BmColourPicker.vue","../../src/components/controls/input/specialised/BmEmail.vue","../../src/components/composables/unique.ts","../../src/components/controls/input/BmBtnDropdown.vue","../../src/components/platform/components/buttonbar/buttonBarConfiguration.ts","../../src/components/platform/common/displayText.ts","../../src/components/platform/common/labelling.ts","../../src/components/platform/components/form/controlConfiguration.ts","../../src/components/platform/components/buttonbar/buttonBar.ts","../../src-da/components/controls/DaNumber.vue","../../src/components/controls/BmFormFlowLayout.vue","../../src/plugins/registerComponents.ts","../../src/plugins/vuetify.ts","../../src/plugins/googleApis.ts","../../src/app/services/generated/visitService.ts","../../src/app/services/generated/journeyv1Service.ts","../../src/app/services/extensions/journeyServiceExtended.ts","../../src/components/controls/address/addresses.ts","../../src/controls/control.ts","../../src/controls/tpcontrol.ts","../../src/app/useLoadingState.ts","../../src/app/services/generated/containerService.ts","../../src/app/services/extensions/containerServiceExtended.ts","../../src/app/services/generated/productbatchService.ts","../../src/components/pages/productionv1/assemblies/dialogs/ScanContainersDialog.vue","../../src/components/mixins/BmLeaveConfirmation.ts","../../src/components/pages/containers/composables/scanContainers.ts","../../src-da/components/mixins/BmExternalLinks.ts","../../src/assets/images/brewman_white.png","../../src/components/dialogs/BmLoader.vue","../../src/components/dialogs/BmErrorDialog.vue","../../src/components/controls/app/BmFooter.vue","../../src/components/controls/snackbar/BmQueuedSnackbar.vue","../../src/app/apiInterceptors.ts"],"sourcesContent":["//! @version @js-joda/core - 3.2.0\n//! @copyright (c) 2015-present, Philipp Thürwächter, Pattrick Hüper & js-joda contributors\n//! @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n//! @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n\n/**\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nfunction createErrorType(name, init, superErrorClass) {\n if (superErrorClass === void 0) {\n superErrorClass = Error;\n }\n\n function JsJodaException(message) {\n if (!Error.captureStackTrace) {\n this.stack = new Error().stack;\n } else {\n Error.captureStackTrace(this, this.constructor);\n }\n\n this.message = message;\n init && init.apply(this, arguments);\n\n this.toString = function () {\n return this.name + \": \" + this.message;\n };\n }\n\n JsJodaException.prototype = Object.create(superErrorClass.prototype);\n JsJodaException.prototype.name = name;\n JsJodaException.prototype.constructor = JsJodaException;\n return JsJodaException;\n}\n\nvar DateTimeException = createErrorType('DateTimeException', messageWithCause);\nvar DateTimeParseException = createErrorType('DateTimeParseException', messageForDateTimeParseException);\nvar UnsupportedTemporalTypeException = createErrorType('UnsupportedTemporalTypeException', null, DateTimeException);\nvar ArithmeticException = createErrorType('ArithmeticException');\nvar IllegalArgumentException = createErrorType('IllegalArgumentException');\nvar IllegalStateException = createErrorType('IllegalStateException');\nvar NullPointerException = createErrorType('NullPointerException');\n\nfunction messageWithCause(message, cause) {\n if (cause === void 0) {\n cause = null;\n }\n\n var msg = message || this.name;\n\n if (cause !== null && cause instanceof Error) {\n msg += '\\n-------\\nCaused by: ' + cause.stack + '\\n-------\\n';\n }\n\n this.message = msg;\n}\n\nfunction messageForDateTimeParseException(message, text, index, cause) {\n if (text === void 0) {\n text = '';\n }\n\n if (index === void 0) {\n index = 0;\n }\n\n if (cause === void 0) {\n cause = null;\n }\n\n var msg = message || this.name;\n msg += ': ' + text + ', at index: ' + index;\n\n if (cause !== null && cause instanceof Error) {\n msg += '\\n-------\\nCaused by: ' + cause.stack + '\\n-------\\n';\n }\n\n this.message = msg;\n\n this.parsedString = function () {\n return text;\n };\n\n this.errorIndex = function () {\n return index;\n };\n}\n\nfunction _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n subClass.__proto__ = superClass;\n}\n\nfunction _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}\n\n/**\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nfunction assert(assertion, msg, error) {\n if (!assertion) {\n if (error) {\n throw new error(msg);\n } else {\n throw new Error(msg);\n }\n }\n}\nfunction requireNonNull(value, parameterName) {\n if (value == null) {\n throw new NullPointerException(parameterName + ' must not be null');\n }\n\n return value;\n}\nfunction requireInstance(value, _class, parameterName) {\n if (!(value instanceof _class)) {\n throw new IllegalArgumentException(parameterName + ' must be an instance of ' + (_class.name ? _class.name : _class) + (value && value.constructor && value.constructor.name ? ', but is ' + value.constructor.name : ''));\n }\n\n return value;\n}\nfunction abstractMethodFail(methodName) {\n throw new TypeError('abstract method \"' + methodName + '\" is not implemented');\n}\n\nvar assert$1 = /*#__PURE__*/Object.freeze({\n __proto__: null,\n assert: assert,\n requireNonNull: requireNonNull,\n requireInstance: requireInstance,\n abstractMethodFail: abstractMethodFail\n});\n\n/**\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar MAX_SAFE_INTEGER = 9007199254740991;\nvar MIN_SAFE_INTEGER = -9007199254740991;\nvar MathUtil = function () {\n function MathUtil() {}\n\n MathUtil.intDiv = function intDiv(x, y) {\n var r = x / y;\n r = MathUtil.roundDown(r);\n return MathUtil.safeZero(r);\n };\n\n MathUtil.intMod = function intMod(x, y) {\n var r = x - MathUtil.intDiv(x, y) * y;\n r = MathUtil.roundDown(r);\n return MathUtil.safeZero(r);\n };\n\n MathUtil.roundDown = function roundDown(r) {\n if (r < 0) {\n return Math.ceil(r);\n } else {\n return Math.floor(r);\n }\n };\n\n MathUtil.floorDiv = function floorDiv(x, y) {\n var r = Math.floor(x / y);\n return MathUtil.safeZero(r);\n };\n\n MathUtil.floorMod = function floorMod(x, y) {\n var r = x - MathUtil.floorDiv(x, y) * y;\n return MathUtil.safeZero(r);\n };\n\n MathUtil.safeAdd = function safeAdd(x, y) {\n MathUtil.verifyInt(x);\n MathUtil.verifyInt(y);\n\n if (x === 0) {\n return MathUtil.safeZero(y);\n }\n\n if (y === 0) {\n return MathUtil.safeZero(x);\n }\n\n var r = MathUtil.safeToInt(x + y);\n\n if (r === x || r === y) {\n throw new ArithmeticException('Invalid addition beyond MAX_SAFE_INTEGER!');\n }\n\n return r;\n };\n\n MathUtil.safeSubtract = function safeSubtract(x, y) {\n MathUtil.verifyInt(x);\n MathUtil.verifyInt(y);\n\n if (x === 0 && y === 0) {\n return 0;\n } else if (x === 0) {\n return MathUtil.safeZero(-1 * y);\n } else if (y === 0) {\n return MathUtil.safeZero(x);\n }\n\n return MathUtil.safeToInt(x - y);\n };\n\n MathUtil.safeMultiply = function safeMultiply(x, y) {\n MathUtil.verifyInt(x);\n MathUtil.verifyInt(y);\n\n if (x === 1) {\n return MathUtil.safeZero(y);\n }\n\n if (y === 1) {\n return MathUtil.safeZero(x);\n }\n\n if (x === 0 || y === 0) {\n return 0;\n }\n\n var r = MathUtil.safeToInt(x * y);\n\n if (r / y !== x || x === MIN_SAFE_INTEGER && y === -1 || y === MIN_SAFE_INTEGER && x === -1) {\n throw new ArithmeticException('Multiplication overflows: ' + x + ' * ' + y);\n }\n\n return r;\n };\n\n MathUtil.parseInt = function (_parseInt) {\n function parseInt(_x) {\n return _parseInt.apply(this, arguments);\n }\n\n parseInt.toString = function () {\n return _parseInt.toString();\n };\n\n return parseInt;\n }(function (value) {\n var r = parseInt(value);\n return MathUtil.safeToInt(r);\n });\n\n MathUtil.safeToInt = function safeToInt(value) {\n MathUtil.verifyInt(value);\n return MathUtil.safeZero(value);\n };\n\n MathUtil.verifyInt = function verifyInt(value) {\n if (value == null) {\n throw new ArithmeticException(\"Invalid value: '\" + value + \"', using null or undefined as argument\");\n }\n\n if (isNaN(value)) {\n throw new ArithmeticException('Invalid int value, using NaN as argument');\n }\n\n if (value % 1 !== 0) {\n throw new ArithmeticException(\"Invalid value: '\" + value + \"' is a float\");\n }\n\n if (value > MAX_SAFE_INTEGER || value < MIN_SAFE_INTEGER) {\n throw new ArithmeticException('Calculation overflows an int: ' + value);\n }\n };\n\n MathUtil.safeZero = function safeZero(value) {\n return value === 0 ? 0 : +value;\n };\n\n MathUtil.compareNumbers = function compareNumbers(a, b) {\n if (a < b) {\n return -1;\n }\n\n if (a > b) {\n return 1;\n }\n\n return 0;\n };\n\n MathUtil.smi = function smi(int) {\n return int >>> 1 & 0x40000000 | int & 0xBFFFFFFF;\n };\n\n MathUtil.hash = function hash(number) {\n if (number !== number || number === Infinity) {\n return 0;\n }\n\n var result = number;\n\n while (number > 0xFFFFFFFF) {\n number /= 0xFFFFFFFF;\n result ^= number;\n }\n\n return MathUtil.smi(result);\n };\n\n MathUtil.hashCode = function hashCode() {\n var result = 17;\n\n for (var _len = arguments.length, numbers = new Array(_len), _key = 0; _key < _len; _key++) {\n numbers[_key] = arguments[_key];\n }\n\n for (var _i = 0, _numbers = numbers; _i < _numbers.length; _i++) {\n var n = _numbers[_i];\n result = (result << 5) - result + MathUtil.hash(n);\n }\n\n return MathUtil.hash(result);\n };\n\n return MathUtil;\n}();\nMathUtil.MAX_SAFE_INTEGER = MAX_SAFE_INTEGER;\nMathUtil.MIN_SAFE_INTEGER = MIN_SAFE_INTEGER;\n\n/**\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar Enum = function () {\n function Enum(name) {\n this._name = name;\n }\n\n var _proto = Enum.prototype;\n\n _proto.equals = function equals(other) {\n return this === other;\n };\n\n _proto.toString = function toString() {\n return this._name;\n };\n\n _proto.toJSON = function toJSON() {\n return this.toString();\n };\n\n return Enum;\n}();\n\n/*\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar TemporalAmount = function () {\n function TemporalAmount() {}\n\n var _proto = TemporalAmount.prototype;\n\n _proto.get = function get(unit) {\n abstractMethodFail('get');\n };\n\n _proto.units = function units() {\n abstractMethodFail('units');\n };\n\n _proto.addTo = function addTo(temporal) {\n abstractMethodFail('addTo');\n };\n\n _proto.subtractFrom = function subtractFrom(temporal) {\n abstractMethodFail('subtractFrom');\n };\n\n return TemporalAmount;\n}();\n\n/*\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar TemporalUnit = function () {\n function TemporalUnit() {}\n\n var _proto = TemporalUnit.prototype;\n\n _proto.duration = function duration() {\n abstractMethodFail('duration');\n };\n\n _proto.isDurationEstimated = function isDurationEstimated() {\n abstractMethodFail('isDurationEstimated');\n };\n\n _proto.isDateBased = function isDateBased() {\n abstractMethodFail('isDateBased');\n };\n\n _proto.isTimeBased = function isTimeBased() {\n abstractMethodFail('isTimeBased');\n };\n\n _proto.isSupportedBy = function isSupportedBy(temporal) {\n abstractMethodFail('isSupportedBy');\n };\n\n _proto.addTo = function addTo(dateTime, periodToAdd) {\n abstractMethodFail('addTo');\n };\n\n _proto.between = function between(temporal1, temporal2) {\n abstractMethodFail('between');\n };\n\n return TemporalUnit;\n}();\n\nvar Duration = function (_TemporalAmount) {\n _inheritsLoose(Duration, _TemporalAmount);\n\n function Duration(seconds, nanos) {\n var _this;\n\n _this = _TemporalAmount.call(this) || this;\n _this._seconds = MathUtil.safeToInt(seconds);\n _this._nanos = MathUtil.safeToInt(nanos);\n return _this;\n }\n\n Duration.ofDays = function ofDays(days) {\n return Duration._create(MathUtil.safeMultiply(days, LocalTime.SECONDS_PER_DAY), 0);\n };\n\n Duration.ofHours = function ofHours(hours) {\n return Duration._create(MathUtil.safeMultiply(hours, LocalTime.SECONDS_PER_HOUR), 0);\n };\n\n Duration.ofMinutes = function ofMinutes(minutes) {\n return Duration._create(MathUtil.safeMultiply(minutes, LocalTime.SECONDS_PER_MINUTE), 0);\n };\n\n Duration.ofSeconds = function ofSeconds(seconds, nanoAdjustment) {\n if (nanoAdjustment === void 0) {\n nanoAdjustment = 0;\n }\n\n var secs = MathUtil.safeAdd(seconds, MathUtil.floorDiv(nanoAdjustment, LocalTime.NANOS_PER_SECOND));\n var nos = MathUtil.floorMod(nanoAdjustment, LocalTime.NANOS_PER_SECOND);\n return Duration._create(secs, nos);\n };\n\n Duration.ofMillis = function ofMillis(millis) {\n var secs = MathUtil.intDiv(millis, 1000);\n var mos = MathUtil.intMod(millis, 1000);\n\n if (mos < 0) {\n mos += 1000;\n secs--;\n }\n\n return Duration._create(secs, mos * 1000000);\n };\n\n Duration.ofNanos = function ofNanos(nanos) {\n var secs = MathUtil.intDiv(nanos, LocalTime.NANOS_PER_SECOND);\n var nos = MathUtil.intMod(nanos, LocalTime.NANOS_PER_SECOND);\n\n if (nos < 0) {\n nos += LocalTime.NANOS_PER_SECOND;\n secs--;\n }\n\n return this._create(secs, nos);\n };\n\n Duration.of = function of(amount, unit) {\n return Duration.ZERO.plus(amount, unit);\n };\n\n Duration.from = function from(amount) {\n requireNonNull(amount, 'amount');\n requireInstance(amount, TemporalAmount);\n var duration = Duration.ZERO;\n amount.units().forEach(function (unit) {\n duration = duration.plus(amount.get(unit), unit);\n });\n return duration;\n };\n\n Duration.between = function between(startInclusive, endExclusive) {\n requireNonNull(startInclusive, 'startInclusive');\n requireNonNull(endExclusive, 'endExclusive');\n var secs = startInclusive.until(endExclusive, ChronoUnit.SECONDS);\n var nanos = 0;\n\n if (startInclusive.isSupported(ChronoField.NANO_OF_SECOND) && endExclusive.isSupported(ChronoField.NANO_OF_SECOND)) {\n try {\n var startNos = startInclusive.getLong(ChronoField.NANO_OF_SECOND);\n nanos = endExclusive.getLong(ChronoField.NANO_OF_SECOND) - startNos;\n\n if (secs > 0 && nanos < 0) {\n nanos += LocalTime.NANOS_PER_SECOND;\n } else if (secs < 0 && nanos > 0) {\n nanos -= LocalTime.NANOS_PER_SECOND;\n } else if (secs === 0 && nanos !== 0) {\n var adjustedEnd = endExclusive.with(ChronoField.NANO_OF_SECOND, startNos);\n secs = startInclusive.until(adjustedEnd, ChronoUnit.SECONDS);\n }\n } catch (e) {}\n }\n\n return this.ofSeconds(secs, nanos);\n };\n\n Duration.parse = function parse(text) {\n requireNonNull(text, 'text');\n var PATTERN = new RegExp('([-+]?)P(?:([-+]?[0-9]+)D)?(T(?:([-+]?[0-9]+)H)?(?:([-+]?[0-9]+)M)?(?:([-+]?[0-9]+)(?:[.,]([0-9]{0,9}))?S)?)?', 'i');\n var matches = PATTERN.exec(text);\n\n if (matches !== null) {\n if ('T' === matches[3] === false) {\n var negate = '-' === matches[1];\n var dayMatch = matches[2];\n var hourMatch = matches[4];\n var minuteMatch = matches[5];\n var secondMatch = matches[6];\n var fractionMatch = matches[7];\n\n if (dayMatch != null || hourMatch != null || minuteMatch != null || secondMatch != null) {\n var daysAsSecs = Duration._parseNumber(text, dayMatch, LocalTime.SECONDS_PER_DAY, 'days');\n\n var hoursAsSecs = Duration._parseNumber(text, hourMatch, LocalTime.SECONDS_PER_HOUR, 'hours');\n\n var minsAsSecs = Duration._parseNumber(text, minuteMatch, LocalTime.SECONDS_PER_MINUTE, 'minutes');\n\n var seconds = Duration._parseNumber(text, secondMatch, 1, 'seconds');\n\n var negativeSecs = secondMatch != null && secondMatch.charAt(0) === '-';\n\n var nanos = Duration._parseFraction(text, fractionMatch, negativeSecs ? -1 : 1);\n\n try {\n return Duration._create(negate, daysAsSecs, hoursAsSecs, minsAsSecs, seconds, nanos);\n } catch (ex) {\n throw new DateTimeParseException('Text cannot be parsed to a Duration: overflow', text, 0, ex);\n }\n }\n }\n }\n\n throw new DateTimeParseException('Text cannot be parsed to a Duration', text, 0);\n };\n\n Duration._parseNumber = function _parseNumber(text, parsed, multiplier, errorText) {\n if (parsed == null) {\n return 0;\n }\n\n try {\n if (parsed[0] === '+') {\n parsed = parsed.substring(1);\n }\n\n return MathUtil.safeMultiply(parseFloat(parsed), multiplier);\n } catch (ex) {\n throw new DateTimeParseException('Text cannot be parsed to a Duration: ' + errorText, text, 0, ex);\n }\n };\n\n Duration._parseFraction = function _parseFraction(text, parsed, negate) {\n if (parsed == null || parsed.length === 0) {\n return 0;\n }\n\n parsed = (parsed + '000000000').substring(0, 9);\n return parseFloat(parsed) * negate;\n };\n\n Duration._create = function _create() {\n if (arguments.length <= 2) {\n return Duration._createSecondsNanos(arguments[0], arguments[1]);\n } else {\n return Duration._createNegateDaysHoursMinutesSecondsNanos(arguments[0], arguments[1], arguments[2], arguments[3], arguments[4], arguments[5]);\n }\n };\n\n Duration._createNegateDaysHoursMinutesSecondsNanos = function _createNegateDaysHoursMinutesSecondsNanos(negate, daysAsSecs, hoursAsSecs, minsAsSecs, secs, nanos) {\n var seconds = MathUtil.safeAdd(daysAsSecs, MathUtil.safeAdd(hoursAsSecs, MathUtil.safeAdd(minsAsSecs, secs)));\n\n if (negate) {\n return Duration.ofSeconds(seconds, nanos).negated();\n }\n\n return Duration.ofSeconds(seconds, nanos);\n };\n\n Duration._createSecondsNanos = function _createSecondsNanos(seconds, nanoAdjustment) {\n if (seconds === void 0) {\n seconds = 0;\n }\n\n if (nanoAdjustment === void 0) {\n nanoAdjustment = 0;\n }\n\n if (seconds === 0 && nanoAdjustment === 0) {\n return Duration.ZERO;\n }\n\n return new Duration(seconds, nanoAdjustment);\n };\n\n var _proto = Duration.prototype;\n\n _proto.get = function get(unit) {\n if (unit === ChronoUnit.SECONDS) {\n return this._seconds;\n } else if (unit === ChronoUnit.NANOS) {\n return this._nanos;\n } else {\n throw new UnsupportedTemporalTypeException('Unsupported unit: ' + unit);\n }\n };\n\n _proto.units = function units() {\n return [ChronoUnit.SECONDS, ChronoUnit.NANOS];\n };\n\n _proto.isZero = function isZero() {\n return this._seconds === 0 && this._nanos === 0;\n };\n\n _proto.isNegative = function isNegative() {\n return this._seconds < 0;\n };\n\n _proto.seconds = function seconds() {\n return this._seconds;\n };\n\n _proto.nano = function nano() {\n return this._nanos;\n };\n\n _proto.withSeconds = function withSeconds(seconds) {\n return Duration._create(seconds, this._nanos);\n };\n\n _proto.withNanos = function withNanos(nanoOfSecond) {\n ChronoField.NANO_OF_SECOND.checkValidIntValue(nanoOfSecond);\n return Duration._create(this._seconds, nanoOfSecond);\n };\n\n _proto.plusDuration = function plusDuration(duration) {\n requireNonNull(duration, 'duration');\n return this.plus(duration.seconds(), duration.nano());\n };\n\n _proto.plus = function plus(durationOrNumber, unitOrNumber) {\n if (arguments.length === 1) {\n return this.plusDuration(durationOrNumber);\n } else if (arguments.length === 2 && unitOrNumber instanceof TemporalUnit) {\n return this.plusAmountUnit(durationOrNumber, unitOrNumber);\n } else {\n return this.plusSecondsNanos(durationOrNumber, unitOrNumber);\n }\n };\n\n _proto.plusAmountUnit = function plusAmountUnit(amountToAdd, unit) {\n requireNonNull(amountToAdd, 'amountToAdd');\n requireNonNull(unit, 'unit');\n\n if (unit === ChronoUnit.DAYS) {\n return this.plusSecondsNanos(MathUtil.safeMultiply(amountToAdd, LocalTime.SECONDS_PER_DAY), 0);\n }\n\n if (unit.isDurationEstimated()) {\n throw new UnsupportedTemporalTypeException('Unit must not have an estimated duration');\n }\n\n if (amountToAdd === 0) {\n return this;\n }\n\n if (unit instanceof ChronoUnit) {\n switch (unit) {\n case ChronoUnit.NANOS:\n return this.plusNanos(amountToAdd);\n\n case ChronoUnit.MICROS:\n return this.plusSecondsNanos(MathUtil.intDiv(amountToAdd, 1000000 * 1000) * 1000, MathUtil.intMod(amountToAdd, 1000000 * 1000) * 1000);\n\n case ChronoUnit.MILLIS:\n return this.plusMillis(amountToAdd);\n\n case ChronoUnit.SECONDS:\n return this.plusSeconds(amountToAdd);\n }\n\n return this.plusSecondsNanos(MathUtil.safeMultiply(unit.duration().seconds(), amountToAdd), 0);\n }\n\n var duration = unit.duration().multipliedBy(amountToAdd);\n return this.plusSecondsNanos(duration.seconds(), duration.nano());\n };\n\n _proto.plusDays = function plusDays(daysToAdd) {\n return this.plusSecondsNanos(MathUtil.safeMultiply(daysToAdd, LocalTime.SECONDS_PER_DAY), 0);\n };\n\n _proto.plusHours = function plusHours(hoursToAdd) {\n return this.plusSecondsNanos(MathUtil.safeMultiply(hoursToAdd, LocalTime.SECONDS_PER_HOUR), 0);\n };\n\n _proto.plusMinutes = function plusMinutes(minutesToAdd) {\n return this.plusSecondsNanos(MathUtil.safeMultiply(minutesToAdd, LocalTime.SECONDS_PER_MINUTE), 0);\n };\n\n _proto.plusSeconds = function plusSeconds(secondsToAdd) {\n return this.plusSecondsNanos(secondsToAdd, 0);\n };\n\n _proto.plusMillis = function plusMillis(millisToAdd) {\n return this.plusSecondsNanos(MathUtil.intDiv(millisToAdd, 1000), MathUtil.intMod(millisToAdd, 1000) * 1000000);\n };\n\n _proto.plusNanos = function plusNanos(nanosToAdd) {\n return this.plusSecondsNanos(0, nanosToAdd);\n };\n\n _proto.plusSecondsNanos = function plusSecondsNanos(secondsToAdd, nanosToAdd) {\n requireNonNull(secondsToAdd, 'secondsToAdd');\n requireNonNull(nanosToAdd, 'nanosToAdd');\n\n if (secondsToAdd === 0 && nanosToAdd === 0) {\n return this;\n }\n\n var epochSec = MathUtil.safeAdd(this._seconds, secondsToAdd);\n epochSec = MathUtil.safeAdd(epochSec, MathUtil.intDiv(nanosToAdd, LocalTime.NANOS_PER_SECOND));\n nanosToAdd = MathUtil.intMod(nanosToAdd, LocalTime.NANOS_PER_SECOND);\n var nanoAdjustment = MathUtil.safeAdd(this._nanos, nanosToAdd);\n return Duration.ofSeconds(epochSec, nanoAdjustment);\n };\n\n _proto.minus = function minus(durationOrNumber, unit) {\n if (arguments.length === 1) {\n return this.minusDuration(durationOrNumber);\n } else {\n return this.minusAmountUnit(durationOrNumber, unit);\n }\n };\n\n _proto.minusDuration = function minusDuration(duration) {\n requireNonNull(duration, 'duration');\n var secsToSubtract = duration.seconds();\n var nanosToSubtract = duration.nano();\n\n if (secsToSubtract === MIN_SAFE_INTEGER) {\n return this.plus(MAX_SAFE_INTEGER, -nanosToSubtract);\n }\n\n return this.plus(-secsToSubtract, -nanosToSubtract);\n };\n\n _proto.minusAmountUnit = function minusAmountUnit(amountToSubtract, unit) {\n requireNonNull(amountToSubtract, 'amountToSubtract');\n requireNonNull(unit, 'unit');\n return amountToSubtract === MIN_SAFE_INTEGER ? this.plusAmountUnit(MAX_SAFE_INTEGER, unit) : this.plusAmountUnit(-amountToSubtract, unit);\n };\n\n _proto.minusDays = function minusDays(daysToSubtract) {\n return daysToSubtract === MIN_SAFE_INTEGER ? this.plusDays(MAX_SAFE_INTEGER) : this.plusDays(-daysToSubtract);\n };\n\n _proto.minusHours = function minusHours(hoursToSubtract) {\n return hoursToSubtract === MIN_SAFE_INTEGER ? this.plusHours(MAX_SAFE_INTEGER) : this.plusHours(-hoursToSubtract);\n };\n\n _proto.minusMinutes = function minusMinutes(minutesToSubtract) {\n return minutesToSubtract === MIN_SAFE_INTEGER ? this.plusMinutes(MAX_SAFE_INTEGER) : this.plusMinutes(-minutesToSubtract);\n };\n\n _proto.minusSeconds = function minusSeconds(secondsToSubtract) {\n return secondsToSubtract === MIN_SAFE_INTEGER ? this.plusSeconds(MAX_SAFE_INTEGER) : this.plusSeconds(-secondsToSubtract);\n };\n\n _proto.minusMillis = function minusMillis(millisToSubtract) {\n return millisToSubtract === MIN_SAFE_INTEGER ? this.plusMillis(MAX_SAFE_INTEGER) : this.plusMillis(-millisToSubtract);\n };\n\n _proto.minusNanos = function minusNanos(nanosToSubtract) {\n return nanosToSubtract === MIN_SAFE_INTEGER ? this.plusNanos(MAX_SAFE_INTEGER) : this.plusNanos(-nanosToSubtract);\n };\n\n _proto.multipliedBy = function multipliedBy(multiplicand) {\n if (multiplicand === 0) {\n return Duration.ZERO;\n }\n\n if (multiplicand === 1) {\n return this;\n }\n\n var secs = MathUtil.safeMultiply(this._seconds, multiplicand);\n var nos = MathUtil.safeMultiply(this._nanos, multiplicand);\n secs = secs + MathUtil.intDiv(nos, LocalTime.NANOS_PER_SECOND);\n nos = MathUtil.intMod(nos, LocalTime.NANOS_PER_SECOND);\n return Duration.ofSeconds(secs, nos);\n };\n\n _proto.dividedBy = function dividedBy(divisor) {\n if (divisor === 0) {\n throw new ArithmeticException('Cannot divide by zero');\n }\n\n if (divisor === 1) {\n return this;\n }\n\n var secs = MathUtil.intDiv(this._seconds, divisor);\n var secsMod = MathUtil.roundDown((this._seconds / divisor - secs) * LocalTime.NANOS_PER_SECOND);\n var nos = MathUtil.intDiv(this._nanos, divisor);\n nos = secsMod + nos;\n return Duration.ofSeconds(secs, nos);\n };\n\n _proto.negated = function negated() {\n return this.multipliedBy(-1);\n };\n\n _proto.abs = function abs() {\n return this.isNegative() ? this.negated() : this;\n };\n\n _proto.addTo = function addTo(temporal) {\n requireNonNull(temporal, 'temporal');\n\n if (this._seconds !== 0) {\n temporal = temporal.plus(this._seconds, ChronoUnit.SECONDS);\n }\n\n if (this._nanos !== 0) {\n temporal = temporal.plus(this._nanos, ChronoUnit.NANOS);\n }\n\n return temporal;\n };\n\n _proto.subtractFrom = function subtractFrom(temporal) {\n requireNonNull(temporal, 'temporal');\n\n if (this._seconds !== 0) {\n temporal = temporal.minus(this._seconds, ChronoUnit.SECONDS);\n }\n\n if (this._nanos !== 0) {\n temporal = temporal.minus(this._nanos, ChronoUnit.NANOS);\n }\n\n return temporal;\n };\n\n _proto.toDays = function toDays() {\n return MathUtil.intDiv(this._seconds, LocalTime.SECONDS_PER_DAY);\n };\n\n _proto.toHours = function toHours() {\n return MathUtil.intDiv(this._seconds, LocalTime.SECONDS_PER_HOUR);\n };\n\n _proto.toMinutes = function toMinutes() {\n return MathUtil.intDiv(this._seconds, LocalTime.SECONDS_PER_MINUTE);\n };\n\n _proto.toMillis = function toMillis() {\n var millis = Math.round(MathUtil.safeMultiply(this._seconds, 1000));\n millis = MathUtil.safeAdd(millis, MathUtil.intDiv(this._nanos, 1000000));\n return millis;\n };\n\n _proto.toNanos = function toNanos() {\n var totalNanos = MathUtil.safeMultiply(this._seconds, LocalTime.NANOS_PER_SECOND);\n totalNanos = MathUtil.safeAdd(totalNanos, this._nanos);\n return totalNanos;\n };\n\n _proto.compareTo = function compareTo(otherDuration) {\n requireNonNull(otherDuration, 'otherDuration');\n requireInstance(otherDuration, Duration, 'otherDuration');\n var cmp = MathUtil.compareNumbers(this._seconds, otherDuration.seconds());\n\n if (cmp !== 0) {\n return cmp;\n }\n\n return this._nanos - otherDuration.nano();\n };\n\n _proto.equals = function equals(otherDuration) {\n if (this === otherDuration) {\n return true;\n }\n\n if (otherDuration instanceof Duration) {\n return this.seconds() === otherDuration.seconds() && this.nano() === otherDuration.nano();\n }\n\n return false;\n };\n\n _proto.toString = function toString() {\n if (this === Duration.ZERO) {\n return 'PT0S';\n }\n\n var hours = MathUtil.intDiv(this._seconds, LocalTime.SECONDS_PER_HOUR);\n var minutes = MathUtil.intDiv(MathUtil.intMod(this._seconds, LocalTime.SECONDS_PER_HOUR), LocalTime.SECONDS_PER_MINUTE);\n var secs = MathUtil.intMod(this._seconds, LocalTime.SECONDS_PER_MINUTE);\n var rval = 'PT';\n\n if (hours !== 0) {\n rval += hours + 'H';\n }\n\n if (minutes !== 0) {\n rval += minutes + 'M';\n }\n\n if (secs === 0 && this._nanos === 0 && rval.length > 2) {\n return rval;\n }\n\n if (secs < 0 && this._nanos > 0) {\n if (secs === -1) {\n rval += '-0';\n } else {\n rval += secs + 1;\n }\n } else {\n rval += secs;\n }\n\n if (this._nanos > 0) {\n rval += '.';\n var nanoString;\n\n if (secs < 0) {\n nanoString = '' + (2 * LocalTime.NANOS_PER_SECOND - this._nanos);\n } else {\n nanoString = '' + (LocalTime.NANOS_PER_SECOND + this._nanos);\n }\n\n nanoString = nanoString.slice(1, nanoString.length);\n rval += nanoString;\n\n while (rval.charAt(rval.length - 1) === '0') {\n rval = rval.slice(0, rval.length - 1);\n }\n }\n\n rval += 'S';\n return rval;\n };\n\n _proto.toJSON = function toJSON() {\n return this.toString();\n };\n\n return Duration;\n}(TemporalAmount);\nfunction _init() {\n Duration.ZERO = new Duration(0, 0);\n}\n\n/*\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @license BSD-3-Clause (see LICENSE.md in the root directory of this source tree)\n */\nvar YearConstants = function YearConstants() {};\nfunction _init$1() {\n YearConstants.MIN_VALUE = -999999;\n YearConstants.MAX_VALUE = 999999;\n}\n\nvar ChronoUnit = function (_TemporalUnit) {\n _inheritsLoose(ChronoUnit, _TemporalUnit);\n\n function ChronoUnit(name, estimatedDuration) {\n var _this;\n\n _this = _TemporalUnit.call(this) || this;\n _this._name = name;\n _this._duration = estimatedDuration;\n return _this;\n }\n\n var _proto = ChronoUnit.prototype;\n\n _proto.duration = function duration() {\n return this._duration;\n };\n\n _proto.isDurationEstimated = function isDurationEstimated() {\n return this.isDateBased() || this === ChronoUnit.FOREVER;\n };\n\n _proto.isDateBased = function isDateBased() {\n return this.compareTo(ChronoUnit.DAYS) >= 0 && this !== ChronoUnit.FOREVER;\n };\n\n _proto.isTimeBased = function isTimeBased() {\n return this.compareTo(ChronoUnit.DAYS) < 0;\n };\n\n _proto.isSupportedBy = function isSupportedBy(temporal) {\n if (this === ChronoUnit.FOREVER) {\n return false;\n }\n\n try {\n temporal.plus(1, this);\n return true;\n } catch (e) {\n try {\n temporal.plus(-1, this);\n return true;\n } catch (e2) {\n return false;\n }\n }\n };\n\n _proto.addTo = function addTo(temporal, amount) {\n return temporal.plus(amount, this);\n };\n\n _proto.between = function between(temporal1, temporal2) {\n return temporal1.until(temporal2, this);\n };\n\n _proto.toString = function toString() {\n return this._name;\n };\n\n _proto.compareTo = function compareTo(other) {\n return this.duration().compareTo(other.duration());\n };\n\n return ChronoUnit;\n}(TemporalUnit);\nfunction _init$2() {\n ChronoUnit.NANOS = new ChronoUnit('Nanos', Duration.ofNanos(1));\n ChronoUnit.MICROS = new ChronoUnit('Micros', Duration.ofNanos(1000));\n ChronoUnit.MILLIS = new ChronoUnit('Millis', Duration.ofNanos(1000000));\n ChronoUnit.SECONDS = new ChronoUnit('Seconds', Duration.ofSeconds(1));\n ChronoUnit.MINUTES = new ChronoUnit('Minutes', Duration.ofSeconds(60));\n ChronoUnit.HOURS = new ChronoUnit('Hours', Duration.ofSeconds(3600));\n ChronoUnit.HALF_DAYS = new ChronoUnit('HalfDays', Duration.ofSeconds(43200));\n ChronoUnit.DAYS = new ChronoUnit('Days', Duration.ofSeconds(86400));\n ChronoUnit.WEEKS = new ChronoUnit('Weeks', Duration.ofSeconds(7 * 86400));\n ChronoUnit.MONTHS = new ChronoUnit('Months', Duration.ofSeconds(31556952 / 12));\n ChronoUnit.YEARS = new ChronoUnit('Years', Duration.ofSeconds(31556952));\n ChronoUnit.DECADES = new ChronoUnit('Decades', Duration.ofSeconds(31556952 * 10));\n ChronoUnit.CENTURIES = new ChronoUnit('Centuries', Duration.ofSeconds(31556952 * 100));\n ChronoUnit.MILLENNIA = new ChronoUnit('Millennia', Duration.ofSeconds(31556952 * 1000));\n ChronoUnit.ERAS = new ChronoUnit('Eras', Duration.ofSeconds(31556952 * (YearConstants.MAX_VALUE + 1)));\n ChronoUnit.FOREVER = new ChronoUnit('Forever', Duration.ofSeconds(MathUtil.MAX_SAFE_INTEGER, 999999999));\n}\n\n/**\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\n\nvar TemporalField = function () {\n function TemporalField() {}\n\n var _proto = TemporalField.prototype;\n\n _proto.isDateBased = function isDateBased() {\n abstractMethodFail('isDateBased');\n };\n\n _proto.isTimeBased = function isTimeBased() {\n abstractMethodFail('isTimeBased');\n };\n\n _proto.baseUnit = function baseUnit() {\n abstractMethodFail('baseUnit');\n };\n\n _proto.rangeUnit = function rangeUnit() {\n abstractMethodFail('rangeUnit');\n };\n\n _proto.range = function range() {\n abstractMethodFail('range');\n };\n\n _proto.rangeRefinedBy = function rangeRefinedBy(temporal) {\n abstractMethodFail('rangeRefinedBy');\n };\n\n _proto.getFrom = function getFrom(temporal) {\n abstractMethodFail('getFrom');\n };\n\n _proto.adjustInto = function adjustInto(temporal, newValue) {\n abstractMethodFail('adjustInto');\n };\n\n _proto.isSupportedBy = function isSupportedBy(temporal) {\n abstractMethodFail('isSupportedBy');\n };\n\n _proto.displayName = function displayName() {\n abstractMethodFail('displayName');\n };\n\n _proto.equals = function equals(other) {\n abstractMethodFail('equals');\n };\n\n _proto.name = function name() {\n abstractMethodFail('name');\n };\n\n return TemporalField;\n}();\n\n/**\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar ValueRange = function () {\n function ValueRange(minSmallest, minLargest, maxSmallest, maxLargest) {\n assert(!(minSmallest > minLargest), 'Smallest minimum value \\'' + minSmallest + '\\' must be less than largest minimum value \\'' + minLargest + '\\'', IllegalArgumentException);\n assert(!(maxSmallest > maxLargest), 'Smallest maximum value \\'' + maxSmallest + '\\' must be less than largest maximum value \\'' + maxLargest + '\\'', IllegalArgumentException);\n assert(!(minLargest > maxLargest), 'Minimum value \\'' + minLargest + '\\' must be less than maximum value \\'' + maxLargest + '\\'', IllegalArgumentException);\n this._minSmallest = minSmallest;\n this._minLargest = minLargest;\n this._maxLargest = maxLargest;\n this._maxSmallest = maxSmallest;\n }\n\n var _proto = ValueRange.prototype;\n\n _proto.isFixed = function isFixed() {\n return this._minSmallest === this._minLargest && this._maxSmallest === this._maxLargest;\n };\n\n _proto.minimum = function minimum() {\n return this._minSmallest;\n };\n\n _proto.largestMinimum = function largestMinimum() {\n return this._minLargest;\n };\n\n _proto.maximum = function maximum() {\n return this._maxLargest;\n };\n\n _proto.smallestMaximum = function smallestMaximum() {\n return this._maxSmallest;\n };\n\n _proto.isValidValue = function isValidValue(value) {\n return this.minimum() <= value && value <= this.maximum();\n };\n\n _proto.checkValidValue = function checkValidValue(value, field) {\n var msg;\n\n if (!this.isValidValue(value)) {\n if (field != null) {\n msg = 'Invalid value for ' + field + ' (valid values ' + this.toString() + '): ' + value;\n } else {\n msg = 'Invalid value (valid values ' + this.toString() + '): ' + value;\n }\n\n return assert(false, msg, DateTimeException);\n }\n\n return value;\n };\n\n _proto.checkValidIntValue = function checkValidIntValue(value, field) {\n if (this.isValidIntValue(value) === false) {\n throw new DateTimeException('Invalid int value for ' + field + ': ' + value);\n }\n\n return value;\n };\n\n _proto.isValidIntValue = function isValidIntValue(value) {\n return this.isIntValue() && this.isValidValue(value);\n };\n\n _proto.isIntValue = function isIntValue() {\n return this.minimum() >= MathUtil.MIN_SAFE_INTEGER && this.maximum() <= MathUtil.MAX_SAFE_INTEGER;\n };\n\n _proto.equals = function equals(other) {\n if (other === this) {\n return true;\n }\n\n if (other instanceof ValueRange) {\n return this._minSmallest === other._minSmallest && this._minLargest === other._minLargest && this._maxSmallest === other._maxSmallest && this._maxLargest === other._maxLargest;\n }\n\n return false;\n };\n\n _proto.hashCode = function hashCode() {\n return MathUtil.hashCode(this._minSmallest, this._minLargest, this._maxSmallest, this._maxLargest);\n };\n\n _proto.toString = function toString() {\n var str = this.minimum() + (this.minimum() !== this.largestMinimum() ? '/' + this.largestMinimum() : '');\n str += ' - ';\n str += this.smallestMaximum() + (this.smallestMaximum() !== this.maximum() ? '/' + this.maximum() : '');\n return str;\n };\n\n ValueRange.of = function of() {\n if (arguments.length === 2) {\n return new ValueRange(arguments[0], arguments[0], arguments[1], arguments[1]);\n } else if (arguments.length === 3) {\n return new ValueRange(arguments[0], arguments[0], arguments[1], arguments[2]);\n } else if (arguments.length === 4) {\n return new ValueRange(arguments[0], arguments[1], arguments[2], arguments[3]);\n } else {\n return assert(false, 'Invalid number of arguments ' + arguments.length, IllegalArgumentException);\n }\n };\n\n return ValueRange;\n}();\n\nvar ChronoField = function (_TemporalField) {\n _inheritsLoose(ChronoField, _TemporalField);\n\n ChronoField.byName = function byName(fieldName) {\n for (var prop in ChronoField) {\n if (ChronoField[prop]) {\n if (ChronoField[prop] instanceof ChronoField && ChronoField[prop].name() === fieldName) {\n return ChronoField[prop];\n }\n }\n }\n };\n\n function ChronoField(name, baseUnit, rangeUnit, range) {\n var _this;\n\n _this = _TemporalField.call(this) || this;\n _this._name = name;\n _this._baseUnit = baseUnit;\n _this._rangeUnit = rangeUnit;\n _this._range = range;\n return _this;\n }\n\n var _proto = ChronoField.prototype;\n\n _proto.name = function name() {\n return this._name;\n };\n\n _proto.baseUnit = function baseUnit() {\n return this._baseUnit;\n };\n\n _proto.rangeUnit = function rangeUnit() {\n return this._rangeUnit;\n };\n\n _proto.range = function range() {\n return this._range;\n };\n\n _proto.displayName = function displayName() {\n return this.toString();\n };\n\n _proto.checkValidValue = function checkValidValue(value) {\n return this.range().checkValidValue(value, this);\n };\n\n _proto.checkValidIntValue = function checkValidIntValue(value) {\n return this.range().checkValidIntValue(value, this);\n };\n\n _proto.isDateBased = function isDateBased() {\n var dateBased = this === ChronoField.DAY_OF_WEEK || this === ChronoField.ALIGNED_DAY_OF_WEEK_IN_MONTH || this === ChronoField.ALIGNED_DAY_OF_WEEK_IN_YEAR || this === ChronoField.DAY_OF_MONTH || this === ChronoField.DAY_OF_YEAR || this === ChronoField.EPOCH_DAY || this === ChronoField.ALIGNED_WEEK_OF_MONTH || this === ChronoField.ALIGNED_WEEK_OF_YEAR || this === ChronoField.MONTH_OF_YEAR || this === ChronoField.YEAR_OF_ERA || this === ChronoField.YEAR || this === ChronoField.ERA;\n return dateBased;\n };\n\n _proto.isTimeBased = function isTimeBased() {\n var timeBased = this === ChronoField.NANO_OF_SECOND || this === ChronoField.NANO_OF_DAY || this === ChronoField.MICRO_OF_SECOND || this === ChronoField.MICRO_OF_DAY || this === ChronoField.MILLI_OF_SECOND || this === ChronoField.MILLI_OF_DAY || this === ChronoField.SECOND_OF_MINUTE || this === ChronoField.SECOND_OF_DAY || this === ChronoField.MINUTE_OF_HOUR || this === ChronoField.MINUTE_OF_DAY || this === ChronoField.HOUR_OF_AMPM || this === ChronoField.CLOCK_HOUR_OF_AMPM || this === ChronoField.HOUR_OF_DAY || this === ChronoField.CLOCK_HOUR_OF_DAY || this === ChronoField.AMPM_OF_DAY;\n return timeBased;\n };\n\n _proto.rangeRefinedBy = function rangeRefinedBy(temporal) {\n return temporal.range(this);\n };\n\n _proto.getFrom = function getFrom(temporal) {\n return temporal.getLong(this);\n };\n\n _proto.toString = function toString() {\n return this.name();\n };\n\n _proto.equals = function equals(other) {\n return this === other;\n };\n\n _proto.adjustInto = function adjustInto(temporal, newValue) {\n return temporal.with(this, newValue);\n };\n\n _proto.isSupportedBy = function isSupportedBy(temporal) {\n return temporal.isSupported(this);\n };\n\n return ChronoField;\n}(TemporalField);\nfunction _init$3() {\n ChronoField.NANO_OF_SECOND = new ChronoField('NanoOfSecond', ChronoUnit.NANOS, ChronoUnit.SECONDS, ValueRange.of(0, 999999999));\n ChronoField.NANO_OF_DAY = new ChronoField('NanoOfDay', ChronoUnit.NANOS, ChronoUnit.DAYS, ValueRange.of(0, 86400 * 1000000000 - 1));\n ChronoField.MICRO_OF_SECOND = new ChronoField('MicroOfSecond', ChronoUnit.MICROS, ChronoUnit.SECONDS, ValueRange.of(0, 999999));\n ChronoField.MICRO_OF_DAY = new ChronoField('MicroOfDay', ChronoUnit.MICROS, ChronoUnit.DAYS, ValueRange.of(0, 86400 * 1000000 - 1));\n ChronoField.MILLI_OF_SECOND = new ChronoField('MilliOfSecond', ChronoUnit.MILLIS, ChronoUnit.SECONDS, ValueRange.of(0, 999));\n ChronoField.MILLI_OF_DAY = new ChronoField('MilliOfDay', ChronoUnit.MILLIS, ChronoUnit.DAYS, ValueRange.of(0, 86400 * 1000 - 1));\n ChronoField.SECOND_OF_MINUTE = new ChronoField('SecondOfMinute', ChronoUnit.SECONDS, ChronoUnit.MINUTES, ValueRange.of(0, 59));\n ChronoField.SECOND_OF_DAY = new ChronoField('SecondOfDay', ChronoUnit.SECONDS, ChronoUnit.DAYS, ValueRange.of(0, 86400 - 1));\n ChronoField.MINUTE_OF_HOUR = new ChronoField('MinuteOfHour', ChronoUnit.MINUTES, ChronoUnit.HOURS, ValueRange.of(0, 59));\n ChronoField.MINUTE_OF_DAY = new ChronoField('MinuteOfDay', ChronoUnit.MINUTES, ChronoUnit.DAYS, ValueRange.of(0, 24 * 60 - 1));\n ChronoField.HOUR_OF_AMPM = new ChronoField('HourOfAmPm', ChronoUnit.HOURS, ChronoUnit.HALF_DAYS, ValueRange.of(0, 11));\n ChronoField.CLOCK_HOUR_OF_AMPM = new ChronoField('ClockHourOfAmPm', ChronoUnit.HOURS, ChronoUnit.HALF_DAYS, ValueRange.of(1, 12));\n ChronoField.HOUR_OF_DAY = new ChronoField('HourOfDay', ChronoUnit.HOURS, ChronoUnit.DAYS, ValueRange.of(0, 23));\n ChronoField.CLOCK_HOUR_OF_DAY = new ChronoField('ClockHourOfDay', ChronoUnit.HOURS, ChronoUnit.DAYS, ValueRange.of(1, 24));\n ChronoField.AMPM_OF_DAY = new ChronoField('AmPmOfDay', ChronoUnit.HALF_DAYS, ChronoUnit.DAYS, ValueRange.of(0, 1));\n ChronoField.DAY_OF_WEEK = new ChronoField('DayOfWeek', ChronoUnit.DAYS, ChronoUnit.WEEKS, ValueRange.of(1, 7));\n ChronoField.ALIGNED_DAY_OF_WEEK_IN_MONTH = new ChronoField('AlignedDayOfWeekInMonth', ChronoUnit.DAYS, ChronoUnit.WEEKS, ValueRange.of(1, 7));\n ChronoField.ALIGNED_DAY_OF_WEEK_IN_YEAR = new ChronoField('AlignedDayOfWeekInYear', ChronoUnit.DAYS, ChronoUnit.WEEKS, ValueRange.of(1, 7));\n ChronoField.DAY_OF_MONTH = new ChronoField('DayOfMonth', ChronoUnit.DAYS, ChronoUnit.MONTHS, ValueRange.of(1, 28, 31), 'day');\n ChronoField.DAY_OF_YEAR = new ChronoField('DayOfYear', ChronoUnit.DAYS, ChronoUnit.YEARS, ValueRange.of(1, 365, 366));\n ChronoField.EPOCH_DAY = new ChronoField('EpochDay', ChronoUnit.DAYS, ChronoUnit.FOREVER, ValueRange.of(Math.floor(YearConstants.MIN_VALUE * 365.25), Math.floor(YearConstants.MAX_VALUE * 365.25)));\n ChronoField.ALIGNED_WEEK_OF_MONTH = new ChronoField('AlignedWeekOfMonth', ChronoUnit.WEEKS, ChronoUnit.MONTHS, ValueRange.of(1, 4, 5));\n ChronoField.ALIGNED_WEEK_OF_YEAR = new ChronoField('AlignedWeekOfYear', ChronoUnit.WEEKS, ChronoUnit.YEARS, ValueRange.of(1, 53));\n ChronoField.MONTH_OF_YEAR = new ChronoField('MonthOfYear', ChronoUnit.MONTHS, ChronoUnit.YEARS, ValueRange.of(1, 12), 'month');\n ChronoField.PROLEPTIC_MONTH = new ChronoField('ProlepticMonth', ChronoUnit.MONTHS, ChronoUnit.FOREVER, ValueRange.of(YearConstants.MIN_VALUE * 12, YearConstants.MAX_VALUE * 12 + 11));\n ChronoField.YEAR_OF_ERA = new ChronoField('YearOfEra', ChronoUnit.YEARS, ChronoUnit.FOREVER, ValueRange.of(1, YearConstants.MAX_VALUE, YearConstants.MAX_VALUE + 1));\n ChronoField.YEAR = new ChronoField('Year', ChronoUnit.YEARS, ChronoUnit.FOREVER, ValueRange.of(YearConstants.MIN_VALUE, YearConstants.MAX_VALUE), 'year');\n ChronoField.ERA = new ChronoField('Era', ChronoUnit.ERAS, ChronoUnit.FOREVER, ValueRange.of(0, 1));\n ChronoField.INSTANT_SECONDS = new ChronoField('InstantSeconds', ChronoUnit.SECONDS, ChronoUnit.FOREVER, ValueRange.of(MIN_SAFE_INTEGER, MAX_SAFE_INTEGER));\n ChronoField.OFFSET_SECONDS = new ChronoField('OffsetSeconds', ChronoUnit.SECONDS, ChronoUnit.FOREVER, ValueRange.of(-18 * 3600, 18 * 3600));\n}\n\n/**\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar TemporalQueries = function () {\n function TemporalQueries() {}\n\n TemporalQueries.zoneId = function zoneId() {\n return TemporalQueries.ZONE_ID;\n };\n\n TemporalQueries.chronology = function chronology() {\n return TemporalQueries.CHRONO;\n };\n\n TemporalQueries.precision = function precision() {\n return TemporalQueries.PRECISION;\n };\n\n TemporalQueries.zone = function zone() {\n return TemporalQueries.ZONE;\n };\n\n TemporalQueries.offset = function offset() {\n return TemporalQueries.OFFSET;\n };\n\n TemporalQueries.localDate = function localDate() {\n return TemporalQueries.LOCAL_DATE;\n };\n\n TemporalQueries.localTime = function localTime() {\n return TemporalQueries.LOCAL_TIME;\n };\n\n return TemporalQueries;\n}();\n\n/**\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar TemporalAccessor = function () {\n function TemporalAccessor() {}\n\n var _proto = TemporalAccessor.prototype;\n\n _proto.query = function query(_query) {\n if (_query === TemporalQueries.zoneId() || _query === TemporalQueries.chronology() || _query === TemporalQueries.precision()) {\n return null;\n }\n\n return _query.queryFrom(this);\n };\n\n _proto.get = function get(field) {\n return this.range(field).checkValidIntValue(this.getLong(field), field);\n };\n\n _proto.range = function range(field) {\n if (field instanceof ChronoField) {\n if (this.isSupported(field)) {\n return field.range();\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported field: ' + field);\n }\n\n return field.rangeRefinedBy(this);\n };\n\n return TemporalAccessor;\n}();\n\nvar TemporalQuery = function (_Enum) {\n _inheritsLoose(TemporalQuery, _Enum);\n\n function TemporalQuery() {\n return _Enum.apply(this, arguments) || this;\n }\n\n var _proto = TemporalQuery.prototype;\n\n _proto.queryFrom = function queryFrom(temporal) {\n abstractMethodFail('queryFrom');\n };\n\n return TemporalQuery;\n}(Enum);\nfunction createTemporalQuery(name, queryFromFunction) {\n var ExtendedTemporalQuery = function (_TemporalQuery) {\n _inheritsLoose(ExtendedTemporalQuery, _TemporalQuery);\n\n function ExtendedTemporalQuery() {\n return _TemporalQuery.apply(this, arguments) || this;\n }\n\n return ExtendedTemporalQuery;\n }(TemporalQuery);\n\n ExtendedTemporalQuery.prototype.queryFrom = queryFromFunction;\n return new ExtendedTemporalQuery(name);\n}\n\nvar DayOfWeek = function (_TemporalAccessor) {\n _inheritsLoose(DayOfWeek, _TemporalAccessor);\n\n function DayOfWeek(ordinal, name) {\n var _this;\n\n _this = _TemporalAccessor.call(this) || this;\n _this._ordinal = ordinal;\n _this._name = name;\n return _this;\n }\n\n var _proto = DayOfWeek.prototype;\n\n _proto.ordinal = function ordinal() {\n return this._ordinal;\n };\n\n _proto.name = function name() {\n return this._name;\n };\n\n DayOfWeek.values = function values() {\n return ENUMS.slice();\n };\n\n DayOfWeek.valueOf = function valueOf(name) {\n var ordinal = 0;\n\n for (ordinal; ordinal < ENUMS.length; ordinal++) {\n if (ENUMS[ordinal].name() === name) {\n break;\n }\n }\n\n return DayOfWeek.of(ordinal + 1);\n };\n\n DayOfWeek.of = function of(dayOfWeek) {\n if (dayOfWeek < 1 || dayOfWeek > 7) {\n throw new DateTimeException('Invalid value for DayOfWeek: ' + dayOfWeek);\n }\n\n return ENUMS[dayOfWeek - 1];\n };\n\n DayOfWeek.from = function from(temporal) {\n assert(temporal != null, 'temporal', NullPointerException);\n\n if (temporal instanceof DayOfWeek) {\n return temporal;\n }\n\n try {\n return DayOfWeek.of(temporal.get(ChronoField.DAY_OF_WEEK));\n } catch (ex) {\n if (ex instanceof DateTimeException) {\n throw new DateTimeException('Unable to obtain DayOfWeek from TemporalAccessor: ' + temporal + ', type ' + (temporal.constructor != null ? temporal.constructor.name : ''), ex);\n } else {\n throw ex;\n }\n }\n };\n\n _proto.value = function value() {\n return this._ordinal + 1;\n };\n\n _proto.displayName = function displayName(style, locale) {\n throw new IllegalArgumentException('Pattern using (localized) text not implemented yet!');\n };\n\n _proto.isSupported = function isSupported(field) {\n if (field instanceof ChronoField) {\n return field === ChronoField.DAY_OF_WEEK;\n }\n\n return field != null && field.isSupportedBy(this);\n };\n\n _proto.range = function range(field) {\n if (field === ChronoField.DAY_OF_WEEK) {\n return field.range();\n } else if (field instanceof ChronoField) {\n throw new UnsupportedTemporalTypeException('Unsupported field: ' + field);\n }\n\n return field.rangeRefinedBy(this);\n };\n\n _proto.get = function get(field) {\n if (field === ChronoField.DAY_OF_WEEK) {\n return this.value();\n }\n\n return this.range(field).checkValidIntValue(this.getLong(field), field);\n };\n\n _proto.getLong = function getLong(field) {\n if (field === ChronoField.DAY_OF_WEEK) {\n return this.value();\n } else if (field instanceof ChronoField) {\n throw new UnsupportedTemporalTypeException('Unsupported field: ' + field);\n }\n\n return field.getFrom(this);\n };\n\n _proto.plus = function plus(days) {\n var amount = MathUtil.floorMod(days, 7);\n return ENUMS[MathUtil.floorMod(this._ordinal + (amount + 7), 7)];\n };\n\n _proto.minus = function minus(days) {\n return this.plus(-1 * MathUtil.floorMod(days, 7));\n };\n\n _proto.query = function query(_query) {\n if (_query === TemporalQueries.precision()) {\n return ChronoUnit.DAYS;\n } else if (_query === TemporalQueries.localDate() || _query === TemporalQueries.localTime() || _query === TemporalQueries.chronology() || _query === TemporalQueries.zone() || _query === TemporalQueries.zoneId() || _query === TemporalQueries.offset()) {\n return null;\n }\n\n assert(_query != null, 'query', NullPointerException);\n return _query.queryFrom(this);\n };\n\n _proto.adjustInto = function adjustInto(temporal) {\n requireNonNull(temporal, 'temporal');\n return temporal.with(ChronoField.DAY_OF_WEEK, this.value());\n };\n\n _proto.equals = function equals(other) {\n return this === other;\n };\n\n _proto.toString = function toString() {\n return this._name;\n };\n\n _proto.compareTo = function compareTo(other) {\n requireNonNull(other, 'other');\n requireInstance(other, DayOfWeek, 'other');\n return this._ordinal - other._ordinal;\n };\n\n _proto.toJSON = function toJSON() {\n return this.toString();\n };\n\n return DayOfWeek;\n}(TemporalAccessor);\nvar ENUMS;\nfunction _init$4() {\n DayOfWeek.MONDAY = new DayOfWeek(0, 'MONDAY');\n DayOfWeek.TUESDAY = new DayOfWeek(1, 'TUESDAY');\n DayOfWeek.WEDNESDAY = new DayOfWeek(2, 'WEDNESDAY');\n DayOfWeek.THURSDAY = new DayOfWeek(3, 'THURSDAY');\n DayOfWeek.FRIDAY = new DayOfWeek(4, 'FRIDAY');\n DayOfWeek.SATURDAY = new DayOfWeek(5, 'SATURDAY');\n DayOfWeek.SUNDAY = new DayOfWeek(6, 'SUNDAY');\n DayOfWeek.FROM = createTemporalQuery('DayOfWeek.FROM', function (temporal) {\n return DayOfWeek.from(temporal);\n });\n ENUMS = [DayOfWeek.MONDAY, DayOfWeek.TUESDAY, DayOfWeek.WEDNESDAY, DayOfWeek.THURSDAY, DayOfWeek.FRIDAY, DayOfWeek.SATURDAY, DayOfWeek.SUNDAY];\n}\n\nvar Month = function (_TemporalAccessor) {\n _inheritsLoose(Month, _TemporalAccessor);\n\n function Month(value, name) {\n var _this;\n\n _this = _TemporalAccessor.call(this) || this;\n _this._value = MathUtil.safeToInt(value);\n _this._name = name;\n return _this;\n }\n\n var _proto = Month.prototype;\n\n _proto.value = function value() {\n return this._value;\n };\n\n _proto.ordinal = function ordinal() {\n return this._value - 1;\n };\n\n _proto.name = function name() {\n return this._name;\n };\n\n _proto.displayName = function displayName(style, locale) {\n throw new IllegalArgumentException('Pattern using (localized) text not implemented yet!');\n };\n\n _proto.isSupported = function isSupported(field) {\n if (null === field) {\n return false;\n }\n\n if (field instanceof ChronoField) {\n return field === ChronoField.MONTH_OF_YEAR;\n }\n\n return field != null && field.isSupportedBy(this);\n };\n\n _proto.get = function get(field) {\n if (field === ChronoField.MONTH_OF_YEAR) {\n return this.value();\n }\n\n return this.range(field).checkValidIntValue(this.getLong(field), field);\n };\n\n _proto.getLong = function getLong(field) {\n if (field === ChronoField.MONTH_OF_YEAR) {\n return this.value();\n } else if (field instanceof ChronoField) {\n throw new UnsupportedTemporalTypeException('Unsupported field: ' + field);\n }\n\n return field.getFrom(this);\n };\n\n _proto.plus = function plus(months) {\n var amount = MathUtil.intMod(months, 12) + 12;\n var newMonthVal = MathUtil.intMod(this.value() + amount, 12);\n newMonthVal = newMonthVal === 0 ? 12 : newMonthVal;\n return Month.of(newMonthVal);\n };\n\n _proto.minus = function minus(months) {\n return this.plus(-1 * MathUtil.intMod(months, 12));\n };\n\n _proto.length = function length(leapYear) {\n switch (this) {\n case Month.FEBRUARY:\n return leapYear ? 29 : 28;\n\n case Month.APRIL:\n case Month.JUNE:\n case Month.SEPTEMBER:\n case Month.NOVEMBER:\n return 30;\n\n default:\n return 31;\n }\n };\n\n _proto.minLength = function minLength() {\n switch (this) {\n case Month.FEBRUARY:\n return 28;\n\n case Month.APRIL:\n case Month.JUNE:\n case Month.SEPTEMBER:\n case Month.NOVEMBER:\n return 30;\n\n default:\n return 31;\n }\n };\n\n _proto.maxLength = function maxLength() {\n switch (this) {\n case Month.FEBRUARY:\n return 29;\n\n case Month.APRIL:\n case Month.JUNE:\n case Month.SEPTEMBER:\n case Month.NOVEMBER:\n return 30;\n\n default:\n return 31;\n }\n };\n\n _proto.firstDayOfYear = function firstDayOfYear(leapYear) {\n var leap = leapYear ? 1 : 0;\n\n switch (this) {\n case Month.JANUARY:\n return 1;\n\n case Month.FEBRUARY:\n return 32;\n\n case Month.MARCH:\n return 60 + leap;\n\n case Month.APRIL:\n return 91 + leap;\n\n case Month.MAY:\n return 121 + leap;\n\n case Month.JUNE:\n return 152 + leap;\n\n case Month.JULY:\n return 182 + leap;\n\n case Month.AUGUST:\n return 213 + leap;\n\n case Month.SEPTEMBER:\n return 244 + leap;\n\n case Month.OCTOBER:\n return 274 + leap;\n\n case Month.NOVEMBER:\n return 305 + leap;\n\n case Month.DECEMBER:\n default:\n return 335 + leap;\n }\n };\n\n _proto.firstMonthOfQuarter = function firstMonthOfQuarter() {\n switch (this) {\n case Month.JANUARY:\n case Month.FEBRUARY:\n case Month.MARCH:\n return Month.JANUARY;\n\n case Month.APRIL:\n case Month.MAY:\n case Month.JUNE:\n return Month.APRIL;\n\n case Month.JULY:\n case Month.AUGUST:\n case Month.SEPTEMBER:\n return Month.JULY;\n\n case Month.OCTOBER:\n case Month.NOVEMBER:\n case Month.DECEMBER:\n default:\n return Month.OCTOBER;\n }\n };\n\n _proto.query = function query(_query) {\n assert(_query != null, 'query() parameter must not be null', DateTimeException);\n\n if (_query === TemporalQueries.chronology()) {\n return IsoChronology.INSTANCE;\n } else if (_query === TemporalQueries.precision()) {\n return ChronoUnit.MONTHS;\n }\n\n return _TemporalAccessor.prototype.query.call(this, _query);\n };\n\n _proto.toString = function toString() {\n switch (this) {\n case Month.JANUARY:\n return 'JANUARY';\n\n case Month.FEBRUARY:\n return 'FEBRUARY';\n\n case Month.MARCH:\n return 'MARCH';\n\n case Month.APRIL:\n return 'APRIL';\n\n case Month.MAY:\n return 'MAY';\n\n case Month.JUNE:\n return 'JUNE';\n\n case Month.JULY:\n return 'JULY';\n\n case Month.AUGUST:\n return 'AUGUST';\n\n case Month.SEPTEMBER:\n return 'SEPTEMBER';\n\n case Month.OCTOBER:\n return 'OCTOBER';\n\n case Month.NOVEMBER:\n return 'NOVEMBER';\n\n case Month.DECEMBER:\n return 'DECEMBER';\n\n default:\n return 'unknown Month, value: ' + this.value();\n }\n };\n\n _proto.toJSON = function toJSON() {\n return this.toString();\n };\n\n _proto.adjustInto = function adjustInto(temporal) {\n return temporal.with(ChronoField.MONTH_OF_YEAR, this.value());\n };\n\n _proto.compareTo = function compareTo(other) {\n requireNonNull(other, 'other');\n requireInstance(other, Month, 'other');\n return this._value - other._value;\n };\n\n _proto.equals = function equals(other) {\n return this === other;\n };\n\n Month.valueOf = function valueOf(name) {\n var ordinal = 0;\n\n for (ordinal; ordinal < MONTHS.length; ordinal++) {\n if (MONTHS[ordinal].name() === name) {\n break;\n }\n }\n\n return Month.of(ordinal + 1);\n };\n\n Month.values = function values() {\n return MONTHS.slice();\n };\n\n Month.of = function of(month) {\n if (month < 1 || month > 12) {\n assert(false, 'Invalid value for MonthOfYear: ' + month, DateTimeException);\n }\n\n return MONTHS[month - 1];\n };\n\n Month.from = function from(temporal) {\n if (temporal instanceof Month) {\n return temporal;\n }\n\n try {\n return Month.of(temporal.get(ChronoField.MONTH_OF_YEAR));\n } catch (ex) {\n throw new DateTimeException('Unable to obtain Month from TemporalAccessor: ' + temporal + ' of type ' + (temporal && temporal.constructor != null ? temporal.constructor.name : ''), ex);\n }\n };\n\n return Month;\n}(TemporalAccessor);\nvar MONTHS;\nfunction _init$5() {\n Month.JANUARY = new Month(1, 'JANUARY');\n Month.FEBRUARY = new Month(2, 'FEBRUARY');\n Month.MARCH = new Month(3, 'MARCH');\n Month.APRIL = new Month(4, 'APRIL');\n Month.MAY = new Month(5, 'MAY');\n Month.JUNE = new Month(6, 'JUNE');\n Month.JULY = new Month(7, 'JULY');\n Month.AUGUST = new Month(8, 'AUGUST');\n Month.SEPTEMBER = new Month(9, 'SEPTEMBER');\n Month.OCTOBER = new Month(10, 'OCTOBER');\n Month.NOVEMBER = new Month(11, 'NOVEMBER');\n Month.DECEMBER = new Month(12, 'DECEMBER');\n MONTHS = [Month.JANUARY, Month.FEBRUARY, Month.MARCH, Month.APRIL, Month.MAY, Month.JUNE, Month.JULY, Month.AUGUST, Month.SEPTEMBER, Month.OCTOBER, Month.NOVEMBER, Month.DECEMBER];\n}\n\nvar PATTERN = /([-+]?)P(?:([-+]?[0-9]+)Y)?(?:([-+]?[0-9]+)M)?(?:([-+]?[0-9]+)W)?(?:([-+]?[0-9]+)D)?/;\nvar Period = function (_TemporalAmount) {\n _inheritsLoose(Period, _TemporalAmount);\n\n function Period(years, months, days) {\n var _this;\n\n _this = _TemporalAmount.call(this) || this;\n\n var _years = MathUtil.safeToInt(years);\n\n var _months = MathUtil.safeToInt(months);\n\n var _days = MathUtil.safeToInt(days);\n\n if (_years === 0 && _months === 0 && _days === 0) {\n if (!Period.ZERO) {\n _this._years = _years;\n _this._months = _months;\n _this._days = _days;\n Period.ZERO = _assertThisInitialized(_this);\n }\n\n return Period.ZERO || _assertThisInitialized(_this);\n }\n\n _this._years = _years;\n _this._months = _months;\n _this._days = _days;\n return _this;\n }\n\n Period.ofYears = function ofYears(years) {\n return Period.create(years, 0, 0);\n };\n\n Period.ofMonths = function ofMonths(months) {\n return Period.create(0, months, 0);\n };\n\n Period.ofWeeks = function ofWeeks(weeks) {\n return Period.create(0, 0, MathUtil.safeMultiply(weeks, 7));\n };\n\n Period.ofDays = function ofDays(days) {\n return Period.create(0, 0, days);\n };\n\n Period.of = function of(years, months, days) {\n return Period.create(years, months, days);\n };\n\n Period.from = function from(amount) {\n if (amount instanceof Period) {\n return amount;\n }\n\n requireNonNull(amount, 'amount');\n var years = 0;\n var months = 0;\n var days = 0;\n var units = amount.units();\n\n for (var i = 0; i < units.length; i++) {\n var unit = units[i];\n var unitAmount = amount.get(unit);\n\n if (unit === ChronoUnit.YEARS) {\n years = MathUtil.safeToInt(unitAmount);\n } else if (unit === ChronoUnit.MONTHS) {\n months = MathUtil.safeToInt(unitAmount);\n } else if (unit === ChronoUnit.DAYS) {\n days = MathUtil.safeToInt(unitAmount);\n } else {\n throw new DateTimeException('Unit must be Years, Months or Days, but was ' + unit);\n }\n }\n\n return Period.create(years, months, days);\n };\n\n Period.between = function between(startDate, endDate) {\n requireNonNull(startDate, 'startDate');\n requireNonNull(endDate, 'endDate');\n requireInstance(startDate, LocalDate, 'startDate');\n requireInstance(endDate, LocalDate, 'endDate');\n return startDate.until(endDate);\n };\n\n Period.parse = function parse(text) {\n requireNonNull(text, 'text');\n\n try {\n return Period._parse(text);\n } catch (ex) {\n if (ex instanceof ArithmeticException) {\n throw new DateTimeParseException('Text cannot be parsed to a Period', text, 0, ex);\n } else {\n throw ex;\n }\n }\n };\n\n Period._parse = function _parse(text) {\n var matches = PATTERN.exec(text);\n\n if (matches != null) {\n var negate = '-' === matches[1] ? -1 : 1;\n var yearMatch = matches[2];\n var monthMatch = matches[3];\n var weekMatch = matches[4];\n var dayMatch = matches[5];\n\n if (yearMatch != null || monthMatch != null || weekMatch != null || dayMatch != null) {\n var years = Period._parseNumber(text, yearMatch, negate);\n\n var months = Period._parseNumber(text, monthMatch, negate);\n\n var weeks = Period._parseNumber(text, weekMatch, negate);\n\n var days = Period._parseNumber(text, dayMatch, negate);\n\n days = MathUtil.safeAdd(days, MathUtil.safeMultiply(weeks, 7));\n return Period.create(years, months, days);\n }\n }\n\n throw new DateTimeParseException('Text cannot be parsed to a Period', text, 0);\n };\n\n Period._parseNumber = function _parseNumber(text, str, negate) {\n if (str == null) {\n return 0;\n }\n\n var val = MathUtil.parseInt(str);\n return MathUtil.safeMultiply(val, negate);\n };\n\n Period.create = function create(years, months, days) {\n return new Period(years, months, days);\n };\n\n var _proto = Period.prototype;\n\n _proto.units = function units() {\n return [ChronoUnit.YEARS, ChronoUnit.MONTHS, ChronoUnit.DAYS];\n };\n\n _proto.chronology = function chronology() {\n return IsoChronology.INSTANCE;\n };\n\n _proto.get = function get(unit) {\n if (unit === ChronoUnit.YEARS) {\n return this._years;\n }\n\n if (unit === ChronoUnit.MONTHS) {\n return this._months;\n }\n\n if (unit === ChronoUnit.DAYS) {\n return this._days;\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported unit: ' + unit);\n };\n\n _proto.isZero = function isZero() {\n return this === Period.ZERO;\n };\n\n _proto.isNegative = function isNegative() {\n return this._years < 0 || this._months < 0 || this._days < 0;\n };\n\n _proto.years = function years() {\n return this._years;\n };\n\n _proto.months = function months() {\n return this._months;\n };\n\n _proto.days = function days() {\n return this._days;\n };\n\n _proto.withYears = function withYears(years) {\n if (years === this._years) {\n return this;\n }\n\n return Period.create(years, this._months, this._days);\n };\n\n _proto.withMonths = function withMonths(months) {\n if (months === this._months) {\n return this;\n }\n\n return Period.create(this._years, months, this._days);\n };\n\n _proto.withDays = function withDays(days) {\n if (days === this._days) {\n return this;\n }\n\n return Period.create(this._years, this._months, days);\n };\n\n _proto.plus = function plus(amountToAdd) {\n var amount = Period.from(amountToAdd);\n return Period.create(MathUtil.safeAdd(this._years, amount._years), MathUtil.safeAdd(this._months, amount._months), MathUtil.safeAdd(this._days, amount._days));\n };\n\n _proto.plusYears = function plusYears(yearsToAdd) {\n if (yearsToAdd === 0) {\n return this;\n }\n\n return Period.create(MathUtil.safeToInt(MathUtil.safeAdd(this._years, yearsToAdd)), this._months, this._days);\n };\n\n _proto.plusMonths = function plusMonths(monthsToAdd) {\n if (monthsToAdd === 0) {\n return this;\n }\n\n return Period.create(this._years, MathUtil.safeToInt(MathUtil.safeAdd(this._months, monthsToAdd)), this._days);\n };\n\n _proto.plusDays = function plusDays(daysToAdd) {\n if (daysToAdd === 0) {\n return this;\n }\n\n return Period.create(this._years, this._months, MathUtil.safeToInt(MathUtil.safeAdd(this._days, daysToAdd)));\n };\n\n _proto.minus = function minus(amountToSubtract) {\n var amount = Period.from(amountToSubtract);\n return Period.create(MathUtil.safeSubtract(this._years, amount._years), MathUtil.safeSubtract(this._months, amount._months), MathUtil.safeSubtract(this._days, amount._days));\n };\n\n _proto.minusYears = function minusYears(yearsToSubtract) {\n return this.plusYears(-1 * yearsToSubtract);\n };\n\n _proto.minusMonths = function minusMonths(monthsToSubtract) {\n return this.plusMonths(-1 * monthsToSubtract);\n };\n\n _proto.minusDays = function minusDays(daysToSubtract) {\n return this.plusDays(-1 * daysToSubtract);\n };\n\n _proto.multipliedBy = function multipliedBy(scalar) {\n if (this === Period.ZERO || scalar === 1) {\n return this;\n }\n\n return Period.create(MathUtil.safeMultiply(this._years, scalar), MathUtil.safeMultiply(this._months, scalar), MathUtil.safeMultiply(this._days, scalar));\n };\n\n _proto.negated = function negated() {\n return this.multipliedBy(-1);\n };\n\n _proto.normalized = function normalized() {\n var totalMonths = this.toTotalMonths();\n var splitYears = MathUtil.intDiv(totalMonths, 12);\n var splitMonths = MathUtil.intMod(totalMonths, 12);\n\n if (splitYears === this._years && splitMonths === this._months) {\n return this;\n }\n\n return Period.create(MathUtil.safeToInt(splitYears), splitMonths, this._days);\n };\n\n _proto.toTotalMonths = function toTotalMonths() {\n return this._years * 12 + this._months;\n };\n\n _proto.addTo = function addTo(temporal) {\n requireNonNull(temporal, 'temporal');\n\n if (this._years !== 0) {\n if (this._months !== 0) {\n temporal = temporal.plus(this.toTotalMonths(), ChronoUnit.MONTHS);\n } else {\n temporal = temporal.plus(this._years, ChronoUnit.YEARS);\n }\n } else if (this._months !== 0) {\n temporal = temporal.plus(this._months, ChronoUnit.MONTHS);\n }\n\n if (this._days !== 0) {\n temporal = temporal.plus(this._days, ChronoUnit.DAYS);\n }\n\n return temporal;\n };\n\n _proto.subtractFrom = function subtractFrom(temporal) {\n requireNonNull(temporal, 'temporal');\n\n if (this._years !== 0) {\n if (this._months !== 0) {\n temporal = temporal.minus(this.toTotalMonths(), ChronoUnit.MONTHS);\n } else {\n temporal = temporal.minus(this._years, ChronoUnit.YEARS);\n }\n } else if (this._months !== 0) {\n temporal = temporal.minus(this._months, ChronoUnit.MONTHS);\n }\n\n if (this._days !== 0) {\n temporal = temporal.minus(this._days, ChronoUnit.DAYS);\n }\n\n return temporal;\n };\n\n _proto.equals = function equals(obj) {\n if (this === obj) {\n return true;\n }\n\n if (obj instanceof Period) {\n var other = obj;\n return this._years === other._years && this._months === other._months && this._days === other._days;\n }\n\n return false;\n };\n\n _proto.hashCode = function hashCode() {\n return MathUtil.hashCode(this._years, this._months, this._days);\n };\n\n _proto.toString = function toString() {\n if (this === Period.ZERO) {\n return 'P0D';\n } else {\n var buf = 'P';\n\n if (this._years !== 0) {\n buf += '' + this._years + 'Y';\n }\n\n if (this._months !== 0) {\n buf += '' + this._months + 'M';\n }\n\n if (this._days !== 0) {\n buf += '' + this._days + 'D';\n }\n\n return buf;\n }\n };\n\n _proto.toJSON = function toJSON() {\n return this.toString();\n };\n\n return Period;\n}(TemporalAmount);\nfunction _init$6() {\n Period.ofDays(0);\n}\n\n/*\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar ParsePosition = function () {\n function ParsePosition(index) {\n this._index = index;\n this._errorIndex = -1;\n }\n\n var _proto = ParsePosition.prototype;\n\n _proto.getIndex = function getIndex() {\n return this._index;\n };\n\n _proto.setIndex = function setIndex(index) {\n this._index = index;\n };\n\n _proto.getErrorIndex = function getErrorIndex() {\n return this._errorIndex;\n };\n\n _proto.setErrorIndex = function setErrorIndex(errorIndex) {\n this._errorIndex = errorIndex;\n };\n\n return ParsePosition;\n}();\n\n/*\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar EnumMap = function () {\n function EnumMap() {\n this._map = {};\n }\n\n var _proto = EnumMap.prototype;\n\n _proto.putAll = function putAll(otherMap) {\n for (var key in otherMap._map) {\n this._map[key] = otherMap._map[key];\n }\n\n return this;\n };\n\n _proto.containsKey = function containsKey(key) {\n return this._map.hasOwnProperty(key.name()) && this.get(key) !== undefined;\n };\n\n _proto.get = function get(key) {\n return this._map[key.name()];\n };\n\n _proto.put = function put(key, val) {\n return this.set(key, val);\n };\n\n _proto.set = function set(key, val) {\n this._map[key.name()] = val;\n return this;\n };\n\n _proto.retainAll = function retainAll(keyList) {\n var map = {};\n\n for (var i = 0; i < keyList.length; i++) {\n var key = keyList[i].name();\n map[key] = this._map[key];\n }\n\n this._map = map;\n return this;\n };\n\n _proto.remove = function remove(key) {\n var keyName = key.name();\n var val = this._map[keyName];\n this._map[keyName] = undefined;\n return val;\n };\n\n _proto.keySet = function keySet() {\n return this._map;\n };\n\n _proto.clear = function clear() {\n this._map = {};\n };\n\n return EnumMap;\n}();\n\nvar ResolverStyle = function (_Enum) {\n _inheritsLoose(ResolverStyle, _Enum);\n\n function ResolverStyle() {\n return _Enum.apply(this, arguments) || this;\n }\n\n return ResolverStyle;\n}(Enum);\nResolverStyle.STRICT = new ResolverStyle('STRICT');\nResolverStyle.SMART = new ResolverStyle('SMART');\nResolverStyle.LENIENT = new ResolverStyle('LENIENT');\n\n/*\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar TemporalAdjuster = function () {\n function TemporalAdjuster() {}\n\n var _proto = TemporalAdjuster.prototype;\n\n _proto.adjustInto = function adjustInto(temporal) {\n abstractMethodFail('adjustInto');\n };\n\n return TemporalAdjuster;\n}();\n\nvar Temporal = function (_TemporalAccessor) {\n _inheritsLoose(Temporal, _TemporalAccessor);\n\n function Temporal() {\n return _TemporalAccessor.apply(this, arguments) || this;\n }\n\n var _proto = Temporal.prototype;\n\n _proto.isSupported = function isSupported(unit) {\n abstractMethodFail('isSupported');\n };\n\n _proto.minus = function minus(p1, p2) {\n if (arguments.length < 2) {\n return this.minusAmount(p1);\n } else {\n return this.minusAmountUnit(p1, p2);\n }\n };\n\n _proto.minusAmount = function minusAmount(amount) {\n abstractMethodFail('minusAmount');\n };\n\n _proto.minusAmountUnit = function minusAmountUnit(amountToSubtract, unit) {\n abstractMethodFail('minusAmountUnit');\n };\n\n _proto.plus = function plus(p1, p2) {\n if (arguments.length < 2) {\n return this.plusAmount(p1);\n } else {\n return this.plusAmountUnit(p1, p2);\n }\n };\n\n _proto.plusAmount = function plusAmount(amount) {\n abstractMethodFail('plusAmount');\n };\n\n _proto.plusAmountUnit = function plusAmountUnit(amountToAdd, unit) {\n abstractMethodFail('plusAmountUnit');\n };\n\n _proto.until = function until(endTemporal, unit) {\n abstractMethodFail('until');\n };\n\n _proto.with = function _with(p1, p2) {\n if (arguments.length < 2) {\n return this.withAdjuster(p1);\n } else {\n return this.withFieldValue(p1, p2);\n }\n };\n\n _proto.withAdjuster = function withAdjuster(adjuster) {\n abstractMethodFail('withAdjuster');\n };\n\n _proto.withFieldValue = function withFieldValue(field, newValue) {\n abstractMethodFail('withFieldValue');\n };\n\n return Temporal;\n}(TemporalAccessor);\n\nvar DefaultInterfaceTemporal = function (_Temporal) {\n _inheritsLoose(DefaultInterfaceTemporal, _Temporal);\n\n function DefaultInterfaceTemporal() {\n return _Temporal.apply(this, arguments) || this;\n }\n\n var _proto = DefaultInterfaceTemporal.prototype;\n\n _proto.withAdjuster = function withAdjuster(adjuster) {\n requireNonNull(adjuster, 'adjuster');\n requireInstance(adjuster, TemporalAdjuster, 'adjuster');\n return adjuster.adjustInto(this);\n };\n\n _proto.plusAmount = function plusAmount(amount) {\n requireNonNull(amount, 'amount');\n requireInstance(amount, TemporalAmount, 'amount');\n return amount.addTo(this);\n };\n\n _proto.minusAmount = function minusAmount(amount) {\n requireNonNull(amount, 'amount');\n requireInstance(amount, TemporalAmount, 'amount');\n return amount.subtractFrom(this);\n };\n\n _proto.minusAmountUnit = function minusAmountUnit(amountToSubtract, unit) {\n requireNonNull(amountToSubtract, 'amountToSubtract');\n requireNonNull(unit, 'unit');\n requireInstance(unit, TemporalUnit, 'unit');\n return amountToSubtract === MIN_SAFE_INTEGER ? this.plusAmountUnit(MAX_SAFE_INTEGER, unit).plusAmountUnit(1, unit) : this.plusAmount(-amountToSubtract, unit);\n };\n\n return DefaultInterfaceTemporal;\n}(Temporal);\n\nvar ChronoLocalDate = function (_DefaultInterfaceTemp) {\n _inheritsLoose(ChronoLocalDate, _DefaultInterfaceTemp);\n\n function ChronoLocalDate() {\n return _DefaultInterfaceTemp.apply(this, arguments) || this;\n }\n\n var _proto = ChronoLocalDate.prototype;\n\n _proto.isSupported = function isSupported(fieldOrUnit) {\n if (fieldOrUnit instanceof ChronoField) {\n return fieldOrUnit.isDateBased();\n } else if (fieldOrUnit instanceof ChronoUnit) {\n return fieldOrUnit.isDateBased();\n }\n\n return fieldOrUnit != null && fieldOrUnit.isSupportedBy(this);\n };\n\n _proto.query = function query(_query) {\n if (_query === TemporalQueries.chronology()) {\n return this.chronology();\n } else if (_query === TemporalQueries.precision()) {\n return ChronoUnit.DAYS;\n } else if (_query === TemporalQueries.localDate()) {\n return LocalDate.ofEpochDay(this.toEpochDay());\n } else if (_query === TemporalQueries.localTime() || _query === TemporalQueries.zone() || _query === TemporalQueries.zoneId() || _query === TemporalQueries.offset()) {\n return null;\n }\n\n return _DefaultInterfaceTemp.prototype.query.call(this, _query);\n };\n\n _proto.adjustInto = function adjustInto(temporal) {\n return temporal.with(ChronoField.EPOCH_DAY, this.toEpochDay());\n };\n\n _proto.format = function format(formatter) {\n requireNonNull(formatter, 'formatter');\n requireInstance(formatter, DateTimeFormatter, 'formatter');\n return formatter.format(this);\n };\n\n return ChronoLocalDate;\n}(DefaultInterfaceTemporal);\n\n/*\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar StringUtil = function () {\n function StringUtil() {}\n\n StringUtil.startsWith = function startsWith(text, pattern) {\n return text.indexOf(pattern) === 0;\n };\n\n StringUtil.hashCode = function hashCode(text) {\n var len = text.length;\n\n if (len === 0) {\n return 0;\n }\n\n var hash = 0;\n\n for (var i = 0; i < len; i++) {\n var chr = text.charCodeAt(i);\n hash = (hash << 5) - hash + chr;\n hash |= 0;\n }\n\n return MathUtil.smi(hash);\n };\n\n return StringUtil;\n}();\n\n/*\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar ZoneId = function () {\n function ZoneId() {}\n\n ZoneId.systemDefault = function systemDefault() {\n throw new DateTimeException('not supported operation');\n };\n\n ZoneId.getAvailableZoneIds = function getAvailableZoneIds() {\n throw new DateTimeException('not supported operation');\n };\n\n ZoneId.of = function of(zoneId) {\n throw new DateTimeException('not supported operation' + zoneId);\n };\n\n ZoneId.ofOffset = function ofOffset(prefix, offset) {\n throw new DateTimeException('not supported operation' + prefix + offset);\n };\n\n ZoneId.from = function from(temporal) {\n throw new DateTimeException('not supported operation' + temporal);\n };\n\n var _proto = ZoneId.prototype;\n\n _proto.id = function id() {\n abstractMethodFail('ZoneId.id');\n };\n\n _proto.rules = function rules() {\n abstractMethodFail('ZoneId.rules');\n };\n\n _proto.normalized = function normalized() {\n var rules = this.rules();\n\n if (rules.isFixedOffset()) {\n return rules.offset(Instant.EPOCH);\n }\n\n return this;\n };\n\n _proto.equals = function equals(other) {\n if (this === other) {\n return true;\n }\n\n if (other instanceof ZoneId) {\n return this.id() === other.id();\n }\n\n return false;\n };\n\n _proto.hashCode = function hashCode() {\n return StringUtil.hashCode(this.id());\n };\n\n _proto.toString = function toString() {\n return this.id();\n };\n\n _proto.toJSON = function toJSON() {\n return this.toString();\n };\n\n return ZoneId;\n}();\n\nvar ZoneRules = function () {\n function ZoneRules() {}\n\n ZoneRules.of = function of(offset) {\n requireNonNull(offset, 'offset');\n return new Fixed(offset);\n };\n\n var _proto = ZoneRules.prototype;\n\n _proto.isFixedOffset = function isFixedOffset() {\n abstractMethodFail('ZoneRules.isFixedOffset');\n };\n\n _proto.offset = function offset(instantOrLocalDateTime) {\n if (instantOrLocalDateTime instanceof Instant) {\n return this.offsetOfInstant(instantOrLocalDateTime);\n } else {\n return this.offsetOfLocalDateTime(instantOrLocalDateTime);\n }\n };\n\n _proto.offsetOfInstant = function offsetOfInstant(instant) {\n abstractMethodFail('ZoneRules.offsetInstant');\n };\n\n _proto.offsetOfEpochMilli = function offsetOfEpochMilli(epochMilli) {\n abstractMethodFail('ZoneRules.offsetOfEpochMilli');\n };\n\n _proto.offsetOfLocalDateTime = function offsetOfLocalDateTime(localDateTime) {\n abstractMethodFail('ZoneRules.offsetLocalDateTime');\n };\n\n _proto.validOffsets = function validOffsets(localDateTime) {\n abstractMethodFail('ZoneRules.validOffsets');\n };\n\n _proto.transition = function transition(localDateTime) {\n abstractMethodFail('ZoneRules.transition');\n };\n\n _proto.standardOffset = function standardOffset(instant) {\n abstractMethodFail('ZoneRules.standardOffset');\n };\n\n _proto.daylightSavings = function daylightSavings(instant) {\n abstractMethodFail('ZoneRules.daylightSavings');\n };\n\n _proto.isDaylightSavings = function isDaylightSavings(instant) {\n abstractMethodFail('ZoneRules.isDaylightSavings');\n };\n\n _proto.isValidOffset = function isValidOffset(localDateTime, offset) {\n abstractMethodFail('ZoneRules.isValidOffset');\n };\n\n _proto.nextTransition = function nextTransition(instant) {\n abstractMethodFail('ZoneRules.nextTransition');\n };\n\n _proto.previousTransition = function previousTransition(instant) {\n abstractMethodFail('ZoneRules.previousTransition');\n };\n\n _proto.transitions = function transitions() {\n abstractMethodFail('ZoneRules.transitions');\n };\n\n _proto.transitionRules = function transitionRules() {\n abstractMethodFail('ZoneRules.transitionRules');\n };\n\n _proto.toString = function toString() {\n abstractMethodFail('ZoneRules.toString');\n };\n\n _proto.toJSON = function toJSON() {\n return this.toString();\n };\n\n return ZoneRules;\n}();\n\nvar Fixed = function (_ZoneRules) {\n _inheritsLoose(Fixed, _ZoneRules);\n\n function Fixed(offset) {\n var _this;\n\n _this = _ZoneRules.call(this) || this;\n _this._offset = offset;\n return _this;\n }\n\n var _proto2 = Fixed.prototype;\n\n _proto2.isFixedOffset = function isFixedOffset() {\n return true;\n };\n\n _proto2.offsetOfInstant = function offsetOfInstant() {\n return this._offset;\n };\n\n _proto2.offsetOfEpochMilli = function offsetOfEpochMilli() {\n return this._offset;\n };\n\n _proto2.offsetOfLocalDateTime = function offsetOfLocalDateTime() {\n return this._offset;\n };\n\n _proto2.validOffsets = function validOffsets() {\n return [this._offset];\n };\n\n _proto2.transition = function transition() {\n return null;\n };\n\n _proto2.standardOffset = function standardOffset() {\n return this._offset;\n };\n\n _proto2.daylightSavings = function daylightSavings() {\n return Duration.ZERO;\n };\n\n _proto2.isDaylightSavings = function isDaylightSavings() {\n return false;\n };\n\n _proto2.isValidOffset = function isValidOffset(localDateTime, offset) {\n return this._offset.equals(offset);\n };\n\n _proto2.nextTransition = function nextTransition() {\n return null;\n };\n\n _proto2.previousTransition = function previousTransition() {\n return null;\n };\n\n _proto2.transitions = function transitions() {\n return [];\n };\n\n _proto2.transitionRules = function transitionRules() {\n return [];\n };\n\n _proto2.equals = function equals(other) {\n if (this === other) {\n return true;\n }\n\n if (other instanceof Fixed) {\n return this._offset.equals(other._offset);\n }\n\n return false;\n };\n\n _proto2.toString = function toString() {\n return 'FixedRules:' + this._offset.toString();\n };\n\n return Fixed;\n}(ZoneRules);\n\nvar SECONDS_CACHE = {};\nvar ID_CACHE = {};\nvar ZoneOffset = function (_ZoneId) {\n _inheritsLoose(ZoneOffset, _ZoneId);\n\n function ZoneOffset(totalSeconds) {\n var _this;\n\n _this = _ZoneId.call(this) || this;\n\n ZoneOffset._validateTotalSeconds(totalSeconds);\n\n _this._totalSeconds = MathUtil.safeToInt(totalSeconds);\n _this._rules = ZoneRules.of(_assertThisInitialized(_this));\n _this._id = ZoneOffset._buildId(totalSeconds);\n return _this;\n }\n\n var _proto = ZoneOffset.prototype;\n\n _proto.totalSeconds = function totalSeconds() {\n return this._totalSeconds;\n };\n\n _proto.id = function id() {\n return this._id;\n };\n\n ZoneOffset._buildId = function _buildId(totalSeconds) {\n if (totalSeconds === 0) {\n return 'Z';\n } else {\n var absTotalSeconds = Math.abs(totalSeconds);\n var absHours = MathUtil.intDiv(absTotalSeconds, LocalTime.SECONDS_PER_HOUR);\n var absMinutes = MathUtil.intMod(MathUtil.intDiv(absTotalSeconds, LocalTime.SECONDS_PER_MINUTE), LocalTime.MINUTES_PER_HOUR);\n var buf = '' + (totalSeconds < 0 ? '-' : '+') + (absHours < 10 ? '0' : '') + absHours + (absMinutes < 10 ? ':0' : ':') + absMinutes;\n var absSeconds = MathUtil.intMod(absTotalSeconds, LocalTime.SECONDS_PER_MINUTE);\n\n if (absSeconds !== 0) {\n buf += (absSeconds < 10 ? ':0' : ':') + absSeconds;\n }\n\n return buf;\n }\n };\n\n ZoneOffset._validateTotalSeconds = function _validateTotalSeconds(totalSeconds) {\n if (Math.abs(totalSeconds) > ZoneOffset.MAX_SECONDS) {\n throw new DateTimeException('Zone offset not in valid range: -18:00 to +18:00');\n }\n };\n\n ZoneOffset._validate = function _validate(hours, minutes, seconds) {\n if (hours < -18 || hours > 18) {\n throw new DateTimeException('Zone offset hours not in valid range: value ' + hours + ' is not in the range -18 to 18');\n }\n\n if (hours > 0) {\n if (minutes < 0 || seconds < 0) {\n throw new DateTimeException('Zone offset minutes and seconds must be positive because hours is positive');\n }\n } else if (hours < 0) {\n if (minutes > 0 || seconds > 0) {\n throw new DateTimeException('Zone offset minutes and seconds must be negative because hours is negative');\n }\n } else if (minutes > 0 && seconds < 0 || minutes < 0 && seconds > 0) {\n throw new DateTimeException('Zone offset minutes and seconds must have the same sign');\n }\n\n if (Math.abs(minutes) > 59) {\n throw new DateTimeException('Zone offset minutes not in valid range: abs(value) ' + Math.abs(minutes) + ' is not in the range 0 to 59');\n }\n\n if (Math.abs(seconds) > 59) {\n throw new DateTimeException('Zone offset seconds not in valid range: abs(value) ' + Math.abs(seconds) + ' is not in the range 0 to 59');\n }\n\n if (Math.abs(hours) === 18 && (Math.abs(minutes) > 0 || Math.abs(seconds) > 0)) {\n throw new DateTimeException('Zone offset not in valid range: -18:00 to +18:00');\n }\n };\n\n ZoneOffset.of = function of(offsetId) {\n requireNonNull(offsetId, 'offsetId');\n var offset = ID_CACHE[offsetId];\n\n if (offset != null) {\n return offset;\n }\n\n var hours, minutes, seconds;\n\n switch (offsetId.length) {\n case 2:\n offsetId = offsetId[0] + '0' + offsetId[1];\n\n case 3:\n hours = ZoneOffset._parseNumber(offsetId, 1, false);\n minutes = 0;\n seconds = 0;\n break;\n\n case 5:\n hours = ZoneOffset._parseNumber(offsetId, 1, false);\n minutes = ZoneOffset._parseNumber(offsetId, 3, false);\n seconds = 0;\n break;\n\n case 6:\n hours = ZoneOffset._parseNumber(offsetId, 1, false);\n minutes = ZoneOffset._parseNumber(offsetId, 4, true);\n seconds = 0;\n break;\n\n case 7:\n hours = ZoneOffset._parseNumber(offsetId, 1, false);\n minutes = ZoneOffset._parseNumber(offsetId, 3, false);\n seconds = ZoneOffset._parseNumber(offsetId, 5, false);\n break;\n\n case 9:\n hours = ZoneOffset._parseNumber(offsetId, 1, false);\n minutes = ZoneOffset._parseNumber(offsetId, 4, true);\n seconds = ZoneOffset._parseNumber(offsetId, 7, true);\n break;\n\n default:\n throw new DateTimeException('Invalid ID for ZoneOffset, invalid format: ' + offsetId);\n }\n\n var first = offsetId[0];\n\n if (first !== '+' && first !== '-') {\n throw new DateTimeException('Invalid ID for ZoneOffset, plus/minus not found when expected: ' + offsetId);\n }\n\n if (first === '-') {\n return ZoneOffset.ofHoursMinutesSeconds(-hours, -minutes, -seconds);\n } else {\n return ZoneOffset.ofHoursMinutesSeconds(hours, minutes, seconds);\n }\n };\n\n ZoneOffset._parseNumber = function _parseNumber(offsetId, pos, precededByColon) {\n if (precededByColon && offsetId[pos - 1] !== ':') {\n throw new DateTimeException('Invalid ID for ZoneOffset, colon not found when expected: ' + offsetId);\n }\n\n var ch1 = offsetId[pos];\n var ch2 = offsetId[pos + 1];\n\n if (ch1 < '0' || ch1 > '9' || ch2 < '0' || ch2 > '9') {\n throw new DateTimeException('Invalid ID for ZoneOffset, non numeric characters found: ' + offsetId);\n }\n\n return (ch1.charCodeAt(0) - 48) * 10 + (ch2.charCodeAt(0) - 48);\n };\n\n ZoneOffset.ofHours = function ofHours(hours) {\n return ZoneOffset.ofHoursMinutesSeconds(hours, 0, 0);\n };\n\n ZoneOffset.ofHoursMinutes = function ofHoursMinutes(hours, minutes) {\n return ZoneOffset.ofHoursMinutesSeconds(hours, minutes, 0);\n };\n\n ZoneOffset.ofHoursMinutesSeconds = function ofHoursMinutesSeconds(hours, minutes, seconds) {\n ZoneOffset._validate(hours, minutes, seconds);\n\n var totalSeconds = hours * LocalTime.SECONDS_PER_HOUR + minutes * LocalTime.SECONDS_PER_MINUTE + seconds;\n return ZoneOffset.ofTotalSeconds(totalSeconds);\n };\n\n ZoneOffset.ofTotalMinutes = function ofTotalMinutes(totalMinutes) {\n var totalSeconds = totalMinutes * LocalTime.SECONDS_PER_MINUTE;\n return ZoneOffset.ofTotalSeconds(totalSeconds);\n };\n\n ZoneOffset.ofTotalSeconds = function ofTotalSeconds(totalSeconds) {\n if (totalSeconds % (15 * LocalTime.SECONDS_PER_MINUTE) === 0) {\n var totalSecs = totalSeconds;\n var result = SECONDS_CACHE[totalSecs];\n\n if (result == null) {\n result = new ZoneOffset(totalSeconds);\n SECONDS_CACHE[totalSecs] = result;\n ID_CACHE[result.id()] = result;\n }\n\n return result;\n } else {\n return new ZoneOffset(totalSeconds);\n }\n };\n\n _proto.rules = function rules() {\n return this._rules;\n };\n\n _proto.get = function get(field) {\n return this.getLong(field);\n };\n\n _proto.getLong = function getLong(field) {\n if (field === ChronoField.OFFSET_SECONDS) {\n return this._totalSeconds;\n } else if (field instanceof ChronoField) {\n throw new DateTimeException('Unsupported field: ' + field);\n }\n\n return field.getFrom(this);\n };\n\n _proto.query = function query(_query) {\n requireNonNull(_query, 'query');\n\n if (_query === TemporalQueries.offset() || _query === TemporalQueries.zone()) {\n return this;\n } else if (_query === TemporalQueries.localDate() || _query === TemporalQueries.localTime() || _query === TemporalQueries.precision() || _query === TemporalQueries.chronology() || _query === TemporalQueries.zoneId()) {\n return null;\n }\n\n return _query.queryFrom(this);\n };\n\n _proto.adjustInto = function adjustInto(temporal) {\n return temporal.with(ChronoField.OFFSET_SECONDS, this._totalSeconds);\n };\n\n _proto.compareTo = function compareTo(other) {\n requireNonNull(other, 'other');\n return other._totalSeconds - this._totalSeconds;\n };\n\n _proto.equals = function equals(obj) {\n if (this === obj) {\n return true;\n }\n\n if (obj instanceof ZoneOffset) {\n return this._totalSeconds === obj._totalSeconds;\n }\n\n return false;\n };\n\n _proto.hashCode = function hashCode() {\n return this._totalSeconds;\n };\n\n _proto.toString = function toString() {\n return this._id;\n };\n\n return ZoneOffset;\n}(ZoneId);\nfunction _init$7() {\n ZoneOffset.MAX_SECONDS = 18 * LocalTime.SECONDS_PER_HOUR;\n ZoneOffset.UTC = ZoneOffset.ofTotalSeconds(0);\n ZoneOffset.MIN = ZoneOffset.ofTotalSeconds(-ZoneOffset.MAX_SECONDS);\n ZoneOffset.MAX = ZoneOffset.ofTotalSeconds(ZoneOffset.MAX_SECONDS);\n}\n\nvar DateTimeBuilder = function (_TemporalAccessor) {\n _inheritsLoose(DateTimeBuilder, _TemporalAccessor);\n\n DateTimeBuilder.create = function create(field, value) {\n var dtb = new DateTimeBuilder();\n\n dtb._addFieldValue(field, value);\n\n return dtb;\n };\n\n function DateTimeBuilder() {\n var _this;\n\n _this = _TemporalAccessor.call(this) || this;\n _this.fieldValues = new EnumMap();\n _this.chrono = null;\n _this.zone = null;\n _this.date = null;\n _this.time = null;\n _this.leapSecond = false;\n _this.excessDays = null;\n return _this;\n }\n\n var _proto = DateTimeBuilder.prototype;\n\n _proto.getFieldValue0 = function getFieldValue0(field) {\n return this.fieldValues.get(field);\n };\n\n _proto._addFieldValue = function _addFieldValue(field, value) {\n requireNonNull(field, 'field');\n var old = this.getFieldValue0(field);\n\n if (old != null && old !== value) {\n throw new DateTimeException('Conflict found: ' + field + ' ' + old + ' differs from ' + field + ' ' + value + ': ' + this);\n }\n\n return this._putFieldValue0(field, value);\n };\n\n _proto._putFieldValue0 = function _putFieldValue0(field, value) {\n this.fieldValues.put(field, value);\n return this;\n };\n\n _proto.resolve = function resolve(resolverStyle, resolverFields) {\n if (resolverFields != null) {\n this.fieldValues.retainAll(resolverFields);\n }\n\n this._mergeDate(resolverStyle);\n\n this._mergeTime(resolverStyle);\n\n this._resolveTimeInferZeroes(resolverStyle);\n\n if (this.excessDays != null && this.excessDays.isZero() === false && this.date != null && this.time != null) {\n this.date = this.date.plus(this.excessDays);\n this.excessDays = Period.ZERO;\n }\n\n this._resolveInstant();\n\n return this;\n };\n\n _proto._mergeDate = function _mergeDate(resolverStyle) {\n this._checkDate(IsoChronology.INSTANCE.resolveDate(this.fieldValues, resolverStyle));\n };\n\n _proto._checkDate = function _checkDate(date) {\n if (date != null) {\n this._addObject(date);\n\n for (var fieldName in this.fieldValues.keySet()) {\n var field = ChronoField.byName(fieldName);\n\n if (field) {\n if (this.fieldValues.get(field) !== undefined) {\n if (field.isDateBased()) {\n var val1 = void 0;\n\n try {\n val1 = date.getLong(field);\n } catch (ex) {\n if (ex instanceof DateTimeException) {\n continue;\n } else {\n throw ex;\n }\n }\n\n var val2 = this.fieldValues.get(field);\n\n if (val1 !== val2) {\n throw new DateTimeException('Conflict found: Field ' + field + ' ' + val1 + ' differs from ' + field + ' ' + val2 + ' derived from ' + date);\n }\n }\n }\n }\n }\n }\n };\n\n _proto._mergeTime = function _mergeTime(resolverStyle) {\n if (this.fieldValues.containsKey(ChronoField.CLOCK_HOUR_OF_DAY)) {\n var ch = this.fieldValues.remove(ChronoField.CLOCK_HOUR_OF_DAY);\n\n if (resolverStyle !== ResolverStyle.LENIENT) {\n if (resolverStyle === ResolverStyle.SMART && ch === 0) ; else {\n ChronoField.CLOCK_HOUR_OF_DAY.checkValidValue(ch);\n }\n }\n\n this._addFieldValue(ChronoField.HOUR_OF_DAY, ch === 24 ? 0 : ch);\n }\n\n if (this.fieldValues.containsKey(ChronoField.CLOCK_HOUR_OF_AMPM)) {\n var _ch = this.fieldValues.remove(ChronoField.CLOCK_HOUR_OF_AMPM);\n\n if (resolverStyle !== ResolverStyle.LENIENT) {\n if (resolverStyle === ResolverStyle.SMART && _ch === 0) ; else {\n ChronoField.CLOCK_HOUR_OF_AMPM.checkValidValue(_ch);\n }\n }\n\n this._addFieldValue(ChronoField.HOUR_OF_AMPM, _ch === 12 ? 0 : _ch);\n }\n\n if (resolverStyle !== ResolverStyle.LENIENT) {\n if (this.fieldValues.containsKey(ChronoField.AMPM_OF_DAY)) {\n ChronoField.AMPM_OF_DAY.checkValidValue(this.fieldValues.get(ChronoField.AMPM_OF_DAY));\n }\n\n if (this.fieldValues.containsKey(ChronoField.HOUR_OF_AMPM)) {\n ChronoField.HOUR_OF_AMPM.checkValidValue(this.fieldValues.get(ChronoField.HOUR_OF_AMPM));\n }\n }\n\n if (this.fieldValues.containsKey(ChronoField.AMPM_OF_DAY) && this.fieldValues.containsKey(ChronoField.HOUR_OF_AMPM)) {\n var ap = this.fieldValues.remove(ChronoField.AMPM_OF_DAY);\n var hap = this.fieldValues.remove(ChronoField.HOUR_OF_AMPM);\n\n this._addFieldValue(ChronoField.HOUR_OF_DAY, ap * 12 + hap);\n }\n\n if (this.fieldValues.containsKey(ChronoField.NANO_OF_DAY)) {\n var nod = this.fieldValues.remove(ChronoField.NANO_OF_DAY);\n\n if (resolverStyle !== ResolverStyle.LENIENT) {\n ChronoField.NANO_OF_DAY.checkValidValue(nod);\n }\n\n this._addFieldValue(ChronoField.SECOND_OF_DAY, MathUtil.intDiv(nod, 1000000000));\n\n this._addFieldValue(ChronoField.NANO_OF_SECOND, MathUtil.intMod(nod, 1000000000));\n }\n\n if (this.fieldValues.containsKey(ChronoField.MICRO_OF_DAY)) {\n var cod = this.fieldValues.remove(ChronoField.MICRO_OF_DAY);\n\n if (resolverStyle !== ResolverStyle.LENIENT) {\n ChronoField.MICRO_OF_DAY.checkValidValue(cod);\n }\n\n this._addFieldValue(ChronoField.SECOND_OF_DAY, MathUtil.intDiv(cod, 1000000));\n\n this._addFieldValue(ChronoField.MICRO_OF_SECOND, MathUtil.intMod(cod, 1000000));\n }\n\n if (this.fieldValues.containsKey(ChronoField.MILLI_OF_DAY)) {\n var lod = this.fieldValues.remove(ChronoField.MILLI_OF_DAY);\n\n if (resolverStyle !== ResolverStyle.LENIENT) {\n ChronoField.MILLI_OF_DAY.checkValidValue(lod);\n }\n\n this._addFieldValue(ChronoField.SECOND_OF_DAY, MathUtil.intDiv(lod, 1000));\n\n this._addFieldValue(ChronoField.MILLI_OF_SECOND, MathUtil.intMod(lod, 1000));\n }\n\n if (this.fieldValues.containsKey(ChronoField.SECOND_OF_DAY)) {\n var sod = this.fieldValues.remove(ChronoField.SECOND_OF_DAY);\n\n if (resolverStyle !== ResolverStyle.LENIENT) {\n ChronoField.SECOND_OF_DAY.checkValidValue(sod);\n }\n\n this._addFieldValue(ChronoField.HOUR_OF_DAY, MathUtil.intDiv(sod, 3600));\n\n this._addFieldValue(ChronoField.MINUTE_OF_HOUR, MathUtil.intMod(MathUtil.intDiv(sod, 60), 60));\n\n this._addFieldValue(ChronoField.SECOND_OF_MINUTE, MathUtil.intMod(sod, 60));\n }\n\n if (this.fieldValues.containsKey(ChronoField.MINUTE_OF_DAY)) {\n var mod = this.fieldValues.remove(ChronoField.MINUTE_OF_DAY);\n\n if (resolverStyle !== ResolverStyle.LENIENT) {\n ChronoField.MINUTE_OF_DAY.checkValidValue(mod);\n }\n\n this._addFieldValue(ChronoField.HOUR_OF_DAY, MathUtil.intDiv(mod, 60));\n\n this._addFieldValue(ChronoField.MINUTE_OF_HOUR, MathUtil.intMod(mod, 60));\n }\n\n if (resolverStyle !== ResolverStyle.LENIENT) {\n if (this.fieldValues.containsKey(ChronoField.MILLI_OF_SECOND)) {\n ChronoField.MILLI_OF_SECOND.checkValidValue(this.fieldValues.get(ChronoField.MILLI_OF_SECOND));\n }\n\n if (this.fieldValues.containsKey(ChronoField.MICRO_OF_SECOND)) {\n ChronoField.MICRO_OF_SECOND.checkValidValue(this.fieldValues.get(ChronoField.MICRO_OF_SECOND));\n }\n }\n\n if (this.fieldValues.containsKey(ChronoField.MILLI_OF_SECOND) && this.fieldValues.containsKey(ChronoField.MICRO_OF_SECOND)) {\n var los = this.fieldValues.remove(ChronoField.MILLI_OF_SECOND);\n var cos = this.fieldValues.get(ChronoField.MICRO_OF_SECOND);\n\n this._putFieldValue0(ChronoField.MICRO_OF_SECOND, los * 1000 + MathUtil.intMod(cos, 1000));\n }\n\n if (this.fieldValues.containsKey(ChronoField.MICRO_OF_SECOND) && this.fieldValues.containsKey(ChronoField.NANO_OF_SECOND)) {\n var nos = this.fieldValues.get(ChronoField.NANO_OF_SECOND);\n\n this._putFieldValue0(ChronoField.MICRO_OF_SECOND, MathUtil.intDiv(nos, 1000));\n\n this.fieldValues.remove(ChronoField.MICRO_OF_SECOND);\n }\n\n if (this.fieldValues.containsKey(ChronoField.MILLI_OF_SECOND) && this.fieldValues.containsKey(ChronoField.NANO_OF_SECOND)) {\n var _nos = this.fieldValues.get(ChronoField.NANO_OF_SECOND);\n\n this._putFieldValue0(ChronoField.MILLI_OF_SECOND, MathUtil.intDiv(_nos, 1000000));\n\n this.fieldValues.remove(ChronoField.MILLI_OF_SECOND);\n }\n\n if (this.fieldValues.containsKey(ChronoField.MICRO_OF_SECOND)) {\n var _cos = this.fieldValues.remove(ChronoField.MICRO_OF_SECOND);\n\n this._putFieldValue0(ChronoField.NANO_OF_SECOND, _cos * 1000);\n } else if (this.fieldValues.containsKey(ChronoField.MILLI_OF_SECOND)) {\n var _los = this.fieldValues.remove(ChronoField.MILLI_OF_SECOND);\n\n this._putFieldValue0(ChronoField.NANO_OF_SECOND, _los * 1000000);\n }\n };\n\n _proto._resolveTimeInferZeroes = function _resolveTimeInferZeroes(resolverStyle) {\n var hod = this.fieldValues.get(ChronoField.HOUR_OF_DAY);\n var moh = this.fieldValues.get(ChronoField.MINUTE_OF_HOUR);\n var som = this.fieldValues.get(ChronoField.SECOND_OF_MINUTE);\n var nos = this.fieldValues.get(ChronoField.NANO_OF_SECOND);\n\n if (hod == null) {\n return;\n }\n\n if (moh == null && (som != null || nos != null)) {\n return;\n }\n\n if (moh != null && som == null && nos != null) {\n return;\n }\n\n if (resolverStyle !== ResolverStyle.LENIENT) {\n if (hod != null) {\n if (resolverStyle === ResolverStyle.SMART && hod === 24 && (moh == null || moh === 0) && (som == null || som === 0) && (nos == null || nos === 0)) {\n hod = 0;\n this.excessDays = Period.ofDays(1);\n }\n\n var hodVal = ChronoField.HOUR_OF_DAY.checkValidIntValue(hod);\n\n if (moh != null) {\n var mohVal = ChronoField.MINUTE_OF_HOUR.checkValidIntValue(moh);\n\n if (som != null) {\n var somVal = ChronoField.SECOND_OF_MINUTE.checkValidIntValue(som);\n\n if (nos != null) {\n var nosVal = ChronoField.NANO_OF_SECOND.checkValidIntValue(nos);\n\n this._addObject(LocalTime.of(hodVal, mohVal, somVal, nosVal));\n } else {\n this._addObject(LocalTime.of(hodVal, mohVal, somVal));\n }\n } else {\n if (nos == null) {\n this._addObject(LocalTime.of(hodVal, mohVal));\n }\n }\n } else {\n if (som == null && nos == null) {\n this._addObject(LocalTime.of(hodVal, 0));\n }\n }\n }\n } else {\n if (hod != null) {\n var _hodVal = hod;\n\n if (moh != null) {\n if (som != null) {\n if (nos == null) {\n nos = 0;\n }\n\n var totalNanos = MathUtil.safeMultiply(_hodVal, 3600000000000);\n totalNanos = MathUtil.safeAdd(totalNanos, MathUtil.safeMultiply(moh, 60000000000));\n totalNanos = MathUtil.safeAdd(totalNanos, MathUtil.safeMultiply(som, 1000000000));\n totalNanos = MathUtil.safeAdd(totalNanos, nos);\n var excessDays = MathUtil.floorDiv(totalNanos, 86400000000000);\n var nod = MathUtil.floorMod(totalNanos, 86400000000000);\n\n this._addObject(LocalTime.ofNanoOfDay(nod));\n\n this.excessDays = Period.ofDays(excessDays);\n } else {\n var totalSecs = MathUtil.safeMultiply(_hodVal, 3600);\n totalSecs = MathUtil.safeAdd(totalSecs, MathUtil.safeMultiply(moh, 60));\n\n var _excessDays = MathUtil.floorDiv(totalSecs, 86400);\n\n var sod = MathUtil.floorMod(totalSecs, 86400);\n\n this._addObject(LocalTime.ofSecondOfDay(sod));\n\n this.excessDays = Period.ofDays(_excessDays);\n }\n } else {\n var _excessDays2 = MathUtil.safeToInt(MathUtil.floorDiv(_hodVal, 24));\n\n _hodVal = MathUtil.floorMod(_hodVal, 24);\n\n this._addObject(LocalTime.of(_hodVal, 0));\n\n this.excessDays = Period.ofDays(_excessDays2);\n }\n }\n }\n\n this.fieldValues.remove(ChronoField.HOUR_OF_DAY);\n this.fieldValues.remove(ChronoField.MINUTE_OF_HOUR);\n this.fieldValues.remove(ChronoField.SECOND_OF_MINUTE);\n this.fieldValues.remove(ChronoField.NANO_OF_SECOND);\n };\n\n _proto._addObject = function _addObject(dateOrTime) {\n if (dateOrTime instanceof ChronoLocalDate) {\n this.date = dateOrTime;\n } else if (dateOrTime instanceof LocalTime) {\n this.time = dateOrTime;\n }\n };\n\n _proto._resolveInstant = function _resolveInstant() {\n if (this.date != null && this.time != null) {\n var offsetSecs = this.fieldValues.get(ChronoField.OFFSET_SECONDS);\n\n if (offsetSecs != null) {\n var offset = ZoneOffset.ofTotalSeconds(offsetSecs);\n var instant = this.date.atTime(this.time).atZone(offset).getLong(ChronoField.INSTANT_SECONDS);\n this.fieldValues.put(ChronoField.INSTANT_SECONDS, instant);\n } else if (this.zone != null) {\n var _instant = this.date.atTime(this.time).atZone(this.zone).getLong(ChronoField.INSTANT_SECONDS);\n\n this.fieldValues.put(ChronoField.INSTANT_SECONDS, _instant);\n }\n }\n };\n\n _proto.build = function build(type) {\n return type.queryFrom(this);\n };\n\n _proto.isSupported = function isSupported(field) {\n if (field == null) {\n return false;\n }\n\n return this.fieldValues.containsKey(field) && this.fieldValues.get(field) !== undefined || this.date != null && this.date.isSupported(field) || this.time != null && this.time.isSupported(field);\n };\n\n _proto.getLong = function getLong(field) {\n requireNonNull(field, 'field');\n var value = this.getFieldValue0(field);\n\n if (value == null) {\n if (this.date != null && this.date.isSupported(field)) {\n return this.date.getLong(field);\n }\n\n if (this.time != null && this.time.isSupported(field)) {\n return this.time.getLong(field);\n }\n\n throw new DateTimeException('Field not found: ' + field);\n }\n\n return value;\n };\n\n _proto.query = function query(_query) {\n if (_query === TemporalQueries.zoneId()) {\n return this.zone;\n } else if (_query === TemporalQueries.chronology()) {\n return this.chrono;\n } else if (_query === TemporalQueries.localDate()) {\n return this.date != null ? LocalDate.from(this.date) : null;\n } else if (_query === TemporalQueries.localTime()) {\n return this.time;\n } else if (_query === TemporalQueries.zone() || _query === TemporalQueries.offset()) {\n return _query.queryFrom(this);\n } else if (_query === TemporalQueries.precision()) {\n return null;\n }\n\n return _query.queryFrom(this);\n };\n\n return DateTimeBuilder;\n}(TemporalAccessor);\n\nvar DateTimeParseContext = function () {\n function DateTimeParseContext() {\n if (arguments.length === 1) {\n if (arguments[0] instanceof DateTimeParseContext) {\n this._constructorSelf.apply(this, arguments);\n\n return;\n } else {\n this._constructorFormatter.apply(this, arguments);\n }\n } else {\n this._constructorParam.apply(this, arguments);\n }\n\n this._caseSensitive = true;\n this._strict = true;\n this._parsed = [new Parsed(this)];\n }\n\n var _proto = DateTimeParseContext.prototype;\n\n _proto._constructorParam = function _constructorParam(locale, symbols, chronology) {\n this._locale = locale;\n this._symbols = symbols;\n this._overrideChronology = chronology;\n };\n\n _proto._constructorFormatter = function _constructorFormatter(formatter) {\n this._locale = formatter.locale();\n this._symbols = formatter.decimalStyle();\n this._overrideChronology = formatter.chronology();\n };\n\n _proto._constructorSelf = function _constructorSelf(other) {\n this._locale = other._locale;\n this._symbols = other._symbols;\n this._overrideChronology = other._overrideChronology;\n this._overrideZone = other._overrideZone;\n this._caseSensitive = other._caseSensitive;\n this._strict = other._strict;\n this._parsed = [new Parsed(this)];\n };\n\n _proto.copy = function copy() {\n return new DateTimeParseContext(this);\n };\n\n _proto.symbols = function symbols() {\n return this._symbols;\n };\n\n _proto.isStrict = function isStrict() {\n return this._strict;\n };\n\n _proto.setStrict = function setStrict(strict) {\n this._strict = strict;\n };\n\n _proto.locale = function locale() {\n return this._locale;\n };\n\n _proto.setLocale = function setLocale(locale) {\n this._locale = locale;\n };\n\n _proto.startOptional = function startOptional() {\n this._parsed.push(this.currentParsed().copy());\n };\n\n _proto.endOptional = function endOptional(successful) {\n if (successful) {\n this._parsed.splice(this._parsed.length - 2, 1);\n } else {\n this._parsed.splice(this._parsed.length - 1, 1);\n }\n };\n\n _proto.isCaseSensitive = function isCaseSensitive() {\n return this._caseSensitive;\n };\n\n _proto.setCaseSensitive = function setCaseSensitive(caseSensitive) {\n this._caseSensitive = caseSensitive;\n };\n\n _proto.subSequenceEquals = function subSequenceEquals(cs1, offset1, cs2, offset2, length) {\n if (offset1 + length > cs1.length || offset2 + length > cs2.length) {\n return false;\n }\n\n if (!this.isCaseSensitive()) {\n cs1 = cs1.toLowerCase();\n cs2 = cs2.toLowerCase();\n }\n\n for (var i = 0; i < length; i++) {\n var ch1 = cs1[offset1 + i];\n var ch2 = cs2[offset2 + i];\n\n if (ch1 !== ch2) {\n return false;\n }\n }\n\n return true;\n };\n\n _proto.charEquals = function charEquals(ch1, ch2) {\n if (this.isCaseSensitive()) {\n return ch1 === ch2;\n }\n\n return this.charEqualsIgnoreCase(ch1, ch2);\n };\n\n _proto.charEqualsIgnoreCase = function charEqualsIgnoreCase(c1, c2) {\n return c1 === c2 || c1.toLowerCase() === c2.toLowerCase();\n };\n\n _proto.setParsedField = function setParsedField(field, value, errorPos, successPos) {\n var currentParsedFieldValues = this.currentParsed().fieldValues;\n var old = currentParsedFieldValues.get(field);\n currentParsedFieldValues.set(field, value);\n return old != null && old !== value ? ~errorPos : successPos;\n };\n\n _proto.setParsedZone = function setParsedZone(zone) {\n requireNonNull(zone, 'zone');\n this.currentParsed().zone = zone;\n };\n\n _proto.getParsed = function getParsed(field) {\n return this.currentParsed().fieldValues.get(field);\n };\n\n _proto.toParsed = function toParsed() {\n return this.currentParsed();\n };\n\n _proto.currentParsed = function currentParsed() {\n return this._parsed[this._parsed.length - 1];\n };\n\n _proto.setParsedLeapSecond = function setParsedLeapSecond() {\n this.currentParsed().leapSecond = true;\n };\n\n _proto.getEffectiveChronology = function getEffectiveChronology() {\n var chrono = this.currentParsed().chrono;\n\n if (chrono == null) {\n chrono = this._overrideChronology;\n\n if (chrono == null) {\n chrono = IsoChronology.INSTANCE;\n }\n }\n\n return chrono;\n };\n\n return DateTimeParseContext;\n}();\n\nvar Parsed = function (_Temporal) {\n _inheritsLoose(Parsed, _Temporal);\n\n function Parsed(dateTimeParseContext) {\n var _this;\n\n _this = _Temporal.call(this) || this;\n _this.chrono = null;\n _this.zone = null;\n _this.fieldValues = new EnumMap();\n _this.leapSecond = false;\n _this.dateTimeParseContext = dateTimeParseContext;\n return _this;\n }\n\n var _proto2 = Parsed.prototype;\n\n _proto2.copy = function copy() {\n var cloned = new Parsed();\n cloned.chrono = this.chrono;\n cloned.zone = this.zone;\n cloned.fieldValues.putAll(this.fieldValues);\n cloned.leapSecond = this.leapSecond;\n cloned.dateTimeParseContext = this.dateTimeParseContext;\n return cloned;\n };\n\n _proto2.toString = function toString() {\n return this.fieldValues + \", \" + this.chrono + \", \" + this.zone;\n };\n\n _proto2.isSupported = function isSupported(field) {\n return this.fieldValues.containsKey(field);\n };\n\n _proto2.get = function get(field) {\n var val = this.fieldValues.get(field);\n assert(val != null);\n return val;\n };\n\n _proto2.query = function query(_query) {\n if (_query === TemporalQueries.chronology()) {\n return this.chrono;\n }\n\n if (_query === TemporalQueries.zoneId() || _query === TemporalQueries.zone()) {\n return this.zone;\n }\n\n return _Temporal.prototype.query.call(this, _query);\n };\n\n _proto2.toBuilder = function toBuilder() {\n var builder = new DateTimeBuilder();\n builder.fieldValues.putAll(this.fieldValues);\n builder.chrono = this.dateTimeParseContext.getEffectiveChronology();\n\n if (this.zone != null) {\n builder.zone = this.zone;\n } else {\n builder.zone = this.overrideZone;\n }\n\n builder.leapSecond = this.leapSecond;\n builder.excessDays = this.excessDays;\n return builder;\n };\n\n return Parsed;\n}(Temporal);\n\n/*\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar DateTimePrintContext = function () {\n function DateTimePrintContext(temporal, localeOrFormatter, symbols) {\n if (arguments.length === 2 && arguments[1] instanceof DateTimeFormatter) {\n this._temporal = DateTimePrintContext.adjust(temporal, localeOrFormatter);\n this._locale = localeOrFormatter.locale();\n this._symbols = localeOrFormatter.decimalStyle();\n } else {\n this._temporal = temporal;\n this._locale = localeOrFormatter;\n this._symbols = symbols;\n }\n\n this._optional = 0;\n }\n\n DateTimePrintContext.adjust = function adjust(temporal, formatter) {\n return temporal;\n };\n\n var _proto = DateTimePrintContext.prototype;\n\n _proto.symbols = function symbols() {\n return this._symbols;\n };\n\n _proto.startOptional = function startOptional() {\n this._optional++;\n };\n\n _proto.endOptional = function endOptional() {\n this._optional--;\n };\n\n _proto.getValueQuery = function getValueQuery(query) {\n var result = this._temporal.query(query);\n\n if (result == null && this._optional === 0) {\n throw new DateTimeException('Unable to extract value: ' + this._temporal);\n }\n\n return result;\n };\n\n _proto.getValue = function getValue(field) {\n try {\n return this._temporal.getLong(field);\n } catch (ex) {\n if (ex instanceof DateTimeException && this._optional > 0) {\n return null;\n }\n\n throw ex;\n }\n };\n\n _proto.temporal = function temporal() {\n return this._temporal;\n };\n\n _proto.locale = function locale() {\n return this._locale;\n };\n\n _proto.setDateTime = function setDateTime(temporal) {\n this._temporal = temporal;\n };\n\n _proto.setLocale = function setLocale(locale) {\n this._locale = locale;\n };\n\n return DateTimePrintContext;\n}();\n\nvar IsoFields = {};\nvar QUARTER_DAYS = [0, 90, 181, 273, 0, 91, 182, 274];\n\nvar Field = function (_TemporalField) {\n _inheritsLoose(Field, _TemporalField);\n\n function Field() {\n return _TemporalField.apply(this, arguments) || this;\n }\n\n var _proto = Field.prototype;\n\n _proto.isDateBased = function isDateBased() {\n return true;\n };\n\n _proto.isTimeBased = function isTimeBased() {\n return false;\n };\n\n _proto._isIso = function _isIso() {\n return true;\n };\n\n Field._getWeekRangeByLocalDate = function _getWeekRangeByLocalDate(date) {\n var wby = Field._getWeekBasedYear(date);\n\n return ValueRange.of(1, Field._getWeekRangeByYear(wby));\n };\n\n Field._getWeekRangeByYear = function _getWeekRangeByYear(wby) {\n var date = LocalDate.of(wby, 1, 1);\n\n if (date.dayOfWeek() === DayOfWeek.THURSDAY || date.dayOfWeek() === DayOfWeek.WEDNESDAY && date.isLeapYear()) {\n return 53;\n }\n\n return 52;\n };\n\n Field._getWeek = function _getWeek(date) {\n var dow0 = date.dayOfWeek().ordinal();\n var doy0 = date.dayOfYear() - 1;\n var doyThu0 = doy0 + (3 - dow0);\n var alignedWeek = MathUtil.intDiv(doyThu0, 7);\n var firstThuDoy0 = doyThu0 - alignedWeek * 7;\n var firstMonDoy0 = firstThuDoy0 - 3;\n\n if (firstMonDoy0 < -3) {\n firstMonDoy0 += 7;\n }\n\n if (doy0 < firstMonDoy0) {\n return Field._getWeekRangeByLocalDate(date.withDayOfYear(180).minusYears(1)).maximum();\n }\n\n var week = MathUtil.intDiv(doy0 - firstMonDoy0, 7) + 1;\n\n if (week === 53) {\n if ((firstMonDoy0 === -3 || firstMonDoy0 === -2 && date.isLeapYear()) === false) {\n week = 1;\n }\n }\n\n return week;\n };\n\n Field._getWeekBasedYear = function _getWeekBasedYear(date) {\n var year = date.year();\n var doy = date.dayOfYear();\n\n if (doy <= 3) {\n var dow = date.dayOfWeek().ordinal();\n\n if (doy - dow < -2) {\n year--;\n }\n } else if (doy >= 363) {\n var _dow = date.dayOfWeek().ordinal();\n\n doy = doy - 363 - (date.isLeapYear() ? 1 : 0);\n\n if (doy - _dow >= 0) {\n year++;\n }\n }\n\n return year;\n };\n\n _proto.displayName = function displayName() {\n return this.toString();\n };\n\n _proto.resolve = function resolve() {\n return null;\n };\n\n _proto.name = function name() {\n return this.toString();\n };\n\n return Field;\n}(TemporalField);\n\nvar DAY_OF_QUARTER_FIELD = function (_Field) {\n _inheritsLoose(DAY_OF_QUARTER_FIELD, _Field);\n\n function DAY_OF_QUARTER_FIELD() {\n return _Field.apply(this, arguments) || this;\n }\n\n var _proto2 = DAY_OF_QUARTER_FIELD.prototype;\n\n _proto2.toString = function toString() {\n return 'DayOfQuarter';\n };\n\n _proto2.baseUnit = function baseUnit() {\n return ChronoUnit.DAYS;\n };\n\n _proto2.rangeUnit = function rangeUnit() {\n return QUARTER_YEARS;\n };\n\n _proto2.range = function range() {\n return ValueRange.of(1, 90, 92);\n };\n\n _proto2.isSupportedBy = function isSupportedBy(temporal) {\n return temporal.isSupported(ChronoField.DAY_OF_YEAR) && temporal.isSupported(ChronoField.MONTH_OF_YEAR) && temporal.isSupported(ChronoField.YEAR) && this._isIso(temporal);\n };\n\n _proto2.rangeRefinedBy = function rangeRefinedBy(temporal) {\n if (temporal.isSupported(this) === false) {\n throw new UnsupportedTemporalTypeException('Unsupported field: DayOfQuarter');\n }\n\n var qoy = temporal.getLong(QUARTER_OF_YEAR);\n\n if (qoy === 1) {\n var year = temporal.getLong(ChronoField.YEAR);\n return IsoChronology.isLeapYear(year) ? ValueRange.of(1, 91) : ValueRange.of(1, 90);\n } else if (qoy === 2) {\n return ValueRange.of(1, 91);\n } else if (qoy === 3 || qoy === 4) {\n return ValueRange.of(1, 92);\n }\n\n return this.range();\n };\n\n _proto2.getFrom = function getFrom(temporal) {\n if (temporal.isSupported(this) === false) {\n throw new UnsupportedTemporalTypeException('Unsupported field: DayOfQuarter');\n }\n\n var doy = temporal.get(ChronoField.DAY_OF_YEAR);\n var moy = temporal.get(ChronoField.MONTH_OF_YEAR);\n var year = temporal.getLong(ChronoField.YEAR);\n return doy - QUARTER_DAYS[MathUtil.intDiv(moy - 1, 3) + (IsoChronology.isLeapYear(year) ? 4 : 0)];\n };\n\n _proto2.adjustInto = function adjustInto(temporal, newValue) {\n var curValue = this.getFrom(temporal);\n this.range().checkValidValue(newValue, this);\n return temporal.with(ChronoField.DAY_OF_YEAR, temporal.getLong(ChronoField.DAY_OF_YEAR) + (newValue - curValue));\n };\n\n _proto2.resolve = function resolve(fieldValues, partialTemporal, resolverStyle) {\n var yearLong = fieldValues.get(ChronoField.YEAR);\n var qoyLong = fieldValues.get(QUARTER_OF_YEAR);\n\n if (yearLong == null || qoyLong == null) {\n return null;\n }\n\n var y = ChronoField.YEAR.checkValidIntValue(yearLong);\n var doq = fieldValues.get(DAY_OF_QUARTER);\n var date;\n\n if (resolverStyle === ResolverStyle.LENIENT) {\n var qoy = qoyLong;\n date = LocalDate.of(y, 1, 1);\n date = date.plusMonths(MathUtil.safeMultiply(MathUtil.safeSubtract(qoy, 1), 3));\n date = date.plusDays(MathUtil.safeSubtract(doq, 1));\n } else {\n var _qoy = QUARTER_OF_YEAR.range().checkValidIntValue(qoyLong, QUARTER_OF_YEAR);\n\n if (resolverStyle === ResolverStyle.STRICT) {\n var max = 92;\n\n if (_qoy === 1) {\n max = IsoChronology.isLeapYear(y) ? 91 : 90;\n } else if (_qoy === 2) {\n max = 91;\n }\n\n ValueRange.of(1, max).checkValidValue(doq, this);\n } else {\n this.range().checkValidValue(doq, this);\n }\n\n date = LocalDate.of(y, (_qoy - 1) * 3 + 1, 1).plusDays(doq - 1);\n }\n\n fieldValues.remove(this);\n fieldValues.remove(ChronoField.YEAR);\n fieldValues.remove(QUARTER_OF_YEAR);\n return date;\n };\n\n return DAY_OF_QUARTER_FIELD;\n}(Field);\n\nvar QUARTER_OF_YEAR_FIELD = function (_Field2) {\n _inheritsLoose(QUARTER_OF_YEAR_FIELD, _Field2);\n\n function QUARTER_OF_YEAR_FIELD() {\n return _Field2.apply(this, arguments) || this;\n }\n\n var _proto3 = QUARTER_OF_YEAR_FIELD.prototype;\n\n _proto3.toString = function toString() {\n return 'QuarterOfYear';\n };\n\n _proto3.baseUnit = function baseUnit() {\n return QUARTER_YEARS;\n };\n\n _proto3.rangeUnit = function rangeUnit() {\n return ChronoUnit.YEARS;\n };\n\n _proto3.range = function range() {\n return ValueRange.of(1, 4);\n };\n\n _proto3.isSupportedBy = function isSupportedBy(temporal) {\n return temporal.isSupported(ChronoField.MONTH_OF_YEAR) && this._isIso(temporal);\n };\n\n _proto3.rangeRefinedBy = function rangeRefinedBy(temporal) {\n return this.range();\n };\n\n _proto3.getFrom = function getFrom(temporal) {\n if (temporal.isSupported(this) === false) {\n throw new UnsupportedTemporalTypeException('Unsupported field: QuarterOfYear');\n }\n\n var moy = temporal.getLong(ChronoField.MONTH_OF_YEAR);\n return MathUtil.intDiv(moy + 2, 3);\n };\n\n _proto3.adjustInto = function adjustInto(temporal, newValue) {\n var curValue = this.getFrom(temporal);\n this.range().checkValidValue(newValue, this);\n return temporal.with(ChronoField.MONTH_OF_YEAR, temporal.getLong(ChronoField.MONTH_OF_YEAR) + (newValue - curValue) * 3);\n };\n\n return QUARTER_OF_YEAR_FIELD;\n}(Field);\n\nvar WEEK_OF_WEEK_BASED_YEAR_FIELD = function (_Field3) {\n _inheritsLoose(WEEK_OF_WEEK_BASED_YEAR_FIELD, _Field3);\n\n function WEEK_OF_WEEK_BASED_YEAR_FIELD() {\n return _Field3.apply(this, arguments) || this;\n }\n\n var _proto4 = WEEK_OF_WEEK_BASED_YEAR_FIELD.prototype;\n\n _proto4.toString = function toString() {\n return 'WeekOfWeekBasedYear';\n };\n\n _proto4.baseUnit = function baseUnit() {\n return ChronoUnit.WEEKS;\n };\n\n _proto4.rangeUnit = function rangeUnit() {\n return WEEK_BASED_YEARS;\n };\n\n _proto4.range = function range() {\n return ValueRange.of(1, 52, 53);\n };\n\n _proto4.isSupportedBy = function isSupportedBy(temporal) {\n return temporal.isSupported(ChronoField.EPOCH_DAY) && this._isIso(temporal);\n };\n\n _proto4.rangeRefinedBy = function rangeRefinedBy(temporal) {\n if (temporal.isSupported(this) === false) {\n throw new UnsupportedTemporalTypeException('Unsupported field: WeekOfWeekBasedYear');\n }\n\n return Field._getWeekRangeByLocalDate(LocalDate.from(temporal));\n };\n\n _proto4.getFrom = function getFrom(temporal) {\n if (temporal.isSupported(this) === false) {\n throw new UnsupportedTemporalTypeException('Unsupported field: WeekOfWeekBasedYear');\n }\n\n return Field._getWeek(LocalDate.from(temporal));\n };\n\n _proto4.adjustInto = function adjustInto(temporal, newValue) {\n this.range().checkValidValue(newValue, this);\n return temporal.plus(MathUtil.safeSubtract(newValue, this.getFrom(temporal)), ChronoUnit.WEEKS);\n };\n\n _proto4.resolve = function resolve(fieldValues, partialTemporal, resolverStyle) {\n var wbyLong = fieldValues.get(WEEK_BASED_YEAR);\n var dowLong = fieldValues.get(ChronoField.DAY_OF_WEEK);\n\n if (wbyLong == null || dowLong == null) {\n return null;\n }\n\n var wby = WEEK_BASED_YEAR.range().checkValidIntValue(wbyLong, WEEK_BASED_YEAR);\n var wowby = fieldValues.get(WEEK_OF_WEEK_BASED_YEAR);\n var date;\n\n if (resolverStyle === ResolverStyle.LENIENT) {\n var dow = dowLong;\n var weeks = 0;\n\n if (dow > 7) {\n weeks = MathUtil.intDiv(dow - 1, 7);\n dow = MathUtil.intMod(dow - 1, 7) + 1;\n } else if (dow < 1) {\n weeks = MathUtil.intDiv(dow, 7) - 1;\n dow = MathUtil.intMod(dow, 7) + 7;\n }\n\n date = LocalDate.of(wby, 1, 4).plusWeeks(wowby - 1).plusWeeks(weeks).with(ChronoField.DAY_OF_WEEK, dow);\n } else {\n var _dow2 = ChronoField.DAY_OF_WEEK.checkValidIntValue(dowLong);\n\n if (resolverStyle === ResolverStyle.STRICT) {\n var temp = LocalDate.of(wby, 1, 4);\n\n var range = Field._getWeekRangeByLocalDate(temp);\n\n range.checkValidValue(wowby, this);\n } else {\n this.range().checkValidValue(wowby, this);\n }\n\n date = LocalDate.of(wby, 1, 4).plusWeeks(wowby - 1).with(ChronoField.DAY_OF_WEEK, _dow2);\n }\n\n fieldValues.remove(this);\n fieldValues.remove(WEEK_BASED_YEAR);\n fieldValues.remove(ChronoField.DAY_OF_WEEK);\n return date;\n };\n\n _proto4.displayName = function displayName() {\n return 'Week';\n };\n\n return WEEK_OF_WEEK_BASED_YEAR_FIELD;\n}(Field);\n\nvar WEEK_BASED_YEAR_FIELD = function (_Field4) {\n _inheritsLoose(WEEK_BASED_YEAR_FIELD, _Field4);\n\n function WEEK_BASED_YEAR_FIELD() {\n return _Field4.apply(this, arguments) || this;\n }\n\n var _proto5 = WEEK_BASED_YEAR_FIELD.prototype;\n\n _proto5.toString = function toString() {\n return 'WeekBasedYear';\n };\n\n _proto5.baseUnit = function baseUnit() {\n return WEEK_BASED_YEARS;\n };\n\n _proto5.rangeUnit = function rangeUnit() {\n return ChronoUnit.FOREVER;\n };\n\n _proto5.range = function range() {\n return ChronoField.YEAR.range();\n };\n\n _proto5.isSupportedBy = function isSupportedBy(temporal) {\n return temporal.isSupported(ChronoField.EPOCH_DAY) && this._isIso(temporal);\n };\n\n _proto5.rangeRefinedBy = function rangeRefinedBy(temporal) {\n return ChronoField.YEAR.range();\n };\n\n _proto5.getFrom = function getFrom(temporal) {\n if (temporal.isSupported(this) === false) {\n throw new UnsupportedTemporalTypeException('Unsupported field: WeekBasedYear');\n }\n\n return Field._getWeekBasedYear(LocalDate.from(temporal));\n };\n\n _proto5.adjustInto = function adjustInto(temporal, newValue) {\n if (this.isSupportedBy(temporal) === false) {\n throw new UnsupportedTemporalTypeException('Unsupported field: WeekBasedYear');\n }\n\n var newWby = this.range().checkValidIntValue(newValue, WEEK_BASED_YEAR);\n var date = LocalDate.from(temporal);\n var dow = date.get(ChronoField.DAY_OF_WEEK);\n\n var week = Field._getWeek(date);\n\n if (week === 53 && Field._getWeekRangeByYear(newWby) === 52) {\n week = 52;\n }\n\n var resolved = LocalDate.of(newWby, 1, 4);\n var days = dow - resolved.get(ChronoField.DAY_OF_WEEK) + (week - 1) * 7;\n resolved = resolved.plusDays(days);\n return temporal.with(resolved);\n };\n\n return WEEK_BASED_YEAR_FIELD;\n}(Field);\n\nvar Unit = function (_TemporalUnit) {\n _inheritsLoose(Unit, _TemporalUnit);\n\n function Unit(name, estimatedDuration) {\n var _this;\n\n _this = _TemporalUnit.call(this) || this;\n _this._name = name;\n _this._duration = estimatedDuration;\n return _this;\n }\n\n var _proto6 = Unit.prototype;\n\n _proto6.duration = function duration() {\n return this._duration;\n };\n\n _proto6.isDurationEstimated = function isDurationEstimated() {\n return true;\n };\n\n _proto6.isDateBased = function isDateBased() {\n return true;\n };\n\n _proto6.isTimeBased = function isTimeBased() {\n return false;\n };\n\n _proto6.isSupportedBy = function isSupportedBy(temporal) {\n return temporal.isSupported(ChronoField.EPOCH_DAY);\n };\n\n _proto6.addTo = function addTo(temporal, periodToAdd) {\n switch (this) {\n case WEEK_BASED_YEARS:\n {\n var added = MathUtil.safeAdd(temporal.get(WEEK_BASED_YEAR), periodToAdd);\n return temporal.with(WEEK_BASED_YEAR, added);\n }\n\n case QUARTER_YEARS:\n return temporal.plus(MathUtil.intDiv(periodToAdd, 256), ChronoUnit.YEARS).plus(MathUtil.intMod(periodToAdd, 256) * 3, ChronoUnit.MONTHS);\n\n default:\n throw new IllegalStateException('Unreachable');\n }\n };\n\n _proto6.between = function between(temporal1, temporal2) {\n switch (this) {\n case WEEK_BASED_YEARS:\n return MathUtil.safeSubtract(temporal2.getLong(WEEK_BASED_YEAR), temporal1.getLong(WEEK_BASED_YEAR));\n\n case QUARTER_YEARS:\n return MathUtil.intDiv(temporal1.until(temporal2, ChronoUnit.MONTHS), 3);\n\n default:\n throw new IllegalStateException('Unreachable');\n }\n };\n\n _proto6.toString = function toString() {\n return name;\n };\n\n return Unit;\n}(TemporalUnit);\n\nvar DAY_OF_QUARTER = null;\nvar QUARTER_OF_YEAR = null;\nvar WEEK_OF_WEEK_BASED_YEAR = null;\nvar WEEK_BASED_YEAR = null;\nvar WEEK_BASED_YEARS = null;\nvar QUARTER_YEARS = null;\nfunction _init$8() {\n DAY_OF_QUARTER = new DAY_OF_QUARTER_FIELD();\n QUARTER_OF_YEAR = new QUARTER_OF_YEAR_FIELD();\n WEEK_OF_WEEK_BASED_YEAR = new WEEK_OF_WEEK_BASED_YEAR_FIELD();\n WEEK_BASED_YEAR = new WEEK_BASED_YEAR_FIELD();\n WEEK_BASED_YEARS = new Unit('WeekBasedYears', Duration.ofSeconds(31556952));\n QUARTER_YEARS = new Unit('QuarterYears', Duration.ofSeconds(31556952 / 4));\n IsoFields.DAY_OF_QUARTER = DAY_OF_QUARTER;\n IsoFields.QUARTER_OF_YEAR = QUARTER_OF_YEAR;\n IsoFields.WEEK_OF_WEEK_BASED_YEAR = WEEK_OF_WEEK_BASED_YEAR;\n IsoFields.WEEK_BASED_YEAR = WEEK_BASED_YEAR;\n IsoFields.WEEK_BASED_YEARS = WEEK_BASED_YEARS;\n IsoFields.QUARTER_YEARS = QUARTER_YEARS;\n\n LocalDate.prototype.isoWeekOfWeekyear = function () {\n return this.get(IsoFields.WEEK_OF_WEEK_BASED_YEAR);\n };\n\n LocalDate.prototype.isoWeekyear = function () {\n return this.get(IsoFields.WEEK_BASED_YEAR);\n };\n}\n\n/**\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar DecimalStyle = function () {\n function DecimalStyle(zeroChar, positiveSignChar, negativeSignChar, decimalPointChar) {\n this._zeroDigit = zeroChar;\n this._zeroDigitCharCode = zeroChar.charCodeAt(0);\n this._positiveSign = positiveSignChar;\n this._negativeSign = negativeSignChar;\n this._decimalSeparator = decimalPointChar;\n }\n\n var _proto = DecimalStyle.prototype;\n\n _proto.positiveSign = function positiveSign() {\n return this._positiveSign;\n };\n\n _proto.withPositiveSign = function withPositiveSign(positiveSign) {\n if (positiveSign === this._positiveSign) {\n return this;\n }\n\n return new DecimalStyle(this._zeroDigit, positiveSign, this._negativeSign, this._decimalSeparator);\n };\n\n _proto.negativeSign = function negativeSign() {\n return this._negativeSign;\n };\n\n _proto.withNegativeSign = function withNegativeSign(negativeSign) {\n if (negativeSign === this._negativeSign) {\n return this;\n }\n\n return new DecimalStyle(this._zeroDigit, this._positiveSign, negativeSign, this._decimalSeparator);\n };\n\n _proto.zeroDigit = function zeroDigit() {\n return this._zeroDigit;\n };\n\n _proto.withZeroDigit = function withZeroDigit(zeroDigit) {\n if (zeroDigit === this._zeroDigit) {\n return this;\n }\n\n return new DecimalStyle(zeroDigit, this._positiveSign, this._negativeSign, this._decimalSeparator);\n };\n\n _proto.decimalSeparator = function decimalSeparator() {\n return this._decimalSeparator;\n };\n\n _proto.withDecimalSeparator = function withDecimalSeparator(decimalSeparator) {\n if (decimalSeparator === this._decimalSeparator) {\n return this;\n }\n\n return new DecimalStyle(this._zeroDigit, this._positiveSign, this._negativeSign, decimalSeparator);\n };\n\n _proto.convertToDigit = function convertToDigit(char) {\n var val = char.charCodeAt(0) - this._zeroDigitCharCode;\n\n return val >= 0 && val <= 9 ? val : -1;\n };\n\n _proto.convertNumberToI18N = function convertNumberToI18N(numericText) {\n if (this._zeroDigit === '0') {\n return numericText;\n }\n\n var diff = this._zeroDigitCharCode - '0'.charCodeAt(0);\n var convertedText = '';\n\n for (var i = 0; i < numericText.length; i++) {\n convertedText += String.fromCharCode(numericText.charCodeAt(i) + diff);\n }\n\n return convertedText;\n };\n\n _proto.equals = function equals(other) {\n if (this === other) {\n return true;\n }\n\n if (other instanceof DecimalStyle) {\n return this._zeroDigit === other._zeroDigit && this._positiveSign === other._positiveSign && this._negativeSign === other._negativeSign && this._decimalSeparator === other._decimalSeparator;\n }\n\n return false;\n };\n\n _proto.hashCode = function hashCode() {\n return this._zeroDigit + this._positiveSign + this._negativeSign + this._decimalSeparator;\n };\n\n _proto.toString = function toString() {\n return 'DecimalStyle[' + this._zeroDigit + this._positiveSign + this._negativeSign + this._decimalSeparator + ']';\n };\n\n DecimalStyle.of = function of() {\n throw new Error('not yet supported');\n };\n\n DecimalStyle.availableLocales = function availableLocales() {\n throw new Error('not yet supported');\n };\n\n return DecimalStyle;\n}();\nDecimalStyle.STANDARD = new DecimalStyle('0', '+', '-', '.');\n\nvar SignStyle = function (_Enum) {\n _inheritsLoose(SignStyle, _Enum);\n\n function SignStyle() {\n return _Enum.apply(this, arguments) || this;\n }\n\n var _proto = SignStyle.prototype;\n\n _proto.parse = function parse(positive, strict, fixedWidth) {\n switch (this) {\n case SignStyle.NORMAL:\n return !positive || !strict;\n\n case SignStyle.ALWAYS:\n case SignStyle.EXCEEDS_PAD:\n return true;\n\n default:\n return !strict && !fixedWidth;\n }\n };\n\n return SignStyle;\n}(Enum);\nSignStyle.NORMAL = new SignStyle('NORMAL');\nSignStyle.NEVER = new SignStyle('NEVER');\nSignStyle.ALWAYS = new SignStyle('ALWAYS');\nSignStyle.EXCEEDS_PAD = new SignStyle('EXCEEDS_PAD');\nSignStyle.NOT_NEGATIVE = new SignStyle('NOT_NEGATIVE');\n\nvar TextStyle = function (_Enum) {\n _inheritsLoose(TextStyle, _Enum);\n\n function TextStyle() {\n return _Enum.apply(this, arguments) || this;\n }\n\n var _proto = TextStyle.prototype;\n\n _proto.isStandalone = function isStandalone() {\n switch (this) {\n case TextStyle.FULL_STANDALONE:\n case TextStyle.SHORT_STANDALONE:\n case TextStyle.NARROW_STANDALONE:\n return true;\n\n default:\n return false;\n }\n };\n\n _proto.asStandalone = function asStandalone() {\n switch (this) {\n case TextStyle.FULL:\n return TextStyle.FULL_STANDALONE;\n\n case TextStyle.SHORT:\n return TextStyle.SHORT_STANDALONE;\n\n case TextStyle.NARROW:\n return TextStyle.NARROW_STANDALONE;\n\n default:\n return this;\n }\n };\n\n _proto.asNormal = function asNormal() {\n switch (this) {\n case TextStyle.FULL_STANDALONE:\n return TextStyle.FULL;\n\n case TextStyle.SHORT_STANDALONE:\n return TextStyle.SHORT;\n\n case TextStyle.NARROW_STANDALONE:\n return TextStyle.NARROW;\n\n default:\n return this;\n }\n };\n\n return TextStyle;\n}(Enum);\nTextStyle.FULL = new TextStyle('FULL');\nTextStyle.FULL_STANDALONE = new TextStyle('FULL_STANDALONE');\nTextStyle.SHORT = new TextStyle('SHORT');\nTextStyle.SHORT_STANDALONE = new TextStyle('SHORT_STANDALONE');\nTextStyle.NARROW = new TextStyle('NARROW');\nTextStyle.NARROW_STANDALONE = new TextStyle('NARROW_STANDALONE');\n\n/**\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar CharLiteralPrinterParser = function () {\n function CharLiteralPrinterParser(literal) {\n if (literal.length > 1) {\n throw new IllegalArgumentException('invalid literal, too long: \"' + literal + '\"');\n }\n\n this._literal = literal;\n }\n\n var _proto = CharLiteralPrinterParser.prototype;\n\n _proto.print = function print(context, buf) {\n buf.append(this._literal);\n return true;\n };\n\n _proto.parse = function parse(context, text, position) {\n var length = text.length;\n\n if (position === length) {\n return ~position;\n }\n\n var ch = text.charAt(position);\n\n if (context.charEquals(this._literal, ch) === false) {\n return ~position;\n }\n\n return position + this._literal.length;\n };\n\n _proto.toString = function toString() {\n if (this._literal === '\\'') {\n return \"''\";\n }\n\n return \"'\" + this._literal + \"'\";\n };\n\n return CharLiteralPrinterParser;\n}();\n\n/**\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar CompositePrinterParser = function () {\n function CompositePrinterParser(printerParsers, optional) {\n this._printerParsers = printerParsers;\n this._optional = optional;\n }\n\n var _proto = CompositePrinterParser.prototype;\n\n _proto.withOptional = function withOptional(optional) {\n if (optional === this._optional) {\n return this;\n }\n\n return new CompositePrinterParser(this._printerParsers, optional);\n };\n\n _proto.print = function print(context, buf) {\n var length = buf.length();\n\n if (this._optional) {\n context.startOptional();\n }\n\n try {\n for (var i = 0; i < this._printerParsers.length; i++) {\n var pp = this._printerParsers[i];\n\n if (pp.print(context, buf) === false) {\n buf.setLength(length);\n return true;\n }\n }\n } finally {\n if (this._optional) {\n context.endOptional();\n }\n }\n\n return true;\n };\n\n _proto.parse = function parse(context, text, position) {\n if (this._optional) {\n context.startOptional();\n var pos = position;\n\n for (var i = 0; i < this._printerParsers.length; i++) {\n var pp = this._printerParsers[i];\n pos = pp.parse(context, text, pos);\n\n if (pos < 0) {\n context.endOptional(false);\n return position;\n }\n }\n\n context.endOptional(true);\n return pos;\n } else {\n for (var _i = 0; _i < this._printerParsers.length; _i++) {\n var _pp = this._printerParsers[_i];\n position = _pp.parse(context, text, position);\n\n if (position < 0) {\n break;\n }\n }\n\n return position;\n }\n };\n\n _proto.toString = function toString() {\n var buf = '';\n\n if (this._printerParsers != null) {\n buf += this._optional ? '[' : '(';\n\n for (var i = 0; i < this._printerParsers.length; i++) {\n var pp = this._printerParsers[i];\n buf += pp.toString();\n }\n\n buf += this._optional ? ']' : ')';\n }\n\n return buf;\n };\n\n return CompositePrinterParser;\n}();\n\n/**\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar FractionPrinterParser = function () {\n function FractionPrinterParser(field, minWidth, maxWidth, decimalPoint) {\n requireNonNull(field, 'field');\n\n if (field.range().isFixed() === false) {\n throw new IllegalArgumentException('Field must have a fixed set of values: ' + field);\n }\n\n if (minWidth < 0 || minWidth > 9) {\n throw new IllegalArgumentException('Minimum width must be from 0 to 9 inclusive but was ' + minWidth);\n }\n\n if (maxWidth < 1 || maxWidth > 9) {\n throw new IllegalArgumentException('Maximum width must be from 1 to 9 inclusive but was ' + maxWidth);\n }\n\n if (maxWidth < minWidth) {\n throw new IllegalArgumentException('Maximum width must exceed or equal the minimum width but ' + maxWidth + ' < ' + minWidth);\n }\n\n this.field = field;\n this.minWidth = minWidth;\n this.maxWidth = maxWidth;\n this.decimalPoint = decimalPoint;\n }\n\n var _proto = FractionPrinterParser.prototype;\n\n _proto.print = function print(context, buf) {\n var value = context.getValue(this.field);\n\n if (value === null) {\n return false;\n }\n\n var symbols = context.symbols();\n\n if (value === 0) {\n if (this.minWidth > 0) {\n if (this.decimalPoint) {\n buf.append(symbols.decimalSeparator());\n }\n\n for (var i = 0; i < this.minWidth; i++) {\n buf.append(symbols.zeroDigit());\n }\n }\n } else {\n var fraction = this.convertToFraction(value, symbols.zeroDigit());\n var outputScale = Math.min(Math.max(fraction.length, this.minWidth), this.maxWidth);\n fraction = fraction.substr(0, outputScale);\n\n if (fraction * 1 > 0) {\n while (fraction.length > this.minWidth && fraction[fraction.length - 1] === '0') {\n fraction = fraction.substr(0, fraction.length - 1);\n }\n }\n\n var str = fraction;\n str = symbols.convertNumberToI18N(str);\n\n if (this.decimalPoint) {\n buf.append(symbols.decimalSeparator());\n }\n\n buf.append(str);\n }\n\n return true;\n };\n\n _proto.parse = function parse(context, text, position) {\n var effectiveMin = context.isStrict() ? this.minWidth : 0;\n var effectiveMax = context.isStrict() ? this.maxWidth : 9;\n var length = text.length;\n\n if (position === length) {\n return effectiveMin > 0 ? ~position : position;\n }\n\n if (this.decimalPoint) {\n if (text[position] !== context.symbols().decimalSeparator()) {\n return effectiveMin > 0 ? ~position : position;\n }\n\n position++;\n }\n\n var minEndPos = position + effectiveMin;\n\n if (minEndPos > length) {\n return ~position;\n }\n\n var maxEndPos = Math.min(position + effectiveMax, length);\n var total = 0;\n var pos = position;\n\n while (pos < maxEndPos) {\n var ch = text.charAt(pos++);\n var digit = context.symbols().convertToDigit(ch);\n\n if (digit < 0) {\n if (pos < minEndPos) {\n return ~position;\n }\n\n pos--;\n break;\n }\n\n total = total * 10 + digit;\n }\n\n var moveLeft = pos - position;\n var scale = Math.pow(10, moveLeft);\n var value = this.convertFromFraction(total, scale);\n return context.setParsedField(this.field, value, position, pos);\n };\n\n _proto.convertToFraction = function convertToFraction(value, zeroDigit) {\n var range = this.field.range();\n range.checkValidValue(value, this.field);\n\n var _min = range.minimum();\n\n var _range = range.maximum() - _min + 1;\n\n var _value = value - _min;\n\n var _scaled = MathUtil.intDiv(_value * 1000000000, _range);\n\n var fraction = '' + _scaled;\n\n while (fraction.length < 9) {\n fraction = zeroDigit + fraction;\n }\n\n return fraction;\n };\n\n _proto.convertFromFraction = function convertFromFraction(total, scale) {\n var range = this.field.range();\n\n var _min = range.minimum();\n\n var _range = range.maximum() - _min + 1;\n\n var _value = MathUtil.intDiv(total * _range, scale);\n\n return _value;\n };\n\n _proto.toString = function toString() {\n var decimal = this.decimalPoint ? ',DecimalPoint' : '';\n return 'Fraction(' + this.field + ',' + this.minWidth + ',' + this.maxWidth + decimal + ')';\n };\n\n return FractionPrinterParser;\n}();\n\nvar MAX_WIDTH = 15;\nvar EXCEED_POINTS = [0, 10, 100, 1000, 10000, 100000, 1000000, 10000000, 100000000, 1000000000];\nvar NumberPrinterParser = function () {\n function NumberPrinterParser(field, minWidth, maxWidth, signStyle, subsequentWidth) {\n if (subsequentWidth === void 0) {\n subsequentWidth = 0;\n }\n\n this._field = field;\n this._minWidth = minWidth;\n this._maxWidth = maxWidth;\n this._signStyle = signStyle;\n this._subsequentWidth = subsequentWidth;\n }\n\n var _proto = NumberPrinterParser.prototype;\n\n _proto.field = function field() {\n return this._field;\n };\n\n _proto.minWidth = function minWidth() {\n return this._minWidth;\n };\n\n _proto.maxWidth = function maxWidth() {\n return this._maxWidth;\n };\n\n _proto.signStyle = function signStyle() {\n return this._signStyle;\n };\n\n _proto.withFixedWidth = function withFixedWidth() {\n if (this._subsequentWidth === -1) {\n return this;\n }\n\n return new NumberPrinterParser(this._field, this._minWidth, this._maxWidth, this._signStyle, -1);\n };\n\n _proto.withSubsequentWidth = function withSubsequentWidth(subsequentWidth) {\n return new NumberPrinterParser(this._field, this._minWidth, this._maxWidth, this._signStyle, this._subsequentWidth + subsequentWidth);\n };\n\n _proto._isFixedWidth = function _isFixedWidth() {\n return this._subsequentWidth === -1 || this._subsequentWidth > 0 && this._minWidth === this._maxWidth && this._signStyle === SignStyle.NOT_NEGATIVE;\n };\n\n _proto.print = function print(context, buf) {\n var contextValue = context.getValue(this._field);\n\n if (contextValue == null) {\n return false;\n }\n\n var value = this._getValue(context, contextValue);\n\n var symbols = context.symbols();\n var str = '' + Math.abs(value);\n\n if (str.length > this._maxWidth) {\n throw new DateTimeException('Field ' + this._field + ' cannot be printed as the value ' + value + ' exceeds the maximum print width of ' + this._maxWidth);\n }\n\n str = symbols.convertNumberToI18N(str);\n\n if (value >= 0) {\n switch (this._signStyle) {\n case SignStyle.EXCEEDS_PAD:\n if (this._minWidth < MAX_WIDTH && value >= EXCEED_POINTS[this._minWidth]) {\n buf.append(symbols.positiveSign());\n }\n\n break;\n\n case SignStyle.ALWAYS:\n buf.append(symbols.positiveSign());\n break;\n }\n } else {\n switch (this._signStyle) {\n case SignStyle.NORMAL:\n case SignStyle.EXCEEDS_PAD:\n case SignStyle.ALWAYS:\n buf.append(symbols.negativeSign());\n break;\n\n case SignStyle.NOT_NEGATIVE:\n throw new DateTimeException('Field ' + this._field + ' cannot be printed as the value ' + value + ' cannot be negative according to the SignStyle');\n }\n }\n\n for (var i = 0; i < this._minWidth - str.length; i++) {\n buf.append(symbols.zeroDigit());\n }\n\n buf.append(str);\n return true;\n };\n\n _proto.parse = function parse(context, text, position) {\n var length = text.length;\n\n if (position === length) {\n return ~position;\n }\n\n assert(position >= 0 && position < length);\n var sign = text.charAt(position);\n var negative = false;\n var positive = false;\n\n if (sign === context.symbols().positiveSign()) {\n if (this._signStyle.parse(true, context.isStrict(), this._minWidth === this._maxWidth) === false) {\n return ~position;\n }\n\n positive = true;\n position++;\n } else if (sign === context.symbols().negativeSign()) {\n if (this._signStyle.parse(false, context.isStrict(), this._minWidth === this._maxWidth) === false) {\n return ~position;\n }\n\n negative = true;\n position++;\n } else {\n if (this._signStyle === SignStyle.ALWAYS && context.isStrict()) {\n return ~position;\n }\n }\n\n var effMinWidth = context.isStrict() || this._isFixedWidth() ? this._minWidth : 1;\n var minEndPos = position + effMinWidth;\n\n if (minEndPos > length) {\n return ~position;\n }\n\n var effMaxWidth = (context.isStrict() || this._isFixedWidth() ? this._maxWidth : 9) + Math.max(this._subsequentWidth, 0);\n var total = 0;\n var pos = position;\n\n for (var pass = 0; pass < 2; pass++) {\n var maxEndPos = Math.min(pos + effMaxWidth, length);\n\n while (pos < maxEndPos) {\n var ch = text.charAt(pos++);\n var digit = context.symbols().convertToDigit(ch);\n\n if (digit < 0) {\n pos--;\n\n if (pos < minEndPos) {\n return ~position;\n }\n\n break;\n }\n\n if (pos - position > MAX_WIDTH) {\n throw new ArithmeticException('number text exceeds length');\n } else {\n total = total * 10 + digit;\n }\n }\n\n if (this._subsequentWidth > 0 && pass === 0) {\n var parseLen = pos - position;\n effMaxWidth = Math.max(effMinWidth, parseLen - this._subsequentWidth);\n pos = position;\n total = 0;\n } else {\n break;\n }\n }\n\n if (negative) {\n if (total === 0 && context.isStrict()) {\n return ~(position - 1);\n }\n\n if (total !== 0) {\n total = -total;\n }\n } else if (this._signStyle === SignStyle.EXCEEDS_PAD && context.isStrict()) {\n var _parseLen = pos - position;\n\n if (positive) {\n if (_parseLen <= this._minWidth) {\n return ~(position - 1);\n }\n } else {\n if (_parseLen > this._minWidth) {\n return ~position;\n }\n }\n }\n\n return this._setValue(context, total, position, pos);\n };\n\n _proto._getValue = function _getValue(context, value) {\n return value;\n };\n\n _proto._setValue = function _setValue(context, value, errorPos, successPos) {\n return context.setParsedField(this._field, value, errorPos, successPos);\n };\n\n _proto.toString = function toString() {\n if (this._minWidth === 1 && this._maxWidth === MAX_WIDTH && this._signStyle === SignStyle.NORMAL) {\n return 'Value(' + this._field + ')';\n }\n\n if (this._minWidth === this._maxWidth && this._signStyle === SignStyle.NOT_NEGATIVE) {\n return 'Value(' + this._field + ',' + this._minWidth + ')';\n }\n\n return 'Value(' + this._field + ',' + this._minWidth + ',' + this._maxWidth + ',' + this._signStyle + ')';\n };\n\n return NumberPrinterParser;\n}();\nvar ReducedPrinterParser = function (_NumberPrinterParser) {\n _inheritsLoose(ReducedPrinterParser, _NumberPrinterParser);\n\n function ReducedPrinterParser(field, width, maxWidth, baseValue, baseDate) {\n var _this;\n\n _this = _NumberPrinterParser.call(this, field, width, maxWidth, SignStyle.NOT_NEGATIVE) || this;\n\n if (width < 1 || width > 10) {\n throw new IllegalArgumentException('The width must be from 1 to 10 inclusive but was ' + width);\n }\n\n if (maxWidth < 1 || maxWidth > 10) {\n throw new IllegalArgumentException('The maxWidth must be from 1 to 10 inclusive but was ' + maxWidth);\n }\n\n if (maxWidth < width) {\n throw new IllegalArgumentException('The maxWidth must be greater than the width');\n }\n\n if (baseDate === null) {\n if (field.range().isValidValue(baseValue) === false) {\n throw new IllegalArgumentException('The base value must be within the range of the field');\n }\n\n if (baseValue + EXCEED_POINTS[width] > MathUtil.MAX_SAFE_INTEGER) {\n throw new DateTimeException('Unable to add printer-parser as the range exceeds the capacity of an int');\n }\n }\n\n _this._baseValue = baseValue;\n _this._baseDate = baseDate;\n return _this;\n }\n\n var _proto2 = ReducedPrinterParser.prototype;\n\n _proto2._getValue = function _getValue(context, value) {\n var absValue = Math.abs(value);\n var baseValue = this._baseValue;\n\n if (this._baseDate !== null) {\n context.temporal();\n var chrono = IsoChronology.INSTANCE;\n baseValue = chrono.date(this._baseDate).get(this._field);\n }\n\n if (value >= baseValue && value < baseValue + EXCEED_POINTS[this._minWidth]) {\n return absValue % EXCEED_POINTS[this._minWidth];\n }\n\n return absValue % EXCEED_POINTS[this._maxWidth];\n };\n\n _proto2._setValue = function _setValue(context, value, errorPos, successPos) {\n var baseValue = this._baseValue;\n\n if (this._baseDate != null) {\n var chrono = context.getEffectiveChronology();\n baseValue = chrono.date(this._baseDate).get(this._field);\n }\n\n var parseLen = successPos - errorPos;\n\n if (parseLen === this._minWidth && value >= 0) {\n var range = EXCEED_POINTS[this._minWidth];\n var lastPart = baseValue % range;\n var basePart = baseValue - lastPart;\n\n if (baseValue > 0) {\n value = basePart + value;\n } else {\n value = basePart - value;\n }\n\n if (value < baseValue) {\n value += range;\n }\n }\n\n return context.setParsedField(this._field, value, errorPos, successPos);\n };\n\n _proto2.withFixedWidth = function withFixedWidth() {\n if (this._subsequentWidth === -1) {\n return this;\n }\n\n return new ReducedPrinterParser(this._field, this._minWidth, this._maxWidth, this._baseValue, this._baseDate, -1);\n };\n\n _proto2.withSubsequentWidth = function withSubsequentWidth(subsequentWidth) {\n return new ReducedPrinterParser(this._field, this._minWidth, this._maxWidth, this._baseValue, this._baseDate, this._subsequentWidth + subsequentWidth);\n };\n\n _proto2.isFixedWidth = function isFixedWidth(context) {\n if (context.isStrict() === false) {\n return false;\n }\n\n return _NumberPrinterParser.prototype.isFixedWidth.call(this, context);\n };\n\n _proto2.toString = function toString() {\n return 'ReducedValue(' + this._field + ',' + this._minWidth + ',' + this._maxWidth + ',' + (this._baseDate != null ? this._baseDate : this._baseValue) + ')';\n };\n\n return ReducedPrinterParser;\n}(NumberPrinterParser);\n\n/**\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar PATTERNS = ['+HH', '+HHmm', '+HH:mm', '+HHMM', '+HH:MM', '+HHMMss', '+HH:MM:ss', '+HHMMSS', '+HH:MM:SS'];\nvar OffsetIdPrinterParser = function () {\n function OffsetIdPrinterParser(noOffsetText, pattern) {\n requireNonNull(noOffsetText, 'noOffsetText');\n requireNonNull(pattern, 'pattern');\n this.noOffsetText = noOffsetText;\n this.type = this._checkPattern(pattern);\n }\n\n var _proto = OffsetIdPrinterParser.prototype;\n\n _proto._checkPattern = function _checkPattern(pattern) {\n for (var i = 0; i < PATTERNS.length; i++) {\n if (PATTERNS[i] === pattern) {\n return i;\n }\n }\n\n throw new IllegalArgumentException('Invalid zone offset pattern: ' + pattern);\n };\n\n _proto.print = function print(context, buf) {\n var offsetSecs = context.getValue(ChronoField.OFFSET_SECONDS);\n\n if (offsetSecs == null) {\n return false;\n }\n\n var totalSecs = MathUtil.safeToInt(offsetSecs);\n\n if (totalSecs === 0) {\n buf.append(this.noOffsetText);\n } else {\n var absHours = Math.abs(MathUtil.intMod(MathUtil.intDiv(totalSecs, 3600), 100));\n var absMinutes = Math.abs(MathUtil.intMod(MathUtil.intDiv(totalSecs, 60), 60));\n var absSeconds = Math.abs(MathUtil.intMod(totalSecs, 60));\n var bufPos = buf.length();\n var output = absHours;\n buf.append(totalSecs < 0 ? '-' : '+').appendChar(MathUtil.intDiv(absHours, 10) + '0').appendChar(MathUtil.intMod(absHours, 10) + '0');\n\n if (this.type >= 3 || this.type >= 1 && absMinutes > 0) {\n buf.append(this.type % 2 === 0 ? ':' : '').appendChar(MathUtil.intDiv(absMinutes, 10) + '0').appendChar(absMinutes % 10 + '0');\n output += absMinutes;\n\n if (this.type >= 7 || this.type >= 5 && absSeconds > 0) {\n buf.append(this.type % 2 === 0 ? ':' : '').appendChar(MathUtil.intDiv(absSeconds, 10) + '0').appendChar(absSeconds % 10 + '0');\n output += absSeconds;\n }\n }\n\n if (output === 0) {\n buf.setLength(bufPos);\n buf.append(this.noOffsetText);\n }\n }\n\n return true;\n };\n\n _proto.parse = function parse(context, text, position) {\n var length = text.length;\n var noOffsetLen = this.noOffsetText.length;\n\n if (noOffsetLen === 0) {\n if (position === length) {\n return context.setParsedField(ChronoField.OFFSET_SECONDS, 0, position, position);\n }\n } else {\n if (position === length) {\n return ~position;\n }\n\n if (context.subSequenceEquals(text, position, this.noOffsetText, 0, noOffsetLen)) {\n return context.setParsedField(ChronoField.OFFSET_SECONDS, 0, position, position + noOffsetLen);\n }\n }\n\n var sign = text[position];\n\n if (sign === '+' || sign === '-') {\n var negative = sign === '-' ? -1 : 1;\n var array = [0, 0, 0, 0];\n array[0] = position + 1;\n\n if ((this._parseNumber(array, 1, text, true) || this._parseNumber(array, 2, text, this.type >= 3) || this._parseNumber(array, 3, text, false)) === false) {\n var offsetSecs = MathUtil.safeZero(negative * (array[1] * 3600 + array[2] * 60 + array[3]));\n return context.setParsedField(ChronoField.OFFSET_SECONDS, offsetSecs, position, array[0]);\n }\n }\n\n if (noOffsetLen === 0) {\n return context.setParsedField(ChronoField.OFFSET_SECONDS, 0, position, position + noOffsetLen);\n }\n\n return ~position;\n };\n\n _proto._parseNumber = function _parseNumber(array, arrayIndex, parseText, required) {\n if ((this.type + 3) / 2 < arrayIndex) {\n return false;\n }\n\n var pos = array[0];\n\n if (this.type % 2 === 0 && arrayIndex > 1) {\n if (pos + 1 > parseText.length || parseText[pos] !== ':') {\n return required;\n }\n\n pos++;\n }\n\n if (pos + 2 > parseText.length) {\n return required;\n }\n\n var ch1 = parseText[pos++];\n var ch2 = parseText[pos++];\n\n if (ch1 < '0' || ch1 > '9' || ch2 < '0' || ch2 > '9') {\n return required;\n }\n\n var value = (ch1.charCodeAt(0) - 48) * 10 + (ch2.charCodeAt(0) - 48);\n\n if (value < 0 || value > 59) {\n return required;\n }\n\n array[arrayIndex] = value;\n array[0] = pos;\n return false;\n };\n\n _proto.toString = function toString() {\n var converted = this.noOffsetText.replace('\\'', '\\'\\'');\n return 'Offset(' + PATTERNS[this.type] + ',\\'' + converted + '\\')';\n };\n\n return OffsetIdPrinterParser;\n}();\nOffsetIdPrinterParser.INSTANCE_ID = new OffsetIdPrinterParser('Z', '+HH:MM:ss');\nOffsetIdPrinterParser.PATTERNS = PATTERNS;\n\n/**\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar PadPrinterParserDecorator = function () {\n function PadPrinterParserDecorator(printerParser, padWidth, padChar) {\n this._printerParser = printerParser;\n this._padWidth = padWidth;\n this._padChar = padChar;\n }\n\n var _proto = PadPrinterParserDecorator.prototype;\n\n _proto.print = function print(context, buf) {\n var preLen = buf.length();\n\n if (this._printerParser.print(context, buf) === false) {\n return false;\n }\n\n var len = buf.length() - preLen;\n\n if (len > this._padWidth) {\n throw new DateTimeException(\"Cannot print as output of \" + len + \" characters exceeds pad width of \" + this._padWidth);\n }\n\n for (var i = 0; i < this._padWidth - len; i++) {\n buf.insert(preLen, this._padChar);\n }\n\n return true;\n };\n\n _proto.parse = function parse(context, text, position) {\n var strict = context.isStrict();\n var caseSensitive = context.isCaseSensitive();\n assert(!(position > text.length));\n assert(position >= 0);\n\n if (position === text.length) {\n return ~position;\n }\n\n var endPos = position + this._padWidth;\n\n if (endPos > text.length) {\n if (strict) {\n return ~position;\n }\n\n endPos = text.length;\n }\n\n var pos = position;\n\n while (pos < endPos && (caseSensitive ? text[pos] === this._padChar : context.charEquals(text[pos], this._padChar))) {\n pos++;\n }\n\n text = text.substring(0, endPos);\n\n var resultPos = this._printerParser.parse(context, text, pos);\n\n if (resultPos !== endPos && strict) {\n return ~(position + pos);\n }\n\n return resultPos;\n };\n\n _proto.toString = function toString() {\n return \"Pad(\" + this._printerParser + \",\" + this._padWidth + (this._padChar === ' ' ? ')' : ',\\'' + this._padChar + '\\')');\n };\n\n return PadPrinterParserDecorator;\n}();\n\nvar SettingsParser = function (_Enum) {\n _inheritsLoose(SettingsParser, _Enum);\n\n function SettingsParser() {\n return _Enum.apply(this, arguments) || this;\n }\n\n var _proto = SettingsParser.prototype;\n\n _proto.print = function print() {\n return true;\n };\n\n _proto.parse = function parse(context, text, position) {\n switch (this) {\n case SettingsParser.SENSITIVE:\n context.setCaseSensitive(true);\n break;\n\n case SettingsParser.INSENSITIVE:\n context.setCaseSensitive(false);\n break;\n\n case SettingsParser.STRICT:\n context.setStrict(true);\n break;\n\n case SettingsParser.LENIENT:\n context.setStrict(false);\n break;\n }\n\n return position;\n };\n\n _proto.toString = function toString() {\n switch (this) {\n case SettingsParser.SENSITIVE:\n return 'ParseCaseSensitive(true)';\n\n case SettingsParser.INSENSITIVE:\n return 'ParseCaseSensitive(false)';\n\n case SettingsParser.STRICT:\n return 'ParseStrict(true)';\n\n case SettingsParser.LENIENT:\n return 'ParseStrict(false)';\n }\n };\n\n return SettingsParser;\n}(Enum);\nSettingsParser.SENSITIVE = new SettingsParser('SENSITIVE');\nSettingsParser.INSENSITIVE = new SettingsParser('INSENSITIVE');\nSettingsParser.STRICT = new SettingsParser('STRICT');\nSettingsParser.LENIENT = new SettingsParser('LENIENT');\n\n/**\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar StringLiteralPrinterParser = function () {\n function StringLiteralPrinterParser(literal) {\n this._literal = literal;\n }\n\n var _proto = StringLiteralPrinterParser.prototype;\n\n _proto.print = function print(context, buf) {\n buf.append(this._literal);\n return true;\n };\n\n _proto.parse = function parse(context, text, position) {\n var length = text.length;\n assert(!(position > length || position < 0));\n\n if (context.subSequenceEquals(text, position, this._literal, 0, this._literal.length) === false) {\n return ~position;\n }\n\n return position + this._literal.length;\n };\n\n _proto.toString = function toString() {\n var converted = this._literal.replace(\"'\", \"''\");\n\n return '\\'' + converted + '\\'';\n };\n\n return StringLiteralPrinterParser;\n}();\n\n/*\n * @copyright (c) 2016, Philipp Thürwächter, Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar ZoneRulesProvider = function () {\n function ZoneRulesProvider() {}\n\n ZoneRulesProvider.getRules = function getRules(zoneId) {\n throw new DateTimeException('unsupported ZoneId:' + zoneId);\n };\n\n ZoneRulesProvider.getAvailableZoneIds = function getAvailableZoneIds() {\n return [];\n };\n\n return ZoneRulesProvider;\n}();\n\nvar ZoneRegion = function (_ZoneId) {\n _inheritsLoose(ZoneRegion, _ZoneId);\n\n ZoneRegion.ofId = function ofId(zoneId) {\n var rules = ZoneRulesProvider.getRules(zoneId);\n return new ZoneRegion(zoneId, rules);\n };\n\n function ZoneRegion(id, rules) {\n var _this;\n\n _this = _ZoneId.call(this) || this;\n _this._id = id;\n _this._rules = rules;\n return _this;\n }\n\n var _proto = ZoneRegion.prototype;\n\n _proto.id = function id() {\n return this._id;\n };\n\n _proto.rules = function rules() {\n return this._rules;\n };\n\n return ZoneRegion;\n}(ZoneId);\n\n/**\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar ZoneIdPrinterParser = function () {\n function ZoneIdPrinterParser(query, description) {\n this.query = query;\n this.description = description;\n }\n\n var _proto = ZoneIdPrinterParser.prototype;\n\n _proto.print = function print(context, buf) {\n var zone = context.getValueQuery(this.query);\n\n if (zone == null) {\n return false;\n }\n\n buf.append(zone.id());\n return true;\n };\n\n _proto.parse = function parse(context, text, position) {\n var length = text.length;\n\n if (position > length) {\n return ~position;\n }\n\n if (position === length) {\n return ~position;\n }\n\n var nextChar = text.charAt(position);\n\n if (nextChar === '+' || nextChar === '-') {\n var newContext = context.copy();\n var endPos = OffsetIdPrinterParser.INSTANCE_ID.parse(newContext, text, position);\n\n if (endPos < 0) {\n return endPos;\n }\n\n var offset = newContext.getParsed(ChronoField.OFFSET_SECONDS);\n var zone = ZoneOffset.ofTotalSeconds(offset);\n context.setParsedZone(zone);\n return endPos;\n } else if (length >= position + 2) {\n var nextNextChar = text.charAt(position + 1);\n\n if (context.charEquals(nextChar, 'U') && context.charEquals(nextNextChar, 'T')) {\n if (length >= position + 3 && context.charEquals(text.charAt(position + 2), 'C')) {\n return this._parsePrefixedOffset(context, text, position, position + 3);\n }\n\n return this._parsePrefixedOffset(context, text, position, position + 2);\n } else if (context.charEquals(nextChar, 'G') && length >= position + 3 && context.charEquals(nextNextChar, 'M') && context.charEquals(text.charAt(position + 2), 'T')) {\n return this._parsePrefixedOffset(context, text, position, position + 3);\n }\n }\n\n if (text.substr(position, 6) === 'SYSTEM') {\n context.setParsedZone(ZoneId.systemDefault());\n return position + 6;\n }\n\n if (context.charEquals(nextChar, 'Z')) {\n context.setParsedZone(ZoneOffset.UTC);\n return position + 1;\n }\n\n var availableZoneIds = ZoneRulesProvider.getAvailableZoneIds();\n\n if (zoneIdTree.size !== availableZoneIds.length) {\n zoneIdTree = ZoneIdTree.createTreeMap(availableZoneIds);\n }\n\n var maxParseLength = length - position;\n var treeMap = zoneIdTree.treeMap;\n var parsedZoneId = null;\n var parseLength = 0;\n\n while (treeMap != null) {\n var parsedSubZoneId = text.substr(position, Math.min(treeMap.length, maxParseLength));\n treeMap = treeMap.get(parsedSubZoneId);\n\n if (treeMap != null && treeMap.isLeaf) {\n parsedZoneId = parsedSubZoneId;\n parseLength = treeMap.length;\n }\n }\n\n if (parsedZoneId != null) {\n context.setParsedZone(ZoneRegion.ofId(parsedZoneId));\n return position + parseLength;\n }\n\n return ~position;\n };\n\n _proto._parsePrefixedOffset = function _parsePrefixedOffset(context, text, prefixPos, position) {\n var prefix = text.substring(prefixPos, position).toUpperCase();\n var newContext = context.copy();\n\n if (position < text.length && context.charEquals(text.charAt(position), 'Z')) {\n context.setParsedZone(ZoneId.ofOffset(prefix, ZoneOffset.UTC));\n return position;\n }\n\n var endPos = OffsetIdPrinterParser.INSTANCE_ID.parse(newContext, text, position);\n\n if (endPos < 0) {\n context.setParsedZone(ZoneId.ofOffset(prefix, ZoneOffset.UTC));\n return position;\n }\n\n var offsetSecs = newContext.getParsed(ChronoField.OFFSET_SECONDS);\n var offset = ZoneOffset.ofTotalSeconds(offsetSecs);\n context.setParsedZone(ZoneId.ofOffset(prefix, offset));\n return endPos;\n };\n\n _proto.toString = function toString() {\n return this.description;\n };\n\n return ZoneIdPrinterParser;\n}();\n\nvar ZoneIdTree = function () {\n ZoneIdTree.createTreeMap = function createTreeMap(availableZoneIds) {\n var sortedZoneIds = availableZoneIds.sort(function (a, b) {\n return a.length - b.length;\n });\n var treeMap = new ZoneIdTreeMap(sortedZoneIds[0].length, false);\n\n for (var i = 0; i < sortedZoneIds.length; i++) {\n treeMap.add(sortedZoneIds[i]);\n }\n\n return new ZoneIdTree(sortedZoneIds.length, treeMap);\n };\n\n function ZoneIdTree(size, treeMap) {\n this.size = size;\n this.treeMap = treeMap;\n }\n\n return ZoneIdTree;\n}();\n\nvar ZoneIdTreeMap = function () {\n function ZoneIdTreeMap(length, isLeaf) {\n if (length === void 0) {\n length = 0;\n }\n\n if (isLeaf === void 0) {\n isLeaf = false;\n }\n\n this.length = length;\n this.isLeaf = isLeaf;\n this._treeMap = {};\n }\n\n var _proto2 = ZoneIdTreeMap.prototype;\n\n _proto2.add = function add(zoneId) {\n var idLength = zoneId.length;\n\n if (idLength === this.length) {\n this._treeMap[zoneId] = new ZoneIdTreeMap(idLength, true);\n } else if (idLength > this.length) {\n var subZoneId = zoneId.substr(0, this.length);\n var subTreeMap = this._treeMap[subZoneId];\n\n if (subTreeMap == null) {\n subTreeMap = new ZoneIdTreeMap(idLength, false);\n this._treeMap[subZoneId] = subTreeMap;\n }\n\n subTreeMap.add(zoneId);\n }\n };\n\n _proto2.get = function get(zoneId) {\n return this._treeMap[zoneId];\n };\n\n return ZoneIdTreeMap;\n}();\n\nvar zoneIdTree = new ZoneIdTree([]);\n\n/**\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar MAX_WIDTH$1 = 15;\nvar DateTimeFormatterBuilder = function () {\n function DateTimeFormatterBuilder() {\n this._active = this;\n this._parent = null;\n this._printerParsers = [];\n this._optional = false;\n this._padNextWidth = 0;\n this._padNextChar = null;\n this._valueParserIndex = -1;\n }\n\n DateTimeFormatterBuilder._of = function _of(parent, optional) {\n requireNonNull(parent, 'parent');\n requireNonNull(optional, 'optional');\n var dtFormatterBuilder = new DateTimeFormatterBuilder();\n dtFormatterBuilder._parent = parent;\n dtFormatterBuilder._optional = optional;\n return dtFormatterBuilder;\n };\n\n var _proto = DateTimeFormatterBuilder.prototype;\n\n _proto.parseCaseSensitive = function parseCaseSensitive() {\n this._appendInternalPrinterParser(SettingsParser.SENSITIVE);\n\n return this;\n };\n\n _proto.parseCaseInsensitive = function parseCaseInsensitive() {\n this._appendInternalPrinterParser(SettingsParser.INSENSITIVE);\n\n return this;\n };\n\n _proto.parseStrict = function parseStrict() {\n this._appendInternalPrinterParser(SettingsParser.STRICT);\n\n return this;\n };\n\n _proto.parseLenient = function parseLenient() {\n this._appendInternalPrinterParser(SettingsParser.LENIENT);\n\n return this;\n };\n\n _proto.appendValue = function appendValue() {\n if (arguments.length === 1) {\n return this._appendValue1.apply(this, arguments);\n } else if (arguments.length === 2) {\n return this._appendValue2.apply(this, arguments);\n } else {\n return this._appendValue4.apply(this, arguments);\n }\n };\n\n _proto._appendValue1 = function _appendValue1(field) {\n requireNonNull(field);\n\n this._appendValuePrinterParser(new NumberPrinterParser(field, 1, MAX_WIDTH$1, SignStyle.NORMAL));\n\n return this;\n };\n\n _proto._appendValue2 = function _appendValue2(field, width) {\n requireNonNull(field);\n\n if (width < 1 || width > MAX_WIDTH$1) {\n throw new IllegalArgumentException(\"The width must be from 1 to \" + MAX_WIDTH$1 + \" inclusive but was \" + width);\n }\n\n var pp = new NumberPrinterParser(field, width, width, SignStyle.NOT_NEGATIVE);\n\n this._appendValuePrinterParser(pp);\n\n return this;\n };\n\n _proto._appendValue4 = function _appendValue4(field, minWidth, maxWidth, signStyle) {\n requireNonNull(field);\n requireNonNull(signStyle);\n\n if (minWidth === maxWidth && signStyle === SignStyle.NOT_NEGATIVE) {\n return this._appendValue2(field, maxWidth);\n }\n\n if (minWidth < 1 || minWidth > MAX_WIDTH$1) {\n throw new IllegalArgumentException(\"The minimum width must be from 1 to \" + MAX_WIDTH$1 + \" inclusive but was \" + minWidth);\n }\n\n if (maxWidth < 1 || maxWidth > MAX_WIDTH$1) {\n throw new IllegalArgumentException(\"The minimum width must be from 1 to \" + MAX_WIDTH$1 + \" inclusive but was \" + maxWidth);\n }\n\n if (maxWidth < minWidth) {\n throw new IllegalArgumentException(\"The maximum width must exceed or equal the minimum width but \" + maxWidth + \" < \" + minWidth);\n }\n\n var pp = new NumberPrinterParser(field, minWidth, maxWidth, signStyle);\n\n this._appendValuePrinterParser(pp);\n\n return this;\n };\n\n _proto.appendValueReduced = function appendValueReduced() {\n if (arguments.length === 4 && arguments[3] instanceof ChronoLocalDate) {\n return this._appendValueReducedFieldWidthMaxWidthBaseDate.apply(this, arguments);\n } else {\n return this._appendValueReducedFieldWidthMaxWidthBaseValue.apply(this, arguments);\n }\n };\n\n _proto._appendValueReducedFieldWidthMaxWidthBaseValue = function _appendValueReducedFieldWidthMaxWidthBaseValue(field, width, maxWidth, baseValue) {\n requireNonNull(field, 'field');\n var pp = new ReducedPrinterParser(field, width, maxWidth, baseValue, null);\n\n this._appendValuePrinterParser(pp);\n\n return this;\n };\n\n _proto._appendValueReducedFieldWidthMaxWidthBaseDate = function _appendValueReducedFieldWidthMaxWidthBaseDate(field, width, maxWidth, baseDate) {\n requireNonNull(field, 'field');\n requireNonNull(baseDate, 'baseDate');\n requireInstance(baseDate, ChronoLocalDate, 'baseDate');\n var pp = new ReducedPrinterParser(field, width, maxWidth, 0, baseDate);\n\n this._appendValuePrinterParser(pp);\n\n return this;\n };\n\n _proto._appendValuePrinterParser = function _appendValuePrinterParser(pp) {\n assert(pp != null);\n\n if (this._active._valueParserIndex >= 0 && this._active._printerParsers[this._active._valueParserIndex] instanceof NumberPrinterParser) {\n var activeValueParser = this._active._valueParserIndex;\n var basePP = this._active._printerParsers[activeValueParser];\n\n if (pp.minWidth() === pp.maxWidth() && pp.signStyle() === SignStyle.NOT_NEGATIVE) {\n basePP = basePP.withSubsequentWidth(pp.maxWidth());\n\n this._appendInternal(pp.withFixedWidth());\n\n this._active._valueParserIndex = activeValueParser;\n } else {\n basePP = basePP.withFixedWidth();\n this._active._valueParserIndex = this._appendInternal(pp);\n }\n\n this._active._printerParsers[activeValueParser] = basePP;\n } else {\n this._active._valueParserIndex = this._appendInternal(pp);\n }\n\n return this;\n };\n\n _proto.appendFraction = function appendFraction(field, minWidth, maxWidth, decimalPoint) {\n this._appendInternal(new FractionPrinterParser(field, minWidth, maxWidth, decimalPoint));\n\n return this;\n };\n\n _proto.appendInstant = function appendInstant(fractionalDigits) {\n if (fractionalDigits === void 0) {\n fractionalDigits = -2;\n }\n\n if (fractionalDigits < -2 || fractionalDigits > 9) {\n throw new IllegalArgumentException('Invalid fractional digits: ' + fractionalDigits);\n }\n\n this._appendInternal(new InstantPrinterParser(fractionalDigits));\n\n return this;\n };\n\n _proto.appendOffsetId = function appendOffsetId() {\n this._appendInternal(OffsetIdPrinterParser.INSTANCE_ID);\n\n return this;\n };\n\n _proto.appendOffset = function appendOffset(pattern, noOffsetText) {\n this._appendInternalPrinterParser(new OffsetIdPrinterParser(noOffsetText, pattern));\n\n return this;\n };\n\n _proto.appendZoneId = function appendZoneId() {\n this._appendInternal(new ZoneIdPrinterParser(TemporalQueries.zoneId(), 'ZoneId()'));\n\n return this;\n };\n\n _proto.appendPattern = function appendPattern(pattern) {\n requireNonNull(pattern, 'pattern');\n\n this._parsePattern(pattern);\n\n return this;\n };\n\n _proto.appendZoneText = function appendZoneText() {\n throw new IllegalArgumentException('Pattern using (localized) text not implemented, use js-joda-locale plugin!');\n };\n\n _proto.appendText = function appendText() {\n throw new IllegalArgumentException('Pattern using (localized) text not implemented, use js-joda-locale plugin!');\n };\n\n _proto.appendLocalizedOffset = function appendLocalizedOffset() {\n throw new IllegalArgumentException('Pattern using (localized) text not implemented, use js-joda-locale plugin!');\n };\n\n _proto.appendWeekField = function appendWeekField() {\n throw new IllegalArgumentException('Pattern using (localized) text not implemented, use js-joda-locale plugin!');\n };\n\n _proto._parsePattern = function _parsePattern(pattern) {\n var FIELD_MAP = {\n 'G': ChronoField.ERA,\n 'y': ChronoField.YEAR_OF_ERA,\n 'u': ChronoField.YEAR,\n 'Q': IsoFields.QUARTER_OF_YEAR,\n 'q': IsoFields.QUARTER_OF_YEAR,\n 'M': ChronoField.MONTH_OF_YEAR,\n 'L': ChronoField.MONTH_OF_YEAR,\n 'D': ChronoField.DAY_OF_YEAR,\n 'd': ChronoField.DAY_OF_MONTH,\n 'F': ChronoField.ALIGNED_DAY_OF_WEEK_IN_MONTH,\n 'E': ChronoField.DAY_OF_WEEK,\n 'c': ChronoField.DAY_OF_WEEK,\n 'e': ChronoField.DAY_OF_WEEK,\n 'a': ChronoField.AMPM_OF_DAY,\n 'H': ChronoField.HOUR_OF_DAY,\n 'k': ChronoField.CLOCK_HOUR_OF_DAY,\n 'K': ChronoField.HOUR_OF_AMPM,\n 'h': ChronoField.CLOCK_HOUR_OF_AMPM,\n 'm': ChronoField.MINUTE_OF_HOUR,\n 's': ChronoField.SECOND_OF_MINUTE,\n 'S': ChronoField.NANO_OF_SECOND,\n 'A': ChronoField.MILLI_OF_DAY,\n 'n': ChronoField.NANO_OF_SECOND,\n 'N': ChronoField.NANO_OF_DAY\n };\n\n for (var pos = 0; pos < pattern.length; pos++) {\n var cur = pattern.charAt(pos);\n\n if (cur >= 'A' && cur <= 'Z' || cur >= 'a' && cur <= 'z') {\n var start = pos++;\n\n for (; pos < pattern.length && pattern.charAt(pos) === cur; pos++) {\n }\n\n var count = pos - start;\n\n if (cur === 'p') {\n var pad = 0;\n\n if (pos < pattern.length) {\n cur = pattern.charAt(pos);\n\n if (cur >= 'A' && cur <= 'Z' || cur >= 'a' && cur <= 'z') {\n pad = count;\n start = pos++;\n\n for (; pos < pattern.length && pattern.charAt(pos) === cur; pos++) {\n }\n\n count = pos - start;\n }\n }\n\n if (pad === 0) {\n throw new IllegalArgumentException('Pad letter \\'p\\' must be followed by valid pad pattern: ' + pattern);\n }\n\n this.padNext(pad);\n }\n\n var field = FIELD_MAP[cur];\n\n if (field != null) {\n this._parseField(cur, count, field);\n } else if (cur === 'z') {\n if (count > 4) {\n throw new IllegalArgumentException('Too many pattern letters: ' + cur);\n } else if (count === 4) {\n this.appendZoneText(TextStyle.FULL);\n } else {\n this.appendZoneText(TextStyle.SHORT);\n }\n } else if (cur === 'V') {\n if (count !== 2) {\n throw new IllegalArgumentException('Pattern letter count must be 2: ' + cur);\n }\n\n this.appendZoneId();\n } else if (cur === 'Z') {\n if (count < 4) {\n this.appendOffset('+HHMM', '+0000');\n } else if (count === 4) {\n this.appendLocalizedOffset(TextStyle.FULL);\n } else if (count === 5) {\n this.appendOffset('+HH:MM:ss', 'Z');\n } else {\n throw new IllegalArgumentException('Too many pattern letters: ' + cur);\n }\n } else if (cur === 'O') {\n if (count === 1) {\n this.appendLocalizedOffset(TextStyle.SHORT);\n } else if (count === 4) {\n this.appendLocalizedOffset(TextStyle.FULL);\n } else {\n throw new IllegalArgumentException('Pattern letter count must be 1 or 4: ' + cur);\n }\n } else if (cur === 'X') {\n if (count > 5) {\n throw new IllegalArgumentException('Too many pattern letters: ' + cur);\n }\n\n this.appendOffset(OffsetIdPrinterParser.PATTERNS[count + (count === 1 ? 0 : 1)], 'Z');\n } else if (cur === 'x') {\n if (count > 5) {\n throw new IllegalArgumentException('Too many pattern letters: ' + cur);\n }\n\n var zero = count === 1 ? '+00' : count % 2 === 0 ? '+0000' : '+00:00';\n this.appendOffset(OffsetIdPrinterParser.PATTERNS[count + (count === 1 ? 0 : 1)], zero);\n } else if (cur === 'W') {\n if (count > 1) {\n throw new IllegalArgumentException('Too many pattern letters: ' + cur);\n }\n\n this.appendWeekField('W', count);\n } else if (cur === 'w') {\n if (count > 2) {\n throw new IllegalArgumentException('Too many pattern letters: ' + cur);\n }\n\n this.appendWeekField('w', count);\n } else if (cur === 'Y') {\n this.appendWeekField('Y', count);\n } else {\n throw new IllegalArgumentException('Unknown pattern letter: ' + cur);\n }\n\n pos--;\n } else if (cur === '\\'') {\n var _start = pos++;\n\n for (; pos < pattern.length; pos++) {\n if (pattern.charAt(pos) === '\\'') {\n if (pos + 1 < pattern.length && pattern.charAt(pos + 1) === '\\'') {\n pos++;\n } else {\n break;\n }\n }\n }\n\n if (pos >= pattern.length) {\n throw new IllegalArgumentException('Pattern ends with an incomplete string literal: ' + pattern);\n }\n\n var str = pattern.substring(_start + 1, pos);\n\n if (str.length === 0) {\n this.appendLiteral('\\'');\n } else {\n this.appendLiteral(str.replace('\\'\\'', '\\''));\n }\n } else if (cur === '[') {\n this.optionalStart();\n } else if (cur === ']') {\n if (this._active._parent === null) {\n throw new IllegalArgumentException('Pattern invalid as it contains ] without previous [');\n }\n\n this.optionalEnd();\n } else if (cur === '{' || cur === '}' || cur === '#') {\n throw new IllegalArgumentException('Pattern includes reserved character: \\'' + cur + '\\'');\n } else {\n this.appendLiteral(cur);\n }\n }\n };\n\n _proto._parseField = function _parseField(cur, count, field) {\n switch (cur) {\n case 'u':\n case 'y':\n if (count === 2) {\n this.appendValueReduced(field, 2, 2, ReducedPrinterParser.BASE_DATE);\n } else if (count < 4) {\n this.appendValue(field, count, MAX_WIDTH$1, SignStyle.NORMAL);\n } else {\n this.appendValue(field, count, MAX_WIDTH$1, SignStyle.EXCEEDS_PAD);\n }\n\n break;\n\n case 'M':\n case 'Q':\n switch (count) {\n case 1:\n this.appendValue(field);\n break;\n\n case 2:\n this.appendValue(field, 2);\n break;\n\n case 3:\n this.appendText(field, TextStyle.SHORT);\n break;\n\n case 4:\n this.appendText(field, TextStyle.FULL);\n break;\n\n case 5:\n this.appendText(field, TextStyle.NARROW);\n break;\n\n default:\n throw new IllegalArgumentException('Too many pattern letters: ' + cur);\n }\n\n break;\n\n case 'L':\n case 'q':\n switch (count) {\n case 1:\n this.appendValue(field);\n break;\n\n case 2:\n this.appendValue(field, 2);\n break;\n\n case 3:\n this.appendText(field, TextStyle.SHORT_STANDALONE);\n break;\n\n case 4:\n this.appendText(field, TextStyle.FULL_STANDALONE);\n break;\n\n case 5:\n this.appendText(field, TextStyle.NARROW_STANDALONE);\n break;\n\n default:\n throw new IllegalArgumentException('Too many pattern letters: ' + cur);\n }\n\n break;\n\n case 'e':\n switch (count) {\n case 1:\n case 2:\n this.appendWeekField('e', count);\n break;\n\n case 3:\n this.appendText(field, TextStyle.SHORT);\n break;\n\n case 4:\n this.appendText(field, TextStyle.FULL);\n break;\n\n case 5:\n this.appendText(field, TextStyle.NARROW);\n break;\n\n default:\n throw new IllegalArgumentException('Too many pattern letters: ' + cur);\n }\n\n break;\n\n case 'c':\n switch (count) {\n case 1:\n this.appendWeekField('c', count);\n break;\n\n case 2:\n throw new IllegalArgumentException('Invalid number of pattern letters: ' + cur);\n\n case 3:\n this.appendText(field, TextStyle.SHORT_STANDALONE);\n break;\n\n case 4:\n this.appendText(field, TextStyle.FULL_STANDALONE);\n break;\n\n case 5:\n this.appendText(field, TextStyle.NARROW_STANDALONE);\n break;\n\n default:\n throw new IllegalArgumentException('Too many pattern letters: ' + cur);\n }\n\n break;\n\n case 'a':\n if (count === 1) {\n this.appendText(field, TextStyle.SHORT);\n } else {\n throw new IllegalArgumentException('Too many pattern letters: ' + cur);\n }\n\n break;\n\n case 'E':\n case 'G':\n switch (count) {\n case 1:\n case 2:\n case 3:\n this.appendText(field, TextStyle.SHORT);\n break;\n\n case 4:\n this.appendText(field, TextStyle.FULL);\n break;\n\n case 5:\n this.appendText(field, TextStyle.NARROW);\n break;\n\n default:\n throw new IllegalArgumentException('Too many pattern letters: ' + cur);\n }\n\n break;\n\n case 'S':\n this.appendFraction(ChronoField.NANO_OF_SECOND, count, count, false);\n break;\n\n case 'F':\n if (count === 1) {\n this.appendValue(field);\n } else {\n throw new IllegalArgumentException('Too many pattern letters: ' + cur);\n }\n\n break;\n\n case 'd':\n case 'h':\n case 'H':\n case 'k':\n case 'K':\n case 'm':\n case 's':\n if (count === 1) {\n this.appendValue(field);\n } else if (count === 2) {\n this.appendValue(field, count);\n } else {\n throw new IllegalArgumentException('Too many pattern letters: ' + cur);\n }\n\n break;\n\n case 'D':\n if (count === 1) {\n this.appendValue(field);\n } else if (count <= 3) {\n this.appendValue(field, count);\n } else {\n throw new IllegalArgumentException('Too many pattern letters: ' + cur);\n }\n\n break;\n\n default:\n if (count === 1) {\n this.appendValue(field);\n } else {\n this.appendValue(field, count);\n }\n\n break;\n }\n };\n\n _proto.padNext = function padNext() {\n if (arguments.length === 1) {\n return this._padNext1.apply(this, arguments);\n } else {\n return this._padNext2.apply(this, arguments);\n }\n };\n\n _proto._padNext1 = function _padNext1(padWidth) {\n return this._padNext2(padWidth, ' ');\n };\n\n _proto._padNext2 = function _padNext2(padWidth, padChar) {\n if (padWidth < 1) {\n throw new IllegalArgumentException('The pad width must be at least one but was ' + padWidth);\n }\n\n this._active._padNextWidth = padWidth;\n this._active._padNextChar = padChar;\n this._active._valueParserIndex = -1;\n return this;\n };\n\n _proto.optionalStart = function optionalStart() {\n this._active._valueParserIndex = -1;\n this._active = DateTimeFormatterBuilder._of(this._active, true);\n return this;\n };\n\n _proto.optionalEnd = function optionalEnd() {\n if (this._active._parent == null) {\n throw new IllegalStateException('Cannot call optionalEnd() as there was no previous call to optionalStart()');\n }\n\n if (this._active._printerParsers.length > 0) {\n var cpp = new CompositePrinterParser(this._active._printerParsers, this._active._optional);\n this._active = this._active._parent;\n\n this._appendInternal(cpp);\n } else {\n this._active = this._active._parent;\n }\n\n return this;\n };\n\n _proto._appendInternal = function _appendInternal(pp) {\n assert(pp != null);\n\n if (this._active._padNextWidth > 0) {\n if (pp != null) {\n pp = new PadPrinterParserDecorator(pp, this._active._padNextWidth, this._active._padNextChar);\n }\n\n this._active._padNextWidth = 0;\n this._active._padNextChar = 0;\n }\n\n this._active._printerParsers.push(pp);\n\n this._active._valueParserIndex = -1;\n return this._active._printerParsers.length - 1;\n };\n\n _proto.appendLiteral = function appendLiteral(literal) {\n assert(literal != null);\n\n if (literal.length > 0) {\n if (literal.length === 1) {\n this._appendInternalPrinterParser(new CharLiteralPrinterParser(literal.charAt(0)));\n } else {\n this._appendInternalPrinterParser(new StringLiteralPrinterParser(literal));\n }\n }\n\n return this;\n };\n\n _proto._appendInternalPrinterParser = function _appendInternalPrinterParser(pp) {\n assert(pp != null);\n\n if (this._active._padNextWidth > 0) {\n if (pp != null) {\n pp = new PadPrinterParserDecorator(pp, this._active._padNextWidth, this._active._padNextChar);\n }\n\n this._active._padNextWidth = 0;\n this._active._padNextChar = 0;\n }\n\n this._active._printerParsers.push(pp);\n\n this._active._valueParserIndex = -1;\n return this._active._printerParsers.length - 1;\n };\n\n _proto.append = function append(formatter) {\n requireNonNull(formatter, 'formatter');\n\n this._appendInternal(formatter._toPrinterParser(false));\n\n return this;\n };\n\n _proto.toFormatter = function toFormatter(resolverStyle) {\n if (resolverStyle === void 0) {\n resolverStyle = ResolverStyle.SMART;\n }\n\n while (this._active._parent != null) {\n this.optionalEnd();\n }\n\n var pp = new CompositePrinterParser(this._printerParsers, false);\n return new DateTimeFormatter(pp, null, DecimalStyle.STANDARD, resolverStyle, null, null, null);\n };\n\n return DateTimeFormatterBuilder;\n}();\nvar SECONDS_PER_10000_YEARS = 146097 * 25 * 86400;\nvar SECONDS_0000_TO_1970 = (146097 * 5 - (30 * 365 + 7)) * 86400;\n\nvar InstantPrinterParser = function () {\n function InstantPrinterParser(fractionalDigits) {\n this.fractionalDigits = fractionalDigits;\n }\n\n var _proto2 = InstantPrinterParser.prototype;\n\n _proto2.print = function print(context, buf) {\n var inSecs = context.getValue(ChronoField.INSTANT_SECONDS);\n var inNanos = 0;\n\n if (context.temporal().isSupported(ChronoField.NANO_OF_SECOND)) {\n inNanos = context.temporal().getLong(ChronoField.NANO_OF_SECOND);\n }\n\n if (inSecs == null) {\n return false;\n }\n\n var inSec = inSecs;\n var inNano = ChronoField.NANO_OF_SECOND.checkValidIntValue(inNanos);\n\n if (inSec >= -SECONDS_0000_TO_1970) {\n var zeroSecs = inSec - SECONDS_PER_10000_YEARS + SECONDS_0000_TO_1970;\n var hi = MathUtil.floorDiv(zeroSecs, SECONDS_PER_10000_YEARS) + 1;\n var lo = MathUtil.floorMod(zeroSecs, SECONDS_PER_10000_YEARS);\n var ldt = LocalDateTime.ofEpochSecond(lo - SECONDS_0000_TO_1970, 0, ZoneOffset.UTC);\n\n if (hi > 0) {\n buf.append('+').append(hi);\n }\n\n buf.append(ldt);\n\n if (ldt.second() === 0) {\n buf.append(':00');\n }\n } else {\n var _zeroSecs = inSec + SECONDS_0000_TO_1970;\n\n var _hi = MathUtil.intDiv(_zeroSecs, SECONDS_PER_10000_YEARS);\n\n var _lo = MathUtil.intMod(_zeroSecs, SECONDS_PER_10000_YEARS);\n\n var _ldt = LocalDateTime.ofEpochSecond(_lo - SECONDS_0000_TO_1970, 0, ZoneOffset.UTC);\n\n var pos = buf.length();\n buf.append(_ldt);\n\n if (_ldt.second() === 0) {\n buf.append(':00');\n }\n\n if (_hi < 0) {\n if (_ldt.year() === -10000) {\n buf.replace(pos, pos + 2, '' + (_hi - 1));\n } else if (_lo === 0) {\n buf.insert(pos, _hi);\n } else {\n buf.insert(pos + 1, Math.abs(_hi));\n }\n }\n }\n\n if (this.fractionalDigits === -2) {\n if (inNano !== 0) {\n buf.append('.');\n\n if (MathUtil.intMod(inNano, 1000000) === 0) {\n buf.append(('' + (MathUtil.intDiv(inNano, 1000000) + 1000)).substring(1));\n } else if (MathUtil.intMod(inNano, 1000) === 0) {\n buf.append(('' + (MathUtil.intDiv(inNano, 1000) + 1000000)).substring(1));\n } else {\n buf.append(('' + (inNano + 1000000000)).substring(1));\n }\n }\n } else if (this.fractionalDigits > 0 || this.fractionalDigits === -1 && inNano > 0) {\n buf.append('.');\n var div = 100000000;\n\n for (var i = 0; this.fractionalDigits === -1 && inNano > 0 || i < this.fractionalDigits; i++) {\n var digit = MathUtil.intDiv(inNano, div);\n buf.append(digit);\n inNano = inNano - digit * div;\n div = MathUtil.intDiv(div, 10);\n }\n }\n\n buf.append('Z');\n return true;\n };\n\n _proto2.parse = function parse(context, text, position) {\n var newContext = context.copy();\n var minDigits = this.fractionalDigits < 0 ? 0 : this.fractionalDigits;\n var maxDigits = this.fractionalDigits < 0 ? 9 : this.fractionalDigits;\n\n var parser = new DateTimeFormatterBuilder().append(DateTimeFormatter.ISO_LOCAL_DATE).appendLiteral('T').appendValue(ChronoField.HOUR_OF_DAY, 2).appendLiteral(':').appendValue(ChronoField.MINUTE_OF_HOUR, 2).appendLiteral(':').appendValue(ChronoField.SECOND_OF_MINUTE, 2).appendFraction(ChronoField.NANO_OF_SECOND, minDigits, maxDigits, true).appendLiteral('Z').toFormatter()._toPrinterParser(false);\n\n var pos = parser.parse(newContext, text, position);\n\n if (pos < 0) {\n return pos;\n }\n\n var yearParsed = newContext.getParsed(ChronoField.YEAR);\n var month = newContext.getParsed(ChronoField.MONTH_OF_YEAR);\n var day = newContext.getParsed(ChronoField.DAY_OF_MONTH);\n var hour = newContext.getParsed(ChronoField.HOUR_OF_DAY);\n var min = newContext.getParsed(ChronoField.MINUTE_OF_HOUR);\n var secVal = newContext.getParsed(ChronoField.SECOND_OF_MINUTE);\n var nanoVal = newContext.getParsed(ChronoField.NANO_OF_SECOND);\n var sec = secVal != null ? secVal : 0;\n var nano = nanoVal != null ? nanoVal : 0;\n var year = MathUtil.intMod(yearParsed, 10000);\n var days = 0;\n\n if (hour === 24 && min === 0 && sec === 0 && nano === 0) {\n hour = 0;\n days = 1;\n } else if (hour === 23 && min === 59 && sec === 60) {\n context.setParsedLeapSecond();\n sec = 59;\n }\n\n var instantSecs;\n\n try {\n var ldt = LocalDateTime.of(year, month, day, hour, min, sec, 0).plusDays(days);\n instantSecs = ldt.toEpochSecond(ZoneOffset.UTC);\n instantSecs += MathUtil.safeMultiply(MathUtil.intDiv(yearParsed, 10000), SECONDS_PER_10000_YEARS);\n } catch (ex) {\n return ~position;\n }\n\n var successPos = pos;\n successPos = context.setParsedField(ChronoField.INSTANT_SECONDS, instantSecs, position, successPos);\n return context.setParsedField(ChronoField.NANO_OF_SECOND, nano, position, successPos);\n };\n\n _proto2.toString = function toString() {\n return 'Instant()';\n };\n\n return InstantPrinterParser;\n}();\n\nfunction _init$9() {\n ReducedPrinterParser.BASE_DATE = LocalDate.of(2000, 1, 1);\n DateTimeFormatterBuilder.CompositePrinterParser = CompositePrinterParser;\n DateTimeFormatterBuilder.PadPrinterParserDecorator = PadPrinterParserDecorator;\n DateTimeFormatterBuilder.SettingsParser = SettingsParser;\n DateTimeFormatterBuilder.CharLiteralPrinterParser = StringLiteralPrinterParser;\n DateTimeFormatterBuilder.StringLiteralPrinterParser = StringLiteralPrinterParser;\n DateTimeFormatterBuilder.CharLiteralPrinterParser = CharLiteralPrinterParser;\n DateTimeFormatterBuilder.NumberPrinterParser = NumberPrinterParser;\n DateTimeFormatterBuilder.ReducedPrinterParser = ReducedPrinterParser;\n DateTimeFormatterBuilder.FractionPrinterParser = FractionPrinterParser;\n DateTimeFormatterBuilder.OffsetIdPrinterParser = OffsetIdPrinterParser;\n DateTimeFormatterBuilder.ZoneIdPrinterParser = ZoneIdPrinterParser;\n}\n\n/*\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar StringBuilder = function () {\n function StringBuilder() {\n this._str = '';\n }\n\n var _proto = StringBuilder.prototype;\n\n _proto.append = function append(str) {\n this._str += str;\n return this;\n };\n\n _proto.appendChar = function appendChar(str) {\n this._str += str[0];\n return this;\n };\n\n _proto.insert = function insert(offset, str) {\n this._str = this._str.slice(0, offset) + str + this._str.slice(offset);\n return this;\n };\n\n _proto.replace = function replace(start, end, str) {\n this._str = this._str.slice(0, start) + str + this._str.slice(end);\n return this;\n };\n\n _proto.length = function length() {\n return this._str.length;\n };\n\n _proto.setLength = function setLength(length) {\n this._str = this._str.slice(0, length);\n return this;\n };\n\n _proto.toString = function toString() {\n return this._str;\n };\n\n return StringBuilder;\n}();\n\n/**\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar DateTimeFormatter = function () {\n DateTimeFormatter.parsedExcessDays = function parsedExcessDays() {\n return DateTimeFormatter.PARSED_EXCESS_DAYS;\n };\n\n DateTimeFormatter.parsedLeapSecond = function parsedLeapSecond() {\n return DateTimeFormatter.PARSED_LEAP_SECOND;\n };\n\n DateTimeFormatter.ofPattern = function ofPattern(pattern) {\n return new DateTimeFormatterBuilder().appendPattern(pattern).toFormatter();\n };\n\n function DateTimeFormatter(printerParser, locale, decimalStyle, resolverStyle, resolverFields, chrono, zone) {\n if (chrono === void 0) {\n chrono = IsoChronology.INSTANCE;\n }\n\n assert(printerParser != null);\n assert(decimalStyle != null);\n assert(resolverStyle != null);\n this._printerParser = printerParser;\n this._locale = locale;\n this._decimalStyle = decimalStyle;\n this._resolverStyle = resolverStyle;\n this._resolverFields = resolverFields;\n this._chrono = chrono;\n this._zone = zone;\n }\n\n var _proto = DateTimeFormatter.prototype;\n\n _proto.locale = function locale() {\n return this._locale;\n };\n\n _proto.decimalStyle = function decimalStyle() {\n return this._decimalStyle;\n };\n\n _proto.chronology = function chronology() {\n return this._chrono;\n };\n\n _proto.withChronology = function withChronology(chrono) {\n if (this._chrono != null && this._chrono.equals(chrono)) {\n return this;\n }\n\n return new DateTimeFormatter(this._printerParser, this._locale, this._decimalStyle, this._resolverStyle, this._resolverFields, chrono, this._zone);\n };\n\n _proto.withLocale = function withLocale() {\n return this;\n };\n\n _proto.withResolverStyle = function withResolverStyle(resolverStyle) {\n requireNonNull(resolverStyle, 'resolverStyle');\n\n if (resolverStyle.equals(this._resolverStyle)) {\n return this;\n }\n\n return new DateTimeFormatter(this._printerParser, this._locale, this._decimalStyle, resolverStyle, this._resolverFields, this._chrono, this._zone);\n };\n\n _proto.format = function format(temporal) {\n var buf = new StringBuilder(32);\n\n this._formatTo(temporal, buf);\n\n return buf.toString();\n };\n\n _proto._formatTo = function _formatTo(temporal, appendable) {\n requireNonNull(temporal, 'temporal');\n requireNonNull(appendable, 'appendable');\n var context = new DateTimePrintContext(temporal, this);\n\n this._printerParser.print(context, appendable);\n };\n\n _proto.parse = function parse(text, type) {\n if (arguments.length === 1) {\n return this.parse1(text);\n } else {\n return this.parse2(text, type);\n }\n };\n\n _proto.parse1 = function parse1(text) {\n requireNonNull(text, 'text');\n\n try {\n return this._parseToBuilder(text, null).resolve(this._resolverStyle, this._resolverFields);\n } catch (ex) {\n if (ex instanceof DateTimeParseException) {\n throw ex;\n } else {\n throw this._createError(text, ex);\n }\n }\n };\n\n _proto.parse2 = function parse2(text, type) {\n requireNonNull(text, 'text');\n requireNonNull(type, 'type');\n\n try {\n var builder = this._parseToBuilder(text, null).resolve(this._resolverStyle, this._resolverFields);\n\n return builder.build(type);\n } catch (ex) {\n if (ex instanceof DateTimeParseException) {\n throw ex;\n } else {\n throw this._createError(text, ex);\n }\n }\n };\n\n _proto._createError = function _createError(text, ex) {\n var abbr = '';\n\n if (text.length > 64) {\n abbr = text.substring(0, 64) + '...';\n } else {\n abbr = text;\n }\n\n return new DateTimeParseException('Text \\'' + abbr + '\\' could not be parsed: ' + ex.message, text, 0, ex);\n };\n\n _proto._parseToBuilder = function _parseToBuilder(text, position) {\n var pos = position != null ? position : new ParsePosition(0);\n\n var result = this._parseUnresolved0(text, pos);\n\n if (result == null || pos.getErrorIndex() >= 0 || position == null && pos.getIndex() < text.length) {\n var abbr = '';\n\n if (text.length > 64) {\n abbr = text.substr(0, 64).toString() + '...';\n } else {\n abbr = text;\n }\n\n if (pos.getErrorIndex() >= 0) {\n throw new DateTimeParseException('Text \\'' + abbr + '\\' could not be parsed at index ' + pos.getErrorIndex(), text, pos.getErrorIndex());\n } else {\n throw new DateTimeParseException('Text \\'' + abbr + '\\' could not be parsed, unparsed text found at index ' + pos.getIndex(), text, pos.getIndex());\n }\n }\n\n return result.toBuilder();\n };\n\n _proto.parseUnresolved = function parseUnresolved(text, position) {\n return this._parseUnresolved0(text, position);\n };\n\n _proto._parseUnresolved0 = function _parseUnresolved0(text, position) {\n assert(text != null, 'text', NullPointerException);\n assert(position != null, 'position', NullPointerException);\n var context = new DateTimeParseContext(this);\n var pos = position.getIndex();\n pos = this._printerParser.parse(context, text, pos);\n\n if (pos < 0) {\n position.setErrorIndex(~pos);\n return null;\n }\n\n position.setIndex(pos);\n return context.toParsed();\n };\n\n _proto._toPrinterParser = function _toPrinterParser(optional) {\n return this._printerParser.withOptional(optional);\n };\n\n _proto.toString = function toString() {\n var pattern = this._printerParser.toString();\n\n return pattern.indexOf('[') === 0 ? pattern : pattern.substring(1, pattern.length - 1);\n };\n\n return DateTimeFormatter;\n}();\nfunction _init$a() {\n DateTimeFormatter.ISO_LOCAL_DATE = new DateTimeFormatterBuilder().appendValue(ChronoField.YEAR, 4, 10, SignStyle.EXCEEDS_PAD).appendLiteral('-').appendValue(ChronoField.MONTH_OF_YEAR, 2).appendLiteral('-').appendValue(ChronoField.DAY_OF_MONTH, 2).toFormatter(ResolverStyle.STRICT).withChronology(IsoChronology.INSTANCE);\n DateTimeFormatter.ISO_LOCAL_TIME = new DateTimeFormatterBuilder().appendValue(ChronoField.HOUR_OF_DAY, 2).appendLiteral(':').appendValue(ChronoField.MINUTE_OF_HOUR, 2).optionalStart().appendLiteral(':').appendValue(ChronoField.SECOND_OF_MINUTE, 2).optionalStart().appendFraction(ChronoField.NANO_OF_SECOND, 0, 9, true).toFormatter(ResolverStyle.STRICT);\n DateTimeFormatter.ISO_LOCAL_DATE_TIME = new DateTimeFormatterBuilder().parseCaseInsensitive().append(DateTimeFormatter.ISO_LOCAL_DATE).appendLiteral('T').append(DateTimeFormatter.ISO_LOCAL_TIME).toFormatter(ResolverStyle.STRICT).withChronology(IsoChronology.INSTANCE);\n DateTimeFormatter.ISO_INSTANT = new DateTimeFormatterBuilder().parseCaseInsensitive().appendInstant().toFormatter(ResolverStyle.STRICT);\n DateTimeFormatter.ISO_OFFSET_DATE_TIME = new DateTimeFormatterBuilder().parseCaseInsensitive().append(DateTimeFormatter.ISO_LOCAL_DATE_TIME).appendOffsetId().toFormatter(ResolverStyle.STRICT).withChronology(IsoChronology.INSTANCE);\n DateTimeFormatter.ISO_ZONED_DATE_TIME = new DateTimeFormatterBuilder().append(DateTimeFormatter.ISO_OFFSET_DATE_TIME).optionalStart().appendLiteral('[').parseCaseSensitive().appendZoneId().appendLiteral(']').toFormatter(ResolverStyle.STRICT).withChronology(IsoChronology.INSTANCE);\n DateTimeFormatter.BASIC_ISO_DATE = new DateTimeFormatterBuilder().appendValue(ChronoField.YEAR, 4, 10, SignStyle.EXCEEDS_PAD).appendValue(ChronoField.MONTH_OF_YEAR, 2).appendValue(ChronoField.DAY_OF_MONTH, 2).toFormatter(ResolverStyle.STRICT).withChronology(IsoChronology.INSTANCE);\n DateTimeFormatter.ISO_OFFSET_DATE = new DateTimeFormatterBuilder().parseCaseInsensitive().append(DateTimeFormatter.ISO_LOCAL_DATE).appendOffsetId().toFormatter(ResolverStyle.STRICT).withChronology(IsoChronology.INSTANCE);\n DateTimeFormatter.ISO_OFFSET_TIME = new DateTimeFormatterBuilder().parseCaseInsensitive().append(DateTimeFormatter.ISO_LOCAL_TIME).appendOffsetId().toFormatter(ResolverStyle.STRICT).withChronology(IsoChronology.INSTANCE);\n DateTimeFormatter.ISO_ORDINAL_DATE = new DateTimeFormatterBuilder().appendValue(ChronoField.YEAR, 4, 10, SignStyle.EXCEEDS_PAD).appendLiteral('-').appendValue(ChronoField.DAY_OF_YEAR).toFormatter(ResolverStyle.STRICT);\n DateTimeFormatter.ISO_WEEK_DATE = new DateTimeFormatterBuilder().appendValue(ChronoField.YEAR, 4, 10, SignStyle.EXCEEDS_PAD).appendLiteral('-W').appendValue(ChronoField.ALIGNED_WEEK_OF_YEAR).appendLiteral('-').appendValue(ChronoField.DAY_OF_WEEK).toFormatter(ResolverStyle.STRICT);\n DateTimeFormatter.PARSED_EXCESS_DAYS = createTemporalQuery('PARSED_EXCESS_DAYS', function (temporal) {\n if (temporal instanceof DateTimeBuilder) {\n return temporal.excessDays;\n } else {\n return Period.ZERO;\n }\n });\n DateTimeFormatter.PARSED_LEAP_SECOND = createTemporalQuery('PARSED_LEAP_SECOND', function (temporal) {\n if (temporal instanceof DateTimeBuilder) {\n return temporal.leapSecond;\n } else {\n return false;\n }\n });\n}\n\nvar MonthDay = function (_TemporalAccessor) {\n _inheritsLoose(MonthDay, _TemporalAccessor);\n\n MonthDay.now = function now(zoneIdOrClock) {\n if (arguments.length === 0) {\n return MonthDay.now0();\n } else if (arguments.length === 1 && zoneIdOrClock instanceof ZoneId) {\n return MonthDay.nowZoneId(zoneIdOrClock);\n } else {\n return MonthDay.nowClock(zoneIdOrClock);\n }\n };\n\n MonthDay.now0 = function now0() {\n return this.nowClock(Clock.systemDefaultZone());\n };\n\n MonthDay.nowZoneId = function nowZoneId(zone) {\n requireNonNull(zone, 'zone');\n return this.nowClock(Clock.system(zone));\n };\n\n MonthDay.nowClock = function nowClock(clock) {\n requireNonNull(clock, 'clock');\n var now = LocalDate.now(clock);\n return MonthDay.of(now.month(), now.dayOfMonth());\n };\n\n MonthDay.of = function of(monthOrNumber, number) {\n if (arguments.length === 2 && monthOrNumber instanceof Month) {\n return MonthDay.ofMonthNumber(monthOrNumber, number);\n } else {\n return MonthDay.ofNumberNumber(monthOrNumber, number);\n }\n };\n\n MonthDay.ofMonthNumber = function ofMonthNumber(month, dayOfMonth) {\n requireNonNull(month, 'month');\n ChronoField.DAY_OF_MONTH.checkValidValue(dayOfMonth);\n\n if (dayOfMonth > month.maxLength()) {\n throw new DateTimeException('Illegal value for DayOfMonth field, value ' + dayOfMonth + ' is not valid for month ' + month.toString());\n }\n\n return new MonthDay(month.value(), dayOfMonth);\n };\n\n MonthDay.ofNumberNumber = function ofNumberNumber(month, dayOfMonth) {\n requireNonNull(month, 'month');\n requireNonNull(dayOfMonth, 'dayOfMonth');\n return MonthDay.of(Month.of(month), dayOfMonth);\n };\n\n MonthDay.from = function from(temporal) {\n requireNonNull(temporal, 'temporal');\n requireInstance(temporal, TemporalAccessor, 'temporal');\n\n if (temporal instanceof MonthDay) {\n return temporal;\n }\n\n try {\n return MonthDay.of(temporal.get(ChronoField.MONTH_OF_YEAR), temporal.get(ChronoField.DAY_OF_MONTH));\n } catch (ex) {\n throw new DateTimeException('Unable to obtain MonthDay from TemporalAccessor: ' + temporal + ', type ' + (temporal && temporal.constructor != null ? temporal.constructor.name : ''));\n }\n };\n\n MonthDay.parse = function parse(text, formatter) {\n if (arguments.length === 1) {\n return MonthDay.parseString(text);\n } else {\n return MonthDay.parseStringFormatter(text, formatter);\n }\n };\n\n MonthDay.parseString = function parseString(text) {\n return MonthDay.parseStringFormatter(text, PARSER);\n };\n\n MonthDay.parseStringFormatter = function parseStringFormatter(text, formatter) {\n requireNonNull(text, 'text');\n requireNonNull(formatter, 'formatter');\n requireInstance(formatter, DateTimeFormatter, 'formatter');\n return formatter.parse(text, MonthDay.FROM);\n };\n\n function MonthDay(month, dayOfMonth) {\n var _this;\n\n _this = _TemporalAccessor.call(this) || this;\n _this._month = MathUtil.safeToInt(month);\n _this._day = MathUtil.safeToInt(dayOfMonth);\n return _this;\n }\n\n var _proto = MonthDay.prototype;\n\n _proto.monthValue = function monthValue() {\n return this._month;\n };\n\n _proto.month = function month() {\n return Month.of(this._month);\n };\n\n _proto.dayOfMonth = function dayOfMonth() {\n return this._day;\n };\n\n _proto.isSupported = function isSupported(field) {\n if (field instanceof ChronoField) {\n return field === ChronoField.MONTH_OF_YEAR || field === ChronoField.DAY_OF_MONTH;\n }\n\n return field != null && field.isSupportedBy(this);\n };\n\n _proto.range = function range(field) {\n if (field === ChronoField.MONTH_OF_YEAR) {\n return field.range();\n } else if (field === ChronoField.DAY_OF_MONTH) {\n return ValueRange.of(1, this.month().minLength(), this.month().maxLength());\n }\n\n return _TemporalAccessor.prototype.range.call(this, field);\n };\n\n _proto.get = function get(field) {\n return this.range(field).checkValidIntValue(this.getLong(field), field);\n };\n\n _proto.getLong = function getLong(field) {\n requireNonNull(field, 'field');\n\n if (field instanceof ChronoField) {\n switch (field) {\n case ChronoField.DAY_OF_MONTH:\n return this._day;\n\n case ChronoField.MONTH_OF_YEAR:\n return this._month;\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported field: ' + field);\n }\n\n return field.getFrom(this);\n };\n\n _proto.isValidYear = function isValidYear(year) {\n return (this._day === 29 && this._month === 2 && Year.isLeap(year) === false) === false;\n };\n\n _proto.withMonth = function withMonth(month) {\n return this.with(Month.of(month));\n };\n\n _proto.with = function _with(month) {\n requireNonNull(month, 'month');\n\n if (month.value() === this._month) {\n return this;\n }\n\n var day = Math.min(this._day, month.maxLength());\n return new MonthDay(month.value(), day);\n };\n\n _proto.withDayOfMonth = function withDayOfMonth(dayOfMonth) {\n if (dayOfMonth === this._day) {\n return this;\n }\n\n return MonthDay.of(this._month, dayOfMonth);\n };\n\n _proto.query = function query(_query) {\n requireNonNull(_query, 'query');\n requireInstance(_query, TemporalQuery, 'query');\n\n if (_query === TemporalQueries.chronology()) {\n return IsoChronology.INSTANCE;\n }\n\n return _TemporalAccessor.prototype.query.call(this, _query);\n };\n\n _proto.adjustInto = function adjustInto(temporal) {\n requireNonNull(temporal, 'temporal');\n temporal = temporal.with(ChronoField.MONTH_OF_YEAR, this._month);\n return temporal.with(ChronoField.DAY_OF_MONTH, Math.min(temporal.range(ChronoField.DAY_OF_MONTH).maximum(), this._day));\n };\n\n _proto.atYear = function atYear(year) {\n return LocalDate.of(year, this._month, this.isValidYear(year) ? this._day : 28);\n };\n\n _proto.compareTo = function compareTo(other) {\n requireNonNull(other, 'other');\n requireInstance(other, MonthDay, 'other');\n var cmp = this._month - other.monthValue();\n\n if (cmp === 0) {\n cmp = this._day - other.dayOfMonth();\n }\n\n return cmp;\n };\n\n _proto.isAfter = function isAfter(other) {\n requireNonNull(other, 'other');\n requireInstance(other, MonthDay, 'other');\n return this.compareTo(other) > 0;\n };\n\n _proto.isBefore = function isBefore(other) {\n requireNonNull(other, 'other');\n requireInstance(other, MonthDay, 'other');\n return this.compareTo(other) < 0;\n };\n\n _proto.equals = function equals(obj) {\n if (this === obj) {\n return true;\n }\n\n if (obj instanceof MonthDay) {\n var other = obj;\n return this.monthValue() === other.monthValue() && this.dayOfMonth() === other.dayOfMonth();\n }\n\n return false;\n };\n\n _proto.toString = function toString() {\n return '--' + (this._month < 10 ? '0' : '') + this._month + (this._day < 10 ? '-0' : '-') + this._day;\n };\n\n _proto.toJSON = function toJSON() {\n return this.toString();\n };\n\n _proto.format = function format(formatter) {\n requireNonNull(formatter, 'formatter');\n requireInstance(formatter, DateTimeFormatter, 'formatter');\n return formatter.format(this);\n };\n\n return MonthDay;\n}(TemporalAccessor);\nvar PARSER;\nfunction _init$b() {\n PARSER = new DateTimeFormatterBuilder().appendLiteral('--').appendValue(ChronoField.MONTH_OF_YEAR, 2).appendLiteral('-').appendValue(ChronoField.DAY_OF_MONTH, 2).toFormatter();\n MonthDay.FROM = createTemporalQuery('MonthDay.FROM', function (temporal) {\n return MonthDay.from(temporal);\n });\n}\n\nvar YearMonth = function (_Temporal) {\n _inheritsLoose(YearMonth, _Temporal);\n\n YearMonth.now = function now(zoneIdOrClock) {\n if (arguments.length === 0) {\n return YearMonth.now0();\n } else if (arguments.length === 1 && zoneIdOrClock instanceof ZoneId) {\n return YearMonth.nowZoneId(zoneIdOrClock);\n } else {\n return YearMonth.nowClock(zoneIdOrClock);\n }\n };\n\n YearMonth.now0 = function now0() {\n return YearMonth.nowClock(Clock.systemDefaultZone());\n };\n\n YearMonth.nowZoneId = function nowZoneId(zone) {\n return YearMonth.nowClock(Clock.system(zone));\n };\n\n YearMonth.nowClock = function nowClock(clock) {\n var now = LocalDate.now(clock);\n return YearMonth.of(now.year(), now.month());\n };\n\n YearMonth.of = function of(year, monthOrNumber) {\n if (arguments.length === 2 && monthOrNumber instanceof Month) {\n return YearMonth.ofNumberMonth(year, monthOrNumber);\n } else {\n return YearMonth.ofNumberNumber(year, monthOrNumber);\n }\n };\n\n YearMonth.ofNumberMonth = function ofNumberMonth(year, month) {\n requireNonNull(month, 'month');\n requireInstance(month, Month, 'month');\n return YearMonth.ofNumberNumber(year, month.value());\n };\n\n YearMonth.ofNumberNumber = function ofNumberNumber(year, month) {\n requireNonNull(year, 'year');\n requireNonNull(month, 'month');\n ChronoField.YEAR.checkValidValue(year);\n ChronoField.MONTH_OF_YEAR.checkValidValue(month);\n return new YearMonth(year, month);\n };\n\n YearMonth.from = function from(temporal) {\n requireNonNull(temporal, 'temporal');\n\n if (temporal instanceof YearMonth) {\n return temporal;\n }\n\n try {\n return YearMonth.of(temporal.get(ChronoField.YEAR), temporal.get(ChronoField.MONTH_OF_YEAR));\n } catch (ex) {\n throw new DateTimeException('Unable to obtain YearMonth from TemporalAccessor: ' + temporal + ', type ' + (temporal && temporal.constructor != null ? temporal.constructor.name : ''));\n }\n };\n\n YearMonth.parse = function parse(text, formatter) {\n if (arguments.length === 1) {\n return YearMonth.parseString(text);\n } else {\n return YearMonth.parseStringFormatter(text, formatter);\n }\n };\n\n YearMonth.parseString = function parseString(text) {\n return YearMonth.parseStringFormatter(text, PARSER$1);\n };\n\n YearMonth.parseStringFormatter = function parseStringFormatter(text, formatter) {\n requireNonNull(formatter, 'formatter');\n return formatter.parse(text, YearMonth.FROM);\n };\n\n function YearMonth(year, month) {\n var _this;\n\n _this = _Temporal.call(this) || this;\n _this._year = MathUtil.safeToInt(year);\n _this._month = MathUtil.safeToInt(month);\n return _this;\n }\n\n var _proto = YearMonth.prototype;\n\n _proto.isSupported = function isSupported(fieldOrUnit) {\n if (arguments.length === 1 && fieldOrUnit instanceof TemporalField) {\n return this.isSupportedField(fieldOrUnit);\n } else {\n return this.isSupportedUnit(fieldOrUnit);\n }\n };\n\n _proto.isSupportedField = function isSupportedField(field) {\n if (field instanceof ChronoField) {\n return field === ChronoField.YEAR || field === ChronoField.MONTH_OF_YEAR || field === ChronoField.PROLEPTIC_MONTH || field === ChronoField.YEAR_OF_ERA || field === ChronoField.ERA;\n }\n\n return field != null && field.isSupportedBy(this);\n };\n\n _proto.isSupportedUnit = function isSupportedUnit(unit) {\n if (unit instanceof ChronoUnit) {\n return unit === ChronoUnit.MONTHS || unit === ChronoUnit.YEARS || unit === ChronoUnit.DECADES || unit === ChronoUnit.CENTURIES || unit === ChronoUnit.MILLENNIA || unit === ChronoUnit.ERAS;\n }\n\n return unit != null && unit.isSupportedBy(this);\n };\n\n _proto.range = function range(field) {\n if (field === ChronoField.YEAR_OF_ERA) {\n return this.year() <= 0 ? ValueRange.of(1, Year.MAX_VALUE + 1) : ValueRange.of(1, Year.MAX_VALUE);\n }\n\n return _Temporal.prototype.range.call(this, field);\n };\n\n _proto.get = function get(field) {\n requireNonNull(field, 'field');\n requireInstance(field, TemporalField, 'field');\n return this.range(field).checkValidIntValue(this.getLong(field), field);\n };\n\n _proto.getLong = function getLong(field) {\n requireNonNull(field, 'field');\n requireInstance(field, TemporalField, 'field');\n\n if (field instanceof ChronoField) {\n switch (field) {\n case ChronoField.MONTH_OF_YEAR:\n return this._month;\n\n case ChronoField.PROLEPTIC_MONTH:\n return this._getProlepticMonth();\n\n case ChronoField.YEAR_OF_ERA:\n return this._year < 1 ? 1 - this._year : this._year;\n\n case ChronoField.YEAR:\n return this._year;\n\n case ChronoField.ERA:\n return this._year < 1 ? 0 : 1;\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported field: ' + field);\n }\n\n return field.getFrom(this);\n };\n\n _proto._getProlepticMonth = function _getProlepticMonth() {\n return MathUtil.safeAdd(MathUtil.safeMultiply(this._year, 12), this._month - 1);\n };\n\n _proto.year = function year() {\n return this._year;\n };\n\n _proto.monthValue = function monthValue() {\n return this._month;\n };\n\n _proto.month = function month() {\n return Month.of(this._month);\n };\n\n _proto.isLeapYear = function isLeapYear() {\n return IsoChronology.isLeapYear(this._year);\n };\n\n _proto.isValidDay = function isValidDay(dayOfMonth) {\n return dayOfMonth >= 1 && dayOfMonth <= this.lengthOfMonth();\n };\n\n _proto.lengthOfMonth = function lengthOfMonth() {\n return this.month().length(this.isLeapYear());\n };\n\n _proto.lengthOfYear = function lengthOfYear() {\n return this.isLeapYear() ? 366 : 365;\n };\n\n _proto.with = function _with(adjusterOrField, value) {\n if (arguments.length === 1) {\n return this.withAdjuster(adjusterOrField);\n } else {\n return this.withFieldValue(adjusterOrField, value);\n }\n };\n\n _proto.withAdjuster = function withAdjuster(adjuster) {\n requireNonNull(adjuster, 'adjuster');\n return adjuster.adjustInto(this);\n };\n\n _proto.withFieldValue = function withFieldValue(field, newValue) {\n requireNonNull(field, 'field');\n requireInstance(field, TemporalField, 'field');\n\n if (field instanceof ChronoField) {\n var f = field;\n f.checkValidValue(newValue);\n\n switch (f) {\n case ChronoField.MONTH_OF_YEAR:\n return this.withMonth(newValue);\n\n case ChronoField.PROLEPTIC_MONTH:\n return this.plusMonths(newValue - this.getLong(ChronoField.PROLEPTIC_MONTH));\n\n case ChronoField.YEAR_OF_ERA:\n return this.withYear(this._year < 1 ? 1 - newValue : newValue);\n\n case ChronoField.YEAR:\n return this.withYear(newValue);\n\n case ChronoField.ERA:\n return this.getLong(ChronoField.ERA) === newValue ? this : this.withYear(1 - this._year);\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported field: ' + field);\n }\n\n return field.adjustInto(this, newValue);\n };\n\n _proto.withYear = function withYear(year) {\n ChronoField.YEAR.checkValidValue(year);\n return new YearMonth(year, this._month);\n };\n\n _proto.withMonth = function withMonth(month) {\n ChronoField.MONTH_OF_YEAR.checkValidValue(month);\n return new YearMonth(this._year, month);\n };\n\n _proto.plusAmount = function plusAmount(amount) {\n requireNonNull(amount, 'amount');\n requireInstance(amount, TemporalAmount, 'amount');\n return amount.addTo(this);\n };\n\n _proto.plusAmountUnit = function plusAmountUnit(amountToAdd, unit) {\n requireNonNull(unit, 'unit');\n requireInstance(unit, TemporalUnit, 'unit');\n\n if (unit instanceof ChronoUnit) {\n switch (unit) {\n case ChronoUnit.MONTHS:\n return this.plusMonths(amountToAdd);\n\n case ChronoUnit.YEARS:\n return this.plusYears(amountToAdd);\n\n case ChronoUnit.DECADES:\n return this.plusYears(MathUtil.safeMultiply(amountToAdd, 10));\n\n case ChronoUnit.CENTURIES:\n return this.plusYears(MathUtil.safeMultiply(amountToAdd, 100));\n\n case ChronoUnit.MILLENNIA:\n return this.plusYears(MathUtil.safeMultiply(amountToAdd, 1000));\n\n case ChronoUnit.ERAS:\n return this.with(ChronoField.ERA, MathUtil.safeAdd(this.getLong(ChronoField.ERA), amountToAdd));\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported unit: ' + unit);\n }\n\n return unit.addTo(this, amountToAdd);\n };\n\n _proto.plusYears = function plusYears(yearsToAdd) {\n if (yearsToAdd === 0) {\n return this;\n }\n\n var newYear = ChronoField.YEAR.checkValidIntValue(this._year + yearsToAdd);\n return this.withYear(newYear);\n };\n\n _proto.plusMonths = function plusMonths(monthsToAdd) {\n if (monthsToAdd === 0) {\n return this;\n }\n\n var monthCount = this._year * 12 + (this._month - 1);\n var calcMonths = monthCount + monthsToAdd;\n var newYear = ChronoField.YEAR.checkValidIntValue(MathUtil.floorDiv(calcMonths, 12));\n var newMonth = MathUtil.floorMod(calcMonths, 12) + 1;\n return new YearMonth(newYear, newMonth);\n };\n\n _proto.minusAmount = function minusAmount(amount) {\n requireNonNull(amount, 'amount');\n return amount.subtractFrom(this);\n };\n\n _proto.minusAmountUnit = function minusAmountUnit(amountToSubtract, unit) {\n return amountToSubtract === MathUtil.MIN_SAFE_INTEGER ? this.plusAmountUnit(MathUtil.MAX_SAFE_INTEGER, unit).plusAmountUnit(1, unit) : this.plusAmountUnit(-amountToSubtract, unit);\n };\n\n _proto.minusYears = function minusYears(yearsToSubtract) {\n return yearsToSubtract === MathUtil.MIN_SAFE_INTEGER ? this.plusYears(MathUtil.MIN_SAFE_INTEGER).plusYears(1) : this.plusYears(-yearsToSubtract);\n };\n\n _proto.minusMonths = function minusMonths(monthsToSubtract) {\n return monthsToSubtract === MathUtil.MIN_SAFE_INTEGER ? this.plusMonths(Math.MAX_SAFE_INTEGER).plusMonths(1) : this.plusMonths(-monthsToSubtract);\n };\n\n _proto.query = function query(_query) {\n requireNonNull(_query, 'query');\n requireInstance(_query, TemporalQuery, 'query');\n\n if (_query === TemporalQueries.chronology()) {\n return IsoChronology.INSTANCE;\n } else if (_query === TemporalQueries.precision()) {\n return ChronoUnit.MONTHS;\n } else if (_query === TemporalQueries.localDate() || _query === TemporalQueries.localTime() || _query === TemporalQueries.zone() || _query === TemporalQueries.zoneId() || _query === TemporalQueries.offset()) {\n return null;\n }\n\n return _Temporal.prototype.query.call(this, _query);\n };\n\n _proto.adjustInto = function adjustInto(temporal) {\n requireNonNull(temporal, 'temporal');\n requireInstance(temporal, Temporal, 'temporal');\n return temporal.with(ChronoField.PROLEPTIC_MONTH, this._getProlepticMonth());\n };\n\n _proto.until = function until(endExclusive, unit) {\n requireNonNull(endExclusive, 'endExclusive');\n requireNonNull(unit, 'unit');\n requireInstance(endExclusive, Temporal, 'endExclusive');\n requireInstance(unit, TemporalUnit, 'unit');\n var end = YearMonth.from(endExclusive);\n\n if (unit instanceof ChronoUnit) {\n var monthsUntil = end._getProlepticMonth() - this._getProlepticMonth();\n\n switch (unit) {\n case ChronoUnit.MONTHS:\n return monthsUntil;\n\n case ChronoUnit.YEARS:\n return monthsUntil / 12;\n\n case ChronoUnit.DECADES:\n return monthsUntil / 120;\n\n case ChronoUnit.CENTURIES:\n return monthsUntil / 1200;\n\n case ChronoUnit.MILLENNIA:\n return monthsUntil / 12000;\n\n case ChronoUnit.ERAS:\n return end.getLong(ChronoField.ERA) - this.getLong(ChronoField.ERA);\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported unit: ' + unit);\n }\n\n return unit.between(this, end);\n };\n\n _proto.atDay = function atDay(dayOfMonth) {\n return LocalDate.of(this._year, this._month, dayOfMonth);\n };\n\n _proto.atEndOfMonth = function atEndOfMonth() {\n return LocalDate.of(this._year, this._month, this.lengthOfMonth());\n };\n\n _proto.compareTo = function compareTo(other) {\n requireNonNull(other, 'other');\n requireInstance(other, YearMonth, 'other');\n var cmp = this._year - other.year();\n\n if (cmp === 0) {\n cmp = this._month - other.monthValue();\n }\n\n return cmp;\n };\n\n _proto.isAfter = function isAfter(other) {\n return this.compareTo(other) > 0;\n };\n\n _proto.isBefore = function isBefore(other) {\n return this.compareTo(other) < 0;\n };\n\n _proto.equals = function equals(obj) {\n if (this === obj) {\n return true;\n }\n\n if (obj instanceof YearMonth) {\n var other = obj;\n return this.year() === other.year() && this.monthValue() === other.monthValue();\n }\n\n return false;\n };\n\n _proto.toString = function toString() {\n return PARSER$1.format(this);\n };\n\n _proto.toJSON = function toJSON() {\n return this.toString();\n };\n\n _proto.format = function format(formatter) {\n requireNonNull(formatter, 'formatter');\n return formatter.format(this);\n };\n\n return YearMonth;\n}(Temporal);\nvar PARSER$1;\nfunction _init$c() {\n PARSER$1 = new DateTimeFormatterBuilder().appendValue(ChronoField.YEAR, 4, 10, SignStyle.EXCEEDS_PAD).appendLiteral('-').appendValue(ChronoField.MONTH_OF_YEAR, 2).toFormatter();\n YearMonth.FROM = createTemporalQuery('YearMonth.FROM', function (temporal) {\n return YearMonth.from(temporal);\n });\n}\n\nvar Year = function (_Temporal) {\n _inheritsLoose(Year, _Temporal);\n\n function Year(value) {\n var _this;\n\n _this = _Temporal.call(this) || this;\n _this._year = MathUtil.safeToInt(value);\n return _this;\n }\n\n var _proto = Year.prototype;\n\n _proto.value = function value() {\n return this._year;\n };\n\n Year.now = function now(zoneIdOrClock) {\n if (zoneIdOrClock === void 0) {\n zoneIdOrClock = undefined;\n }\n\n if (zoneIdOrClock === undefined) {\n return Year.now0();\n } else if (zoneIdOrClock instanceof ZoneId) {\n return Year.nowZoneId(zoneIdOrClock);\n } else {\n return Year.nowClock(zoneIdOrClock);\n }\n };\n\n Year.now0 = function now0() {\n return Year.nowClock(Clock.systemDefaultZone());\n };\n\n Year.nowZoneId = function nowZoneId(zone) {\n requireNonNull(zone, 'zone');\n requireInstance(zone, ZoneId, 'zone');\n return Year.nowClock(Clock.system(zone));\n };\n\n Year.nowClock = function nowClock(clock) {\n requireNonNull(clock, 'clock');\n requireInstance(clock, Clock, 'clock');\n var now = LocalDate.now(clock);\n return Year.of(now.year());\n };\n\n Year.of = function of(isoYear) {\n requireNonNull(isoYear, 'isoYear');\n ChronoField.YEAR.checkValidValue(isoYear);\n return new Year(isoYear);\n };\n\n Year.from = function from(temporal) {\n requireNonNull(temporal, 'temporal');\n requireInstance(temporal, TemporalAccessor, 'temporal');\n\n if (temporal instanceof Year) {\n return temporal;\n }\n\n try {\n return Year.of(temporal.get(ChronoField.YEAR));\n } catch (ex) {\n throw new DateTimeException('Unable to obtain Year from TemporalAccessor: ' + temporal + ', type ' + (temporal && temporal.constructor != null ? temporal.constructor.name : ''));\n }\n };\n\n Year.parse = function parse(text, formatter) {\n if (arguments.length <= 1) {\n return Year.parseText(text);\n } else {\n return Year.parseTextFormatter(text, formatter);\n }\n };\n\n Year.parseText = function parseText(text) {\n requireNonNull(text, 'text');\n return Year.parse(text, PARSER$2);\n };\n\n Year.parseTextFormatter = function parseTextFormatter(text, formatter) {\n if (formatter === void 0) {\n formatter = PARSER$2;\n }\n\n requireNonNull(text, 'text');\n requireNonNull(formatter, 'formatter');\n requireInstance(formatter, DateTimeFormatter, 'formatter');\n return formatter.parse(text, Year.FROM);\n };\n\n Year.isLeap = function isLeap(year) {\n return MathUtil.intMod(year, 4) === 0 && (MathUtil.intMod(year, 100) !== 0 || MathUtil.intMod(year, 400) === 0);\n };\n\n _proto.isSupported = function isSupported(fieldOrUnit) {\n if (arguments.length === 1 && fieldOrUnit instanceof TemporalField) {\n return this.isSupportedField(fieldOrUnit);\n } else {\n return this.isSupportedUnit(fieldOrUnit);\n }\n };\n\n _proto.isSupportedField = function isSupportedField(field) {\n if (field instanceof ChronoField) {\n return field === ChronoField.YEAR || field === ChronoField.YEAR_OF_ERA || field === ChronoField.ERA;\n }\n\n return field != null && field.isSupportedBy(this);\n };\n\n _proto.isSupportedUnit = function isSupportedUnit(unit) {\n if (unit instanceof ChronoUnit) {\n return unit === ChronoUnit.YEARS || unit === ChronoUnit.DECADES || unit === ChronoUnit.CENTURIES || unit === ChronoUnit.MILLENNIA || unit === ChronoUnit.ERAS;\n }\n\n return unit != null && unit.isSupportedBy(this);\n };\n\n _proto.range = function range(field) {\n if (this.isSupported(field)) {\n return field.range();\n } else if (field instanceof ChronoField) {\n throw new UnsupportedTemporalTypeException('Unsupported field: ' + field);\n }\n\n return _Temporal.prototype.range.call(this, field);\n };\n\n _proto.get = function get(field) {\n return this.range(field).checkValidIntValue(this.getLong(field), field);\n };\n\n _proto.getLong = function getLong(field) {\n requireNonNull(field, 'field');\n\n if (field instanceof ChronoField) {\n switch (field) {\n case ChronoField.YEAR_OF_ERA:\n return this._year < 1 ? 1 - this._year : this._year;\n\n case ChronoField.YEAR:\n return this._year;\n\n case ChronoField.ERA:\n return this._year < 1 ? 0 : 1;\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported field: ' + field);\n }\n\n return field.getFrom(this);\n };\n\n _proto.isLeap = function isLeap() {\n return Year.isLeap(this._year);\n };\n\n _proto.withAdjuster = function withAdjuster(adjuster) {\n requireNonNull(adjuster, 'adjuster');\n return adjuster.adjustInto(this);\n };\n\n _proto.withFieldValue = function withFieldValue(field, newValue) {\n requireNonNull(field, 'field');\n requireInstance(field, TemporalField, 'field');\n\n if (field instanceof ChronoField) {\n field.checkValidValue(newValue);\n\n switch (field) {\n case ChronoField.YEAR_OF_ERA:\n return Year.of(this._year < 1 ? 1 - newValue : newValue);\n\n case ChronoField.YEAR:\n return Year.of(newValue);\n\n case ChronoField.ERA:\n return this.getLong(ChronoField.ERA) === newValue ? this : Year.of(1 - this._year);\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported field: ' + field);\n }\n\n return field.adjustInto(this, newValue);\n };\n\n _proto.plusAmount = function plusAmount(amount) {\n requireNonNull(amount, 'amount');\n requireInstance(amount, TemporalAmount, 'amount');\n return amount.addTo(this);\n };\n\n _proto.plusAmountUnit = function plusAmountUnit(amountToAdd, unit) {\n requireNonNull(amountToAdd, 'amountToAdd');\n requireNonNull(unit, 'unit');\n requireInstance(unit, TemporalUnit, 'unit');\n\n if (unit instanceof ChronoUnit) {\n switch (unit) {\n case ChronoUnit.YEARS:\n return this.plusYears(amountToAdd);\n\n case ChronoUnit.DECADES:\n return this.plusYears(MathUtil.safeMultiply(amountToAdd, 10));\n\n case ChronoUnit.CENTURIES:\n return this.plusYears(MathUtil.safeMultiply(amountToAdd, 100));\n\n case ChronoUnit.MILLENNIA:\n return this.plusYears(MathUtil.safeMultiply(amountToAdd, 1000));\n\n case ChronoUnit.ERAS:\n return this.with(ChronoField.ERA, MathUtil.safeAdd(this.getLong(ChronoField.ERA), amountToAdd));\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported unit: ' + unit);\n }\n\n return unit.addTo(this, amountToAdd);\n };\n\n _proto.plusYears = function plusYears(yearsToAdd) {\n if (yearsToAdd === 0) {\n return this;\n }\n\n return Year.of(ChronoField.YEAR.checkValidIntValue(MathUtil.safeAdd(this._year, yearsToAdd)));\n };\n\n _proto.minusAmount = function minusAmount(amount) {\n requireNonNull(amount, 'amount');\n requireInstance(amount, TemporalAmount, 'amount');\n return amount.subtractFrom(this);\n };\n\n _proto.minusAmountUnit = function minusAmountUnit(amountToSubtract, unit) {\n requireNonNull(amountToSubtract, 'amountToSubtract');\n requireNonNull(unit, 'unit');\n requireInstance(unit, TemporalUnit, 'unit');\n return amountToSubtract === MathUtil.MIN_SAFE_INTEGER ? this.plus(MathUtil.MAX_SAFE_INTEGER, unit).plus(1, unit) : this.plus(-amountToSubtract, unit);\n };\n\n _proto.minusYears = function minusYears(yearsToSubtract) {\n return yearsToSubtract === MathUtil.MIN_SAFE_INTEGER ? this.plusYears(MathUtil.MAX_SAFE_INTEGER).plusYears(1) : this.plusYears(-yearsToSubtract);\n };\n\n _proto.adjustInto = function adjustInto(temporal) {\n requireNonNull(temporal, 'temporal');\n return temporal.with(ChronoField.YEAR, this._year);\n };\n\n _proto.isValidMonthDay = function isValidMonthDay(monthDay) {\n return monthDay != null && monthDay.isValidYear(this._year);\n };\n\n _proto.length = function length() {\n return this.isLeap() ? 366 : 365;\n };\n\n _proto.atDay = function atDay(dayOfYear) {\n return LocalDate.ofYearDay(this._year, dayOfYear);\n };\n\n _proto.atMonth = function atMonth(monthOrNumber) {\n if (arguments.length === 1 && monthOrNumber instanceof Month) {\n return this.atMonthMonth(monthOrNumber);\n } else {\n return this.atMonthNumber(monthOrNumber);\n }\n };\n\n _proto.atMonthMonth = function atMonthMonth(month) {\n requireNonNull(month, 'month');\n requireInstance(month, Month, 'month');\n return YearMonth.of(this._year, month);\n };\n\n _proto.atMonthNumber = function atMonthNumber(month) {\n requireNonNull(month, 'month');\n return YearMonth.of(this._year, month);\n };\n\n _proto.atMonthDay = function atMonthDay(monthDay) {\n requireNonNull(monthDay, 'monthDay');\n requireInstance(monthDay, MonthDay, 'monthDay');\n return monthDay.atYear(this._year);\n };\n\n _proto.query = function query(_query) {\n requireNonNull(_query, 'query()');\n requireInstance(_query, TemporalQuery, 'query()');\n\n if (_query === TemporalQueries.chronology()) {\n return IsoChronology.INSTANCE;\n } else if (_query === TemporalQueries.precision()) {\n return ChronoUnit.YEARS;\n } else if (_query === TemporalQueries.localDate() || _query === TemporalQueries.localTime() || _query === TemporalQueries.zone() || _query === TemporalQueries.zoneId() || _query === TemporalQueries.offset()) {\n return null;\n }\n\n return _Temporal.prototype.query.call(this, _query);\n };\n\n _proto.compareTo = function compareTo(other) {\n requireNonNull(other, 'other');\n requireInstance(other, Year, 'other');\n return this._year - other._year;\n };\n\n _proto.isAfter = function isAfter(other) {\n requireNonNull(other, 'other');\n requireInstance(other, Year, 'other');\n return this._year > other._year;\n };\n\n _proto.isBefore = function isBefore(other) {\n requireNonNull(other, 'other');\n requireInstance(other, Year, 'other');\n return this._year < other._year;\n };\n\n _proto.format = function format(formatter) {\n requireNonNull(formatter, 'formatter');\n requireInstance(formatter, DateTimeFormatter, 'formatter');\n return formatter.format(this);\n };\n\n _proto.equals = function equals(other) {\n if (this === other) {\n return true;\n }\n\n if (other instanceof Year) {\n return this.value() === other.value();\n }\n\n return false;\n };\n\n _proto.toString = function toString() {\n return '' + this._year;\n };\n\n _proto.toJSON = function toJSON() {\n return this.toString();\n };\n\n _proto.until = function until(endExclusive, unit) {\n var end = Year.from(endExclusive);\n\n if (unit instanceof ChronoUnit) {\n var yearsUntil = end.value() - this.value();\n\n switch (unit) {\n case ChronoUnit.YEARS:\n return yearsUntil;\n\n case ChronoUnit.DECADES:\n return MathUtil.intDiv(yearsUntil, 10);\n\n case ChronoUnit.CENTURIES:\n return MathUtil.intDiv(yearsUntil, 100);\n\n case ChronoUnit.MILLENNIA:\n return MathUtil.intDiv(yearsUntil, 1000);\n\n case ChronoUnit.ERAS:\n return end.getLong(ChronoField.ERA) - this.getLong(ChronoField.ERA);\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported unit: ' + unit);\n }\n\n return unit.between(this, end);\n };\n\n return Year;\n}(Temporal);\nvar PARSER$2;\nfunction _init$d() {\n Year.MIN_VALUE = YearConstants.MIN_VALUE;\n Year.MAX_VALUE = YearConstants.MAX_VALUE;\n PARSER$2 = new DateTimeFormatterBuilder().appendValue(ChronoField.YEAR, 4, 10, SignStyle.EXCEEDS_PAD).toFormatter();\n Year.FROM = createTemporalQuery('Year.FROM', function (temporal) {\n return Year.from(temporal);\n });\n}\n\nvar TemporalAdjusters = function () {\n function TemporalAdjusters() {}\n\n TemporalAdjusters.firstDayOfMonth = function firstDayOfMonth() {\n return Impl.FIRST_DAY_OF_MONTH;\n };\n\n TemporalAdjusters.lastDayOfMonth = function lastDayOfMonth() {\n return Impl.LAST_DAY_OF_MONTH;\n };\n\n TemporalAdjusters.firstDayOfNextMonth = function firstDayOfNextMonth() {\n return Impl.FIRST_DAY_OF_NEXT_MONTH;\n };\n\n TemporalAdjusters.firstDayOfYear = function firstDayOfYear() {\n return Impl.FIRST_DAY_OF_YEAR;\n };\n\n TemporalAdjusters.lastDayOfYear = function lastDayOfYear() {\n return Impl.LAST_DAY_OF_YEAR;\n };\n\n TemporalAdjusters.firstDayOfNextYear = function firstDayOfNextYear() {\n return Impl.FIRST_DAY_OF_NEXT_YEAR;\n };\n\n TemporalAdjusters.firstInMonth = function firstInMonth(dayOfWeek) {\n requireNonNull(dayOfWeek, 'dayOfWeek');\n return new DayOfWeekInMonth(1, dayOfWeek);\n };\n\n TemporalAdjusters.lastInMonth = function lastInMonth(dayOfWeek) {\n requireNonNull(dayOfWeek, 'dayOfWeek');\n return new DayOfWeekInMonth(-1, dayOfWeek);\n };\n\n TemporalAdjusters.dayOfWeekInMonth = function dayOfWeekInMonth(ordinal, dayOfWeek) {\n requireNonNull(dayOfWeek, 'dayOfWeek');\n return new DayOfWeekInMonth(ordinal, dayOfWeek);\n };\n\n TemporalAdjusters.next = function next(dayOfWeek) {\n return new RelativeDayOfWeek(2, dayOfWeek);\n };\n\n TemporalAdjusters.nextOrSame = function nextOrSame(dayOfWeek) {\n return new RelativeDayOfWeek(0, dayOfWeek);\n };\n\n TemporalAdjusters.previous = function previous(dayOfWeek) {\n return new RelativeDayOfWeek(3, dayOfWeek);\n };\n\n TemporalAdjusters.previousOrSame = function previousOrSame(dayOfWeek) {\n return new RelativeDayOfWeek(1, dayOfWeek);\n };\n\n return TemporalAdjusters;\n}();\n\nvar Impl = function (_TemporalAdjuster) {\n _inheritsLoose(Impl, _TemporalAdjuster);\n\n function Impl(ordinal) {\n var _this;\n\n _this = _TemporalAdjuster.call(this) || this;\n _this._ordinal = ordinal;\n return _this;\n }\n\n var _proto = Impl.prototype;\n\n _proto.adjustInto = function adjustInto(temporal) {\n switch (this._ordinal) {\n case 0:\n return temporal.with(ChronoField.DAY_OF_MONTH, 1);\n\n case 1:\n return temporal.with(ChronoField.DAY_OF_MONTH, temporal.range(ChronoField.DAY_OF_MONTH).maximum());\n\n case 2:\n return temporal.with(ChronoField.DAY_OF_MONTH, 1).plus(1, ChronoUnit.MONTHS);\n\n case 3:\n return temporal.with(ChronoField.DAY_OF_YEAR, 1);\n\n case 4:\n return temporal.with(ChronoField.DAY_OF_YEAR, temporal.range(ChronoField.DAY_OF_YEAR).maximum());\n\n case 5:\n return temporal.with(ChronoField.DAY_OF_YEAR, 1).plus(1, ChronoUnit.YEARS);\n }\n\n throw new IllegalStateException('Unreachable');\n };\n\n return Impl;\n}(TemporalAdjuster);\n\nImpl.FIRST_DAY_OF_MONTH = new Impl(0);\nImpl.LAST_DAY_OF_MONTH = new Impl(1);\nImpl.FIRST_DAY_OF_NEXT_MONTH = new Impl(2);\nImpl.FIRST_DAY_OF_YEAR = new Impl(3);\nImpl.LAST_DAY_OF_YEAR = new Impl(4);\nImpl.FIRST_DAY_OF_NEXT_YEAR = new Impl(5);\n\nvar DayOfWeekInMonth = function (_TemporalAdjuster2) {\n _inheritsLoose(DayOfWeekInMonth, _TemporalAdjuster2);\n\n function DayOfWeekInMonth(ordinal, dow) {\n var _this2;\n\n _this2 = _TemporalAdjuster2.call(this) || this;\n _this2._ordinal = ordinal;\n _this2._dowValue = dow.value();\n return _this2;\n }\n\n var _proto2 = DayOfWeekInMonth.prototype;\n\n _proto2.adjustInto = function adjustInto(temporal) {\n if (this._ordinal >= 0) {\n var temp = temporal.with(ChronoField.DAY_OF_MONTH, 1);\n var curDow = temp.get(ChronoField.DAY_OF_WEEK);\n var dowDiff = MathUtil.intMod(this._dowValue - curDow + 7, 7);\n dowDiff += (this._ordinal - 1) * 7;\n return temp.plus(dowDiff, ChronoUnit.DAYS);\n } else {\n var _temp = temporal.with(ChronoField.DAY_OF_MONTH, temporal.range(ChronoField.DAY_OF_MONTH).maximum());\n\n var _curDow = _temp.get(ChronoField.DAY_OF_WEEK);\n\n var daysDiff = this._dowValue - _curDow;\n daysDiff = daysDiff === 0 ? 0 : daysDiff > 0 ? daysDiff - 7 : daysDiff;\n daysDiff -= (-this._ordinal - 1) * 7;\n return _temp.plus(daysDiff, ChronoUnit.DAYS);\n }\n };\n\n return DayOfWeekInMonth;\n}(TemporalAdjuster);\n\nvar RelativeDayOfWeek = function (_TemporalAdjuster3) {\n _inheritsLoose(RelativeDayOfWeek, _TemporalAdjuster3);\n\n function RelativeDayOfWeek(relative, dayOfWeek) {\n var _this3;\n\n _this3 = _TemporalAdjuster3.call(this) || this;\n requireNonNull(dayOfWeek, 'dayOfWeek');\n _this3._relative = relative;\n _this3._dowValue = dayOfWeek.value();\n return _this3;\n }\n\n var _proto3 = RelativeDayOfWeek.prototype;\n\n _proto3.adjustInto = function adjustInto(temporal) {\n var calDow = temporal.get(ChronoField.DAY_OF_WEEK);\n\n if (this._relative < 2 && calDow === this._dowValue) {\n return temporal;\n }\n\n if ((this._relative & 1) === 0) {\n var daysDiff = calDow - this._dowValue;\n return temporal.plus(daysDiff >= 0 ? 7 - daysDiff : -daysDiff, ChronoUnit.DAYS);\n } else {\n var _daysDiff = this._dowValue - calDow;\n\n return temporal.minus(_daysDiff >= 0 ? 7 - _daysDiff : -_daysDiff, ChronoUnit.DAYS);\n }\n };\n\n return RelativeDayOfWeek;\n}(TemporalAdjuster);\n\nvar IsoChronology = function (_Enum) {\n _inheritsLoose(IsoChronology, _Enum);\n\n function IsoChronology() {\n return _Enum.apply(this, arguments) || this;\n }\n\n IsoChronology.isLeapYear = function isLeapYear(prolepticYear) {\n return (prolepticYear & 3) === 0 && (prolepticYear % 100 !== 0 || prolepticYear % 400 === 0);\n };\n\n var _proto = IsoChronology.prototype;\n\n _proto._updateResolveMap = function _updateResolveMap(fieldValues, field, value) {\n requireNonNull(fieldValues, 'fieldValues');\n requireNonNull(field, 'field');\n var current = fieldValues.get(field);\n\n if (current != null && current !== value) {\n throw new DateTimeException('Invalid state, field: ' + field + ' ' + current + ' conflicts with ' + field + ' ' + value);\n }\n\n fieldValues.put(field, value);\n };\n\n _proto.resolveDate = function resolveDate(fieldValues, resolverStyle) {\n if (fieldValues.containsKey(ChronoField.EPOCH_DAY)) {\n return LocalDate.ofEpochDay(fieldValues.remove(ChronoField.EPOCH_DAY));\n }\n\n var prolepticMonth = fieldValues.remove(ChronoField.PROLEPTIC_MONTH);\n\n if (prolepticMonth != null) {\n if (resolverStyle !== ResolverStyle.LENIENT) {\n ChronoField.PROLEPTIC_MONTH.checkValidValue(prolepticMonth);\n }\n\n this._updateResolveMap(fieldValues, ChronoField.MONTH_OF_YEAR, MathUtil.floorMod(prolepticMonth, 12) + 1);\n\n this._updateResolveMap(fieldValues, ChronoField.YEAR, MathUtil.floorDiv(prolepticMonth, 12));\n }\n\n var yoeLong = fieldValues.remove(ChronoField.YEAR_OF_ERA);\n\n if (yoeLong != null) {\n if (resolverStyle !== ResolverStyle.LENIENT) {\n ChronoField.YEAR_OF_ERA.checkValidValue(yoeLong);\n }\n\n var era = fieldValues.remove(ChronoField.ERA);\n\n if (era == null) {\n var year = fieldValues.get(ChronoField.YEAR);\n\n if (resolverStyle === ResolverStyle.STRICT) {\n if (year != null) {\n this._updateResolveMap(fieldValues, ChronoField.YEAR, year > 0 ? yoeLong : MathUtil.safeSubtract(1, yoeLong));\n } else {\n fieldValues.put(ChronoField.YEAR_OF_ERA, yoeLong);\n }\n } else {\n this._updateResolveMap(fieldValues, ChronoField.YEAR, year == null || year > 0 ? yoeLong : MathUtil.safeSubtract(1, yoeLong));\n }\n } else if (era === 1) {\n this._updateResolveMap(fieldValues, ChronoField.YEAR, yoeLong);\n } else if (era === 0) {\n this._updateResolveMap(fieldValues, ChronoField.YEAR, MathUtil.safeSubtract(1, yoeLong));\n } else {\n throw new DateTimeException('Invalid value for era: ' + era);\n }\n } else if (fieldValues.containsKey(ChronoField.ERA)) {\n ChronoField.ERA.checkValidValue(fieldValues.get(ChronoField.ERA));\n }\n\n if (fieldValues.containsKey(ChronoField.YEAR)) {\n if (fieldValues.containsKey(ChronoField.MONTH_OF_YEAR)) {\n if (fieldValues.containsKey(ChronoField.DAY_OF_MONTH)) {\n var y = ChronoField.YEAR.checkValidIntValue(fieldValues.remove(ChronoField.YEAR));\n var moy = fieldValues.remove(ChronoField.MONTH_OF_YEAR);\n var dom = fieldValues.remove(ChronoField.DAY_OF_MONTH);\n\n if (resolverStyle === ResolverStyle.LENIENT) {\n var months = moy - 1;\n var days = dom - 1;\n return LocalDate.of(y, 1, 1).plusMonths(months).plusDays(days);\n } else if (resolverStyle === ResolverStyle.SMART) {\n ChronoField.DAY_OF_MONTH.checkValidValue(dom);\n\n if (moy === 4 || moy === 6 || moy === 9 || moy === 11) {\n dom = Math.min(dom, 30);\n } else if (moy === 2) {\n dom = Math.min(dom, Month.FEBRUARY.length(Year.isLeap(y)));\n }\n\n return LocalDate.of(y, moy, dom);\n } else {\n return LocalDate.of(y, moy, dom);\n }\n }\n }\n\n if (fieldValues.containsKey(ChronoField.DAY_OF_YEAR)) {\n var _y = ChronoField.YEAR.checkValidIntValue(fieldValues.remove(ChronoField.YEAR));\n\n if (resolverStyle === ResolverStyle.LENIENT) {\n var _days = MathUtil.safeSubtract(fieldValues.remove(ChronoField.DAY_OF_YEAR), 1);\n\n return LocalDate.ofYearDay(_y, 1).plusDays(_days);\n }\n\n var doy = ChronoField.DAY_OF_YEAR.checkValidIntValue(fieldValues.remove(ChronoField.DAY_OF_YEAR));\n return LocalDate.ofYearDay(_y, doy);\n }\n\n if (fieldValues.containsKey(ChronoField.ALIGNED_WEEK_OF_YEAR)) {\n if (fieldValues.containsKey(ChronoField.ALIGNED_DAY_OF_WEEK_IN_YEAR)) {\n var _y2 = ChronoField.YEAR.checkValidIntValue(fieldValues.remove(ChronoField.YEAR));\n\n if (resolverStyle === ResolverStyle.LENIENT) {\n var weeks = MathUtil.safeSubtract(fieldValues.remove(ChronoField.ALIGNED_WEEK_OF_YEAR), 1);\n\n var _days2 = MathUtil.safeSubtract(fieldValues.remove(ChronoField.ALIGNED_DAY_OF_WEEK_IN_YEAR), 1);\n\n return LocalDate.of(_y2, 1, 1).plusWeeks(weeks).plusDays(_days2);\n }\n\n var aw = ChronoField.ALIGNED_WEEK_OF_YEAR.checkValidIntValue(fieldValues.remove(ChronoField.ALIGNED_WEEK_OF_YEAR));\n var ad = ChronoField.ALIGNED_DAY_OF_WEEK_IN_YEAR.checkValidIntValue(fieldValues.remove(ChronoField.ALIGNED_DAY_OF_WEEK_IN_YEAR));\n var date = LocalDate.of(_y2, 1, 1).plusDays((aw - 1) * 7 + (ad - 1));\n\n if (resolverStyle === ResolverStyle.STRICT && date.get(ChronoField.YEAR) !== _y2) {\n throw new DateTimeException('Strict mode rejected date parsed to a different year');\n }\n\n return date;\n }\n\n if (fieldValues.containsKey(ChronoField.DAY_OF_WEEK)) {\n var _y3 = ChronoField.YEAR.checkValidIntValue(fieldValues.remove(ChronoField.YEAR));\n\n if (resolverStyle === ResolverStyle.LENIENT) {\n var _weeks = MathUtil.safeSubtract(fieldValues.remove(ChronoField.ALIGNED_WEEK_OF_YEAR), 1);\n\n var _days3 = MathUtil.safeSubtract(fieldValues.remove(ChronoField.DAY_OF_WEEK), 1);\n\n return LocalDate.of(_y3, 1, 1).plusWeeks(_weeks).plusDays(_days3);\n }\n\n var _aw = ChronoField.ALIGNED_WEEK_OF_YEAR.checkValidIntValue(fieldValues.remove(ChronoField.ALIGNED_WEEK_OF_YEAR));\n\n var dow = ChronoField.DAY_OF_WEEK.checkValidIntValue(fieldValues.remove(ChronoField.DAY_OF_WEEK));\n\n var _date = LocalDate.of(_y3, 1, 1).plusWeeks(_aw - 1).with(TemporalAdjusters.nextOrSame(DayOfWeek.of(dow)));\n\n if (resolverStyle === ResolverStyle.STRICT && _date.get(ChronoField.YEAR) !== _y3) {\n throw new DateTimeException('Strict mode rejected date parsed to a different month');\n }\n\n return _date;\n }\n }\n }\n\n return null;\n };\n\n _proto.date = function date(temporal) {\n return LocalDate.from(temporal);\n };\n\n return IsoChronology;\n}(Enum);\nfunction _init$e() {\n IsoChronology.INSTANCE = new IsoChronology('IsoChronology');\n}\n\nvar OffsetTime = function (_DefaultInterfaceTemp) {\n _inheritsLoose(OffsetTime, _DefaultInterfaceTemp);\n\n OffsetTime.from = function from(temporal) {\n requireNonNull(temporal, 'temporal');\n\n if (temporal instanceof OffsetTime) {\n return temporal;\n } else if (temporal instanceof OffsetDateTime) {\n return temporal.toOffsetTime();\n }\n\n try {\n var time = LocalTime.from(temporal);\n var offset = ZoneOffset.from(temporal);\n return new OffsetTime(time, offset);\n } catch (ex) {\n throw new DateTimeException(\"Unable to obtain OffsetTime TemporalAccessor: \" + temporal + \", type \" + (temporal.constructor != null ? temporal.constructor.name : ''));\n }\n };\n\n OffsetTime.now = function now(clockOrZone) {\n if (arguments.length === 0) {\n return OffsetTime._now(Clock.systemDefaultZone());\n } else if (clockOrZone instanceof Clock) {\n return OffsetTime._now(clockOrZone);\n } else {\n return OffsetTime._now(Clock.system(clockOrZone));\n }\n };\n\n OffsetTime._now = function _now(clock) {\n requireNonNull(clock, 'clock');\n var now = clock.instant();\n return OffsetTime.ofInstant(now, clock.zone().rules().offset(now));\n };\n\n OffsetTime.of = function of() {\n if (arguments.length <= 2) {\n return OffsetTime.ofTimeAndOffset.apply(this, arguments);\n } else {\n return OffsetTime.ofNumbers.apply(this, arguments);\n }\n };\n\n OffsetTime.ofNumbers = function ofNumbers(hour, minute, second, nanoOfSecond, offset) {\n var time = LocalTime.of(hour, minute, second, nanoOfSecond);\n return new OffsetTime(time, offset);\n };\n\n OffsetTime.ofTimeAndOffset = function ofTimeAndOffset(time, offset) {\n return new OffsetTime(time, offset);\n };\n\n OffsetTime.ofInstant = function ofInstant(instant, zone) {\n requireNonNull(instant, 'instant');\n requireInstance(instant, Instant, 'instant');\n requireNonNull(zone, 'zone');\n requireInstance(zone, ZoneId, 'zone');\n var rules = zone.rules();\n var offset = rules.offset(instant);\n var secsOfDay = instant.epochSecond() % LocalTime.SECONDS_PER_DAY;\n secsOfDay = (secsOfDay + offset.totalSeconds()) % LocalTime.SECONDS_PER_DAY;\n\n if (secsOfDay < 0) {\n secsOfDay += LocalTime.SECONDS_PER_DAY;\n }\n\n var time = LocalTime.ofSecondOfDay(secsOfDay, instant.nano());\n return new OffsetTime(time, offset);\n };\n\n OffsetTime.parse = function parse(text, formatter) {\n if (formatter === void 0) {\n formatter = DateTimeFormatter.ISO_OFFSET_TIME;\n }\n\n requireNonNull(formatter, 'formatter');\n return formatter.parse(text, OffsetTime.FROM);\n };\n\n function OffsetTime(time, offset) {\n var _this;\n\n _this = _DefaultInterfaceTemp.call(this) || this;\n requireNonNull(time, 'time');\n requireInstance(time, LocalTime, 'time');\n requireNonNull(offset, 'offset');\n requireInstance(offset, ZoneOffset, 'offset');\n _this._time = time;\n _this._offset = offset;\n return _this;\n }\n\n var _proto = OffsetTime.prototype;\n\n _proto.adjustInto = function adjustInto(temporal) {\n return temporal.with(ChronoField.NANO_OF_DAY, this._time.toNanoOfDay()).with(ChronoField.OFFSET_SECONDS, this.offset().totalSeconds());\n };\n\n _proto.atDate = function atDate(date) {\n return OffsetDateTime.of(date, this._time, this._offset);\n };\n\n _proto.format = function format(formatter) {\n requireNonNull(formatter, 'formatter');\n return formatter.format(this, OffsetTime.FROM);\n };\n\n _proto.get = function get(field) {\n return _DefaultInterfaceTemp.prototype.get.call(this, field);\n };\n\n _proto.getLong = function getLong(field) {\n if (field instanceof ChronoField) {\n if (field === ChronoField.OFFSET_SECONDS) {\n return this._offset.totalSeconds();\n }\n\n return this._time.getLong(field);\n }\n\n return field.getFrom(this);\n };\n\n _proto.hour = function hour() {\n return this._time.hour();\n };\n\n _proto.minute = function minute() {\n return this._time.minute();\n };\n\n _proto.second = function second() {\n return this._time.second();\n };\n\n _proto.nano = function nano() {\n return this._time.nano();\n };\n\n _proto.offset = function offset() {\n return this._offset;\n };\n\n _proto.isAfter = function isAfter(other) {\n requireNonNull(other, 'other');\n return this._toEpochNano() > other._toEpochNano();\n };\n\n _proto.isBefore = function isBefore(other) {\n requireNonNull(other, 'other');\n return this._toEpochNano() < other._toEpochNano();\n };\n\n _proto.isEqual = function isEqual(other) {\n requireNonNull(other, 'other');\n return this._toEpochNano() === other._toEpochNano();\n };\n\n _proto.isSupported = function isSupported(fieldOrUnit) {\n if (fieldOrUnit instanceof ChronoField) {\n return fieldOrUnit.isTimeBased() || fieldOrUnit === ChronoField.OFFSET_SECONDS;\n } else if (fieldOrUnit instanceof ChronoUnit) {\n return fieldOrUnit.isTimeBased();\n }\n\n return fieldOrUnit != null && fieldOrUnit.isSupportedBy(this);\n };\n\n _proto.minusHours = function minusHours(hours) {\n return this._withLocalTimeOffset(this._time.minusHours(hours), this._offset);\n };\n\n _proto.minusMinutes = function minusMinutes(minutes) {\n return this._withLocalTimeOffset(this._time.minusMinutes(minutes), this._offset);\n };\n\n _proto.minusSeconds = function minusSeconds(seconds) {\n return this._withLocalTimeOffset(this._time.minusSeconds(seconds), this._offset);\n };\n\n _proto.minusNanos = function minusNanos(nanos) {\n return this._withLocalTimeOffset(this._time.minusNanos(nanos), this._offset);\n };\n\n _proto.minusAmount = function minusAmount(amount) {\n requireNonNull(amount);\n return amount.subtractFrom(this);\n };\n\n _proto.minusAmountUnit = function minusAmountUnit(amountToSubtract, unit) {\n return this.plus(-1 * amountToSubtract, unit);\n };\n\n _proto.plusAmount = function plusAmount(amount) {\n requireNonNull(amount);\n return amount.addTo(this);\n };\n\n _proto.plusAmountUnit = function plusAmountUnit(amountToAdd, unit) {\n if (unit instanceof ChronoUnit) {\n return this._withLocalTimeOffset(this._time.plus(amountToAdd, unit), this._offset);\n }\n\n return unit.addTo(this, amountToAdd);\n };\n\n _proto.plusHours = function plusHours(hours) {\n return this._withLocalTimeOffset(this._time.plusHours(hours), this._offset);\n };\n\n _proto.plusMinutes = function plusMinutes(minutes) {\n return this._withLocalTimeOffset(this._time.plusMinutes(minutes), this._offset);\n };\n\n _proto.plusSeconds = function plusSeconds(seconds) {\n return this._withLocalTimeOffset(this._time.plusSeconds(seconds), this._offset);\n };\n\n _proto.plusNanos = function plusNanos(nanos) {\n return this._withLocalTimeOffset(this._time.plusNanos(nanos), this._offset);\n };\n\n _proto.query = function query(_query) {\n requireNonNull(_query, 'query');\n\n if (_query === TemporalQueries.precision()) {\n return ChronoUnit.NANOS;\n } else if (_query === TemporalQueries.offset() || _query === TemporalQueries.zone()) {\n return this.offset();\n } else if (_query === TemporalQueries.localTime()) {\n return this._time;\n } else if (_query === TemporalQueries.chronology() || _query === TemporalQueries.localDate() || _query === TemporalQueries.zoneId()) {\n return null;\n }\n\n return _DefaultInterfaceTemp.prototype.query.call(this, _query);\n };\n\n _proto.range = function range(field) {\n if (field instanceof ChronoField) {\n if (field === ChronoField.OFFSET_SECONDS) {\n return field.range();\n }\n\n return this._time.range(field);\n }\n\n return field.rangeRefinedBy(this);\n };\n\n _proto.toLocalTime = function toLocalTime() {\n return this._time;\n };\n\n _proto.truncatedTo = function truncatedTo(unit) {\n return this._withLocalTimeOffset(this._time.truncatedTo(unit), this._offset);\n };\n\n _proto.until = function until(endExclusive, unit) {\n requireNonNull(endExclusive, 'endExclusive');\n requireNonNull(unit, 'unit');\n var end = OffsetTime.from(endExclusive);\n\n if (unit instanceof ChronoUnit) {\n var nanosUntil = end._toEpochNano() - this._toEpochNano();\n\n switch (unit) {\n case ChronoUnit.NANOS:\n return nanosUntil;\n\n case ChronoUnit.MICROS:\n return Math.floor(nanosUntil / 1000);\n\n case ChronoUnit.MILLIS:\n return Math.floor(nanosUntil / 1000000);\n\n case ChronoUnit.SECONDS:\n return Math.floor(nanosUntil / LocalTime.NANOS_PER_SECOND);\n\n case ChronoUnit.MINUTES:\n return Math.floor(nanosUntil / LocalTime.NANOS_PER_MINUTE);\n\n case ChronoUnit.HOURS:\n return Math.floor(nanosUntil / LocalTime.NANOS_PER_HOUR);\n\n case ChronoUnit.HALF_DAYS:\n return Math.floor(nanosUntil / (12 * LocalTime.NANOS_PER_HOUR));\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported unit: ' + unit);\n }\n\n return unit.between(this, end);\n };\n\n _proto.withHour = function withHour(hour) {\n return this._withLocalTimeOffset(this._time.withHour(hour), this._offset);\n };\n\n _proto.withMinute = function withMinute(minute) {\n return this._withLocalTimeOffset(this._time.withMinute(minute), this._offset);\n };\n\n _proto.withSecond = function withSecond(second) {\n return this._withLocalTimeOffset(this._time.withSecond(second), this._offset);\n };\n\n _proto.withNano = function withNano(nano) {\n return this._withLocalTimeOffset(this._time.withNano(nano), this._offset);\n };\n\n _proto.withOffsetSameInstant = function withOffsetSameInstant(offset) {\n requireNonNull(offset, 'offset');\n\n if (offset.equals(this._offset)) {\n return this;\n }\n\n var difference = offset.totalSeconds() - this._offset.totalSeconds();\n\n var adjusted = this._time.plusSeconds(difference);\n\n return new OffsetTime(adjusted, offset);\n };\n\n _proto.withOffsetSameLocal = function withOffsetSameLocal(offset) {\n return offset != null && offset.equals(this._offset) ? this : new OffsetTime(this._time, offset);\n };\n\n _proto._toEpochNano = function _toEpochNano() {\n var nod = this._time.toNanoOfDay();\n\n var offsetNanos = this._offset.totalSeconds() * LocalTime.NANOS_PER_SECOND;\n return nod - offsetNanos;\n };\n\n _proto.withAdjuster = function withAdjuster(adjuster) {\n requireNonNull(adjuster, 'adjuster');\n\n if (adjuster instanceof LocalTime) {\n return this._withLocalTimeOffset(adjuster, this._offset);\n } else if (adjuster instanceof ZoneOffset) {\n return this._withLocalTimeOffset(this._time, adjuster);\n } else if (adjuster instanceof OffsetTime) {\n return adjuster;\n }\n\n return adjuster.adjustInto(this);\n };\n\n _proto.withFieldValue = function withFieldValue(field, newValue) {\n requireNonNull(field, 'field');\n\n if (field instanceof ChronoField) {\n if (field === ChronoField.OFFSET_SECONDS) {\n return this._withLocalTimeOffset(this._time, ZoneOffset.ofTotalSeconds(field.checkValidIntValue(newValue)));\n }\n\n return this._withLocalTimeOffset(this._time.with(field, newValue), this._offset);\n }\n\n return field.adjustInto(this, newValue);\n };\n\n _proto._withLocalTimeOffset = function _withLocalTimeOffset(time, offset) {\n if (this._time === time && this._offset.equals(offset)) {\n return this;\n }\n\n return new OffsetTime(time, offset);\n };\n\n _proto.compareTo = function compareTo(other) {\n requireNonNull(other, 'other');\n requireInstance(other, OffsetTime, 'other');\n\n if (this._offset.equals(other._offset)) {\n return this._time.compareTo(other._time);\n }\n\n var compare = MathUtil.compareNumbers(this._toEpochNano(), other._toEpochNano());\n\n if (compare === 0) {\n return this._time.compareTo(other._time);\n }\n\n return compare;\n };\n\n _proto.equals = function equals(other) {\n if (this === other) {\n return true;\n }\n\n if (other instanceof OffsetTime) {\n return this._time.equals(other._time) && this._offset.equals(other._offset);\n }\n\n return false;\n };\n\n _proto.hashCode = function hashCode() {\n return this._time.hashCode() ^ this._offset.hashCode();\n };\n\n _proto.toString = function toString() {\n return this._time.toString() + this._offset.toString();\n };\n\n _proto.toJSON = function toJSON() {\n return this.toString();\n };\n\n return OffsetTime;\n}(DefaultInterfaceTemporal);\nfunction _init$f() {\n OffsetTime.MIN = OffsetTime.ofNumbers(0, 0, 0, 0, ZoneOffset.MAX);\n OffsetTime.MAX = OffsetTime.ofNumbers(23, 59, 59, 999999999, ZoneOffset.MIN);\n OffsetTime.FROM = createTemporalQuery('OffsetTime.FROM', function (temporal) {\n return OffsetTime.from(temporal);\n });\n}\n\nvar ChronoZonedDateTime = function (_DefaultInterfaceTemp) {\n _inheritsLoose(ChronoZonedDateTime, _DefaultInterfaceTemp);\n\n function ChronoZonedDateTime() {\n return _DefaultInterfaceTemp.apply(this, arguments) || this;\n }\n\n var _proto = ChronoZonedDateTime.prototype;\n\n _proto.query = function query(_query) {\n if (_query === TemporalQueries.zoneId() || _query === TemporalQueries.zone()) {\n return this.zone();\n } else if (_query === TemporalQueries.chronology()) {\n return this.toLocalDate().chronology();\n } else if (_query === TemporalQueries.precision()) {\n return ChronoUnit.NANOS;\n } else if (_query === TemporalQueries.offset()) {\n return this.offset();\n } else if (_query === TemporalQueries.localDate()) {\n return LocalDate.ofEpochDay(this.toLocalDate().toEpochDay());\n } else if (_query === TemporalQueries.localTime()) {\n return this.toLocalTime();\n }\n\n return _DefaultInterfaceTemp.prototype.query.call(this, _query);\n };\n\n _proto.format = function format(formatter) {\n requireNonNull(formatter, 'formatter');\n return formatter.format(this);\n };\n\n _proto.toInstant = function toInstant() {\n return Instant.ofEpochSecond(this.toEpochSecond(), this.toLocalTime().nano());\n };\n\n _proto.toEpochSecond = function toEpochSecond() {\n var epochDay = this.toLocalDate().toEpochDay();\n var secs = epochDay * 86400 + this.toLocalTime().toSecondOfDay();\n secs -= this.offset().totalSeconds();\n return secs;\n };\n\n _proto.compareTo = function compareTo(other) {\n requireNonNull(other, 'other');\n var cmp = MathUtil.compareNumbers(this.toEpochSecond(), other.toEpochSecond());\n\n if (cmp === 0) {\n cmp = this.toLocalTime().nano() - other.toLocalTime().nano();\n\n if (cmp === 0) {\n cmp = this.toLocalDateTime().compareTo(other.toLocalDateTime());\n\n if (cmp === 0) {\n cmp = strcmp(this.zone().id(), other.zone().id());\n }\n }\n }\n\n return cmp;\n };\n\n _proto.isAfter = function isAfter(other) {\n requireNonNull(other, 'other');\n var thisEpochSec = this.toEpochSecond();\n var otherEpochSec = other.toEpochSecond();\n return thisEpochSec > otherEpochSec || thisEpochSec === otherEpochSec && this.toLocalTime().nano() > other.toLocalTime().nano();\n };\n\n _proto.isBefore = function isBefore(other) {\n requireNonNull(other, 'other');\n var thisEpochSec = this.toEpochSecond();\n var otherEpochSec = other.toEpochSecond();\n return thisEpochSec < otherEpochSec || thisEpochSec === otherEpochSec && this.toLocalTime().nano() < other.toLocalTime().nano();\n };\n\n _proto.isEqual = function isEqual(other) {\n requireNonNull(other, 'other');\n return this.toEpochSecond() === other.toEpochSecond() && this.toLocalTime().nano() === other.toLocalTime().nano();\n };\n\n _proto.equals = function equals(other) {\n if (this === other) {\n return true;\n }\n\n if (other instanceof ChronoZonedDateTime) {\n return this.compareTo(other) === 0;\n }\n\n return false;\n };\n\n return ChronoZonedDateTime;\n}(DefaultInterfaceTemporal);\n\nfunction strcmp(a, b) {\n if (a < b) {\n return -1;\n }\n\n if (a > b) {\n return 1;\n }\n\n return 0;\n}\n\nvar ZonedDateTime = function (_ChronoZonedDateTime) {\n _inheritsLoose(ZonedDateTime, _ChronoZonedDateTime);\n\n ZonedDateTime.now = function now(clockOrZone) {\n var clock;\n\n if (clockOrZone instanceof ZoneId) {\n clock = Clock.system(clockOrZone);\n } else {\n clock = clockOrZone == null ? Clock.systemDefaultZone() : clockOrZone;\n }\n\n return ZonedDateTime.ofInstant(clock.instant(), clock.zone());\n };\n\n ZonedDateTime.of = function of() {\n if (arguments.length <= 2) {\n return ZonedDateTime.of2.apply(this, arguments);\n } else if (arguments.length === 3 && arguments[0] instanceof LocalDate) {\n return ZonedDateTime.of3.apply(this, arguments);\n } else {\n return ZonedDateTime.of8.apply(this, arguments);\n }\n };\n\n ZonedDateTime.of3 = function of3(date, time, zone) {\n return ZonedDateTime.of2(LocalDateTime.of(date, time), zone);\n };\n\n ZonedDateTime.of2 = function of2(localDateTime, zone) {\n return ZonedDateTime.ofLocal(localDateTime, zone, null);\n };\n\n ZonedDateTime.of8 = function of8(year, month, dayOfMonth, hour, minute, second, nanoOfSecond, zone) {\n var dt = LocalDateTime.of(year, month, dayOfMonth, hour, minute, second, nanoOfSecond);\n return ZonedDateTime.ofLocal(dt, zone, null);\n };\n\n ZonedDateTime.ofLocal = function ofLocal(localDateTime, zone, preferredOffset) {\n requireNonNull(localDateTime, 'localDateTime');\n requireNonNull(zone, 'zone');\n\n if (zone instanceof ZoneOffset) {\n return new ZonedDateTime(localDateTime, zone, zone);\n }\n\n var offset = null;\n var rules = zone.rules();\n var validOffsets = rules.validOffsets(localDateTime);\n\n if (validOffsets.length === 1) {\n offset = validOffsets[0];\n } else if (validOffsets.length === 0) {\n var trans = rules.transition(localDateTime);\n localDateTime = localDateTime.plusSeconds(trans.duration().seconds());\n offset = trans.offsetAfter();\n } else {\n if (preferredOffset != null && validOffsets.some(function (validOffset) {\n return validOffset.equals(preferredOffset);\n })) {\n offset = preferredOffset;\n } else {\n offset = requireNonNull(validOffsets[0], 'offset');\n }\n }\n\n return new ZonedDateTime(localDateTime, offset, zone);\n };\n\n ZonedDateTime.ofInstant = function ofInstant() {\n if (arguments.length === 2) {\n return ZonedDateTime.ofInstant2.apply(this, arguments);\n } else {\n return ZonedDateTime.ofInstant3.apply(this, arguments);\n }\n };\n\n ZonedDateTime.ofInstant2 = function ofInstant2(instant, zone) {\n requireNonNull(instant, 'instant');\n requireNonNull(zone, 'zone');\n return ZonedDateTime._create(instant.epochSecond(), instant.nano(), zone);\n };\n\n ZonedDateTime.ofInstant3 = function ofInstant3(localDateTime, offset, zone) {\n requireNonNull(localDateTime, 'localDateTime');\n requireNonNull(offset, 'offset');\n requireNonNull(zone, 'zone');\n return ZonedDateTime._create(localDateTime.toEpochSecond(offset), localDateTime.nano(), zone);\n };\n\n ZonedDateTime._create = function _create(epochSecond, nanoOfSecond, zone) {\n var rules = zone.rules();\n var instant = Instant.ofEpochSecond(epochSecond, nanoOfSecond);\n var offset = rules.offset(instant);\n var ldt = LocalDateTime.ofEpochSecond(epochSecond, nanoOfSecond, offset);\n return new ZonedDateTime(ldt, offset, zone);\n };\n\n ZonedDateTime.ofStrict = function ofStrict(localDateTime, offset, zone) {\n requireNonNull(localDateTime, 'localDateTime');\n requireNonNull(offset, 'offset');\n requireNonNull(zone, 'zone');\n var rules = zone.rules();\n\n if (rules.isValidOffset(localDateTime, offset) === false) {\n var trans = rules.transition(localDateTime);\n\n if (trans != null && trans.isGap()) {\n throw new DateTimeException('LocalDateTime ' + localDateTime + ' does not exist in zone ' + zone + ' due to a gap in the local time-line, typically caused by daylight savings');\n }\n\n throw new DateTimeException('ZoneOffset \"' + offset + '\" is not valid for LocalDateTime \"' + localDateTime + '\" in zone \"' + zone + '\"');\n }\n\n return new ZonedDateTime(localDateTime, offset, zone);\n };\n\n ZonedDateTime.ofLenient = function ofLenient(localDateTime, offset, zone) {\n requireNonNull(localDateTime, 'localDateTime');\n requireNonNull(offset, 'offset');\n requireNonNull(zone, 'zone');\n\n if (zone instanceof ZoneOffset && offset.equals(zone) === false) {\n throw new IllegalArgumentException('ZoneId must match ZoneOffset');\n }\n\n return new ZonedDateTime(localDateTime, offset, zone);\n };\n\n ZonedDateTime.from = function from(temporal) {\n requireNonNull(temporal, 'temporal');\n\n if (temporal instanceof ZonedDateTime) {\n return temporal;\n }\n\n var zone = ZoneId.from(temporal);\n\n if (temporal.isSupported(ChronoField.INSTANT_SECONDS)) {\n var zdt = ZonedDateTime._from(temporal, zone);\n\n if (zdt != null) return zdt;\n }\n\n var ldt = LocalDateTime.from(temporal);\n return ZonedDateTime.of2(ldt, zone);\n };\n\n ZonedDateTime._from = function _from(temporal, zone) {\n try {\n return ZonedDateTime.__from(temporal, zone);\n } catch (ex) {\n if (!(ex instanceof DateTimeException)) throw ex;\n }\n };\n\n ZonedDateTime.__from = function __from(temporal, zone) {\n var epochSecond = temporal.getLong(ChronoField.INSTANT_SECONDS);\n var nanoOfSecond = temporal.get(ChronoField.NANO_OF_SECOND);\n return ZonedDateTime._create(epochSecond, nanoOfSecond, zone);\n };\n\n ZonedDateTime.parse = function parse(text, formatter) {\n if (formatter === void 0) {\n formatter = DateTimeFormatter.ISO_ZONED_DATE_TIME;\n }\n\n requireNonNull(formatter, 'formatter');\n return formatter.parse(text, ZonedDateTime.FROM);\n };\n\n function ZonedDateTime(dateTime, offset, zone) {\n var _this;\n\n requireNonNull(dateTime, 'dateTime');\n requireNonNull(offset, 'offset');\n requireNonNull(zone, 'zone');\n _this = _ChronoZonedDateTime.call(this) || this;\n _this._dateTime = dateTime;\n _this._offset = offset;\n _this._zone = zone;\n return _this;\n }\n\n var _proto = ZonedDateTime.prototype;\n\n _proto._resolveLocal = function _resolveLocal(newDateTime) {\n requireNonNull(newDateTime, 'newDateTime');\n return ZonedDateTime.ofLocal(newDateTime, this._zone, this._offset);\n };\n\n _proto._resolveInstant = function _resolveInstant(newDateTime) {\n return ZonedDateTime.ofInstant3(newDateTime, this._offset, this._zone);\n };\n\n _proto._resolveOffset = function _resolveOffset(offset) {\n if (offset.equals(this._offset) === false && this._zone.rules().isValidOffset(this._dateTime, offset)) {\n return new ZonedDateTime(this._dateTime, offset, this._zone);\n }\n\n return this;\n };\n\n _proto.isSupported = function isSupported(fieldOrUnit) {\n if (fieldOrUnit instanceof ChronoField) {\n return true;\n } else if (fieldOrUnit instanceof ChronoUnit) {\n return fieldOrUnit.isDateBased() || fieldOrUnit.isTimeBased();\n }\n\n return fieldOrUnit != null && fieldOrUnit.isSupportedBy(this);\n };\n\n _proto.range = function range(field) {\n if (field instanceof ChronoField) {\n if (field === ChronoField.INSTANT_SECONDS || field === ChronoField.OFFSET_SECONDS) {\n return field.range();\n }\n\n return this._dateTime.range(field);\n }\n\n return field.rangeRefinedBy(this);\n };\n\n _proto.get = function get(field) {\n return this.getLong(field);\n };\n\n _proto.getLong = function getLong(field) {\n if (field instanceof ChronoField) {\n switch (field) {\n case ChronoField.INSTANT_SECONDS:\n return this.toEpochSecond();\n\n case ChronoField.OFFSET_SECONDS:\n return this._offset.totalSeconds();\n }\n\n return this._dateTime.getLong(field);\n }\n\n requireNonNull(field, 'field');\n return field.getFrom(this);\n };\n\n _proto.offset = function offset() {\n return this._offset;\n };\n\n _proto.withEarlierOffsetAtOverlap = function withEarlierOffsetAtOverlap() {\n var trans = this._zone.rules().transition(this._dateTime);\n\n if (trans != null && trans.isOverlap()) {\n var earlierOffset = trans.offsetBefore();\n\n if (earlierOffset.equals(this._offset) === false) {\n return new ZonedDateTime(this._dateTime, earlierOffset, this._zone);\n }\n }\n\n return this;\n };\n\n _proto.withLaterOffsetAtOverlap = function withLaterOffsetAtOverlap() {\n var trans = this._zone.rules().transition(this.toLocalDateTime());\n\n if (trans != null) {\n var laterOffset = trans.offsetAfter();\n\n if (laterOffset.equals(this._offset) === false) {\n return new ZonedDateTime(this._dateTime, laterOffset, this._zone);\n }\n }\n\n return this;\n };\n\n _proto.zone = function zone() {\n return this._zone;\n };\n\n _proto.withZoneSameLocal = function withZoneSameLocal(zone) {\n requireNonNull(zone, 'zone');\n return this._zone.equals(zone) ? this : ZonedDateTime.ofLocal(this._dateTime, zone, this._offset);\n };\n\n _proto.withZoneSameInstant = function withZoneSameInstant(zone) {\n requireNonNull(zone, 'zone');\n return this._zone.equals(zone) ? this : ZonedDateTime._create(this._dateTime.toEpochSecond(this._offset), this._dateTime.nano(), zone);\n };\n\n _proto.withFixedOffsetZone = function withFixedOffsetZone() {\n return this._zone.equals(this._offset) ? this : new ZonedDateTime(this._dateTime, this._offset, this._offset);\n };\n\n _proto.year = function year() {\n return this._dateTime.year();\n };\n\n _proto.monthValue = function monthValue() {\n return this._dateTime.monthValue();\n };\n\n _proto.month = function month() {\n return this._dateTime.month();\n };\n\n _proto.dayOfMonth = function dayOfMonth() {\n return this._dateTime.dayOfMonth();\n };\n\n _proto.dayOfYear = function dayOfYear() {\n return this._dateTime.dayOfYear();\n };\n\n _proto.dayOfWeek = function dayOfWeek() {\n return this._dateTime.dayOfWeek();\n };\n\n _proto.hour = function hour() {\n return this._dateTime.hour();\n };\n\n _proto.minute = function minute() {\n return this._dateTime.minute();\n };\n\n _proto.second = function second() {\n return this._dateTime.second();\n };\n\n _proto.nano = function nano() {\n return this._dateTime.nano();\n };\n\n _proto.withAdjuster = function withAdjuster(adjuster) {\n if (adjuster instanceof LocalDate) {\n return this._resolveLocal(LocalDateTime.of(adjuster, this._dateTime.toLocalTime()));\n } else if (adjuster instanceof LocalTime) {\n return this._resolveLocal(LocalDateTime.of(this._dateTime.toLocalDate(), adjuster));\n } else if (adjuster instanceof LocalDateTime) {\n return this._resolveLocal(adjuster);\n } else if (adjuster instanceof Instant) {\n var instant = adjuster;\n return ZonedDateTime._create(instant.epochSecond(), instant.nano(), this._zone);\n } else if (adjuster instanceof ZoneOffset) {\n return this._resolveOffset(adjuster);\n }\n\n requireNonNull(adjuster, 'adjuster');\n return adjuster.adjustInto(this);\n };\n\n _proto.withFieldValue = function withFieldValue(field, newValue) {\n if (field instanceof ChronoField) {\n switch (field) {\n case ChronoField.INSTANT_SECONDS:\n return ZonedDateTime._create(newValue, this.nano(), this._zone);\n\n case ChronoField.OFFSET_SECONDS:\n {\n var offset = ZoneOffset.ofTotalSeconds(field.checkValidIntValue(newValue));\n return this._resolveOffset(offset);\n }\n }\n\n return this._resolveLocal(this._dateTime.with(field, newValue));\n }\n\n return field.adjustInto(this, newValue);\n };\n\n _proto.withYear = function withYear(year) {\n return this._resolveLocal(this._dateTime.withYear(year));\n };\n\n _proto.withMonth = function withMonth(month) {\n return this._resolveLocal(this._dateTime.withMonth(month));\n };\n\n _proto.withDayOfMonth = function withDayOfMonth(dayOfMonth) {\n return this._resolveLocal(this._dateTime.withDayOfMonth(dayOfMonth));\n };\n\n _proto.withDayOfYear = function withDayOfYear(dayOfYear) {\n return this._resolveLocal(this._dateTime.withDayOfYear(dayOfYear));\n };\n\n _proto.withHour = function withHour(hour) {\n return this._resolveLocal(this._dateTime.withHour(hour));\n };\n\n _proto.withMinute = function withMinute(minute) {\n return this._resolveLocal(this._dateTime.withMinute(minute));\n };\n\n _proto.withSecond = function withSecond(second) {\n return this._resolveLocal(this._dateTime.withSecond(second));\n };\n\n _proto.withNano = function withNano(nanoOfSecond) {\n return this._resolveLocal(this._dateTime.withNano(nanoOfSecond));\n };\n\n _proto.truncatedTo = function truncatedTo(unit) {\n return this._resolveLocal(this._dateTime.truncatedTo(unit));\n };\n\n _proto.plusAmount = function plusAmount(amount) {\n requireNonNull(amount);\n return amount.addTo(this);\n };\n\n _proto.plusAmountUnit = function plusAmountUnit(amountToAdd, unit) {\n if (unit instanceof ChronoUnit) {\n if (unit.isDateBased()) {\n return this._resolveLocal(this._dateTime.plus(amountToAdd, unit));\n } else {\n return this._resolveInstant(this._dateTime.plus(amountToAdd, unit));\n }\n }\n\n requireNonNull(unit, 'unit');\n return unit.addTo(this, amountToAdd);\n };\n\n _proto.plusYears = function plusYears(years) {\n return this._resolveLocal(this._dateTime.plusYears(years));\n };\n\n _proto.plusMonths = function plusMonths(months) {\n return this._resolveLocal(this._dateTime.plusMonths(months));\n };\n\n _proto.plusWeeks = function plusWeeks(weeks) {\n return this._resolveLocal(this._dateTime.plusWeeks(weeks));\n };\n\n _proto.plusDays = function plusDays(days) {\n return this._resolveLocal(this._dateTime.plusDays(days));\n };\n\n _proto.plusHours = function plusHours(hours) {\n return this._resolveInstant(this._dateTime.plusHours(hours));\n };\n\n _proto.plusMinutes = function plusMinutes(minutes) {\n return this._resolveInstant(this._dateTime.plusMinutes(minutes));\n };\n\n _proto.plusSeconds = function plusSeconds(seconds) {\n return this._resolveInstant(this._dateTime.plusSeconds(seconds));\n };\n\n _proto.plusNanos = function plusNanos(nanos) {\n return this._resolveInstant(this._dateTime.plusNanos(nanos));\n };\n\n _proto.minusAmount = function minusAmount(amount) {\n requireNonNull(amount, 'amount');\n return amount.subtractFrom(this);\n };\n\n _proto.minusAmountUnit = function minusAmountUnit(amountToSubtract, unit) {\n return this.plusAmountUnit(-1 * amountToSubtract, unit);\n };\n\n _proto.minusYears = function minusYears(years) {\n return this.plusYears(-1 * years);\n };\n\n _proto.minusMonths = function minusMonths(months) {\n return this.plusMonths(-1 * months);\n };\n\n _proto.minusWeeks = function minusWeeks(weeks) {\n return this.plusWeeks(-1 * weeks);\n };\n\n _proto.minusDays = function minusDays(days) {\n return this.plusDays(-1 * days);\n };\n\n _proto.minusHours = function minusHours(hours) {\n return this.plusHours(-1 * hours);\n };\n\n _proto.minusMinutes = function minusMinutes(minutes) {\n return this.plusMinutes(-1 * minutes);\n };\n\n _proto.minusSeconds = function minusSeconds(seconds) {\n return this.plusSeconds(-1 * seconds);\n };\n\n _proto.minusNanos = function minusNanos(nanos) {\n return this.plusNanos(-1 * nanos);\n };\n\n _proto.query = function query(_query) {\n if (_query === TemporalQueries.localDate()) {\n return this.toLocalDate();\n }\n\n requireNonNull(_query, 'query');\n return _ChronoZonedDateTime.prototype.query.call(this, _query);\n };\n\n _proto.until = function until(endExclusive, unit) {\n var end = ZonedDateTime.from(endExclusive);\n\n if (unit instanceof ChronoUnit) {\n end = end.withZoneSameInstant(this._zone);\n\n if (unit.isDateBased()) {\n return this._dateTime.until(end._dateTime, unit);\n } else {\n var difference = this._offset.totalSeconds() - end._offset.totalSeconds();\n\n var adjustedEnd = end._dateTime.plusSeconds(difference);\n\n return this._dateTime.until(adjustedEnd, unit);\n }\n }\n\n return unit.between(this, end);\n };\n\n _proto.toLocalDateTime = function toLocalDateTime() {\n return this._dateTime;\n };\n\n _proto.toLocalDate = function toLocalDate() {\n return this._dateTime.toLocalDate();\n };\n\n _proto.toLocalTime = function toLocalTime() {\n return this._dateTime.toLocalTime();\n };\n\n _proto.toOffsetDateTime = function toOffsetDateTime() {\n return OffsetDateTime.of(this._dateTime, this._offset);\n };\n\n _proto.equals = function equals(other) {\n if (this === other) {\n return true;\n }\n\n if (other instanceof ZonedDateTime) {\n return this._dateTime.equals(other._dateTime) && this._offset.equals(other._offset) && this._zone.equals(other._zone);\n }\n\n return false;\n };\n\n _proto.hashCode = function hashCode() {\n return MathUtil.hashCode(this._dateTime.hashCode(), this._offset.hashCode(), this._zone.hashCode());\n };\n\n _proto.toString = function toString() {\n var str = this._dateTime.toString() + this._offset.toString();\n\n if (this._offset !== this._zone) {\n str += '[' + this._zone.toString() + ']';\n }\n\n return str;\n };\n\n _proto.toJSON = function toJSON() {\n return this.toString();\n };\n\n _proto.format = function format(formatter) {\n return _ChronoZonedDateTime.prototype.format.call(this, formatter);\n };\n\n return ZonedDateTime;\n}(ChronoZonedDateTime);\nfunction _init$g() {\n ZonedDateTime.FROM = createTemporalQuery('ZonedDateTime.FROM', function (temporal) {\n return ZonedDateTime.from(temporal);\n });\n}\n\nvar OffsetDateTime = function (_DefaultInterfaceTemp) {\n _inheritsLoose(OffsetDateTime, _DefaultInterfaceTemp);\n\n OffsetDateTime.from = function from(temporal) {\n requireNonNull(temporal, 'temporal');\n\n if (temporal instanceof OffsetDateTime) {\n return temporal;\n }\n\n try {\n var offset = ZoneOffset.from(temporal);\n\n try {\n var ldt = LocalDateTime.from(temporal);\n return OffsetDateTime.of(ldt, offset);\n } catch (_) {\n var instant = Instant.from(temporal);\n return OffsetDateTime.ofInstant(instant, offset);\n }\n } catch (ex) {\n throw new DateTimeException(\"Unable to obtain OffsetDateTime TemporalAccessor: \" + temporal + \", type \" + (temporal.constructor != null ? temporal.constructor.name : ''));\n }\n };\n\n OffsetDateTime.now = function now(clockOrZone) {\n if (arguments.length === 0) {\n return OffsetDateTime.now(Clock.systemDefaultZone());\n } else {\n requireNonNull(clockOrZone, 'clockOrZone');\n\n if (clockOrZone instanceof ZoneId) {\n return OffsetDateTime.now(Clock.system(clockOrZone));\n } else if (clockOrZone instanceof Clock) {\n var now = clockOrZone.instant();\n return OffsetDateTime.ofInstant(now, clockOrZone.zone().rules().offset(now));\n } else {\n throw new IllegalArgumentException('clockOrZone must be an instance of ZoneId or Clock');\n }\n }\n };\n\n OffsetDateTime.of = function of() {\n if (arguments.length <= 2) {\n return OffsetDateTime.ofDateTime.apply(this, arguments);\n } else if (arguments.length === 3) {\n return OffsetDateTime.ofDateAndTime.apply(this, arguments);\n } else {\n return OffsetDateTime.ofNumbers.apply(this, arguments);\n }\n };\n\n OffsetDateTime.ofDateTime = function ofDateTime(dateTime, offset) {\n return new OffsetDateTime(dateTime, offset);\n };\n\n OffsetDateTime.ofDateAndTime = function ofDateAndTime(date, time, offset) {\n var dt = LocalDateTime.of(date, time);\n return new OffsetDateTime(dt, offset);\n };\n\n OffsetDateTime.ofNumbers = function ofNumbers(year, month, dayOfMonth, hour, minute, second, nanoOfSecond, offset) {\n if (hour === void 0) {\n hour = 0;\n }\n\n if (minute === void 0) {\n minute = 0;\n }\n\n if (second === void 0) {\n second = 0;\n }\n\n if (nanoOfSecond === void 0) {\n nanoOfSecond = 0;\n }\n\n var dt = LocalDateTime.of(year, month, dayOfMonth, hour, minute, second, nanoOfSecond);\n return new OffsetDateTime(dt, offset);\n };\n\n OffsetDateTime.ofInstant = function ofInstant(instant, zone) {\n requireNonNull(instant, 'instant');\n requireNonNull(zone, 'zone');\n var rules = zone.rules();\n var offset = rules.offset(instant);\n var ldt = LocalDateTime.ofEpochSecond(instant.epochSecond(), instant.nano(), offset);\n return new OffsetDateTime(ldt, offset);\n };\n\n OffsetDateTime.parse = function parse(text, formatter) {\n if (formatter === void 0) {\n formatter = DateTimeFormatter.ISO_OFFSET_DATE_TIME;\n }\n\n requireNonNull(formatter, 'formatter');\n return formatter.parse(text, OffsetDateTime.FROM);\n };\n\n function OffsetDateTime(dateTime, offset) {\n var _this;\n\n _this = _DefaultInterfaceTemp.call(this) || this;\n requireNonNull(dateTime, 'dateTime');\n requireInstance(dateTime, LocalDateTime, 'dateTime');\n requireNonNull(offset, 'offset');\n requireInstance(offset, ZoneOffset, 'offset');\n _this._dateTime = dateTime;\n _this._offset = offset;\n return _this;\n }\n\n var _proto = OffsetDateTime.prototype;\n\n _proto.adjustInto = function adjustInto(temporal) {\n return temporal.with(ChronoField.EPOCH_DAY, this.toLocalDate().toEpochDay()).with(ChronoField.NANO_OF_DAY, this.toLocalTime().toNanoOfDay()).with(ChronoField.OFFSET_SECONDS, this.offset().totalSeconds());\n };\n\n _proto.until = function until(endExclusive, unit) {\n var end = OffsetDateTime.from(endExclusive);\n\n if (unit instanceof ChronoUnit) {\n end = end.withOffsetSameInstant(this._offset);\n return this._dateTime.until(end._dateTime, unit);\n }\n\n return unit.between(this, end);\n };\n\n _proto.atZoneSameInstant = function atZoneSameInstant(zone) {\n return ZonedDateTime.ofInstant(this._dateTime, this._offset, zone);\n };\n\n _proto.atZoneSimilarLocal = function atZoneSimilarLocal(zone) {\n return ZonedDateTime.ofLocal(this._dateTime, zone, this._offset);\n };\n\n _proto.query = function query(_query) {\n requireNonNull(_query, 'query');\n\n if (_query === TemporalQueries.chronology()) {\n return IsoChronology.INSTANCE;\n } else if (_query === TemporalQueries.precision()) {\n return ChronoUnit.NANOS;\n } else if (_query === TemporalQueries.offset() || _query === TemporalQueries.zone()) {\n return this.offset();\n } else if (_query === TemporalQueries.localDate()) {\n return this.toLocalDate();\n } else if (_query === TemporalQueries.localTime()) {\n return this.toLocalTime();\n } else if (_query === TemporalQueries.zoneId()) {\n return null;\n }\n\n return _DefaultInterfaceTemp.prototype.query.call(this, _query);\n };\n\n _proto.get = function get(field) {\n if (field instanceof ChronoField) {\n switch (field) {\n case ChronoField.INSTANT_SECONDS:\n throw new DateTimeException('Field too large for an int: ' + field);\n\n case ChronoField.OFFSET_SECONDS:\n return this.offset().totalSeconds();\n }\n\n return this._dateTime.get(field);\n }\n\n return _DefaultInterfaceTemp.prototype.get.call(this, field);\n };\n\n _proto.getLong = function getLong(field) {\n if (field instanceof ChronoField) {\n switch (field) {\n case ChronoField.INSTANT_SECONDS:\n return this.toEpochSecond();\n\n case ChronoField.OFFSET_SECONDS:\n return this.offset().totalSeconds();\n }\n\n return this._dateTime.getLong(field);\n }\n\n return field.getFrom(this);\n };\n\n _proto.offset = function offset() {\n return this._offset;\n };\n\n _proto.year = function year() {\n return this._dateTime.year();\n };\n\n _proto.monthValue = function monthValue() {\n return this._dateTime.monthValue();\n };\n\n _proto.month = function month() {\n return this._dateTime.month();\n };\n\n _proto.dayOfMonth = function dayOfMonth() {\n return this._dateTime.dayOfMonth();\n };\n\n _proto.dayOfYear = function dayOfYear() {\n return this._dateTime.dayOfYear();\n };\n\n _proto.dayOfWeek = function dayOfWeek() {\n return this._dateTime.dayOfWeek();\n };\n\n _proto.hour = function hour() {\n return this._dateTime.hour();\n };\n\n _proto.minute = function minute() {\n return this._dateTime.minute();\n };\n\n _proto.second = function second() {\n return this._dateTime.second();\n };\n\n _proto.nano = function nano() {\n return this._dateTime.nano();\n };\n\n _proto.toLocalDateTime = function toLocalDateTime() {\n return this._dateTime;\n };\n\n _proto.toLocalDate = function toLocalDate() {\n return this._dateTime.toLocalDate();\n };\n\n _proto.toLocalTime = function toLocalTime() {\n return this._dateTime.toLocalTime();\n };\n\n _proto.toOffsetTime = function toOffsetTime() {\n return OffsetTime.of(this._dateTime.toLocalTime(), this._offset);\n };\n\n _proto.toZonedDateTime = function toZonedDateTime() {\n return ZonedDateTime.of(this._dateTime, this._offset);\n };\n\n _proto.toInstant = function toInstant() {\n return this._dateTime.toInstant(this._offset);\n };\n\n _proto.toEpochSecond = function toEpochSecond() {\n return this._dateTime.toEpochSecond(this._offset);\n };\n\n _proto.isSupported = function isSupported(fieldOrUnit) {\n if (fieldOrUnit instanceof ChronoField) {\n return fieldOrUnit.isDateBased() || fieldOrUnit.isTimeBased();\n }\n\n if (fieldOrUnit instanceof ChronoUnit) {\n return fieldOrUnit.isDateBased() || fieldOrUnit.isTimeBased();\n }\n\n return fieldOrUnit != null && fieldOrUnit.isSupportedBy(this);\n };\n\n _proto.range = function range(field) {\n if (field instanceof ChronoField) {\n if (field === ChronoField.INSTANT_SECONDS || field === ChronoField.OFFSET_SECONDS) {\n return field.range();\n }\n\n return this._dateTime.range(field);\n }\n\n return field.rangeRefinedBy(this);\n };\n\n _proto.withAdjuster = function withAdjuster(adjuster) {\n requireNonNull(adjuster);\n\n if (adjuster instanceof LocalDate || adjuster instanceof LocalTime || adjuster instanceof LocalDateTime) {\n return this._withDateTimeOffset(this._dateTime.with(adjuster), this._offset);\n } else if (adjuster instanceof Instant) {\n return OffsetDateTime.ofInstant(adjuster, this._offset);\n } else if (adjuster instanceof ZoneOffset) {\n return this._withDateTimeOffset(this._dateTime, adjuster);\n } else if (adjuster instanceof OffsetDateTime) {\n return adjuster;\n }\n\n return adjuster.adjustInto(this);\n };\n\n _proto.withFieldValue = function withFieldValue(field, newValue) {\n requireNonNull(field);\n\n if (field instanceof ChronoField) {\n var f = field;\n\n switch (f) {\n case ChronoField.INSTANT_SECONDS:\n return OffsetDateTime.ofInstant(Instant.ofEpochSecond(newValue, this.nano()), this._offset);\n\n case ChronoField.OFFSET_SECONDS:\n {\n return this._withDateTimeOffset(this._dateTime, ZoneOffset.ofTotalSeconds(f.checkValidIntValue(newValue)));\n }\n }\n\n return this._withDateTimeOffset(this._dateTime.with(field, newValue), this._offset);\n }\n\n return field.adjustInto(this, newValue);\n };\n\n _proto._withDateTimeOffset = function _withDateTimeOffset(dateTime, offset) {\n if (this._dateTime === dateTime && this._offset.equals(offset)) {\n return this;\n }\n\n return new OffsetDateTime(dateTime, offset);\n };\n\n _proto.withYear = function withYear(year) {\n return this._withDateTimeOffset(this._dateTime.withYear(year), this._offset);\n };\n\n _proto.withMonth = function withMonth(month) {\n return this._withDateTimeOffset(this._dateTime.withMonth(month), this._offset);\n };\n\n _proto.withDayOfMonth = function withDayOfMonth(dayOfMonth) {\n return this._withDateTimeOffset(this._dateTime.withDayOfMonth(dayOfMonth), this._offset);\n };\n\n _proto.withDayOfYear = function withDayOfYear(dayOfYear) {\n return this._withDateTimeOffset(this._dateTime.withDayOfYear(dayOfYear), this._offset);\n };\n\n _proto.withHour = function withHour(hour) {\n return this._withDateTimeOffset(this._dateTime.withHour(hour), this._offset);\n };\n\n _proto.withMinute = function withMinute(minute) {\n return this._withDateTimeOffset(this._dateTime.withMinute(minute), this._offset);\n };\n\n _proto.withSecond = function withSecond(second) {\n return this._withDateTimeOffset(this._dateTime.withSecond(second), this._offset);\n };\n\n _proto.withNano = function withNano(nanoOfSecond) {\n return this._withDateTimeOffset(this._dateTime.withNano(nanoOfSecond), this._offset);\n };\n\n _proto.withOffsetSameLocal = function withOffsetSameLocal(offset) {\n requireNonNull(offset, 'offset');\n return this._withDateTimeOffset(this._dateTime, offset);\n };\n\n _proto.withOffsetSameInstant = function withOffsetSameInstant(offset) {\n requireNonNull(offset, 'offset');\n\n if (offset.equals(this._offset)) {\n return this;\n }\n\n var difference = offset.totalSeconds() - this._offset.totalSeconds();\n\n var adjusted = this._dateTime.plusSeconds(difference);\n\n return new OffsetDateTime(adjusted, offset);\n };\n\n _proto.truncatedTo = function truncatedTo(unit) {\n return this._withDateTimeOffset(this._dateTime.truncatedTo(unit), this._offset);\n };\n\n _proto.plusAmount = function plusAmount(amount) {\n requireNonNull(amount, 'amount');\n return amount.addTo(this);\n };\n\n _proto.plusAmountUnit = function plusAmountUnit(amountToAdd, unit) {\n if (unit instanceof ChronoUnit) {\n return this._withDateTimeOffset(this._dateTime.plus(amountToAdd, unit), this._offset);\n }\n\n return unit.addTo(this, amountToAdd);\n };\n\n _proto.plusYears = function plusYears(years) {\n return this._withDateTimeOffset(this._dateTime.plusYears(years), this._offset);\n };\n\n _proto.plusMonths = function plusMonths(months) {\n return this._withDateTimeOffset(this._dateTime.plusMonths(months), this._offset);\n };\n\n _proto.plusWeeks = function plusWeeks(weeks) {\n return this._withDateTimeOffset(this._dateTime.plusWeeks(weeks), this._offset);\n };\n\n _proto.plusDays = function plusDays(days) {\n return this._withDateTimeOffset(this._dateTime.plusDays(days), this._offset);\n };\n\n _proto.plusHours = function plusHours(hours) {\n return this._withDateTimeOffset(this._dateTime.plusHours(hours), this._offset);\n };\n\n _proto.plusMinutes = function plusMinutes(minutes) {\n return this._withDateTimeOffset(this._dateTime.plusMinutes(minutes), this._offset);\n };\n\n _proto.plusSeconds = function plusSeconds(seconds) {\n return this._withDateTimeOffset(this._dateTime.plusSeconds(seconds), this._offset);\n };\n\n _proto.plusNanos = function plusNanos(nanos) {\n return this._withDateTimeOffset(this._dateTime.plusNanos(nanos), this._offset);\n };\n\n _proto.minusAmount = function minusAmount(amount) {\n requireNonNull(amount);\n return amount.subtractFrom(this);\n };\n\n _proto.minusAmountUnit = function minusAmountUnit(amountToSubtract, unit) {\n return this.plus(-1 * amountToSubtract, unit);\n };\n\n _proto.minusYears = function minusYears(years) {\n return this._withDateTimeOffset(this._dateTime.minusYears(years), this._offset);\n };\n\n _proto.minusMonths = function minusMonths(months) {\n return this._withDateTimeOffset(this._dateTime.minusMonths(months), this._offset);\n };\n\n _proto.minusWeeks = function minusWeeks(weeks) {\n return this._withDateTimeOffset(this._dateTime.minusWeeks(weeks), this._offset);\n };\n\n _proto.minusDays = function minusDays(days) {\n return this._withDateTimeOffset(this._dateTime.minusDays(days), this._offset);\n };\n\n _proto.minusHours = function minusHours(hours) {\n return this._withDateTimeOffset(this._dateTime.minusHours(hours), this._offset);\n };\n\n _proto.minusMinutes = function minusMinutes(minutes) {\n return this._withDateTimeOffset(this._dateTime.minusMinutes(minutes), this._offset);\n };\n\n _proto.minusSeconds = function minusSeconds(seconds) {\n return this._withDateTimeOffset(this._dateTime.minusSeconds(seconds), this._offset);\n };\n\n _proto.minusNanos = function minusNanos(nanos) {\n return this._withDateTimeOffset(this._dateTime.minusNanos(nanos), this._offset);\n };\n\n _proto.compareTo = function compareTo(other) {\n requireNonNull(other, 'other');\n requireInstance(other, OffsetDateTime, 'other');\n\n if (this.offset().equals(other.offset())) {\n return this.toLocalDateTime().compareTo(other.toLocalDateTime());\n }\n\n var cmp = MathUtil.compareNumbers(this.toEpochSecond(), other.toEpochSecond());\n\n if (cmp === 0) {\n cmp = this.toLocalTime().nano() - other.toLocalTime().nano();\n\n if (cmp === 0) {\n cmp = this.toLocalDateTime().compareTo(other.toLocalDateTime());\n }\n }\n\n return cmp;\n };\n\n _proto.isAfter = function isAfter(other) {\n requireNonNull(other, 'other');\n var thisEpochSec = this.toEpochSecond();\n var otherEpochSec = other.toEpochSecond();\n return thisEpochSec > otherEpochSec || thisEpochSec === otherEpochSec && this.toLocalTime().nano() > other.toLocalTime().nano();\n };\n\n _proto.isBefore = function isBefore(other) {\n requireNonNull(other, 'other');\n var thisEpochSec = this.toEpochSecond();\n var otherEpochSec = other.toEpochSecond();\n return thisEpochSec < otherEpochSec || thisEpochSec === otherEpochSec && this.toLocalTime().nano() < other.toLocalTime().nano();\n };\n\n _proto.isEqual = function isEqual(other) {\n requireNonNull(other, 'other');\n return this.toEpochSecond() === other.toEpochSecond() && this.toLocalTime().nano() === other.toLocalTime().nano();\n };\n\n _proto.equals = function equals(other) {\n if (this === other) {\n return true;\n }\n\n if (other instanceof OffsetDateTime) {\n return this._dateTime.equals(other._dateTime) && this._offset.equals(other._offset);\n }\n\n return false;\n };\n\n _proto.hashCode = function hashCode() {\n return this._dateTime.hashCode() ^ this._offset.hashCode();\n };\n\n _proto.toString = function toString() {\n return this._dateTime.toString() + this._offset.toString();\n };\n\n _proto.toJSON = function toJSON() {\n return this.toString();\n };\n\n _proto.format = function format(formatter) {\n requireNonNull(formatter, 'formatter');\n return formatter.format(this);\n };\n\n return OffsetDateTime;\n}(DefaultInterfaceTemporal);\nfunction _init$h() {\n OffsetDateTime.MIN = LocalDateTime.MIN.atOffset(ZoneOffset.MAX);\n OffsetDateTime.MAX = LocalDateTime.MAX.atOffset(ZoneOffset.MIN);\n OffsetDateTime.FROM = createTemporalQuery('OffsetDateTime.FROM', function (temporal) {\n return OffsetDateTime.from(temporal);\n });\n}\n\nvar DAYS_PER_CYCLE = 146097;\nvar DAYS_0000_TO_1970 = DAYS_PER_CYCLE * 5 - (30 * 365 + 7);\nvar LocalDate = function (_ChronoLocalDate) {\n _inheritsLoose(LocalDate, _ChronoLocalDate);\n\n LocalDate.now = function now(clockOrZone) {\n var clock;\n\n if (clockOrZone == null) {\n clock = Clock.systemDefaultZone();\n } else if (clockOrZone instanceof ZoneId) {\n clock = Clock.system(clockOrZone);\n } else {\n clock = clockOrZone;\n }\n\n return LocalDate.ofInstant(clock.instant(), clock.zone());\n };\n\n LocalDate.ofInstant = function ofInstant(instant, zone) {\n if (zone === void 0) {\n zone = ZoneId.systemDefault();\n }\n\n requireNonNull(instant, 'instant');\n var offset = zone.rules().offset(instant);\n var epochSec = instant.epochSecond() + offset.totalSeconds();\n var epochDay = MathUtil.floorDiv(epochSec, LocalTime.SECONDS_PER_DAY);\n return LocalDate.ofEpochDay(epochDay);\n };\n\n LocalDate.of = function of(year, month, dayOfMonth) {\n return new LocalDate(year, month, dayOfMonth);\n };\n\n LocalDate.ofYearDay = function ofYearDay(year, dayOfYear) {\n ChronoField.YEAR.checkValidValue(year);\n var leap = IsoChronology.isLeapYear(year);\n\n if (dayOfYear === 366 && leap === false) {\n assert(false, 'Invalid date \\'DayOfYear 366\\' as \\'' + year + '\\' is not a leap year', DateTimeException);\n }\n\n var moy = Month.of(Math.floor((dayOfYear - 1) / 31 + 1));\n var monthEnd = moy.firstDayOfYear(leap) + moy.length(leap) - 1;\n\n if (dayOfYear > monthEnd) {\n moy = moy.plus(1);\n }\n\n var dom = dayOfYear - moy.firstDayOfYear(leap) + 1;\n return new LocalDate(year, moy.value(), dom);\n };\n\n LocalDate.ofEpochDay = function ofEpochDay(epochDay) {\n if (epochDay === void 0) {\n epochDay = 0;\n }\n\n var adjust, adjustCycles, doyEst, yearEst, zeroDay;\n zeroDay = epochDay + DAYS_0000_TO_1970;\n zeroDay -= 60;\n adjust = 0;\n\n if (zeroDay < 0) {\n adjustCycles = MathUtil.intDiv(zeroDay + 1, DAYS_PER_CYCLE) - 1;\n adjust = adjustCycles * 400;\n zeroDay += -adjustCycles * DAYS_PER_CYCLE;\n }\n\n yearEst = MathUtil.intDiv(400 * zeroDay + 591, DAYS_PER_CYCLE);\n doyEst = zeroDay - (365 * yearEst + MathUtil.intDiv(yearEst, 4) - MathUtil.intDiv(yearEst, 100) + MathUtil.intDiv(yearEst, 400));\n\n if (doyEst < 0) {\n yearEst--;\n doyEst = zeroDay - (365 * yearEst + MathUtil.intDiv(yearEst, 4) - MathUtil.intDiv(yearEst, 100) + MathUtil.intDiv(yearEst, 400));\n }\n\n yearEst += adjust;\n var marchDoy0 = doyEst;\n var marchMonth0 = MathUtil.intDiv(marchDoy0 * 5 + 2, 153);\n var month = (marchMonth0 + 2) % 12 + 1;\n var dom = marchDoy0 - MathUtil.intDiv(marchMonth0 * 306 + 5, 10) + 1;\n yearEst += MathUtil.intDiv(marchMonth0, 10);\n var year = yearEst;\n return new LocalDate(year, month, dom);\n };\n\n LocalDate.from = function from(temporal) {\n requireNonNull(temporal, 'temporal');\n var date = temporal.query(TemporalQueries.localDate());\n\n if (date == null) {\n throw new DateTimeException(\"Unable to obtain LocalDate from TemporalAccessor: \" + temporal + \", type \" + (temporal.constructor != null ? temporal.constructor.name : ''));\n }\n\n return date;\n };\n\n LocalDate.parse = function parse(text, formatter) {\n if (formatter === void 0) {\n formatter = DateTimeFormatter.ISO_LOCAL_DATE;\n }\n\n assert(formatter != null, 'formatter', NullPointerException);\n return formatter.parse(text, LocalDate.FROM);\n };\n\n LocalDate._resolvePreviousValid = function _resolvePreviousValid(year, month, day) {\n switch (month) {\n case 2:\n day = Math.min(day, IsoChronology.isLeapYear(year) ? 29 : 28);\n break;\n\n case 4:\n case 6:\n case 9:\n case 11:\n day = Math.min(day, 30);\n break;\n }\n\n return LocalDate.of(year, month, day);\n };\n\n function LocalDate(year, month, dayOfMonth) {\n var _this;\n\n _this = _ChronoLocalDate.call(this) || this;\n requireNonNull(year, 'year');\n requireNonNull(month, 'month');\n requireNonNull(dayOfMonth, 'dayOfMonth');\n\n if (month instanceof Month) {\n month = month.value();\n }\n\n _this._year = MathUtil.safeToInt(year);\n _this._month = MathUtil.safeToInt(month);\n _this._day = MathUtil.safeToInt(dayOfMonth);\n\n LocalDate._validate(_this._year, _this._month, _this._day);\n\n return _this;\n }\n\n LocalDate._validate = function _validate(year, month, dayOfMonth) {\n var dom;\n ChronoField.YEAR.checkValidValue(year);\n ChronoField.MONTH_OF_YEAR.checkValidValue(month);\n ChronoField.DAY_OF_MONTH.checkValidValue(dayOfMonth);\n\n if (dayOfMonth > 28) {\n dom = 31;\n\n switch (month) {\n case 2:\n dom = IsoChronology.isLeapYear(year) ? 29 : 28;\n break;\n\n case 4:\n case 6:\n case 9:\n case 11:\n dom = 30;\n }\n\n if (dayOfMonth > dom) {\n if (dayOfMonth === 29) {\n assert(false, 'Invalid date \\'February 29\\' as \\'' + year + '\\' is not a leap year', DateTimeException);\n } else {\n assert(false, 'Invalid date \\'' + year + '\\' \\'' + month + '\\' \\'' + dayOfMonth + '\\'', DateTimeException);\n }\n }\n }\n };\n\n var _proto = LocalDate.prototype;\n\n _proto.isSupported = function isSupported(field) {\n return _ChronoLocalDate.prototype.isSupported.call(this, field);\n };\n\n _proto.range = function range(field) {\n if (field instanceof ChronoField) {\n if (field.isDateBased()) {\n switch (field) {\n case ChronoField.DAY_OF_MONTH:\n return ValueRange.of(1, this.lengthOfMonth());\n\n case ChronoField.DAY_OF_YEAR:\n return ValueRange.of(1, this.lengthOfYear());\n\n case ChronoField.ALIGNED_WEEK_OF_MONTH:\n return ValueRange.of(1, this.month() === Month.FEBRUARY && this.isLeapYear() === false ? 4 : 5);\n\n case ChronoField.YEAR_OF_ERA:\n return this._year <= 0 ? ValueRange.of(1, Year.MAX_VALUE + 1) : ValueRange.of(1, Year.MAX_VALUE);\n }\n\n return field.range();\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported field: ' + field);\n }\n\n return field.rangeRefinedBy(this);\n };\n\n _proto.get = function get(field) {\n return this.getLong(field);\n };\n\n _proto.getLong = function getLong(field) {\n assert(field != null, '', NullPointerException);\n\n if (field instanceof ChronoField) {\n return this._get0(field);\n }\n\n return field.getFrom(this);\n };\n\n _proto._get0 = function _get0(field) {\n switch (field) {\n case ChronoField.DAY_OF_WEEK:\n return this.dayOfWeek().value();\n\n case ChronoField.ALIGNED_DAY_OF_WEEK_IN_MONTH:\n return MathUtil.intMod(this._day - 1, 7) + 1;\n\n case ChronoField.ALIGNED_DAY_OF_WEEK_IN_YEAR:\n return MathUtil.intMod(this.dayOfYear() - 1, 7) + 1;\n\n case ChronoField.DAY_OF_MONTH:\n return this._day;\n\n case ChronoField.DAY_OF_YEAR:\n return this.dayOfYear();\n\n case ChronoField.EPOCH_DAY:\n return this.toEpochDay();\n\n case ChronoField.ALIGNED_WEEK_OF_MONTH:\n return MathUtil.intDiv(this._day - 1, 7) + 1;\n\n case ChronoField.ALIGNED_WEEK_OF_YEAR:\n return MathUtil.intDiv(this.dayOfYear() - 1, 7) + 1;\n\n case ChronoField.MONTH_OF_YEAR:\n return this._month;\n\n case ChronoField.PROLEPTIC_MONTH:\n return this._prolepticMonth();\n\n case ChronoField.YEAR_OF_ERA:\n return this._year >= 1 ? this._year : 1 - this._year;\n\n case ChronoField.YEAR:\n return this._year;\n\n case ChronoField.ERA:\n return this._year >= 1 ? 1 : 0;\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported field: ' + field);\n };\n\n _proto._prolepticMonth = function _prolepticMonth() {\n return this._year * 12 + (this._month - 1);\n };\n\n _proto.chronology = function chronology() {\n return IsoChronology.INSTANCE;\n };\n\n _proto.year = function year() {\n return this._year;\n };\n\n _proto.monthValue = function monthValue() {\n return this._month;\n };\n\n _proto.month = function month() {\n return Month.of(this._month);\n };\n\n _proto.dayOfMonth = function dayOfMonth() {\n return this._day;\n };\n\n _proto.dayOfYear = function dayOfYear() {\n return this.month().firstDayOfYear(this.isLeapYear()) + this._day - 1;\n };\n\n _proto.dayOfWeek = function dayOfWeek() {\n var dow0 = MathUtil.floorMod(this.toEpochDay() + 3, 7);\n return DayOfWeek.of(dow0 + 1);\n };\n\n _proto.isLeapYear = function isLeapYear() {\n return IsoChronology.isLeapYear(this._year);\n };\n\n _proto.lengthOfMonth = function lengthOfMonth() {\n switch (this._month) {\n case 2:\n return this.isLeapYear() ? 29 : 28;\n\n case 4:\n case 6:\n case 9:\n case 11:\n return 30;\n\n default:\n return 31;\n }\n };\n\n _proto.lengthOfYear = function lengthOfYear() {\n return this.isLeapYear() ? 366 : 365;\n };\n\n _proto.withAdjuster = function withAdjuster(adjuster) {\n requireNonNull(adjuster, 'adjuster');\n\n if (adjuster instanceof LocalDate) {\n return adjuster;\n }\n\n assert(typeof adjuster.adjustInto === 'function', 'adjuster', IllegalArgumentException);\n return adjuster.adjustInto(this);\n };\n\n _proto.withFieldValue = function withFieldValue(field, newValue) {\n assert(field != null, 'field', NullPointerException);\n\n if (field instanceof ChronoField) {\n var f = field;\n f.checkValidValue(newValue);\n\n switch (f) {\n case ChronoField.DAY_OF_WEEK:\n return this.plusDays(newValue - this.dayOfWeek().value());\n\n case ChronoField.ALIGNED_DAY_OF_WEEK_IN_MONTH:\n return this.plusDays(newValue - this.getLong(ChronoField.ALIGNED_DAY_OF_WEEK_IN_MONTH));\n\n case ChronoField.ALIGNED_DAY_OF_WEEK_IN_YEAR:\n return this.plusDays(newValue - this.getLong(ChronoField.ALIGNED_DAY_OF_WEEK_IN_YEAR));\n\n case ChronoField.DAY_OF_MONTH:\n return this.withDayOfMonth(newValue);\n\n case ChronoField.DAY_OF_YEAR:\n return this.withDayOfYear(newValue);\n\n case ChronoField.EPOCH_DAY:\n return LocalDate.ofEpochDay(newValue);\n\n case ChronoField.ALIGNED_WEEK_OF_MONTH:\n return this.plusWeeks(newValue - this.getLong(ChronoField.ALIGNED_WEEK_OF_MONTH));\n\n case ChronoField.ALIGNED_WEEK_OF_YEAR:\n return this.plusWeeks(newValue - this.getLong(ChronoField.ALIGNED_WEEK_OF_YEAR));\n\n case ChronoField.MONTH_OF_YEAR:\n return this.withMonth(newValue);\n\n case ChronoField.PROLEPTIC_MONTH:\n return this.plusMonths(newValue - this.getLong(ChronoField.PROLEPTIC_MONTH));\n\n case ChronoField.YEAR_OF_ERA:\n return this.withYear(this._year >= 1 ? newValue : 1 - newValue);\n\n case ChronoField.YEAR:\n return this.withYear(newValue);\n\n case ChronoField.ERA:\n return this.getLong(ChronoField.ERA) === newValue ? this : this.withYear(1 - this._year);\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported field: ' + field);\n }\n\n return field.adjustInto(this, newValue);\n };\n\n _proto.withYear = function withYear(year) {\n if (this._year === year) {\n return this;\n }\n\n ChronoField.YEAR.checkValidValue(year);\n return LocalDate._resolvePreviousValid(year, this._month, this._day);\n };\n\n _proto.withMonth = function withMonth(month) {\n var m = month instanceof Month ? month.value() : month;\n\n if (this._month === m) {\n return this;\n }\n\n ChronoField.MONTH_OF_YEAR.checkValidValue(m);\n return LocalDate._resolvePreviousValid(this._year, m, this._day);\n };\n\n _proto.withDayOfMonth = function withDayOfMonth(dayOfMonth) {\n if (this._day === dayOfMonth) {\n return this;\n }\n\n return LocalDate.of(this._year, this._month, dayOfMonth);\n };\n\n _proto.withDayOfYear = function withDayOfYear(dayOfYear) {\n if (this.dayOfYear() === dayOfYear) {\n return this;\n }\n\n return LocalDate.ofYearDay(this._year, dayOfYear);\n };\n\n _proto.plusAmount = function plusAmount(amount) {\n requireNonNull(amount, 'amount');\n return amount.addTo(this);\n };\n\n _proto.plusAmountUnit = function plusAmountUnit(amountToAdd, unit) {\n requireNonNull(amountToAdd, 'amountToAdd');\n requireNonNull(unit, 'unit');\n\n if (unit instanceof ChronoUnit) {\n switch (unit) {\n case ChronoUnit.DAYS:\n return this.plusDays(amountToAdd);\n\n case ChronoUnit.WEEKS:\n return this.plusWeeks(amountToAdd);\n\n case ChronoUnit.MONTHS:\n return this.plusMonths(amountToAdd);\n\n case ChronoUnit.YEARS:\n return this.plusYears(amountToAdd);\n\n case ChronoUnit.DECADES:\n return this.plusYears(MathUtil.safeMultiply(amountToAdd, 10));\n\n case ChronoUnit.CENTURIES:\n return this.plusYears(MathUtil.safeMultiply(amountToAdd, 100));\n\n case ChronoUnit.MILLENNIA:\n return this.plusYears(MathUtil.safeMultiply(amountToAdd, 1000));\n\n case ChronoUnit.ERAS:\n return this.with(ChronoField.ERA, MathUtil.safeAdd(this.getLong(ChronoField.ERA), amountToAdd));\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported unit: ' + unit);\n }\n\n return unit.addTo(this, amountToAdd);\n };\n\n _proto.plusYears = function plusYears(yearsToAdd) {\n if (yearsToAdd === 0) {\n return this;\n }\n\n var newYear = ChronoField.YEAR.checkValidIntValue(this._year + yearsToAdd);\n return LocalDate._resolvePreviousValid(newYear, this._month, this._day);\n };\n\n _proto.plusMonths = function plusMonths(monthsToAdd) {\n if (monthsToAdd === 0) {\n return this;\n }\n\n var monthCount = this._year * 12 + (this._month - 1);\n var calcMonths = monthCount + monthsToAdd;\n var newYear = ChronoField.YEAR.checkValidIntValue(MathUtil.floorDiv(calcMonths, 12));\n var newMonth = MathUtil.floorMod(calcMonths, 12) + 1;\n return LocalDate._resolvePreviousValid(newYear, newMonth, this._day);\n };\n\n _proto.plusWeeks = function plusWeeks(weeksToAdd) {\n return this.plusDays(MathUtil.safeMultiply(weeksToAdd, 7));\n };\n\n _proto.plusDays = function plusDays(daysToAdd) {\n if (daysToAdd === 0) {\n return this;\n }\n\n var mjDay = MathUtil.safeAdd(this.toEpochDay(), daysToAdd);\n return LocalDate.ofEpochDay(mjDay);\n };\n\n _proto.minusAmount = function minusAmount(amount) {\n requireNonNull(amount, 'amount');\n return amount.subtractFrom(this);\n };\n\n _proto.minusAmountUnit = function minusAmountUnit(amountToSubtract, unit) {\n requireNonNull(amountToSubtract, 'amountToSubtract');\n requireNonNull(unit, 'unit');\n return this.plusAmountUnit(-1 * amountToSubtract, unit);\n };\n\n _proto.minusYears = function minusYears(yearsToSubtract) {\n return this.plusYears(yearsToSubtract * -1);\n };\n\n _proto.minusMonths = function minusMonths(monthsToSubtract) {\n return this.plusMonths(monthsToSubtract * -1);\n };\n\n _proto.minusWeeks = function minusWeeks(weeksToSubtract) {\n return this.plusWeeks(weeksToSubtract * -1);\n };\n\n _proto.minusDays = function minusDays(daysToSubtract) {\n return this.plusDays(daysToSubtract * -1);\n };\n\n _proto.query = function query(_query) {\n requireNonNull(_query, 'query');\n\n if (_query === TemporalQueries.localDate()) {\n return this;\n }\n\n return _ChronoLocalDate.prototype.query.call(this, _query);\n };\n\n _proto.adjustInto = function adjustInto(temporal) {\n return _ChronoLocalDate.prototype.adjustInto.call(this, temporal);\n };\n\n _proto.until = function until(p1, p2) {\n if (arguments.length < 2) {\n return this.until1(p1);\n } else {\n return this.until2(p1, p2);\n }\n };\n\n _proto.until2 = function until2(endExclusive, unit) {\n var end = LocalDate.from(endExclusive);\n\n if (unit instanceof ChronoUnit) {\n switch (unit) {\n case ChronoUnit.DAYS:\n return this.daysUntil(end);\n\n case ChronoUnit.WEEKS:\n return MathUtil.intDiv(this.daysUntil(end), 7);\n\n case ChronoUnit.MONTHS:\n return this._monthsUntil(end);\n\n case ChronoUnit.YEARS:\n return MathUtil.intDiv(this._monthsUntil(end), 12);\n\n case ChronoUnit.DECADES:\n return MathUtil.intDiv(this._monthsUntil(end), 120);\n\n case ChronoUnit.CENTURIES:\n return MathUtil.intDiv(this._monthsUntil(end), 1200);\n\n case ChronoUnit.MILLENNIA:\n return MathUtil.intDiv(this._monthsUntil(end), 12000);\n\n case ChronoUnit.ERAS:\n return end.getLong(ChronoField.ERA) - this.getLong(ChronoField.ERA);\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported unit: ' + unit);\n }\n\n return unit.between(this, end);\n };\n\n _proto.daysUntil = function daysUntil(end) {\n return end.toEpochDay() - this.toEpochDay();\n };\n\n _proto._monthsUntil = function _monthsUntil(end) {\n var packed1 = this._prolepticMonth() * 32 + this.dayOfMonth();\n var packed2 = end._prolepticMonth() * 32 + end.dayOfMonth();\n return MathUtil.intDiv(packed2 - packed1, 32);\n };\n\n _proto.until1 = function until1(endDate) {\n var end = LocalDate.from(endDate);\n\n var totalMonths = end._prolepticMonth() - this._prolepticMonth();\n\n var days = end._day - this._day;\n\n if (totalMonths > 0 && days < 0) {\n totalMonths--;\n var calcDate = this.plusMonths(totalMonths);\n days = end.toEpochDay() - calcDate.toEpochDay();\n } else if (totalMonths < 0 && days > 0) {\n totalMonths++;\n days -= end.lengthOfMonth();\n }\n\n var years = MathUtil.intDiv(totalMonths, 12);\n var months = MathUtil.intMod(totalMonths, 12);\n return Period.of(years, months, days);\n };\n\n _proto.atTime = function atTime() {\n if (arguments.length === 1) {\n return this.atTime1.apply(this, arguments);\n } else {\n return this.atTime4.apply(this, arguments);\n }\n };\n\n _proto.atTime1 = function atTime1(time) {\n requireNonNull(time, 'time');\n\n if (time instanceof LocalTime) {\n return LocalDateTime.of(this, time);\n } else if (time instanceof OffsetTime) {\n return this._atTimeOffsetTime(time);\n } else {\n throw new IllegalArgumentException('time must be an instance of LocalTime or OffsetTime' + (time && time.constructor && time.constructor.name ? ', but is ' + time.constructor.name : ''));\n }\n };\n\n _proto.atTime4 = function atTime4(hour, minute, second, nanoOfSecond) {\n if (second === void 0) {\n second = 0;\n }\n\n if (nanoOfSecond === void 0) {\n nanoOfSecond = 0;\n }\n\n return this.atTime1(LocalTime.of(hour, minute, second, nanoOfSecond));\n };\n\n _proto._atTimeOffsetTime = function _atTimeOffsetTime(time) {\n return OffsetDateTime.of(LocalDateTime.of(this, time.toLocalTime()), time.offset());\n };\n\n _proto.atStartOfDay = function atStartOfDay(zone) {\n if (zone != null) {\n return this.atStartOfDayWithZone(zone);\n } else {\n return LocalDateTime.of(this, LocalTime.MIDNIGHT);\n }\n };\n\n _proto.atStartOfDayWithZone = function atStartOfDayWithZone(zone) {\n requireNonNull(zone, 'zone');\n var ldt = this.atTime(LocalTime.MIDNIGHT);\n\n if (zone instanceof ZoneOffset === false) {\n var trans = zone.rules().transition(ldt);\n\n if (trans != null && trans.isGap()) {\n ldt = trans.dateTimeAfter();\n }\n }\n\n return ZonedDateTime.of(ldt, zone);\n };\n\n _proto.toEpochDay = function toEpochDay() {\n var y = this._year;\n var m = this._month;\n var total = 0;\n total += 365 * y;\n\n if (y >= 0) {\n total += MathUtil.intDiv(y + 3, 4) - MathUtil.intDiv(y + 99, 100) + MathUtil.intDiv(y + 399, 400);\n } else {\n total -= MathUtil.intDiv(y, -4) - MathUtil.intDiv(y, -100) + MathUtil.intDiv(y, -400);\n }\n\n total += MathUtil.intDiv(367 * m - 362, 12);\n total += this.dayOfMonth() - 1;\n\n if (m > 2) {\n total--;\n\n if (!IsoChronology.isLeapYear(y)) {\n total--;\n }\n }\n\n return total - DAYS_0000_TO_1970;\n };\n\n _proto.compareTo = function compareTo(other) {\n requireNonNull(other, 'other');\n requireInstance(other, LocalDate, 'other');\n return this._compareTo0(other);\n };\n\n _proto._compareTo0 = function _compareTo0(otherDate) {\n var cmp = this._year - otherDate._year;\n\n if (cmp === 0) {\n cmp = this._month - otherDate._month;\n\n if (cmp === 0) {\n cmp = this._day - otherDate._day;\n }\n }\n\n return cmp;\n };\n\n _proto.isAfter = function isAfter(other) {\n return this.compareTo(other) > 0;\n };\n\n _proto.isBefore = function isBefore(other) {\n return this.compareTo(other) < 0;\n };\n\n _proto.isEqual = function isEqual(other) {\n return this.compareTo(other) === 0;\n };\n\n _proto.equals = function equals(other) {\n if (this === other) {\n return true;\n }\n\n if (other instanceof LocalDate) {\n return this._compareTo0(other) === 0;\n }\n\n return false;\n };\n\n _proto.hashCode = function hashCode() {\n var yearValue = this._year;\n var monthValue = this._month;\n var dayValue = this._day;\n return MathUtil.hash(yearValue & 0xFFFFF800 ^ (yearValue << 11) + (monthValue << 6) + dayValue);\n };\n\n _proto.toString = function toString() {\n var dayString, monthString, yearString;\n var yearValue = this._year;\n var monthValue = this._month;\n var dayValue = this._day;\n var absYear = Math.abs(yearValue);\n\n if (absYear < 1000) {\n if (yearValue < 0) {\n yearString = '-' + ('' + (yearValue - 10000)).slice(-4);\n } else {\n yearString = ('' + (yearValue + 10000)).slice(-4);\n }\n } else {\n if (yearValue > 9999) {\n yearString = '+' + yearValue;\n } else {\n yearString = '' + yearValue;\n }\n }\n\n if (monthValue < 10) {\n monthString = '-0' + monthValue;\n } else {\n monthString = '-' + monthValue;\n }\n\n if (dayValue < 10) {\n dayString = '-0' + dayValue;\n } else {\n dayString = '-' + dayValue;\n }\n\n return yearString + monthString + dayString;\n };\n\n _proto.toJSON = function toJSON() {\n return this.toString();\n };\n\n _proto.format = function format(formatter) {\n requireNonNull(formatter, 'formatter');\n requireInstance(formatter, DateTimeFormatter, 'formatter');\n return _ChronoLocalDate.prototype.format.call(this, formatter);\n };\n\n return LocalDate;\n}(ChronoLocalDate);\nfunction _init$i() {\n LocalDate.MIN = LocalDate.of(YearConstants.MIN_VALUE, 1, 1);\n LocalDate.MAX = LocalDate.of(YearConstants.MAX_VALUE, 12, 31);\n LocalDate.EPOCH_0 = LocalDate.ofEpochDay(0);\n LocalDate.FROM = createTemporalQuery('LocalDate.FROM', function (temporal) {\n return LocalDate.from(temporal);\n });\n}\n\nvar ChronoLocalDateTime = function (_DefaultInterfaceTemp) {\n _inheritsLoose(ChronoLocalDateTime, _DefaultInterfaceTemp);\n\n function ChronoLocalDateTime() {\n return _DefaultInterfaceTemp.apply(this, arguments) || this;\n }\n\n var _proto = ChronoLocalDateTime.prototype;\n\n _proto.chronology = function chronology() {\n return this.toLocalDate().chronology();\n };\n\n _proto.query = function query(_query) {\n if (_query === TemporalQueries.chronology()) {\n return this.chronology();\n } else if (_query === TemporalQueries.precision()) {\n return ChronoUnit.NANOS;\n } else if (_query === TemporalQueries.localDate()) {\n return LocalDate.ofEpochDay(this.toLocalDate().toEpochDay());\n } else if (_query === TemporalQueries.localTime()) {\n return this.toLocalTime();\n } else if (_query === TemporalQueries.zone() || _query === TemporalQueries.zoneId() || _query === TemporalQueries.offset()) {\n return null;\n }\n\n return _DefaultInterfaceTemp.prototype.query.call(this, _query);\n };\n\n _proto.adjustInto = function adjustInto(temporal) {\n return temporal.with(ChronoField.EPOCH_DAY, this.toLocalDate().toEpochDay()).with(ChronoField.NANO_OF_DAY, this.toLocalTime().toNanoOfDay());\n };\n\n _proto.toInstant = function toInstant(offset) {\n requireInstance(offset, ZoneOffset, 'zoneId');\n return Instant.ofEpochSecond(this.toEpochSecond(offset), this.toLocalTime().nano());\n };\n\n _proto.toEpochSecond = function toEpochSecond(offset) {\n requireNonNull(offset, 'offset');\n var epochDay = this.toLocalDate().toEpochDay();\n var secs = epochDay * 86400 + this.toLocalTime().toSecondOfDay();\n secs -= offset.totalSeconds();\n return MathUtil.safeToInt(secs);\n };\n\n return ChronoLocalDateTime;\n}(DefaultInterfaceTemporal);\n\nvar LocalDateTime = function (_ChronoLocalDateTime) {\n _inheritsLoose(LocalDateTime, _ChronoLocalDateTime);\n\n LocalDateTime.now = function now(clockOrZone) {\n if (clockOrZone == null) {\n return LocalDateTime._now(Clock.systemDefaultZone());\n } else if (clockOrZone instanceof Clock) {\n return LocalDateTime._now(clockOrZone);\n } else {\n return LocalDateTime._now(Clock.system(clockOrZone));\n }\n };\n\n LocalDateTime._now = function _now(clock) {\n requireNonNull(clock, 'clock');\n return LocalDateTime.ofInstant(clock.instant(), clock.zone());\n };\n\n LocalDateTime._ofEpochMillis = function _ofEpochMillis(epochMilli, offset) {\n var localSecond = MathUtil.floorDiv(epochMilli, 1000) + offset.totalSeconds();\n var localEpochDay = MathUtil.floorDiv(localSecond, LocalTime.SECONDS_PER_DAY);\n var secsOfDay = MathUtil.floorMod(localSecond, LocalTime.SECONDS_PER_DAY);\n var nanoOfSecond = MathUtil.floorMod(epochMilli, 1000) * 1000000;\n var date = LocalDate.ofEpochDay(localEpochDay);\n var time = LocalTime.ofSecondOfDay(secsOfDay, nanoOfSecond);\n return new LocalDateTime(date, time);\n };\n\n LocalDateTime.of = function of() {\n if (arguments.length <= 2) {\n return LocalDateTime.ofDateAndTime.apply(this, arguments);\n } else {\n return LocalDateTime.ofNumbers.apply(this, arguments);\n }\n };\n\n LocalDateTime.ofNumbers = function ofNumbers(year, month, dayOfMonth, hour, minute, second, nanoOfSecond) {\n if (hour === void 0) {\n hour = 0;\n }\n\n if (minute === void 0) {\n minute = 0;\n }\n\n if (second === void 0) {\n second = 0;\n }\n\n if (nanoOfSecond === void 0) {\n nanoOfSecond = 0;\n }\n\n var date = LocalDate.of(year, month, dayOfMonth);\n var time = LocalTime.of(hour, minute, second, nanoOfSecond);\n return new LocalDateTime(date, time);\n };\n\n LocalDateTime.ofDateAndTime = function ofDateAndTime(date, time) {\n requireNonNull(date, 'date');\n requireNonNull(time, 'time');\n return new LocalDateTime(date, time);\n };\n\n LocalDateTime.ofInstant = function ofInstant(instant, zone) {\n if (zone === void 0) {\n zone = ZoneId.systemDefault();\n }\n\n requireNonNull(instant, 'instant');\n requireInstance(instant, Instant, 'instant');\n requireNonNull(zone, 'zone');\n var offset = zone.rules().offset(instant);\n return LocalDateTime.ofEpochSecond(instant.epochSecond(), instant.nano(), offset);\n };\n\n LocalDateTime.ofEpochSecond = function ofEpochSecond(epochSecond, nanoOfSecond, offset) {\n if (epochSecond === void 0) {\n epochSecond = 0;\n }\n\n if (nanoOfSecond === void 0) {\n nanoOfSecond = 0;\n }\n\n if (arguments.length === 2 && nanoOfSecond instanceof ZoneOffset) {\n offset = nanoOfSecond;\n nanoOfSecond = 0;\n }\n\n requireNonNull(offset, 'offset');\n var localSecond = epochSecond + offset.totalSeconds();\n var localEpochDay = MathUtil.floorDiv(localSecond, LocalTime.SECONDS_PER_DAY);\n var secsOfDay = MathUtil.floorMod(localSecond, LocalTime.SECONDS_PER_DAY);\n var date = LocalDate.ofEpochDay(localEpochDay);\n var time = LocalTime.ofSecondOfDay(secsOfDay, nanoOfSecond);\n return new LocalDateTime(date, time);\n };\n\n LocalDateTime.from = function from(temporal) {\n requireNonNull(temporal, 'temporal');\n\n if (temporal instanceof LocalDateTime) {\n return temporal;\n } else if (temporal instanceof ZonedDateTime) {\n return temporal.toLocalDateTime();\n }\n\n try {\n var date = LocalDate.from(temporal);\n var time = LocalTime.from(temporal);\n return new LocalDateTime(date, time);\n } catch (ex) {\n throw new DateTimeException(\"Unable to obtain LocalDateTime TemporalAccessor: \" + temporal + \", type \" + (temporal.constructor != null ? temporal.constructor.name : ''));\n }\n };\n\n LocalDateTime.parse = function parse(text, formatter) {\n if (formatter === void 0) {\n formatter = DateTimeFormatter.ISO_LOCAL_DATE_TIME;\n }\n\n requireNonNull(formatter, 'formatter');\n return formatter.parse(text, LocalDateTime.FROM);\n };\n\n function LocalDateTime(date, time) {\n var _this;\n\n _this = _ChronoLocalDateTime.call(this) || this;\n requireInstance(date, LocalDate, 'date');\n requireInstance(time, LocalTime, 'time');\n _this._date = date;\n _this._time = time;\n return _this;\n }\n\n var _proto = LocalDateTime.prototype;\n\n _proto._withDateTime = function _withDateTime(newDate, newTime) {\n if (this._date.equals(newDate) && this._time.equals(newTime)) {\n return this;\n }\n\n return new LocalDateTime(newDate, newTime);\n };\n\n _proto.isSupported = function isSupported(fieldOrUnit) {\n if (fieldOrUnit instanceof ChronoField) {\n return fieldOrUnit.isDateBased() || fieldOrUnit.isTimeBased();\n } else if (fieldOrUnit instanceof ChronoUnit) {\n return fieldOrUnit.isDateBased() || fieldOrUnit.isTimeBased();\n }\n\n return fieldOrUnit != null && fieldOrUnit.isSupportedBy(this);\n };\n\n _proto.range = function range(field) {\n if (field instanceof ChronoField) {\n return field.isTimeBased() ? this._time.range(field) : this._date.range(field);\n }\n\n return field.rangeRefinedBy(this);\n };\n\n _proto.get = function get(field) {\n if (field instanceof ChronoField) {\n return field.isTimeBased() ? this._time.get(field) : this._date.get(field);\n }\n\n return _ChronoLocalDateTime.prototype.get.call(this, field);\n };\n\n _proto.getLong = function getLong(field) {\n requireNonNull(field, 'field');\n\n if (field instanceof ChronoField) {\n return field.isTimeBased() ? this._time.getLong(field) : this._date.getLong(field);\n }\n\n return field.getFrom(this);\n };\n\n _proto.year = function year() {\n return this._date.year();\n };\n\n _proto.monthValue = function monthValue() {\n return this._date.monthValue();\n };\n\n _proto.month = function month() {\n return this._date.month();\n };\n\n _proto.dayOfMonth = function dayOfMonth() {\n return this._date.dayOfMonth();\n };\n\n _proto.dayOfYear = function dayOfYear() {\n return this._date.dayOfYear();\n };\n\n _proto.dayOfWeek = function dayOfWeek() {\n return this._date.dayOfWeek();\n };\n\n _proto.hour = function hour() {\n return this._time.hour();\n };\n\n _proto.minute = function minute() {\n return this._time.minute();\n };\n\n _proto.second = function second() {\n return this._time.second();\n };\n\n _proto.nano = function nano() {\n return this._time.nano();\n };\n\n _proto.withAdjuster = function withAdjuster(adjuster) {\n requireNonNull(adjuster, 'adjuster');\n\n if (adjuster instanceof LocalDate) {\n return this._withDateTime(adjuster, this._time);\n } else if (adjuster instanceof LocalTime) {\n return this._withDateTime(this._date, adjuster);\n } else if (adjuster instanceof LocalDateTime) {\n return adjuster;\n }\n\n assert(typeof adjuster.adjustInto === 'function', 'adjuster', IllegalArgumentException);\n return adjuster.adjustInto(this);\n };\n\n _proto.withFieldValue = function withFieldValue(field, newValue) {\n requireNonNull(field, 'field');\n\n if (field instanceof ChronoField) {\n if (field.isTimeBased()) {\n return this._withDateTime(this._date, this._time.with(field, newValue));\n } else {\n return this._withDateTime(this._date.with(field, newValue), this._time);\n }\n }\n\n return field.adjustInto(this, newValue);\n };\n\n _proto.withYear = function withYear(year) {\n return this._withDateTime(this._date.withYear(year), this._time);\n };\n\n _proto.withMonth = function withMonth(month) {\n return this._withDateTime(this._date.withMonth(month), this._time);\n };\n\n _proto.withDayOfMonth = function withDayOfMonth(dayOfMonth) {\n return this._withDateTime(this._date.withDayOfMonth(dayOfMonth), this._time);\n };\n\n _proto.withDayOfYear = function withDayOfYear(dayOfYear) {\n return this._withDateTime(this._date.withDayOfYear(dayOfYear), this._time);\n };\n\n _proto.withHour = function withHour(hour) {\n var newTime = this._time.withHour(hour);\n\n return this._withDateTime(this._date, newTime);\n };\n\n _proto.withMinute = function withMinute(minute) {\n var newTime = this._time.withMinute(minute);\n\n return this._withDateTime(this._date, newTime);\n };\n\n _proto.withSecond = function withSecond(second) {\n var newTime = this._time.withSecond(second);\n\n return this._withDateTime(this._date, newTime);\n };\n\n _proto.withNano = function withNano(nanoOfSecond) {\n var newTime = this._time.withNano(nanoOfSecond);\n\n return this._withDateTime(this._date, newTime);\n };\n\n _proto.truncatedTo = function truncatedTo(unit) {\n return this._withDateTime(this._date, this._time.truncatedTo(unit));\n };\n\n _proto.plusAmount = function plusAmount(amount) {\n requireNonNull(amount, 'amount');\n return amount.addTo(this);\n };\n\n _proto.plusAmountUnit = function plusAmountUnit(amountToAdd, unit) {\n requireNonNull(unit, 'unit');\n\n if (unit instanceof ChronoUnit) {\n switch (unit) {\n case ChronoUnit.NANOS:\n return this.plusNanos(amountToAdd);\n\n case ChronoUnit.MICROS:\n return this.plusDays(MathUtil.intDiv(amountToAdd, LocalTime.MICROS_PER_DAY)).plusNanos(MathUtil.intMod(amountToAdd, LocalTime.MICROS_PER_DAY) * 1000);\n\n case ChronoUnit.MILLIS:\n return this.plusDays(MathUtil.intDiv(amountToAdd, LocalTime.MILLIS_PER_DAY)).plusNanos(MathUtil.intMod(amountToAdd, LocalTime.MILLIS_PER_DAY) * 1000000);\n\n case ChronoUnit.SECONDS:\n return this.plusSeconds(amountToAdd);\n\n case ChronoUnit.MINUTES:\n return this.plusMinutes(amountToAdd);\n\n case ChronoUnit.HOURS:\n return this.plusHours(amountToAdd);\n\n case ChronoUnit.HALF_DAYS:\n return this.plusDays(MathUtil.intDiv(amountToAdd, 256)).plusHours(MathUtil.intMod(amountToAdd, 256) * 12);\n }\n\n return this._withDateTime(this._date.plus(amountToAdd, unit), this._time);\n }\n\n return unit.addTo(this, amountToAdd);\n };\n\n _proto.plusYears = function plusYears(years) {\n var newDate = this._date.plusYears(years);\n\n return this._withDateTime(newDate, this._time);\n };\n\n _proto.plusMonths = function plusMonths(months) {\n var newDate = this._date.plusMonths(months);\n\n return this._withDateTime(newDate, this._time);\n };\n\n _proto.plusWeeks = function plusWeeks(weeks) {\n var newDate = this._date.plusWeeks(weeks);\n\n return this._withDateTime(newDate, this._time);\n };\n\n _proto.plusDays = function plusDays(days) {\n var newDate = this._date.plusDays(days);\n\n return this._withDateTime(newDate, this._time);\n };\n\n _proto.plusHours = function plusHours(hours) {\n return this._plusWithOverflow(this._date, hours, 0, 0, 0, 1);\n };\n\n _proto.plusMinutes = function plusMinutes(minutes) {\n return this._plusWithOverflow(this._date, 0, minutes, 0, 0, 1);\n };\n\n _proto.plusSeconds = function plusSeconds(seconds) {\n return this._plusWithOverflow(this._date, 0, 0, seconds, 0, 1);\n };\n\n _proto.plusNanos = function plusNanos(nanos) {\n return this._plusWithOverflow(this._date, 0, 0, 0, nanos, 1);\n };\n\n _proto.minusAmount = function minusAmount(amount) {\n requireNonNull(amount, 'amount');\n return amount.subtractFrom(this);\n };\n\n _proto.minusAmountUnit = function minusAmountUnit(amountToSubtract, unit) {\n requireNonNull(unit, 'unit');\n return this.plusAmountUnit(-1 * amountToSubtract, unit);\n };\n\n _proto.minusYears = function minusYears(years) {\n return this.plusYears(-1 * years);\n };\n\n _proto.minusMonths = function minusMonths(months) {\n return this.plusMonths(-1 * months);\n };\n\n _proto.minusWeeks = function minusWeeks(weeks) {\n return this.plusWeeks(-1 * weeks);\n };\n\n _proto.minusDays = function minusDays(days) {\n return this.plusDays(-1 * days);\n };\n\n _proto.minusHours = function minusHours(hours) {\n return this._plusWithOverflow(this._date, hours, 0, 0, 0, -1);\n };\n\n _proto.minusMinutes = function minusMinutes(minutes) {\n return this._plusWithOverflow(this._date, 0, minutes, 0, 0, -1);\n };\n\n _proto.minusSeconds = function minusSeconds(seconds) {\n return this._plusWithOverflow(this._date, 0, 0, seconds, 0, -1);\n };\n\n _proto.minusNanos = function minusNanos(nanos) {\n return this._plusWithOverflow(this._date, 0, 0, 0, nanos, -1);\n };\n\n _proto._plusWithOverflow = function _plusWithOverflow(newDate, hours, minutes, seconds, nanos, sign) {\n if (hours === 0 && minutes === 0 && seconds === 0 && nanos === 0) {\n return this._withDateTime(newDate, this._time);\n }\n\n var totDays = MathUtil.intDiv(nanos, LocalTime.NANOS_PER_DAY) + MathUtil.intDiv(seconds, LocalTime.SECONDS_PER_DAY) + MathUtil.intDiv(minutes, LocalTime.MINUTES_PER_DAY) + MathUtil.intDiv(hours, LocalTime.HOURS_PER_DAY);\n totDays *= sign;\n var totNanos = MathUtil.intMod(nanos, LocalTime.NANOS_PER_DAY) + MathUtil.intMod(seconds, LocalTime.SECONDS_PER_DAY) * LocalTime.NANOS_PER_SECOND + MathUtil.intMod(minutes, LocalTime.MINUTES_PER_DAY) * LocalTime.NANOS_PER_MINUTE + MathUtil.intMod(hours, LocalTime.HOURS_PER_DAY) * LocalTime.NANOS_PER_HOUR;\n\n var curNoD = this._time.toNanoOfDay();\n\n totNanos = totNanos * sign + curNoD;\n totDays += MathUtil.floorDiv(totNanos, LocalTime.NANOS_PER_DAY);\n var newNoD = MathUtil.floorMod(totNanos, LocalTime.NANOS_PER_DAY);\n var newTime = newNoD === curNoD ? this._time : LocalTime.ofNanoOfDay(newNoD);\n return this._withDateTime(newDate.plusDays(totDays), newTime);\n };\n\n _proto.query = function query(_query) {\n requireNonNull(_query, 'query');\n\n if (_query === TemporalQueries.localDate()) {\n return this.toLocalDate();\n }\n\n return _ChronoLocalDateTime.prototype.query.call(this, _query);\n };\n\n _proto.adjustInto = function adjustInto(temporal) {\n return _ChronoLocalDateTime.prototype.adjustInto.call(this, temporal);\n };\n\n _proto.until = function until(endExclusive, unit) {\n requireNonNull(endExclusive, 'endExclusive');\n requireNonNull(unit, 'unit');\n var end = LocalDateTime.from(endExclusive);\n\n if (unit instanceof ChronoUnit) {\n if (unit.isTimeBased()) {\n var daysUntil = this._date.daysUntil(end._date);\n\n var timeUntil = end._time.toNanoOfDay() - this._time.toNanoOfDay();\n\n if (daysUntil > 0 && timeUntil < 0) {\n daysUntil--;\n timeUntil += LocalTime.NANOS_PER_DAY;\n } else if (daysUntil < 0 && timeUntil > 0) {\n daysUntil++;\n timeUntil -= LocalTime.NANOS_PER_DAY;\n }\n\n var amount = daysUntil;\n\n switch (unit) {\n case ChronoUnit.NANOS:\n amount = MathUtil.safeMultiply(amount, LocalTime.NANOS_PER_DAY);\n return MathUtil.safeAdd(amount, timeUntil);\n\n case ChronoUnit.MICROS:\n amount = MathUtil.safeMultiply(amount, LocalTime.MICROS_PER_DAY);\n return MathUtil.safeAdd(amount, MathUtil.intDiv(timeUntil, 1000));\n\n case ChronoUnit.MILLIS:\n amount = MathUtil.safeMultiply(amount, LocalTime.MILLIS_PER_DAY);\n return MathUtil.safeAdd(amount, MathUtil.intDiv(timeUntil, 1000000));\n\n case ChronoUnit.SECONDS:\n amount = MathUtil.safeMultiply(amount, LocalTime.SECONDS_PER_DAY);\n return MathUtil.safeAdd(amount, MathUtil.intDiv(timeUntil, LocalTime.NANOS_PER_SECOND));\n\n case ChronoUnit.MINUTES:\n amount = MathUtil.safeMultiply(amount, LocalTime.MINUTES_PER_DAY);\n return MathUtil.safeAdd(amount, MathUtil.intDiv(timeUntil, LocalTime.NANOS_PER_MINUTE));\n\n case ChronoUnit.HOURS:\n amount = MathUtil.safeMultiply(amount, LocalTime.HOURS_PER_DAY);\n return MathUtil.safeAdd(amount, MathUtil.intDiv(timeUntil, LocalTime.NANOS_PER_HOUR));\n\n case ChronoUnit.HALF_DAYS:\n amount = MathUtil.safeMultiply(amount, 2);\n return MathUtil.safeAdd(amount, MathUtil.intDiv(timeUntil, LocalTime.NANOS_PER_HOUR * 12));\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported unit: ' + unit);\n }\n\n var endDate = end._date;\n var endTime = end._time;\n\n if (endDate.isAfter(this._date) && endTime.isBefore(this._time)) {\n endDate = endDate.minusDays(1);\n } else if (endDate.isBefore(this._date) && endTime.isAfter(this._time)) {\n endDate = endDate.plusDays(1);\n }\n\n return this._date.until(endDate, unit);\n }\n\n return unit.between(this, end);\n };\n\n _proto.atOffset = function atOffset(offset) {\n return OffsetDateTime.of(this, offset);\n };\n\n _proto.atZone = function atZone(zone) {\n return ZonedDateTime.of(this, zone);\n };\n\n _proto.toLocalDate = function toLocalDate() {\n return this._date;\n };\n\n _proto.toLocalTime = function toLocalTime() {\n return this._time;\n };\n\n _proto.compareTo = function compareTo(other) {\n requireNonNull(other, 'other');\n requireInstance(other, LocalDateTime, 'other');\n return this._compareTo0(other);\n };\n\n _proto._compareTo0 = function _compareTo0(other) {\n var cmp = this._date.compareTo(other.toLocalDate());\n\n if (cmp === 0) {\n cmp = this._time.compareTo(other.toLocalTime());\n }\n\n return cmp;\n };\n\n _proto.isAfter = function isAfter(other) {\n return this.compareTo(other) > 0;\n };\n\n _proto.isBefore = function isBefore(other) {\n return this.compareTo(other) < 0;\n };\n\n _proto.isEqual = function isEqual(other) {\n return this.compareTo(other) === 0;\n };\n\n _proto.equals = function equals(other) {\n if (this === other) {\n return true;\n }\n\n if (other instanceof LocalDateTime) {\n return this._date.equals(other._date) && this._time.equals(other._time);\n }\n\n return false;\n };\n\n _proto.hashCode = function hashCode() {\n return this._date.hashCode() ^ this._time.hashCode();\n };\n\n _proto.toString = function toString() {\n return this._date.toString() + 'T' + this._time.toString();\n };\n\n _proto.toJSON = function toJSON() {\n return this.toString();\n };\n\n _proto.format = function format(formatter) {\n requireNonNull(formatter, 'formatter');\n return formatter.format(this);\n };\n\n return LocalDateTime;\n}(ChronoLocalDateTime);\nfunction _init$j() {\n LocalDateTime.MIN = LocalDateTime.of(LocalDate.MIN, LocalTime.MIN);\n LocalDateTime.MAX = LocalDateTime.of(LocalDate.MAX, LocalTime.MAX);\n LocalDateTime.FROM = createTemporalQuery('LocalDateTime.FROM', function (temporal) {\n return LocalDateTime.from(temporal);\n });\n}\n\nvar LocalTime = function (_Temporal) {\n _inheritsLoose(LocalTime, _Temporal);\n\n LocalTime.now = function now(clockOrZone) {\n if (clockOrZone == null) {\n return LocalTime._now(Clock.systemDefaultZone());\n } else if (clockOrZone instanceof Clock) {\n return LocalTime._now(clockOrZone);\n } else {\n return LocalTime._now(Clock.system(clockOrZone));\n }\n };\n\n LocalTime._now = function _now(clock) {\n if (clock === void 0) {\n clock = Clock.systemDefaultZone();\n }\n\n requireNonNull(clock, 'clock');\n return LocalTime.ofInstant(clock.instant(), clock.zone());\n };\n\n LocalTime.ofInstant = function ofInstant(instant, zone) {\n if (zone === void 0) {\n zone = ZoneId.systemDefault();\n }\n\n var offset = zone.rules().offset(instant);\n var secsOfDay = MathUtil.intMod(instant.epochSecond(), LocalTime.SECONDS_PER_DAY);\n secsOfDay = MathUtil.intMod(secsOfDay + offset.totalSeconds(), LocalTime.SECONDS_PER_DAY);\n\n if (secsOfDay < 0) {\n secsOfDay += LocalTime.SECONDS_PER_DAY;\n }\n\n return LocalTime.ofSecondOfDay(secsOfDay, instant.nano());\n };\n\n LocalTime.of = function of(hour, minute, second, nanoOfSecond) {\n return new LocalTime(hour, minute, second, nanoOfSecond);\n };\n\n LocalTime.ofSecondOfDay = function ofSecondOfDay(secondOfDay, nanoOfSecond) {\n if (secondOfDay === void 0) {\n secondOfDay = 0;\n }\n\n if (nanoOfSecond === void 0) {\n nanoOfSecond = 0;\n }\n\n ChronoField.SECOND_OF_DAY.checkValidValue(secondOfDay);\n ChronoField.NANO_OF_SECOND.checkValidValue(nanoOfSecond);\n var hours = MathUtil.intDiv(secondOfDay, LocalTime.SECONDS_PER_HOUR);\n secondOfDay -= hours * LocalTime.SECONDS_PER_HOUR;\n var minutes = MathUtil.intDiv(secondOfDay, LocalTime.SECONDS_PER_MINUTE);\n secondOfDay -= minutes * LocalTime.SECONDS_PER_MINUTE;\n return new LocalTime(hours, minutes, secondOfDay, nanoOfSecond);\n };\n\n LocalTime.ofNanoOfDay = function ofNanoOfDay(nanoOfDay) {\n if (nanoOfDay === void 0) {\n nanoOfDay = 0;\n }\n\n ChronoField.NANO_OF_DAY.checkValidValue(nanoOfDay);\n var hours = MathUtil.intDiv(nanoOfDay, LocalTime.NANOS_PER_HOUR);\n nanoOfDay -= hours * LocalTime.NANOS_PER_HOUR;\n var minutes = MathUtil.intDiv(nanoOfDay, LocalTime.NANOS_PER_MINUTE);\n nanoOfDay -= minutes * LocalTime.NANOS_PER_MINUTE;\n var seconds = MathUtil.intDiv(nanoOfDay, LocalTime.NANOS_PER_SECOND);\n nanoOfDay -= seconds * LocalTime.NANOS_PER_SECOND;\n return new LocalTime(hours, minutes, seconds, nanoOfDay);\n };\n\n LocalTime.from = function from(temporal) {\n requireNonNull(temporal, 'temporal');\n var time = temporal.query(TemporalQueries.localTime());\n\n if (time == null) {\n throw new DateTimeException(\"Unable to obtain LocalTime TemporalAccessor: \" + temporal + \", type \" + (temporal.constructor != null ? temporal.constructor.name : ''));\n }\n\n return time;\n };\n\n LocalTime.parse = function parse(text, formatter) {\n if (formatter === void 0) {\n formatter = DateTimeFormatter.ISO_LOCAL_TIME;\n }\n\n requireNonNull(formatter, 'formatter');\n return formatter.parse(text, LocalTime.FROM);\n };\n\n function LocalTime(hour, minute, second, nanoOfSecond) {\n var _this;\n\n if (hour === void 0) {\n hour = 0;\n }\n\n if (minute === void 0) {\n minute = 0;\n }\n\n if (second === void 0) {\n second = 0;\n }\n\n if (nanoOfSecond === void 0) {\n nanoOfSecond = 0;\n }\n\n _this = _Temporal.call(this) || this;\n\n var _hour = MathUtil.safeToInt(hour);\n\n var _minute = MathUtil.safeToInt(minute);\n\n var _second = MathUtil.safeToInt(second);\n\n var _nanoOfSecond = MathUtil.safeToInt(nanoOfSecond);\n\n LocalTime._validate(_hour, _minute, _second, _nanoOfSecond);\n\n if (_minute === 0 && _second === 0 && _nanoOfSecond === 0) {\n if (!LocalTime.HOURS[_hour]) {\n _this._hour = _hour;\n _this._minute = _minute;\n _this._second = _second;\n _this._nano = _nanoOfSecond;\n LocalTime.HOURS[_hour] = _assertThisInitialized(_this);\n }\n\n return LocalTime.HOURS[_hour] || _assertThisInitialized(_this);\n }\n\n _this._hour = _hour;\n _this._minute = _minute;\n _this._second = _second;\n _this._nano = _nanoOfSecond;\n return _this;\n }\n\n LocalTime._validate = function _validate(hour, minute, second, nanoOfSecond) {\n ChronoField.HOUR_OF_DAY.checkValidValue(hour);\n ChronoField.MINUTE_OF_HOUR.checkValidValue(minute);\n ChronoField.SECOND_OF_MINUTE.checkValidValue(second);\n ChronoField.NANO_OF_SECOND.checkValidValue(nanoOfSecond);\n };\n\n var _proto = LocalTime.prototype;\n\n _proto.isSupported = function isSupported(fieldOrUnit) {\n if (fieldOrUnit instanceof ChronoField) {\n return fieldOrUnit.isTimeBased();\n } else if (fieldOrUnit instanceof ChronoUnit) {\n return fieldOrUnit.isTimeBased();\n }\n\n return fieldOrUnit != null && fieldOrUnit.isSupportedBy(this);\n };\n\n _proto.range = function range(field) {\n requireNonNull(field);\n return _Temporal.prototype.range.call(this, field);\n };\n\n _proto.get = function get(field) {\n return this.getLong(field);\n };\n\n _proto.getLong = function getLong(field) {\n requireNonNull(field, 'field');\n\n if (field instanceof ChronoField) {\n return this._get0(field);\n }\n\n return field.getFrom(this);\n };\n\n _proto._get0 = function _get0(field) {\n switch (field) {\n case ChronoField.NANO_OF_SECOND:\n return this._nano;\n\n case ChronoField.NANO_OF_DAY:\n return this.toNanoOfDay();\n\n case ChronoField.MICRO_OF_SECOND:\n return MathUtil.intDiv(this._nano, 1000);\n\n case ChronoField.MICRO_OF_DAY:\n return MathUtil.intDiv(this.toNanoOfDay(), 1000);\n\n case ChronoField.MILLI_OF_SECOND:\n return MathUtil.intDiv(this._nano, 1000000);\n\n case ChronoField.MILLI_OF_DAY:\n return MathUtil.intDiv(this.toNanoOfDay(), 1000000);\n\n case ChronoField.SECOND_OF_MINUTE:\n return this._second;\n\n case ChronoField.SECOND_OF_DAY:\n return this.toSecondOfDay();\n\n case ChronoField.MINUTE_OF_HOUR:\n return this._minute;\n\n case ChronoField.MINUTE_OF_DAY:\n return this._hour * 60 + this._minute;\n\n case ChronoField.HOUR_OF_AMPM:\n return MathUtil.intMod(this._hour, 12);\n\n case ChronoField.CLOCK_HOUR_OF_AMPM:\n {\n var ham = MathUtil.intMod(this._hour, 12);\n return ham % 12 === 0 ? 12 : ham;\n }\n\n case ChronoField.HOUR_OF_DAY:\n return this._hour;\n\n case ChronoField.CLOCK_HOUR_OF_DAY:\n return this._hour === 0 ? 24 : this._hour;\n\n case ChronoField.AMPM_OF_DAY:\n return MathUtil.intDiv(this._hour, 12);\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported field: ' + field);\n };\n\n _proto.hour = function hour() {\n return this._hour;\n };\n\n _proto.minute = function minute() {\n return this._minute;\n };\n\n _proto.second = function second() {\n return this._second;\n };\n\n _proto.nano = function nano() {\n return this._nano;\n };\n\n _proto.withAdjuster = function withAdjuster(adjuster) {\n requireNonNull(adjuster, 'adjuster');\n\n if (adjuster instanceof LocalTime) {\n return adjuster;\n }\n\n assert(typeof adjuster.adjustInto === 'function', 'adjuster', IllegalArgumentException);\n return adjuster.adjustInto(this);\n };\n\n _proto.withFieldValue = function withFieldValue(field, newValue) {\n requireNonNull(field, 'field');\n requireInstance(field, TemporalField, 'field');\n\n if (field instanceof ChronoField) {\n field.checkValidValue(newValue);\n\n switch (field) {\n case ChronoField.NANO_OF_SECOND:\n return this.withNano(newValue);\n\n case ChronoField.NANO_OF_DAY:\n return LocalTime.ofNanoOfDay(newValue);\n\n case ChronoField.MICRO_OF_SECOND:\n return this.withNano(newValue * 1000);\n\n case ChronoField.MICRO_OF_DAY:\n return LocalTime.ofNanoOfDay(newValue * 1000);\n\n case ChronoField.MILLI_OF_SECOND:\n return this.withNano(newValue * 1000000);\n\n case ChronoField.MILLI_OF_DAY:\n return LocalTime.ofNanoOfDay(newValue * 1000000);\n\n case ChronoField.SECOND_OF_MINUTE:\n return this.withSecond(newValue);\n\n case ChronoField.SECOND_OF_DAY:\n return this.plusSeconds(newValue - this.toSecondOfDay());\n\n case ChronoField.MINUTE_OF_HOUR:\n return this.withMinute(newValue);\n\n case ChronoField.MINUTE_OF_DAY:\n return this.plusMinutes(newValue - (this._hour * 60 + this._minute));\n\n case ChronoField.HOUR_OF_AMPM:\n return this.plusHours(newValue - MathUtil.intMod(this._hour, 12));\n\n case ChronoField.CLOCK_HOUR_OF_AMPM:\n return this.plusHours((newValue === 12 ? 0 : newValue) - MathUtil.intMod(this._hour, 12));\n\n case ChronoField.HOUR_OF_DAY:\n return this.withHour(newValue);\n\n case ChronoField.CLOCK_HOUR_OF_DAY:\n return this.withHour(newValue === 24 ? 0 : newValue);\n\n case ChronoField.AMPM_OF_DAY:\n return this.plusHours((newValue - MathUtil.intDiv(this._hour, 12)) * 12);\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported field: ' + field);\n }\n\n return field.adjustInto(this, newValue);\n };\n\n _proto.withHour = function withHour(hour) {\n if (hour === void 0) {\n hour = 0;\n }\n\n if (this._hour === hour) {\n return this;\n }\n\n return new LocalTime(hour, this._minute, this._second, this._nano);\n };\n\n _proto.withMinute = function withMinute(minute) {\n if (minute === void 0) {\n minute = 0;\n }\n\n if (this._minute === minute) {\n return this;\n }\n\n return new LocalTime(this._hour, minute, this._second, this._nano);\n };\n\n _proto.withSecond = function withSecond(second) {\n if (second === void 0) {\n second = 0;\n }\n\n if (this._second === second) {\n return this;\n }\n\n return new LocalTime(this._hour, this._minute, second, this._nano);\n };\n\n _proto.withNano = function withNano(nanoOfSecond) {\n if (nanoOfSecond === void 0) {\n nanoOfSecond = 0;\n }\n\n if (this._nano === nanoOfSecond) {\n return this;\n }\n\n return new LocalTime(this._hour, this._minute, this._second, nanoOfSecond);\n };\n\n _proto.truncatedTo = function truncatedTo(unit) {\n requireNonNull(unit, 'unit');\n\n if (unit === ChronoUnit.NANOS) {\n return this;\n }\n\n var unitDur = unit.duration();\n\n if (unitDur.seconds() > LocalTime.SECONDS_PER_DAY) {\n throw new DateTimeException('Unit is too large to be used for truncation');\n }\n\n var dur = unitDur.toNanos();\n\n if (MathUtil.intMod(LocalTime.NANOS_PER_DAY, dur) !== 0) {\n throw new DateTimeException('Unit must divide into a standard day without remainder');\n }\n\n var nod = this.toNanoOfDay();\n return LocalTime.ofNanoOfDay(MathUtil.intDiv(nod, dur) * dur);\n };\n\n _proto.plusAmount = function plusAmount(amount) {\n requireNonNull(amount, 'amount');\n return amount.addTo(this);\n };\n\n _proto.plusAmountUnit = function plusAmountUnit(amountToAdd, unit) {\n requireNonNull(unit, 'unit');\n\n if (unit instanceof ChronoUnit) {\n switch (unit) {\n case ChronoUnit.NANOS:\n return this.plusNanos(amountToAdd);\n\n case ChronoUnit.MICROS:\n return this.plusNanos(MathUtil.intMod(amountToAdd, LocalTime.MICROS_PER_DAY) * 1000);\n\n case ChronoUnit.MILLIS:\n return this.plusNanos(MathUtil.intMod(amountToAdd, LocalTime.MILLIS_PER_DAY) * 1000000);\n\n case ChronoUnit.SECONDS:\n return this.plusSeconds(amountToAdd);\n\n case ChronoUnit.MINUTES:\n return this.plusMinutes(amountToAdd);\n\n case ChronoUnit.HOURS:\n return this.plusHours(amountToAdd);\n\n case ChronoUnit.HALF_DAYS:\n return this.plusHours(MathUtil.intMod(amountToAdd, 2) * 12);\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported unit: ' + unit);\n }\n\n return unit.addTo(this, amountToAdd);\n };\n\n _proto.plusHours = function plusHours(hoursToAdd) {\n if (hoursToAdd === 0) {\n return this;\n }\n\n var newHour = MathUtil.intMod(MathUtil.intMod(hoursToAdd, LocalTime.HOURS_PER_DAY) + this._hour + LocalTime.HOURS_PER_DAY, LocalTime.HOURS_PER_DAY);\n return new LocalTime(newHour, this._minute, this._second, this._nano);\n };\n\n _proto.plusMinutes = function plusMinutes(minutesToAdd) {\n if (minutesToAdd === 0) {\n return this;\n }\n\n var mofd = this._hour * LocalTime.MINUTES_PER_HOUR + this._minute;\n var newMofd = MathUtil.intMod(MathUtil.intMod(minutesToAdd, LocalTime.MINUTES_PER_DAY) + mofd + LocalTime.MINUTES_PER_DAY, LocalTime.MINUTES_PER_DAY);\n\n if (mofd === newMofd) {\n return this;\n }\n\n var newHour = MathUtil.intDiv(newMofd, LocalTime.MINUTES_PER_HOUR);\n var newMinute = MathUtil.intMod(newMofd, LocalTime.MINUTES_PER_HOUR);\n return new LocalTime(newHour, newMinute, this._second, this._nano);\n };\n\n _proto.plusSeconds = function plusSeconds(secondsToAdd) {\n if (secondsToAdd === 0) {\n return this;\n }\n\n var sofd = this._hour * LocalTime.SECONDS_PER_HOUR + this._minute * LocalTime.SECONDS_PER_MINUTE + this._second;\n var newSofd = MathUtil.intMod(MathUtil.intMod(secondsToAdd, LocalTime.SECONDS_PER_DAY) + sofd + LocalTime.SECONDS_PER_DAY, LocalTime.SECONDS_PER_DAY);\n\n if (sofd === newSofd) {\n return this;\n }\n\n var newHour = MathUtil.intDiv(newSofd, LocalTime.SECONDS_PER_HOUR);\n var newMinute = MathUtil.intMod(MathUtil.intDiv(newSofd, LocalTime.SECONDS_PER_MINUTE), LocalTime.MINUTES_PER_HOUR);\n var newSecond = MathUtil.intMod(newSofd, LocalTime.SECONDS_PER_MINUTE);\n return new LocalTime(newHour, newMinute, newSecond, this._nano);\n };\n\n _proto.plusNanos = function plusNanos(nanosToAdd) {\n if (nanosToAdd === 0) {\n return this;\n }\n\n var nofd = this.toNanoOfDay();\n var newNofd = MathUtil.intMod(MathUtil.intMod(nanosToAdd, LocalTime.NANOS_PER_DAY) + nofd + LocalTime.NANOS_PER_DAY, LocalTime.NANOS_PER_DAY);\n\n if (nofd === newNofd) {\n return this;\n }\n\n var newHour = MathUtil.intDiv(newNofd, LocalTime.NANOS_PER_HOUR);\n var newMinute = MathUtil.intMod(MathUtil.intDiv(newNofd, LocalTime.NANOS_PER_MINUTE), LocalTime.MINUTES_PER_HOUR);\n var newSecond = MathUtil.intMod(MathUtil.intDiv(newNofd, LocalTime.NANOS_PER_SECOND), LocalTime.SECONDS_PER_MINUTE);\n var newNano = MathUtil.intMod(newNofd, LocalTime.NANOS_PER_SECOND);\n return new LocalTime(newHour, newMinute, newSecond, newNano);\n };\n\n _proto.minusAmount = function minusAmount(amount) {\n requireNonNull(amount, 'amount');\n return amount.subtractFrom(this);\n };\n\n _proto.minusAmountUnit = function minusAmountUnit(amountToSubtract, unit) {\n requireNonNull(unit, 'unit');\n return this.plusAmountUnit(-1 * amountToSubtract, unit);\n };\n\n _proto.minusHours = function minusHours(hoursToSubtract) {\n return this.plusHours(-1 * MathUtil.intMod(hoursToSubtract, LocalTime.HOURS_PER_DAY));\n };\n\n _proto.minusMinutes = function minusMinutes(minutesToSubtract) {\n return this.plusMinutes(-1 * MathUtil.intMod(minutesToSubtract, LocalTime.MINUTES_PER_DAY));\n };\n\n _proto.minusSeconds = function minusSeconds(secondsToSubtract) {\n return this.plusSeconds(-1 * MathUtil.intMod(secondsToSubtract, LocalTime.SECONDS_PER_DAY));\n };\n\n _proto.minusNanos = function minusNanos(nanosToSubtract) {\n return this.plusNanos(-1 * MathUtil.intMod(nanosToSubtract, LocalTime.NANOS_PER_DAY));\n };\n\n _proto.query = function query(_query) {\n requireNonNull(_query, 'query');\n\n if (_query === TemporalQueries.precision()) {\n return ChronoUnit.NANOS;\n } else if (_query === TemporalQueries.localTime()) {\n return this;\n }\n\n if (_query === TemporalQueries.chronology() || _query === TemporalQueries.zoneId() || _query === TemporalQueries.zone() || _query === TemporalQueries.offset() || _query === TemporalQueries.localDate()) {\n return null;\n }\n\n return _query.queryFrom(this);\n };\n\n _proto.adjustInto = function adjustInto(temporal) {\n return temporal.with(LocalTime.NANO_OF_DAY, this.toNanoOfDay());\n };\n\n _proto.until = function until(endExclusive, unit) {\n requireNonNull(endExclusive, 'endExclusive');\n requireNonNull(unit, 'unit');\n var end = LocalTime.from(endExclusive);\n\n if (unit instanceof ChronoUnit) {\n var nanosUntil = end.toNanoOfDay() - this.toNanoOfDay();\n\n switch (unit) {\n case ChronoUnit.NANOS:\n return nanosUntil;\n\n case ChronoUnit.MICROS:\n return MathUtil.intDiv(nanosUntil, 1000);\n\n case ChronoUnit.MILLIS:\n return MathUtil.intDiv(nanosUntil, 1000000);\n\n case ChronoUnit.SECONDS:\n return MathUtil.intDiv(nanosUntil, LocalTime.NANOS_PER_SECOND);\n\n case ChronoUnit.MINUTES:\n return MathUtil.intDiv(nanosUntil, LocalTime.NANOS_PER_MINUTE);\n\n case ChronoUnit.HOURS:\n return MathUtil.intDiv(nanosUntil, LocalTime.NANOS_PER_HOUR);\n\n case ChronoUnit.HALF_DAYS:\n return MathUtil.intDiv(nanosUntil, 12 * LocalTime.NANOS_PER_HOUR);\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported unit: ' + unit);\n }\n\n return unit.between(this, end);\n };\n\n _proto.atDate = function atDate(date) {\n return LocalDateTime.of(date, this);\n };\n\n _proto.toSecondOfDay = function toSecondOfDay() {\n var total = this._hour * LocalTime.SECONDS_PER_HOUR;\n total += this._minute * LocalTime.SECONDS_PER_MINUTE;\n total += this._second;\n return total;\n };\n\n _proto.toNanoOfDay = function toNanoOfDay() {\n var total = this._hour * LocalTime.NANOS_PER_HOUR;\n total += this._minute * LocalTime.NANOS_PER_MINUTE;\n total += this._second * LocalTime.NANOS_PER_SECOND;\n total += this._nano;\n return total;\n };\n\n _proto.compareTo = function compareTo(other) {\n requireNonNull(other, 'other');\n requireInstance(other, LocalTime, 'other');\n var cmp = MathUtil.compareNumbers(this._hour, other._hour);\n\n if (cmp === 0) {\n cmp = MathUtil.compareNumbers(this._minute, other._minute);\n\n if (cmp === 0) {\n cmp = MathUtil.compareNumbers(this._second, other._second);\n\n if (cmp === 0) {\n cmp = MathUtil.compareNumbers(this._nano, other._nano);\n }\n }\n }\n\n return cmp;\n };\n\n _proto.isAfter = function isAfter(other) {\n return this.compareTo(other) > 0;\n };\n\n _proto.isBefore = function isBefore(other) {\n return this.compareTo(other) < 0;\n };\n\n _proto.equals = function equals(other) {\n if (this === other) {\n return true;\n }\n\n if (other instanceof LocalTime) {\n return this._hour === other._hour && this._minute === other._minute && this._second === other._second && this._nano === other._nano;\n }\n\n return false;\n };\n\n _proto.hashCode = function hashCode() {\n var nod = this.toNanoOfDay();\n return MathUtil.hash(nod);\n };\n\n _proto.toString = function toString() {\n var buf = '';\n var hourValue = this._hour;\n var minuteValue = this._minute;\n var secondValue = this._second;\n var nanoValue = this._nano;\n buf += hourValue < 10 ? '0' : '';\n buf += hourValue;\n buf += minuteValue < 10 ? ':0' : ':';\n buf += minuteValue;\n\n if (secondValue > 0 || nanoValue > 0) {\n buf += secondValue < 10 ? ':0' : ':';\n buf += secondValue;\n\n if (nanoValue > 0) {\n buf += '.';\n\n if (MathUtil.intMod(nanoValue, 1000000) === 0) {\n buf += ('' + (MathUtil.intDiv(nanoValue, 1000000) + 1000)).substring(1);\n } else if (MathUtil.intMod(nanoValue, 1000) === 0) {\n buf += ('' + (MathUtil.intDiv(nanoValue, 1000) + 1000000)).substring(1);\n } else {\n buf += ('' + (nanoValue + 1000000000)).substring(1);\n }\n }\n }\n\n return buf;\n };\n\n _proto.toJSON = function toJSON() {\n return this.toString();\n };\n\n _proto.format = function format(formatter) {\n requireNonNull(formatter, 'formatter');\n return formatter.format(this);\n };\n\n return LocalTime;\n}(Temporal);\nfunction _init$k() {\n LocalTime.HOURS = [];\n\n for (var hour = 0; hour < 24; hour++) {\n LocalTime.of(hour, 0, 0, 0);\n }\n\n LocalTime.MIN = LocalTime.HOURS[0];\n LocalTime.MAX = new LocalTime(23, 59, 59, 999999999);\n LocalTime.MIDNIGHT = LocalTime.HOURS[0];\n LocalTime.NOON = LocalTime.HOURS[12];\n LocalTime.FROM = createTemporalQuery('LocalTime.FROM', function (temporal) {\n return LocalTime.from(temporal);\n });\n}\nLocalTime.HOURS_PER_DAY = 24;\nLocalTime.MINUTES_PER_HOUR = 60;\nLocalTime.MINUTES_PER_DAY = LocalTime.MINUTES_PER_HOUR * LocalTime.HOURS_PER_DAY;\nLocalTime.SECONDS_PER_MINUTE = 60;\nLocalTime.SECONDS_PER_HOUR = LocalTime.SECONDS_PER_MINUTE * LocalTime.MINUTES_PER_HOUR;\nLocalTime.SECONDS_PER_DAY = LocalTime.SECONDS_PER_HOUR * LocalTime.HOURS_PER_DAY;\nLocalTime.MILLIS_PER_DAY = LocalTime.SECONDS_PER_DAY * 1000;\nLocalTime.MICROS_PER_DAY = LocalTime.SECONDS_PER_DAY * 1000000;\nLocalTime.NANOS_PER_SECOND = 1000000000;\nLocalTime.NANOS_PER_MINUTE = LocalTime.NANOS_PER_SECOND * LocalTime.SECONDS_PER_MINUTE;\nLocalTime.NANOS_PER_HOUR = LocalTime.NANOS_PER_MINUTE * LocalTime.MINUTES_PER_HOUR;\nLocalTime.NANOS_PER_DAY = LocalTime.NANOS_PER_HOUR * LocalTime.HOURS_PER_DAY;\n\nvar NANOS_PER_MILLI = 1000000;\nvar Instant = function (_Temporal) {\n _inheritsLoose(Instant, _Temporal);\n\n Instant.now = function now(clock) {\n if (clock === void 0) {\n clock = Clock.systemUTC();\n }\n\n return clock.instant();\n };\n\n Instant.ofEpochSecond = function ofEpochSecond(epochSecond, nanoAdjustment) {\n if (nanoAdjustment === void 0) {\n nanoAdjustment = 0;\n }\n\n var secs = epochSecond + MathUtil.floorDiv(nanoAdjustment, LocalTime.NANOS_PER_SECOND);\n var nos = MathUtil.floorMod(nanoAdjustment, LocalTime.NANOS_PER_SECOND);\n return Instant._create(secs, nos);\n };\n\n Instant.ofEpochMilli = function ofEpochMilli(epochMilli) {\n var secs = MathUtil.floorDiv(epochMilli, 1000);\n var mos = MathUtil.floorMod(epochMilli, 1000);\n return Instant._create(secs, mos * 1000000);\n };\n\n Instant.from = function from(temporal) {\n try {\n var instantSecs = temporal.getLong(ChronoField.INSTANT_SECONDS);\n var nanoOfSecond = temporal.get(ChronoField.NANO_OF_SECOND);\n return Instant.ofEpochSecond(instantSecs, nanoOfSecond);\n } catch (ex) {\n throw new DateTimeException('Unable to obtain Instant from TemporalAccessor: ' + temporal + ', type ' + typeof temporal, ex);\n }\n };\n\n Instant.parse = function parse(text) {\n return DateTimeFormatter.ISO_INSTANT.parse(text, Instant.FROM);\n };\n\n Instant._create = function _create(seconds, nanoOfSecond) {\n if (seconds === 0 && nanoOfSecond === 0) {\n return Instant.EPOCH;\n }\n\n return new Instant(seconds, nanoOfSecond);\n };\n\n Instant._validate = function _validate(seconds, nanoOfSecond) {\n if (seconds < Instant.MIN_SECONDS || seconds > Instant.MAX_SECONDS) {\n throw new DateTimeException('Instant exceeds minimum or maximum instant');\n }\n\n if (nanoOfSecond < 0 || nanoOfSecond > LocalTime.NANOS_PER_SECOND) {\n throw new DateTimeException('Instant exceeds minimum or maximum instant');\n }\n };\n\n function Instant(seconds, nanoOfSecond) {\n var _this;\n\n _this = _Temporal.call(this) || this;\n\n Instant._validate(seconds, nanoOfSecond);\n\n _this._seconds = MathUtil.safeToInt(seconds);\n _this._nanos = MathUtil.safeToInt(nanoOfSecond);\n return _this;\n }\n\n var _proto = Instant.prototype;\n\n _proto.isSupported = function isSupported(fieldOrUnit) {\n if (fieldOrUnit instanceof ChronoField) {\n return fieldOrUnit === ChronoField.INSTANT_SECONDS || fieldOrUnit === ChronoField.NANO_OF_SECOND || fieldOrUnit === ChronoField.MICRO_OF_SECOND || fieldOrUnit === ChronoField.MILLI_OF_SECOND;\n }\n\n if (fieldOrUnit instanceof ChronoUnit) {\n return fieldOrUnit.isTimeBased() || fieldOrUnit === ChronoUnit.DAYS;\n }\n\n return fieldOrUnit != null && fieldOrUnit.isSupportedBy(this);\n };\n\n _proto.range = function range(field) {\n return _Temporal.prototype.range.call(this, field);\n };\n\n _proto.get = function get(field) {\n return this.getLong(field);\n };\n\n _proto.getLong = function getLong(field) {\n if (field instanceof ChronoField) {\n switch (field) {\n case ChronoField.NANO_OF_SECOND:\n return this._nanos;\n\n case ChronoField.MICRO_OF_SECOND:\n return MathUtil.intDiv(this._nanos, 1000);\n\n case ChronoField.MILLI_OF_SECOND:\n return MathUtil.intDiv(this._nanos, NANOS_PER_MILLI);\n\n case ChronoField.INSTANT_SECONDS:\n return this._seconds;\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported field: ' + field);\n }\n\n return field.getFrom(this);\n };\n\n _proto.epochSecond = function epochSecond() {\n return this._seconds;\n };\n\n _proto.nano = function nano() {\n return this._nanos;\n };\n\n _proto.withAdjuster = function withAdjuster(adjuster) {\n requireNonNull(adjuster, 'adjuster');\n return adjuster.adjustInto(this);\n };\n\n _proto.withFieldValue = function withFieldValue(field, newValue) {\n requireNonNull(field, 'field');\n\n if (field instanceof ChronoField) {\n field.checkValidValue(newValue);\n\n switch (field) {\n case ChronoField.MILLI_OF_SECOND:\n {\n var nval = newValue * NANOS_PER_MILLI;\n return nval !== this._nanos ? Instant._create(this._seconds, nval) : this;\n }\n\n case ChronoField.MICRO_OF_SECOND:\n {\n var _nval = newValue * 1000;\n\n return _nval !== this._nanos ? Instant._create(this._seconds, _nval) : this;\n }\n\n case ChronoField.NANO_OF_SECOND:\n return newValue !== this._nanos ? Instant._create(this._seconds, newValue) : this;\n\n case ChronoField.INSTANT_SECONDS:\n return newValue !== this._seconds ? Instant._create(newValue, this._nanos) : this;\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported field: ' + field);\n }\n\n return field.adjustInto(this, newValue);\n };\n\n _proto.truncatedTo = function truncatedTo(unit) {\n requireNonNull(unit, 'unit');\n\n if (unit === ChronoUnit.NANOS) {\n return this;\n }\n\n var unitDur = unit.duration();\n\n if (unitDur.seconds() > LocalTime.SECONDS_PER_DAY) {\n throw new DateTimeException('Unit is too large to be used for truncation');\n }\n\n var dur = unitDur.toNanos();\n\n if (MathUtil.intMod(LocalTime.NANOS_PER_DAY, dur) !== 0) {\n throw new DateTimeException('Unit must divide into a standard day without remainder');\n }\n\n var nod = MathUtil.intMod(this._seconds, LocalTime.SECONDS_PER_DAY) * LocalTime.NANOS_PER_SECOND + this._nanos;\n\n var result = MathUtil.intDiv(nod, dur) * dur;\n return this.plusNanos(result - nod);\n };\n\n _proto.plusAmount = function plusAmount(amount) {\n requireNonNull(amount, 'amount');\n return amount.addTo(this);\n };\n\n _proto.plusAmountUnit = function plusAmountUnit(amountToAdd, unit) {\n requireNonNull(amountToAdd, 'amountToAdd');\n requireNonNull(unit, 'unit');\n requireInstance(unit, TemporalUnit);\n\n if (unit instanceof ChronoUnit) {\n switch (unit) {\n case ChronoUnit.NANOS:\n return this.plusNanos(amountToAdd);\n\n case ChronoUnit.MICROS:\n return this._plus(MathUtil.intDiv(amountToAdd, 1000000), MathUtil.intMod(amountToAdd, 1000000) * 1000);\n\n case ChronoUnit.MILLIS:\n return this.plusMillis(amountToAdd);\n\n case ChronoUnit.SECONDS:\n return this.plusSeconds(amountToAdd);\n\n case ChronoUnit.MINUTES:\n return this.plusSeconds(MathUtil.safeMultiply(amountToAdd, LocalTime.SECONDS_PER_MINUTE));\n\n case ChronoUnit.HOURS:\n return this.plusSeconds(MathUtil.safeMultiply(amountToAdd, LocalTime.SECONDS_PER_HOUR));\n\n case ChronoUnit.HALF_DAYS:\n return this.plusSeconds(MathUtil.safeMultiply(amountToAdd, LocalTime.SECONDS_PER_DAY / 2));\n\n case ChronoUnit.DAYS:\n return this.plusSeconds(MathUtil.safeMultiply(amountToAdd, LocalTime.SECONDS_PER_DAY));\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported unit: ' + unit);\n }\n\n return unit.addTo(this, amountToAdd);\n };\n\n _proto.plusSeconds = function plusSeconds(secondsToAdd) {\n return this._plus(secondsToAdd, 0);\n };\n\n _proto.plusMillis = function plusMillis(millisToAdd) {\n return this._plus(MathUtil.intDiv(millisToAdd, 1000), MathUtil.intMod(millisToAdd, 1000) * NANOS_PER_MILLI);\n };\n\n _proto.plusNanos = function plusNanos(nanosToAdd) {\n return this._plus(0, nanosToAdd);\n };\n\n _proto._plus = function _plus(secondsToAdd, nanosToAdd) {\n if (secondsToAdd === 0 && nanosToAdd === 0) {\n return this;\n }\n\n var epochSec = this._seconds + secondsToAdd;\n epochSec = epochSec + MathUtil.intDiv(nanosToAdd, LocalTime.NANOS_PER_SECOND);\n var nanoAdjustment = this._nanos + nanosToAdd % LocalTime.NANOS_PER_SECOND;\n return Instant.ofEpochSecond(epochSec, nanoAdjustment);\n };\n\n _proto.minusAmount = function minusAmount(amount) {\n requireNonNull(amount, 'amount');\n return amount.subtractFrom(this);\n };\n\n _proto.minusAmountUnit = function minusAmountUnit(amountToSubtract, unit) {\n return this.plusAmountUnit(-1 * amountToSubtract, unit);\n };\n\n _proto.minusSeconds = function minusSeconds(secondsToSubtract) {\n return this.plusSeconds(secondsToSubtract * -1);\n };\n\n _proto.minusMillis = function minusMillis(millisToSubtract) {\n return this.plusMillis(-1 * millisToSubtract);\n };\n\n _proto.minusNanos = function minusNanos(nanosToSubtract) {\n return this.plusNanos(-1 * nanosToSubtract);\n };\n\n _proto.query = function query(_query) {\n requireNonNull(_query, 'query');\n\n if (_query === TemporalQueries.precision()) {\n return ChronoUnit.NANOS;\n }\n\n if (_query === TemporalQueries.localDate() || _query === TemporalQueries.localTime() || _query === TemporalQueries.chronology() || _query === TemporalQueries.zoneId() || _query === TemporalQueries.zone() || _query === TemporalQueries.offset()) {\n return null;\n }\n\n return _query.queryFrom(this);\n };\n\n _proto.adjustInto = function adjustInto(temporal) {\n requireNonNull(temporal, 'temporal');\n return temporal.with(ChronoField.INSTANT_SECONDS, this._seconds).with(ChronoField.NANO_OF_SECOND, this._nanos);\n };\n\n _proto.until = function until(endExclusive, unit) {\n requireNonNull(endExclusive, 'endExclusive');\n requireNonNull(unit, 'unit');\n var end = Instant.from(endExclusive);\n\n if (unit instanceof ChronoUnit) {\n switch (unit) {\n case ChronoUnit.NANOS:\n return this._nanosUntil(end);\n\n case ChronoUnit.MICROS:\n return MathUtil.intDiv(this._nanosUntil(end), 1000);\n\n case ChronoUnit.MILLIS:\n return MathUtil.safeSubtract(end.toEpochMilli(), this.toEpochMilli());\n\n case ChronoUnit.SECONDS:\n return this._secondsUntil(end);\n\n case ChronoUnit.MINUTES:\n return MathUtil.intDiv(this._secondsUntil(end), LocalTime.SECONDS_PER_MINUTE);\n\n case ChronoUnit.HOURS:\n return MathUtil.intDiv(this._secondsUntil(end), LocalTime.SECONDS_PER_HOUR);\n\n case ChronoUnit.HALF_DAYS:\n return MathUtil.intDiv(this._secondsUntil(end), 12 * LocalTime.SECONDS_PER_HOUR);\n\n case ChronoUnit.DAYS:\n return MathUtil.intDiv(this._secondsUntil(end), LocalTime.SECONDS_PER_DAY);\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported unit: ' + unit);\n }\n\n return unit.between(this, end);\n };\n\n _proto._nanosUntil = function _nanosUntil(end) {\n var secsDiff = MathUtil.safeSubtract(end.epochSecond(), this.epochSecond());\n var totalNanos = MathUtil.safeMultiply(secsDiff, LocalTime.NANOS_PER_SECOND);\n return MathUtil.safeAdd(totalNanos, end.nano() - this.nano());\n };\n\n _proto._secondsUntil = function _secondsUntil(end) {\n var secsDiff = MathUtil.safeSubtract(end.epochSecond(), this.epochSecond());\n var nanosDiff = end.nano() - this.nano();\n\n if (secsDiff > 0 && nanosDiff < 0) {\n secsDiff--;\n } else if (secsDiff < 0 && nanosDiff > 0) {\n secsDiff++;\n }\n\n return secsDiff;\n };\n\n _proto.atOffset = function atOffset(offset) {\n return OffsetDateTime.ofInstant(this, offset);\n };\n\n _proto.atZone = function atZone(zone) {\n return ZonedDateTime.ofInstant(this, zone);\n };\n\n _proto.toEpochMilli = function toEpochMilli() {\n var millis = MathUtil.safeMultiply(this._seconds, 1000);\n return millis + MathUtil.intDiv(this._nanos, NANOS_PER_MILLI);\n };\n\n _proto.compareTo = function compareTo(otherInstant) {\n requireNonNull(otherInstant, 'otherInstant');\n requireInstance(otherInstant, Instant, 'otherInstant');\n var cmp = MathUtil.compareNumbers(this._seconds, otherInstant._seconds);\n\n if (cmp !== 0) {\n return cmp;\n }\n\n return this._nanos - otherInstant._nanos;\n };\n\n _proto.isAfter = function isAfter(otherInstant) {\n return this.compareTo(otherInstant) > 0;\n };\n\n _proto.isBefore = function isBefore(otherInstant) {\n return this.compareTo(otherInstant) < 0;\n };\n\n _proto.equals = function equals(other) {\n if (this === other) {\n return true;\n }\n\n if (other instanceof Instant) {\n return this.epochSecond() === other.epochSecond() && this.nano() === other.nano();\n }\n\n return false;\n };\n\n _proto.hashCode = function hashCode() {\n return MathUtil.hashCode(this._seconds, this._nanos);\n };\n\n _proto.toString = function toString() {\n return DateTimeFormatter.ISO_INSTANT.format(this);\n };\n\n _proto.toJSON = function toJSON() {\n return this.toString();\n };\n\n return Instant;\n}(Temporal);\nfunction _init$l() {\n Instant.MIN_SECONDS = -31619119219200;\n Instant.MAX_SECONDS = 31494816403199;\n Instant.EPOCH = new Instant(0, 0);\n Instant.MIN = Instant.ofEpochSecond(Instant.MIN_SECONDS, 0);\n Instant.MAX = Instant.ofEpochSecond(Instant.MAX_SECONDS, 999999999);\n Instant.FROM = createTemporalQuery('Instant.FROM', function (temporal) {\n return Instant.from(temporal);\n });\n}\n\nvar Clock = function () {\n function Clock() {}\n\n Clock.systemUTC = function systemUTC() {\n return new SystemClock(ZoneOffset.UTC);\n };\n\n Clock.systemDefaultZone = function systemDefaultZone() {\n return new SystemClock(ZoneId.systemDefault());\n };\n\n Clock.system = function system(zone) {\n return new SystemClock(zone);\n };\n\n Clock.fixed = function fixed(fixedInstant, zoneId) {\n return new FixedClock(fixedInstant, zoneId);\n };\n\n Clock.offset = function offset(baseClock, duration) {\n return new OffsetClock(baseClock, duration);\n };\n\n var _proto = Clock.prototype;\n\n _proto.millis = function millis() {\n abstractMethodFail('Clock.millis');\n };\n\n _proto.instant = function instant() {\n abstractMethodFail('Clock.instant');\n };\n\n _proto.zone = function zone() {\n abstractMethodFail('Clock.zone');\n };\n\n _proto.withZone = function withZone() {\n abstractMethodFail('Clock.withZone');\n };\n\n return Clock;\n}();\n\nvar SystemClock = function (_Clock) {\n _inheritsLoose(SystemClock, _Clock);\n\n function SystemClock(zone) {\n var _this;\n\n requireNonNull(zone, 'zone');\n _this = _Clock.call(this) || this;\n _this._zone = zone;\n return _this;\n }\n\n var _proto2 = SystemClock.prototype;\n\n _proto2.zone = function zone() {\n return this._zone;\n };\n\n _proto2.millis = function millis() {\n return new Date().getTime();\n };\n\n _proto2.instant = function instant() {\n return Instant.ofEpochMilli(this.millis());\n };\n\n _proto2.equals = function equals(obj) {\n if (obj instanceof SystemClock) {\n return this._zone.equals(obj._zone);\n }\n\n return false;\n };\n\n _proto2.withZone = function withZone(zone) {\n if (zone.equals(this._zone)) {\n return this;\n }\n\n return new SystemClock(zone);\n };\n\n _proto2.toString = function toString() {\n return 'SystemClock[' + this._zone.toString() + ']';\n };\n\n return SystemClock;\n}(Clock);\n\nvar FixedClock = function (_Clock2) {\n _inheritsLoose(FixedClock, _Clock2);\n\n function FixedClock(fixedInstant, zoneId) {\n var _this2;\n\n _this2 = _Clock2.call(this) || this;\n _this2._instant = fixedInstant;\n _this2._zoneId = zoneId;\n return _this2;\n }\n\n var _proto3 = FixedClock.prototype;\n\n _proto3.instant = function instant() {\n return this._instant;\n };\n\n _proto3.millis = function millis() {\n return this._instant.toEpochMilli();\n };\n\n _proto3.zone = function zone() {\n return this._zoneId;\n };\n\n _proto3.toString = function toString() {\n return 'FixedClock[]';\n };\n\n _proto3.equals = function equals(obj) {\n if (obj instanceof FixedClock) {\n return this._instant.equals(obj._instant) && this._zoneId.equals(obj._zoneId);\n }\n\n return false;\n };\n\n _proto3.withZone = function withZone(zone) {\n if (zone.equals(this._zoneId)) {\n return this;\n }\n\n return new FixedClock(this._instant, zone);\n };\n\n return FixedClock;\n}(Clock);\n\nvar OffsetClock = function (_Clock3) {\n _inheritsLoose(OffsetClock, _Clock3);\n\n function OffsetClock(baseClock, offset) {\n var _this3;\n\n _this3 = _Clock3.call(this) || this;\n _this3._baseClock = baseClock;\n _this3._offset = offset;\n return _this3;\n }\n\n var _proto4 = OffsetClock.prototype;\n\n _proto4.zone = function zone() {\n return this._baseClock.zone();\n };\n\n _proto4.withZone = function withZone(zone) {\n if (zone.equals(this._baseClock.zone())) {\n return this;\n }\n\n return new OffsetClock(this._baseClock.withZone(zone), this._offset);\n };\n\n _proto4.millis = function millis() {\n return this._baseClock.millis() + this._offset.toMillis();\n };\n\n _proto4.instant = function instant() {\n return this._baseClock.instant().plus(this._offset);\n };\n\n _proto4.equals = function equals(obj) {\n if (obj instanceof OffsetClock) {\n return this._baseClock.equals(obj._baseClock) && this._offset.equals(obj._offset);\n }\n\n return false;\n };\n\n _proto4.toString = function toString() {\n return 'OffsetClock[' + this._baseClock + ',' + this._offset + ']';\n };\n\n return OffsetClock;\n}(Clock);\n\n/*\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar ZoneOffsetTransition = function () {\n ZoneOffsetTransition.of = function of(transition, offsetBefore, offsetAfter) {\n return new ZoneOffsetTransition(transition, offsetBefore, offsetAfter);\n };\n\n function ZoneOffsetTransition(transition, offsetBefore, offsetAfter) {\n requireNonNull(transition, 'transition');\n requireNonNull(offsetBefore, 'offsetBefore');\n requireNonNull(offsetAfter, 'offsetAfter');\n\n if (offsetBefore.equals(offsetAfter)) {\n throw new IllegalArgumentException('Offsets must not be equal');\n }\n\n if (transition.nano() !== 0) {\n throw new IllegalArgumentException('Nano-of-second must be zero');\n }\n\n if (transition instanceof LocalDateTime) {\n this._transition = transition;\n } else {\n this._transition = LocalDateTime.ofEpochSecond(transition, 0, offsetBefore);\n }\n\n this._offsetBefore = offsetBefore;\n this._offsetAfter = offsetAfter;\n }\n\n var _proto = ZoneOffsetTransition.prototype;\n\n _proto.instant = function instant() {\n return this._transition.toInstant(this._offsetBefore);\n };\n\n _proto.toEpochSecond = function toEpochSecond() {\n return this._transition.toEpochSecond(this._offsetBefore);\n };\n\n _proto.dateTimeBefore = function dateTimeBefore() {\n return this._transition;\n };\n\n _proto.dateTimeAfter = function dateTimeAfter() {\n return this._transition.plusSeconds(this.durationSeconds());\n };\n\n _proto.offsetBefore = function offsetBefore() {\n return this._offsetBefore;\n };\n\n _proto.offsetAfter = function offsetAfter() {\n return this._offsetAfter;\n };\n\n _proto.duration = function duration() {\n return Duration.ofSeconds(this.durationSeconds());\n };\n\n _proto.durationSeconds = function durationSeconds() {\n return this._offsetAfter.totalSeconds() - this._offsetBefore.totalSeconds();\n };\n\n _proto.isGap = function isGap() {\n return this._offsetAfter.totalSeconds() > this._offsetBefore.totalSeconds();\n };\n\n _proto.isOverlap = function isOverlap() {\n return this._offsetAfter.totalSeconds() < this._offsetBefore.totalSeconds();\n };\n\n _proto.isValidOffset = function isValidOffset(offset) {\n return this.isGap() ? false : this._offsetBefore.equals(offset) || this._offsetAfter.equals(offset);\n };\n\n _proto.validOffsets = function validOffsets() {\n if (this.isGap()) {\n return [];\n } else {\n return [this._offsetBefore, this._offsetAfter];\n }\n };\n\n _proto.compareTo = function compareTo(transition) {\n return this.instant().compareTo(transition.instant());\n };\n\n _proto.equals = function equals(other) {\n if (other === this) {\n return true;\n }\n\n if (other instanceof ZoneOffsetTransition) {\n var d = other;\n return this._transition.equals(d._transition) && this._offsetBefore.equals(d.offsetBefore()) && this._offsetAfter.equals(d.offsetAfter());\n }\n\n return false;\n };\n\n _proto.hashCode = function hashCode() {\n return this._transition.hashCode() ^ this._offsetBefore.hashCode() ^ this._offsetAfter.hashCode() >>> 16;\n };\n\n _proto.toString = function toString() {\n return 'Transition[' + (this.isGap() ? 'Gap' : 'Overlap') + ' at ' + this._transition.toString() + this._offsetBefore.toString() + ' to ' + this._offsetAfter + ']';\n };\n\n return ZoneOffsetTransition;\n}();\n\n/*\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nfunction _init$m() {\n TemporalQueries.ZONE_ID = createTemporalQuery('ZONE_ID', function (temporal) {\n return temporal.query(TemporalQueries.ZONE_ID);\n });\n TemporalQueries.CHRONO = createTemporalQuery('CHRONO', function (temporal) {\n return temporal.query(TemporalQueries.CHRONO);\n });\n TemporalQueries.PRECISION = createTemporalQuery('PRECISION', function (temporal) {\n return temporal.query(TemporalQueries.PRECISION);\n });\n TemporalQueries.OFFSET = createTemporalQuery('OFFSET', function (temporal) {\n if (temporal.isSupported(ChronoField.OFFSET_SECONDS)) {\n return ZoneOffset.ofTotalSeconds(temporal.get(ChronoField.OFFSET_SECONDS));\n }\n\n return null;\n });\n TemporalQueries.ZONE = createTemporalQuery('ZONE', function (temporal) {\n var zone = temporal.query(TemporalQueries.ZONE_ID);\n return zone != null ? zone : temporal.query(TemporalQueries.OFFSET);\n });\n TemporalQueries.LOCAL_DATE = createTemporalQuery('LOCAL_DATE', function (temporal) {\n if (temporal.isSupported(ChronoField.EPOCH_DAY)) {\n return LocalDate.ofEpochDay(temporal.getLong(ChronoField.EPOCH_DAY));\n }\n\n return null;\n });\n TemporalQueries.LOCAL_TIME = createTemporalQuery('LOCAL_TIME', function (temporal) {\n if (temporal.isSupported(ChronoField.NANO_OF_DAY)) {\n return LocalTime.ofNanoOfDay(temporal.getLong(ChronoField.NANO_OF_DAY));\n }\n\n return null;\n });\n}\n\nvar SystemDefaultZoneRules = function (_ZoneRules) {\n _inheritsLoose(SystemDefaultZoneRules, _ZoneRules);\n\n function SystemDefaultZoneRules() {\n return _ZoneRules.apply(this, arguments) || this;\n }\n\n var _proto = SystemDefaultZoneRules.prototype;\n\n _proto.isFixedOffset = function isFixedOffset() {\n return false;\n };\n\n _proto.offsetOfInstant = function offsetOfInstant(instant) {\n var offsetInMinutes = new Date(instant.toEpochMilli()).getTimezoneOffset();\n return ZoneOffset.ofTotalMinutes(offsetInMinutes * -1);\n };\n\n _proto.offsetOfEpochMilli = function offsetOfEpochMilli(epochMilli) {\n var offsetInMinutes = new Date(epochMilli).getTimezoneOffset();\n return ZoneOffset.ofTotalMinutes(offsetInMinutes * -1);\n };\n\n _proto.offsetOfLocalDateTime = function offsetOfLocalDateTime(localDateTime) {\n var epochMilli = localDateTime.toEpochSecond(ZoneOffset.UTC) * 1000;\n var offsetInMinutesBeforePossibleTransition = new Date(epochMilli).getTimezoneOffset();\n var epochMilliSystemZone = epochMilli + offsetInMinutesBeforePossibleTransition * 60000;\n var offsetInMinutesAfterPossibleTransition = new Date(epochMilliSystemZone).getTimezoneOffset();\n return ZoneOffset.ofTotalMinutes(offsetInMinutesAfterPossibleTransition * -1);\n };\n\n _proto.validOffsets = function validOffsets(localDateTime) {\n return [this.offsetOfLocalDateTime(localDateTime)];\n };\n\n _proto.transition = function transition() {\n return null;\n };\n\n _proto.standardOffset = function standardOffset(instant) {\n return this.offsetOfInstant(instant);\n };\n\n _proto.daylightSavings = function daylightSavings() {\n this._throwNotSupported();\n };\n\n _proto.isDaylightSavings = function isDaylightSavings() {\n this._throwNotSupported();\n };\n\n _proto.isValidOffset = function isValidOffset(dateTime, offset) {\n return this.offsetOfLocalDateTime(dateTime).equals(offset);\n };\n\n _proto.nextTransition = function nextTransition() {\n this._throwNotSupported();\n };\n\n _proto.previousTransition = function previousTransition() {\n this._throwNotSupported();\n };\n\n _proto.transitions = function transitions() {\n this._throwNotSupported();\n };\n\n _proto.transitionRules = function transitionRules() {\n this._throwNotSupported();\n };\n\n _proto._throwNotSupported = function _throwNotSupported() {\n throw new DateTimeException('not supported operation');\n };\n\n _proto.equals = function equals(other) {\n if (this === other || other instanceof SystemDefaultZoneRules) {\n return true;\n } else {\n return false;\n }\n };\n\n _proto.toString = function toString() {\n return 'SYSTEM';\n };\n\n return SystemDefaultZoneRules;\n}(ZoneRules);\n\nvar SystemDefaultZoneId = function (_ZoneId) {\n _inheritsLoose(SystemDefaultZoneId, _ZoneId);\n\n function SystemDefaultZoneId() {\n var _this;\n\n _this = _ZoneId.call(this) || this;\n _this._rules = new SystemDefaultZoneRules();\n return _this;\n }\n\n var _proto = SystemDefaultZoneId.prototype;\n\n _proto.rules = function rules() {\n return this._rules;\n };\n\n _proto.equals = function equals(other) {\n if (this === other) {\n return true;\n }\n\n return false;\n };\n\n _proto.id = function id() {\n return 'SYSTEM';\n };\n\n return SystemDefaultZoneId;\n}(ZoneId);\n\n/*\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar ZoneIdFactory = function () {\n function ZoneIdFactory() {}\n\n ZoneIdFactory.systemDefault = function systemDefault() {\n return SYSTEM_DEFAULT_ZONE_ID_INSTANCE;\n };\n\n ZoneIdFactory.getAvailableZoneIds = function getAvailableZoneIds() {\n return ZoneRulesProvider.getAvailableZoneIds();\n };\n\n ZoneIdFactory.of = function of(zoneId) {\n requireNonNull(zoneId, 'zoneId');\n\n if (zoneId === 'Z') {\n return ZoneOffset.UTC;\n }\n\n if (zoneId.length === 1) {\n throw new DateTimeException('Invalid zone: ' + zoneId);\n }\n\n if (StringUtil.startsWith(zoneId, '+') || StringUtil.startsWith(zoneId, '-')) {\n return ZoneOffset.of(zoneId);\n }\n\n if (zoneId === 'UTC' || zoneId === 'GMT' || zoneId === 'GMT0' || zoneId === 'UT') {\n return new ZoneRegion(zoneId, ZoneOffset.UTC.rules());\n }\n\n if (StringUtil.startsWith(zoneId, 'UTC+') || StringUtil.startsWith(zoneId, 'GMT+') || StringUtil.startsWith(zoneId, 'UTC-') || StringUtil.startsWith(zoneId, 'GMT-')) {\n var offset = ZoneOffset.of(zoneId.substring(3));\n\n if (offset.totalSeconds() === 0) {\n return new ZoneRegion(zoneId.substring(0, 3), offset.rules());\n }\n\n return new ZoneRegion(zoneId.substring(0, 3) + offset.id(), offset.rules());\n }\n\n if (StringUtil.startsWith(zoneId, 'UT+') || StringUtil.startsWith(zoneId, 'UT-')) {\n var _offset = ZoneOffset.of(zoneId.substring(2));\n\n if (_offset.totalSeconds() === 0) {\n return new ZoneRegion('UT', _offset.rules());\n }\n\n return new ZoneRegion('UT' + _offset.id(), _offset.rules());\n }\n\n if (zoneId === 'SYSTEM') {\n return ZoneId.systemDefault();\n }\n\n return ZoneRegion.ofId(zoneId);\n };\n\n ZoneIdFactory.ofOffset = function ofOffset(prefix, offset) {\n requireNonNull(prefix, 'prefix');\n requireNonNull(offset, 'offset');\n\n if (prefix.length === 0) {\n return offset;\n }\n\n if (prefix === 'GMT' || prefix === 'UTC' || prefix === 'UT') {\n if (offset.totalSeconds() === 0) {\n return new ZoneRegion(prefix, offset.rules());\n }\n\n return new ZoneRegion(prefix + offset.id(), offset.rules());\n }\n\n throw new IllegalArgumentException('Invalid prefix, must be GMT, UTC or UT: ' + prefix);\n };\n\n ZoneIdFactory.from = function from(temporal) {\n requireNonNull(temporal, 'temporal');\n var obj = temporal.query(TemporalQueries.zone());\n\n if (obj == null) {\n throw new DateTimeException('Unable to obtain ZoneId from TemporalAccessor: ' + temporal + ', type ' + (temporal.constructor != null ? temporal.constructor.name : ''));\n }\n\n return obj;\n };\n\n return ZoneIdFactory;\n}();\nvar SYSTEM_DEFAULT_ZONE_ID_INSTANCE = null;\nfunction _init$n() {\n SYSTEM_DEFAULT_ZONE_ID_INSTANCE = new SystemDefaultZoneId();\n ZoneId.systemDefault = ZoneIdFactory.systemDefault;\n ZoneId.getAvailableZoneIds = ZoneIdFactory.getAvailableZoneIds;\n ZoneId.of = ZoneIdFactory.of;\n ZoneId.ofOffset = ZoneIdFactory.ofOffset;\n ZoneId.from = ZoneIdFactory.from;\n ZoneOffset.from = ZoneIdFactory.from;\n ZoneId.SYSTEM = SYSTEM_DEFAULT_ZONE_ID_INSTANCE;\n ZoneId.UTC = ZoneOffset.ofTotalSeconds(0);\n}\n\n/*\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar isInit = false;\n\nfunction init() {\n if (isInit) {\n return;\n }\n\n isInit = true;\n _init$1();\n _init();\n _init$2();\n _init$3();\n _init$k();\n _init$8();\n _init$m();\n _init$4();\n _init$l();\n _init$i();\n _init$j();\n _init$d();\n _init$5();\n _init$c();\n _init$b();\n _init$6();\n _init$7();\n _init$g();\n _init$n();\n _init$e();\n _init$a();\n _init$9();\n _init$h();\n _init$f();\n}\n\ninit();\n\n/*\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\n\nvar ToNativeJsConverter = function () {\n function ToNativeJsConverter(temporal, zone) {\n var zonedDateTime;\n\n if (temporal instanceof LocalDate) {\n zone = zone == null ? ZoneId.systemDefault() : zone;\n zonedDateTime = temporal.atStartOfDay(zone);\n } else if (temporal instanceof LocalDateTime) {\n zone = zone == null ? ZoneId.systemDefault() : zone;\n zonedDateTime = temporal.atZone(zone);\n } else if (temporal instanceof ZonedDateTime) {\n if (zone == null) {\n zonedDateTime = temporal;\n } else {\n zonedDateTime = temporal.withZoneSameInstant(zone);\n }\n } else {\n throw new IllegalArgumentException('unsupported instance for convert operation:' + temporal);\n }\n\n this.instant = zonedDateTime.toInstant();\n }\n\n var _proto = ToNativeJsConverter.prototype;\n\n _proto.toDate = function toDate() {\n return new Date(this.instant.toEpochMilli());\n };\n\n _proto.toEpochMilli = function toEpochMilli() {\n return this.instant.toEpochMilli();\n };\n\n return ToNativeJsConverter;\n}();\n\nfunction convert(temporal, zone) {\n return new ToNativeJsConverter(temporal, zone);\n}\n\nvar NativeJsTemporal = function (_TemporalAccessor) {\n _inheritsLoose(NativeJsTemporal, _TemporalAccessor);\n\n function NativeJsTemporal(date, zone) {\n var _this;\n\n if (zone === void 0) {\n zone = ZoneId.systemDefault();\n }\n\n _this = _TemporalAccessor.call(this) || this;\n _this._zone = zone;\n\n if (date instanceof Date) {\n _this._epochMilli = date.getTime();\n return _assertThisInitialized(_this);\n } else if (typeof date.toDate === 'function' && date.toDate() instanceof Date) {\n _this._epochMilli = date.toDate().getTime();\n return _assertThisInitialized(_this);\n }\n\n assert(false, 'date must be either a javascript date or a moment');\n return _this;\n }\n\n var _proto = NativeJsTemporal.prototype;\n\n _proto.query = function query(_query) {\n requireNonNull(_query, 'query');\n\n if (_query === TemporalQueries.localDate()) {\n return LocalDate.ofInstant(Instant.ofEpochMilli(this._epochMilli), this._zone);\n } else if (_query === TemporalQueries.localTime()) {\n return LocalTime.ofInstant(Instant.ofEpochMilli(this._epochMilli), this._zone);\n } else if (_query === TemporalQueries.zone()) {\n return this._zone;\n }\n\n return _TemporalAccessor.prototype.query.call(this, _query);\n };\n\n _proto.get = function get(field) {\n return this.getLong(field);\n };\n\n _proto.getLong = function getLong(field) {\n requireNonNull(field, 'field');\n\n if (field instanceof ChronoField) {\n switch (field) {\n case ChronoField.NANO_OF_SECOND:\n return MathUtil.floorMod(this._epochMilli, 1000) * 1000000;\n\n case ChronoField.INSTANT_SECONDS:\n return MathUtil.floorDiv(this._epochMilli, 1000);\n }\n\n throw new UnsupportedTemporalTypeException('Unsupported field: ' + field);\n }\n\n return field.getFrom(this);\n };\n\n _proto.isSupported = function isSupported(field) {\n return field === ChronoField.INSTANT_SECONDS || field === ChronoField.NANO_OF_SECOND;\n };\n\n return NativeJsTemporal;\n}(TemporalAccessor);\n\nfunction nativeJs(date, zone) {\n return new NativeJsTemporal(date, zone);\n}\n\nfunction bindUse(jsJoda) {\n var used = [];\n return function use(fn) {\n if (!~used.indexOf(fn)) {\n fn(jsJoda);\n used.push(fn);\n }\n\n return jsJoda;\n };\n}\n\n/**\n * @copyright (c) 2016, Philipp Thürwächter & Pattrick Hüper\n * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n */\nvar _ = {\n assert: assert$1,\n DateTimeBuilder: DateTimeBuilder,\n DateTimeParseContext: DateTimeParseContext,\n DateTimePrintContext: DateTimePrintContext,\n MathUtil: MathUtil,\n StringUtil: StringUtil,\n StringBuilder: StringBuilder\n};\nvar jsJodaExports = {\n _: _,\n convert: convert,\n nativeJs: nativeJs,\n ArithmeticException: ArithmeticException,\n DateTimeException: DateTimeException,\n DateTimeParseException: DateTimeParseException,\n IllegalArgumentException: IllegalArgumentException,\n IllegalStateException: IllegalStateException,\n UnsupportedTemporalTypeException: UnsupportedTemporalTypeException,\n NullPointerException: NullPointerException,\n Clock: Clock,\n DayOfWeek: DayOfWeek,\n Duration: Duration,\n Instant: Instant,\n LocalDate: LocalDate,\n LocalTime: LocalTime,\n LocalDateTime: LocalDateTime,\n OffsetTime: OffsetTime,\n OffsetDateTime: OffsetDateTime,\n Month: Month,\n MonthDay: MonthDay,\n Period: Period,\n Year: Year,\n YearConstants: YearConstants,\n YearMonth: YearMonth,\n ZonedDateTime: ZonedDateTime,\n ZoneOffset: ZoneOffset,\n ZoneId: ZoneId,\n ZoneRegion: ZoneRegion,\n ZoneOffsetTransition: ZoneOffsetTransition,\n ZoneRules: ZoneRules,\n ZoneRulesProvider: ZoneRulesProvider,\n ChronoLocalDate: ChronoLocalDate,\n ChronoLocalDateTime: ChronoLocalDateTime,\n ChronoZonedDateTime: ChronoZonedDateTime,\n IsoChronology: IsoChronology,\n ChronoField: ChronoField,\n ChronoUnit: ChronoUnit,\n IsoFields: IsoFields,\n Temporal: Temporal,\n TemporalAccessor: TemporalAccessor,\n TemporalAdjuster: TemporalAdjuster,\n TemporalAdjusters: TemporalAdjusters,\n TemporalAmount: TemporalAmount,\n TemporalField: TemporalField,\n TemporalQueries: TemporalQueries,\n TemporalQuery: TemporalQuery,\n TemporalUnit: TemporalUnit,\n ValueRange: ValueRange,\n DateTimeFormatter: DateTimeFormatter,\n DateTimeFormatterBuilder: DateTimeFormatterBuilder,\n DecimalStyle: DecimalStyle,\n ResolverStyle: ResolverStyle,\n SignStyle: SignStyle,\n TextStyle: TextStyle\n};\nvar use = bindUse(jsJodaExports);\njsJodaExports.use = use;\n\nexport { ArithmeticException, ChronoField, ChronoLocalDate, ChronoLocalDateTime, ChronoUnit, ChronoZonedDateTime, Clock, DateTimeException, DateTimeFormatter, DateTimeFormatterBuilder, DateTimeParseException, DayOfWeek, DecimalStyle, Duration, IllegalArgumentException, IllegalStateException, Instant, IsoChronology, IsoFields, LocalDate, LocalDateTime, LocalTime, Month, MonthDay, NullPointerException, OffsetDateTime, OffsetTime, Period, ResolverStyle, SignStyle, Temporal, TemporalAccessor, TemporalAdjuster, TemporalAdjusters, TemporalAmount, TemporalField, TemporalQueries, TemporalQuery, TemporalUnit, TextStyle, UnsupportedTemporalTypeException, ValueRange, Year, YearConstants, YearMonth, ZoneId, ZoneOffset, ZoneOffsetTransition, ZoneRegion, ZoneRules, ZoneRulesProvider, ZonedDateTime, _, convert, nativeJs, use };\n","//! @version @js-joda/timezone - 2.12.2-2021e\n//! @copyright (c) 2015-present, Philipp Thürwächter, Pattrick Hüper & js-joda contributors\n//! @copyright (c) 2007-present, Stephen Colebourne & Michael Nascimento Santos\n//! @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n\n(function (global, factory) {\n\ttypeof exports === 'object' && typeof module !== 'undefined' ? factory(require('@js-joda/core')) :\n\ttypeof define === 'function' && define.amd ? define(['@js-joda/core'], factory) :\n\t(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global.JSJoda));\n})(this, (function (core) { 'use strict';\n\n\tvar version = \"2021e\";\n\tvar zones$1 = [\n\t\t\"Africa/Abidjan|LMT GMT|g.8 0|01|-2ldXH.Q|48e5\",\n\t\t\"Africa/Nairobi|LMT +0230 EAT +0245|-2r.g -2u -30 -2J|012132|-2ua2r.g N6nV.g 3Fbu h1cu dzbJ|47e5\",\n\t\t\"Africa/Algiers|PMT WET WEST CET CEST|-9.l 0 -10 -10 -20|0121212121212121343431312123431213|-2nco9.l cNb9.l HA0 19A0 1iM0 11c0 1oo0 Wo0 1rc0 QM0 1EM0 UM0 DA0 Imo0 rd0 De0 9Xz0 1fb0 1ap0 16K0 2yo0 mEp0 hwL0 jxA0 11A0 dDd0 17b0 11B0 1cN0 2Dy0 1cN0 1fB0 1cL0|26e5\",\n\t\t\"Africa/Lagos|LMT GMT +0030 WAT|-d.z 0 -u -10|01023|-2B40d.z 7iod.z dnXK.p dLzH.z|17e6\",\n\t\t\"Africa/Bissau|LMT -01 GMT|12.k 10 0|012|-2ldX0 2xoo0|39e4\",\n\t\t\"Africa/Maputo|LMT CAT|-2a.k -20|01|-2GJea.k|26e5\",\n\t\t\"Africa/Cairo|EET EEST|-20 -30|0101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-1bIO0 vb0 1ip0 11z0 1iN0 1nz0 12p0 1pz0 10N0 1pz0 16p0 1jz0 s3d0 Vz0 1oN0 11b0 1oO0 10N0 1pz0 10N0 1pb0 10N0 1pb0 10N0 1pb0 10N0 1pz0 10N0 1pb0 10N0 1pb0 11d0 1oL0 11d0 1pb0 11d0 1oL0 11d0 1oL0 11d0 1oL0 11d0 1pb0 11d0 1oL0 11d0 1oL0 11d0 1oL0 11d0 1pb0 11d0 1oL0 11d0 1oL0 11d0 1oL0 11d0 1pb0 11d0 1oL0 11d0 1WL0 rd0 1Rz0 wp0 1pb0 11d0 1oL0 11d0 1oL0 11d0 1oL0 11d0 1pb0 11d0 1qL0 Xd0 1oL0 11d0 1oL0 11d0 1pb0 11d0 1oL0 11d0 1oL0 11d0 1ny0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 11z0 1o10 11z0 1o10 WL0 1qN0 Rb0 1wp0 On0 1zd0 Lz0 1EN0 Fb0 c10 8n0 8Nd0 gL0 e10 mn0|15e6\",\n\t\t\"Africa/Casablanca|LMT +00 +01|u.k 0 -10|01212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212|-2gMnt.E 130Lt.E rb0 Dd0 dVb0 b6p0 TX0 EoB0 LL0 gnd0 rz0 43d0 AL0 1Nd0 XX0 1Cp0 pz0 dEp0 4mn0 SyN0 AL0 1Nd0 wn0 1FB0 Db0 1zd0 Lz0 1Nf0 wM0 co0 go0 1o00 s00 dA0 vc0 11A0 A00 e00 y00 11A0 uM0 e00 Dc0 11A0 s00 e00 IM0 WM0 mo0 gM0 LA0 WM0 jA0 e00 28M0 e00 2600 gM0 2600 e00 2600 gM0 2600 gM0 2600 e00 2600 gM0 2600 e00 28M0 e00 2600 gM0 2600 e00 2600 gM0 2600 gM0 2600 e00 2600 gM0 2600 e00 2600 gM0 2600 gM0 2600 e00 2600 gM0|32e5\",\n\t\t\"Africa/Ceuta|WET WEST CET CEST|0 -10 -10 -20|010101010101010101010232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232|-25KN0 11z0 drd0 18p0 3HX0 17d0 1fz0 1a10 1io0 1a00 1y7o0 LL0 gnd0 rz0 43d0 AL0 1Nd0 XX0 1Cp0 pz0 dEp0 4VB0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|85e3\",\n\t\t\"Africa/El_Aaiun|LMT -01 +00 +01|Q.M 10 0 -10|012323232323232323232323232323232323232323232323232323232323232323232323232323232323|-1rDz7.c 1GVA7.c 6L0 AL0 1Nd0 XX0 1Cp0 pz0 1cBB0 AL0 1Nd0 wn0 1FB0 Db0 1zd0 Lz0 1Nf0 wM0 co0 go0 1o00 s00 dA0 vc0 11A0 A00 e00 y00 11A0 uM0 e00 Dc0 11A0 s00 e00 IM0 WM0 mo0 gM0 LA0 WM0 jA0 e00 28M0 e00 2600 gM0 2600 e00 2600 gM0 2600 gM0 2600 e00 2600 gM0 2600 e00 28M0 e00 2600 gM0 2600 e00 2600 gM0 2600 gM0 2600 e00 2600 gM0 2600 e00 2600 gM0 2600 gM0 2600 e00 2600 gM0|20e4\",\n\t\t\"Africa/Johannesburg|SAST SAST SAST|-1u -20 -30|012121|-2GJdu 1Ajdu 1cL0 1cN0 1cL0|84e5\",\n\t\t\"Africa/Juba|LMT CAT CAST EAT|-26.s -20 -30 -30|012121212121212121212121212121212131|-1yW26.s 1zK06.s 16L0 1iN0 17b0 1jd0 17b0 1ip0 17z0 1i10 17X0 1hB0 18n0 1hd0 19b0 1gp0 19z0 1iN0 17b0 1ip0 17z0 1i10 18n0 1hd0 18L0 1gN0 19b0 1gp0 19z0 1iN0 17z0 1i10 17X0 yGd0 PeX0|\",\n\t\t\"Africa/Khartoum|LMT CAT CAST EAT|-2a.8 -20 -30 -30|012121212121212121212121212121212131|-1yW2a.8 1zK0a.8 16L0 1iN0 17b0 1jd0 17b0 1ip0 17z0 1i10 17X0 1hB0 18n0 1hd0 19b0 1gp0 19z0 1iN0 17b0 1ip0 17z0 1i10 18n0 1hd0 18L0 1gN0 19b0 1gp0 19z0 1iN0 17z0 1i10 17X0 yGd0 HjL0|51e5\",\n\t\t\"Africa/Monrovia|MMT MMT GMT|H.8 I.u 0|012|-23Lzg.Q 28G01.m|11e5\",\n\t\t\"Africa/Ndjamena|LMT WAT WAST|-10.c -10 -20|0121|-2le10.c 2J3c0.c Wn0|13e5\",\n\t\t\"Africa/Sao_Tome|LMT GMT WAT|A.J 0 -10|0121|-2le00 4i6N0 2q00|\",\n\t\t\"Africa/Tripoli|LMT CET CEST EET|-Q.I -10 -20 -20|012121213121212121212121213123123|-21JcQ.I 1hnBQ.I vx0 4iP0 xx0 4eN0 Bb0 7ip0 U0n0 A10 1db0 1cN0 1db0 1dd0 1db0 1eN0 1bb0 1e10 1cL0 1c10 1db0 1dd0 1db0 1cN0 1db0 1q10 fAn0 1ep0 1db0 AKq0 TA0 1o00|11e5\",\n\t\t\"Africa/Tunis|PMT CET CEST|-9.l -10 -20|0121212121212121212121212121212121|-2nco9.l 18pa9.l 1qM0 DA0 3Tc0 11B0 1ze0 WM0 7z0 3d0 14L0 1cN0 1f90 1ar0 16J0 1gXB0 WM0 1rA0 11c0 nwo0 Ko0 1cM0 1cM0 1rA0 10M0 zuM0 10N0 1aN0 1qM0 WM0 1qM0 11A0 1o00|20e5\",\n\t\t\"Africa/Windhoek|+0130 SAST SAST CAT WAT|-1u -20 -30 -20 -10|01213434343434343434343434343434343434343434343434343|-2GJdu 1Ajdu 1cL0 1SqL0 9Io0 16P0 1nX0 11B0 1qL0 WN0 1qL0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1qL0 WN0 1qL0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1qL0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1qL0 WN0 1qL0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0|32e4\",\n\t\t\"America/Adak|NST NWT NPT BST BDT AHST HST HDT|b0 a0 a0 b0 a0 a0 a0 90|012034343434343434343434343434343456767676767676767676767676767676767676767676767676767676767676767676767676767676767676767676767676767676767676|-17SX0 8wW0 iB0 Qlb0 52O0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 cm0 10q0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|326\",\n\t\t\"America/Anchorage|AST AWT APT AHST AHDT YST AKST AKDT|a0 90 90 a0 90 90 90 80|012034343434343434343434343434343456767676767676767676767676767676767676767676767676767676767676767676767676767676767676767676767676767676767676|-17T00 8wX0 iA0 Qlb0 52O0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 cm0 10q0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|30e4\",\n\t\t\"America/Puerto_Rico|AST AWT APT|40 30 30|0120|-17lU0 7XT0 iu0|24e5\",\n\t\t\"America/Araguaina|LMT -03 -02|3c.M 30 20|0121212121212121212121212121212121212121212121212121|-2glwL.c HdKL.c 1cc0 1e10 1bX0 Ezd0 So0 1vA0 Mn0 1BB0 ML0 1BB0 zX0 qe10 xb0 2ep0 nz0 1C10 zX0 1C10 LX0 1C10 Mn0 H210 Rb0 1tB0 IL0 1Fd0 FX0 1EN0 FX0 1HB0 Lz0 dMN0 Lz0 1zd0 Rb0 1wN0 Wn0 1tB0 Rb0 1tB0 WL0 1tB0 Rb0 1zd0 On0 1HB0 FX0 ny10 Lz0|14e4\",\n\t\t\"America/Argentina/Buenos_Aires|CMT -04 -03 -02|4g.M 40 30 20|01212121212121212121212121212121212121212123232323232323232|-20UHH.c pKnH.c Mn0 1iN0 Tb0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 MN0 2jz0 MN0 4lX0 u10 5Lb0 1pB0 Fnz0 u10 uL0 1vd0 SL0 1vd0 SL0 1vd0 17z0 1cN0 1fz0 1cN0 1cL0 1cN0 asn0 Db0 zvd0 Bz0 1tB0 TX0 1wp0 Rb0 1wp0 Rb0 1wp0 TX0 A4p0 uL0 1qN0 WL0|\",\n\t\t\"America/Argentina/Catamarca|CMT -04 -03 -02|4g.M 40 30 20|01212121212121212121212121212121212121212123232323132321232|-20UHH.c pKnH.c Mn0 1iN0 Tb0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 MN0 2jz0 MN0 4lX0 u10 5Lb0 1pB0 Fnz0 u10 uL0 1vd0 SL0 1vd0 SL0 1vd0 17z0 1cN0 1fz0 1cN0 1cL0 1cN0 asn0 Db0 zvd0 Bz0 1tB0 TX0 1wp0 Rb0 1wq0 Ra0 1wp0 TX0 rlB0 7B0 8zb0 uL0|\",\n\t\t\"America/Argentina/Cordoba|CMT -04 -03 -02|4g.M 40 30 20|01212121212121212121212121212121212121212123232323132323232|-20UHH.c pKnH.c Mn0 1iN0 Tb0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 MN0 2jz0 MN0 4lX0 u10 5Lb0 1pB0 Fnz0 u10 uL0 1vd0 SL0 1vd0 SL0 1vd0 17z0 1cN0 1fz0 1cN0 1cL0 1cN0 asn0 Db0 zvd0 Bz0 1tB0 TX0 1wp0 Rb0 1wq0 Ra0 1wp0 TX0 A4p0 uL0 1qN0 WL0|\",\n\t\t\"America/Argentina/Jujuy|CMT -04 -03 -02|4g.M 40 30 20|012121212121212121212121212121212121212121232323121323232|-20UHH.c pKnH.c Mn0 1iN0 Tb0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 MN0 2jz0 MN0 4lX0 u10 5Lb0 1pB0 Fnz0 u10 uL0 1vd0 SL0 1vd0 SL0 1vd0 17z0 1cN0 1fz0 1cN0 1cL0 1cN0 asn0 Db0 zvd0 Bz0 1tB0 TX0 1ze0 TX0 1ld0 WK0 1wp0 TX0 A4p0 uL0|\",\n\t\t\"America/Argentina/La_Rioja|CMT -04 -03 -02|4g.M 40 30 20|012121212121212121212121212121212121212121232323231232321232|-20UHH.c pKnH.c Mn0 1iN0 Tb0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 MN0 2jz0 MN0 4lX0 u10 5Lb0 1pB0 Fnz0 u10 uL0 1vd0 SL0 1vd0 SL0 1vd0 17z0 1cN0 1fz0 1cN0 1cL0 1cN0 asn0 Db0 zvd0 Bz0 1tB0 TX0 1wp0 Qn0 qO0 16n0 Rb0 1wp0 TX0 rlB0 7B0 8zb0 uL0|\",\n\t\t\"America/Argentina/Mendoza|CMT -04 -03 -02|4g.M 40 30 20|01212121212121212121212121212121212121212123232312121321232|-20UHH.c pKnH.c Mn0 1iN0 Tb0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 MN0 2jz0 MN0 4lX0 u10 5Lb0 1pB0 Fnz0 u10 uL0 1vd0 SL0 1vd0 SL0 1vd0 17z0 1cN0 1fz0 1cN0 1cL0 1cN0 asn0 Db0 zvd0 Bz0 1tB0 TX0 1u20 SL0 1vd0 Tb0 1wp0 TW0 ri10 Op0 7TX0 uL0|\",\n\t\t\"America/Argentina/Rio_Gallegos|CMT -04 -03 -02|4g.M 40 30 20|01212121212121212121212121212121212121212123232323232321232|-20UHH.c pKnH.c Mn0 1iN0 Tb0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 MN0 2jz0 MN0 4lX0 u10 5Lb0 1pB0 Fnz0 u10 uL0 1vd0 SL0 1vd0 SL0 1vd0 17z0 1cN0 1fz0 1cN0 1cL0 1cN0 asn0 Db0 zvd0 Bz0 1tB0 TX0 1wp0 Rb0 1wp0 Rb0 1wp0 TX0 rlB0 7B0 8zb0 uL0|\",\n\t\t\"America/Argentina/Salta|CMT -04 -03 -02|4g.M 40 30 20|012121212121212121212121212121212121212121232323231323232|-20UHH.c pKnH.c Mn0 1iN0 Tb0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 MN0 2jz0 MN0 4lX0 u10 5Lb0 1pB0 Fnz0 u10 uL0 1vd0 SL0 1vd0 SL0 1vd0 17z0 1cN0 1fz0 1cN0 1cL0 1cN0 asn0 Db0 zvd0 Bz0 1tB0 TX0 1wp0 Rb0 1wq0 Ra0 1wp0 TX0 A4p0 uL0|\",\n\t\t\"America/Argentina/San_Juan|CMT -04 -03 -02|4g.M 40 30 20|012121212121212121212121212121212121212121232323231232321232|-20UHH.c pKnH.c Mn0 1iN0 Tb0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 MN0 2jz0 MN0 4lX0 u10 5Lb0 1pB0 Fnz0 u10 uL0 1vd0 SL0 1vd0 SL0 1vd0 17z0 1cN0 1fz0 1cN0 1cL0 1cN0 asn0 Db0 zvd0 Bz0 1tB0 TX0 1wp0 Qn0 qO0 16n0 Rb0 1wp0 TX0 rld0 m10 8lb0 uL0|\",\n\t\t\"America/Argentina/San_Luis|CMT -04 -03 -02|4g.M 40 30 20|012121212121212121212121212121212121212121232323121212321212|-20UHH.c pKnH.c Mn0 1iN0 Tb0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 MN0 2jz0 MN0 4lX0 u10 5Lb0 1pB0 Fnz0 u10 uL0 1vd0 SL0 1vd0 SL0 1vd0 17z0 1cN0 1fz0 1cN0 1cL0 1cN0 asn0 Db0 zvd0 Bz0 1tB0 XX0 1q20 SL0 AN0 vDb0 m10 8lb0 8L0 jd0 1qN0 WL0 1qN0|\",\n\t\t\"America/Argentina/Tucuman|CMT -04 -03 -02|4g.M 40 30 20|0121212121212121212121212121212121212121212323232313232123232|-20UHH.c pKnH.c Mn0 1iN0 Tb0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 MN0 2jz0 MN0 4lX0 u10 5Lb0 1pB0 Fnz0 u10 uL0 1vd0 SL0 1vd0 SL0 1vd0 17z0 1cN0 1fz0 1cN0 1cL0 1cN0 asn0 Db0 zvd0 Bz0 1tB0 TX0 1wp0 Rb0 1wq0 Ra0 1wp0 TX0 rlB0 4N0 8BX0 uL0 1qN0 WL0|\",\n\t\t\"America/Argentina/Ushuaia|CMT -04 -03 -02|4g.M 40 30 20|01212121212121212121212121212121212121212123232323232321232|-20UHH.c pKnH.c Mn0 1iN0 Tb0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 1C10 LX0 1C10 LX0 1C10 LX0 1C10 Mn0 MN0 2jz0 MN0 4lX0 u10 5Lb0 1pB0 Fnz0 u10 uL0 1vd0 SL0 1vd0 SL0 1vd0 17z0 1cN0 1fz0 1cN0 1cL0 1cN0 asn0 Db0 zvd0 Bz0 1tB0 TX0 1wp0 Rb0 1wp0 Rb0 1wp0 TX0 rkN0 8p0 8zb0 uL0|\",\n\t\t\"America/Asuncion|AMT -04 -03|3O.E 40 30|012121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212|-1x589.k 1DKM9.k 3CL0 3Dd0 10L0 1pB0 10n0 1pB0 10n0 1pB0 1cL0 1dd0 1db0 1dd0 1cL0 1dd0 1cL0 1dd0 1cL0 1dd0 1db0 1dd0 1cL0 1dd0 1cL0 1dd0 1cL0 1dd0 1db0 1dd0 1cL0 1lB0 14n0 1dd0 1cL0 1fd0 WL0 1rd0 1aL0 1dB0 Xz0 1qp0 Xb0 1qN0 10L0 1rB0 TX0 1tB0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1qN0 1cL0 WN0 1qL0 11B0 1nX0 1ip0 WL0 1qN0 WL0 1qN0 WL0 1tB0 TX0 1tB0 TX0 1tB0 19X0 1a10 1fz0 1a10 1fz0 1cN0 17b0 1ip0 17b0 1ip0 17b0 1ip0 19X0 1fB0 19X0 1fB0 19X0 1ip0 17b0 1ip0 17b0 1ip0 19X0 1fB0 19X0 1fB0 19X0 1fB0 19X0 1ip0 17b0 1ip0 17b0 1ip0 19X0 1fB0 19X0 1fB0 19X0 1ip0 17b0 1ip0 17b0 1ip0 19X0 1fB0 19X0 1fB0 19X0 1fB0 19X0 1ip0 17b0 1ip0 17b0 1ip0|28e5\",\n\t\t\"America/Panama|CMT EST|5j.A 50|01|-2uduE.o|15e5\",\n\t\t\"America/Bahia_Banderas|LMT MST CST PST MDT CDT|71 70 60 80 60 50|0121212131414141414141414141414141414152525252525252525252525252525252525252525252525252525252|-1UQF0 deL0 8lc0 17c0 10M0 1dd0 otX0 gmN0 P2N0 13Vd0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 1fB0 WL0 1fB0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nW0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0|84e3\",\n\t\t\"America/Bahia|LMT -03 -02|2y.4 30 20|01212121212121212121212121212121212121212121212121212121212121|-2glxp.U HdLp.U 1cc0 1e10 1bX0 Ezd0 So0 1vA0 Mn0 1BB0 ML0 1BB0 zX0 qe10 xb0 2ep0 nz0 1C10 zX0 1C10 LX0 1C10 Mn0 H210 Rb0 1tB0 IL0 1Fd0 FX0 1EN0 FX0 1HB0 Lz0 1EN0 Lz0 1C10 IL0 1HB0 Db0 1HB0 On0 1zd0 On0 1zd0 Lz0 1zd0 Rb0 1wN0 Wn0 1tB0 Rb0 1tB0 WL0 1tB0 Rb0 1zd0 On0 1HB0 FX0 l5B0 Rb0|27e5\",\n\t\t\"America/Barbados|LMT AST ADT -0330|3W.t 40 30 3u|0121213121212121|-2m4k1.v 1eAN1.v RB0 1Bz0 Op0 1rb0 11d0 1jJc0 IL0 1ip0 17b0 1ip0 17b0 1ld0 13b0|28e4\",\n\t\t\"America/Belem|LMT -03 -02|3d.U 30 20|012121212121212121212121212121|-2glwK.4 HdKK.4 1cc0 1e10 1bX0 Ezd0 So0 1vA0 Mn0 1BB0 ML0 1BB0 zX0 qe10 xb0 2ep0 nz0 1C10 zX0 1C10 LX0 1C10 Mn0 H210 Rb0 1tB0 IL0 1Fd0 FX0|20e5\",\n\t\t\"America/Belize|LMT CST -0530 CWT CPT CDT|5Q.M 60 5u 50 50 50|012121212121212121212121212121212121212121212121213412121212121212121212121212121212121212121215151|-2kBu7.c fPA7.c Onu 1zcu Rbu 1wou Rbu 1wou Rbu 1zcu Onu 1zcu Onu 1zcu Rbu 1wou Rbu 1wou Rbu 1wou Rbu 1zcu Onu 1zcu Onu 1zcu Rbu 1wou Rbu 1wou Rbu 1zcu Onu 1zcu Onu 1zcu Onu 1zcu Rbu 1wou Rbu 1wou Rbu 1zcu Onu 1zcu Onu 1zcu Rbu Rcu 7Bt0 Ni0 4nd0 Rbu 1wou Rbu 1wou Rbu 1zcu Onu 1zcu Onu 1zcu Rbu 1wou Rbu 1wou Rbu 1wou Rbu 1zcu Onu 1zcu Onu 1zcu Rbu 1wou Rbu 1wou Rbu 1zcu Onu 1zcu Onu 1zcu Onu 1zcu Rbu 1wou Rbu 1wou Rbu 1zcu Onu e9Au qn0 lxB0 mn0|57e3\",\n\t\t\"America/Boa_Vista|LMT -04 -03|42.E 40 30|0121212121212121212121212121212121|-2glvV.k HdKV.k 1cc0 1e10 1bX0 Ezd0 So0 1vA0 Mn0 1BB0 ML0 1BB0 zX0 qe10 xb0 2ep0 nz0 1C10 zX0 1C10 LX0 1C10 Mn0 H210 Rb0 1tB0 IL0 1Fd0 FX0 smp0 WL0 1tB0 2L0|62e2\",\n\t\t\"America/Bogota|BMT -05 -04|4U.g 50 40|0121|-2eb73.I 38yo3.I 2en0|90e5\",\n\t\t\"America/Boise|PST PDT MST MWT MPT MDT|80 70 70 60 60 60|0101023425252525252525252525252525252525252525252525252525252525252525252525252525252525252525252525252525252525252525252525252525252525252525252525252|-261q0 1nX0 11B0 1nX0 8C10 JCL0 8x20 ix0 QwN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 Dd0 1Kn0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|21e4\",\n\t\t\"America/Cambridge_Bay|-00 MST MWT MPT MDDT MDT CST CDT EST|0 70 60 60 50 60 60 50 50|0123141515151515151515151515151515151515151515678651515151515151515151515151515151515151515151515151515151515151515151515151|-21Jc0 RO90 8x20 ix0 LCL0 1fA0 zgO0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11A0 1nX0 2K0 WQ0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|15e2\",\n\t\t\"America/Campo_Grande|LMT -04 -03|3C.s 40 30|01212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-2glwl.w HdLl.w 1cc0 1e10 1bX0 Ezd0 So0 1vA0 Mn0 1BB0 ML0 1BB0 zX0 qe10 xb0 2ep0 nz0 1C10 zX0 1C10 LX0 1C10 Mn0 H210 Rb0 1tB0 IL0 1Fd0 FX0 1EN0 FX0 1HB0 Lz0 1EN0 Lz0 1C10 IL0 1HB0 Db0 1HB0 On0 1zd0 On0 1zd0 Lz0 1zd0 Rb0 1wN0 Wn0 1tB0 Rb0 1tB0 WL0 1tB0 Rb0 1zd0 On0 1HB0 FX0 1C10 Lz0 1Ip0 HX0 1zd0 On0 1HB0 IL0 1wp0 On0 1C10 Lz0 1C10 On0 1zd0 On0 1zd0 Rb0 1zd0 Lz0 1C10 Lz0 1C10 On0 1zd0 On0 1zd0 On0 1zd0 On0 1HB0 FX0|77e4\",\n\t\t\"America/Cancun|LMT CST EST EDT CDT|5L.4 60 50 40 50|0123232341414141414141414141414141414141412|-1UQG0 2q2o0 yLB0 1lb0 14p0 1lb0 14p0 Lz0 xB0 14p0 1nX0 11B0 1nX0 1fB0 WL0 1fB0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 Dd0|63e4\",\n\t\t\"America/Caracas|CMT -0430 -04|4r.E 4u 40|01212|-2kV7w.k 28KM2.k 1IwOu kqo0|29e5\",\n\t\t\"America/Cayenne|LMT -04 -03|3t.k 40 30|012|-2mrwu.E 2gWou.E|58e3\",\n\t\t\"America/Chicago|CST CDT EST CWT CPT|60 50 50 50 50|01010101010101010101010101010101010102010101010103401010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-261s0 1nX0 11B0 1nX0 1wp0 TX0 WN0 1qL0 1cN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 11z0 1o10 11z0 11B0 1Hz0 14p0 11z0 1o10 11z0 1qN0 WL0 1qN0 11z0 1o10 11z0 RB0 8x30 iw0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|92e5\",\n\t\t\"America/Chihuahua|LMT MST CST CDT MDT|74.k 70 60 50 60|0121212323241414141414141414141414141414141414141414141414141414141414141414141414141414141|-1UQF0 deL0 8lc0 17c0 10M0 1dd0 2zQN0 1lb0 14p0 1lb0 14q0 1lb0 14p0 1nX0 11B0 1nX0 1fB0 WL0 1fB0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0|81e4\",\n\t\t\"America/Costa_Rica|SJMT CST CDT|5A.d 60 50|0121212121|-1Xd6n.L 2lu0n.L Db0 1Kp0 Db0 pRB0 15b0 1kp0 mL0|12e5\",\n\t\t\"America/Phoenix|MST MDT MWT|70 60 60|01010202010|-261r0 1nX0 11B0 1nX0 SgN0 4Al1 Ap0 1db0 SWqX 1cL0|42e5\",\n\t\t\"America/Cuiaba|LMT -04 -03|3I.k 40 30|012121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-2glwf.E HdLf.E 1cc0 1e10 1bX0 Ezd0 So0 1vA0 Mn0 1BB0 ML0 1BB0 zX0 qe10 xb0 2ep0 nz0 1C10 zX0 1C10 LX0 1C10 Mn0 H210 Rb0 1tB0 IL0 1Fd0 FX0 1EN0 FX0 1HB0 Lz0 1EN0 Lz0 1C10 IL0 1HB0 Db0 1HB0 On0 1zd0 On0 1zd0 Lz0 1zd0 Rb0 1wN0 Wn0 1tB0 Rb0 1tB0 WL0 1tB0 Rb0 1zd0 On0 1HB0 FX0 4a10 HX0 1zd0 On0 1HB0 IL0 1wp0 On0 1C10 Lz0 1C10 On0 1zd0 On0 1zd0 Rb0 1zd0 Lz0 1C10 Lz0 1C10 On0 1zd0 On0 1zd0 On0 1zd0 On0 1HB0 FX0|54e4\",\n\t\t\"America/Danmarkshavn|LMT -03 -02 GMT|1e.E 30 20 0|01212121212121212121212121212121213|-2a5WJ.k 2z5fJ.k 19U0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 DC0|8\",\n\t\t\"America/Dawson_Creek|PST PDT PWT PPT MST|80 70 70 70 70|0102301010101010101010101010101010101010101010101010101014|-25TO0 1in0 UGp0 8x10 iy0 3NB0 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 ML0|12e3\",\n\t\t\"America/Dawson|YST YDT YWT YPT YDDT PST PDT MST|90 80 80 80 70 80 70 70|010102304056565656565656565656565656565656565656565656565656565656565656565656565656565656567|-25TN0 1in0 1o10 13V0 Ser0 8x00 iz0 LCL0 1fA0 jrA0 fNd0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1z90|13e2\",\n\t\t\"America/Denver|MST MDT MWT MPT|70 60 60 60|01010101023010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-261r0 1nX0 11B0 1nX0 11B0 1qL0 WN0 mn0 Ord0 8x20 ix0 LCN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|26e5\",\n\t\t\"America/Detroit|LMT CST EST EWT EPT EDT|5w.b 60 50 40 40 40|0123425252525252525252525252525252525252525252525252525252525252525252525252525252525252525252525252525252525252525252525252525252525252525252|-2Cgir.N peqr.N 156L0 8x40 iv0 6fd0 11z0 JxX1 SMX 1cN0 1cL0 aW10 1cL0 s10 1Vz0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|37e5\",\n\t\t\"America/Edmonton|LMT MST MDT MWT MPT|7x.Q 70 60 60 60|0121212121212134121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-2yd4q.8 shdq.8 1in0 17d0 hz0 2dB0 1fz0 1a10 11z0 1qN0 WL0 1qN0 11z0 IGN0 8x20 ix0 3NB0 11z0 XQp0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|10e5\",\n\t\t\"America/Eirunepe|LMT -05 -04|4D.s 50 40|0121212121212121212121212121212121|-2glvk.w HdLk.w 1cc0 1e10 1bX0 Ezd0 So0 1vA0 Mn0 1BB0 ML0 1BB0 zX0 qe10 xb0 2ep0 nz0 1C10 zX0 1C10 LX0 1C10 Mn0 H210 Rb0 1tB0 IL0 1Fd0 FX0 dPB0 On0 yTd0 d5X0|31e3\",\n\t\t\"America/El_Salvador|LMT CST CDT|5U.M 60 50|012121|-1XiG3.c 2Fvc3.c WL0 1qN0 WL0|11e5\",\n\t\t\"America/Tijuana|LMT MST PST PDT PWT PPT|7M.4 70 80 70 70 70|012123245232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232|-1UQE0 4PX0 8mM0 8lc0 SN0 1cL0 pHB0 83r0 zI0 5O10 1Rz0 cOO0 11A0 1o00 11A0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1o00 11A0 BUp0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 U10 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|20e5\",\n\t\t\"America/Fort_Nelson|PST PDT PWT PPT MST|80 70 70 70 70|01023010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010104|-25TO0 1in0 UGp0 8x10 iy0 3NB0 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0|39e2\",\n\t\t\"America/Fort_Wayne|CST CDT CWT CPT EST EDT|60 50 50 50 50 40|010101023010101010101010101040454545454545454545454545454545454545454545454545454545454545454545454|-261s0 1nX0 11B0 1nX0 QI10 Db0 RB0 8x30 iw0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 5Tz0 1o10 qLb0 1cL0 1cN0 1cL0 1qhd0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|\",\n\t\t\"America/Fortaleza|LMT -03 -02|2y 30 20|0121212121212121212121212121212121212121|-2glxq HdLq 1cc0 1e10 1bX0 Ezd0 So0 1vA0 Mn0 1BB0 ML0 1BB0 zX0 qe10 xb0 2ep0 nz0 1C10 zX0 1C10 LX0 1C10 Mn0 H210 Rb0 1tB0 IL0 1Fd0 FX0 1EN0 FX0 1HB0 Lz0 nsp0 WL0 1tB0 5z0 2mN0 On0|34e5\",\n\t\t\"America/Glace_Bay|LMT AST ADT AWT APT|3X.M 40 30 30 30|012134121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-2IsI0.c CwO0.c 1in0 UGp0 8x50 iu0 iq10 11z0 Jg10 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|19e3\",\n\t\t\"America/Godthab|LMT -03 -02|3q.U 30 20|0121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-2a5Ux.4 2z5dx.4 19U0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|17e3\",\n\t\t\"America/Goose_Bay|NST NDT NST NDT NWT NPT AST ADT ADDT|3u.Q 2u.Q 3u 2u 2u 2u 40 30 20|010232323232323245232323232323232323232323232323232323232326767676767676767676767676767676767676767676768676767676767676767676767676767676767676767676767676767676767676767676767676767676767676767676767676|-25TSt.8 1in0 DXb0 2HbX.8 WL0 1qN0 WL0 1qN0 WL0 1tB0 TX0 1tB0 WL0 1qN0 WL0 1qN0 7UHu itu 1tB0 WL0 1qN0 WL0 1qN0 WL0 1qN0 WL0 1tB0 WL0 1ld0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 S10 g0u 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14n1 1lb0 14p0 1nW0 11C0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zcX Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|76e2\",\n\t\t\"America/Grand_Turk|KMT EST EDT AST|57.a 50 40 40|0121212121212121212121212121212121212121212121212121212121212121212121212132121212121212121212121212121212121212121|-2l1uQ.O 2HHBQ.O 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 7jA0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|37e2\",\n\t\t\"America/Guatemala|LMT CST CDT|62.4 60 50|0121212121|-24KhV.U 2efXV.U An0 mtd0 Nz0 ifB0 17b0 zDB0 11z0|13e5\",\n\t\t\"America/Guayaquil|QMT -05 -04|5e 50 40|0121|-1yVSK 2uILK rz0|27e5\",\n\t\t\"America/Guyana|LMT -04 -0345 -03|3Q.D 40 3J 30|01231|-2mf87.l 8Hc7.l 2r7bJ Ey0f|80e4\",\n\t\t\"America/Halifax|LMT AST ADT AWT APT|4e.o 40 30 30 30|0121212121212121212121212121212121212121212121212134121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-2IsHJ.A xzzJ.A 1db0 3I30 1in0 3HX0 IL0 1E10 ML0 1yN0 Pb0 1Bd0 Mn0 1Bd0 Rz0 1w10 Xb0 1w10 LX0 1w10 Xb0 1w10 Lz0 1C10 Jz0 1E10 OL0 1yN0 Un0 1qp0 Xb0 1qp0 11X0 1w10 Lz0 1HB0 LX0 1C10 FX0 1w10 Xb0 1qp0 Xb0 1BB0 LX0 1td0 Xb0 1qp0 Xb0 Rf0 8x50 iu0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 3Qp0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 3Qp0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 6i10 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|39e4\",\n\t\t\"America/Havana|HMT CST CDT|5t.A 50 40|012121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-1Meuu.o 72zu.o ML0 sld0 An0 1Nd0 Db0 1Nd0 An0 6Ep0 An0 1Nd0 An0 JDd0 Mn0 1Ap0 On0 1fd0 11X0 1qN0 WL0 1wp0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 14n0 1ld0 14L0 1kN0 15b0 1kp0 1cL0 1cN0 1fz0 1a10 1fz0 1fB0 11z0 14p0 1nX0 11B0 1nX0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 14n0 1ld0 14n0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 1a10 1in0 1a10 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1cM0 1cM0 1cM0 1fA0 17c0 1o00 11A0 1qM0 11A0 1o00 11A0 1o00 14o0 1lc0 14o0 1lc0 11A0 6i00 Rc0 1wo0 U00 1tA0 Rc0 1wo0 U00 1wo0 U00 1zc0 U00 1qM0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Rc0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Rc0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Rc0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Rc0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0|21e5\",\n\t\t\"America/Hermosillo|LMT MST CST PST MDT|7n.Q 70 60 80 60|0121212131414141|-1UQF0 deL0 8lc0 17c0 10M0 1dd0 otX0 gmN0 P2N0 13Vd0 1lb0 14p0 1lb0 14p0 1lb0|64e4\",\n\t\t\"America/Indiana/Knox|CST CDT CWT CPT EST|60 50 50 50 50|0101023010101010101010101010101010101040101010101010101010101010101010101010101010101010141010101010101010101010101010101010101010101010101010101010101010|-261s0 1nX0 11B0 1nX0 SgN0 8x30 iw0 3NB0 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 1fz0 1cN0 1cL0 1cN0 11z0 1o10 11z0 1o10 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 3Cn0 8wp0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 z8o0 1o00 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|\",\n\t\t\"America/Indiana/Marengo|CST CDT CWT CPT EST EDT|60 50 50 50 50 40|0101023010101010101010104545454545414545454545454545454545454545454545454545454545454545454545454545454|-261s0 1nX0 11B0 1nX0 SgN0 8x30 iw0 dyN0 11z0 6fd0 11z0 1o10 11z0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 jrz0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1VA0 LA0 1BX0 1e6p0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|\",\n\t\t\"America/Indiana/Petersburg|CST CDT CWT CPT EST EDT|60 50 50 50 50 40|01010230101010101010101010104010101010101010101010141014545454545454545454545454545454545454545454545454545454545454|-261s0 1nX0 11B0 1nX0 SgN0 8x30 iw0 njX0 WN0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 3Fb0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 19co0 1o00 Rd0 1zb0 Oo0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|\",\n\t\t\"America/Indiana/Tell_City|CST CDT CWT CPT EST EDT|60 50 50 50 50 40|01010230101010101010101010401054541010101010101010101010101010101010101010101010101010101010101010|-261s0 1nX0 11B0 1nX0 SgN0 8x30 iw0 njX0 WN0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 8wn0 1cN0 1cL0 1cN0 1cK0 1cN0 1cL0 1qhd0 1o00 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|\",\n\t\t\"America/Indiana/Vevay|CST CDT CWT CPT EST EDT|60 50 50 50 50 40|010102304545454545454545454545454545454545454545454545454545454545454545454545454|-261s0 1nX0 11B0 1nX0 SgN0 8x30 iw0 kPB0 Awn0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1lnd0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|\",\n\t\t\"America/Indiana/Vincennes|CST CDT CWT CPT EST EDT|60 50 50 50 50 40|01010230101010101010101010101010454541014545454545454545454545454545454545454545454545454545454545454|-261s0 1nX0 11B0 1nX0 SgN0 8x30 iw0 1o10 11z0 g0p0 11z0 1o10 11z0 1qL0 WN0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 1fz0 1cN0 WL0 1qN0 1cL0 1cN0 1cL0 1cN0 caL0 1cL0 1cN0 1cL0 1qhd0 1o00 Rd0 1zb0 Oo0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|\",\n\t\t\"America/Indiana/Winamac|CST CDT CWT CPT EST EDT|60 50 50 50 50 40|01010230101010101010101010101010101010454541054545454545454545454545454545454545454545454545454545454545454|-261s0 1nX0 11B0 1nX0 SgN0 8x30 iw0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 1fz0 1cN0 1cL0 1cN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 jrz0 1cL0 1cN0 1cL0 1qhd0 1o00 Rd0 1za0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|\",\n\t\t\"America/Inuvik|-00 PST PDDT MST MDT|0 80 60 70 60|0121343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343|-FnA0 tWU0 1fA0 wPe0 2pz0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|35e2\",\n\t\t\"America/Iqaluit|-00 EWT EPT EST EDDT EDT CST CDT|0 40 40 50 30 40 60 50|01234353535353535353535353535353535353535353567353535353535353535353535353535353535353535353535353535353535353535353535353|-16K00 7nX0 iv0 LCL0 1fA0 zgO0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11C0 1nX0 11A0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|67e2\",\n\t\t\"America/Jamaica|KMT EST EDT|57.a 50 40|0121212121212121212121|-2l1uQ.O 2uM1Q.O 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0|94e4\",\n\t\t\"America/Juneau|PST PWT PPT PDT YDT YST AKST AKDT|80 70 70 70 80 90 90 80|01203030303030303030303030403030356767676767676767676767676767676767676767676767676767676767676767676767676767676767676767676767676767676767676|-17T20 8x10 iy0 Vo10 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cM0 1cM0 1cL0 1cN0 1fz0 1a10 1fz0 co0 10q0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|33e3\",\n\t\t\"America/Kentucky/Louisville|CST CDT CWT CPT EST EDT|60 50 50 50 50 40|0101010102301010101010101010101010101454545454545414545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454|-261s0 1nX0 11B0 1nX0 3Fd0 Nb0 LPd0 11z0 RB0 8x30 iw0 1nX1 e0X 9vd0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 xz0 gso0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1VA0 LA0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|\",\n\t\t\"America/Kentucky/Monticello|CST CDT CWT CPT EST EDT|60 50 50 50 50 40|0101023010101010101010101010101010101010101010101010101010101010101010101454545454545454545454545454545454545454545454545454545454545454545454545454|-261s0 1nX0 11B0 1nX0 SgN0 8x30 iw0 SWp0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11A0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|\",\n\t\t\"America/La_Paz|CMT BST -04|4w.A 3w.A 40|012|-1x37r.o 13b0|19e5\",\n\t\t\"America/Lima|LMT -05 -04|58.A 50 40|0121212121212121|-2tyGP.o 1bDzP.o zX0 1aN0 1cL0 1cN0 1cL0 1PrB0 zX0 1O10 zX0 6Gp0 zX0 98p0 zX0|11e6\",\n\t\t\"America/Los_Angeles|PST PDT PWT PPT|80 70 70 70|010102301010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-261q0 1nX0 11B0 1nX0 SgN0 8x10 iy0 5Wp1 1VaX 3dA0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1a00 1fA0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|15e6\",\n\t\t\"America/Maceio|LMT -03 -02|2m.Q 30 20|012121212121212121212121212121212121212121|-2glxB.8 HdLB.8 1cc0 1e10 1bX0 Ezd0 So0 1vA0 Mn0 1BB0 ML0 1BB0 zX0 qe10 xb0 2ep0 nz0 1C10 zX0 1C10 LX0 1C10 Mn0 H210 Rb0 1tB0 IL0 1Fd0 FX0 1EN0 FX0 1HB0 Lz0 dMN0 Lz0 8Q10 WL0 1tB0 5z0 2mN0 On0|93e4\",\n\t\t\"America/Managua|MMT CST EST CDT|5J.c 60 50 50|0121313121213131|-1quie.M 1yAMe.M 4mn0 9Up0 Dz0 1K10 Dz0 s3F0 1KH0 DB0 9In0 k8p0 19X0 1o30 11y0|22e5\",\n\t\t\"America/Manaus|LMT -04 -03|40.4 40 30|01212121212121212121212121212121|-2glvX.U HdKX.U 1cc0 1e10 1bX0 Ezd0 So0 1vA0 Mn0 1BB0 ML0 1BB0 zX0 qe10 xb0 2ep0 nz0 1C10 zX0 1C10 LX0 1C10 Mn0 H210 Rb0 1tB0 IL0 1Fd0 FX0 dPB0 On0|19e5\",\n\t\t\"America/Martinique|FFMT AST ADT|44.k 40 30|0121|-2mPTT.E 2LPbT.E 19X0|39e4\",\n\t\t\"America/Matamoros|LMT CST CDT|6E 60 50|0121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-1UQG0 2FjC0 1nX0 i6p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 1fB0 WL0 1fB0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 U10 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|45e4\",\n\t\t\"America/Mazatlan|LMT MST CST PST MDT|75.E 70 60 80 60|0121212131414141414141414141414141414141414141414141414141414141414141414141414141414141414141|-1UQF0 deL0 8lc0 17c0 10M0 1dd0 otX0 gmN0 P2N0 13Vd0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 1fB0 WL0 1fB0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0|44e4\",\n\t\t\"America/Menominee|CST CDT CWT CPT EST|60 50 50 50 50|01010230101041010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-261s0 1nX0 11B0 1nX0 SgN0 8x30 iw0 1o10 11z0 LCN0 1fz0 6410 9Jb0 1cM0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|85e2\",\n\t\t\"America/Merida|LMT CST EST CDT|5W.s 60 50 50|0121313131313131313131313131313131313131313131313131313131313131313131313131313131313131|-1UQG0 2q2o0 2hz0 wu30 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 1fB0 WL0 1fB0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0|11e5\",\n\t\t\"America/Metlakatla|PST PWT PPT PDT AKST AKDT|80 70 70 70 90 80|01203030303030303030303030303030304545450454545454545454545454545454545454545454|-17T20 8x10 iy0 Vo10 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1hU10 Rd0 1zb0 Op0 1zb0 Op0 1zb0 uM0 jB0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|14e2\",\n\t\t\"America/Mexico_City|LMT MST CST CDT CWT|6A.A 70 60 50 50|012121232324232323232323232323232323232323232323232323232323232323232323232323232323232323232323232|-1UQF0 deL0 8lc0 17c0 10M0 1dd0 gEn0 TX0 3xd0 Jb0 6zB0 SL0 e5d0 17b0 1Pff0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 1fB0 WL0 1fB0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0|20e6\",\n\t\t\"America/Miquelon|LMT AST -03 -02|3I.E 40 30 20|012323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232|-2mKkf.k 2LTAf.k gQ10 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|61e2\",\n\t\t\"America/Moncton|EST AST ADT AWT APT|50 40 30 30 30|012121212121212121212134121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-2IsH0 CwN0 1in0 zAo0 An0 1Nd0 An0 1Nd0 An0 1Nd0 An0 1Nd0 An0 1Nd0 An0 1K10 Lz0 1zB0 NX0 1u10 Wn0 S20 8x50 iu0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 11z0 1o10 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 3Cp0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14n1 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 ReX 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|64e3\",\n\t\t\"America/Monterrey|LMT CST CDT|6F.g 60 50|0121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-1UQG0 2FjC0 1nX0 i6p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 1fB0 WL0 1fB0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0|41e5\",\n\t\t\"America/Montevideo|LMT MMT -04 -03 -0330 -0230 -02 -0130|3I.P 3I.P 40 30 3u 2u 20 1u|012343434343434343434343435353636353636375363636363636363636363636363636363636363636363|-2tRUf.9 sVc0 8jcf.9 1db0 1dcu 1cLu 1dcu 1cLu ircu 11zu 1o0u 11zu 1o0u 11zu 1o0u 11zu 1qMu WLu 1qMu WLu 1fAu 1cLu 1o0u 11zu NAu 3jXu zXu Dq0u 19Xu pcu jz0 cm10 19X0 6tB0 1fbu 3o0u jX0 4vB0 xz0 3Cp0 mmu 1a10 IMu Db0 4c10 uL0 1Nd0 An0 1SN0 uL0 mp0 28L0 iPB0 un0 1SN0 xz0 1zd0 Lz0 1zd0 Rb0 1zd0 On0 1wp0 Rb0 s8p0 1fB0 1ip0 11z0 1ld0 14n0 1o10 11z0 1o10 11z0 1o10 14n0 1ld0 14n0 1ld0 14n0 1o10 11z0 1o10 11z0 1o10 11z0|17e5\",\n\t\t\"America/Toronto|EST EDT EWT EPT|50 40 40 40|01010101010101010101010101010101010101010101012301010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-25TR0 1in0 11Wu 1nzu 1fD0 WJ0 1wr0 Nb0 1Ap0 On0 1zd0 On0 1wp0 TX0 1tB0 TX0 1tB0 TX0 1tB0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 4kM0 8x40 iv0 1o10 11z0 1nX0 11z0 1o10 11z0 1o10 1qL0 11D0 1nX0 11B0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 11z0 1o10 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|65e5\",\n\t\t\"America/New_York|EST EDT EWT EPT|50 40 40 40|01010101010101010101010101010101010101010101010102301010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-261t0 1nX0 11B0 1nX0 11B0 1qL0 1a10 11z0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 11z0 1o10 11z0 RB0 8x40 iv0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|21e6\",\n\t\t\"America/Nipigon|EST EDT EWT EPT|50 40 40 40|010123010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-25TR0 1in0 Rnb0 3je0 8x40 iv0 19yN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|16e2\",\n\t\t\"America/Nome|NST NWT NPT BST BDT YST AKST AKDT|b0 a0 a0 b0 a0 90 90 80|012034343434343434343434343434343456767676767676767676767676767676767676767676767676767676767676767676767676767676767676767676767676767676767676|-17SX0 8wW0 iB0 Qlb0 52O0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 cl0 10q0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|38e2\",\n\t\t\"America/Noronha|LMT -02 -01|29.E 20 10|0121212121212121212121212121212121212121|-2glxO.k HdKO.k 1cc0 1e10 1bX0 Ezd0 So0 1vA0 Mn0 1BB0 ML0 1BB0 zX0 qe10 xb0 2ep0 nz0 1C10 zX0 1C10 LX0 1C10 Mn0 H210 Rb0 1tB0 IL0 1Fd0 FX0 1EN0 FX0 1HB0 Lz0 nsp0 WL0 1tB0 2L0 2pB0 On0|30e2\",\n\t\t\"America/North_Dakota/Beulah|MST MDT MWT MPT CST CDT|70 60 60 60 60 50|010102301010101010101010101010101010101010101010101010101010101010101010101010101010101010101014545454545454545454545454545454545454545454545454545454|-261r0 1nX0 11B0 1nX0 SgN0 8x20 ix0 QwN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Oo0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|\",\n\t\t\"America/North_Dakota/Center|MST MDT MWT MPT CST CDT|70 60 60 60 60 50|010102301010101010101010101010101010101010101010101010101014545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454|-261r0 1nX0 11B0 1nX0 SgN0 8x20 ix0 QwN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14o0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|\",\n\t\t\"America/North_Dakota/New_Salem|MST MDT MWT MPT CST CDT|70 60 60 60 60 50|010102301010101010101010101010101010101010101010101010101010101010101010101010101454545454545454545454545454545454545454545454545454545454545454545454|-261r0 1nX0 11B0 1nX0 SgN0 8x20 ix0 QwN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14o0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|\",\n\t\t\"America/Ojinaga|LMT MST CST CDT MDT|6V.E 70 60 50 60|0121212323241414141414141414141414141414141414141414141414141414141414141414141414141414141|-1UQF0 deL0 8lc0 17c0 10M0 1dd0 2zQN0 1lb0 14p0 1lb0 14q0 1lb0 14p0 1nX0 11B0 1nX0 1fB0 WL0 1fB0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 U10 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|23e3\",\n\t\t\"America/Pangnirtung|-00 AST AWT APT ADDT ADT EDT EST CST CDT|0 40 30 30 20 30 40 50 60 50|012314151515151515151515151515151515167676767689767676767676767676767676767676767676767676767676767676767676767676767676767|-1XiM0 PnG0 8x50 iu0 LCL0 1fA0 zgO0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1o00 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11C0 1nX0 11A0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|14e2\",\n\t\t\"America/Paramaribo|LMT PMT PMT -0330 -03|3E.E 3E.Q 3E.A 3u 30|01234|-2nDUj.k Wqo0.c qanX.I 1yVXN.o|24e4\",\n\t\t\"America/Port-au-Prince|PPMT EST EDT|4N 50 40|01212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-28RHb 2FnMb 19X0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14q0 1o00 11A0 1o00 11A0 1o00 14o0 1lc0 14o0 1lc0 14o0 1o00 11A0 1o00 11A0 1o00 14o0 1lc0 14o0 1lc0 i6n0 1nX0 11B0 1nX0 d430 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 3iN0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|23e5\",\n\t\t\"America/Rio_Branco|LMT -05 -04|4v.c 50 40|01212121212121212121212121212121|-2glvs.M HdLs.M 1cc0 1e10 1bX0 Ezd0 So0 1vA0 Mn0 1BB0 ML0 1BB0 zX0 qe10 xb0 2ep0 nz0 1C10 zX0 1C10 LX0 1C10 Mn0 H210 Rb0 1tB0 IL0 1Fd0 FX0 NBd0 d5X0|31e4\",\n\t\t\"America/Porto_Velho|LMT -04 -03|4f.A 40 30|012121212121212121212121212121|-2glvI.o HdKI.o 1cc0 1e10 1bX0 Ezd0 So0 1vA0 Mn0 1BB0 ML0 1BB0 zX0 qe10 xb0 2ep0 nz0 1C10 zX0 1C10 LX0 1C10 Mn0 H210 Rb0 1tB0 IL0 1Fd0 FX0|37e4\",\n\t\t\"America/Punta_Arenas|SMT -05 -04 -03|4G.K 50 40 30|0102021212121212121232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323|-2q2jh.e fJAh.e 5knG.K 1Vzh.e jRAG.K 1pbh.e 11d0 1oL0 11d0 1oL0 11d0 1oL0 11d0 1pb0 11d0 nHX0 op0 blz0 ko0 Qeo0 WL0 1zd0 On0 1ip0 11z0 1o10 11z0 1qN0 WL0 1ld0 14n0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 WL0 1qN0 1cL0 1cN0 11z0 1o10 11z0 1qN0 WL0 1fB0 19X0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 17b0 1ip0 11z0 1ip0 1fz0 1fB0 11z0 1qN0 WL0 1qN0 WL0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 17b0 1ip0 11z0 1o10 19X0 1fB0 1nX0 G10 1EL0 Op0 1zb0 Rd0 1wn0 Rd0 46n0 Ap0|\",\n\t\t\"America/Rainy_River|CST CDT CWT CPT|60 50 50 50|010123010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-25TQ0 1in0 Rnb0 3je0 8x30 iw0 19yN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|842\",\n\t\t\"America/Rankin_Inlet|-00 CST CDDT CDT EST|0 60 40 50 50|012131313131313131313131313131313131313131313431313131313131313131313131313131313131313131313131313131313131313131313131|-vDc0 keu0 1fA0 zgO0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|26e2\",\n\t\t\"America/Recife|LMT -03 -02|2j.A 30 20|0121212121212121212121212121212121212121|-2glxE.o HdLE.o 1cc0 1e10 1bX0 Ezd0 So0 1vA0 Mn0 1BB0 ML0 1BB0 zX0 qe10 xb0 2ep0 nz0 1C10 zX0 1C10 LX0 1C10 Mn0 H210 Rb0 1tB0 IL0 1Fd0 FX0 1EN0 FX0 1HB0 Lz0 nsp0 WL0 1tB0 2L0 2pB0 On0|33e5\",\n\t\t\"America/Regina|LMT MST MDT MWT MPT CST|6W.A 70 60 60 60 60|012121212121212121212121341212121212121212121212121215|-2AD51.o uHe1.o 1in0 s2L0 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 11z0 66N0 1cL0 1cN0 19X0 1fB0 1cL0 1fB0 1cL0 1cN0 1cL0 M30 8x20 ix0 1ip0 1cL0 1ip0 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 11z0 1o10 11z0 3NB0 1cL0 1cN0|19e4\",\n\t\t\"America/Resolute|-00 CST CDDT CDT EST|0 60 40 50 50|012131313131313131313131313131313131313131313431313131313431313131313131313131313131313131313131313131313131313131313131|-SnA0 GWS0 1fA0 zgO0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|229\",\n\t\t\"America/Santarem|LMT -04 -03|3C.M 40 30|0121212121212121212121212121212|-2glwl.c HdLl.c 1cc0 1e10 1bX0 Ezd0 So0 1vA0 Mn0 1BB0 ML0 1BB0 zX0 qe10 xb0 2ep0 nz0 1C10 zX0 1C10 LX0 1C10 Mn0 H210 Rb0 1tB0 IL0 1Fd0 FX0 NBd0|21e4\",\n\t\t\"America/Santiago|SMT -05 -04 -03|4G.K 50 40 30|010202121212121212321232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323|-2q2jh.e fJAh.e 5knG.K 1Vzh.e jRAG.K 1pbh.e 11d0 1oL0 11d0 1oL0 11d0 1oL0 11d0 1pb0 11d0 nHX0 op0 9Bz0 jb0 1oN0 ko0 Qeo0 WL0 1zd0 On0 1ip0 11z0 1o10 11z0 1qN0 WL0 1ld0 14n0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 WL0 1qN0 1cL0 1cN0 11z0 1o10 11z0 1qN0 WL0 1fB0 19X0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 17b0 1ip0 11z0 1ip0 1fz0 1fB0 11z0 1qN0 WL0 1qN0 WL0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 17b0 1ip0 11z0 1o10 19X0 1fB0 1nX0 G10 1EL0 Op0 1zb0 Rd0 1wn0 Rd0 46n0 Ap0 1Nb0 Ap0 1Nb0 Ap0 1zb0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1qL0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1qL0 WN0 1qL0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1qL0 WN0 1qL0 11B0 1nX0 11B0|62e5\",\n\t\t\"America/Santo_Domingo|SDMT EST EDT -0430 AST|4E 50 40 4u 40|01213131313131414|-1ttjk 1lJMk Mn0 6sp0 Lbu 1Cou yLu 1RAu wLu 1QMu xzu 1Q0u xXu 1PAu 13jB0 e00|29e5\",\n\t\t\"America/Sao_Paulo|LMT -03 -02|36.s 30 20|01212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-2glwR.w HdKR.w 1cc0 1e10 1bX0 Ezd0 So0 1vA0 Mn0 1BB0 ML0 1BB0 zX0 pTd0 PX0 2ep0 nz0 1C10 zX0 1C10 LX0 1C10 Mn0 H210 Rb0 1tB0 IL0 1Fd0 FX0 1EN0 FX0 1HB0 Lz0 1EN0 Lz0 1C10 IL0 1HB0 Db0 1HB0 On0 1zd0 On0 1zd0 Lz0 1zd0 Rb0 1wN0 Wn0 1tB0 Rb0 1tB0 WL0 1tB0 Rb0 1zd0 On0 1HB0 FX0 1C10 Lz0 1Ip0 HX0 1zd0 On0 1HB0 IL0 1wp0 On0 1C10 Lz0 1C10 On0 1zd0 On0 1zd0 Rb0 1zd0 Lz0 1C10 Lz0 1C10 On0 1zd0 On0 1zd0 On0 1zd0 On0 1HB0 FX0|20e6\",\n\t\t\"America/Scoresbysund|LMT -02 -01 +00|1r.Q 20 10 0|0121323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232|-2a5Ww.8 2z5ew.8 1a00 1cK0 1cL0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|452\",\n\t\t\"America/Sitka|PST PWT PPT PDT YST AKST AKDT|80 70 70 70 90 90 80|01203030303030303030303030303030345656565656565656565656565656565656565656565656565656565656565656565656565656565656565656565656565656565656565|-17T20 8x10 iy0 Vo10 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 co0 10q0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|90e2\",\n\t\t\"America/St_Johns|NST NDT NST NDT NWT NPT NDDT|3u.Q 2u.Q 3u 2u 2u 2u 1u|01010101010101010101010101010101010102323232323232324523232323232323232323232323232323232323232323232323232323232323232323232323232323232326232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232|-28oit.8 14L0 1nB0 1in0 1gm0 Dz0 1JB0 1cL0 1cN0 1cL0 1fB0 19X0 1fB0 19X0 1fB0 19X0 1fB0 19X0 1fB0 1cL0 1cN0 1cL0 1fB0 19X0 1fB0 19X0 1fB0 19X0 1fB0 19X0 1fB0 1cL0 1fB0 19X0 1fB0 19X0 10O0 eKX.8 19X0 1iq0 WL0 1qN0 WL0 1qN0 WL0 1tB0 TX0 1tB0 WL0 1qN0 WL0 1qN0 7UHu itu 1tB0 WL0 1qN0 WL0 1qN0 WL0 1qN0 WL0 1tB0 WL0 1ld0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14n1 1lb0 14p0 1nW0 11C0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zcX Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|11e4\",\n\t\t\"America/Swift_Current|LMT MST MDT MWT MPT CST|7b.k 70 60 60 60 60|012134121212121212121215|-2AD4M.E uHdM.E 1in0 UGp0 8x20 ix0 1o10 17b0 1ip0 11z0 1o10 11z0 1o10 11z0 isN0 1cL0 3Cp0 1cL0 1cN0 11z0 1qN0 WL0 pMp0|16e3\",\n\t\t\"America/Tegucigalpa|LMT CST CDT|5M.Q 60 50|01212121|-1WGGb.8 2ETcb.8 WL0 1qN0 WL0 GRd0 AL0|11e5\",\n\t\t\"America/Thule|LMT AST ADT|4z.8 40 30|012121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-2a5To.Q 31NBo.Q 1cL0 1cN0 1cL0 1fB0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|656\",\n\t\t\"America/Thunder_Bay|CST EST EWT EPT EDT|60 50 40 40 40|0123141414141414141414141414141414141414141414141414141414141414141414141414141414141414141414141414141414141414141414141414141414141414141|-2q5S0 1iaN0 8x40 iv0 XNB0 1cL0 1cN0 1fz0 1cN0 1cL0 3Cp0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|11e4\",\n\t\t\"America/Vancouver|PST PDT PWT PPT|80 70 70 70|0102301010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-25TO0 1in0 UGp0 8x10 iy0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|23e5\",\n\t\t\"America/Whitehorse|YST YDT YWT YPT YDDT PST PDT MST|90 80 80 80 70 80 70 70|010102304056565656565656565656565656565656565656565656565656565656565656565656565656565656567|-25TN0 1in0 1o10 13V0 Ser0 8x00 iz0 LCL0 1fA0 3NA0 vrd0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1z90|23e3\",\n\t\t\"America/Winnipeg|CST CDT CWT CPT|60 50 50 50|010101023010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-2aIi0 WL0 3ND0 1in0 Jap0 Rb0 aCN0 8x30 iw0 1tB0 11z0 1ip0 11z0 1o10 11z0 1o10 11z0 1rd0 10L0 1op0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 1cL0 1cN0 11z0 6i10 WL0 6i10 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1a00 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1a00 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 14o0 1lc0 14o0 1o00 11A0 1o00 11A0 1o00 14o0 1lc0 14o0 1lc0 14o0 1o00 11A0 1o00 11A0 1o00 14o0 1lc0 14o0 1lc0 14o0 1lc0 14o0 1o00 11A0 1o00 11A0 1o00 14o0 1lc0 14o0 1lc0 14o0 1o00 11A0 1o00 11A0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|66e4\",\n\t\t\"America/Yakutat|YST YWT YPT YDT AKST AKDT|90 80 80 80 90 80|01203030303030303030303030303030304545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454|-17T10 8x00 iz0 Vo10 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 cn0 10q0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|642\",\n\t\t\"America/Yellowknife|-00 MST MWT MPT MDDT MDT|0 70 60 60 50 60|012314151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151515151|-1pdA0 hix0 8x20 ix0 LCL0 1fA0 zgO0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|19e3\",\n\t\t\"Antarctica/Casey|-00 +08 +11|0 -80 -b0|0121212121212|-2q00 1DjS0 T90 40P0 KL0 blz0 3m10 1o30 14k0 1kr0 12l0 1o01|10\",\n\t\t\"Antarctica/Davis|-00 +07 +05|0 -70 -50|01012121|-vyo0 iXt0 alj0 1D7v0 VB0 3Wn0 KN0|70\",\n\t\t\"Pacific/Port_Moresby|+10|-a0|0||25e4\",\n\t\t\"Antarctica/Macquarie|AEST AEDT -00|-a0 -b0 0|010201010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101|-29E80 1a00 4SK0 1ayy0 Lvs0 1cM0 1o00 Rc0 1wo0 Rc0 1wo0 U00 1wo0 LA0 1C00 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Rc0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 11A0 1qM0 WM0 1qM0 Oo0 1zc0 Oo0 1zc0 Oo0 1wo0 WM0 1tA0 WM0 1tA0 U00 1tA0 U00 1tA0 11A0 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1cM0 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 11A0 1o00 1io0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1cM0 1cM0 1a00 1io0 1cM0 1cM0 1cM0 1cM0 3Co0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0|1\",\n\t\t\"Antarctica/Mawson|-00 +06 +05|0 -60 -50|012|-CEo0 2fyk0|60\",\n\t\t\"Pacific/Auckland|NZMT NZST NZST NZDT|-bu -cu -c0 -d0|01020202020202020202020202023232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323|-1GCVu Lz0 1tB0 11zu 1o0u 11zu 1o0u 11zu 1o0u 14nu 1lcu 14nu 1lcu 1lbu 11Au 1nXu 11Au 1nXu 11Au 1nXu 11Au 1nXu 11Au 1qLu WMu 1qLu 11Au 1n1bu IM0 1C00 Rc0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Rc0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Rc0 1zc0 Oo0 1qM0 14o0 1lc0 14o0 1lc0 14o0 1lc0 17c0 1io0 17c0 1io0 17c0 1io0 17c0 1lc0 14o0 1lc0 14o0 1lc0 17c0 1io0 17c0 1io0 17c0 1lc0 14o0 1lc0 14o0 1lc0 17c0 1io0 17c0 1io0 17c0 1io0 17c0 1io0 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1cM0 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1cM0 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1io0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1cM0 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1cM0 1fA0 1a00 1fA0 1a00|14e5\",\n\t\t\"Antarctica/Palmer|-00 -03 -04 -02|0 30 40 20|0121212121213121212121212121212121212121212121212121212121212121212121212121212121|-cao0 nD0 1vd0 SL0 1vd0 17z0 1cN0 1fz0 1cN0 1cL0 1cN0 asn0 Db0 jsN0 14N0 11z0 1o10 11z0 1qN0 WL0 1qN0 WL0 1qN0 1cL0 1cN0 11z0 1o10 11z0 1qN0 WL0 1fB0 19X0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 17b0 1ip0 11z0 1ip0 1fz0 1fB0 11z0 1qN0 WL0 1qN0 WL0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 17b0 1ip0 11z0 1o10 19X0 1fB0 1nX0 G10 1EL0 Op0 1zb0 Rd0 1wn0 Rd0 46n0 Ap0|40\",\n\t\t\"Antarctica/Rothera|-00 -03|0 30|01|gOo0|130\",\n\t\t\"Asia/Riyadh|LMT +03|-36.Q -30|01|-TvD6.Q|57e5\",\n\t\t\"Antarctica/Troll|-00 +00 +02|0 0 -20|01212121212121212121212121212121212121212121212121212121212121212121|1puo0 hd0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|40\",\n\t\t\"Antarctica/Vostok|-00 +06|0 -60|01|-tjA0|25\",\n\t\t\"Europe/Oslo|CET CEST|-10 -20|010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-2awM0 Qm0 W6o0 5pf0 WM0 1fA0 1cM0 1cM0 1cM0 1cM0 wJc0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1qM0 WM0 zpc0 1a00 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|62e4\",\n\t\t\"Asia/Almaty|LMT +05 +06 +07|-57.M -50 -60 -70|012323232323232323232321232323232323232323232323232|-1Pc57.M eUo7.M 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0|15e5\",\n\t\t\"Asia/Amman|LMT EET EEST|-2n.I -20 -30|0121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-1yW2n.I 1HiMn.I KL0 1oN0 11b0 1oN0 11b0 1pd0 1dz0 1cp0 11b0 1op0 11b0 fO10 1db0 1e10 1cL0 1cN0 1cL0 1cN0 1fz0 1pd0 10n0 1ld0 14n0 1hB0 15b0 1ip0 19X0 1cN0 1cL0 1cN0 17b0 1ld0 14o0 1lc0 17c0 1io0 17c0 1io0 17c0 1So0 y00 1fc0 1dc0 1co0 1dc0 1cM0 1cM0 1cM0 1o00 11A0 1lc0 17c0 1cM0 1cM0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 4bX0 Dd0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 LA0 1C00 LA0 1C00 Oo0 1zc0 Oo0 1C00 LA0 1C00 LA0 1C00 LA0 1C00 LA0 1C00 Oo0 1zc0 Oo0 1C00 LA0 1C00 LA0 1C00 LA0 1C00 LA0 1C00 Oo0 1C00 LA0 1C00|25e5\",\n\t\t\"Asia/Anadyr|LMT +12 +13 +14 +11|-bN.U -c0 -d0 -e0 -b0|01232121212121212121214121212121212121212121212121212121212141|-1PcbN.U eUnN.U 23CL0 1db0 2q10 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 2sp0 WM0|13e3\",\n\t\t\"Asia/Aqtau|LMT +04 +05 +06|-3l.4 -40 -50 -60|012323232323232323232123232312121212121212121212|-1Pc3l.4 eUnl.4 24PX0 2pX0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cN0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0|15e4\",\n\t\t\"Asia/Aqtobe|LMT +04 +05 +06|-3M.E -40 -50 -60|0123232323232323232321232323232323232323232323232|-1Pc3M.E eUnM.E 23CL0 3Db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0|27e4\",\n\t\t\"Asia/Ashgabat|LMT +04 +05 +06|-3R.w -40 -50 -60|0123232323232323232323212|-1Pc3R.w eUnR.w 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0|41e4\",\n\t\t\"Asia/Atyrau|LMT +03 +05 +06 +04|-3r.I -30 -50 -60 -40|01232323232323232323242323232323232324242424242|-1Pc3r.I eUor.I 24PW0 2pX0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 2sp0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0|\",\n\t\t\"Asia/Baghdad|BMT +03 +04|-2V.A -30 -40|012121212121212121212121212121212121212121212121212121|-26BeV.A 2ACnV.A 11b0 1cp0 1dz0 1dd0 1db0 1cN0 1cp0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1de0 1dc0 1dc0 1dc0 1cM0 1dc0 1cM0 1dc0 1cM0 1dc0 1dc0 1dc0 1cM0 1dc0 1cM0 1dc0 1cM0 1dc0 1dc0 1dc0 1cM0 1dc0 1cM0 1dc0 1cM0 1dc0 1dc0 1dc0 1cM0 1dc0 1cM0 1dc0 1cM0 1dc0|66e5\",\n\t\t\"Asia/Qatar|LMT +04 +03|-3q.8 -40 -30|012|-21Jfq.8 27BXq.8|96e4\",\n\t\t\"Asia/Baku|LMT +03 +04 +05|-3j.o -30 -40 -50|01232323232323232323232123232323232323232323232323232323232323232|-1Pc3j.o 1jUoj.o WCL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 1cM0 9Je0 1o00 11z0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00|27e5\",\n\t\t\"Asia/Bangkok|BMT +07|-6G.4 -70|01|-218SG.4|15e6\",\n\t\t\"Asia/Barnaul|LMT +06 +07 +08|-5z -60 -70 -80|0123232323232323232323212323232321212121212121212121212121212121212|-21S5z pCnz 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 p90 LE0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 8Hz0 3rd0|\",\n\t\t\"Asia/Beirut|EET EEST|-20 -30|010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-21aq0 1on0 1410 1db0 19B0 1in0 1ip0 WL0 1lQp0 11b0 1oN0 11b0 1oN0 11b0 1pd0 11b0 1oN0 11b0 q6N0 En0 1oN0 11b0 1oN0 11b0 1oN0 11b0 1pd0 11b0 1oN0 11b0 1op0 11b0 dA10 17b0 1iN0 17b0 1iN0 17b0 1iN0 17b0 1vB0 SL0 1mp0 13z0 1iN0 17b0 1iN0 17b0 1jd0 12n0 1a10 1cL0 1cN0 1cL0 1cN0 1cL0 1fB0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1qL0 WN0 1qL0 WN0 1qL0 11B0 1nX0 11B0 1nX0 11B0 1qL0 WN0 1qL0 WN0 1qL0 WN0 1qL0 11B0 1nX0 11B0 1nX0 11B0 1qL0 WN0 1qL0 WN0 1qL0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1qL0 WN0 1qL0 WN0 1qL0 11B0 1nX0 11B0 1nX0 11B0 1qL0 WN0 1qL0 WN0 1qL0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1qL0 WN0 1qL0 WN0 1qL0 11B0 1nX0 11B0 1nX0 11B0 1qL0 WN0 1qL0 WN0 1qL0 WN0 1qL0 11B0 1nX0 11B0 1nX0|22e5\",\n\t\t\"Asia/Bishkek|LMT +05 +06 +07|-4W.o -50 -60 -70|012323232323232323232321212121212121212121212121212|-1Pc4W.o eUnW.o 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2e00 1tX0 17b0 1ip0 17b0 1ip0 17b0 1ip0 17b0 1ip0 19X0 1cPu 1nX0 11B0 1nX0 11B0 1qL0 WN0 1qL0 WN0 1qL0 11B0 1nX0 11B0 1nX0 11B0 1qL0 WN0|87e4\",\n\t\t\"Asia/Brunei|LMT +0730 +08|-7D.E -7u -80|012|-1KITD.E gDc9.E|42e4\",\n\t\t\"Asia/Kolkata|MMT IST +0630|-5l.a -5u -6u|012121|-2zOtl.a 1r2LP.a 1un0 HB0 7zX0|15e6\",\n\t\t\"Asia/Chita|LMT +08 +09 +10|-7x.Q -80 -90 -a0|012323232323232323232321232323232323232323232323232323232323232312|-21Q7x.Q pAnx.Q 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 8Hz0 3re0|33e4\",\n\t\t\"Asia/Choibalsan|LMT +07 +08 +10 +09|-7C -70 -80 -a0 -90|0123434343434343434343434343434343434343434343424242|-2APHC 2UkoC cKn0 1da0 1dd0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1fB0 1cL0 1cN0 1cL0 1cN0 1cL0 6hD0 11z0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 3Db0 h1f0 1cJ0 1cP0 1cJ0|38e3\",\n\t\t\"Asia/Shanghai|CST CDT|-80 -90|01010101010101010101010101010|-23uw0 18n0 OjB0 Rz0 11d0 1wL0 A10 8HX0 1G10 Tz0 1ip0 1jX0 1cN0 11b0 1oN0 aL0 1tU30 Rb0 1o10 11z0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0|23e6\",\n\t\t\"Asia/Colombo|MMT +0530 +06 +0630|-5j.w -5u -60 -6u|01231321|-2zOtj.w 1rFbN.w 1zzu 7Apu 23dz0 11zu n3cu|22e5\",\n\t\t\"Asia/Dhaka|HMT +0630 +0530 +06 +07|-5R.k -6u -5u -60 -70|0121343|-18LFR.k 1unn.k HB0 m6n0 2kxbu 1i00|16e6\",\n\t\t\"Asia/Damascus|LMT EET EEST|-2p.c -20 -30|01212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-21Jep.c Hep.c 17b0 1ip0 17b0 1ip0 17b0 1ip0 19X0 1xRB0 11X0 1oN0 10L0 1pB0 11b0 1oN0 10L0 1mp0 13X0 1oN0 11b0 1pd0 11b0 1oN0 11b0 1oN0 11b0 1oN0 11b0 1pd0 11b0 1oN0 11b0 1oN0 11b0 1oN0 11b0 1pd0 11b0 1oN0 Nb0 1AN0 Nb0 bcp0 19X0 1gp0 19X0 3ld0 1xX0 Vd0 1Bz0 Sp0 1vX0 10p0 1dz0 1cN0 1cL0 1db0 1db0 1g10 1an0 1ap0 1db0 1fd0 1db0 1cN0 1db0 1dd0 1db0 1cp0 1dz0 1c10 1dX0 1cN0 1db0 1dd0 1db0 1cN0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1db0 1cN0 1db0 1cN0 19z0 1fB0 1qL0 11B0 1on0 Wp0 1qL0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1qL0 WN0 1qL0 WN0 1qL0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1qL0 WN0 1qL0 WN0 1qL0 11B0 1nX0 11B0 1nX0 11B0 1qL0 WN0 1qL0 WN0 1qL0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1qL0 WN0 1qL0 WN0 1qL0 11B0 1nX0 11B0 1nX0 11B0 1qL0 WN0 1qL0|26e5\",\n\t\t\"Asia/Dili|LMT +08 +09|-8m.k -80 -90|01212|-2le8m.k 1dnXm.k 1nfA0 Xld0|19e4\",\n\t\t\"Asia/Dubai|LMT +04|-3F.c -40|01|-21JfF.c|39e5\",\n\t\t\"Asia/Dushanbe|LMT +05 +06 +07|-4z.c -50 -60 -70|012323232323232323232321|-1Pc4z.c eUnz.c 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2hB0|76e4\",\n\t\t\"Asia/Famagusta|LMT EET EEST +03|-2f.M -20 -30 -30|0121212121212121212121212121212121212121212121212121212121212121212121212121212121212312121212121212121212121212121212121212121|-1Vc2f.M 2a3cf.M 1cL0 1qp0 Xz0 19B0 19X0 1fB0 1db0 1cp0 1cL0 1fB0 19X0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1fB0 1cL0 1cN0 1cL0 1cN0 1o30 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 15U0 2Ks0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|\",\n\t\t\"Asia/Gaza|EET EEST IST IDT|-20 -30 -20 -30|010101010101010101010101010101010123232323232323232323232323232320101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-1c2o0 MM0 iM0 4JA0 10o0 1pA0 10M0 1pA0 16o0 1jA0 16o0 1jA0 pBa0 Vz0 1oN0 11b0 1oO0 10N0 1pz0 10N0 1pb0 10N0 1pb0 10N0 1pb0 10N0 1pz0 10N0 1pb0 10N0 1pb0 11d0 1oL0 dW0 hfB0 Db0 1fB0 Rb0 bXB0 gM0 8Q00 IM0 1wo0 TX0 1HB0 IL0 1s10 10n0 1o10 WL0 1zd0 On0 1ld0 11z0 1o10 14n0 1o10 14n0 1nd0 12n0 1nd0 Xz0 1q10 12n0 M10 C00 17c0 1io0 17c0 1io0 17c0 1o00 1cL0 1fB0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 17c0 1io0 18N0 1bz0 19z0 1gp0 1610 1iL0 11z0 1o10 14o0 1lA1 SKX 1xd1 MKX 1AN0 1a00 1fA0 1cL0 1cN0 1nX0 1210 1nA0 1210 1qL0 WN0 1qL0 WN0 1qL0 11c0 1on0 11B0 1o00 11A0 1qo0 Xc0 1qo0 Xc0 1qo0 1200 1nA0 1200 1qo0 Xc0 1qo0 Xc0 1qo0 Xc0 1qo0 Xc0 1qo0 1200 1nA0 1200 1qo0 Xc0 1qo0 Xc0 1qo0 Xc0 1qo0 Xc0 1qo0 1200 1qo0 Xc0 1qo0|18e5\",\n\t\t\"Asia/Hebron|EET EEST IST IDT|-20 -30 -20 -30|01010101010101010101010101010101012323232323232323232323232323232010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-1c2o0 MM0 iM0 4JA0 10o0 1pA0 10M0 1pA0 16o0 1jA0 16o0 1jA0 pBa0 Vz0 1oN0 11b0 1oO0 10N0 1pz0 10N0 1pb0 10N0 1pb0 10N0 1pb0 10N0 1pz0 10N0 1pb0 10N0 1pb0 11d0 1oL0 dW0 hfB0 Db0 1fB0 Rb0 bXB0 gM0 8Q00 IM0 1wo0 TX0 1HB0 IL0 1s10 10n0 1o10 WL0 1zd0 On0 1ld0 11z0 1o10 14n0 1o10 14n0 1nd0 12n0 1nd0 Xz0 1q10 12n0 M10 C00 17c0 1io0 17c0 1io0 17c0 1o00 1cL0 1fB0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 17c0 1io0 18N0 1bz0 19z0 1gp0 1610 1iL0 12L0 1mN0 14o0 1lc0 Tb0 1xd1 MKX bB0 cn0 1cN0 1a00 1fA0 1cL0 1cN0 1nX0 1210 1nA0 1210 1qL0 WN0 1qL0 WN0 1qL0 11c0 1on0 11B0 1o00 11A0 1qo0 Xc0 1qo0 Xc0 1qo0 1200 1nA0 1200 1qo0 Xc0 1qo0 Xc0 1qo0 Xc0 1qo0 Xc0 1qo0 1200 1nA0 1200 1qo0 Xc0 1qo0 Xc0 1qo0 Xc0 1qo0 Xc0 1qo0 1200 1qo0 Xc0 1qo0|25e4\",\n\t\t\"Asia/Ho_Chi_Minh|LMT PLMT +07 +08 +09|-76.E -76.u -70 -80 -90|0123423232|-2yC76.E bK00.a 1h7b6.u 5lz0 18o0 3Oq0 k5b0 aW00 BAM0|90e5\",\n\t\t\"Asia/Hong_Kong|LMT HKT HKST HKWT JST|-7A.G -80 -90 -8u -90|0123412121212121212121212121212121212121212121212121212121212121212121|-2CFH0 1taO0 Hc0 xUu 9tBu 11z0 1tDu Rc0 1wo0 11A0 1cM0 11A0 1o00 11A0 1o00 11A0 1o00 14o0 1o00 11A0 1nX0 U10 1tz0 U10 1wn0 Rd0 1wn0 U10 1tz0 U10 1tz0 U10 1tz0 U10 1wn0 Rd0 1wn0 Rd0 1wn0 U10 1tz0 U10 1tz0 17d0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 s10 1Vz0 1cN0 1cL0 1cN0 1cL0 6fd0 14n0|73e5\",\n\t\t\"Asia/Hovd|LMT +06 +07 +08|-66.A -60 -70 -80|012323232323232323232323232323232323232323232323232|-2APG6.A 2Uko6.A cKn0 1db0 1dd0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1fB0 1cL0 1cN0 1cL0 1cN0 1cL0 6hD0 11z0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 kEp0 1cJ0 1cP0 1cJ0|81e3\",\n\t\t\"Asia/Irkutsk|IMT +07 +08 +09|-6V.5 -70 -80 -90|01232323232323232323232123232323232323232323232323232323232323232|-21zGV.5 pjXV.5 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 8Hz0|60e4\",\n\t\t\"Europe/Istanbul|IMT EET EEST +03 +04|-1U.U -20 -30 -30 -40|0121212121212121212121212121212121212121212121234312121212121212121212121212121212121212121212121212121212121212123|-2ogNU.U dzzU.U 11b0 8tB0 1on0 1410 1db0 19B0 1in0 3Rd0 Un0 1oN0 11b0 zSN0 CL0 mp0 1Vz0 1gN0 8yn0 1yp0 ML0 1kp0 17b0 1ip0 17b0 1fB0 19X0 1ip0 19X0 1ip0 17b0 qdB0 38L0 1jd0 Tz0 l6O0 11A0 WN0 1qL0 TB0 1tX0 U10 1tz0 11B0 1in0 17d0 z90 cne0 pb0 2Cp0 1800 14o0 1dc0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1a00 1fA0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WO0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 Xc0 1qo0 WM0 1qM0 11A0 1o00 1200 1nA0 11A0 1tA0 U00 15w0|13e6\",\n\t\t\"Asia/Jakarta|BMT +0720 +0730 +09 +08 WIB|-77.c -7k -7u -90 -80 -70|01232425|-1Q0Tk luM0 mPzO 8vWu 6kpu 4PXu xhcu|31e6\",\n\t\t\"Asia/Jayapura|LMT +09 +0930 WIT|-9m.M -90 -9u -90|0123|-1uu9m.M sMMm.M L4nu|26e4\",\n\t\t\"Asia/Jerusalem|JMT IST IDT IDDT|-2k.E -20 -30 -40|01212121212121321212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-26Bek.E SyOk.E MM0 iM0 4JA0 10o0 1pA0 10M0 1pA0 16o0 1jA0 16o0 1jA0 3LA0 Eo0 oo0 1co0 1dA0 16o0 10M0 1jc0 1tA0 14o0 1cM0 1a00 11A0 1Nc0 Ao0 1Nc0 Ao0 1Ko0 LA0 1o00 WM0 EQK0 Db0 1fB0 Rb0 bXB0 gM0 8Q00 IM0 1wo0 TX0 1HB0 IL0 1s10 10n0 1o10 WL0 1zd0 On0 1ld0 11z0 1o10 14n0 1o10 14n0 1nd0 12n0 1nd0 Xz0 1q10 12n0 1hB0 1dX0 1ep0 1aL0 1eN0 17X0 1nf0 11z0 1tB0 19W0 1e10 17b0 1ep0 1gL0 18N0 1fz0 1eN0 17b0 1gq0 1gn0 19d0 1dz0 1c10 17X0 1hB0 1gn0 19d0 1dz0 1c10 17X0 1kp0 1dz0 1c10 1aL0 1eN0 1oL0 10N0 1oL0 10N0 1oL0 10N0 1rz0 W10 1rz0 W10 1rz0 10N0 1oL0 10N0 1oL0 10N0 1rz0 W10 1rz0 W10 1rz0 10N0 1oL0 10N0 1oL0 10N0 1oL0 10N0 1rz0 W10 1rz0 W10 1rz0 10N0 1oL0 10N0 1oL0 10N0 1rz0 W10 1rz0 W10 1rz0 W10 1rz0 10N0 1oL0 10N0 1oL0|81e4\",\n\t\t\"Asia/Kabul|+04 +0430|-40 -4u|01|-10Qs0|46e5\",\n\t\t\"Asia/Kamchatka|LMT +11 +12 +13|-ay.A -b0 -c0 -d0|012323232323232323232321232323232323232323232323232323232323212|-1SLKy.A ivXy.A 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 2sp0 WM0|18e4\",\n\t\t\"Asia/Karachi|LMT +0530 +0630 +05 PKT PKST|-4s.c -5u -6u -50 -50 -60|012134545454|-2xoss.c 1qOKW.c 7zX0 eup0 LqMu 1fy00 1cL0 dK10 11b0 1610 1jX0|24e6\",\n\t\t\"Asia/Urumqi|LMT +06|-5O.k -60|01|-1GgtO.k|32e5\",\n\t\t\"Asia/Kathmandu|LMT +0530 +0545|-5F.g -5u -5J|012|-21JhF.g 2EGMb.g|12e5\",\n\t\t\"Asia/Khandyga|LMT +08 +09 +10 +11|-92.d -80 -90 -a0 -b0|0123232323232323232323212323232323232323232323232343434343434343432|-21Q92.d pAp2.d 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 qK0 yN0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 17V0 7zD0|66e2\",\n\t\t\"Asia/Krasnoyarsk|LMT +06 +07 +08|-6b.q -60 -70 -80|01232323232323232323232123232323232323232323232323232323232323232|-21Hib.q prAb.q 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 8Hz0|10e5\",\n\t\t\"Asia/Kuala_Lumpur|SMT +07 +0720 +0730 +09 +08|-6T.p -70 -7k -7u -90 -80|0123435|-2Bg6T.p 17anT.p l5XE 17bO 8Fyu 1so1u|71e5\",\n\t\t\"Asia/Kuching|LMT +0730 +08 +0820 +09|-7l.k -7u -80 -8k -90|0123232323232323242|-1KITl.k gDbP.k 6ynu AnE 1O0k AnE 1NAk AnE 1NAk AnE 1NAk AnE 1O0k AnE 1NAk AnE pAk 8Fz0|13e4\",\n\t\t\"Asia/Macau|LMT CST +09 +10 CDT|-7y.a -80 -90 -a0 -90|012323214141414141414141414141414141414141414141414141414141414141414141|-2CFHy.a 1uqKy.a PX0 1kn0 15B0 11b0 4Qq0 1oM0 11c0 1ko0 1u00 11A0 1cM0 11c0 1o00 11A0 1o00 11A0 1oo0 1400 1o00 11A0 1o00 U00 1tA0 U00 1wo0 Rc0 1wru U10 1tz0 U10 1tz0 U10 1tz0 U10 1wn0 Rd0 1wn0 Rd0 1wn0 U10 1tz0 U10 1tz0 17d0 1cK0 1cO0 1cK0 1cO0 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 s10 1Vz0 1cN0 1cL0 1cN0 1cL0 6fd0 14n0|57e4\",\n\t\t\"Asia/Magadan|LMT +10 +11 +12|-a3.c -a0 -b0 -c0|012323232323232323232321232323232323232323232323232323232323232312|-1Pca3.c eUo3.c 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 8Hz0 3Cq0|95e3\",\n\t\t\"Asia/Makassar|LMT MMT +08 +09 WITA|-7V.A -7V.A -80 -90 -80|01234|-21JjV.A vfc0 myLV.A 8ML0|15e5\",\n\t\t\"Asia/Manila|PST PDT JST|-80 -90 -90|010201010|-1kJI0 AL0 cK10 65X0 mXB0 vX0 VK10 1db0|24e6\",\n\t\t\"Asia/Nicosia|LMT EET EEST|-2d.s -20 -30|01212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-1Vc2d.s 2a3cd.s 1cL0 1qp0 Xz0 19B0 19X0 1fB0 1db0 1cp0 1cL0 1fB0 19X0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1fB0 1cL0 1cN0 1cL0 1cN0 1o30 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|32e4\",\n\t\t\"Asia/Novokuznetsk|LMT +06 +07 +08|-5M.M -60 -70 -80|012323232323232323232321232323232323232323232323232323232323212|-1PctM.M eULM.M 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 2sp0 WM0|55e4\",\n\t\t\"Asia/Novosibirsk|LMT +06 +07 +08|-5v.E -60 -70 -80|0123232323232323232323212323212121212121212121212121212121212121212|-21Qnv.E pAFv.E 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 ml0 Os0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 8Hz0 4eN0|15e5\",\n\t\t\"Asia/Omsk|LMT +05 +06 +07|-4R.u -50 -60 -70|01232323232323232323232123232323232323232323232323232323232323232|-224sR.u pMLR.u 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 8Hz0|12e5\",\n\t\t\"Asia/Oral|LMT +03 +05 +06 +04|-3p.o -30 -50 -60 -40|01232323232323232424242424242424242424242424242|-1Pc3p.o eUop.o 23CK0 3Db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 2pB0 1cM0 1fA0 1cM0 1cM0 IM0 1EM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0|27e4\",\n\t\t\"Asia/Pontianak|LMT PMT +0730 +09 +08 WITA WIB|-7h.k -7h.k -7u -90 -80 -80 -70|012324256|-2ua7h.k XE00 munL.k 8Rau 6kpu 4PXu xhcu Wqnu|23e4\",\n\t\t\"Asia/Pyongyang|LMT KST JST KST|-8n -8u -90 -90|012313|-2um8n 97XR 1lTzu 2Onc0 6BA0|29e5\",\n\t\t\"Asia/Qostanay|LMT +04 +05 +06|-4e.s -40 -50 -60|012323232323232323232123232323232323232323232323|-1Pc4e.s eUoe.s 23CL0 3Db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0|\",\n\t\t\"Asia/Qyzylorda|LMT +04 +05 +06|-4l.Q -40 -50 -60|01232323232323232323232323232323232323232323232|-1Pc4l.Q eUol.Q 23CL0 3Db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 3ao0 1EM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 zQl0|73e4\",\n\t\t\"Asia/Rangoon|RMT +0630 +09|-6o.L -6u -90|0121|-21Jio.L SmnS.L 7j9u|48e5\",\n\t\t\"Asia/Sakhalin|LMT +09 +11 +12 +10|-9u.M -90 -b0 -c0 -a0|01232323232323232323232423232323232424242424242424242424242424242|-2AGVu.M 1BoMu.M 1qFa0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 2pB0 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 8Hz0 3rd0|58e4\",\n\t\t\"Asia/Samarkand|LMT +04 +05 +06|-4r.R -40 -50 -60|01232323232323232323232|-1Pc4r.R eUor.R 23CL0 3Db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0|36e4\",\n\t\t\"Asia/Seoul|LMT KST JST KST KDT KDT|-8r.Q -8u -90 -90 -a0 -9u|012343434343151515151515134343|-2um8r.Q 97XV.Q 1m1zu 6CM0 Fz0 1kN0 14n0 1kN0 14L0 1zd0 On0 69B0 2I0u OL0 1FB0 Rb0 1qN0 TX0 1tB0 TX0 1tB0 TX0 1tB0 TX0 2ap0 12FBu 11A0 1o00 11A0|23e6\",\n\t\t\"Asia/Srednekolymsk|LMT +10 +11 +12|-ae.Q -a0 -b0 -c0|01232323232323232323232123232323232323232323232323232323232323232|-1Pcae.Q eUoe.Q 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 8Hz0|35e2\",\n\t\t\"Asia/Taipei|CST JST CDT|-80 -90 -90|01020202020202020202020202020202020202020|-1iw80 joM0 1yo0 Tz0 1ip0 1jX0 1cN0 11b0 1oN0 11b0 1oN0 11b0 1oN0 11b0 10N0 1BX0 10p0 1pz0 10p0 1pz0 10p0 1db0 1dd0 1db0 1cN0 1db0 1cN0 1db0 1cN0 1db0 1BB0 ML0 1Bd0 ML0 uq10 1db0 1cN0 1db0 97B0 AL0|74e5\",\n\t\t\"Asia/Tashkent|LMT +05 +06 +07|-4B.b -50 -60 -70|012323232323232323232321|-1Pc4B.b eUnB.b 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0|23e5\",\n\t\t\"Asia/Tbilisi|TBMT +03 +04 +05|-2X.b -30 -40 -50|0123232323232323232323212121232323232323232323212|-1Pc2X.b 1jUnX.b WCL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 1cK0 1cL0 1cN0 1cL0 1cN0 2pz0 1cL0 1fB0 3Nz0 11B0 1nX0 11B0 1qL0 WN0 1qL0 WN0 1qL0 11B0 1nX0 11B0 1nX0 11B0 An0 Os0 WM0|11e5\",\n\t\t\"Asia/Tehran|LMT TMT +0330 +04 +05 +0430|-3p.I -3p.I -3u -40 -50 -4u|01234325252525252525252525252525252525252525252525252525252525252525252525252525252525252525252525252|-2btDp.I 1d3c0 1huLT.I TXu 1pz0 sN0 vAu 1cL0 1dB0 1en0 pNB0 UL0 1cN0 1dz0 1cp0 1dz0 1cp0 1dz0 1cp0 1dz0 1cp0 1dz0 1cN0 1dz0 1cp0 1dz0 1cp0 1dz0 1cp0 1dz0 1cN0 1dz0 1cp0 1dz0 1cp0 1dz0 1cp0 1dz0 1cN0 1dz0 64p0 1dz0 1cN0 1dz0 1cp0 1dz0 1cp0 1dz0 1cp0 1dz0 1cN0 1dz0 1cp0 1dz0 1cp0 1dz0 1cp0 1dz0 1cN0 1dz0 1cp0 1dz0 1cp0 1dz0 1cp0 1dz0 1cN0 1dz0 1cp0 1dz0 1cp0 1dz0 1cp0 1dz0 1cN0 1dz0 1cp0 1dz0 1cp0 1dz0 1cp0 1dz0 1cp0 1dz0 1cN0 1dz0 1cp0 1dz0 1cp0 1dz0 1cp0 1dz0 1cN0 1dz0 1cp0 1dz0 1cp0 1dz0 1cp0 1dz0|14e6\",\n\t\t\"Asia/Thimphu|LMT +0530 +06|-5W.A -5u -60|012|-Su5W.A 1BGMs.A|79e3\",\n\t\t\"Asia/Tokyo|JST JDT|-90 -a0|010101010|-QJJ0 Rc0 1lc0 14o0 1zc0 Oo0 1zc0 Oo0|38e6\",\n\t\t\"Asia/Tomsk|LMT +06 +07 +08|-5D.P -60 -70 -80|0123232323232323232323212323232323232323232323212121212121212121212|-21NhD.P pxzD.P 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 co0 1bB0 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 8Hz0 3Qp0|10e5\",\n\t\t\"Asia/Ulaanbaatar|LMT +07 +08 +09|-77.w -70 -80 -90|012323232323232323232323232323232323232323232323232|-2APH7.w 2Uko7.w cKn0 1db0 1dd0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1fB0 1cL0 1cN0 1cL0 1cN0 1cL0 6hD0 11z0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 kEp0 1cJ0 1cP0 1cJ0|12e5\",\n\t\t\"Asia/Ust-Nera|LMT +08 +09 +12 +11 +10|-9w.S -80 -90 -c0 -b0 -a0|012343434343434343434345434343434343434343434343434343434343434345|-21Q9w.S pApw.S 23CL0 1d90 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 17V0 7zD0|65e2\",\n\t\t\"Asia/Vladivostok|LMT +09 +10 +11|-8L.v -90 -a0 -b0|01232323232323232323232123232323232323232323232323232323232323232|-1SJIL.v itXL.v 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 8Hz0|60e4\",\n\t\t\"Asia/Yakutsk|LMT +08 +09 +10|-8C.W -80 -90 -a0|01232323232323232323232123232323232323232323232323232323232323232|-21Q8C.W pAoC.W 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 8Hz0|28e4\",\n\t\t\"Asia/Yekaterinburg|LMT PMT +04 +05 +06|-42.x -3J.5 -40 -50 -60|012343434343434343434343234343434343434343434343434343434343434343|-2ag42.x 7mQh.s qBvJ.5 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 8Hz0|14e5\",\n\t\t\"Asia/Yerevan|LMT +03 +04 +05|-2W -30 -40 -50|0123232323232323232323212121212323232323232323232323232323232|-1Pc2W 1jUnW WCL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 2pB0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 4RX0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0|13e5\",\n\t\t\"Atlantic/Azores|HMT -02 -01 +00 WET|1S.w 20 10 0 0|0121212121212121212121212121212121212121212123212321232123212121212121212121212121212121212121212121232323232323232323232323232323234323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232|-2ldW0 aPX0 Sp0 LX0 1vc0 Tc0 1uM0 SM0 1vc0 Tc0 1vc0 SM0 1vc0 6600 1co0 3E00 17c0 1fA0 1a00 1io0 1a00 1io0 17c0 3I00 17c0 1cM0 1cM0 3Fc0 1cM0 1a00 1fA0 1io0 17c0 1cM0 1cM0 1a00 1fA0 1io0 1qM0 Dc0 1tA0 1cM0 1dc0 1400 gL0 IM0 s10 U00 dX0 Rc0 pd0 Rc0 gL0 Oo0 pd0 Rc0 gL0 Oo0 pd0 14o0 1cM0 1cP0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 qIl0 1cM0 1fA0 1cM0 1cM0 1cN0 1cL0 1cN0 1cM0 1cM0 1cM0 1cM0 1cN0 1cL0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cL0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|25e4\",\n\t\t\"Atlantic/Bermuda|BMT BST AST ADT|4j.i 3j.i 40 30|010102323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232|-28p7E.G 1bb0 1i10 11X0 ru30 thbE.G 1PX0 11B0 1tz0 Rd0 1zb0 Op0 1zb0 3I10 Lz0 1EN0 FX0 1HB0 FX0 1Kp0 Db0 1Kp0 Db0 1Kp0 FX0 93d0 11z0 GAp0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|65e3\",\n\t\t\"Atlantic/Canary|LMT -01 WET WEST|11.A 10 0 -10|01232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232|-1UtaW.o XPAW.o 1lAK0 1a10 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|54e4\",\n\t\t\"Atlantic/Cape_Verde|LMT -02 -01|1y.4 20 10|01212|-2ldW0 1eEo0 7zX0 1djf0|50e4\",\n\t\t\"Atlantic/Faroe|LMT WET WEST|r.4 0 -10|01212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-2uSnw.U 2Wgow.U 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|49e3\",\n\t\t\"Atlantic/Madeira|FMT -01 +00 +01 WET WEST|17.A 10 0 -10 0 -10|0121212121212121212121212121212121212121212123212321232123212121212121212121212121212121212121212121454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454|-2ldX0 aPX0 Sp0 LX0 1vc0 Tc0 1uM0 SM0 1vc0 Tc0 1vc0 SM0 1vc0 6600 1co0 3E00 17c0 1fA0 1a00 1io0 1a00 1io0 17c0 3I00 17c0 1cM0 1cM0 3Fc0 1cM0 1a00 1fA0 1io0 17c0 1cM0 1cM0 1a00 1fA0 1io0 1qM0 Dc0 1tA0 1cM0 1dc0 1400 gL0 IM0 s10 U00 dX0 Rc0 pd0 Rc0 gL0 Oo0 pd0 Rc0 gL0 Oo0 pd0 14o0 1cM0 1cP0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 qIl0 1cM0 1fA0 1cM0 1cM0 1cN0 1cL0 1cN0 1cM0 1cM0 1cM0 1cM0 1cN0 1cL0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|27e4\",\n\t\t\"Atlantic/Reykjavik|LMT -01 +00 GMT|1s 10 0 0|012121212121212121212121212121212121212121212121212121212121212121213|-2uWmw mfaw 1Bd0 ML0 1LB0 Cn0 1LB0 3fX0 C10 HrX0 1cO0 LB0 1EL0 LA0 1C00 Oo0 1wo0 Rc0 1wo0 Rc0 1wo0 Rc0 1zc0 Oo0 1zc0 14o0 1lc0 14o0 1lc0 14o0 1o00 11A0 1lc0 14o0 1o00 14o0 1lc0 14o0 1lc0 14o0 1lc0 14o0 1lc0 14o0 1o00 14o0 1lc0 14o0 1lc0 14o0 1lc0 14o0 1lc0 14o0 1lc0 14o0 1o00 14o0 1lc0 14o0 1lc0 14o0 1lc0 14o0 1lc0 14o0 1o00 14o0|12e4\",\n\t\t\"Atlantic/South_Georgia|-02|20|0||30\",\n\t\t\"Atlantic/Stanley|SMT -04 -03 -02|3P.o 40 30 20|012121212121212323212121212121212121212121212121212121212121212121212|-2kJw8.A 12bA8.A 19X0 1fB0 19X0 1ip0 19X0 1fB0 19X0 1fB0 19X0 1fB0 Cn0 1Cc10 WL0 1qL0 U10 1tz0 2mN0 WN0 1qL0 WN0 1qL0 WN0 1qL0 WN0 1tz0 U10 1tz0 WN0 1qL0 WN0 1qL0 WN0 1qL0 WN0 1qL0 WN0 1tz0 WN0 1qL0 WN0 1qL0 WN0 1qL0 WN0 1qL0 WN0 1qN0 U10 1wn0 Rd0 1wn0 U10 1tz0 U10 1tz0 U10 1tz0 U10 1tz0 U10 1wn0 U10 1tz0 U10 1tz0 U10|21e2\",\n\t\t\"Australia/Sydney|AEST AEDT|-a0 -b0|0101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101|-293k0 xc0 10jc0 yM0 1cM0 1cM0 1fA0 1a00 17c00 LA0 1C00 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Rc0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 14o0 1o00 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 U00 1qM0 WM0 1tA0 WM0 1tA0 U00 1tA0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Rc0 1zc0 Oo0 1zc0 Oo0 1zc0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 11A0 1o00 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 11A0 1o00 WM0 1qM0 14o0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0|40e5\",\n\t\t\"Australia/Adelaide|ACST ACDT|-9u -au|0101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101|-293ju xc0 10jc0 yM0 1cM0 1cM0 1fA0 1a00 17c00 LA0 1C00 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Rc0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Rc0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 U00 1qM0 WM0 1tA0 WM0 1tA0 U00 1tA0 U00 1tA0 Oo0 1zc0 WM0 1qM0 Rc0 1zc0 U00 1tA0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 11A0 1o00 WM0 1qM0 14o0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0|11e5\",\n\t\t\"Australia/Brisbane|AEST AEDT|-a0 -b0|01010101010101010|-293k0 xc0 10jc0 yM0 1cM0 1cM0 1fA0 1a00 17c00 LA0 H1A0 Oo0 1zc0 Oo0 1zc0 Oo0|20e5\",\n\t\t\"Australia/Broken_Hill|ACST ACDT|-9u -au|0101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101|-293ju xc0 10jc0 yM0 1cM0 1cM0 1fA0 1a00 17c00 LA0 1C00 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Rc0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 14o0 1o00 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 U00 1qM0 WM0 1tA0 WM0 1tA0 U00 1tA0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Rc0 1zc0 Oo0 1zc0 Oo0 1zc0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 11A0 1o00 WM0 1qM0 14o0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0|18e3\",\n\t\t\"Australia/Hobart|AEST AEDT|-a0 -b0|0101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101|-29E80 1a00 1qM0 Oo0 1zc0 Oo0 TAo0 yM0 1cM0 1cM0 1fA0 1a00 VfA0 1cM0 1o00 Rc0 1wo0 Rc0 1wo0 U00 1wo0 LA0 1C00 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Rc0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 11A0 1qM0 WM0 1qM0 Oo0 1zc0 Oo0 1zc0 Oo0 1wo0 WM0 1tA0 WM0 1tA0 U00 1tA0 U00 1tA0 11A0 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1cM0 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 11A0 1o00 1io0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1cM0 1cM0 1a00 1io0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0|21e4\",\n\t\t\"Australia/Darwin|ACST ACDT|-9u -au|010101010|-293ju xc0 10jc0 yM0 1cM0 1cM0 1fA0 1a00|12e4\",\n\t\t\"Australia/Eucla|+0845 +0945|-8J -9J|0101010101010101010|-293iJ xc0 10jc0 yM0 1cM0 1cM0 1gSo0 Oo0 l5A0 Oo0 iJA0 G00 zU00 IM0 1qM0 11A0 1o00 11A0|368\",\n\t\t\"Australia/Lord_Howe|AEST +1030 +1130 +11|-a0 -au -bu -b0|0121212121313131313131313131313131313131313131313131313131313131313131313131313131313131313131313131313131313131313|raC0 1zdu Rb0 1zd0 On0 1zd0 On0 1zd0 On0 1zd0 TXu 1qMu WLu 1tAu WLu 1tAu TXu 1tAu Onu 1zcu Onu 1zcu Onu 1zcu Rbu 1zcu Onu 1zcu Onu 1zcu 11zu 1o0u 11zu 1o0u 11zu 1o0u 11zu 1qMu WLu 11Au 1nXu 1qMu 11zu 1o0u 11zu 1o0u 11zu 1qMu WLu 1qMu 11zu 1o0u WLu 1qMu 14nu 1cMu 1cLu 1cMu 1cLu 1cMu 1cLu 1cMu 1cLu 1fAu 1cLu 1cMu 1cLu 1cMu 1cLu 1cMu 1cLu 1cMu 1cLu 1cMu 1cLu 1fAu 1cLu 1cMu 1cLu 1cMu 1cLu 1cMu 1cLu 1cMu 1cLu 1cMu 1fzu 1cMu 1cLu 1cMu 1cLu 1cMu 1cLu 1cMu 1cLu 1cMu 1cLu 1fAu 1cLu 1cMu 1cLu 1cMu 1cLu 1cMu 1cLu 1cMu 1cLu 1cMu 1cLu 1fAu 1cLu 1cMu 1cLu 1cMu|347\",\n\t\t\"Australia/Lindeman|AEST AEDT|-a0 -b0|010101010101010101010|-293k0 xc0 10jc0 yM0 1cM0 1cM0 1fA0 1a00 17c00 LA0 H1A0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Rc0 1zc0 Oo0|10\",\n\t\t\"Australia/Melbourne|AEST AEDT|-a0 -b0|0101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101|-293k0 xc0 10jc0 yM0 1cM0 1cM0 1fA0 1a00 17c00 LA0 1C00 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Rc0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Rc0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 U00 1qM0 WM0 1qM0 11A0 1tA0 U00 1tA0 U00 1tA0 Oo0 1zc0 Oo0 1zc0 Rc0 1zc0 Oo0 1zc0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 11A0 1o00 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 11A0 1o00 WM0 1qM0 14o0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0|39e5\",\n\t\t\"Australia/Perth|AWST AWDT|-80 -90|0101010101010101010|-293i0 xc0 10jc0 yM0 1cM0 1cM0 1gSo0 Oo0 l5A0 Oo0 iJA0 G00 zU00 IM0 1qM0 11A0 1o00 11A0|18e5\",\n\t\t\"CET|CET CEST|-10 -20|01010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-2aFe0 11d0 1iO0 11A0 1o00 11A0 Qrc0 6i00 WM0 1fA0 1cM0 1cM0 1cM0 16M0 1gMM0 1a00 1fA0 1cM0 1cM0 1cM0 1fA0 1a00 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|\",\n\t\t\"Pacific/Easter|EMT -07 -06 -05|7h.s 70 60 50|012121212121212121212121212123232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323|-1uSgG.w 1s4IG.w WL0 1zd0 On0 1ip0 11z0 1o10 11z0 1qN0 WL0 1ld0 14n0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 WL0 1qN0 11z0 1o10 2pA0 11z0 1o10 11z0 1qN0 WL0 1qN0 WL0 1qN0 1cL0 1cN0 11z0 1o10 11z0 1qN0 WL0 1fB0 19X0 1qN0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 17b0 1ip0 11z0 1ip0 1fz0 1fB0 11z0 1qN0 WL0 1qN0 WL0 1qN0 WL0 1qN0 11z0 1o10 11z0 1o10 11z0 1qN0 WL0 1qN0 17b0 1ip0 11z0 1o10 19X0 1fB0 1nX0 G10 1EL0 Op0 1zb0 Rd0 1wn0 Rd0 46n0 Ap0 1Nb0 Ap0 1Nb0 Ap0 1zb0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1qL0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1qL0 WN0 1qL0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1nX0 11B0 1qL0 WN0 1qL0 11B0 1nX0 11B0|30e2\",\n\t\t\"CST6CDT|CST CDT CWT CPT|60 50 50 50|010102301010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-261s0 1nX0 11B0 1nX0 SgN0 8x30 iw0 QwN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|\",\n\t\t\"EET|EET EEST|-20 -30|010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|hDB0 1a00 1fA0 1cM0 1cM0 1cM0 1fA0 1a00 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|\",\n\t\t\"Europe/Dublin|DMT IST GMT BST IST|p.l -y.D 0 -10 -10|01232323232324242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242424242|-2ax9y.D Rc0 1fzy.D 14M0 1fc0 1g00 1co0 1dc0 1co0 1oo0 1400 1dc0 19A0 1io0 1io0 WM0 1o00 14o0 1o00 17c0 1io0 17c0 1fA0 1a00 1lc0 17c0 1io0 17c0 1fA0 1a00 1io0 17c0 1io0 17c0 1fA0 1cM0 1io0 17c0 1fA0 1a00 1io0 17c0 1io0 17c0 1fA0 1a00 1io0 1qM0 Dc0 g600 14o0 1wo0 17c0 1io0 11A0 1o00 17c0 1fA0 1a00 1fA0 1cM0 1fA0 1a00 17c0 1fA0 1a00 1io0 17c0 1lc0 17c0 1fA0 1a00 1io0 17c0 1io0 17c0 1fA0 1a00 1a00 1qM0 WM0 1qM0 11A0 1o00 WM0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1tA0 IM0 90o0 U00 1tA0 U00 1tA0 U00 1tA0 U00 1tA0 WM0 1qM0 WM0 1qM0 WM0 1tA0 U00 1tA0 U00 1tA0 11z0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1o00 14o0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|12e5\",\n\t\t\"EST|EST|50|0||\",\n\t\t\"EST5EDT|EST EDT EWT EPT|50 40 40 40|010102301010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-261t0 1nX0 11B0 1nX0 SgN0 8x40 iv0 QwN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|\",\n\t\t\"Etc/GMT-0|GMT|0|0||\",\n\t\t\"Etc/GMT-1|+01|-10|0||\",\n\t\t\"Etc/GMT-11|+11|-b0|0||\",\n\t\t\"Pacific/Tarawa|+12|-c0|0||29e3\",\n\t\t\"Etc/GMT-13|+13|-d0|0||\",\n\t\t\"Etc/GMT-14|+14|-e0|0||\",\n\t\t\"Etc/GMT-2|+02|-20|0||\",\n\t\t\"Etc/GMT-3|+03|-30|0||\",\n\t\t\"Etc/GMT-4|+04|-40|0||\",\n\t\t\"Etc/GMT-5|+05|-50|0||\",\n\t\t\"Etc/GMT-6|+06|-60|0||\",\n\t\t\"Indian/Christmas|+07|-70|0||21e2\",\n\t\t\"Etc/GMT-8|+08|-80|0||\",\n\t\t\"Pacific/Palau|+09|-90|0||21e3\",\n\t\t\"Etc/GMT+1|-01|10|0||\",\n\t\t\"Etc/GMT+10|-10|a0|0||\",\n\t\t\"Etc/GMT+11|-11|b0|0||\",\n\t\t\"Etc/GMT+12|-12|c0|0||\",\n\t\t\"Etc/GMT+3|-03|30|0||\",\n\t\t\"Etc/GMT+4|-04|40|0||\",\n\t\t\"Etc/GMT+5|-05|50|0||\",\n\t\t\"Etc/GMT+6|-06|60|0||\",\n\t\t\"Etc/GMT+7|-07|70|0||\",\n\t\t\"Etc/GMT+8|-08|80|0||\",\n\t\t\"Etc/GMT+9|-09|90|0||\",\n\t\t\"Etc/UTC|UTC|0|0||\",\n\t\t\"Europe/Amsterdam|AMT NST +0120 +0020 CEST CET|-j.w -1j.w -1k -k -20 -10|010101010101010101010101010101010101010101012323234545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545|-2aFcj.w 11b0 1iP0 11A0 1io0 1cM0 1fA0 1a00 1fA0 1a00 1fA0 1a00 1co0 1io0 1yo0 Pc0 1a00 1fA0 1Bc0 Mo0 1tc0 Uo0 1tA0 U00 1uo0 W00 1s00 VA0 1so0 Vc0 1sM0 UM0 1wo0 Rc0 1u00 Wo0 1rA0 W00 1s00 VA0 1sM0 UM0 1w00 fV0 BCX.w 1tA0 U00 1u00 Wo0 1sm0 601k WM0 1fA0 1cM0 1cM0 1cM0 16M0 1gMM0 1a00 1fA0 1cM0 1cM0 1cM0 1fA0 1a00 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|16e5\",\n\t\t\"Europe/Andorra|WET CET CEST|0 -10 -20|012121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-UBA0 1xIN0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|79e3\",\n\t\t\"Europe/Astrakhan|LMT +03 +04 +05|-3c.c -30 -40 -50|012323232323232323212121212121212121212121212121212121212121212|-1Pcrc.c eUMc.c 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 2pB0 1cM0 1fA0 1cM0 3Co0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 8Hz0 3rd0|10e5\",\n\t\t\"Europe/Athens|AMT EET EEST CEST CET|-1y.Q -20 -30 -20 -10|012123434121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-2a61x.Q CNbx.Q mn0 kU10 9b0 3Es0 Xa0 1fb0 1dd0 k3X0 Nz0 SCp0 1vc0 SO0 1cM0 1a00 1ao0 1fc0 1a10 1fG0 1cg0 1dX0 1bX0 1cQ0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|35e5\",\n\t\t\"Europe/London|GMT BST BDST|0 -10 -20|0101010101010101010101010101010101010101010101010121212121210101210101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-2axa0 Rc0 1fA0 14M0 1fc0 1g00 1co0 1dc0 1co0 1oo0 1400 1dc0 19A0 1io0 1io0 WM0 1o00 14o0 1o00 17c0 1io0 17c0 1fA0 1a00 1lc0 17c0 1io0 17c0 1fA0 1a00 1io0 17c0 1io0 17c0 1fA0 1cM0 1io0 17c0 1fA0 1a00 1io0 17c0 1io0 17c0 1fA0 1a00 1io0 1qM0 Dc0 2Rz0 Dc0 1zc0 Oo0 1zc0 Rc0 1wo0 17c0 1iM0 FA0 xB0 1fA0 1a00 14o0 bb0 LA0 xB0 Rc0 1wo0 11A0 1o00 17c0 1fA0 1a00 1fA0 1cM0 1fA0 1a00 17c0 1fA0 1a00 1io0 17c0 1lc0 17c0 1fA0 1a00 1io0 17c0 1io0 17c0 1fA0 1a00 1a00 1qM0 WM0 1qM0 11A0 1o00 WM0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1tA0 IM0 90o0 U00 1tA0 U00 1tA0 U00 1tA0 U00 1tA0 WM0 1qM0 WM0 1qM0 WM0 1tA0 U00 1tA0 U00 1tA0 11z0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1o00 14o0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|10e6\",\n\t\t\"Europe/Belgrade|CET CEST|-10 -20|01010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-19RC0 3IP0 WM0 1fA0 1cM0 1cM0 1rc0 Qo0 1vmo0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|12e5\",\n\t\t\"Europe/Berlin|CET CEST CEMT|-10 -20 -30|01010101010101210101210101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-2aFe0 11d0 1iO0 11A0 1o00 11A0 Qrc0 6i00 WM0 1fA0 1cM0 1cM0 1cM0 kL0 Nc0 m10 WM0 1ao0 1cp0 dX0 jz0 Dd0 1io0 17c0 1fA0 1a00 1ehA0 1a00 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|41e5\",\n\t\t\"Europe/Prague|CET CEST GMT|-10 -20 0|01010101010101010201010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-2aFe0 11d0 1iO0 11A0 1o00 11A0 Qrc0 6i00 WM0 1fA0 1cM0 1cM0 1cM0 1cM0 1qM0 11c0 mp0 xA0 mn0 17c0 1io0 17c0 1fc0 1ao0 1bNc0 1cM0 1fA0 1a00 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|13e5\",\n\t\t\"Europe/Brussels|WET CET CEST WEST|0 -10 -20 -10|0121212103030303030303030303030303030303030303030303212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-2ehc0 3zX0 11c0 1iO0 11A0 1o00 11A0 my0 Ic0 1qM0 Rc0 1EM0 UM0 1u00 10o0 1io0 1io0 17c0 1a00 1fA0 1cM0 1cM0 1io0 17c0 1fA0 1a00 1io0 1a30 1io0 17c0 1fA0 1a00 1io0 17c0 1cM0 1cM0 1a00 1io0 1cM0 1cM0 1a00 1fA0 1io0 17c0 1cM0 1cM0 1a00 1fA0 1io0 1qM0 Dc0 y00 5Wn0 WM0 1fA0 1cM0 16M0 1iM0 16M0 1C00 Uo0 1eeo0 1a00 1fA0 1cM0 1cM0 1cM0 1fA0 1a00 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|21e5\",\n\t\t\"Europe/Bucharest|BMT EET EEST|-1I.o -20 -30|0121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-1xApI.o 20LI.o RA0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1Axc0 On0 1fA0 1a10 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cK0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cL0 1cN0 1cL0 1fB0 1nX0 11E0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|19e5\",\n\t\t\"Europe/Budapest|CET CEST|-10 -20|0101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-2aFe0 11d0 1iO0 11A0 1o00 11A0 1oo0 11c0 1lc0 17c0 O1V0 3Nf0 WM0 1fA0 1cM0 1cM0 1oJ0 1dd0 1020 1fX0 1cp0 1cM0 1cM0 1cM0 1fA0 1a00 bhy0 Rb0 1wr0 Rc0 1C00 LA0 1C00 LA0 SNW0 1a00 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cO0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|17e5\",\n\t\t\"Europe/Zurich|CET CEST|-10 -20|01010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-19Lc0 11A0 1o00 11A0 1xG10 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|38e4\",\n\t\t\"Europe/Chisinau|CMT BMT EET EEST CEST CET MSK MSD|-1T -1I.o -20 -30 -20 -10 -30 -40|012323232323232323234545467676767676767676767323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232323232|-26jdT wGMa.A 20LI.o RA0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 27A0 2en0 39g0 WM0 1fA0 1cM0 V90 1t7z0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 gL0 WO0 1cM0 1cM0 1cK0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1fB0 1nX0 11D0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|67e4\",\n\t\t\"Europe/Copenhagen|CET CEST|-10 -20|0101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-2azC0 Tz0 VuO0 60q0 WM0 1fA0 1cM0 1cM0 1cM0 S00 1HA0 Nc0 1C00 Dc0 1Nc0 Ao0 1h5A0 1a00 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|12e5\",\n\t\t\"Europe/Gibraltar|GMT BST BDST CET CEST|0 -10 -20 -10 -20|010101010101010101010101010101010101010101010101012121212121010121010101010101010101034343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343|-2axa0 Rc0 1fA0 14M0 1fc0 1g00 1co0 1dc0 1co0 1oo0 1400 1dc0 19A0 1io0 1io0 WM0 1o00 14o0 1o00 17c0 1io0 17c0 1fA0 1a00 1lc0 17c0 1io0 17c0 1fA0 1a00 1io0 17c0 1io0 17c0 1fA0 1cM0 1io0 17c0 1fA0 1a00 1io0 17c0 1io0 17c0 1fA0 1a00 1io0 1qM0 Dc0 2Rz0 Dc0 1zc0 Oo0 1zc0 Rc0 1wo0 17c0 1iM0 FA0 xB0 1fA0 1a00 14o0 bb0 LA0 xB0 Rc0 1wo0 11A0 1o00 17c0 1fA0 1a00 1fA0 1cM0 1fA0 1a00 17c0 1fA0 1a00 1io0 17c0 1lc0 17c0 1fA0 10Jz0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|30e3\",\n\t\t\"Europe/Helsinki|HMT EET EEST|-1D.N -20 -30|0121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-1WuND.N OULD.N 1dA0 1xGq0 1cM0 1cM0 1cM0 1cN0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|12e5\",\n\t\t\"Europe/Kaliningrad|CET CEST EET EEST MSK MSD +03|-10 -20 -20 -30 -30 -40 -30|01010101010101232454545454545454543232323232323232323232323232323232323232323262|-2aFe0 11d0 1iO0 11A0 1o00 11A0 Qrc0 6i00 WM0 1fA0 1cM0 1cM0 1cM0 390 7A0 1en0 12N0 1pbb0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cN0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 8Hz0|44e4\",\n\t\t\"Europe/Kiev|KMT EET MSK CEST CET MSD EEST|-22.4 -20 -30 -20 -10 -40 -30|0123434252525252525252525256161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161|-1Pc22.4 eUo2.4 rnz0 2Hg0 WM0 1fA0 da0 1v4m0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 Db0 3220 1cK0 1cL0 1cN0 1cL0 1cN0 1cL0 1cQ0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|34e5\",\n\t\t\"Europe/Kirov|LMT +03 +04 +05|-3i.M -30 -40 -50|01232323232323232321212121212121212121212121212121212121212121|-22WM0 qH90 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 2pB0 1cM0 1fA0 1cM0 3Co0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 8Hz0|48e4\",\n\t\t\"Europe/Lisbon|LMT WET WEST WEMT CET CEST|A.J 0 -10 -20 -10 -20|01212121212121212121212121212121212121212121232123212321232121212121212121212121212121212121212121214121212121212121212121212121212124545454212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-2le00 aPX0 Sp0 LX0 1vc0 Tc0 1uM0 SM0 1vc0 Tc0 1vc0 SM0 1vc0 6600 1co0 3E00 17c0 1fA0 1a00 1io0 1a00 1io0 17c0 3I00 17c0 1cM0 1cM0 3Fc0 1cM0 1a00 1fA0 1io0 17c0 1cM0 1cM0 1a00 1fA0 1io0 1qM0 Dc0 1tA0 1cM0 1dc0 1400 gL0 IM0 s10 U00 dX0 Rc0 pd0 Rc0 gL0 Oo0 pd0 Rc0 gL0 Oo0 pd0 14o0 1cM0 1cP0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 pvy0 1cM0 1cM0 1fA0 1cM0 1cM0 1cN0 1cL0 1cN0 1cM0 1cM0 1cM0 1cM0 1cN0 1cL0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|27e5\",\n\t\t\"Europe/Luxembourg|LMT CET CEST WET WEST WEST WET|-o.A -10 -20 0 -10 -20 -10|0121212134343434343434343434343434343434343434343434565651212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-2DG0o.A t6mo.A TB0 1nX0 Up0 1o20 11A0 rW0 CM0 1qP0 R90 1EO0 UK0 1u20 10m0 1ip0 1in0 17e0 19W0 1fB0 1db0 1cp0 1in0 17d0 1fz0 1a10 1in0 1a10 1in0 17f0 1fA0 1a00 1io0 17c0 1cM0 1cM0 1a00 1io0 1cM0 1cM0 1a00 1fA0 1io0 17c0 1cM0 1cM0 1a00 1fA0 1io0 1qM0 Dc0 vA0 60L0 WM0 1fA0 1cM0 17c0 1io0 16M0 1C00 Uo0 1eeo0 1a00 1fA0 1cM0 1cM0 1cM0 1fA0 1a00 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|54e4\",\n\t\t\"Europe/Madrid|WET WEST WEMT CET CEST|0 -10 -20 -10 -20|010101010101010101210343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343|-25Td0 19B0 1cL0 1dd0 b1z0 18p0 3HX0 17d0 1fz0 1a10 1io0 1a00 1in0 17d0 iIn0 Hd0 1cL0 bb0 1200 2s20 14n0 5aL0 Mp0 1vz0 17d0 1in0 17d0 1in0 17d0 1in0 17d0 6hX0 11B0 XHX0 1a10 1fz0 1a10 19X0 1cN0 1fz0 1a10 1fC0 1cM0 1cM0 1cM0 1fA0 1a00 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|62e5\",\n\t\t\"Europe/Malta|CET CEST|-10 -20|0101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-2arB0 Lz0 1cN0 1db0 1410 1on0 Wp0 1qL0 17d0 1cL0 M3B0 5M20 WM0 1fA0 1co0 17c0 1iM0 16m0 1de0 1lc0 14m0 1lc0 WO0 1qM0 GTW0 On0 1C10 LA0 1C00 LA0 1EM0 LA0 1C00 LA0 1zc0 Oo0 1C00 Oo0 1co0 1cM0 1lA0 Xc0 1qq0 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1o10 11z0 1iN0 19z0 1fB0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|42e4\",\n\t\t\"Europe/Minsk|MMT EET MSK CEST CET MSD EEST +03|-1O -20 -30 -20 -10 -40 -30 -30|01234343252525252525252525261616161616161616161616161616161616161617|-1Pc1O eUnO qNX0 3gQ0 WM0 1fA0 1cM0 Al0 1tsn0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 3Fc0 1cN0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0|19e5\",\n\t\t\"Europe/Monaco|PMT WET WEST WEMT CET CEST|-9.l 0 -10 -20 -10 -20|01212121212121212121212121212121212121212121212121232323232345454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454|-2n5c9.l cFX9.l HA0 19A0 1iM0 11c0 1oo0 Wo0 1rc0 QM0 1EM0 UM0 1u00 10o0 1io0 1wo0 Rc0 1a00 1fA0 1cM0 1cM0 1io0 17c0 1fA0 1a00 1io0 1a00 1io0 17c0 1fA0 1a00 1io0 17c0 1cM0 1cM0 1a00 1io0 1cM0 1cM0 1a00 1fA0 1io0 17c0 1cM0 1cM0 1a00 1fA0 1io0 1qM0 Df0 2RV0 11z0 11B0 1ze0 WM0 1fA0 1cM0 1fa0 1aq0 16M0 1ekn0 1cL0 1fC0 1a00 1fA0 1cM0 1cM0 1cM0 1fA0 1a00 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|38e3\",\n\t\t\"Europe/Moscow|MMT MMT MST MDST MSD MSK +05 EET EEST MSK|-2u.h -2v.j -3v.j -4v.j -40 -30 -50 -20 -30 -40|012132345464575454545454545454545458754545454545454545454545454545454545454595|-2ag2u.h 2pyW.W 1bA0 11X0 GN0 1Hb0 c4v.j ik0 3DA0 dz0 15A0 c10 2q10 iM10 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cN0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 8Hz0|16e6\",\n\t\t\"Europe/Paris|PMT WET WEST CEST CET WEMT|-9.l 0 -10 -20 -10 -20|0121212121212121212121212121212121212121212121212123434352543434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434343434|-2nco9.l cNb9.l HA0 19A0 1iM0 11c0 1oo0 Wo0 1rc0 QM0 1EM0 UM0 1u00 10o0 1io0 1wo0 Rc0 1a00 1fA0 1cM0 1cM0 1io0 17c0 1fA0 1a00 1io0 1a00 1io0 17c0 1fA0 1a00 1io0 17c0 1cM0 1cM0 1a00 1io0 1cM0 1cM0 1a00 1fA0 1io0 17c0 1cM0 1cM0 1a00 1fA0 1io0 1qM0 Df0 Ik0 5M30 WM0 1fA0 1cM0 Vx0 hB0 1aq0 16M0 1ekn0 1cL0 1fC0 1a00 1fA0 1cM0 1cM0 1cM0 1fA0 1a00 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|11e6\",\n\t\t\"Europe/Riga|RMT LST EET MSK CEST CET MSD EEST|-1A.y -2A.y -20 -30 -20 -10 -40 -30|010102345454536363636363636363727272727272727272727272727272727272727272727272727272727272727272727272727272727272727272727272|-25TzA.y 11A0 1iM0 ko0 gWm0 yDXA.y 2bX0 3fE0 WM0 1fA0 1cM0 1cM0 4m0 1sLy0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cN0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cN0 1o00 11A0 1o00 11A0 1qM0 3oo0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|64e4\",\n\t\t\"Europe/Rome|CET CEST|-10 -20|0101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-2arB0 Lz0 1cN0 1db0 1410 1on0 Wp0 1qL0 17d0 1cL0 M3B0 5M20 WM0 1fA0 1cM0 16M0 1iM0 16m0 1de0 1lc0 14m0 1lc0 WO0 1qM0 GTW0 On0 1C10 LA0 1C00 LA0 1EM0 LA0 1C00 LA0 1zc0 Oo0 1C00 Oo0 1C00 LA0 1zc0 Oo0 1C00 LA0 1C00 LA0 1zc0 Oo0 1C00 Oo0 1zc0 Oo0 1fC0 1a00 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|39e5\",\n\t\t\"Europe/Samara|LMT +03 +04 +05|-3k.k -30 -40 -50|0123232323232323232121232323232323232323232323232323232323212|-22WM0 qH90 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 2pB0 1cM0 1fA0 2y10 14m0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 2sp0 WM0|12e5\",\n\t\t\"Europe/Saratov|LMT +03 +04 +05|-34.i -30 -40 -50|012323232323232321212121212121212121212121212121212121212121212|-22WM0 qH90 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 2pB0 1cM0 1cM0 1cM0 1fA0 1cM0 3Co0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 8Hz0 5810|\",\n\t\t\"Europe/Simferopol|SMT EET MSK CEST CET MSD EEST MSK|-2g -20 -30 -20 -10 -40 -30 -40|012343432525252525252525252161616525252616161616161616161616161616161616172|-1Pc2g eUog rEn0 2qs0 WM0 1fA0 1cM0 3V0 1u0L0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1Q00 4eL0 1cL0 1cN0 1cL0 1cN0 dX0 WL0 1cN0 1cL0 1fB0 1o30 11B0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11z0 1nW0|33e4\",\n\t\t\"Europe/Sofia|EET CET CEST EEST|-20 -10 -20 -30|01212103030303030303030303030303030303030303030303030303030303030303030303030303030303030303030303030303030303030303030303030|-168L0 WM0 1fA0 1cM0 1cM0 1cN0 1mKH0 1dd0 1fb0 1ap0 1fb0 1a20 1fy0 1a30 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cK0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1fB0 1nX0 11E0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|12e5\",\n\t\t\"Europe/Stockholm|CET CEST|-10 -20|01010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-2azC0 TB0 2yDe0 1a00 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|15e5\",\n\t\t\"Europe/Tallinn|TMT CET CEST EET MSK MSD EEST|-1D -10 -20 -20 -30 -40 -30|012103421212454545454545454546363636363636363636363636363636363636363636363636363636363636363636363636363636363636363636363|-26oND teD 11A0 1Ta0 4rXl KSLD 2FX0 2Jg0 WM0 1fA0 1cM0 18J0 1sTX0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cN0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o10 11A0 1qM0 5QM0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|41e4\",\n\t\t\"Europe/Tirane|LMT CET CEST|-1j.k -10 -20|01212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-2glBj.k 14pcj.k 5LC0 WM0 4M0 1fCK0 10n0 1op0 11z0 1pd0 11z0 1qN0 WL0 1qp0 Xb0 1qp0 Xb0 1qp0 11z0 1lB0 11z0 1qN0 11z0 1iN0 16n0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|42e4\",\n\t\t\"Europe/Ulyanovsk|LMT +03 +04 +05 +02|-3d.A -30 -40 -50 -20|01232323232323232321214121212121212121212121212121212121212121212|-22WM0 qH90 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 2pB0 1cM0 1fA0 2pB0 IM0 rX0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 8Hz0 3rd0|13e5\",\n\t\t\"Europe/Uzhgorod|CET CEST MSK MSD EET EEST|-10 -20 -30 -40 -20 -30|010101023232323232323232320454545454545454545454545454545454545454545454545454545454545454545454545454545454545454545454|-1cqL0 6i00 WM0 1fA0 1cM0 1ml0 1Cp0 1r3W0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1Q00 1Nf0 2pw0 1cL0 1cN0 1cL0 1cN0 1cL0 1cQ0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|11e4\",\n\t\t\"Europe/Vienna|CET CEST|-10 -20|0101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-2aFe0 11d0 1iO0 11A0 1o00 11A0 3KM0 14o0 LA00 6i00 WM0 1fA0 1cM0 1cM0 1cM0 400 2qM0 1ao0 1co0 1cM0 1io0 17c0 1gHa0 19X0 1cP0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|18e5\",\n\t\t\"Europe/Vilnius|WMT KMT CET EET MSK CEST MSD EEST|-1o -1z.A -10 -20 -30 -20 -40 -30|012324525254646464646464646473737373737373737352537373737373737373737373737373737373737373737373737373737373737373737373|-293do 6ILM.o 1Ooz.A zz0 Mfd0 29W0 3is0 WM0 1fA0 1cM0 LV0 1tgL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cN0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11B0 1o00 11A0 1qM0 8io0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|54e4\",\n\t\t\"Europe/Volgograd|LMT +03 +04 +05|-2V.E -30 -40 -50|0123232323232323212121212121212121212121212121212121212121212121|-21IqV.E psLV.E 23CL0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 2pB0 1cM0 1cM0 1cM0 1fA0 1cM0 3Co0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 8Hz0 9Jd0 5gn0|10e5\",\n\t\t\"Europe/Warsaw|WMT CET CEST EET EEST|-1o -10 -20 -20 -30|012121234312121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121|-2ctdo 1LXo 11d0 1iO0 11A0 1o00 11A0 1on0 11A0 6zy0 HWP0 5IM0 WM0 1fA0 1cM0 1dz0 1mL0 1en0 15B0 1aq0 1nA0 11A0 1io0 17c0 1fA0 1a00 iDX0 LA0 1cM0 1cM0 1C00 Oo0 1cM0 1cM0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1C00 LA0 uso0 1a00 1fA0 1cM0 1cM0 1cM0 1fA0 1a00 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cN0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|17e5\",\n\t\t\"Europe/Zaporozhye|+0220 EET MSK CEST CET MSD EEST|-2k -20 -30 -20 -10 -40 -30|01234342525252525252525252526161616161616161616161616161616161616161616161616161616161616161616161616161616161616161616161|-1Pc2k eUok rdb0 2RE0 WM0 1fA0 8m0 1v9a0 1db0 1cN0 1db0 1cN0 1db0 1dd0 1cO0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cK0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cQ0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|77e4\",\n\t\t\"HST|HST|a0|0||\",\n\t\t\"Indian/Chagos|LMT +05 +06|-4N.E -50 -60|012|-2xosN.E 3AGLN.E|30e2\",\n\t\t\"Indian/Cocos|+0630|-6u|0||596\",\n\t\t\"Indian/Kerguelen|-00 +05|0 -50|01|-MG00|130\",\n\t\t\"Indian/Mahe|LMT +04|-3F.M -40|01|-2xorF.M|79e3\",\n\t\t\"Indian/Maldives|MMT +05|-4S -50|01|-olgS|35e4\",\n\t\t\"Indian/Mauritius|LMT +04 +05|-3O -40 -50|012121|-2xorO 34unO 14L0 12kr0 11z0|15e4\",\n\t\t\"Indian/Reunion|LMT +04|-3F.Q -40|01|-2mDDF.Q|84e4\",\n\t\t\"Pacific/Kwajalein|+11 +10 +09 -12 +12|-b0 -a0 -90 c0 -c0|012034|-1kln0 akp0 6Up0 12ry0 Wan0|14e3\",\n\t\t\"MET|MET MEST|-10 -20|01010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-2aFe0 11d0 1iO0 11A0 1o00 11A0 Qrc0 6i00 WM0 1fA0 1cM0 1cM0 1cM0 16M0 1gMM0 1a00 1fA0 1cM0 1cM0 1cM0 1fA0 1a00 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|\",\n\t\t\"MST|MST|70|0||\",\n\t\t\"MST7MDT|MST MDT MWT MPT|70 60 60 60|010102301010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-261r0 1nX0 11B0 1nX0 SgN0 8x20 ix0 QwN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|\",\n\t\t\"Pacific/Chatham|+1215 +1245 +1345|-cf -cJ -dJ|012121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212121212|-WqAf 1adef IM0 1C00 Rc0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Rc0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Oo0 1zc0 Rc0 1zc0 Oo0 1qM0 14o0 1lc0 14o0 1lc0 14o0 1lc0 17c0 1io0 17c0 1io0 17c0 1io0 17c0 1lc0 14o0 1lc0 14o0 1lc0 17c0 1io0 17c0 1io0 17c0 1lc0 14o0 1lc0 14o0 1lc0 17c0 1io0 17c0 1io0 17c0 1io0 17c0 1io0 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1cM0 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1cM0 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1io0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1cM0 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1cM0 1fA0 1a00 1fA0 1a00|600\",\n\t\t\"Pacific/Apia|LMT -1130 -11 -10 +14 +13|bq.U bu b0 a0 -e0 -d0|01232345454545454545454545|-2nDMx.4 1yW03.4 2rRbu 1ff0 1a00 CI0 AQ0 1cM0 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1a00 1fA0 1cM0 1fA0 1a00 1fA0 1a00 1fA0|37e3\",\n\t\t\"Pacific/Bougainville|+10 +09 +11|-a0 -90 -b0|0102|-16Wy0 7CN0 2MQp0|18e4\",\n\t\t\"Pacific/Chuuk|+10 +09|-a0 -90|01010|-2ewy0 axB0 RVX0 axd0|49e3\",\n\t\t\"Pacific/Efate|LMT +11 +12|-bd.g -b0 -c0|012121212121212121212121|-2l9nd.g 2uNXd.g Dc0 n610 1cL0 1cN0 1cL0 1fB0 19X0 1fB0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1fB0 Lz0 1Nd0 An0|66e3\",\n\t\t\"Pacific/Enderbury|-00 -12 -11 +13|0 c0 b0 -d0|0123|-1iIo0 1GsA0 B7X0|1\",\n\t\t\"Pacific/Fakaofo|-11 +13|b0 -d0|01|1Gfn0|483\",\n\t\t\"Pacific/Fiji|LMT +12 +13|-bT.I -c0 -d0|01212121212121212121212121212121212121212121212121212121212121|-2bUzT.I 3m8NT.I LA0 1EM0 IM0 nJc0 LA0 1o00 Rc0 1wo0 Ao0 1Nc0 Ao0 1Q00 xz0 1SN0 uM0 1SM0 uM0 1VA0 s00 1VA0 s00 1VA0 s00 20o0 pc0 2hc0 bc0 4q00 pc0 20o0 pc0 20o0 pc0 20o0 s00 1VA0 s00 20o0 pc0 20o0 pc0 20o0 pc0 20o0 pc0 20o0 s00 20o0 pc0 20o0 pc0 20o0 pc0 20o0 pc0 20o0 s00 1VA0 s00|88e4\",\n\t\t\"Pacific/Galapagos|LMT -05 -06|5W.o 50 60|01212|-1yVS1.A 2dTz1.A gNd0 rz0|25e3\",\n\t\t\"Pacific/Gambier|LMT -09|8X.M 90|01|-2jof0.c|125\",\n\t\t\"Pacific/Guadalcanal|LMT +11|-aD.M -b0|01|-2joyD.M|11e4\",\n\t\t\"Pacific/Guam|GST +09 GDT ChST|-a0 -90 -b0 -a0|01020202020202020203|-18jK0 6pB0 AhB0 3QL0 g2p0 3p91 WOX rX0 1zd0 Rb0 1wp0 Rb0 5xd0 rX0 5sN0 zb1 1C0X On0 ULb0|17e4\",\n\t\t\"Pacific/Honolulu|HST HDT HWT HPT HST|au 9u 9u 9u a0|0102304|-1thLu 8x0 lef0 8wWu iAu 46p0|37e4\",\n\t\t\"Pacific/Kiritimati|-1040 -10 +14|aE a0 -e0|012|nIaE B7Xk|51e2\",\n\t\t\"Pacific/Kosrae|+11 +09 +10 +12|-b0 -90 -a0 -c0|01021030|-2ewz0 axC0 HBy0 akp0 axd0 WOK0 1bdz0|66e2\",\n\t\t\"Pacific/Majuro|+11 +09 +10 +12|-b0 -90 -a0 -c0|0102103|-2ewz0 axC0 HBy0 akp0 6RB0 12um0|28e3\",\n\t\t\"Pacific/Marquesas|LMT -0930|9i 9u|01|-2joeG|86e2\",\n\t\t\"Pacific/Pago_Pago|LMT SST|bm.M b0|01|-2nDMB.c|37e2\",\n\t\t\"Pacific/Nauru|LMT +1130 +09 +12|-b7.E -bu -90 -c0|01213|-1Xdn7.E QCnB.E 7mqu 1lnbu|10e3\",\n\t\t\"Pacific/Niue|LMT -1120 -11|bj.E bk b0|012|-FScE.k suo0.k|12e2\",\n\t\t\"Pacific/Norfolk|+1112 +1130 +1230 +11 +12|-bc -bu -cu -b0 -c0|012134343434343434343434343434343434343434|-Kgbc W01G Oo0 1COo0 9Jcu 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0|25e4\",\n\t\t\"Pacific/Noumea|LMT +11 +12|-b5.M -b0 -c0|01212121|-2l9n5.M 2EqM5.M xX0 1PB0 yn0 HeP0 Ao0|98e3\",\n\t\t\"Pacific/Pitcairn|-0830 -08|8u 80|01|18Vku|56\",\n\t\t\"Pacific/Pohnpei|+11 +09 +10|-b0 -90 -a0|010210|-2ewz0 axC0 HBy0 akp0 axd0|34e3\",\n\t\t\"Pacific/Rarotonga|LMT -1030 -0930 -10|aD.4 au 9u a0|0123232323232323232323232323|-FSdk.U 13tbO.U IL0 1zcu Onu 1zcu Onu 1zcu Rbu 1zcu Onu 1zcu Onu 1zcu Onu 1zcu Onu 1zcu Onu 1zcu Rbu 1zcu Onu 1zcu Onu 1zcu Onu|13e3\",\n\t\t\"Pacific/Tahiti|LMT -10|9W.g a0|01|-2joe1.I|18e4\",\n\t\t\"Pacific/Tongatapu|LMT +1220 +13 +14|-cj.c -ck -d0 -e0|01232323232|-XbMj.c BgLX.c 1yndk 15A0 1wo0 xz0 1Q10 xz0 zWN0 s00|75e3\",\n\t\t\"PST8PDT|PST PDT PWT PPT|80 70 70 70|010102301010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|-261q0 1nX0 11B0 1nX0 SgN0 8x10 iy0 QwN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1cN0 1cL0 1cN0 1cL0 s10 1Vz0 LB0 1BX0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 1cN0 1fz0 1a10 1fz0 1cN0 1cL0 1cN0 1cL0 1cN0 1cL0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 14p0 1lb0 14p0 1lb0 14p0 1nX0 11B0 1nX0 11B0 1nX0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Rd0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0 Op0 1zb0|\",\n\t\t\"WET|WET WEST|0 -10|010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010101010|hDB0 1a00 1fA0 1cM0 1cM0 1cM0 1fA0 1a00 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1cM0 1fA0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00 11A0 1qM0 WM0 1qM0 WM0 1qM0 WM0 1qM0 11A0 1o00 11A0 1o00|\"\n\t];\n\tvar links$1 = [\n\t\t\"Africa/Abidjan|Africa/Accra\",\n\t\t\"Africa/Abidjan|Africa/Bamako\",\n\t\t\"Africa/Abidjan|Africa/Banjul\",\n\t\t\"Africa/Abidjan|Africa/Conakry\",\n\t\t\"Africa/Abidjan|Africa/Dakar\",\n\t\t\"Africa/Abidjan|Africa/Freetown\",\n\t\t\"Africa/Abidjan|Africa/Lome\",\n\t\t\"Africa/Abidjan|Africa/Nouakchott\",\n\t\t\"Africa/Abidjan|Africa/Ouagadougou\",\n\t\t\"Africa/Abidjan|Africa/Timbuktu\",\n\t\t\"Africa/Abidjan|Atlantic/St_Helena\",\n\t\t\"Africa/Cairo|Egypt\",\n\t\t\"Africa/Johannesburg|Africa/Maseru\",\n\t\t\"Africa/Johannesburg|Africa/Mbabane\",\n\t\t\"Africa/Lagos|Africa/Bangui\",\n\t\t\"Africa/Lagos|Africa/Brazzaville\",\n\t\t\"Africa/Lagos|Africa/Douala\",\n\t\t\"Africa/Lagos|Africa/Kinshasa\",\n\t\t\"Africa/Lagos|Africa/Libreville\",\n\t\t\"Africa/Lagos|Africa/Luanda\",\n\t\t\"Africa/Lagos|Africa/Malabo\",\n\t\t\"Africa/Lagos|Africa/Niamey\",\n\t\t\"Africa/Lagos|Africa/Porto-Novo\",\n\t\t\"Africa/Maputo|Africa/Blantyre\",\n\t\t\"Africa/Maputo|Africa/Bujumbura\",\n\t\t\"Africa/Maputo|Africa/Gaborone\",\n\t\t\"Africa/Maputo|Africa/Harare\",\n\t\t\"Africa/Maputo|Africa/Kigali\",\n\t\t\"Africa/Maputo|Africa/Lubumbashi\",\n\t\t\"Africa/Maputo|Africa/Lusaka\",\n\t\t\"Africa/Nairobi|Africa/Addis_Ababa\",\n\t\t\"Africa/Nairobi|Africa/Asmara\",\n\t\t\"Africa/Nairobi|Africa/Asmera\",\n\t\t\"Africa/Nairobi|Africa/Dar_es_Salaam\",\n\t\t\"Africa/Nairobi|Africa/Djibouti\",\n\t\t\"Africa/Nairobi|Africa/Kampala\",\n\t\t\"Africa/Nairobi|Africa/Mogadishu\",\n\t\t\"Africa/Nairobi|Indian/Antananarivo\",\n\t\t\"Africa/Nairobi|Indian/Comoro\",\n\t\t\"Africa/Nairobi|Indian/Mayotte\",\n\t\t\"Africa/Tripoli|Libya\",\n\t\t\"America/Adak|America/Atka\",\n\t\t\"America/Adak|US/Aleutian\",\n\t\t\"America/Anchorage|US/Alaska\",\n\t\t\"America/Argentina/Buenos_Aires|America/Buenos_Aires\",\n\t\t\"America/Argentina/Catamarca|America/Argentina/ComodRivadavia\",\n\t\t\"America/Argentina/Catamarca|America/Catamarca\",\n\t\t\"America/Argentina/Cordoba|America/Cordoba\",\n\t\t\"America/Argentina/Cordoba|America/Rosario\",\n\t\t\"America/Argentina/Jujuy|America/Jujuy\",\n\t\t\"America/Argentina/Mendoza|America/Mendoza\",\n\t\t\"America/Chicago|US/Central\",\n\t\t\"America/Denver|America/Shiprock\",\n\t\t\"America/Denver|Navajo\",\n\t\t\"America/Denver|US/Mountain\",\n\t\t\"America/Detroit|US/Michigan\",\n\t\t\"America/Edmonton|Canada/Mountain\",\n\t\t\"America/Fort_Wayne|America/Indiana/Indianapolis\",\n\t\t\"America/Fort_Wayne|America/Indianapolis\",\n\t\t\"America/Fort_Wayne|US/East-Indiana\",\n\t\t\"America/Godthab|America/Nuuk\",\n\t\t\"America/Halifax|Canada/Atlantic\",\n\t\t\"America/Havana|Cuba\",\n\t\t\"America/Indiana/Knox|America/Knox_IN\",\n\t\t\"America/Indiana/Knox|US/Indiana-Starke\",\n\t\t\"America/Jamaica|Jamaica\",\n\t\t\"America/Kentucky/Louisville|America/Louisville\",\n\t\t\"America/Los_Angeles|US/Pacific\",\n\t\t\"America/Manaus|Brazil/West\",\n\t\t\"America/Mazatlan|Mexico/BajaSur\",\n\t\t\"America/Mexico_City|Mexico/General\",\n\t\t\"America/New_York|US/Eastern\",\n\t\t\"America/Noronha|Brazil/DeNoronha\",\n\t\t\"America/Panama|America/Atikokan\",\n\t\t\"America/Panama|America/Cayman\",\n\t\t\"America/Panama|America/Coral_Harbour\",\n\t\t\"America/Phoenix|America/Creston\",\n\t\t\"America/Phoenix|US/Arizona\",\n\t\t\"America/Puerto_Rico|America/Anguilla\",\n\t\t\"America/Puerto_Rico|America/Antigua\",\n\t\t\"America/Puerto_Rico|America/Aruba\",\n\t\t\"America/Puerto_Rico|America/Blanc-Sablon\",\n\t\t\"America/Puerto_Rico|America/Curacao\",\n\t\t\"America/Puerto_Rico|America/Dominica\",\n\t\t\"America/Puerto_Rico|America/Grenada\",\n\t\t\"America/Puerto_Rico|America/Guadeloupe\",\n\t\t\"America/Puerto_Rico|America/Kralendijk\",\n\t\t\"America/Puerto_Rico|America/Lower_Princes\",\n\t\t\"America/Puerto_Rico|America/Marigot\",\n\t\t\"America/Puerto_Rico|America/Montserrat\",\n\t\t\"America/Puerto_Rico|America/Port_of_Spain\",\n\t\t\"America/Puerto_Rico|America/St_Barthelemy\",\n\t\t\"America/Puerto_Rico|America/St_Kitts\",\n\t\t\"America/Puerto_Rico|America/St_Lucia\",\n\t\t\"America/Puerto_Rico|America/St_Thomas\",\n\t\t\"America/Puerto_Rico|America/St_Vincent\",\n\t\t\"America/Puerto_Rico|America/Tortola\",\n\t\t\"America/Puerto_Rico|America/Virgin\",\n\t\t\"America/Regina|Canada/Saskatchewan\",\n\t\t\"America/Rio_Branco|America/Porto_Acre\",\n\t\t\"America/Rio_Branco|Brazil/Acre\",\n\t\t\"America/Santiago|Chile/Continental\",\n\t\t\"America/Sao_Paulo|Brazil/East\",\n\t\t\"America/St_Johns|Canada/Newfoundland\",\n\t\t\"America/Tijuana|America/Ensenada\",\n\t\t\"America/Tijuana|America/Santa_Isabel\",\n\t\t\"America/Tijuana|Mexico/BajaNorte\",\n\t\t\"America/Toronto|America/Montreal\",\n\t\t\"America/Toronto|America/Nassau\",\n\t\t\"America/Toronto|Canada/Eastern\",\n\t\t\"America/Vancouver|Canada/Pacific\",\n\t\t\"America/Whitehorse|Canada/Yukon\",\n\t\t\"America/Winnipeg|Canada/Central\",\n\t\t\"Asia/Ashgabat|Asia/Ashkhabad\",\n\t\t\"Asia/Bangkok|Asia/Phnom_Penh\",\n\t\t\"Asia/Bangkok|Asia/Vientiane\",\n\t\t\"Asia/Dhaka|Asia/Dacca\",\n\t\t\"Asia/Dubai|Asia/Muscat\",\n\t\t\"Asia/Ho_Chi_Minh|Asia/Saigon\",\n\t\t\"Asia/Hong_Kong|Hongkong\",\n\t\t\"Asia/Jerusalem|Asia/Tel_Aviv\",\n\t\t\"Asia/Jerusalem|Israel\",\n\t\t\"Asia/Kathmandu|Asia/Katmandu\",\n\t\t\"Asia/Kolkata|Asia/Calcutta\",\n\t\t\"Asia/Kuala_Lumpur|Asia/Singapore\",\n\t\t\"Asia/Kuala_Lumpur|Singapore\",\n\t\t\"Asia/Macau|Asia/Macao\",\n\t\t\"Asia/Makassar|Asia/Ujung_Pandang\",\n\t\t\"Asia/Nicosia|Europe/Nicosia\",\n\t\t\"Asia/Qatar|Asia/Bahrain\",\n\t\t\"Asia/Rangoon|Asia/Yangon\",\n\t\t\"Asia/Riyadh|Antarctica/Syowa\",\n\t\t\"Asia/Riyadh|Asia/Aden\",\n\t\t\"Asia/Riyadh|Asia/Kuwait\",\n\t\t\"Asia/Seoul|ROK\",\n\t\t\"Asia/Shanghai|Asia/Chongqing\",\n\t\t\"Asia/Shanghai|Asia/Chungking\",\n\t\t\"Asia/Shanghai|Asia/Harbin\",\n\t\t\"Asia/Shanghai|PRC\",\n\t\t\"Asia/Taipei|ROC\",\n\t\t\"Asia/Tehran|Iran\",\n\t\t\"Asia/Thimphu|Asia/Thimbu\",\n\t\t\"Asia/Tokyo|Japan\",\n\t\t\"Asia/Ulaanbaatar|Asia/Ulan_Bator\",\n\t\t\"Asia/Urumqi|Asia/Kashgar\",\n\t\t\"Atlantic/Faroe|Atlantic/Faeroe\",\n\t\t\"Atlantic/Reykjavik|Iceland\",\n\t\t\"Atlantic/South_Georgia|Etc/GMT+2\",\n\t\t\"Australia/Adelaide|Australia/South\",\n\t\t\"Australia/Brisbane|Australia/Queensland\",\n\t\t\"Australia/Broken_Hill|Australia/Yancowinna\",\n\t\t\"Australia/Darwin|Australia/North\",\n\t\t\"Australia/Hobart|Australia/Currie\",\n\t\t\"Australia/Hobart|Australia/Tasmania\",\n\t\t\"Australia/Lord_Howe|Australia/LHI\",\n\t\t\"Australia/Melbourne|Australia/Victoria\",\n\t\t\"Australia/Perth|Australia/West\",\n\t\t\"Australia/Sydney|Australia/ACT\",\n\t\t\"Australia/Sydney|Australia/Canberra\",\n\t\t\"Australia/Sydney|Australia/NSW\",\n\t\t\"Etc/GMT-0|Etc/GMT\",\n\t\t\"Etc/GMT-0|Etc/GMT+0\",\n\t\t\"Etc/GMT-0|Etc/GMT0\",\n\t\t\"Etc/GMT-0|Etc/Greenwich\",\n\t\t\"Etc/GMT-0|GMT\",\n\t\t\"Etc/GMT-0|GMT+0\",\n\t\t\"Etc/GMT-0|GMT-0\",\n\t\t\"Etc/GMT-0|GMT0\",\n\t\t\"Etc/GMT-0|Greenwich\",\n\t\t\"Etc/UTC|Etc/UTC\",\n\t\t\"Etc/UTC|Etc/Universal\",\n\t\t\"Etc/UTC|Etc/Zulu\",\n\t\t\"Etc/UTC|UCT\",\n\t\t\"Etc/UTC|UTC\",\n\t\t\"Etc/UTC|Universal\",\n\t\t\"Etc/UTC|Zulu\",\n\t\t\"Europe/Belgrade|Europe/Ljubljana\",\n\t\t\"Europe/Belgrade|Europe/Podgorica\",\n\t\t\"Europe/Belgrade|Europe/Sarajevo\",\n\t\t\"Europe/Belgrade|Europe/Skopje\",\n\t\t\"Europe/Belgrade|Europe/Zagreb\",\n\t\t\"Europe/Chisinau|Europe/Tiraspol\",\n\t\t\"Europe/Dublin|Eire\",\n\t\t\"Europe/Helsinki|Europe/Mariehamn\",\n\t\t\"Europe/Istanbul|Asia/Istanbul\",\n\t\t\"Europe/Istanbul|Turkey\",\n\t\t\"Europe/Lisbon|Portugal\",\n\t\t\"Europe/London|Europe/Belfast\",\n\t\t\"Europe/London|Europe/Guernsey\",\n\t\t\"Europe/London|Europe/Isle_of_Man\",\n\t\t\"Europe/London|Europe/Jersey\",\n\t\t\"Europe/London|GB\",\n\t\t\"Europe/London|GB-Eire\",\n\t\t\"Europe/Moscow|W-SU\",\n\t\t\"Europe/Oslo|Arctic/Longyearbyen\",\n\t\t\"Europe/Oslo|Atlantic/Jan_Mayen\",\n\t\t\"Europe/Prague|Europe/Bratislava\",\n\t\t\"Europe/Rome|Europe/San_Marino\",\n\t\t\"Europe/Rome|Europe/Vatican\",\n\t\t\"Europe/Warsaw|Poland\",\n\t\t\"Europe/Zurich|Europe/Busingen\",\n\t\t\"Europe/Zurich|Europe/Vaduz\",\n\t\t\"Indian/Christmas|Etc/GMT-7\",\n\t\t\"Pacific/Auckland|Antarctica/McMurdo\",\n\t\t\"Pacific/Auckland|Antarctica/South_Pole\",\n\t\t\"Pacific/Auckland|NZ\",\n\t\t\"Pacific/Chatham|NZ-CHAT\",\n\t\t\"Pacific/Chuuk|Pacific/Truk\",\n\t\t\"Pacific/Chuuk|Pacific/Yap\",\n\t\t\"Pacific/Easter|Chile/EasterIsland\",\n\t\t\"Pacific/Enderbury|Pacific/Kanton\",\n\t\t\"Pacific/Guam|Pacific/Saipan\",\n\t\t\"Pacific/Honolulu|Pacific/Johnston\",\n\t\t\"Pacific/Honolulu|US/Hawaii\",\n\t\t\"Pacific/Kwajalein|Kwajalein\",\n\t\t\"Pacific/Pago_Pago|Pacific/Midway\",\n\t\t\"Pacific/Pago_Pago|Pacific/Samoa\",\n\t\t\"Pacific/Pago_Pago|US/Samoa\",\n\t\t\"Pacific/Palau|Etc/GMT-9\",\n\t\t\"Pacific/Pohnpei|Pacific/Ponape\",\n\t\t\"Pacific/Port_Moresby|Antarctica/DumontDUrville\",\n\t\t\"Pacific/Port_Moresby|Etc/GMT-10\",\n\t\t\"Pacific/Tarawa|Etc/GMT-12\",\n\t\t\"Pacific/Tarawa|Pacific/Funafuti\",\n\t\t\"Pacific/Tarawa|Pacific/Wake\",\n\t\t\"Pacific/Tarawa|Pacific/Wallis\"\n\t];\n\tvar countries = [\n\t\t\"AD|Europe/Andorra\",\n\t\t\"AE|Asia/Dubai\",\n\t\t\"AF|Asia/Kabul\",\n\t\t\"AG|America/Puerto_Rico America/Antigua\",\n\t\t\"AI|America/Puerto_Rico America/Anguilla\",\n\t\t\"AL|Europe/Tirane\",\n\t\t\"AM|Asia/Yerevan\",\n\t\t\"AO|Africa/Lagos Africa/Luanda\",\n\t\t\"AQ|Antarctica/Casey Antarctica/Davis Antarctica/Mawson Antarctica/Palmer Antarctica/Rothera Antarctica/Troll Antarctica/Vostok Pacific/Auckland Pacific/Port_Moresby Asia/Riyadh Antarctica/McMurdo Antarctica/DumontDUrville Antarctica/Syowa\",\n\t\t\"AR|America/Argentina/Buenos_Aires America/Argentina/Cordoba America/Argentina/Salta America/Argentina/Jujuy America/Argentina/Tucuman America/Argentina/Catamarca America/Argentina/La_Rioja America/Argentina/San_Juan America/Argentina/Mendoza America/Argentina/San_Luis America/Argentina/Rio_Gallegos America/Argentina/Ushuaia\",\n\t\t\"AS|Pacific/Pago_Pago\",\n\t\t\"AT|Europe/Vienna\",\n\t\t\"AU|Australia/Lord_Howe Antarctica/Macquarie Australia/Hobart Australia/Melbourne Australia/Sydney Australia/Broken_Hill Australia/Brisbane Australia/Lindeman Australia/Adelaide Australia/Darwin Australia/Perth Australia/Eucla\",\n\t\t\"AW|America/Puerto_Rico America/Aruba\",\n\t\t\"AX|Europe/Helsinki Europe/Mariehamn\",\n\t\t\"AZ|Asia/Baku\",\n\t\t\"BA|Europe/Belgrade Europe/Sarajevo\",\n\t\t\"BB|America/Barbados\",\n\t\t\"BD|Asia/Dhaka\",\n\t\t\"BE|Europe/Brussels\",\n\t\t\"BF|Africa/Abidjan Africa/Ouagadougou\",\n\t\t\"BG|Europe/Sofia\",\n\t\t\"BH|Asia/Qatar Asia/Bahrain\",\n\t\t\"BI|Africa/Maputo Africa/Bujumbura\",\n\t\t\"BJ|Africa/Lagos Africa/Porto-Novo\",\n\t\t\"BL|America/Puerto_Rico America/St_Barthelemy\",\n\t\t\"BM|Atlantic/Bermuda\",\n\t\t\"BN|Asia/Brunei\",\n\t\t\"BO|America/La_Paz\",\n\t\t\"BQ|America/Puerto_Rico America/Kralendijk\",\n\t\t\"BR|America/Noronha America/Belem America/Fortaleza America/Recife America/Araguaina America/Maceio America/Bahia America/Sao_Paulo America/Campo_Grande America/Cuiaba America/Santarem America/Porto_Velho America/Boa_Vista America/Manaus America/Eirunepe America/Rio_Branco\",\n\t\t\"BS|America/Toronto America/Nassau\",\n\t\t\"BT|Asia/Thimphu\",\n\t\t\"BW|Africa/Maputo Africa/Gaborone\",\n\t\t\"BY|Europe/Minsk\",\n\t\t\"BZ|America/Belize\",\n\t\t\"CA|America/St_Johns America/Halifax America/Glace_Bay America/Moncton America/Goose_Bay America/Toronto America/Nipigon America/Thunder_Bay America/Iqaluit America/Pangnirtung America/Winnipeg America/Rainy_River America/Resolute America/Rankin_Inlet America/Regina America/Swift_Current America/Edmonton America/Cambridge_Bay America/Yellowknife America/Inuvik America/Dawson_Creek America/Fort_Nelson America/Whitehorse America/Dawson America/Vancouver America/Panama America/Puerto_Rico America/Phoenix America/Blanc-Sablon America/Atikokan America/Creston\",\n\t\t\"CC|Indian/Cocos\",\n\t\t\"CD|Africa/Maputo Africa/Lagos Africa/Kinshasa Africa/Lubumbashi\",\n\t\t\"CF|Africa/Lagos Africa/Bangui\",\n\t\t\"CG|Africa/Lagos Africa/Brazzaville\",\n\t\t\"CH|Europe/Zurich\",\n\t\t\"CI|Africa/Abidjan\",\n\t\t\"CK|Pacific/Rarotonga\",\n\t\t\"CL|America/Santiago America/Punta_Arenas Pacific/Easter\",\n\t\t\"CM|Africa/Lagos Africa/Douala\",\n\t\t\"CN|Asia/Shanghai Asia/Urumqi\",\n\t\t\"CO|America/Bogota\",\n\t\t\"CR|America/Costa_Rica\",\n\t\t\"CU|America/Havana\",\n\t\t\"CV|Atlantic/Cape_Verde\",\n\t\t\"CW|America/Puerto_Rico America/Curacao\",\n\t\t\"CX|Indian/Christmas\",\n\t\t\"CY|Asia/Nicosia Asia/Famagusta\",\n\t\t\"CZ|Europe/Prague\",\n\t\t\"DE|Europe/Zurich Europe/Berlin Europe/Busingen\",\n\t\t\"DJ|Africa/Nairobi Africa/Djibouti\",\n\t\t\"DK|Europe/Copenhagen\",\n\t\t\"DM|America/Puerto_Rico America/Dominica\",\n\t\t\"DO|America/Santo_Domingo\",\n\t\t\"DZ|Africa/Algiers\",\n\t\t\"EC|America/Guayaquil Pacific/Galapagos\",\n\t\t\"EE|Europe/Tallinn\",\n\t\t\"EG|Africa/Cairo\",\n\t\t\"EH|Africa/El_Aaiun\",\n\t\t\"ER|Africa/Nairobi Africa/Asmara\",\n\t\t\"ES|Europe/Madrid Africa/Ceuta Atlantic/Canary\",\n\t\t\"ET|Africa/Nairobi Africa/Addis_Ababa\",\n\t\t\"FI|Europe/Helsinki\",\n\t\t\"FJ|Pacific/Fiji\",\n\t\t\"FK|Atlantic/Stanley\",\n\t\t\"FM|Pacific/Chuuk Pacific/Pohnpei Pacific/Kosrae\",\n\t\t\"FO|Atlantic/Faroe\",\n\t\t\"FR|Europe/Paris\",\n\t\t\"GA|Africa/Lagos Africa/Libreville\",\n\t\t\"GB|Europe/London\",\n\t\t\"GD|America/Puerto_Rico America/Grenada\",\n\t\t\"GE|Asia/Tbilisi\",\n\t\t\"GF|America/Cayenne\",\n\t\t\"GG|Europe/London Europe/Guernsey\",\n\t\t\"GH|Africa/Abidjan Africa/Accra\",\n\t\t\"GI|Europe/Gibraltar\",\n\t\t\"GL|America/Nuuk America/Danmarkshavn America/Scoresbysund America/Thule\",\n\t\t\"GM|Africa/Abidjan Africa/Banjul\",\n\t\t\"GN|Africa/Abidjan Africa/Conakry\",\n\t\t\"GP|America/Puerto_Rico America/Guadeloupe\",\n\t\t\"GQ|Africa/Lagos Africa/Malabo\",\n\t\t\"GR|Europe/Athens\",\n\t\t\"GS|Atlantic/South_Georgia\",\n\t\t\"GT|America/Guatemala\",\n\t\t\"GU|Pacific/Guam\",\n\t\t\"GW|Africa/Bissau\",\n\t\t\"GY|America/Guyana\",\n\t\t\"HK|Asia/Hong_Kong\",\n\t\t\"HN|America/Tegucigalpa\",\n\t\t\"HR|Europe/Belgrade Europe/Zagreb\",\n\t\t\"HT|America/Port-au-Prince\",\n\t\t\"HU|Europe/Budapest\",\n\t\t\"ID|Asia/Jakarta Asia/Pontianak Asia/Makassar Asia/Jayapura\",\n\t\t\"IE|Europe/Dublin\",\n\t\t\"IL|Asia/Jerusalem\",\n\t\t\"IM|Europe/London Europe/Isle_of_Man\",\n\t\t\"IN|Asia/Kolkata\",\n\t\t\"IO|Indian/Chagos\",\n\t\t\"IQ|Asia/Baghdad\",\n\t\t\"IR|Asia/Tehran\",\n\t\t\"IS|Atlantic/Reykjavik\",\n\t\t\"IT|Europe/Rome\",\n\t\t\"JE|Europe/London Europe/Jersey\",\n\t\t\"JM|America/Jamaica\",\n\t\t\"JO|Asia/Amman\",\n\t\t\"JP|Asia/Tokyo\",\n\t\t\"KE|Africa/Nairobi\",\n\t\t\"KG|Asia/Bishkek\",\n\t\t\"KH|Asia/Bangkok Asia/Phnom_Penh\",\n\t\t\"KI|Pacific/Tarawa Pacific/Kanton Pacific/Kiritimati\",\n\t\t\"KM|Africa/Nairobi Indian/Comoro\",\n\t\t\"KN|America/Puerto_Rico America/St_Kitts\",\n\t\t\"KP|Asia/Pyongyang\",\n\t\t\"KR|Asia/Seoul\",\n\t\t\"KW|Asia/Riyadh Asia/Kuwait\",\n\t\t\"KY|America/Panama America/Cayman\",\n\t\t\"KZ|Asia/Almaty Asia/Qyzylorda Asia/Qostanay Asia/Aqtobe Asia/Aqtau Asia/Atyrau Asia/Oral\",\n\t\t\"LA|Asia/Bangkok Asia/Vientiane\",\n\t\t\"LB|Asia/Beirut\",\n\t\t\"LC|America/Puerto_Rico America/St_Lucia\",\n\t\t\"LI|Europe/Zurich Europe/Vaduz\",\n\t\t\"LK|Asia/Colombo\",\n\t\t\"LR|Africa/Monrovia\",\n\t\t\"LS|Africa/Johannesburg Africa/Maseru\",\n\t\t\"LT|Europe/Vilnius\",\n\t\t\"LU|Europe/Luxembourg\",\n\t\t\"LV|Europe/Riga\",\n\t\t\"LY|Africa/Tripoli\",\n\t\t\"MA|Africa/Casablanca\",\n\t\t\"MC|Europe/Monaco\",\n\t\t\"MD|Europe/Chisinau\",\n\t\t\"ME|Europe/Belgrade Europe/Podgorica\",\n\t\t\"MF|America/Puerto_Rico America/Marigot\",\n\t\t\"MG|Africa/Nairobi Indian/Antananarivo\",\n\t\t\"MH|Pacific/Majuro Pacific/Kwajalein\",\n\t\t\"MK|Europe/Belgrade Europe/Skopje\",\n\t\t\"ML|Africa/Abidjan Africa/Bamako\",\n\t\t\"MM|Asia/Yangon\",\n\t\t\"MN|Asia/Ulaanbaatar Asia/Hovd Asia/Choibalsan\",\n\t\t\"MO|Asia/Macau\",\n\t\t\"MP|Pacific/Guam Pacific/Saipan\",\n\t\t\"MQ|America/Martinique\",\n\t\t\"MR|Africa/Abidjan Africa/Nouakchott\",\n\t\t\"MS|America/Puerto_Rico America/Montserrat\",\n\t\t\"MT|Europe/Malta\",\n\t\t\"MU|Indian/Mauritius\",\n\t\t\"MV|Indian/Maldives\",\n\t\t\"MW|Africa/Maputo Africa/Blantyre\",\n\t\t\"MX|America/Mexico_City America/Cancun America/Merida America/Monterrey America/Matamoros America/Mazatlan America/Chihuahua America/Ojinaga America/Hermosillo America/Tijuana America/Bahia_Banderas\",\n\t\t\"MY|Asia/Kuala_Lumpur Asia/Kuching Asia/Singapore\",\n\t\t\"MZ|Africa/Maputo\",\n\t\t\"NA|Africa/Windhoek\",\n\t\t\"NC|Pacific/Noumea\",\n\t\t\"NE|Africa/Lagos Africa/Niamey\",\n\t\t\"NF|Pacific/Norfolk\",\n\t\t\"NG|Africa/Lagos\",\n\t\t\"NI|America/Managua\",\n\t\t\"NL|Europe/Amsterdam\",\n\t\t\"NO|Europe/Oslo\",\n\t\t\"NP|Asia/Kathmandu\",\n\t\t\"NR|Pacific/Nauru\",\n\t\t\"NU|Pacific/Niue\",\n\t\t\"NZ|Pacific/Auckland Pacific/Chatham\",\n\t\t\"OM|Asia/Dubai Asia/Muscat\",\n\t\t\"PA|America/Panama\",\n\t\t\"PE|America/Lima\",\n\t\t\"PF|Pacific/Tahiti Pacific/Marquesas Pacific/Gambier\",\n\t\t\"PG|Pacific/Port_Moresby Pacific/Bougainville\",\n\t\t\"PH|Asia/Manila\",\n\t\t\"PK|Asia/Karachi\",\n\t\t\"PL|Europe/Warsaw\",\n\t\t\"PM|America/Miquelon\",\n\t\t\"PN|Pacific/Pitcairn\",\n\t\t\"PR|America/Puerto_Rico\",\n\t\t\"PS|Asia/Gaza Asia/Hebron\",\n\t\t\"PT|Europe/Lisbon Atlantic/Madeira Atlantic/Azores\",\n\t\t\"PW|Pacific/Palau\",\n\t\t\"PY|America/Asuncion\",\n\t\t\"QA|Asia/Qatar\",\n\t\t\"RE|Indian/Reunion\",\n\t\t\"RO|Europe/Bucharest\",\n\t\t\"RS|Europe/Belgrade\",\n\t\t\"RU|Europe/Kaliningrad Europe/Moscow Europe/Simferopol Europe/Kirov Europe/Volgograd Europe/Astrakhan Europe/Saratov Europe/Ulyanovsk Europe/Samara Asia/Yekaterinburg Asia/Omsk Asia/Novosibirsk Asia/Barnaul Asia/Tomsk Asia/Novokuznetsk Asia/Krasnoyarsk Asia/Irkutsk Asia/Chita Asia/Yakutsk Asia/Khandyga Asia/Vladivostok Asia/Ust-Nera Asia/Magadan Asia/Sakhalin Asia/Srednekolymsk Asia/Kamchatka Asia/Anadyr\",\n\t\t\"RW|Africa/Maputo Africa/Kigali\",\n\t\t\"SA|Asia/Riyadh\",\n\t\t\"SB|Pacific/Guadalcanal\",\n\t\t\"SC|Indian/Mahe\",\n\t\t\"SD|Africa/Khartoum\",\n\t\t\"SE|Europe/Stockholm\",\n\t\t\"SG|Asia/Singapore\",\n\t\t\"SH|Africa/Abidjan Atlantic/St_Helena\",\n\t\t\"SI|Europe/Belgrade Europe/Ljubljana\",\n\t\t\"SJ|Europe/Oslo Arctic/Longyearbyen\",\n\t\t\"SK|Europe/Prague Europe/Bratislava\",\n\t\t\"SL|Africa/Abidjan Africa/Freetown\",\n\t\t\"SM|Europe/Rome Europe/San_Marino\",\n\t\t\"SN|Africa/Abidjan Africa/Dakar\",\n\t\t\"SO|Africa/Nairobi Africa/Mogadishu\",\n\t\t\"SR|America/Paramaribo\",\n\t\t\"SS|Africa/Juba\",\n\t\t\"ST|Africa/Sao_Tome\",\n\t\t\"SV|America/El_Salvador\",\n\t\t\"SX|America/Puerto_Rico America/Lower_Princes\",\n\t\t\"SY|Asia/Damascus\",\n\t\t\"SZ|Africa/Johannesburg Africa/Mbabane\",\n\t\t\"TC|America/Grand_Turk\",\n\t\t\"TD|Africa/Ndjamena\",\n\t\t\"TF|Indian/Reunion Indian/Kerguelen\",\n\t\t\"TG|Africa/Abidjan Africa/Lome\",\n\t\t\"TH|Asia/Bangkok\",\n\t\t\"TJ|Asia/Dushanbe\",\n\t\t\"TK|Pacific/Fakaofo\",\n\t\t\"TL|Asia/Dili\",\n\t\t\"TM|Asia/Ashgabat\",\n\t\t\"TN|Africa/Tunis\",\n\t\t\"TO|Pacific/Tongatapu\",\n\t\t\"TR|Europe/Istanbul\",\n\t\t\"TT|America/Puerto_Rico America/Port_of_Spain\",\n\t\t\"TV|Pacific/Funafuti\",\n\t\t\"TW|Asia/Taipei\",\n\t\t\"TZ|Africa/Nairobi Africa/Dar_es_Salaam\",\n\t\t\"UA|Europe/Simferopol Europe/Kiev Europe/Uzhgorod Europe/Zaporozhye\",\n\t\t\"UG|Africa/Nairobi Africa/Kampala\",\n\t\t\"UM|Pacific/Pago_Pago Pacific/Wake Pacific/Honolulu Pacific/Midway\",\n\t\t\"US|America/New_York America/Detroit America/Kentucky/Louisville America/Kentucky/Monticello America/Indiana/Indianapolis America/Indiana/Vincennes America/Indiana/Winamac America/Indiana/Marengo America/Indiana/Petersburg America/Indiana/Vevay America/Chicago America/Indiana/Tell_City America/Indiana/Knox America/Menominee America/North_Dakota/Center America/North_Dakota/New_Salem America/North_Dakota/Beulah America/Denver America/Boise America/Phoenix America/Los_Angeles America/Anchorage America/Juneau America/Sitka America/Metlakatla America/Yakutat America/Nome America/Adak Pacific/Honolulu\",\n\t\t\"UY|America/Montevideo\",\n\t\t\"UZ|Asia/Samarkand Asia/Tashkent\",\n\t\t\"VA|Europe/Rome Europe/Vatican\",\n\t\t\"VC|America/Puerto_Rico America/St_Vincent\",\n\t\t\"VE|America/Caracas\",\n\t\t\"VG|America/Puerto_Rico America/Tortola\",\n\t\t\"VI|America/Puerto_Rico America/St_Thomas\",\n\t\t\"VN|Asia/Bangkok Asia/Ho_Chi_Minh\",\n\t\t\"VU|Pacific/Efate\",\n\t\t\"WF|Pacific/Wallis\",\n\t\t\"WS|Pacific/Apia\",\n\t\t\"YE|Asia/Riyadh Asia/Aden\",\n\t\t\"YT|Africa/Nairobi Indian/Mayotte\",\n\t\t\"ZA|Africa/Johannesburg\",\n\t\t\"ZM|Africa/Maputo Africa/Lusaka\",\n\t\t\"ZW|Africa/Maputo Africa/Harare\"\n\t];\n\tvar latest = {\n\t\tversion: version,\n\t\tzones: zones$1,\n\t\tlinks: links$1,\n\t\tcountries: countries\n\t};\n\n\tfunction _inheritsLoose(subClass, superClass) {\n\t subClass.prototype = Object.create(superClass.prototype);\n\t subClass.prototype.constructor = subClass;\n\n\t _setPrototypeOf(subClass, superClass);\n\t}\n\n\tfunction _setPrototypeOf(o, p) {\n\t _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {\n\t o.__proto__ = p;\n\t return o;\n\t };\n\n\t return _setPrototypeOf(o, p);\n\t}\n\n\tfunction _unsupportedIterableToArray(o, minLen) {\n\t if (!o) return;\n\t if (typeof o === \"string\") return _arrayLikeToArray(o, minLen);\n\t var n = Object.prototype.toString.call(o).slice(8, -1);\n\t if (n === \"Object\" && o.constructor) n = o.constructor.name;\n\t if (n === \"Map\" || n === \"Set\") return Array.from(o);\n\t if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);\n\t}\n\n\tfunction _arrayLikeToArray(arr, len) {\n\t if (len == null || len > arr.length) len = arr.length;\n\n\t for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];\n\n\t return arr2;\n\t}\n\n\tfunction _createForOfIteratorHelperLoose(o, allowArrayLike) {\n\t var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"];\n\t if (it) return (it = it.call(o)).next.bind(it);\n\n\t if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") {\n\t if (it) o = it;\n\t var i = 0;\n\t return function () {\n\t if (i >= o.length) return {\n\t done: true\n\t };\n\t return {\n\t done: false,\n\t value: o[i++]\n\t };\n\t };\n\t }\n\n\t throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n\t}\n\n\tvar MomentZoneRules = function (_ZoneRules) {\n\t _inheritsLoose(MomentZoneRules, _ZoneRules);\n\n\t function MomentZoneRules(tzdbInfo) {\n\t var _this;\n\n\t _this = _ZoneRules.call(this) || this;\n\t _this._tzdbInfo = tzdbInfo;\n\t _this._ldtUntils = new LDTUntils(_this._tzdbInfo.untils, _this._tzdbInfo.offsets);\n\t return _this;\n\t }\n\n\t var _proto = MomentZoneRules.prototype;\n\n\t _proto.isFixedOffset = function isFixedOffset() {\n\t return this._tzdbInfo.offsets.length === 1;\n\t };\n\n\t _proto.offsetOfInstant = function offsetOfInstant(instant) {\n\t var epochMilli = instant.toEpochMilli();\n\t return this.offsetOfEpochMilli(epochMilli);\n\t };\n\n\t _proto.offsetOfEpochMilli = function offsetOfEpochMilli(epochMilli) {\n\t var index = binarySearch(this._tzdbInfo.untils, epochMilli);\n\t return core.ZoneOffset.ofTotalSeconds(this._offsetByIndexInSeconds(index));\n\t };\n\n\t _proto.offsetOfLocalDateTime = function offsetOfLocalDateTime(localDateTime) {\n\t var info = this._offsetInfo(localDateTime);\n\n\t if (info instanceof core.ZoneOffsetTransition) {\n\t return info.offsetBefore();\n\t }\n\n\t return info;\n\t };\n\n\t _proto._offsetInfo = function _offsetInfo(localDateTime) {\n\t var index = ldtBinarySearch(this._ldtUntils, localDateTime);\n\t var offsetIndex = index >> 1;\n\n\t if (index % 2 === 1) {\n\t var ldtBefore = this._ldtUntils.get(Math.max(index - 1, 0));\n\n\t var ldtAfter = this._ldtUntils.get(Math.min(index, this._ldtUntils.size - 1));\n\n\t var offsetBefore = core.ZoneOffset.ofTotalSeconds(this._offsetByIndexInSeconds(offsetIndex));\n\t var offsetAfter = core.ZoneOffset.ofTotalSeconds(this._offsetByIndexInSeconds(Math.min(offsetIndex + 1, this._tzdbInfo.offsets.length - 1)));\n\n\t if (offsetBefore.compareTo(offsetAfter) > 0) {\n\t return core.ZoneOffsetTransition.of(ldtBefore, offsetBefore, offsetAfter);\n\t } else {\n\t return core.ZoneOffsetTransition.of(ldtAfter, offsetBefore, offsetAfter);\n\t }\n\t }\n\n\t return core.ZoneOffset.ofTotalSeconds(this._offsetByIndexInSeconds(offsetIndex));\n\t };\n\n\t _proto._offsetByIndexInSeconds = function _offsetByIndexInSeconds(index) {\n\t return -offsetInSeconds(this._tzdbInfo.offsets[index]);\n\t };\n\n\t _proto.validOffsets = function validOffsets(localDateTime) {\n\t var info = this._offsetInfo(localDateTime);\n\n\t if (info instanceof core.ZoneOffsetTransition) {\n\t return info.validOffsets();\n\t }\n\n\t return [info];\n\t };\n\n\t _proto.transition = function transition(localDateTime) {\n\t var info = this._offsetInfo(localDateTime);\n\n\t if (info instanceof core.ZoneOffsetTransition) {\n\t return info;\n\t }\n\n\t return null;\n\t };\n\n\t _proto.standardOffset = function standardOffset(instant) {\n\t notSupported('ZoneRules.standardOffset');\n\t };\n\n\t _proto.daylightSavings = function daylightSavings(instant) {\n\t notSupported('ZoneRules.daylightSavings');\n\t };\n\n\t _proto.isDaylightSavings = function isDaylightSavings(instant) {\n\t notSupported('ZoneRules.isDaylightSavings');\n\t };\n\n\t _proto.isValidOffset = function isValidOffset(localDateTime, offset) {\n\t return this.validOffsets(localDateTime).some(function (o) {\n\t return o.equals(offset);\n\t });\n\t };\n\n\t _proto.nextTransition = function nextTransition(instant) {\n\t notSupported('ZoneRules.nextTransition');\n\t };\n\n\t _proto.previousTransition = function previousTransition(instant) {\n\t notSupported('ZoneRules.previousTransition');\n\t };\n\n\t _proto.transitions = function transitions() {\n\t notSupported('ZoneRules.transitions');\n\t };\n\n\t _proto.transitionRules = function transitionRules() {\n\t notSupported('ZoneRules.transitionRules');\n\t };\n\n\t _proto.equals = function equals(other) {\n\t if (this === other) {\n\t return true;\n\t }\n\n\t if (other instanceof MomentZoneRules) {\n\t return this._tzdbInfo === other._tzdbInfo;\n\t }\n\n\t return false;\n\t };\n\n\t _proto.toString = function toString() {\n\t return this._tzdbInfo.name;\n\t };\n\n\t return MomentZoneRules;\n\t}(core.ZoneRules);\n\n\tvar LDTUntils = function () {\n\t function LDTUntils(_tzdbUntils, tzdbOffsets) {\n\t this._tzdbUntils = _tzdbUntils;\n\t this._tzdbOffsets = tzdbOffsets;\n\t this._ldtUntils = [];\n\t this.size = this._tzdbUntils.length * 2;\n\t }\n\n\t var _proto2 = LDTUntils.prototype;\n\n\t _proto2._generateTupple = function _generateTupple(index) {\n\t var epochMillis = this._tzdbUntils[index];\n\n\t if (epochMillis === Infinity) {\n\t return [core.LocalDateTime.MAX, core.LocalDateTime.MAX];\n\t }\n\n\t var instant = core.Instant.ofEpochMilli(epochMillis);\n\t var offset1 = offsetInSeconds(this._tzdbOffsets[index]);\n\t var zone1 = core.ZoneOffset.ofTotalSeconds(-offset1);\n\t var ldt1 = core.LocalDateTime.ofInstant(instant, zone1);\n\t var nextIndex = Math.min(index + 1, this._tzdbOffsets.length - 1);\n\t var offset2 = offsetInSeconds(this._tzdbOffsets[nextIndex]);\n\t var zone2 = core.ZoneOffset.ofTotalSeconds(-offset2);\n\t var ldt2 = core.LocalDateTime.ofInstant(instant, zone2);\n\n\t if (offset1 > offset2) {\n\t return [ldt1, ldt2];\n\t } else {\n\t return [ldt2, ldt1];\n\t }\n\t };\n\n\t _proto2._getTupple = function _getTupple(index) {\n\t if (this._ldtUntils[index] == null) {\n\t this._ldtUntils[index] = this._generateTupple(index);\n\t }\n\n\t return this._ldtUntils[index];\n\t };\n\n\t _proto2.get = function get(index) {\n\t var ldtTupple = this._getTupple(index >> 1);\n\n\t return ldtTupple[index % 2];\n\t };\n\n\t return LDTUntils;\n\t}();\n\n\tfunction ldtBinarySearch(array, value) {\n\t var hi = array.size - 1,\n\t lo = -1,\n\t mid;\n\n\t while (hi - lo > 1) {\n\t if (!value.isBefore(array.get(mid = hi + lo >> 1))) {\n\t lo = mid;\n\t } else {\n\t hi = mid;\n\t }\n\t }\n\n\t return hi;\n\t}\n\n\tfunction offsetInSeconds(tzdbOffset) {\n\t return roundDown(+tzdbOffset * 60);\n\t}\n\n\tfunction roundDown(r) {\n\t if (r < 0) {\n\t return Math.ceil(r);\n\t } else {\n\t return Math.floor(r);\n\t }\n\t}\n\n\tfunction binarySearch(array, value) {\n\t var hi = array.length - 1,\n\t lo = -1,\n\t mid;\n\n\t while (hi - lo > 1) {\n\t if (array[mid = hi + lo >> 1] <= value) {\n\t lo = mid;\n\t } else {\n\t hi = mid;\n\t }\n\t }\n\n\t return hi;\n\t}\n\n\tfunction notSupported(msg) {\n\t throw new Error(\"not supported: \" + msg);\n\t}\n\n\tfunction charCodeToInt(charCode) {\n\t if (charCode > 96) {\n\t return charCode - 87;\n\t } else if (charCode > 64) {\n\t return charCode - 29;\n\t }\n\n\t return charCode - 48;\n\t}\n\n\tfunction unpackBase60(string) {\n\t var i = 0,\n\t parts = string.split('.'),\n\t whole = parts[0],\n\t fractional = parts[1] || '',\n\t multiplier = 1,\n\t num,\n\t out = 0,\n\t sign = 1;\n\n\t if (string.charCodeAt(0) === 45) {\n\t i = 1;\n\t sign = -1;\n\t }\n\n\t for (i; i < whole.length; i++) {\n\t num = charCodeToInt(whole.charCodeAt(i));\n\t out = 60 * out + num;\n\t }\n\n\t for (i = 0; i < fractional.length; i++) {\n\t multiplier = multiplier / 60;\n\t num = charCodeToInt(fractional.charCodeAt(i));\n\t out += num * multiplier;\n\t }\n\n\t return out * sign;\n\t}\n\n\tfunction arrayToInt(array) {\n\t for (var i = 0; i < array.length; i++) {\n\t array[i] = unpackBase60(array[i]);\n\t }\n\t}\n\n\tfunction intToUntil(array, length) {\n\t for (var i = 0; i < length; i++) {\n\t array[i] = Math.round((array[i - 1] || 0) + array[i] * 60000);\n\t }\n\n\t array[length - 1] = Infinity;\n\t}\n\n\tfunction mapIndices(source, indices) {\n\t var out = [],\n\t i;\n\n\t for (i = 0; i < indices.length; i++) {\n\t out[i] = source[indices[i]];\n\t }\n\n\t return out;\n\t}\n\n\tfunction unpack(string) {\n\t var data = string.split('|'),\n\t offsets = data[2].split(' '),\n\t indices = data[3].split(''),\n\t untils = data[4].split(' ');\n\t arrayToInt(offsets);\n\t arrayToInt(indices);\n\t arrayToInt(untils);\n\t intToUntil(untils, indices.length);\n\t return {\n\t name: data[0],\n\t abbrs: mapIndices(data[1].split(' '), indices),\n\t offsets: mapIndices(offsets, indices),\n\t untils: untils,\n\t population: data[5] | 0\n\t };\n\t}\n\n\tvar TZDB_DATA;\n\tvar TZDB_VERSION;\n\tvar AVAILABLE_ZONE_IDS = [];\n\tvar zones = {};\n\tvar links = {};\n\tvar MomentZoneRulesProvider = function (_ZoneRulesProvider) {\n\t _inheritsLoose(MomentZoneRulesProvider, _ZoneRulesProvider);\n\n\t function MomentZoneRulesProvider() {\n\t return _ZoneRulesProvider.apply(this, arguments) || this;\n\t }\n\n\t MomentZoneRulesProvider.getRules = function getRules(zoneId) {\n\t var tzdbZoneInfo = zones[links[zoneId]];\n\n\t if (tzdbZoneInfo == null) {\n\t throw new core.DateTimeException(\"Unknown time-zone ID: \" + zoneId);\n\t }\n\n\t return new MomentZoneRules(tzdbZoneInfo);\n\t };\n\n\t MomentZoneRulesProvider.getAvailableZoneIds = function getAvailableZoneIds() {\n\t return AVAILABLE_ZONE_IDS;\n\t };\n\n\t MomentZoneRulesProvider.getVersion = function getVersion() {\n\t return TZDB_VERSION;\n\t };\n\n\t MomentZoneRulesProvider.getTzdbData = function getTzdbData() {\n\t return TZDB_DATA;\n\t };\n\n\t MomentZoneRulesProvider.loadTzdbData = function loadTzdbData(packedJson) {\n\t TZDB_DATA = packedJson;\n\t TZDB_VERSION = packedJson.version;\n\n\t for (var _iterator = _createForOfIteratorHelperLoose(packedJson.zones), _step; !(_step = _iterator()).done;) {\n\t var packedZoneInfo = _step.value;\n\t var tzdbZoneInfo = unpack(packedZoneInfo);\n\t AVAILABLE_ZONE_IDS.push(tzdbZoneInfo.name);\n\t zones[tzdbZoneInfo.name] = tzdbZoneInfo;\n\t links[tzdbZoneInfo.name] = tzdbZoneInfo.name;\n\t }\n\n\t for (var _iterator2 = _createForOfIteratorHelperLoose(packedJson.links), _step2; !(_step2 = _iterator2()).done;) {\n\t var packedLink = _step2.value;\n\t var link = packedLink.split('|');\n\t AVAILABLE_ZONE_IDS.push(link[1]);\n\t links[link[1]] = link[0];\n\t }\n\t };\n\n\t return MomentZoneRulesProvider;\n\t}(core.ZoneRulesProvider);\n\n\tfunction getResolvedZoneId(ZoneId) {\n\t try {\n\t var resolvedTimeZone = Intl.DateTimeFormat().resolvedOptions().timeZone;\n\t return ZoneId.of(resolvedTimeZone);\n\t } catch (err) {}\n\n\t return null;\n\t}\n\n\tfunction extendSystemDefaultZoneId(ZoneId) {\n\t var resolvedZoneId = getResolvedZoneId(ZoneId);\n\n\t if (resolvedZoneId == null) {\n\t return;\n\t }\n\n\t ZoneId.systemDefault = function () {\n\t return resolvedZoneId;\n\t };\n\t}\n\n\t/*\n\t * @copyright (c) 2016-present, Philipp Thürwächter, Pattrick Hüper\n\t * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n\t */\n\tfunction plug (jsJoda) {\n\t jsJoda.ZoneRulesProvider.getRules = MomentZoneRulesProvider.getRules;\n\t jsJoda.ZoneRulesProvider.getAvailableZoneIds = MomentZoneRulesProvider.getAvailableZoneIds;\n\t jsJoda.ZoneRulesProvider.getTzdbData = MomentZoneRulesProvider.getTzdbData;\n\t jsJoda.ZoneRulesProvider.loadTzdbData = MomentZoneRulesProvider.loadTzdbData;\n\t extendSystemDefaultZoneId(jsJoda.ZoneId);\n\t return jsJoda;\n\t}\n\n\t/*\n\t * @copyright (c) 2016-present, Philipp Thürwächter, Pattrick Hüper\n\t * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n\t */\n\tfunction autoPlug() {\n\t core.use(plug);\n\t}\n\n\t/*\n\t * @copyright (c) 2016-present, Philipp Thürwächter, Pattrick Hüper\n\t * @license BSD-3-Clause (see LICENSE in the root directory of this source tree)\n\t */\n\tMomentZoneRulesProvider.loadTzdbData(latest);\n\tautoPlug();\n\n}));\n//# sourceMappingURL=js-joda-timezone.js.map\n","/*!\n * Vue.js v2.7.14\n * (c) 2014-2022 Evan You\n * Released under the MIT License.\n */\nvar emptyObject = Object.freeze({});\nvar isArray = Array.isArray;\n// These helpers produce better VM code in JS engines due to their\n// explicitness and function inlining.\nfunction isUndef(v) {\n return v === undefined || v === null;\n}\nfunction isDef(v) {\n return v !== undefined && v !== null;\n}\nfunction isTrue(v) {\n return v === true;\n}\nfunction isFalse(v) {\n return v === false;\n}\n/**\n * Check if value is primitive.\n */\nfunction isPrimitive(value) {\n return (typeof value === 'string' ||\n typeof value === 'number' ||\n // $flow-disable-line\n typeof value === 'symbol' ||\n typeof value === 'boolean');\n}\nfunction isFunction(value) {\n return typeof value === 'function';\n}\n/**\n * Quick object check - this is primarily used to tell\n * objects from primitive values when we know the value\n * is a JSON-compliant type.\n */\nfunction isObject(obj) {\n return obj !== null && typeof obj === 'object';\n}\n/**\n * Get the raw type string of a value, e.g., [object Object].\n */\nvar _toString = Object.prototype.toString;\nfunction toRawType(value) {\n return _toString.call(value).slice(8, -1);\n}\n/**\n * Strict object type check. Only returns true\n * for plain JavaScript objects.\n */\nfunction isPlainObject(obj) {\n return _toString.call(obj) === '[object Object]';\n}\nfunction isRegExp(v) {\n return _toString.call(v) === '[object RegExp]';\n}\n/**\n * Check if val is a valid array index.\n */\nfunction isValidArrayIndex(val) {\n var n = parseFloat(String(val));\n return n >= 0 && Math.floor(n) === n && isFinite(val);\n}\nfunction isPromise(val) {\n return (isDef(val) &&\n typeof val.then === 'function' &&\n typeof val.catch === 'function');\n}\n/**\n * Convert a value to a string that is actually rendered.\n */\nfunction toString(val) {\n return val == null\n ? ''\n : Array.isArray(val) || (isPlainObject(val) && val.toString === _toString)\n ? JSON.stringify(val, null, 2)\n : String(val);\n}\n/**\n * Convert an input value to a number for persistence.\n * If the conversion fails, return original string.\n */\nfunction toNumber(val) {\n var n = parseFloat(val);\n return isNaN(n) ? val : n;\n}\n/**\n * Make a map and return a function for checking if a key\n * is in that map.\n */\nfunction makeMap(str, expectsLowerCase) {\n var map = Object.create(null);\n var list = str.split(',');\n for (var i = 0; i < list.length; i++) {\n map[list[i]] = true;\n }\n return expectsLowerCase ? function (val) { return map[val.toLowerCase()]; } : function (val) { return map[val]; };\n}\n/**\n * Check if a tag is a built-in tag.\n */\nvar isBuiltInTag = makeMap('slot,component', true);\n/**\n * Check if an attribute is a reserved attribute.\n */\nvar isReservedAttribute = makeMap('key,ref,slot,slot-scope,is');\n/**\n * Remove an item from an array.\n */\nfunction remove$2(arr, item) {\n var len = arr.length;\n if (len) {\n // fast path for the only / last item\n if (item === arr[len - 1]) {\n arr.length = len - 1;\n return;\n }\n var index = arr.indexOf(item);\n if (index > -1) {\n return arr.splice(index, 1);\n }\n }\n}\n/**\n * Check whether an object has the property.\n */\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nfunction hasOwn(obj, key) {\n return hasOwnProperty.call(obj, key);\n}\n/**\n * Create a cached version of a pure function.\n */\nfunction cached(fn) {\n var cache = Object.create(null);\n return function cachedFn(str) {\n var hit = cache[str];\n return hit || (cache[str] = fn(str));\n };\n}\n/**\n * Camelize a hyphen-delimited string.\n */\nvar camelizeRE = /-(\\w)/g;\nvar camelize = cached(function (str) {\n return str.replace(camelizeRE, function (_, c) { return (c ? c.toUpperCase() : ''); });\n});\n/**\n * Capitalize a string.\n */\nvar capitalize = cached(function (str) {\n return str.charAt(0).toUpperCase() + str.slice(1);\n});\n/**\n * Hyphenate a camelCase string.\n */\nvar hyphenateRE = /\\B([A-Z])/g;\nvar hyphenate = cached(function (str) {\n return str.replace(hyphenateRE, '-$1').toLowerCase();\n});\n/**\n * Simple bind polyfill for environments that do not support it,\n * e.g., PhantomJS 1.x. Technically, we don't need this anymore\n * since native bind is now performant enough in most browsers.\n * But removing it would mean breaking code that was able to run in\n * PhantomJS 1.x, so this must be kept for backward compatibility.\n */\n/* istanbul ignore next */\nfunction polyfillBind(fn, ctx) {\n function boundFn(a) {\n var l = arguments.length;\n return l\n ? l > 1\n ? fn.apply(ctx, arguments)\n : fn.call(ctx, a)\n : fn.call(ctx);\n }\n boundFn._length = fn.length;\n return boundFn;\n}\nfunction nativeBind(fn, ctx) {\n return fn.bind(ctx);\n}\n// @ts-expect-error bind cannot be `undefined`\nvar bind = Function.prototype.bind ? nativeBind : polyfillBind;\n/**\n * Convert an Array-like object to a real Array.\n */\nfunction toArray(list, start) {\n start = start || 0;\n var i = list.length - start;\n var ret = new Array(i);\n while (i--) {\n ret[i] = list[i + start];\n }\n return ret;\n}\n/**\n * Mix properties into target object.\n */\nfunction extend(to, _from) {\n for (var key in _from) {\n to[key] = _from[key];\n }\n return to;\n}\n/**\n * Merge an Array of Objects into a single Object.\n */\nfunction toObject(arr) {\n var res = {};\n for (var i = 0; i < arr.length; i++) {\n if (arr[i]) {\n extend(res, arr[i]);\n }\n }\n return res;\n}\n/* eslint-disable no-unused-vars */\n/**\n * Perform no operation.\n * Stubbing args to make Flow happy without leaving useless transpiled code\n * with ...rest (https://flow.org/blog/2017/05/07/Strict-Function-Call-Arity/).\n */\nfunction noop(a, b, c) { }\n/**\n * Always return false.\n */\nvar no = function (a, b, c) { return false; };\n/* eslint-enable no-unused-vars */\n/**\n * Return the same value.\n */\nvar identity = function (_) { return _; };\n/**\n * Check if two values are loosely equal - that is,\n * if they are plain objects, do they have the same shape?\n */\nfunction looseEqual(a, b) {\n if (a === b)\n return true;\n var isObjectA = isObject(a);\n var isObjectB = isObject(b);\n if (isObjectA && isObjectB) {\n try {\n var isArrayA = Array.isArray(a);\n var isArrayB = Array.isArray(b);\n if (isArrayA && isArrayB) {\n return (a.length === b.length &&\n a.every(function (e, i) {\n return looseEqual(e, b[i]);\n }));\n }\n else if (a instanceof Date && b instanceof Date) {\n return a.getTime() === b.getTime();\n }\n else if (!isArrayA && !isArrayB) {\n var keysA = Object.keys(a);\n var keysB = Object.keys(b);\n return (keysA.length === keysB.length &&\n keysA.every(function (key) {\n return looseEqual(a[key], b[key]);\n }));\n }\n else {\n /* istanbul ignore next */\n return false;\n }\n }\n catch (e) {\n /* istanbul ignore next */\n return false;\n }\n }\n else if (!isObjectA && !isObjectB) {\n return String(a) === String(b);\n }\n else {\n return false;\n }\n}\n/**\n * Return the first index at which a loosely equal value can be\n * found in the array (if value is a plain object, the array must\n * contain an object of the same shape), or -1 if it is not present.\n */\nfunction looseIndexOf(arr, val) {\n for (var i = 0; i < arr.length; i++) {\n if (looseEqual(arr[i], val))\n return i;\n }\n return -1;\n}\n/**\n * Ensure a function is called only once.\n */\nfunction once(fn) {\n var called = false;\n return function () {\n if (!called) {\n called = true;\n fn.apply(this, arguments);\n }\n };\n}\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is#polyfill\nfunction hasChanged(x, y) {\n if (x === y) {\n return x === 0 && 1 / x !== 1 / y;\n }\n else {\n return x === x || y === y;\n }\n}\n\nvar SSR_ATTR = 'data-server-rendered';\nvar ASSET_TYPES = ['component', 'directive', 'filter'];\nvar LIFECYCLE_HOOKS = [\n 'beforeCreate',\n 'created',\n 'beforeMount',\n 'mounted',\n 'beforeUpdate',\n 'updated',\n 'beforeDestroy',\n 'destroyed',\n 'activated',\n 'deactivated',\n 'errorCaptured',\n 'serverPrefetch',\n 'renderTracked',\n 'renderTriggered'\n];\n\nvar config = {\n /**\n * Option merge strategies (used in core/util/options)\n */\n // $flow-disable-line\n optionMergeStrategies: Object.create(null),\n /**\n * Whether to suppress warnings.\n */\n silent: false,\n /**\n * Show production mode tip message on boot?\n */\n productionTip: process.env.NODE_ENV !== 'production',\n /**\n * Whether to enable devtools\n */\n devtools: process.env.NODE_ENV !== 'production',\n /**\n * Whether to record perf\n */\n performance: false,\n /**\n * Error handler for watcher errors\n */\n errorHandler: null,\n /**\n * Warn handler for watcher warns\n */\n warnHandler: null,\n /**\n * Ignore certain custom elements\n */\n ignoredElements: [],\n /**\n * Custom user key aliases for v-on\n */\n // $flow-disable-line\n keyCodes: Object.create(null),\n /**\n * Check if a tag is reserved so that it cannot be registered as a\n * component. This is platform-dependent and may be overwritten.\n */\n isReservedTag: no,\n /**\n * Check if an attribute is reserved so that it cannot be used as a component\n * prop. This is platform-dependent and may be overwritten.\n */\n isReservedAttr: no,\n /**\n * Check if a tag is an unknown element.\n * Platform-dependent.\n */\n isUnknownElement: no,\n /**\n * Get the namespace of an element\n */\n getTagNamespace: noop,\n /**\n * Parse the real tag name for the specific platform.\n */\n parsePlatformTagName: identity,\n /**\n * Check if an attribute must be bound using property, e.g. value\n * Platform-dependent.\n */\n mustUseProp: no,\n /**\n * Perform updates asynchronously. Intended to be used by Vue Test Utils\n * This will significantly reduce performance if set to false.\n */\n async: true,\n /**\n * Exposed for legacy reasons\n */\n _lifecycleHooks: LIFECYCLE_HOOKS\n};\n\n/**\n * unicode letters used for parsing html tags, component names and property paths.\n * using https://www.w3.org/TR/html53/semantics-scripting.html#potentialcustomelementname\n * skipping \\u10000-\\uEFFFF due to it freezing up PhantomJS\n */\nvar unicodeRegExp = /a-zA-Z\\u00B7\\u00C0-\\u00D6\\u00D8-\\u00F6\\u00F8-\\u037D\\u037F-\\u1FFF\\u200C-\\u200D\\u203F-\\u2040\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD/;\n/**\n * Check if a string starts with $ or _\n */\nfunction isReserved(str) {\n var c = (str + '').charCodeAt(0);\n return c === 0x24 || c === 0x5f;\n}\n/**\n * Define a property.\n */\nfunction def(obj, key, val, enumerable) {\n Object.defineProperty(obj, key, {\n value: val,\n enumerable: !!enumerable,\n writable: true,\n configurable: true\n });\n}\n/**\n * Parse simple path.\n */\nvar bailRE = new RegExp(\"[^\".concat(unicodeRegExp.source, \".$_\\\\d]\"));\nfunction parsePath(path) {\n if (bailRE.test(path)) {\n return;\n }\n var segments = path.split('.');\n return function (obj) {\n for (var i = 0; i < segments.length; i++) {\n if (!obj)\n return;\n obj = obj[segments[i]];\n }\n return obj;\n };\n}\n\n// can we use __proto__?\nvar hasProto = '__proto__' in {};\n// Browser environment sniffing\nvar inBrowser = typeof window !== 'undefined';\nvar UA = inBrowser && window.navigator.userAgent.toLowerCase();\nvar isIE = UA && /msie|trident/.test(UA);\nvar isIE9 = UA && UA.indexOf('msie 9.0') > 0;\nvar isEdge = UA && UA.indexOf('edge/') > 0;\nUA && UA.indexOf('android') > 0;\nvar isIOS = UA && /iphone|ipad|ipod|ios/.test(UA);\nUA && /chrome\\/\\d+/.test(UA) && !isEdge;\nUA && /phantomjs/.test(UA);\nvar isFF = UA && UA.match(/firefox\\/(\\d+)/);\n// Firefox has a \"watch\" function on Object.prototype...\n// @ts-expect-error firebox support\nvar nativeWatch = {}.watch;\nvar supportsPassive = false;\nif (inBrowser) {\n try {\n var opts = {};\n Object.defineProperty(opts, 'passive', {\n get: function () {\n /* istanbul ignore next */\n supportsPassive = true;\n }\n }); // https://github.com/facebook/flow/issues/285\n window.addEventListener('test-passive', null, opts);\n }\n catch (e) { }\n}\n// this needs to be lazy-evaled because vue may be required before\n// vue-server-renderer can set VUE_ENV\nvar _isServer;\nvar isServerRendering = function () {\n if (_isServer === undefined) {\n /* istanbul ignore if */\n if (!inBrowser && typeof global !== 'undefined') {\n // detect presence of vue-server-renderer and avoid\n // Webpack shimming the process\n _isServer =\n global['process'] && global['process'].env.VUE_ENV === 'server';\n }\n else {\n _isServer = false;\n }\n }\n return _isServer;\n};\n// detect devtools\nvar devtools = inBrowser && window.__VUE_DEVTOOLS_GLOBAL_HOOK__;\n/* istanbul ignore next */\nfunction isNative(Ctor) {\n return typeof Ctor === 'function' && /native code/.test(Ctor.toString());\n}\nvar hasSymbol = typeof Symbol !== 'undefined' &&\n isNative(Symbol) &&\n typeof Reflect !== 'undefined' &&\n isNative(Reflect.ownKeys);\nvar _Set; // $flow-disable-line\n/* istanbul ignore if */ if (typeof Set !== 'undefined' && isNative(Set)) {\n // use native Set when available.\n _Set = Set;\n}\nelse {\n // a non-standard Set polyfill that only works with primitive keys.\n _Set = /** @class */ (function () {\n function Set() {\n this.set = Object.create(null);\n }\n Set.prototype.has = function (key) {\n return this.set[key] === true;\n };\n Set.prototype.add = function (key) {\n this.set[key] = true;\n };\n Set.prototype.clear = function () {\n this.set = Object.create(null);\n };\n return Set;\n }());\n}\n\nvar currentInstance = null;\n/**\n * This is exposed for compatibility with v3 (e.g. some functions in VueUse\n * relies on it). Do not use this internally, just use `currentInstance`.\n *\n * @internal this function needs manual type declaration because it relies\n * on previously manually authored types from Vue 2\n */\nfunction getCurrentInstance() {\n return currentInstance && { proxy: currentInstance };\n}\n/**\n * @internal\n */\nfunction setCurrentInstance(vm) {\n if (vm === void 0) { vm = null; }\n if (!vm)\n currentInstance && currentInstance._scope.off();\n currentInstance = vm;\n vm && vm._scope.on();\n}\n\n/**\n * @internal\n */\nvar VNode = /** @class */ (function () {\n function VNode(tag, data, children, text, elm, context, componentOptions, asyncFactory) {\n this.tag = tag;\n this.data = data;\n this.children = children;\n this.text = text;\n this.elm = elm;\n this.ns = undefined;\n this.context = context;\n this.fnContext = undefined;\n this.fnOptions = undefined;\n this.fnScopeId = undefined;\n this.key = data && data.key;\n this.componentOptions = componentOptions;\n this.componentInstance = undefined;\n this.parent = undefined;\n this.raw = false;\n this.isStatic = false;\n this.isRootInsert = true;\n this.isComment = false;\n this.isCloned = false;\n this.isOnce = false;\n this.asyncFactory = asyncFactory;\n this.asyncMeta = undefined;\n this.isAsyncPlaceholder = false;\n }\n Object.defineProperty(VNode.prototype, \"child\", {\n // DEPRECATED: alias for componentInstance for backwards compat.\n /* istanbul ignore next */\n get: function () {\n return this.componentInstance;\n },\n enumerable: false,\n configurable: true\n });\n return VNode;\n}());\nvar createEmptyVNode = function (text) {\n if (text === void 0) { text = ''; }\n var node = new VNode();\n node.text = text;\n node.isComment = true;\n return node;\n};\nfunction createTextVNode(val) {\n return new VNode(undefined, undefined, undefined, String(val));\n}\n// optimized shallow clone\n// used for static nodes and slot nodes because they may be reused across\n// multiple renders, cloning them avoids errors when DOM manipulations rely\n// on their elm reference.\nfunction cloneVNode(vnode) {\n var cloned = new VNode(vnode.tag, vnode.data, \n // #7975\n // clone children array to avoid mutating original in case of cloning\n // a child.\n vnode.children && vnode.children.slice(), vnode.text, vnode.elm, vnode.context, vnode.componentOptions, vnode.asyncFactory);\n cloned.ns = vnode.ns;\n cloned.isStatic = vnode.isStatic;\n cloned.key = vnode.key;\n cloned.isComment = vnode.isComment;\n cloned.fnContext = vnode.fnContext;\n cloned.fnOptions = vnode.fnOptions;\n cloned.fnScopeId = vnode.fnScopeId;\n cloned.asyncMeta = vnode.asyncMeta;\n cloned.isCloned = true;\n return cloned;\n}\n\n/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n\r\nvar __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n };\r\n return __assign.apply(this, arguments);\r\n};\n\nvar uid$2 = 0;\nvar pendingCleanupDeps = [];\nvar cleanupDeps = function () {\n for (var i = 0; i < pendingCleanupDeps.length; i++) {\n var dep = pendingCleanupDeps[i];\n dep.subs = dep.subs.filter(function (s) { return s; });\n dep._pending = false;\n }\n pendingCleanupDeps.length = 0;\n};\n/**\n * A dep is an observable that can have multiple\n * directives subscribing to it.\n * @internal\n */\nvar Dep = /** @class */ (function () {\n function Dep() {\n // pending subs cleanup\n this._pending = false;\n this.id = uid$2++;\n this.subs = [];\n }\n Dep.prototype.addSub = function (sub) {\n this.subs.push(sub);\n };\n Dep.prototype.removeSub = function (sub) {\n // #12696 deps with massive amount of subscribers are extremely slow to\n // clean up in Chromium\n // to workaround this, we unset the sub for now, and clear them on\n // next scheduler flush.\n this.subs[this.subs.indexOf(sub)] = null;\n if (!this._pending) {\n this._pending = true;\n pendingCleanupDeps.push(this);\n }\n };\n Dep.prototype.depend = function (info) {\n if (Dep.target) {\n Dep.target.addDep(this);\n if (process.env.NODE_ENV !== 'production' && info && Dep.target.onTrack) {\n Dep.target.onTrack(__assign({ effect: Dep.target }, info));\n }\n }\n };\n Dep.prototype.notify = function (info) {\n // stabilize the subscriber list first\n var subs = this.subs.filter(function (s) { return s; });\n if (process.env.NODE_ENV !== 'production' && !config.async) {\n // subs aren't sorted in scheduler if not running async\n // we need to sort them now to make sure they fire in correct\n // order\n subs.sort(function (a, b) { return a.id - b.id; });\n }\n for (var i = 0, l = subs.length; i < l; i++) {\n var sub = subs[i];\n if (process.env.NODE_ENV !== 'production' && info) {\n sub.onTrigger &&\n sub.onTrigger(__assign({ effect: subs[i] }, info));\n }\n sub.update();\n }\n };\n return Dep;\n}());\n// The current target watcher being evaluated.\n// This is globally unique because only one watcher\n// can be evaluated at a time.\nDep.target = null;\nvar targetStack = [];\nfunction pushTarget(target) {\n targetStack.push(target);\n Dep.target = target;\n}\nfunction popTarget() {\n targetStack.pop();\n Dep.target = targetStack[targetStack.length - 1];\n}\n\n/*\n * not type checking this file because flow doesn't play well with\n * dynamically accessing methods on Array prototype\n */\nvar arrayProto = Array.prototype;\nvar arrayMethods = Object.create(arrayProto);\nvar methodsToPatch = [\n 'push',\n 'pop',\n 'shift',\n 'unshift',\n 'splice',\n 'sort',\n 'reverse'\n];\n/**\n * Intercept mutating methods and emit events\n */\nmethodsToPatch.forEach(function (method) {\n // cache original method\n var original = arrayProto[method];\n def(arrayMethods, method, function mutator() {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n var result = original.apply(this, args);\n var ob = this.__ob__;\n var inserted;\n switch (method) {\n case 'push':\n case 'unshift':\n inserted = args;\n break;\n case 'splice':\n inserted = args.slice(2);\n break;\n }\n if (inserted)\n ob.observeArray(inserted);\n // notify change\n if (process.env.NODE_ENV !== 'production') {\n ob.dep.notify({\n type: \"array mutation\" /* TriggerOpTypes.ARRAY_MUTATION */,\n target: this,\n key: method\n });\n }\n else {\n ob.dep.notify();\n }\n return result;\n });\n});\n\nvar arrayKeys = Object.getOwnPropertyNames(arrayMethods);\nvar NO_INIITIAL_VALUE = {};\n/**\n * In some cases we may want to disable observation inside a component's\n * update computation.\n */\nvar shouldObserve = true;\nfunction toggleObserving(value) {\n shouldObserve = value;\n}\n// ssr mock dep\nvar mockDep = {\n notify: noop,\n depend: noop,\n addSub: noop,\n removeSub: noop\n};\n/**\n * Observer class that is attached to each observed\n * object. Once attached, the observer converts the target\n * object's property keys into getter/setters that\n * collect dependencies and dispatch updates.\n */\nvar Observer = /** @class */ (function () {\n function Observer(value, shallow, mock) {\n if (shallow === void 0) { shallow = false; }\n if (mock === void 0) { mock = false; }\n this.value = value;\n this.shallow = shallow;\n this.mock = mock;\n // this.value = value\n this.dep = mock ? mockDep : new Dep();\n this.vmCount = 0;\n def(value, '__ob__', this);\n if (isArray(value)) {\n if (!mock) {\n if (hasProto) {\n value.__proto__ = arrayMethods;\n /* eslint-enable no-proto */\n }\n else {\n for (var i = 0, l = arrayKeys.length; i < l; i++) {\n var key = arrayKeys[i];\n def(value, key, arrayMethods[key]);\n }\n }\n }\n if (!shallow) {\n this.observeArray(value);\n }\n }\n else {\n /**\n * Walk through all properties and convert them into\n * getter/setters. This method should only be called when\n * value type is Object.\n */\n var keys = Object.keys(value);\n for (var i = 0; i < keys.length; i++) {\n var key = keys[i];\n defineReactive(value, key, NO_INIITIAL_VALUE, undefined, shallow, mock);\n }\n }\n }\n /**\n * Observe a list of Array items.\n */\n Observer.prototype.observeArray = function (value) {\n for (var i = 0, l = value.length; i < l; i++) {\n observe(value[i], false, this.mock);\n }\n };\n return Observer;\n}());\n// helpers\n/**\n * Attempt to create an observer instance for a value,\n * returns the new observer if successfully observed,\n * or the existing observer if the value already has one.\n */\nfunction observe(value, shallow, ssrMockReactivity) {\n if (value && hasOwn(value, '__ob__') && value.__ob__ instanceof Observer) {\n return value.__ob__;\n }\n if (shouldObserve &&\n (ssrMockReactivity || !isServerRendering()) &&\n (isArray(value) || isPlainObject(value)) &&\n Object.isExtensible(value) &&\n !value.__v_skip /* ReactiveFlags.SKIP */ &&\n !isRef(value) &&\n !(value instanceof VNode)) {\n return new Observer(value, shallow, ssrMockReactivity);\n }\n}\n/**\n * Define a reactive property on an Object.\n */\nfunction defineReactive(obj, key, val, customSetter, shallow, mock) {\n var dep = new Dep();\n var property = Object.getOwnPropertyDescriptor(obj, key);\n if (property && property.configurable === false) {\n return;\n }\n // cater for pre-defined getter/setters\n var getter = property && property.get;\n var setter = property && property.set;\n if ((!getter || setter) &&\n (val === NO_INIITIAL_VALUE || arguments.length === 2)) {\n val = obj[key];\n }\n var childOb = !shallow && observe(val, false, mock);\n Object.defineProperty(obj, key, {\n enumerable: true,\n configurable: true,\n get: function reactiveGetter() {\n var value = getter ? getter.call(obj) : val;\n if (Dep.target) {\n if (process.env.NODE_ENV !== 'production') {\n dep.depend({\n target: obj,\n type: \"get\" /* TrackOpTypes.GET */,\n key: key\n });\n }\n else {\n dep.depend();\n }\n if (childOb) {\n childOb.dep.depend();\n if (isArray(value)) {\n dependArray(value);\n }\n }\n }\n return isRef(value) && !shallow ? value.value : value;\n },\n set: function reactiveSetter(newVal) {\n var value = getter ? getter.call(obj) : val;\n if (!hasChanged(value, newVal)) {\n return;\n }\n if (process.env.NODE_ENV !== 'production' && customSetter) {\n customSetter();\n }\n if (setter) {\n setter.call(obj, newVal);\n }\n else if (getter) {\n // #7981: for accessor properties without setter\n return;\n }\n else if (!shallow && isRef(value) && !isRef(newVal)) {\n value.value = newVal;\n return;\n }\n else {\n val = newVal;\n }\n childOb = !shallow && observe(newVal, false, mock);\n if (process.env.NODE_ENV !== 'production') {\n dep.notify({\n type: \"set\" /* TriggerOpTypes.SET */,\n target: obj,\n key: key,\n newValue: newVal,\n oldValue: value\n });\n }\n else {\n dep.notify();\n }\n }\n });\n return dep;\n}\nfunction set(target, key, val) {\n if (process.env.NODE_ENV !== 'production' && (isUndef(target) || isPrimitive(target))) {\n warn(\"Cannot set reactive property on undefined, null, or primitive value: \".concat(target));\n }\n if (isReadonly(target)) {\n process.env.NODE_ENV !== 'production' && warn(\"Set operation on key \\\"\".concat(key, \"\\\" failed: target is readonly.\"));\n return;\n }\n var ob = target.__ob__;\n if (isArray(target) && isValidArrayIndex(key)) {\n target.length = Math.max(target.length, key);\n target.splice(key, 1, val);\n // when mocking for SSR, array methods are not hijacked\n if (ob && !ob.shallow && ob.mock) {\n observe(val, false, true);\n }\n return val;\n }\n if (key in target && !(key in Object.prototype)) {\n target[key] = val;\n return val;\n }\n if (target._isVue || (ob && ob.vmCount)) {\n process.env.NODE_ENV !== 'production' &&\n warn('Avoid adding reactive properties to a Vue instance or its root $data ' +\n 'at runtime - declare it upfront in the data option.');\n return val;\n }\n if (!ob) {\n target[key] = val;\n return val;\n }\n defineReactive(ob.value, key, val, undefined, ob.shallow, ob.mock);\n if (process.env.NODE_ENV !== 'production') {\n ob.dep.notify({\n type: \"add\" /* TriggerOpTypes.ADD */,\n target: target,\n key: key,\n newValue: val,\n oldValue: undefined\n });\n }\n else {\n ob.dep.notify();\n }\n return val;\n}\nfunction del(target, key) {\n if (process.env.NODE_ENV !== 'production' && (isUndef(target) || isPrimitive(target))) {\n warn(\"Cannot delete reactive property on undefined, null, or primitive value: \".concat(target));\n }\n if (isArray(target) && isValidArrayIndex(key)) {\n target.splice(key, 1);\n return;\n }\n var ob = target.__ob__;\n if (target._isVue || (ob && ob.vmCount)) {\n process.env.NODE_ENV !== 'production' &&\n warn('Avoid deleting properties on a Vue instance or its root $data ' +\n '- just set it to null.');\n return;\n }\n if (isReadonly(target)) {\n process.env.NODE_ENV !== 'production' &&\n warn(\"Delete operation on key \\\"\".concat(key, \"\\\" failed: target is readonly.\"));\n return;\n }\n if (!hasOwn(target, key)) {\n return;\n }\n delete target[key];\n if (!ob) {\n return;\n }\n if (process.env.NODE_ENV !== 'production') {\n ob.dep.notify({\n type: \"delete\" /* TriggerOpTypes.DELETE */,\n target: target,\n key: key\n });\n }\n else {\n ob.dep.notify();\n }\n}\n/**\n * Collect dependencies on array elements when the array is touched, since\n * we cannot intercept array element access like property getters.\n */\nfunction dependArray(value) {\n for (var e = void 0, i = 0, l = value.length; i < l; i++) {\n e = value[i];\n if (e && e.__ob__) {\n e.__ob__.dep.depend();\n }\n if (isArray(e)) {\n dependArray(e);\n }\n }\n}\n\nfunction reactive(target) {\n makeReactive(target, false);\n return target;\n}\n/**\n * Return a shallowly-reactive copy of the original object, where only the root\n * level properties are reactive. It also does not auto-unwrap refs (even at the\n * root level).\n */\nfunction shallowReactive(target) {\n makeReactive(target, true);\n def(target, \"__v_isShallow\" /* ReactiveFlags.IS_SHALLOW */, true);\n return target;\n}\nfunction makeReactive(target, shallow) {\n // if trying to observe a readonly proxy, return the readonly version.\n if (!isReadonly(target)) {\n if (process.env.NODE_ENV !== 'production') {\n if (isArray(target)) {\n warn(\"Avoid using Array as root value for \".concat(shallow ? \"shallowReactive()\" : \"reactive()\", \" as it cannot be tracked in watch() or watchEffect(). Use \").concat(shallow ? \"shallowRef()\" : \"ref()\", \" instead. This is a Vue-2-only limitation.\"));\n }\n var existingOb = target && target.__ob__;\n if (existingOb && existingOb.shallow !== shallow) {\n warn(\"Target is already a \".concat(existingOb.shallow ? \"\" : \"non-\", \"shallow reactive object, and cannot be converted to \").concat(shallow ? \"\" : \"non-\", \"shallow.\"));\n }\n }\n var ob = observe(target, shallow, isServerRendering() /* ssr mock reactivity */);\n if (process.env.NODE_ENV !== 'production' && !ob) {\n if (target == null || isPrimitive(target)) {\n warn(\"value cannot be made reactive: \".concat(String(target)));\n }\n if (isCollectionType(target)) {\n warn(\"Vue 2 does not support reactive collection types such as Map or Set.\");\n }\n }\n }\n}\nfunction isReactive(value) {\n if (isReadonly(value)) {\n return isReactive(value[\"__v_raw\" /* ReactiveFlags.RAW */]);\n }\n return !!(value && value.__ob__);\n}\nfunction isShallow(value) {\n return !!(value && value.__v_isShallow);\n}\nfunction isReadonly(value) {\n return !!(value && value.__v_isReadonly);\n}\nfunction isProxy(value) {\n return isReactive(value) || isReadonly(value);\n}\nfunction toRaw(observed) {\n var raw = observed && observed[\"__v_raw\" /* ReactiveFlags.RAW */];\n return raw ? toRaw(raw) : observed;\n}\nfunction markRaw(value) {\n // non-extensible objects won't be observed anyway\n if (Object.isExtensible(value)) {\n def(value, \"__v_skip\" /* ReactiveFlags.SKIP */, true);\n }\n return value;\n}\n/**\n * @internal\n */\nfunction isCollectionType(value) {\n var type = toRawType(value);\n return (type === 'Map' || type === 'WeakMap' || type === 'Set' || type === 'WeakSet');\n}\n\n/**\n * @internal\n */\nvar RefFlag = \"__v_isRef\";\nfunction isRef(r) {\n return !!(r && r.__v_isRef === true);\n}\nfunction ref$1(value) {\n return createRef(value, false);\n}\nfunction shallowRef(value) {\n return createRef(value, true);\n}\nfunction createRef(rawValue, shallow) {\n if (isRef(rawValue)) {\n return rawValue;\n }\n var ref = {};\n def(ref, RefFlag, true);\n def(ref, \"__v_isShallow\" /* ReactiveFlags.IS_SHALLOW */, shallow);\n def(ref, 'dep', defineReactive(ref, 'value', rawValue, null, shallow, isServerRendering()));\n return ref;\n}\nfunction triggerRef(ref) {\n if (process.env.NODE_ENV !== 'production' && !ref.dep) {\n warn(\"received object is not a triggerable ref.\");\n }\n if (process.env.NODE_ENV !== 'production') {\n ref.dep &&\n ref.dep.notify({\n type: \"set\" /* TriggerOpTypes.SET */,\n target: ref,\n key: 'value'\n });\n }\n else {\n ref.dep && ref.dep.notify();\n }\n}\nfunction unref(ref) {\n return isRef(ref) ? ref.value : ref;\n}\nfunction proxyRefs(objectWithRefs) {\n if (isReactive(objectWithRefs)) {\n return objectWithRefs;\n }\n var proxy = {};\n var keys = Object.keys(objectWithRefs);\n for (var i = 0; i < keys.length; i++) {\n proxyWithRefUnwrap(proxy, objectWithRefs, keys[i]);\n }\n return proxy;\n}\nfunction proxyWithRefUnwrap(target, source, key) {\n Object.defineProperty(target, key, {\n enumerable: true,\n configurable: true,\n get: function () {\n var val = source[key];\n if (isRef(val)) {\n return val.value;\n }\n else {\n var ob = val && val.__ob__;\n if (ob)\n ob.dep.depend();\n return val;\n }\n },\n set: function (value) {\n var oldValue = source[key];\n if (isRef(oldValue) && !isRef(value)) {\n oldValue.value = value;\n }\n else {\n source[key] = value;\n }\n }\n });\n}\nfunction customRef(factory) {\n var dep = new Dep();\n var _a = factory(function () {\n if (process.env.NODE_ENV !== 'production') {\n dep.depend({\n target: ref,\n type: \"get\" /* TrackOpTypes.GET */,\n key: 'value'\n });\n }\n else {\n dep.depend();\n }\n }, function () {\n if (process.env.NODE_ENV !== 'production') {\n dep.notify({\n target: ref,\n type: \"set\" /* TriggerOpTypes.SET */,\n key: 'value'\n });\n }\n else {\n dep.notify();\n }\n }), get = _a.get, set = _a.set;\n var ref = {\n get value() {\n return get();\n },\n set value(newVal) {\n set(newVal);\n }\n };\n def(ref, RefFlag, true);\n return ref;\n}\nfunction toRefs(object) {\n if (process.env.NODE_ENV !== 'production' && !isReactive(object)) {\n warn(\"toRefs() expects a reactive object but received a plain one.\");\n }\n var ret = isArray(object) ? new Array(object.length) : {};\n for (var key in object) {\n ret[key] = toRef(object, key);\n }\n return ret;\n}\nfunction toRef(object, key, defaultValue) {\n var val = object[key];\n if (isRef(val)) {\n return val;\n }\n var ref = {\n get value() {\n var val = object[key];\n return val === undefined ? defaultValue : val;\n },\n set value(newVal) {\n object[key] = newVal;\n }\n };\n def(ref, RefFlag, true);\n return ref;\n}\n\nvar rawToReadonlyFlag = \"__v_rawToReadonly\";\nvar rawToShallowReadonlyFlag = \"__v_rawToShallowReadonly\";\nfunction readonly(target) {\n return createReadonly(target, false);\n}\nfunction createReadonly(target, shallow) {\n if (!isPlainObject(target)) {\n if (process.env.NODE_ENV !== 'production') {\n if (isArray(target)) {\n warn(\"Vue 2 does not support readonly arrays.\");\n }\n else if (isCollectionType(target)) {\n warn(\"Vue 2 does not support readonly collection types such as Map or Set.\");\n }\n else {\n warn(\"value cannot be made readonly: \".concat(typeof target));\n }\n }\n return target;\n }\n if (process.env.NODE_ENV !== 'production' && !Object.isExtensible(target)) {\n warn(\"Vue 2 does not support creating readonly proxy for non-extensible object.\");\n }\n // already a readonly object\n if (isReadonly(target)) {\n return target;\n }\n // already has a readonly proxy\n var existingFlag = shallow ? rawToShallowReadonlyFlag : rawToReadonlyFlag;\n var existingProxy = target[existingFlag];\n if (existingProxy) {\n return existingProxy;\n }\n var proxy = Object.create(Object.getPrototypeOf(target));\n def(target, existingFlag, proxy);\n def(proxy, \"__v_isReadonly\" /* ReactiveFlags.IS_READONLY */, true);\n def(proxy, \"__v_raw\" /* ReactiveFlags.RAW */, target);\n if (isRef(target)) {\n def(proxy, RefFlag, true);\n }\n if (shallow || isShallow(target)) {\n def(proxy, \"__v_isShallow\" /* ReactiveFlags.IS_SHALLOW */, true);\n }\n var keys = Object.keys(target);\n for (var i = 0; i < keys.length; i++) {\n defineReadonlyProperty(proxy, target, keys[i], shallow);\n }\n return proxy;\n}\nfunction defineReadonlyProperty(proxy, target, key, shallow) {\n Object.defineProperty(proxy, key, {\n enumerable: true,\n configurable: true,\n get: function () {\n var val = target[key];\n return shallow || !isPlainObject(val) ? val : readonly(val);\n },\n set: function () {\n process.env.NODE_ENV !== 'production' &&\n warn(\"Set operation on key \\\"\".concat(key, \"\\\" failed: target is readonly.\"));\n }\n });\n}\n/**\n * Returns a reactive-copy of the original object, where only the root level\n * properties are readonly, and does NOT unwrap refs nor recursively convert\n * returned properties.\n * This is used for creating the props proxy object for stateful components.\n */\nfunction shallowReadonly(target) {\n return createReadonly(target, true);\n}\n\nfunction computed(getterOrOptions, debugOptions) {\n var getter;\n var setter;\n var onlyGetter = isFunction(getterOrOptions);\n if (onlyGetter) {\n getter = getterOrOptions;\n setter = process.env.NODE_ENV !== 'production'\n ? function () {\n warn('Write operation failed: computed value is readonly');\n }\n : noop;\n }\n else {\n getter = getterOrOptions.get;\n setter = getterOrOptions.set;\n }\n var watcher = isServerRendering()\n ? null\n : new Watcher(currentInstance, getter, noop, { lazy: true });\n if (process.env.NODE_ENV !== 'production' && watcher && debugOptions) {\n watcher.onTrack = debugOptions.onTrack;\n watcher.onTrigger = debugOptions.onTrigger;\n }\n var ref = {\n // some libs rely on the presence effect for checking computed refs\n // from normal refs, but the implementation doesn't matter\n effect: watcher,\n get value() {\n if (watcher) {\n if (watcher.dirty) {\n watcher.evaluate();\n }\n if (Dep.target) {\n if (process.env.NODE_ENV !== 'production' && Dep.target.onTrack) {\n Dep.target.onTrack({\n effect: Dep.target,\n target: ref,\n type: \"get\" /* TrackOpTypes.GET */,\n key: 'value'\n });\n }\n watcher.depend();\n }\n return watcher.value;\n }\n else {\n return getter();\n }\n },\n set value(newVal) {\n setter(newVal);\n }\n };\n def(ref, RefFlag, true);\n def(ref, \"__v_isReadonly\" /* ReactiveFlags.IS_READONLY */, onlyGetter);\n return ref;\n}\n\nvar WATCHER = \"watcher\";\nvar WATCHER_CB = \"\".concat(WATCHER, \" callback\");\nvar WATCHER_GETTER = \"\".concat(WATCHER, \" getter\");\nvar WATCHER_CLEANUP = \"\".concat(WATCHER, \" cleanup\");\n// Simple effect.\nfunction watchEffect(effect, options) {\n return doWatch(effect, null, options);\n}\nfunction watchPostEffect(effect, options) {\n return doWatch(effect, null, (process.env.NODE_ENV !== 'production'\n ? __assign(__assign({}, options), { flush: 'post' }) : { flush: 'post' }));\n}\nfunction watchSyncEffect(effect, options) {\n return doWatch(effect, null, (process.env.NODE_ENV !== 'production'\n ? __assign(__assign({}, options), { flush: 'sync' }) : { flush: 'sync' }));\n}\n// initial value for watchers to trigger on undefined initial values\nvar INITIAL_WATCHER_VALUE = {};\n// implementation\nfunction watch(source, cb, options) {\n if (process.env.NODE_ENV !== 'production' && typeof cb !== 'function') {\n warn(\"`watch(fn, options?)` signature has been moved to a separate API. \" +\n \"Use `watchEffect(fn, options?)` instead. `watch` now only \" +\n \"supports `watch(source, cb, options?) signature.\");\n }\n return doWatch(source, cb, options);\n}\nfunction doWatch(source, cb, _a) {\n var _b = _a === void 0 ? emptyObject : _a, immediate = _b.immediate, deep = _b.deep, _c = _b.flush, flush = _c === void 0 ? 'pre' : _c, onTrack = _b.onTrack, onTrigger = _b.onTrigger;\n if (process.env.NODE_ENV !== 'production' && !cb) {\n if (immediate !== undefined) {\n warn(\"watch() \\\"immediate\\\" option is only respected when using the \" +\n \"watch(source, callback, options?) signature.\");\n }\n if (deep !== undefined) {\n warn(\"watch() \\\"deep\\\" option is only respected when using the \" +\n \"watch(source, callback, options?) signature.\");\n }\n }\n var warnInvalidSource = function (s) {\n warn(\"Invalid watch source: \".concat(s, \". A watch source can only be a getter/effect \") +\n \"function, a ref, a reactive object, or an array of these types.\");\n };\n var instance = currentInstance;\n var call = function (fn, type, args) {\n if (args === void 0) { args = null; }\n return invokeWithErrorHandling(fn, null, args, instance, type);\n };\n var getter;\n var forceTrigger = false;\n var isMultiSource = false;\n if (isRef(source)) {\n getter = function () { return source.value; };\n forceTrigger = isShallow(source);\n }\n else if (isReactive(source)) {\n getter = function () {\n source.__ob__.dep.depend();\n return source;\n };\n deep = true;\n }\n else if (isArray(source)) {\n isMultiSource = true;\n forceTrigger = source.some(function (s) { return isReactive(s) || isShallow(s); });\n getter = function () {\n return source.map(function (s) {\n if (isRef(s)) {\n return s.value;\n }\n else if (isReactive(s)) {\n return traverse(s);\n }\n else if (isFunction(s)) {\n return call(s, WATCHER_GETTER);\n }\n else {\n process.env.NODE_ENV !== 'production' && warnInvalidSource(s);\n }\n });\n };\n }\n else if (isFunction(source)) {\n if (cb) {\n // getter with cb\n getter = function () { return call(source, WATCHER_GETTER); };\n }\n else {\n // no cb -> simple effect\n getter = function () {\n if (instance && instance._isDestroyed) {\n return;\n }\n if (cleanup) {\n cleanup();\n }\n return call(source, WATCHER, [onCleanup]);\n };\n }\n }\n else {\n getter = noop;\n process.env.NODE_ENV !== 'production' && warnInvalidSource(source);\n }\n if (cb && deep) {\n var baseGetter_1 = getter;\n getter = function () { return traverse(baseGetter_1()); };\n }\n var cleanup;\n var onCleanup = function (fn) {\n cleanup = watcher.onStop = function () {\n call(fn, WATCHER_CLEANUP);\n };\n };\n // in SSR there is no need to setup an actual effect, and it should be noop\n // unless it's eager\n if (isServerRendering()) {\n // we will also not call the invalidate callback (+ runner is not set up)\n onCleanup = noop;\n if (!cb) {\n getter();\n }\n else if (immediate) {\n call(cb, WATCHER_CB, [\n getter(),\n isMultiSource ? [] : undefined,\n onCleanup\n ]);\n }\n return noop;\n }\n var watcher = new Watcher(currentInstance, getter, noop, {\n lazy: true\n });\n watcher.noRecurse = !cb;\n var oldValue = isMultiSource ? [] : INITIAL_WATCHER_VALUE;\n // overwrite default run\n watcher.run = function () {\n if (!watcher.active) {\n return;\n }\n if (cb) {\n // watch(source, cb)\n var newValue = watcher.get();\n if (deep ||\n forceTrigger ||\n (isMultiSource\n ? newValue.some(function (v, i) {\n return hasChanged(v, oldValue[i]);\n })\n : hasChanged(newValue, oldValue))) {\n // cleanup before running cb again\n if (cleanup) {\n cleanup();\n }\n call(cb, WATCHER_CB, [\n newValue,\n // pass undefined as the old value when it's changed for the first time\n oldValue === INITIAL_WATCHER_VALUE ? undefined : oldValue,\n onCleanup\n ]);\n oldValue = newValue;\n }\n }\n else {\n // watchEffect\n watcher.get();\n }\n };\n if (flush === 'sync') {\n watcher.update = watcher.run;\n }\n else if (flush === 'post') {\n watcher.post = true;\n watcher.update = function () { return queueWatcher(watcher); };\n }\n else {\n // pre\n watcher.update = function () {\n if (instance && instance === currentInstance && !instance._isMounted) {\n // pre-watcher triggered before\n var buffer = instance._preWatchers || (instance._preWatchers = []);\n if (buffer.indexOf(watcher) < 0)\n buffer.push(watcher);\n }\n else {\n queueWatcher(watcher);\n }\n };\n }\n if (process.env.NODE_ENV !== 'production') {\n watcher.onTrack = onTrack;\n watcher.onTrigger = onTrigger;\n }\n // initial run\n if (cb) {\n if (immediate) {\n watcher.run();\n }\n else {\n oldValue = watcher.get();\n }\n }\n else if (flush === 'post' && instance) {\n instance.$once('hook:mounted', function () { return watcher.get(); });\n }\n else {\n watcher.get();\n }\n return function () {\n watcher.teardown();\n };\n}\n\nvar activeEffectScope;\nvar EffectScope = /** @class */ (function () {\n function EffectScope(detached) {\n if (detached === void 0) { detached = false; }\n this.detached = detached;\n /**\n * @internal\n */\n this.active = true;\n /**\n * @internal\n */\n this.effects = [];\n /**\n * @internal\n */\n this.cleanups = [];\n this.parent = activeEffectScope;\n if (!detached && activeEffectScope) {\n this.index =\n (activeEffectScope.scopes || (activeEffectScope.scopes = [])).push(this) - 1;\n }\n }\n EffectScope.prototype.run = function (fn) {\n if (this.active) {\n var currentEffectScope = activeEffectScope;\n try {\n activeEffectScope = this;\n return fn();\n }\n finally {\n activeEffectScope = currentEffectScope;\n }\n }\n else if (process.env.NODE_ENV !== 'production') {\n warn(\"cannot run an inactive effect scope.\");\n }\n };\n /**\n * This should only be called on non-detached scopes\n * @internal\n */\n EffectScope.prototype.on = function () {\n activeEffectScope = this;\n };\n /**\n * This should only be called on non-detached scopes\n * @internal\n */\n EffectScope.prototype.off = function () {\n activeEffectScope = this.parent;\n };\n EffectScope.prototype.stop = function (fromParent) {\n if (this.active) {\n var i = void 0, l = void 0;\n for (i = 0, l = this.effects.length; i < l; i++) {\n this.effects[i].teardown();\n }\n for (i = 0, l = this.cleanups.length; i < l; i++) {\n this.cleanups[i]();\n }\n if (this.scopes) {\n for (i = 0, l = this.scopes.length; i < l; i++) {\n this.scopes[i].stop(true);\n }\n }\n // nested scope, dereference from parent to avoid memory leaks\n if (!this.detached && this.parent && !fromParent) {\n // optimized O(1) removal\n var last = this.parent.scopes.pop();\n if (last && last !== this) {\n this.parent.scopes[this.index] = last;\n last.index = this.index;\n }\n }\n this.parent = undefined;\n this.active = false;\n }\n };\n return EffectScope;\n}());\nfunction effectScope(detached) {\n return new EffectScope(detached);\n}\n/**\n * @internal\n */\nfunction recordEffectScope(effect, scope) {\n if (scope === void 0) { scope = activeEffectScope; }\n if (scope && scope.active) {\n scope.effects.push(effect);\n }\n}\nfunction getCurrentScope() {\n return activeEffectScope;\n}\nfunction onScopeDispose(fn) {\n if (activeEffectScope) {\n activeEffectScope.cleanups.push(fn);\n }\n else if (process.env.NODE_ENV !== 'production') {\n warn(\"onScopeDispose() is called when there is no active effect scope\" +\n \" to be associated with.\");\n }\n}\n\nfunction provide(key, value) {\n if (!currentInstance) {\n if (process.env.NODE_ENV !== 'production') {\n warn(\"provide() can only be used inside setup().\");\n }\n }\n else {\n // TS doesn't allow symbol as index type\n resolveProvided(currentInstance)[key] = value;\n }\n}\nfunction resolveProvided(vm) {\n // by default an instance inherits its parent's provides object\n // but when it needs to provide values of its own, it creates its\n // own provides object using parent provides object as prototype.\n // this way in `inject` we can simply look up injections from direct\n // parent and let the prototype chain do the work.\n var existing = vm._provided;\n var parentProvides = vm.$parent && vm.$parent._provided;\n if (parentProvides === existing) {\n return (vm._provided = Object.create(parentProvides));\n }\n else {\n return existing;\n }\n}\nfunction inject(key, defaultValue, treatDefaultAsFactory) {\n if (treatDefaultAsFactory === void 0) { treatDefaultAsFactory = false; }\n // fallback to `currentRenderingInstance` so that this can be called in\n // a functional component\n var instance = currentInstance;\n if (instance) {\n // #2400\n // to support `app.use` plugins,\n // fallback to appContext's `provides` if the instance is at root\n var provides = instance.$parent && instance.$parent._provided;\n if (provides && key in provides) {\n // TS doesn't allow symbol as index type\n return provides[key];\n }\n else if (arguments.length > 1) {\n return treatDefaultAsFactory && isFunction(defaultValue)\n ? defaultValue.call(instance)\n : defaultValue;\n }\n else if (process.env.NODE_ENV !== 'production') {\n warn(\"injection \\\"\".concat(String(key), \"\\\" not found.\"));\n }\n }\n else if (process.env.NODE_ENV !== 'production') {\n warn(\"inject() can only be used inside setup() or functional components.\");\n }\n}\n\nvar normalizeEvent = cached(function (name) {\n var passive = name.charAt(0) === '&';\n name = passive ? name.slice(1) : name;\n var once = name.charAt(0) === '~'; // Prefixed last, checked first\n name = once ? name.slice(1) : name;\n var capture = name.charAt(0) === '!';\n name = capture ? name.slice(1) : name;\n return {\n name: name,\n once: once,\n capture: capture,\n passive: passive\n };\n});\nfunction createFnInvoker(fns, vm) {\n function invoker() {\n var fns = invoker.fns;\n if (isArray(fns)) {\n var cloned = fns.slice();\n for (var i = 0; i < cloned.length; i++) {\n invokeWithErrorHandling(cloned[i], null, arguments, vm, \"v-on handler\");\n }\n }\n else {\n // return handler return value for single handlers\n return invokeWithErrorHandling(fns, null, arguments, vm, \"v-on handler\");\n }\n }\n invoker.fns = fns;\n return invoker;\n}\nfunction updateListeners(on, oldOn, add, remove, createOnceHandler, vm) {\n var name, cur, old, event;\n for (name in on) {\n cur = on[name];\n old = oldOn[name];\n event = normalizeEvent(name);\n if (isUndef(cur)) {\n process.env.NODE_ENV !== 'production' &&\n warn(\"Invalid handler for event \\\"\".concat(event.name, \"\\\": got \") + String(cur), vm);\n }\n else if (isUndef(old)) {\n if (isUndef(cur.fns)) {\n cur = on[name] = createFnInvoker(cur, vm);\n }\n if (isTrue(event.once)) {\n cur = on[name] = createOnceHandler(event.name, cur, event.capture);\n }\n add(event.name, cur, event.capture, event.passive, event.params);\n }\n else if (cur !== old) {\n old.fns = cur;\n on[name] = old;\n }\n }\n for (name in oldOn) {\n if (isUndef(on[name])) {\n event = normalizeEvent(name);\n remove(event.name, oldOn[name], event.capture);\n }\n }\n}\n\nfunction mergeVNodeHook(def, hookKey, hook) {\n if (def instanceof VNode) {\n def = def.data.hook || (def.data.hook = {});\n }\n var invoker;\n var oldHook = def[hookKey];\n function wrappedHook() {\n hook.apply(this, arguments);\n // important: remove merged hook to ensure it's called only once\n // and prevent memory leak\n remove$2(invoker.fns, wrappedHook);\n }\n if (isUndef(oldHook)) {\n // no existing hook\n invoker = createFnInvoker([wrappedHook]);\n }\n else {\n /* istanbul ignore if */\n if (isDef(oldHook.fns) && isTrue(oldHook.merged)) {\n // already a merged invoker\n invoker = oldHook;\n invoker.fns.push(wrappedHook);\n }\n else {\n // existing plain hook\n invoker = createFnInvoker([oldHook, wrappedHook]);\n }\n }\n invoker.merged = true;\n def[hookKey] = invoker;\n}\n\nfunction extractPropsFromVNodeData(data, Ctor, tag) {\n // we are only extracting raw values here.\n // validation and default values are handled in the child\n // component itself.\n var propOptions = Ctor.options.props;\n if (isUndef(propOptions)) {\n return;\n }\n var res = {};\n var attrs = data.attrs, props = data.props;\n if (isDef(attrs) || isDef(props)) {\n for (var key in propOptions) {\n var altKey = hyphenate(key);\n if (process.env.NODE_ENV !== 'production') {\n var keyInLowerCase = key.toLowerCase();\n if (key !== keyInLowerCase && attrs && hasOwn(attrs, keyInLowerCase)) {\n tip(\"Prop \\\"\".concat(keyInLowerCase, \"\\\" is passed to component \") +\n \"\".concat(formatComponentName(\n // @ts-expect-error tag is string\n tag || Ctor), \", but the declared prop name is\") +\n \" \\\"\".concat(key, \"\\\". \") +\n \"Note that HTML attributes are case-insensitive and camelCased \" +\n \"props need to use their kebab-case equivalents when using in-DOM \" +\n \"templates. You should probably use \\\"\".concat(altKey, \"\\\" instead of \\\"\").concat(key, \"\\\".\"));\n }\n }\n checkProp(res, props, key, altKey, true) ||\n checkProp(res, attrs, key, altKey, false);\n }\n }\n return res;\n}\nfunction checkProp(res, hash, key, altKey, preserve) {\n if (isDef(hash)) {\n if (hasOwn(hash, key)) {\n res[key] = hash[key];\n if (!preserve) {\n delete hash[key];\n }\n return true;\n }\n else if (hasOwn(hash, altKey)) {\n res[key] = hash[altKey];\n if (!preserve) {\n delete hash[altKey];\n }\n return true;\n }\n }\n return false;\n}\n\n// The template compiler attempts to minimize the need for normalization by\n// statically analyzing the template at compile time.\n//\n// For plain HTML markup, normalization can be completely skipped because the\n// generated render function is guaranteed to return Array. There are\n// two cases where extra normalization is needed:\n// 1. When the children contains components - because a functional component\n// may return an Array instead of a single root. In this case, just a simple\n// normalization is needed - if any child is an Array, we flatten the whole\n// thing with Array.prototype.concat. It is guaranteed to be only 1-level deep\n// because functional components already normalize their own children.\nfunction simpleNormalizeChildren(children) {\n for (var i = 0; i < children.length; i++) {\n if (isArray(children[i])) {\n return Array.prototype.concat.apply([], children);\n }\n }\n return children;\n}\n// 2. When the children contains constructs that always generated nested Arrays,\n// e.g. \n\n\n","\n\n\n\n\n","\n\n\n\n\n","\n\n\n\n\n","\n\n\n\n\n","\n\n\n\n\n","\n\n\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 */\nfunction baseSlice(array, start, end) {\n var index = -1,\n length = array.length;\n\n if (start < 0) {\n start = -start > length ? 0 : (length + start);\n }\n end = end > length ? length : end;\n if (end < 0) {\n end += length;\n }\n length = start > end ? 0 : ((end - start) >>> 0);\n start >>>= 0;\n\n var result = Array(length);\n while (++index < length) {\n result[index] = array[index + start];\n }\n return result;\n}\n\nexport default baseSlice;\n","import baseSlice from './_baseSlice.js';\n\n/**\n * Casts `array` to a slice if it's needed.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {number} start The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the cast slice.\n */\nfunction castSlice(array, start, end) {\n var length = array.length;\n end = end === undefined ? length : end;\n return (!start && end >= length) ? array : baseSlice(array, start, end);\n}\n\nexport default castSlice;\n","/** Used to compose unicode character classes. */\nvar rsAstralRange = '\\\\ud800-\\\\udfff',\n rsComboMarksRange = '\\\\u0300-\\\\u036f',\n reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n rsVarRange = '\\\\ufe0e\\\\ufe0f';\n\n/** Used to compose unicode capture groups. */\nvar rsZWJ = '\\\\u200d';\n\n/** Used to detect strings with [zero-width joiners or code points from the astral planes](http://eev.ee/blog/2015/09/12/dark-corners-of-unicode/). */\nvar reHasUnicode = RegExp('[' + rsZWJ + rsAstralRange + rsComboRange + rsVarRange + ']');\n\n/**\n * Checks if `string` contains Unicode symbols.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {boolean} Returns `true` if a symbol is found, else `false`.\n */\nfunction hasUnicode(string) {\n return reHasUnicode.test(string);\n}\n\nexport default hasUnicode;\n","import baseGetTag from './_baseGetTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar regexpTag = '[object RegExp]';\n\n/**\n * The base implementation of `_.isRegExp` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a regexp, else `false`.\n */\nfunction baseIsRegExp(value) {\n return isObjectLike(value) && baseGetTag(value) == regexpTag;\n}\n\nexport default baseIsRegExp;\n","import baseIsRegExp from './_baseIsRegExp.js';\nimport baseUnary from './_baseUnary.js';\nimport nodeUtil from './_nodeUtil.js';\n\n/* Node.js helper references. */\nvar nodeIsRegExp = nodeUtil && nodeUtil.isRegExp;\n\n/**\n * Checks if `value` is classified as a `RegExp` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a regexp, else `false`.\n * @example\n *\n * _.isRegExp(/abc/);\n * // => true\n *\n * _.isRegExp('/abc/');\n * // => false\n */\nvar isRegExp = nodeIsRegExp ? baseUnary(nodeIsRegExp) : baseIsRegExp;\n\nexport default isRegExp;\n","/**\n * The base implementation of `_.property` without support for deep paths.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\nfunction baseProperty(key) {\n return function(object) {\n return object == null ? undefined : object[key];\n };\n}\n\nexport default baseProperty;\n","import baseProperty from './_baseProperty.js';\n\n/**\n * Gets the size of an ASCII `string`.\n *\n * @private\n * @param {string} string The string inspect.\n * @returns {number} Returns the string size.\n */\nvar asciiSize = baseProperty('length');\n\nexport default asciiSize;\n","/** Used to compose unicode character classes. */\nvar rsAstralRange = '\\\\ud800-\\\\udfff',\n rsComboMarksRange = '\\\\u0300-\\\\u036f',\n reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n rsVarRange = '\\\\ufe0e\\\\ufe0f';\n\n/** Used to compose unicode capture groups. */\nvar rsAstral = '[' + rsAstralRange + ']',\n rsCombo = '[' + rsComboRange + ']',\n rsFitz = '\\\\ud83c[\\\\udffb-\\\\udfff]',\n rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')',\n rsNonAstral = '[^' + rsAstralRange + ']',\n rsRegional = '(?:\\\\ud83c[\\\\udde6-\\\\uddff]){2}',\n rsSurrPair = '[\\\\ud800-\\\\udbff][\\\\udc00-\\\\udfff]',\n rsZWJ = '\\\\u200d';\n\n/** Used to compose unicode regexes. */\nvar reOptMod = rsModifier + '?',\n rsOptVar = '[' + rsVarRange + ']?',\n rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*',\n rsSeq = rsOptVar + reOptMod + rsOptJoin,\n rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')';\n\n/** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */\nvar reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g');\n\n/**\n * Gets the size of a Unicode `string`.\n *\n * @private\n * @param {string} string The string inspect.\n * @returns {number} Returns the string size.\n */\nfunction unicodeSize(string) {\n var result = reUnicode.lastIndex = 0;\n while (reUnicode.test(string)) {\n ++result;\n }\n return result;\n}\n\nexport default unicodeSize;\n","import asciiSize from './_asciiSize.js';\nimport hasUnicode from './_hasUnicode.js';\nimport unicodeSize from './_unicodeSize.js';\n\n/**\n * Gets the number of symbols in `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the string size.\n */\nfunction stringSize(string) {\n return hasUnicode(string)\n ? unicodeSize(string)\n : asciiSize(string);\n}\n\nexport default stringSize;\n","/**\n * Converts an ASCII `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\nfunction asciiToArray(string) {\n return string.split('');\n}\n\nexport default asciiToArray;\n","/** Used to compose unicode character classes. */\nvar rsAstralRange = '\\\\ud800-\\\\udfff',\n rsComboMarksRange = '\\\\u0300-\\\\u036f',\n reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n rsVarRange = '\\\\ufe0e\\\\ufe0f';\n\n/** Used to compose unicode capture groups. */\nvar rsAstral = '[' + rsAstralRange + ']',\n rsCombo = '[' + rsComboRange + ']',\n rsFitz = '\\\\ud83c[\\\\udffb-\\\\udfff]',\n rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')',\n rsNonAstral = '[^' + rsAstralRange + ']',\n rsRegional = '(?:\\\\ud83c[\\\\udde6-\\\\uddff]){2}',\n rsSurrPair = '[\\\\ud800-\\\\udbff][\\\\udc00-\\\\udfff]',\n rsZWJ = '\\\\u200d';\n\n/** Used to compose unicode regexes. */\nvar reOptMod = rsModifier + '?',\n rsOptVar = '[' + rsVarRange + ']?',\n rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*',\n rsSeq = rsOptVar + reOptMod + rsOptJoin,\n rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')';\n\n/** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */\nvar reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g');\n\n/**\n * Converts a Unicode `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\nfunction unicodeToArray(string) {\n return string.match(reUnicode) || [];\n}\n\nexport default unicodeToArray;\n","import asciiToArray from './_asciiToArray.js';\nimport hasUnicode from './_hasUnicode.js';\nimport unicodeToArray from './_unicodeToArray.js';\n\n/**\n * Converts `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\nfunction stringToArray(string) {\n return hasUnicode(string)\n ? unicodeToArray(string)\n : asciiToArray(string);\n}\n\nexport default stringToArray;\n","/** Used to match a single whitespace character. */\nvar reWhitespace = /\\s/;\n\n/**\n * Used by `_.trim` and `_.trimEnd` to get the index of the last non-whitespace\n * character of `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the index of the last non-whitespace character.\n */\nfunction trimmedEndIndex(string) {\n var index = string.length;\n\n while (index-- && reWhitespace.test(string.charAt(index))) {}\n return index;\n}\n\nexport default trimmedEndIndex;\n","import trimmedEndIndex from './_trimmedEndIndex.js';\n\n/** Used to match leading whitespace. */\nvar reTrimStart = /^\\s+/;\n\n/**\n * The base implementation of `_.trim`.\n *\n * @private\n * @param {string} string The string to trim.\n * @returns {string} Returns the trimmed string.\n */\nfunction baseTrim(string) {\n return string\n ? string.slice(0, trimmedEndIndex(string) + 1).replace(reTrimStart, '')\n : string;\n}\n\nexport default baseTrim;\n","import baseTrim from './_baseTrim.js';\nimport isObject from './isObject.js';\nimport isSymbol from './isSymbol.js';\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\nfunction toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n if (isObject(value)) {\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n value = isObject(other) ? (other + '') : other;\n }\n if (typeof value != 'string') {\n return value === 0 ? value : +value;\n }\n value = baseTrim(value);\n var isBinary = reIsBinary.test(value);\n return (isBinary || reIsOctal.test(value))\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nexport default toNumber;\n","import toNumber from './toNumber.js';\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0,\n MAX_INTEGER = 1.7976931348623157e+308;\n\n/**\n * Converts `value` to a finite number.\n *\n * @static\n * @memberOf _\n * @since 4.12.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted number.\n * @example\n *\n * _.toFinite(3.2);\n * // => 3.2\n *\n * _.toFinite(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toFinite(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toFinite('3.2');\n * // => 3.2\n */\nfunction toFinite(value) {\n if (!value) {\n return value === 0 ? value : 0;\n }\n value = toNumber(value);\n if (value === INFINITY || value === -INFINITY) {\n var sign = (value < 0 ? -1 : 1);\n return sign * MAX_INTEGER;\n }\n return value === value ? value : 0;\n}\n\nexport default toFinite;\n","import toFinite from './toFinite.js';\n\n/**\n * Converts `value` to an integer.\n *\n * **Note:** This method is loosely based on\n * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toInteger(3.2);\n * // => 3\n *\n * _.toInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toInteger(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toInteger('3.2');\n * // => 3\n */\nfunction toInteger(value) {\n var result = toFinite(value),\n remainder = result % 1;\n\n return result === result ? (remainder ? result - remainder : result) : 0;\n}\n\nexport default toInteger;\n","import baseToString from './_baseToString.js';\nimport castSlice from './_castSlice.js';\nimport hasUnicode from './_hasUnicode.js';\nimport isObject from './isObject.js';\nimport isRegExp from './isRegExp.js';\nimport stringSize from './_stringSize.js';\nimport stringToArray from './_stringToArray.js';\nimport toInteger from './toInteger.js';\nimport toString from './toString.js';\n\n/** Used as default options for `_.truncate`. */\nvar DEFAULT_TRUNC_LENGTH = 30,\n DEFAULT_TRUNC_OMISSION = '...';\n\n/** Used to match `RegExp` flags from their coerced string values. */\nvar reFlags = /\\w*$/;\n\n/**\n * Truncates `string` if it's longer than the given maximum string length.\n * The last characters of the truncated string are replaced with the omission\n * string which defaults to \"...\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to truncate.\n * @param {Object} [options={}] The options object.\n * @param {number} [options.length=30] The maximum string length.\n * @param {string} [options.omission='...'] The string to indicate text is omitted.\n * @param {RegExp|string} [options.separator] The separator pattern to truncate to.\n * @returns {string} Returns the truncated string.\n * @example\n *\n * _.truncate('hi-diddly-ho there, neighborino');\n * // => 'hi-diddly-ho there, neighbo...'\n *\n * _.truncate('hi-diddly-ho there, neighborino', {\n * 'length': 24,\n * 'separator': ' '\n * });\n * // => 'hi-diddly-ho there,...'\n *\n * _.truncate('hi-diddly-ho there, neighborino', {\n * 'length': 24,\n * 'separator': /,? +/\n * });\n * // => 'hi-diddly-ho there...'\n *\n * _.truncate('hi-diddly-ho there, neighborino', {\n * 'omission': ' [...]'\n * });\n * // => 'hi-diddly-ho there, neig [...]'\n */\nfunction truncate(string, options) {\n var length = DEFAULT_TRUNC_LENGTH,\n omission = DEFAULT_TRUNC_OMISSION;\n\n if (isObject(options)) {\n var separator = 'separator' in options ? options.separator : separator;\n length = 'length' in options ? toInteger(options.length) : length;\n omission = 'omission' in options ? baseToString(options.omission) : omission;\n }\n string = toString(string);\n\n var strLength = string.length;\n if (hasUnicode(string)) {\n var strSymbols = stringToArray(string);\n strLength = strSymbols.length;\n }\n if (length >= strLength) {\n return string;\n }\n var end = length - stringSize(omission);\n if (end < 1) {\n return omission;\n }\n var result = strSymbols\n ? castSlice(strSymbols, 0, end).join('')\n : string.slice(0, end);\n\n if (separator === undefined) {\n return result + omission;\n }\n if (strSymbols) {\n end += (result.length - end);\n }\n if (isRegExp(separator)) {\n if (string.slice(end).search(separator)) {\n var match,\n substring = result;\n\n if (!separator.global) {\n separator = RegExp(separator.source, toString(reFlags.exec(separator)) + 'g');\n }\n separator.lastIndex = 0;\n while ((match = separator.exec(substring))) {\n var newEnd = match.index;\n }\n result = result.slice(0, newEnd === undefined ? end : newEnd);\n }\n } else if (string.indexOf(baseToString(separator), end) != end) {\n var index = result.lastIndexOf(separator);\n if (index > -1) {\n result = result.slice(0, index);\n }\n }\n return result + omission;\n}\n\nexport default truncate;\n","\n\n\n\n\n","\n\n\n\n\n","\n\n\n\n\n","\n\n\n","\n\n\n\n\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class AnnualProductionEntry extends ModelObject {\n\n /**\n * Estimate of Beer Production Figure over the next calendar year. Typically equal to last calendar year's actual production figure, unless good reason to believe otherwise.\n */\n public annualBeerProductionLitres: number = 0;\n private _annualEthanolProductionLitres: number | null = null;\n /**\n * Annual Ethanol Production figure for use in duty calculations. For UK this is the actual production in the previous year (year to 31st Jan), or the estimate of production for the current year if that is above the small production limit (450000 Litres in 2023)..\n */\n public get annualEthanolProductionLitres(): number | null { return this._annualEthanolProductionLitres }\n public set annualEthanolProductionLitres(value: number | null) {\n this._annualEthanolProductionLitres = value === undefined ? null : value;\n }\n /**\n * Date from which this production figure should be used for duty calculations.\n */\n public effectiveDate: LocalDate = LocalDate.ofEpochDay(0);\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.annualBeerProductionLitres = jsonSerializedObject.annualBeerProductionLitres;\n this.annualEthanolProductionLitres = jsonSerializedObject.annualEthanolProductionLitres == null ? null : jsonSerializedObject.annualEthanolProductionLitres;\n this.effectiveDate = LocalDate.parse(jsonSerializedObject.effectiveDate);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.annualBeerProductionLitres = this.annualBeerProductionLitres;\n toRet.annualEthanolProductionLitres = this.annualEthanolProductionLitres == null ? null : this.annualEthanolProductionLitres;\n toRet.effectiveDate = this.effectiveDate.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class SupplierManufacturerReadOnly extends ModelObject {\n\n /**\n * Identifies if this Manufacturer is the tenant themselves.\n */\n public isTenant: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.isTenant = jsonSerializedObject.isTenant;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.isTenant = this.isTenant;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class SupplierManufacturerContactReadOnly extends ModelObject {\n\n /**\n * SupplierManufacturer Id\n */\n public supplierManufacturerId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.supplierManufacturerId = Guid.fromString(jsonSerializedObject.supplierManufacturerId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.supplierManufacturerId = this.supplierManufacturerId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"supplierManufacturerId\", rule: (v: any) => !v.isEmpty() || \"SupplierManufacturerContactReadOnly.SupplierManufacturerId cannot be empty\"},\n ];\n}\n\n\nexport class SupplierManufacturerContact extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Salutation\n * Not Nullable\n * Max Length : 1000\n */\n public salutation: string = \"\";\n /**\n * Forename\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public forename: string = \"\";\n /**\n * Surname\n * Not Nullable\n * Max Length : 1000\n */\n public surname: string = \"\";\n /**\n * JobTitle\n * Not Nullable\n * Max Length : 1000\n */\n public jobTitle: string = \"\";\n /**\n * Email Address\n * Not Nullable\n * Max Length : 1000\n */\n public emailAddress: string = \"\";\n /**\n * Telephone number\n * Not Nullable\n * Max Length : 1000\n */\n public phoneNumber: string = \"\";\n /**\n * Phone Extension\n * Not Nullable\n * Max Length : 1000\n */\n public phoneExtension: string = \"\";\n /**\n * Mobile Phone Number\n * Not Nullable\n * Max Length : 1000\n */\n public mobileNumber: string = \"\";\n /**\n * Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n public readOnly: SupplierManufacturerContactReadOnly = new SupplierManufacturerContactReadOnly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.salutation = jsonSerializedObject.salutation;\n this.forename = jsonSerializedObject.forename;\n this.surname = jsonSerializedObject.surname;\n this.jobTitle = jsonSerializedObject.jobTitle;\n this.emailAddress = jsonSerializedObject.emailAddress;\n this.phoneNumber = jsonSerializedObject.phoneNumber;\n this.phoneExtension = jsonSerializedObject.phoneExtension;\n this.mobileNumber = jsonSerializedObject.mobileNumber;\n this.notes = jsonSerializedObject.notes;\n this.readOnly = new SupplierManufacturerContactReadOnly(jsonSerializedObject.readOnly);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.salutation = this.salutation;\n toRet.forename = this.forename;\n toRet.surname = this.surname;\n toRet.jobTitle = this.jobTitle;\n toRet.emailAddress = this.emailAddress;\n toRet.phoneNumber = this.phoneNumber;\n toRet.phoneExtension = this.phoneExtension;\n toRet.mobileNumber = this.mobileNumber;\n toRet.notes = this.notes;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"SupplierManufacturerContact.Id cannot be empty\"},\n {field: \"salutation\", rule: (v: any) => v == null || v.length <= 1000 || \"Salutation has too many characters (1000)\"},\n {field: \"forename\", rule: (v: any) => v == null || v.length !== 0 || \"Forename cannot be empty\"},\n {field: \"forename\", rule: (v: any) => v == null || v.length <= 1000 || \"Forename has too many characters (1000)\"},\n {field: \"surname\", rule: (v: any) => v == null || v.length <= 1000 || \"Surname has too many characters (1000)\"},\n {field: \"jobTitle\", rule: (v: any) => v == null || v.length <= 1000 || \"JobTitle has too many characters (1000)\"},\n {field: \"emailAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"EmailAddress has too many characters (1000)\"},\n {field: \"phoneNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"PhoneNumber has too many characters (1000)\"},\n {field: \"phoneExtension\", rule: (v: any) => v == null || v.length <= 1000 || \"PhoneExtension has too many characters (1000)\"},\n {field: \"mobileNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"MobileNumber has too many characters (1000)\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class SupplierManufacturer extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Address\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine1: string = \"\";\n /**\n * Address\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine2: string = \"\";\n /**\n * Address\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine3: string = \"\";\n /**\n * Address\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine4: string = \"\";\n /**\n * Address\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine5: string = \"\";\n /**\n * Address\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine6: string = \"\";\n /**\n * Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public businessName: string = \"\";\n /**\n * Code. Used for linking to external systems such as accounts package. Can not be changed after creation.\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public code: string = \"\";\n /**\n * Contact Name\n * Not Nullable\n * Max Length : 1000\n */\n public contactName: string = \"\";\n /**\n * Email\n * Not Nullable\n * Max Length : 1000\n */\n public emailAddress: string = \"\";\n /**\n * Is this a Manufacturer?\n */\n public isManufacturer: boolean = false;\n /**\n * Is this a Supplier?\n */\n public isSupplier: boolean = false;\n /**\n * Mobile Number\n * Not Nullable\n * Max Length : 1000\n */\n public mobileNumber: string = \"\";\n /**\n * Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n /**\n * Telephone No\n * Not Nullable\n * Max Length : 1000\n */\n public phoneNumber: string = \"\";\n /**\n * Post Code\n * Not Nullable\n * Max Length : 1000\n */\n public postcode: string = \"\";\n private _vatCodeId: Guid | null = null;\n /**\n * Standard Vat Code Id\n */\n public get vatCodeId(): Guid | null { return this._vatCodeId }\n public set vatCodeId(value: Guid | null) {\n this._vatCodeId = value === undefined ? null : value;\n }\n /**\n * VAT Registration Code\n * Not Nullable\n * Max Length : 1000\n */\n public vatReg: string = \"\";\n public annualProduction: AnnualProductionEntry[] = [];\n public readOnly: SupplierManufacturerReadOnly = new SupplierManufacturerReadOnly();\n public isHidden: boolean = false;\n /**\n * AWRS Number\n * Not Nullable\n * Max Length : 1000\n */\n public awrsNumber: string = \"\";\n /**\n * International Bank Account Number\n * Not Nullable\n * Max Length : 1000\n */\n public iban: string = \"\";\n /**\n * Bank Identification Code\n * Not Nullable\n * Max Length : 1000\n */\n public bic: string = \"\";\n /**\n * Default delivery price to add to purchase orders for this supplier.\n */\n public defaultPoDeliveryCharge: number = 0;\n private _purchaseOrderTemplateId: Guid | null = null;\n /**\n * Purchase order document template set to this supplier.\n */\n public get purchaseOrderTemplateId(): Guid | null { return this._purchaseOrderTemplateId }\n public set purchaseOrderTemplateId(value: Guid | null) {\n this._purchaseOrderTemplateId = value === undefined ? null : value;\n }\n public webAddress: string = \"\";\n /**\n * Identifies if this supplier is approved\n */\n public isApproved: boolean = false;\n private _lastApprovedDate: LocalDate | null = null;\n /**\n * Last approved date for this supplier\n */\n public get lastApprovedDate(): LocalDate | null { return this._lastApprovedDate }\n public set lastApprovedDate(value: LocalDate | null) {\n this._lastApprovedDate = value === undefined ? null : value;\n }\n public contacts: SupplierManufacturerContact[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.addressLine1 = jsonSerializedObject.addressLine1;\n this.addressLine2 = jsonSerializedObject.addressLine2;\n this.addressLine3 = jsonSerializedObject.addressLine3;\n this.addressLine4 = jsonSerializedObject.addressLine4;\n this.addressLine5 = jsonSerializedObject.addressLine5;\n this.addressLine6 = jsonSerializedObject.addressLine6;\n this.businessName = jsonSerializedObject.businessName;\n this.code = jsonSerializedObject.code;\n this.contactName = jsonSerializedObject.contactName;\n this.emailAddress = jsonSerializedObject.emailAddress;\n this.isManufacturer = jsonSerializedObject.isManufacturer;\n this.isSupplier = jsonSerializedObject.isSupplier;\n this.mobileNumber = jsonSerializedObject.mobileNumber;\n this.notes = jsonSerializedObject.notes;\n this.phoneNumber = jsonSerializedObject.phoneNumber;\n this.postcode = jsonSerializedObject.postcode;\n this.vatCodeId = jsonSerializedObject.vatCodeId == null ? null : Guid.fromString(jsonSerializedObject.vatCodeId);\n this.vatReg = jsonSerializedObject.vatReg;\n this.annualProduction = jsonSerializedObject.annualProduction.map((v: any) => new AnnualProductionEntry(v));\n this.readOnly = new SupplierManufacturerReadOnly(jsonSerializedObject.readOnly);\n this.isHidden = jsonSerializedObject.isHidden;\n this.awrsNumber = jsonSerializedObject.awrsNumber;\n this.iban = jsonSerializedObject.iban;\n this.bic = jsonSerializedObject.bic;\n this.defaultPoDeliveryCharge = jsonSerializedObject.defaultPoDeliveryCharge;\n this.purchaseOrderTemplateId = jsonSerializedObject.purchaseOrderTemplateId == null ? null : Guid.fromString(jsonSerializedObject.purchaseOrderTemplateId);\n this.webAddress = jsonSerializedObject.webAddress;\n this.isApproved = jsonSerializedObject.isApproved;\n this.lastApprovedDate = jsonSerializedObject.lastApprovedDate == null ? null : LocalDate.parse(jsonSerializedObject.lastApprovedDate);\n this.contacts = jsonSerializedObject.contacts.map((v: any) => new SupplierManufacturerContact(v));\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.addressLine1 = this.addressLine1;\n toRet.addressLine2 = this.addressLine2;\n toRet.addressLine3 = this.addressLine3;\n toRet.addressLine4 = this.addressLine4;\n toRet.addressLine5 = this.addressLine5;\n toRet.addressLine6 = this.addressLine6;\n toRet.businessName = this.businessName;\n toRet.code = this.code;\n toRet.contactName = this.contactName;\n toRet.emailAddress = this.emailAddress;\n toRet.isManufacturer = this.isManufacturer;\n toRet.isSupplier = this.isSupplier;\n toRet.mobileNumber = this.mobileNumber;\n toRet.notes = this.notes;\n toRet.phoneNumber = this.phoneNumber;\n toRet.postcode = this.postcode;\n toRet.vatCodeId = this.vatCodeId == null ? null : this.vatCodeId.toString();\n toRet.vatReg = this.vatReg;\n toRet.annualProduction = this.annualProduction.map(v => v.toJsonSerializedObject());\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.isHidden = this.isHidden;\n toRet.awrsNumber = this.awrsNumber;\n toRet.iban = this.iban;\n toRet.bic = this.bic;\n toRet.defaultPoDeliveryCharge = this.defaultPoDeliveryCharge;\n toRet.purchaseOrderTemplateId = this.purchaseOrderTemplateId == null ? null : this.purchaseOrderTemplateId.toString();\n toRet.webAddress = this.webAddress;\n toRet.isApproved = this.isApproved;\n toRet.lastApprovedDate = this.lastApprovedDate == null ? null : this.lastApprovedDate.toString();\n toRet.contacts = this.contacts.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"SupplierManufacturer.Id cannot be empty\"},\n {field: \"addressLine1\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine1 has too many characters (1000)\"},\n {field: \"addressLine2\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine2 has too many characters (1000)\"},\n {field: \"addressLine3\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine3 has too many characters (1000)\"},\n {field: \"addressLine4\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine4 has too many characters (1000)\"},\n {field: \"addressLine5\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine5 has too many characters (1000)\"},\n {field: \"addressLine6\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine6 has too many characters (1000)\"},\n {field: \"businessName\", rule: (v: any) => v == null || v.length !== 0 || \"BusinessName cannot be empty\"},\n {field: \"businessName\", rule: (v: any) => v == null || v.length <= 1000 || \"BusinessName has too many characters (1000)\"},\n {field: \"code\", rule: (v: any) => v == null || v.length !== 0 || \"Code cannot be empty\"},\n {field: \"code\", rule: (v: any) => v == null || v.length <= 1000 || \"Code has too many characters (1000)\"},\n {field: \"contactName\", rule: (v: any) => v == null || v.length <= 1000 || \"ContactName has too many characters (1000)\"},\n {field: \"emailAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"EmailAddress has too many characters (1000)\"},\n {field: \"mobileNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"MobileNumber has too many characters (1000)\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"phoneNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"PhoneNumber has too many characters (1000)\"},\n {field: \"postcode\", rule: (v: any) => v == null || v.length <= 1000 || \"Postcode has too many characters (1000)\"},\n {field: \"vatCodeId\", rule: (v: any) => v == null || !v.isEmpty() || \"SupplierManufacturer.VatCodeId cannot be empty\"},\n {field: \"vatReg\", rule: (v: any) => v == null || v.length <= 1000 || \"VatReg has too many characters (1000)\"},\n {field: \"annualProduction\", rule: (v: any) => !!v || \"annualProduction is required\"},\n {field: \"annualProduction\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AnnualProductionEntry[]).reduce((acc: Array, curr: AnnualProductionEntry) => acc.concat(curr.validate()), new Array());\n }},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"awrsNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"AwrsNumber has too many characters (1000)\"},\n {field: \"iban\", rule: (v: any) => v == null || v.length <= 1000 || \"Iban has too many characters (1000)\"},\n {field: \"bic\", rule: (v: any) => v == null || v.length <= 1000 || \"Bic has too many characters (1000)\"},\n {field: \"purchaseOrderTemplateId\", rule: (v: any) => v == null || !v.isEmpty() || \"SupplierManufacturer.PurchaseOrderTemplateId cannot be empty\"},\n {field: \"webAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"WebAddress has too many characters (1000)\"},\n {field: \"contacts\", rule: (v: any) => !!v || \"contacts is required\"},\n {field: \"contacts\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as SupplierManufacturerContact[]).reduce((acc: Array, curr: SupplierManufacturerContact) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SupplierManufacturerSummary extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public businessName: string = \"\";\n /**\n * Code. Used for linking to external systems such as accounts package. Can not be changed after creation.\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public code: string = \"\";\n /**\n * Identifies if this Manufacturer is the tenant themselves.\n */\n public isTenant: boolean = false;\n /**\n * Is this a Supplier?\n */\n public isSupplier: boolean = false;\n /**\n * Is this a Manufacturer?\n */\n public isManufacturer: boolean = false;\n /**\n * Contact Name\n * Not Nullable\n * Max Length : 1000\n */\n public contactName: string = \"\";\n /**\n * Telephone No\n * Not Nullable\n * Max Length : 1000\n */\n public phoneNumber: string = \"\";\n public isHidden: boolean = false;\n /**\n * Default delivery price to add to purchase orders for this supplier.\n */\n public defaultPoDeliveryCharge: number = 0;\n public webAddress: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.businessName = jsonSerializedObject.businessName;\n this.code = jsonSerializedObject.code;\n this.isTenant = jsonSerializedObject.isTenant;\n this.isSupplier = jsonSerializedObject.isSupplier;\n this.isManufacturer = jsonSerializedObject.isManufacturer;\n this.contactName = jsonSerializedObject.contactName;\n this.phoneNumber = jsonSerializedObject.phoneNumber;\n this.isHidden = jsonSerializedObject.isHidden;\n this.defaultPoDeliveryCharge = jsonSerializedObject.defaultPoDeliveryCharge;\n this.webAddress = jsonSerializedObject.webAddress;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.businessName = this.businessName;\n toRet.code = this.code;\n toRet.isTenant = this.isTenant;\n toRet.isSupplier = this.isSupplier;\n toRet.isManufacturer = this.isManufacturer;\n toRet.contactName = this.contactName;\n toRet.phoneNumber = this.phoneNumber;\n toRet.isHidden = this.isHidden;\n toRet.defaultPoDeliveryCharge = this.defaultPoDeliveryCharge;\n toRet.webAddress = this.webAddress;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"SupplierManufacturerSummary.Id cannot be empty\"},\n {field: \"businessName\", rule: (v: any) => v == null || v.length !== 0 || \"BusinessName cannot be empty\"},\n {field: \"businessName\", rule: (v: any) => v == null || v.length <= 1000 || \"BusinessName has too many characters (1000)\"},\n {field: \"code\", rule: (v: any) => v == null || v.length !== 0 || \"Code cannot be empty\"},\n {field: \"code\", rule: (v: any) => v == null || v.length <= 1000 || \"Code has too many characters (1000)\"},\n {field: \"contactName\", rule: (v: any) => v == null || v.length <= 1000 || \"ContactName has too many characters (1000)\"},\n {field: \"phoneNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"PhoneNumber has too many characters (1000)\"},\n {field: \"webAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"WebAddress has too many characters (1000)\"},\n ];\n}\n\n\nexport class GetAllSupplierManufacturersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllSupplierManufacturersResponse extends ModelObject {\n\n public supplierManufacturers: SupplierManufacturer[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.supplierManufacturers = jsonSerializedObject.supplierManufacturers.map((v: any) => new SupplierManufacturer(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.supplierManufacturers = this.supplierManufacturers.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"supplierManufacturers\", rule: (v: any) => !!v || \"supplierManufacturers is required\"},\n {field: \"supplierManufacturers\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as SupplierManufacturer[]).reduce((acc: Array, curr: SupplierManufacturer) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetSupplierManufacturerRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public supplierManufacturerId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.supplierManufacturerId = Guid.fromString(jsonSerializedObject.supplierManufacturerId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.supplierManufacturerId = this.supplierManufacturerId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"supplierManufacturerId\", rule: (v: any) => !v.isEmpty() || \".SupplierManufacturerId cannot be empty\"},\n ];\n}\n\n\nexport class GetSupplierManufacturerResponse extends ModelObject {\n\n public supplierManufacturer: SupplierManufacturer = new SupplierManufacturer();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.supplierManufacturer = new SupplierManufacturer(jsonSerializedObject.supplierManufacturer);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.supplierManufacturer = this.supplierManufacturer.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"supplierManufacturer\", rule: (v: any) => !!v || \"supplierManufacturer is required\"},\n {field: \"supplierManufacturer\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetSupplierManufacturersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public supplierManufacturerIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.supplierManufacturerIds = jsonSerializedObject.supplierManufacturerIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.supplierManufacturerIds = this.supplierManufacturerIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetSupplierManufacturersResponse extends ModelObject {\n\n public supplierManufacturers: SupplierManufacturer[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.supplierManufacturers = jsonSerializedObject.supplierManufacturers.map((v: any) => new SupplierManufacturer(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.supplierManufacturers = this.supplierManufacturers.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"supplierManufacturers\", rule: (v: any) => !!v || \"supplierManufacturers is required\"},\n {field: \"supplierManufacturers\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as SupplierManufacturer[]).reduce((acc: Array, curr: SupplierManufacturer) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveSupplierManufacturerRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public supplierManufacturer: SupplierManufacturer = new SupplierManufacturer();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.supplierManufacturer = new SupplierManufacturer(jsonSerializedObject.supplierManufacturer);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.supplierManufacturer = this.supplierManufacturer.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"supplierManufacturer\", rule: (v: any) => !!v || \"supplierManufacturer is required\"},\n {field: \"supplierManufacturer\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetSupplierManufacturerIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public supplierManufacturerId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.supplierManufacturerId = Guid.fromString(jsonSerializedObject.supplierManufacturerId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.supplierManufacturerId = this.supplierManufacturerId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"supplierManufacturerId\", rule: (v: any) => !v.isEmpty() || \".SupplierManufacturerId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllSupplierManufacturerSummariesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllSupplierManufacturerSummariesResponse extends ModelObject {\n\n public supplierManufacturerSummaries: SupplierManufacturerSummary[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.supplierManufacturerSummaries = jsonSerializedObject.supplierManufacturerSummaries.map((v: any) => new SupplierManufacturerSummary(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.supplierManufacturerSummaries = this.supplierManufacturerSummaries.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"supplierManufacturerSummaries\", rule: (v: any) => !!v || \"supplierManufacturerSummaries is required\"},\n {field: \"supplierManufacturerSummaries\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as SupplierManufacturerSummary[]).reduce((acc: Array, curr: SupplierManufacturerSummary) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GenerateSupplierManufacturerCodeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public supplierManufacturerName: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.supplierManufacturerName = jsonSerializedObject.supplierManufacturerName;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.supplierManufacturerName = this.supplierManufacturerName;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"supplierManufacturerName\", rule: (v: any) => v == null || v.length !== 0 || \"SupplierManufacturerName cannot be empty\"},\n ];\n}\n\n\nexport class GenerateSupplierManufacturerCodeResponse extends ModelObject {\n\n /**\n * Code. Used for linking to external systems such as accounts package. Can not be changed after creation.\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public code: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.code = jsonSerializedObject.code;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.code = this.code;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"code\", rule: (v: any) => v == null || v.length !== 0 || \"Code cannot be empty\"},\n {field: \"code\", rule: (v: any) => v == null || v.length <= 1000 || \"Code has too many characters (1000)\"},\n ];\n}\n\n\nexport class SupplierManufacturerService extends ServiceBase {\n\n public async getAllSupplierManufacturers(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllSupplierManufacturersRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllSupplierManufacturersResponse(response).supplierManufacturers;\n return this.makeJsonRequest(\"supplierManufacturer/v1/getAllSupplierManufacturers\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getSupplierManufacturer(tenantId: Guid, supplierManufacturerId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetSupplierManufacturerRequest();\n req.tenantId = tenantId;\n req.supplierManufacturerId = supplierManufacturerId;\n const extractor = (response:any) => new GetSupplierManufacturerResponse(response).supplierManufacturer;\n return this.makeJsonRequest(\"supplierManufacturer/v1/getSupplierManufacturer\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getSupplierManufacturers(tenantId: Guid, supplierManufacturerIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetSupplierManufacturersRequest();\n req.tenantId = tenantId;\n req.supplierManufacturerIds = supplierManufacturerIds;\n const extractor = (response:any) => new GetSupplierManufacturersResponse(response).supplierManufacturers;\n return this.makeJsonRequest(\"supplierManufacturer/v1/getSupplierManufacturers\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveSupplierManufacturer(tenantId: Guid, supplierManufacturer: SupplierManufacturer, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveSupplierManufacturerRequest();\n req.tenantId = tenantId;\n req.supplierManufacturer = supplierManufacturer;\n const extractor = null;\n return this.makeJsonRequest(\"supplierManufacturer/v1/saveSupplierManufacturer\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setSupplierManufacturerIsHidden(tenantId: Guid, supplierManufacturerId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetSupplierManufacturerIsHiddenRequest();\n req.tenantId = tenantId;\n req.supplierManufacturerId = supplierManufacturerId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"supplierManufacturer/v1/setSupplierManufacturerIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllSupplierManufacturerSummaries(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllSupplierManufacturerSummariesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllSupplierManufacturerSummariesResponse(response).supplierManufacturerSummaries;\n return this.makeJsonRequest(\"supplierManufacturer/v1/getAllSupplierManufacturerSummaries\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async generateSupplierManufacturerCode(tenantId: Guid, supplierManufacturerName: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GenerateSupplierManufacturerCodeRequest();\n req.tenantId = tenantId;\n req.supplierManufacturerName = supplierManufacturerName;\n const extractor = (response:any) => new GenerateSupplierManufacturerCodeResponse(response).code;\n return this.makeJsonRequest(\"supplierManufacturer/v1/generateSupplierManufacturerCode\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const supplierManufacturerService = new SupplierManufacturerService();","import type { SupplierManufacturer } from \"@/app/services/generated/suppliermanufacturerService\";\nimport { SupplierManufacturerService } from \"@/app/services/generated/suppliermanufacturerService\";\nimport type BaseEnumType from \"@/app/services/baseEnumType\";\nimport type Guid from \"@/app/types/common/guid\";\n\nexport default class SupplierManufacturerServiceExtended extends SupplierManufacturerService {\n public async getAllSupplierManufacturersByBusinessType(\n tenantId: Guid,\n businessType: EnumBusinessType\n ): Promise {\n const supplierManufacturers = await super.getAllSupplierManufacturers(\n tenantId\n );\n return supplierManufacturers.filter((supplierManufacturer) =>\n businessType.isBusinessTypeOf(supplierManufacturer)\n );\n }\n}\n\nexport class EnumBusinessType implements BaseEnumType {\n private static allValues: EnumBusinessType[] = []; // make sure this is top-most\n\n public static none = new EnumBusinessType(\n 0,\n \"None\",\n \"enum_business_type_none\",\n () => false\n );\n public static supplier = new EnumBusinessType(\n 1,\n \"Supplier\",\n \"enum_business_type_supplier\",\n (supplierManufacturer: Readonly) =>\n supplierManufacturer.isSupplier\n );\n public static manufacturer = new EnumBusinessType(\n 2,\n \"Manufacturer\",\n \"enum_business_type_manufacturer\",\n (supplierManufacturer: Readonly) =>\n supplierManufacturer.isManufacturer\n );\n public static supplierAndManufacturer = new EnumBusinessType(\n 3,\n \"SupplierAndManufacturer\",\n \"enum_business_type_supplier_and_manufacturer\",\n (supplierManufacturer: Readonly) =>\n supplierManufacturer.isSupplier || supplierManufacturer.isManufacturer\n );\n\n public key: number;\n public value: string;\n public translationKey?: string;\n private readonly supplierMatch: (\n supplierManufacturer: Readonly\n ) => boolean;\n\n private constructor(\n key: number,\n value: string,\n translationKey: string,\n supplierMatch: (\n supplierManufacturer: Readonly\n ) => boolean\n ) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n this.supplierMatch = supplierMatch;\n\n EnumBusinessType.allValues.push(this);\n }\n\n public static getValues(): EnumBusinessType[] {\n return EnumBusinessType.allValues;\n }\n\n public isBusinessTypeOf(\n supplierManufacturer: Readonly\n ): boolean {\n return this.supplierMatch(supplierManufacturer);\n }\n\n public static getByKey(key: number): EnumBusinessType {\n const found = EnumBusinessType.allValues.find((e) => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumBusinessType - Key not found: ${key}`);\n }\n\n return found;\n }\n\n public includesSupplier() {\n return (\n this.key === EnumBusinessType.supplier.key ||\n this.key === EnumBusinessType.supplierAndManufacturer.key\n );\n }\n\n public includesManufacturer() {\n return (\n this.key === EnumBusinessType.manufacturer.key ||\n this.key === EnumBusinessType.supplierAndManufacturer.key\n );\n }\n\n public static fromBooleans(\n isSupplier: boolean,\n isManufacturer: boolean\n ): EnumBusinessType {\n if (isManufacturer) {\n return isSupplier\n ? EnumBusinessType.supplierAndManufacturer\n : EnumBusinessType.manufacturer;\n }\n return isSupplier ? EnumBusinessType.supplier : EnumBusinessType.none;\n }\n}\n\nexport const supplierManufacturerService =\n new SupplierManufacturerServiceExtended();\n","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumAccountPostingLineType implements BaseEnumType {\n private static allValues: EnumAccountPostingLineType[] = []; // make sure this is top-most\n \n public static order = new EnumAccountPostingLineType(0, \"Order\", \"enum_account_posting_line_type_order\");\n public static credit = new EnumAccountPostingLineType(1, \"Credit\", \"enum_account_posting_line_type_credit\");\n public static outlet = new EnumAccountPostingLineType(2, \"Outlet\", \"enum_account_posting_line_type_outlet\");\n public static stockItem = new EnumAccountPostingLineType(3, \"StockItem\", \"enum_account_posting_line_type_stock_item\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumAccountPostingLineType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isOrder() { return this === EnumAccountPostingLineType.order; }\n public isCredit() { return this === EnumAccountPostingLineType.credit; }\n public isOutlet() { return this === EnumAccountPostingLineType.outlet; }\n public isStockItem() { return this === EnumAccountPostingLineType.stockItem; }\n\n public static getValues(): readonly EnumAccountPostingLineType[] {\n return EnumAccountPostingLineType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumAccountPostingLineType[] {\n return EnumAccountPostingLineType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumAccountPostingLineType {\n const found = EnumAccountPostingLineType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumAccountPostingLineType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumAccountPostingLineType): EnumAccountPostingLineType {\n const found = name ? EnumAccountPostingLineType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumAccountPostingLineType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumAccountPostingStatus implements BaseEnumType {\n private static allValues: EnumAccountPostingStatus[] = []; // make sure this is top-most\n \n public static inProgress = new EnumAccountPostingStatus(0, \"InProgress\", \"enum_account_posting_status_in_progress\");\n public static successful = new EnumAccountPostingStatus(1, \"Successful\", \"enum_account_posting_status_successful\");\n public static errored = new EnumAccountPostingStatus(2, \"Errored\", \"enum_account_posting_status_errored\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumAccountPostingStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isInProgress() { return this === EnumAccountPostingStatus.inProgress; }\n public isSuccessful() { return this === EnumAccountPostingStatus.successful; }\n public isErrored() { return this === EnumAccountPostingStatus.errored; }\n\n public static getValues(): readonly EnumAccountPostingStatus[] {\n return EnumAccountPostingStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumAccountPostingStatus[] {\n return EnumAccountPostingStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumAccountPostingStatus {\n const found = EnumAccountPostingStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumAccountPostingStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumAccountPostingStatus): EnumAccountPostingStatus {\n const found = name ? EnumAccountPostingStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumAccountPostingStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumAccountsPackageType implements BaseEnumType {\n private static allValues: EnumAccountsPackageType[] = []; // make sure this is top-most\n \n public static none = new EnumAccountsPackageType(0, \"None\", \"enum_accounts_package_type_none\");\n public static xero = new EnumAccountsPackageType(1, \"Xero\", \"enum_accounts_package_type_xero\");\n public static quickBooksLive = new EnumAccountsPackageType(2, \"QuickBooksLive\", \"enum_accounts_package_type_quick_books_live\");\n public static quickBooksSandbox = new EnumAccountsPackageType(3, \"QuickBooksSandbox\", \"enum_accounts_package_type_quick_books_sandbox\");\n public static sageOne = new EnumAccountsPackageType(4, \"SageOne\", \"enum_accounts_package_type_sage_one\");\n public static sage50 = new EnumAccountsPackageType(5, \"Sage50\", \"enum_accounts_package_type_sage50\");\n public static sage200 = new EnumAccountsPackageType(6, \"Sage200\", \"enum_accounts_package_type_sage200\");\n public static brewmanApi = new EnumAccountsPackageType(7, \"BrewmanApi\", \"enum_accounts_package_type_brewman_api\");\n public static customCsv = new EnumAccountsPackageType(8, \"CustomCsv\", \"enum_accounts_package_type_custom_csv\");\n public static greenTree = new EnumAccountsPackageType(9, \"GreenTree\", \"enum_accounts_package_type_green_tree\");\n public static sage200Web = new EnumAccountsPackageType(10, \"Sage200Web\", \"enum_accounts_package_type_sage200_web\");\n public static lexoffice = new EnumAccountsPackageType(11, \"Lexoffice\", \"enum_accounts_package_type_lexoffice\");\n public static fortnox = new EnumAccountsPackageType(12, \"Fortnox\", \"enum_accounts_package_type_fortnox\");\n public static sageOneZa = new EnumAccountsPackageType(13, \"SageOneZa\", \"enum_accounts_package_type_sage_one_za\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumAccountsPackageType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumAccountsPackageType.none; }\n public isXero() { return this === EnumAccountsPackageType.xero; }\n public isQuickBooksLive() { return this === EnumAccountsPackageType.quickBooksLive; }\n public isQuickBooksSandbox() { return this === EnumAccountsPackageType.quickBooksSandbox; }\n public isSageOne() { return this === EnumAccountsPackageType.sageOne; }\n public isSage50() { return this === EnumAccountsPackageType.sage50; }\n public isSage200() { return this === EnumAccountsPackageType.sage200; }\n public isBrewmanApi() { return this === EnumAccountsPackageType.brewmanApi; }\n public isCustomCsv() { return this === EnumAccountsPackageType.customCsv; }\n public isGreenTree() { return this === EnumAccountsPackageType.greenTree; }\n public isSage200Web() { return this === EnumAccountsPackageType.sage200Web; }\n public isLexoffice() { return this === EnumAccountsPackageType.lexoffice; }\n public isFortnox() { return this === EnumAccountsPackageType.fortnox; }\n public isSageOneZa() { return this === EnumAccountsPackageType.sageOneZa; }\n\n public static getValues(): readonly EnumAccountsPackageType[] {\n return EnumAccountsPackageType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumAccountsPackageType[] {\n return EnumAccountsPackageType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumAccountsPackageType {\n const found = EnumAccountsPackageType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumAccountsPackageType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumAccountsPackageType): EnumAccountsPackageType {\n const found = name ? EnumAccountsPackageType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumAccountsPackageType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumActivityLogType implements BaseEnumType {\n private static allValues: EnumActivityLogType[] = []; // make sure this is top-most\n \n public static none = new EnumActivityLogType(0, \"None\", \"enum_activity_log_type_none\");\n public static orderCreated = new EnumActivityLogType(1, \"OrderCreated\", \"enum_activity_log_type_order_created\");\n public static orderCancelled = new EnumActivityLogType(2, \"OrderCancelled\", \"enum_activity_log_type_order_cancelled\");\n public static orderCompleted = new EnumActivityLogType(3, \"OrderCompleted\", \"enum_activity_log_type_order_completed\");\n public static creditCreated = new EnumActivityLogType(4, \"CreditCreated\", \"enum_activity_log_type_credit_created\");\n public static creditCancelled = new EnumActivityLogType(5, \"CreditCancelled\", \"enum_activity_log_type_credit_cancelled\");\n public static creditCompleted = new EnumActivityLogType(6, \"CreditCompleted\", \"enum_activity_log_type_credit_completed\");\n public static taskCreated = new EnumActivityLogType(7, \"TaskCreated\", \"enum_activity_log_type_task_created\");\n public static taskCancelled = new EnumActivityLogType(8, \"TaskCancelled\", \"enum_activity_log_type_task_cancelled\");\n public static taskCompleted = new EnumActivityLogType(9, \"TaskCompleted\", \"enum_activity_log_type_task_completed\");\n public static communication = new EnumActivityLogType(10, \"Communication\", \"enum_activity_log_type_communication\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumActivityLogType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumActivityLogType.none; }\n public isOrderCreated() { return this === EnumActivityLogType.orderCreated; }\n public isOrderCancelled() { return this === EnumActivityLogType.orderCancelled; }\n public isOrderCompleted() { return this === EnumActivityLogType.orderCompleted; }\n public isCreditCreated() { return this === EnumActivityLogType.creditCreated; }\n public isCreditCancelled() { return this === EnumActivityLogType.creditCancelled; }\n public isCreditCompleted() { return this === EnumActivityLogType.creditCompleted; }\n public isTaskCreated() { return this === EnumActivityLogType.taskCreated; }\n public isTaskCancelled() { return this === EnumActivityLogType.taskCancelled; }\n public isTaskCompleted() { return this === EnumActivityLogType.taskCompleted; }\n public isCommunication() { return this === EnumActivityLogType.communication; }\n\n public static getValues(): readonly EnumActivityLogType[] {\n return EnumActivityLogType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumActivityLogType[] {\n return EnumActivityLogType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumActivityLogType {\n const found = EnumActivityLogType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumActivityLogType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumActivityLogType): EnumActivityLogType {\n const found = name ? EnumActivityLogType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumActivityLogType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumAggregatingOperation implements BaseEnumType {\n private static allValues: EnumAggregatingOperation[] = []; // make sure this is top-most\n \n public static none = new EnumAggregatingOperation(0, \"None\", \"enum_aggregating_operation_none\");\n public static sum = new EnumAggregatingOperation(1, \"Sum\", \"enum_aggregating_operation_sum\");\n public static highest = new EnumAggregatingOperation(2, \"Highest\", \"enum_aggregating_operation_highest\");\n public static lowest = new EnumAggregatingOperation(3, \"Lowest\", \"enum_aggregating_operation_lowest\");\n public static average = new EnumAggregatingOperation(4, \"Average\", \"enum_aggregating_operation_average\");\n public static count = new EnumAggregatingOperation(5, \"Count\", \"enum_aggregating_operation_count\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumAggregatingOperation.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumAggregatingOperation.none; }\n public isSum() { return this === EnumAggregatingOperation.sum; }\n public isHighest() { return this === EnumAggregatingOperation.highest; }\n public isLowest() { return this === EnumAggregatingOperation.lowest; }\n public isAverage() { return this === EnumAggregatingOperation.average; }\n public isCount() { return this === EnumAggregatingOperation.count; }\n\n public static getValues(): readonly EnumAggregatingOperation[] {\n return EnumAggregatingOperation.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumAggregatingOperation[] {\n return EnumAggregatingOperation.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumAggregatingOperation {\n const found = EnumAggregatingOperation.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumAggregatingOperation - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumAggregatingOperation): EnumAggregatingOperation {\n const found = name ? EnumAggregatingOperation.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumAggregatingOperation - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumAlcoholType implements BaseEnumType {\n private static allValues: EnumAlcoholType[] = []; // make sure this is top-most\n \n public static none = new EnumAlcoholType(0, \"None\", \"enum_alcohol_type_none\");\n public static beer = new EnumAlcoholType(1, \"Beer\", \"enum_alcohol_type_beer\");\n public static stillCiderPerry = new EnumAlcoholType(2, \"StillCiderPerry\", \"enum_alcohol_type_still_cider_perry\");\n public static sparklingCiderPerry = new EnumAlcoholType(3, \"SparklingCiderPerry\", \"enum_alcohol_type_sparkling_cider_perry\");\n public static stillWine = new EnumAlcoholType(4, \"StillWine\", \"enum_alcohol_type_still_wine\");\n public static sparklingWine = new EnumAlcoholType(5, \"SparklingWine\", \"enum_alcohol_type_sparkling_wine\");\n public static spirits = new EnumAlcoholType(6, \"Spirits\", \"enum_alcohol_type_spirits\");\n public static scotchWhisky = new EnumAlcoholType(7, \"ScotchWhisky\", \"enum_alcohol_type_scotch_whisky\");\n public static irishWhiskey = new EnumAlcoholType(8, \"IrishWhiskey\", \"enum_alcohol_type_irish_whiskey\");\n public static traditionalAfricanBeer = new EnumAlcoholType(9, \"TraditionalAfricanBeer\", \"enum_alcohol_type_traditional_african_beer\");\n public static brandy = new EnumAlcoholType(13, \"Brandy\", \"enum_alcohol_type_brandy\");\n public static spiritsFromGrape = new EnumAlcoholType(14, \"SpiritsFromGrape\", \"enum_alcohol_type_spirits_from_grape\");\n public static whisky = new EnumAlcoholType(15, \"Whisky\", \"enum_alcohol_type_whisky\");\n public static rumAndSugarSpirits = new EnumAlcoholType(16, \"RumAndSugarSpirits\", \"enum_alcohol_type_rum_and_sugar_spirits\");\n public static gin = new EnumAlcoholType(17, \"Gin\", \"enum_alcohol_type_gin\");\n public static vodka = new EnumAlcoholType(18, \"Vodka\", \"enum_alcohol_type_vodka\");\n public static other = new EnumAlcoholType(19, \"Other\", \"enum_alcohol_type_other\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumAlcoholType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumAlcoholType.none; }\n public isBeer() { return this === EnumAlcoholType.beer; }\n public isStillCiderPerry() { return this === EnumAlcoholType.stillCiderPerry; }\n public isSparklingCiderPerry() { return this === EnumAlcoholType.sparklingCiderPerry; }\n public isStillWine() { return this === EnumAlcoholType.stillWine; }\n public isSparklingWine() { return this === EnumAlcoholType.sparklingWine; }\n public isSpirits() { return this === EnumAlcoholType.spirits; }\n public isScotchWhisky() { return this === EnumAlcoholType.scotchWhisky; }\n public isIrishWhiskey() { return this === EnumAlcoholType.irishWhiskey; }\n public isTraditionalAfricanBeer() { return this === EnumAlcoholType.traditionalAfricanBeer; }\n public isBrandy() { return this === EnumAlcoholType.brandy; }\n public isSpiritsFromGrape() { return this === EnumAlcoholType.spiritsFromGrape; }\n public isWhisky() { return this === EnumAlcoholType.whisky; }\n public isRumAndSugarSpirits() { return this === EnumAlcoholType.rumAndSugarSpirits; }\n public isGin() { return this === EnumAlcoholType.gin; }\n public isVodka() { return this === EnumAlcoholType.vodka; }\n public isOther() { return this === EnumAlcoholType.other; }\n\n public static getValues(): readonly EnumAlcoholType[] {\n return EnumAlcoholType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumAlcoholType[] {\n return EnumAlcoholType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumAlcoholType {\n const found = EnumAlcoholType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumAlcoholType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumAlcoholType): EnumAlcoholType {\n const found = name ? EnumAlcoholType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumAlcoholType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumAssemblyIngredientSource implements BaseEnumType {\n private static allValues: EnumAssemblyIngredientSource[] = []; // make sure this is top-most\n \n public static stock = new EnumAssemblyIngredientSource(0, \"Stock\", \"enum_assembly_ingredient_source_stock\");\n public static assembly = new EnumAssemblyIngredientSource(1, \"Assembly\", \"enum_assembly_ingredient_source_assembly\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumAssemblyIngredientSource.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isStock() { return this === EnumAssemblyIngredientSource.stock; }\n public isAssembly() { return this === EnumAssemblyIngredientSource.assembly; }\n\n public static getValues(): readonly EnumAssemblyIngredientSource[] {\n return EnumAssemblyIngredientSource.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumAssemblyIngredientSource[] {\n return EnumAssemblyIngredientSource.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumAssemblyIngredientSource {\n const found = EnumAssemblyIngredientSource.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumAssemblyIngredientSource - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumAssemblyIngredientSource): EnumAssemblyIngredientSource {\n const found = name ? EnumAssemblyIngredientSource.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumAssemblyIngredientSource - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumAssemblyOutputTarget implements BaseEnumType {\n private static allValues: EnumAssemblyOutputTarget[] = []; // make sure this is top-most\n \n public static stock = new EnumAssemblyOutputTarget(0, \"Stock\", \"enum_assembly_output_target_stock\");\n public static assembly = new EnumAssemblyOutputTarget(1, \"Assembly\", \"enum_assembly_output_target_assembly\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumAssemblyOutputTarget.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isStock() { return this === EnumAssemblyOutputTarget.stock; }\n public isAssembly() { return this === EnumAssemblyOutputTarget.assembly; }\n\n public static getValues(): readonly EnumAssemblyOutputTarget[] {\n return EnumAssemblyOutputTarget.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumAssemblyOutputTarget[] {\n return EnumAssemblyOutputTarget.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumAssemblyOutputTarget {\n const found = EnumAssemblyOutputTarget.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumAssemblyOutputTarget - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumAssemblyOutputTarget): EnumAssemblyOutputTarget {\n const found = name ? EnumAssemblyOutputTarget.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumAssemblyOutputTarget - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumAssemblyRecipeType implements BaseEnumType {\n private static allValues: EnumAssemblyRecipeType[] = []; // make sure this is top-most\n \n public static recipe = new EnumAssemblyRecipeType(0, \"Recipe\", \"enum_assembly_recipe_type_recipe\");\n public static packaging = new EnumAssemblyRecipeType(1, \"Packaging\", \"enum_assembly_recipe_type_packaging\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumAssemblyRecipeType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isRecipe() { return this === EnumAssemblyRecipeType.recipe; }\n public isPackaging() { return this === EnumAssemblyRecipeType.packaging; }\n\n public static getValues(): readonly EnumAssemblyRecipeType[] {\n return EnumAssemblyRecipeType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumAssemblyRecipeType[] {\n return EnumAssemblyRecipeType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumAssemblyRecipeType {\n const found = EnumAssemblyRecipeType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumAssemblyRecipeType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumAssemblyRecipeType): EnumAssemblyRecipeType {\n const found = name ? EnumAssemblyRecipeType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumAssemblyRecipeType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumAssemblyStatus implements BaseEnumType {\n private static allValues: EnumAssemblyStatus[] = []; // make sure this is top-most\n \n public static open = new EnumAssemblyStatus(0, \"Open\", \"enum_assembly_status_open\");\n public static inProgress = new EnumAssemblyStatus(1, \"InProgress\", \"enum_assembly_status_in_progress\");\n public static complete = new EnumAssemblyStatus(2, \"Complete\", \"enum_assembly_status_complete\");\n public static cancelled = new EnumAssemblyStatus(3, \"Cancelled\", \"enum_assembly_status_cancelled\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumAssemblyStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isOpen() { return this === EnumAssemblyStatus.open; }\n public isInProgress() { return this === EnumAssemblyStatus.inProgress; }\n public isComplete() { return this === EnumAssemblyStatus.complete; }\n public isCancelled() { return this === EnumAssemblyStatus.cancelled; }\n\n public static getValues(): readonly EnumAssemblyStatus[] {\n return EnumAssemblyStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumAssemblyStatus[] {\n return EnumAssemblyStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumAssemblyStatus {\n const found = EnumAssemblyStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumAssemblyStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumAssemblyStatus): EnumAssemblyStatus {\n const found = name ? EnumAssemblyStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumAssemblyStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumAssemblyType implements BaseEnumType {\n private static allValues: EnumAssemblyType[] = []; // make sure this is top-most\n \n public static materialProduction = new EnumAssemblyType(0, \"MaterialProduction\", \"enum_assembly_type_material_production\");\n public static productPackaging = new EnumAssemblyType(1, \"ProductPackaging\", \"enum_assembly_type_product_packaging\");\n public static maintenance = new EnumAssemblyType(2, \"Maintenance\", \"enum_assembly_type_maintenance\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumAssemblyType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isMaterialProduction() { return this === EnumAssemblyType.materialProduction; }\n public isProductPackaging() { return this === EnumAssemblyType.productPackaging; }\n public isMaintenance() { return this === EnumAssemblyType.maintenance; }\n\n public static getValues(): readonly EnumAssemblyType[] {\n return EnumAssemblyType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumAssemblyType[] {\n return EnumAssemblyType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumAssemblyType {\n const found = EnumAssemblyType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumAssemblyType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumAssemblyType): EnumAssemblyType {\n const found = name ? EnumAssemblyType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumAssemblyType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumAustralianAlcoholTariff implements BaseEnumType {\n private static allValues: EnumAustralianAlcoholTariff[] = []; // make sure this is top-most\n \n public static none = new EnumAustralianAlcoholTariff(0, \"None\", \"enum_australian_alcohol_tariff_none\");\n public static beerAbvUpto3Less8LOrUpto48LNoPump_1_1 = new EnumAustralianAlcoholTariff(101, \"BeerAbvUpto3Less8LOrUpto48LNoPump_1_1\", \"enum_australian_alcohol_tariff_beer_abv_upto3_less8_l_or_upto48_l_no_pump_1_1\");\n public static beerAbvUpto3Over48LOr8LPlusPump_1_2 = new EnumAustralianAlcoholTariff(102, \"BeerAbvUpto3Over48LOr8LPlusPump_1_2\", \"enum_australian_alcohol_tariff_beer_abv_upto3_over48_l_or8_l_plus_pump_1_2\");\n public static beerAbv3To3_5Less8LOrUpto48LNoPump_1_5 = new EnumAustralianAlcoholTariff(105, \"BeerAbv3To3_5Less8LOrUpto48LNoPump_1_5\", \"enum_australian_alcohol_tariff_beer_abv3_to3_5_less8_l_or_upto48_l_no_pump_1_5\");\n public static beerAbv3To3_5Over48LOr8LPlusPump_1_6 = new EnumAustralianAlcoholTariff(106, \"BeerAbv3To3_5Over48LOr8LPlusPump_1_6\", \"enum_australian_alcohol_tariff_beer_abv3_to3_5_over48_l_or8_l_plus_pump_1_6\");\n public static beerAbvOver3_5Less8LOrUpto48LNoPump_1_10 = new EnumAustralianAlcoholTariff(110, \"BeerAbvOver3_5Less8LOrUpto48LNoPump_1_10\", \"enum_australian_alcohol_tariff_beer_abv_over3_5_less8_l_or_upto48_l_no_pump_1_10\");\n public static beerAbvOver3_5Over48LOr8LPlusPump_1_11 = new EnumAustralianAlcoholTariff(111, \"BeerAbvOver3_5Over48LOr8LPlusPump_1_11\", \"enum_australian_alcohol_tariff_beer_abv_over3_5_over48_l_or8_l_plus_pump_1_11\");\n public static beerAbvUpto3NonCommercial_1_15 = new EnumAustralianAlcoholTariff(115, \"BeerAbvUpto3NonCommercial_1_15\", \"enum_australian_alcohol_tariff_beer_abv_upto3_non_commercial_1_15\");\n public static beerAbvOver3NonCommercial_1_16 = new EnumAustralianAlcoholTariff(116, \"BeerAbvOver3NonCommercial_1_16\", \"enum_australian_alcohol_tariff_beer_abv_over3_non_commercial_1_16\");\n public static otherAbvUpto10_2 = new EnumAustralianAlcoholTariff(200, \"OtherAbvUpto10_2\", \"enum_australian_alcohol_tariff_other_abv_upto10_2\");\n public static brandy_3_1 = new EnumAustralianAlcoholTariff(301, \"Brandy_3_1\", \"enum_australian_alcohol_tariff_brandy_3_1\");\n public static otherAbvOver10_3_2 = new EnumAustralianAlcoholTariff(302, \"OtherAbvOver10_3_2\", \"enum_australian_alcohol_tariff_other_abv_over10_3_2\");\n public static spiritsExemptForFortifyingWine_3_5 = new EnumAustralianAlcoholTariff(305, \"SpiritsExemptForFortifyingWine_3_5\", \"enum_australian_alcohol_tariff_spirits_exempt_for_fortifying_wine_3_5\");\n public static spiritsSoldForExemptUsage_3_6 = new EnumAustralianAlcoholTariff(306, \"SpiritsSoldForExemptUsage_3_6\", \"enum_australian_alcohol_tariff_spirits_sold_for_exempt_usage_3_6\");\n public static spiritsForExemptUsage_3_7 = new EnumAustralianAlcoholTariff(307, \"SpiritsForExemptUsage_3_7\", \"enum_australian_alcohol_tariff_spirits_for_exempt_usage_3_7\");\n public static spiritsDenatured_3_8 = new EnumAustralianAlcoholTariff(308, \"SpiritsDenatured_3_8\", \"enum_australian_alcohol_tariff_spirits_denatured_3_8\");\n public static otherSpirits_3_10 = new EnumAustralianAlcoholTariff(310, \"OtherSpirits_3_10\", \"enum_australian_alcohol_tariff_other_spirits_3_10\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumAustralianAlcoholTariff.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumAustralianAlcoholTariff.none; }\n public isBeerAbvUpto3Less8LOrUpto48LNoPump_1_1() { return this === EnumAustralianAlcoholTariff.beerAbvUpto3Less8LOrUpto48LNoPump_1_1; }\n public isBeerAbvUpto3Over48LOr8LPlusPump_1_2() { return this === EnumAustralianAlcoholTariff.beerAbvUpto3Over48LOr8LPlusPump_1_2; }\n public isBeerAbv3To3_5Less8LOrUpto48LNoPump_1_5() { return this === EnumAustralianAlcoholTariff.beerAbv3To3_5Less8LOrUpto48LNoPump_1_5; }\n public isBeerAbv3To3_5Over48LOr8LPlusPump_1_6() { return this === EnumAustralianAlcoholTariff.beerAbv3To3_5Over48LOr8LPlusPump_1_6; }\n public isBeerAbvOver3_5Less8LOrUpto48LNoPump_1_10() { return this === EnumAustralianAlcoholTariff.beerAbvOver3_5Less8LOrUpto48LNoPump_1_10; }\n public isBeerAbvOver3_5Over48LOr8LPlusPump_1_11() { return this === EnumAustralianAlcoholTariff.beerAbvOver3_5Over48LOr8LPlusPump_1_11; }\n public isBeerAbvUpto3NonCommercial_1_15() { return this === EnumAustralianAlcoholTariff.beerAbvUpto3NonCommercial_1_15; }\n public isBeerAbvOver3NonCommercial_1_16() { return this === EnumAustralianAlcoholTariff.beerAbvOver3NonCommercial_1_16; }\n public isOtherAbvUpto10_2() { return this === EnumAustralianAlcoholTariff.otherAbvUpto10_2; }\n public isBrandy_3_1() { return this === EnumAustralianAlcoholTariff.brandy_3_1; }\n public isOtherAbvOver10_3_2() { return this === EnumAustralianAlcoholTariff.otherAbvOver10_3_2; }\n public isSpiritsExemptForFortifyingWine_3_5() { return this === EnumAustralianAlcoholTariff.spiritsExemptForFortifyingWine_3_5; }\n public isSpiritsSoldForExemptUsage_3_6() { return this === EnumAustralianAlcoholTariff.spiritsSoldForExemptUsage_3_6; }\n public isSpiritsForExemptUsage_3_7() { return this === EnumAustralianAlcoholTariff.spiritsForExemptUsage_3_7; }\n public isSpiritsDenatured_3_8() { return this === EnumAustralianAlcoholTariff.spiritsDenatured_3_8; }\n public isOtherSpirits_3_10() { return this === EnumAustralianAlcoholTariff.otherSpirits_3_10; }\n\n public static getValues(): readonly EnumAustralianAlcoholTariff[] {\n return EnumAustralianAlcoholTariff.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumAustralianAlcoholTariff[] {\n return EnumAustralianAlcoholTariff.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumAustralianAlcoholTariff {\n const found = EnumAustralianAlcoholTariff.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumAustralianAlcoholTariff - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumAustralianAlcoholTariff): EnumAustralianAlcoholTariff {\n const found = name ? EnumAustralianAlcoholTariff.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumAustralianAlcoholTariff - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumBeerflexOrderConfirmationStatus implements BaseEnumType {\n private static allValues: EnumBeerflexOrderConfirmationStatus[] = []; // make sure this is top-most\n \n public static none = new EnumBeerflexOrderConfirmationStatus(0, \"None\", \"enum_beerflex_order_confirmation_status_none\");\n public static unconfirmed = new EnumBeerflexOrderConfirmationStatus(1, \"Unconfirmed\", \"enum_beerflex_order_confirmation_status_unconfirmed\");\n public static confirmedDelivered = new EnumBeerflexOrderConfirmationStatus(2, \"ConfirmedDelivered\", \"enum_beerflex_order_confirmation_status_confirmed_delivered\");\n public static confirmedFailed = new EnumBeerflexOrderConfirmationStatus(3, \"ConfirmedFailed\", \"enum_beerflex_order_confirmation_status_confirmed_failed\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumBeerflexOrderConfirmationStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumBeerflexOrderConfirmationStatus.none; }\n public isUnconfirmed() { return this === EnumBeerflexOrderConfirmationStatus.unconfirmed; }\n public isConfirmedDelivered() { return this === EnumBeerflexOrderConfirmationStatus.confirmedDelivered; }\n public isConfirmedFailed() { return this === EnumBeerflexOrderConfirmationStatus.confirmedFailed; }\n\n public static getValues(): readonly EnumBeerflexOrderConfirmationStatus[] {\n return EnumBeerflexOrderConfirmationStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumBeerflexOrderConfirmationStatus[] {\n return EnumBeerflexOrderConfirmationStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumBeerflexOrderConfirmationStatus {\n const found = EnumBeerflexOrderConfirmationStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumBeerflexOrderConfirmationStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumBeerflexOrderConfirmationStatus): EnumBeerflexOrderConfirmationStatus {\n const found = name ? EnumBeerflexOrderConfirmationStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumBeerflexOrderConfirmationStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumBeerflexOrderType implements BaseEnumType {\n private static allValues: EnumBeerflexOrderType[] = []; // make sure this is top-most\n \n public static none = new EnumBeerflexOrderType(0, \"None\", \"enum_beerflex_order_type_none\");\n public static order = new EnumBeerflexOrderType(1, \"Order\", \"enum_beerflex_order_type_order\");\n public static uplift = new EnumBeerflexOrderType(2, \"Uplift\", \"enum_beerflex_order_type_uplift\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumBeerflexOrderType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumBeerflexOrderType.none; }\n public isOrder() { return this === EnumBeerflexOrderType.order; }\n public isUplift() { return this === EnumBeerflexOrderType.uplift; }\n\n public static getValues(): readonly EnumBeerflexOrderType[] {\n return EnumBeerflexOrderType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumBeerflexOrderType[] {\n return EnumBeerflexOrderType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumBeerflexOrderType {\n const found = EnumBeerflexOrderType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumBeerflexOrderType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumBeerflexOrderType): EnumBeerflexOrderType {\n const found = name ? EnumBeerflexOrderType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumBeerflexOrderType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumBmEntityType implements BaseEnumType {\n private static allValues: EnumBmEntityType[] = []; // make sure this is top-most\n \n public static none = new EnumBmEntityType(0, \"None\", \"enum_bm_entity_type_none\");\n public static outlet = new EnumBmEntityType(1, \"Outlet\", \"enum_bm_entity_type_outlet\");\n public static order = new EnumBmEntityType(2, \"Order\", \"enum_bm_entity_type_order\");\n public static credit = new EnumBmEntityType(3, \"Credit\", \"enum_bm_entity_type_credit\");\n public static bmTask = new EnumBmEntityType(4, \"BmTask\", \"enum_bm_entity_type_bm_task\");\n public static communicationLogEntry = new EnumBmEntityType(5, \"CommunicationLogEntry\", \"enum_bm_entity_type_communication_log_entry\");\n public static assembly = new EnumBmEntityType(6, \"Assembly\", \"enum_bm_entity_type_assembly\");\n public static assemblyProcedure = new EnumBmEntityType(7, \"AssemblyProcedure\", \"enum_bm_entity_type_assembly_procedure\");\n public static supplier = new EnumBmEntityType(8, \"Supplier\", \"enum_bm_entity_type_supplier\");\n public static outletGroup = new EnumBmEntityType(9, \"OutletGroup\", \"enum_bm_entity_type_outlet_group\");\n public static purchaseOrder = new EnumBmEntityType(10, \"PurchaseOrder\", \"enum_bm_entity_type_purchase_order\");\n public static product = new EnumBmEntityType(11, \"Product\", \"enum_bm_entity_type_product\");\n public static material = new EnumBmEntityType(12, \"Material\", \"enum_bm_entity_type_material\");\n public static stockTake = new EnumBmEntityType(13, \"StockTake\", \"enum_bm_entity_type_stock_take\");\n public static stockTransfer = new EnumBmEntityType(14, \"StockTransfer\", \"enum_bm_entity_type_stock_transfer\");\n public static stockAdjustment = new EnumBmEntityType(15, \"StockAdjustment\", \"enum_bm_entity_type_stock_adjustment\");\n public static ullage = new EnumBmEntityType(16, \"Ullage\", \"enum_bm_entity_type_ullage\");\n public static priceList = new EnumBmEntityType(17, \"PriceList\", \"enum_bm_entity_type_price_list\");\n public static lead = new EnumBmEntityType(18, \"Lead\", \"enum_bm_entity_type_lead\");\n public static leadCommunicationLogEntry = new EnumBmEntityType(19, \"LeadCommunicationLogEntry\", \"enum_bm_entity_type_lead_communication_log_entry\");\n public static vessel = new EnumBmEntityType(20, \"Vessel\", \"enum_bm_entity_type_vessel\");\n public static pallet = new EnumBmEntityType(21, \"Pallet\", \"enum_bm_entity_type_pallet\");\n public static batch = new EnumBmEntityType(22, \"Batch\", \"enum_bm_entity_type_batch\");\n public static batchProcessInstruction = new EnumBmEntityType(23, \"BatchProcessInstruction\", \"enum_bm_entity_type_batch_process_instruction\");\n public static process = new EnumBmEntityType(24, \"Process\", \"enum_bm_entity_type_process\");\n public static tpSetting = new EnumBmEntityType(25, \"TpSetting\", \"enum_bm_entity_type_tp_setting\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumBmEntityType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumBmEntityType.none; }\n public isOutlet() { return this === EnumBmEntityType.outlet; }\n public isOrder() { return this === EnumBmEntityType.order; }\n public isCredit() { return this === EnumBmEntityType.credit; }\n public isBmTask() { return this === EnumBmEntityType.bmTask; }\n public isCommunicationLogEntry() { return this === EnumBmEntityType.communicationLogEntry; }\n public isAssembly() { return this === EnumBmEntityType.assembly; }\n public isAssemblyProcedure() { return this === EnumBmEntityType.assemblyProcedure; }\n public isSupplier() { return this === EnumBmEntityType.supplier; }\n public isOutletGroup() { return this === EnumBmEntityType.outletGroup; }\n public isPurchaseOrder() { return this === EnumBmEntityType.purchaseOrder; }\n public isProduct() { return this === EnumBmEntityType.product; }\n public isMaterial() { return this === EnumBmEntityType.material; }\n public isStockTake() { return this === EnumBmEntityType.stockTake; }\n public isStockTransfer() { return this === EnumBmEntityType.stockTransfer; }\n public isStockAdjustment() { return this === EnumBmEntityType.stockAdjustment; }\n public isUllage() { return this === EnumBmEntityType.ullage; }\n public isPriceList() { return this === EnumBmEntityType.priceList; }\n public isLead() { return this === EnumBmEntityType.lead; }\n public isLeadCommunicationLogEntry() { return this === EnumBmEntityType.leadCommunicationLogEntry; }\n public isVessel() { return this === EnumBmEntityType.vessel; }\n public isPallet() { return this === EnumBmEntityType.pallet; }\n public isBatch() { return this === EnumBmEntityType.batch; }\n public isBatchProcessInstruction() { return this === EnumBmEntityType.batchProcessInstruction; }\n public isProcess() { return this === EnumBmEntityType.process; }\n public isTpSetting() { return this === EnumBmEntityType.tpSetting; }\n\n public static getValues(): readonly EnumBmEntityType[] {\n return EnumBmEntityType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumBmEntityType[] {\n return EnumBmEntityType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumBmEntityType {\n const found = EnumBmEntityType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumBmEntityType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumBmEntityType): EnumBmEntityType {\n const found = name ? EnumBmEntityType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumBmEntityType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumBottleDepositBalanceChangeReason implements BaseEnumType {\n private static allValues: EnumBottleDepositBalanceChangeReason[] = []; // make sure this is top-most\n \n public static none = new EnumBottleDepositBalanceChangeReason(0, \"None\", \"enum_bottle_deposit_balance_change_reason_none\");\n public static manual = new EnumBottleDepositBalanceChangeReason(1, \"Manual\", \"enum_bottle_deposit_balance_change_reason_manual\");\n public static return = new EnumBottleDepositBalanceChangeReason(2, \"Return\", \"enum_bottle_deposit_balance_change_reason_return\");\n public static redemption = new EnumBottleDepositBalanceChangeReason(3, \"Redemption\", \"enum_bottle_deposit_balance_change_reason_redemption\");\n public static credit = new EnumBottleDepositBalanceChangeReason(4, \"Credit\", \"enum_bottle_deposit_balance_change_reason_credit\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumBottleDepositBalanceChangeReason.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumBottleDepositBalanceChangeReason.none; }\n public isManual() { return this === EnumBottleDepositBalanceChangeReason.manual; }\n public isReturn() { return this === EnumBottleDepositBalanceChangeReason.return; }\n public isRedemption() { return this === EnumBottleDepositBalanceChangeReason.redemption; }\n public isCredit() { return this === EnumBottleDepositBalanceChangeReason.credit; }\n\n public static getValues(): readonly EnumBottleDepositBalanceChangeReason[] {\n return EnumBottleDepositBalanceChangeReason.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumBottleDepositBalanceChangeReason[] {\n return EnumBottleDepositBalanceChangeReason.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumBottleDepositBalanceChangeReason {\n const found = EnumBottleDepositBalanceChangeReason.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumBottleDepositBalanceChangeReason - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumBottleDepositBalanceChangeReason): EnumBottleDepositBalanceChangeReason {\n const found = name ? EnumBottleDepositBalanceChangeReason.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumBottleDepositBalanceChangeReason - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumCacheEntityType implements BaseEnumType {\n private static allValues: EnumCacheEntityType[] = []; // make sure this is top-most\n \n public static none = new EnumCacheEntityType(0, \"None\", \"enum_cache_entity_type_none\");\n public static communicationSubject = new EnumCacheEntityType(1, \"CommunicationSubject\", \"enum_cache_entity_type_communication_subject\");\n public static communicationType = new EnumCacheEntityType(2, \"CommunicationType\", \"enum_cache_entity_type_communication_type\");\n public static courier = new EnumCacheEntityType(3, \"Courier\", \"enum_cache_entity_type_courier\");\n public static creditTerm = new EnumCacheEntityType(4, \"CreditTerm\", \"enum_cache_entity_type_credit_term\");\n public static deliveryArea = new EnumCacheEntityType(5, \"DeliveryArea\", \"enum_cache_entity_type_delivery_area\");\n public static glCode = new EnumCacheEntityType(6, \"GlCode\", \"enum_cache_entity_type_gl_code\");\n public static outletRating = new EnumCacheEntityType(7, \"OutletRating\", \"enum_cache_entity_type_outlet_rating\");\n public static outletType = new EnumCacheEntityType(8, \"OutletType\", \"enum_cache_entity_type_outlet_type\");\n public static packageType = new EnumCacheEntityType(9, \"PackageType\", \"enum_cache_entity_type_package_type\");\n public static pricingCategory = new EnumCacheEntityType(10, \"PricingCategory\", \"enum_cache_entity_type_pricing_category\");\n public static productBrand = new EnumCacheEntityType(11, \"ProductBrand\", \"enum_cache_entity_type_product_brand\");\n public static qcTest = new EnumCacheEntityType(12, \"QcTest\", \"enum_cache_entity_type_qc_test\");\n public static salesArea = new EnumCacheEntityType(13, \"SalesArea\", \"enum_cache_entity_type_sales_area\");\n public static salesCode = new EnumCacheEntityType(14, \"SalesCode\", \"enum_cache_entity_type_sales_code\");\n public static stockGroup = new EnumCacheEntityType(15, \"StockGroup\", \"enum_cache_entity_type_stock_group\");\n public static stockLocation = new EnumCacheEntityType(16, \"StockLocation\", \"enum_cache_entity_type_stock_location\");\n public static taskQueue = new EnumCacheEntityType(17, \"TaskQueue\", \"enum_cache_entity_type_task_queue\");\n public static taskType = new EnumCacheEntityType(18, \"TaskType\", \"enum_cache_entity_type_task_type\");\n public static unitOfMeasure = new EnumCacheEntityType(19, \"UnitOfMeasure\", \"enum_cache_entity_type_unit_of_measure\");\n public static vatCode = new EnumCacheEntityType(20, \"VatCode\", \"enum_cache_entity_type_vat_code\");\n public static vehicle = new EnumCacheEntityType(21, \"Vehicle\", \"enum_cache_entity_type_vehicle\");\n public static vesselMaintenanceProcess = new EnumCacheEntityType(22, \"VesselMaintenanceProcess\", \"enum_cache_entity_type_vessel_maintenance_process\");\n public static vesselType = new EnumCacheEntityType(23, \"VesselType\", \"enum_cache_entity_type_vessel_type\");\n public static vessel = new EnumCacheEntityType(24, \"Vessel\", \"enum_cache_entity_type_vessel\");\n public static leadLossReason = new EnumCacheEntityType(25, \"LeadLossReason\", \"enum_cache_entity_type_lead_loss_reason\");\n public static leadPipelineStage = new EnumCacheEntityType(26, \"LeadPipelineStage\", \"enum_cache_entity_type_lead_pipeline_stage\");\n public static leadSource = new EnumCacheEntityType(27, \"LeadSource\", \"enum_cache_entity_type_lead_source\");\n public static priceList = new EnumCacheEntityType(28, \"PriceList\", \"enum_cache_entity_type_price_list\");\n public static outlet = new EnumCacheEntityType(30, \"Outlet\", \"enum_cache_entity_type_outlet\");\n public static group = new EnumCacheEntityType(31, \"Group\", \"enum_cache_entity_type_group\");\n public static supplierManufacturer = new EnumCacheEntityType(32, \"SupplierManufacturer\", \"enum_cache_entity_type_supplier_manufacturer\");\n public static palletType = new EnumCacheEntityType(33, \"PalletType\", \"enum_cache_entity_type_pallet_type\");\n public static item = new EnumCacheEntityType(34, \"Item\", \"enum_cache_entity_type_item\");\n public static distributionCentre = new EnumCacheEntityType(35, \"DistributionCentre\", \"enum_cache_entity_type_distribution_centre\");\n public static vesselState = new EnumCacheEntityType(36, \"VesselState\", \"enum_cache_entity_type_vessel_state\");\n public static caskType = new EnumCacheEntityType(37, \"CaskType\", \"enum_cache_entity_type_cask_type\");\n public static caskSubType = new EnumCacheEntityType(38, \"CaskSubType\", \"enum_cache_entity_type_cask_sub_type\");\n public static obsolete_CaskLocation = new EnumCacheEntityType(39, \"Obsolete_CaskLocation\", \"enum_cache_entity_type_obsolete__cask_location\");\n public static caskSubLocation = new EnumCacheEntityType(40, \"CaskSubLocation\", \"enum_cache_entity_type_cask_sub_location\");\n public static caskSubSubLocation = new EnumCacheEntityType(41, \"CaskSubSubLocation\", \"enum_cache_entity_type_cask_sub_sub_location\");\n public static taskNotificationSetting = new EnumCacheEntityType(42, \"TaskNotificationSetting\", \"enum_cache_entity_type_task_notification_setting\");\n public static lead = new EnumCacheEntityType(43, \"Lead\", \"enum_cache_entity_type_lead\");\n public static vesselCapability = new EnumCacheEntityType(44, \"VesselCapability\", \"enum_cache_entity_type_vessel_capability\");\n public static orderTypeText = new EnumCacheEntityType(45, \"OrderTypeText\", \"enum_cache_entity_type_order_type_text\");\n public static recipe = new EnumCacheEntityType(46, \"Recipe\", \"enum_cache_entity_type_recipe\");\n public static batchTemplate = new EnumCacheEntityType(47, \"BatchTemplate\", \"enum_cache_entity_type_batch_template\");\n public static tenantSettings = new EnumCacheEntityType(48, \"TenantSettings\", \"enum_cache_entity_type_tenant_settings\");\n public static tenant = new EnumCacheEntityType(49, \"Tenant\", \"enum_cache_entity_type_tenant\");\n public static outletSubType = new EnumCacheEntityType(50, \"OutletSubType\", \"enum_cache_entity_type_outlet_sub_type\");\n public static collectionTime = new EnumCacheEntityType(51, \"CollectionTime\", \"enum_cache_entity_type_collection_time\");\n public static accountsLink = new EnumCacheEntityType(52, \"AccountsLink\", \"enum_cache_entity_type_accounts_link\");\n public static vesselValuation = new EnumCacheEntityType(53, \"VesselValuation\", \"enum_cache_entity_type_vessel_valuation\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumCacheEntityType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumCacheEntityType.none; }\n public isCommunicationSubject() { return this === EnumCacheEntityType.communicationSubject; }\n public isCommunicationType() { return this === EnumCacheEntityType.communicationType; }\n public isCourier() { return this === EnumCacheEntityType.courier; }\n public isCreditTerm() { return this === EnumCacheEntityType.creditTerm; }\n public isDeliveryArea() { return this === EnumCacheEntityType.deliveryArea; }\n public isGlCode() { return this === EnumCacheEntityType.glCode; }\n public isOutletRating() { return this === EnumCacheEntityType.outletRating; }\n public isOutletType() { return this === EnumCacheEntityType.outletType; }\n public isPackageType() { return this === EnumCacheEntityType.packageType; }\n public isPricingCategory() { return this === EnumCacheEntityType.pricingCategory; }\n public isProductBrand() { return this === EnumCacheEntityType.productBrand; }\n public isQcTest() { return this === EnumCacheEntityType.qcTest; }\n public isSalesArea() { return this === EnumCacheEntityType.salesArea; }\n public isSalesCode() { return this === EnumCacheEntityType.salesCode; }\n public isStockGroup() { return this === EnumCacheEntityType.stockGroup; }\n public isStockLocation() { return this === EnumCacheEntityType.stockLocation; }\n public isTaskQueue() { return this === EnumCacheEntityType.taskQueue; }\n public isTaskType() { return this === EnumCacheEntityType.taskType; }\n public isUnitOfMeasure() { return this === EnumCacheEntityType.unitOfMeasure; }\n public isVatCode() { return this === EnumCacheEntityType.vatCode; }\n public isVehicle() { return this === EnumCacheEntityType.vehicle; }\n public isVesselMaintenanceProcess() { return this === EnumCacheEntityType.vesselMaintenanceProcess; }\n public isVesselType() { return this === EnumCacheEntityType.vesselType; }\n public isVessel() { return this === EnumCacheEntityType.vessel; }\n public isLeadLossReason() { return this === EnumCacheEntityType.leadLossReason; }\n public isLeadPipelineStage() { return this === EnumCacheEntityType.leadPipelineStage; }\n public isLeadSource() { return this === EnumCacheEntityType.leadSource; }\n public isPriceList() { return this === EnumCacheEntityType.priceList; }\n public isOutlet() { return this === EnumCacheEntityType.outlet; }\n public isGroup() { return this === EnumCacheEntityType.group; }\n public isSupplierManufacturer() { return this === EnumCacheEntityType.supplierManufacturer; }\n public isPalletType() { return this === EnumCacheEntityType.palletType; }\n public isItem() { return this === EnumCacheEntityType.item; }\n public isDistributionCentre() { return this === EnumCacheEntityType.distributionCentre; }\n public isVesselState() { return this === EnumCacheEntityType.vesselState; }\n public isCaskType() { return this === EnumCacheEntityType.caskType; }\n public isCaskSubType() { return this === EnumCacheEntityType.caskSubType; }\n public isObsolete_CaskLocation() { return this === EnumCacheEntityType.obsolete_CaskLocation; }\n public isCaskSubLocation() { return this === EnumCacheEntityType.caskSubLocation; }\n public isCaskSubSubLocation() { return this === EnumCacheEntityType.caskSubSubLocation; }\n public isTaskNotificationSetting() { return this === EnumCacheEntityType.taskNotificationSetting; }\n public isLead() { return this === EnumCacheEntityType.lead; }\n public isVesselCapability() { return this === EnumCacheEntityType.vesselCapability; }\n public isOrderTypeText() { return this === EnumCacheEntityType.orderTypeText; }\n public isRecipe() { return this === EnumCacheEntityType.recipe; }\n public isBatchTemplate() { return this === EnumCacheEntityType.batchTemplate; }\n public isTenantSettings() { return this === EnumCacheEntityType.tenantSettings; }\n public isTenant() { return this === EnumCacheEntityType.tenant; }\n public isOutletSubType() { return this === EnumCacheEntityType.outletSubType; }\n public isCollectionTime() { return this === EnumCacheEntityType.collectionTime; }\n public isAccountsLink() { return this === EnumCacheEntityType.accountsLink; }\n public isVesselValuation() { return this === EnumCacheEntityType.vesselValuation; }\n\n public static getValues(): readonly EnumCacheEntityType[] {\n return EnumCacheEntityType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumCacheEntityType[] {\n return EnumCacheEntityType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumCacheEntityType {\n const found = EnumCacheEntityType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumCacheEntityType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumCacheEntityType): EnumCacheEntityType {\n const found = name ? EnumCacheEntityType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumCacheEntityType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumCaseLabelWeightType implements BaseEnumType {\n private static allValues: EnumCaseLabelWeightType[] = []; // make sure this is top-most\n \n public static export = new EnumCaseLabelWeightType(69, \"Export\", \"enum_case_label_weight_type_export\");\n public static none = new EnumCaseLabelWeightType(78, \"None\", \"enum_case_label_weight_type_none\");\n public static standard = new EnumCaseLabelWeightType(83, \"Standard\", \"enum_case_label_weight_type_standard\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumCaseLabelWeightType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isExport() { return this === EnumCaseLabelWeightType.export; }\n public isNone() { return this === EnumCaseLabelWeightType.none; }\n public isStandard() { return this === EnumCaseLabelWeightType.standard; }\n\n public static getValues(): readonly EnumCaseLabelWeightType[] {\n return EnumCaseLabelWeightType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumCaseLabelWeightType[] {\n return EnumCaseLabelWeightType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumCaseLabelWeightType {\n const found = EnumCaseLabelWeightType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumCaseLabelWeightType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumCaseLabelWeightType): EnumCaseLabelWeightType {\n const found = name ? EnumCaseLabelWeightType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumCaseLabelWeightType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumChangeLogLineType implements BaseEnumType {\n private static allValues: EnumChangeLogLineType[] = []; // make sure this is top-most\n \n public static unknown = new EnumChangeLogLineType(0, \"Unknown\", \"enum_change_log_line_type_unknown\");\n public static fieldChange = new EnumChangeLogLineType(1, \"FieldChange\", \"enum_change_log_line_type_field_change\");\n public static add = new EnumChangeLogLineType(2, \"Add\", \"enum_change_log_line_type_add\");\n public static remove = new EnumChangeLogLineType(3, \"Remove\", \"enum_change_log_line_type_remove\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumChangeLogLineType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isUnknown() { return this === EnumChangeLogLineType.unknown; }\n public isFieldChange() { return this === EnumChangeLogLineType.fieldChange; }\n public isAdd() { return this === EnumChangeLogLineType.add; }\n public isRemove() { return this === EnumChangeLogLineType.remove; }\n\n public static getValues(): readonly EnumChangeLogLineType[] {\n return EnumChangeLogLineType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumChangeLogLineType[] {\n return EnumChangeLogLineType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumChangeLogLineType {\n const found = EnumChangeLogLineType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumChangeLogLineType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumChangeLogLineType): EnumChangeLogLineType {\n const found = name ? EnumChangeLogLineType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumChangeLogLineType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumChangeSection implements BaseEnumType {\n private static allValues: EnumChangeSection[] = []; // make sure this is top-most\n \n public static general = new EnumChangeSection(1, \"General\", \"enum_change_section_general\");\n public static orders = new EnumChangeSection(2, \"Orders\", \"enum_change_section_orders\");\n public static credits = new EnumChangeSection(3, \"Credits\", \"enum_change_section_credits\");\n public static externalOrders = new EnumChangeSection(4, \"ExternalOrders\", \"enum_change_section_external_orders\");\n public static containerTracking = new EnumChangeSection(5, \"ContainerTracking\", \"enum_change_section_container_tracking\");\n public static ullage = new EnumChangeSection(6, \"Ullage\", \"enum_change_section_ullage\");\n public static duty = new EnumChangeSection(7, \"Duty\", \"enum_change_section_duty\");\n public static reporting = new EnumChangeSection(8, \"Reporting\", \"enum_change_section_reporting\");\n public static security = new EnumChangeSection(9, \"Security\", \"enum_change_section_security\");\n public static newVersion = new EnumChangeSection(10, \"NewVersion\", \"enum_change_section_new_version\");\n public static brewRep = new EnumChangeSection(11, \"BrewRep\", \"enum_change_section_brew_rep\");\n public static stock = new EnumChangeSection(12, \"Stock\", \"enum_change_section_stock\");\n public static outlets = new EnumChangeSection(13, \"Outlets\", \"enum_change_section_outlets\");\n public static telesales = new EnumChangeSection(14, \"Telesales\", \"enum_change_section_telesales\");\n public static prices = new EnumChangeSection(15, \"Prices\", \"enum_change_section_prices\");\n public static production = new EnumChangeSection(16, \"Production\", \"enum_change_section_production\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumChangeSection.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isGeneral() { return this === EnumChangeSection.general; }\n public isOrders() { return this === EnumChangeSection.orders; }\n public isCredits() { return this === EnumChangeSection.credits; }\n public isExternalOrders() { return this === EnumChangeSection.externalOrders; }\n public isContainerTracking() { return this === EnumChangeSection.containerTracking; }\n public isUllage() { return this === EnumChangeSection.ullage; }\n public isDuty() { return this === EnumChangeSection.duty; }\n public isReporting() { return this === EnumChangeSection.reporting; }\n public isSecurity() { return this === EnumChangeSection.security; }\n public isNewVersion() { return this === EnumChangeSection.newVersion; }\n public isBrewRep() { return this === EnumChangeSection.brewRep; }\n public isStock() { return this === EnumChangeSection.stock; }\n public isOutlets() { return this === EnumChangeSection.outlets; }\n public isTelesales() { return this === EnumChangeSection.telesales; }\n public isPrices() { return this === EnumChangeSection.prices; }\n public isProduction() { return this === EnumChangeSection.production; }\n\n public static getValues(): readonly EnumChangeSection[] {\n return EnumChangeSection.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumChangeSection[] {\n return EnumChangeSection.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumChangeSection {\n const found = EnumChangeSection.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumChangeSection - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumChangeSection): EnumChangeSection {\n const found = name ? EnumChangeSection.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumChangeSection - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumChangeType implements BaseEnumType {\n private static allValues: EnumChangeType[] = []; // make sure this is top-most\n \n public static fix = new EnumChangeType(1, \"Fix\", \"enum_change_type_fix\");\n public static enhancement = new EnumChangeType(2, \"Enhancement\", \"enum_change_type_enhancement\");\n public static newVersion = new EnumChangeType(3, \"NewVersion\", \"enum_change_type_new_version\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumChangeType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isFix() { return this === EnumChangeType.fix; }\n public isEnhancement() { return this === EnumChangeType.enhancement; }\n public isNewVersion() { return this === EnumChangeType.newVersion; }\n\n public static getValues(): readonly EnumChangeType[] {\n return EnumChangeType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumChangeType[] {\n return EnumChangeType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumChangeType {\n const found = EnumChangeType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumChangeType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumChangeType): EnumChangeType {\n const found = name ? EnumChangeType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumChangeType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumColumnType implements BaseEnumType {\n private static allValues: EnumColumnType[] = []; // make sure this is top-most\n \n public static none = new EnumColumnType(0, \"None\", \"enum_column_type_none\");\n public static string = new EnumColumnType(1, \"String\", \"enum_column_type_string\");\n public static date = new EnumColumnType(2, \"Date\", \"enum_column_type_date\");\n public static timestamp = new EnumColumnType(3, \"Timestamp\", \"enum_column_type_timestamp\");\n public static double = new EnumColumnType(4, \"Double\", \"enum_column_type_double\");\n public static boolean = new EnumColumnType(5, \"Boolean\", \"enum_column_type_boolean\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumColumnType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumColumnType.none; }\n public isString() { return this === EnumColumnType.string; }\n public isDate() { return this === EnumColumnType.date; }\n public isTimestamp() { return this === EnumColumnType.timestamp; }\n public isDouble() { return this === EnumColumnType.double; }\n public isBoolean() { return this === EnumColumnType.boolean; }\n\n public static getValues(): readonly EnumColumnType[] {\n return EnumColumnType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumColumnType[] {\n return EnumColumnType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumColumnType {\n const found = EnumColumnType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumColumnType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumColumnType): EnumColumnType {\n const found = name ? EnumColumnType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumColumnType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumConsumableType implements BaseEnumType {\n private static allValues: EnumConsumableType[] = []; // make sure this is top-most\n \n public static caskLabel = new EnumConsumableType(0, \"CaskLabel\", \"enum_consumable_type_cask_label\");\n public static caseLabel = new EnumConsumableType(1, \"CaseLabel\", \"enum_consumable_type_case_label\");\n public static cleaningCard = new EnumConsumableType(2, \"CleaningCard\", \"enum_consumable_type_cleaning_card\");\n public static deliveryCharge = new EnumConsumableType(3, \"DeliveryCharge\", \"enum_consumable_type_delivery_charge\");\n public static printer = new EnumConsumableType(4, \"Printer\", \"enum_consumable_type_printer\");\n public static ribbon = new EnumConsumableType(5, \"Ribbon\", \"enum_consumable_type_ribbon\");\n public static scanner = new EnumConsumableType(6, \"Scanner\", \"enum_consumable_type_scanner\");\n public static permanentLabel = new EnumConsumableType(7, \"PermanentLabel\", \"enum_consumable_type_permanent_label\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumConsumableType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isCaskLabel() { return this === EnumConsumableType.caskLabel; }\n public isCaseLabel() { return this === EnumConsumableType.caseLabel; }\n public isCleaningCard() { return this === EnumConsumableType.cleaningCard; }\n public isDeliveryCharge() { return this === EnumConsumableType.deliveryCharge; }\n public isPrinter() { return this === EnumConsumableType.printer; }\n public isRibbon() { return this === EnumConsumableType.ribbon; }\n public isScanner() { return this === EnumConsumableType.scanner; }\n public isPermanentLabel() { return this === EnumConsumableType.permanentLabel; }\n\n public static getValues(): readonly EnumConsumableType[] {\n return EnumConsumableType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumConsumableType[] {\n return EnumConsumableType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumConsumableType {\n const found = EnumConsumableType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumConsumableType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumConsumableType): EnumConsumableType {\n const found = name ? EnumConsumableType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumConsumableType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumContainerStatus implements BaseEnumType {\n private static allValues: EnumContainerStatus[] = []; // make sure this is top-most\n \n public static cleanAndIn = new EnumContainerStatus(0, \"CleanAndIn\", \"enum_container_status_clean_and_in\");\n public static fullAndIn = new EnumContainerStatus(1, \"FullAndIn\", \"enum_container_status_full_and_in\");\n public static out = new EnumContainerStatus(2, \"Out\", \"enum_container_status_out\");\n public static lost = new EnumContainerStatus(3, \"Lost\", \"enum_container_status_lost\");\n public static dirtyAndIn = new EnumContainerStatus(4, \"DirtyAndIn\", \"enum_container_status_dirty_and_in\");\n public static outOfOrder = new EnumContainerStatus(5, \"OutOfOrder\", \"enum_container_status_out_of_order\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumContainerStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isCleanAndIn() { return this === EnumContainerStatus.cleanAndIn; }\n public isFullAndIn() { return this === EnumContainerStatus.fullAndIn; }\n public isOut() { return this === EnumContainerStatus.out; }\n public isLost() { return this === EnumContainerStatus.lost; }\n public isDirtyAndIn() { return this === EnumContainerStatus.dirtyAndIn; }\n public isOutOfOrder() { return this === EnumContainerStatus.outOfOrder; }\n\n public static getValues(): readonly EnumContainerStatus[] {\n return EnumContainerStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumContainerStatus[] {\n return EnumContainerStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumContainerStatus {\n const found = EnumContainerStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumContainerStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumContainerStatus): EnumContainerStatus {\n const found = name ? EnumContainerStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumContainerStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumCountry implements BaseEnumType {\n private static allValues: EnumCountry[] = []; // make sure this is top-most\n \n public static none = new EnumCountry(0, \"None\", \"enum_country_none\");\n public static uk = new EnumCountry(1, \"Uk\", \"enum_country_uk\");\n public static germany = new EnumCountry(2, \"Germany\", \"enum_country_germany\");\n public static australia = new EnumCountry(3, \"Australia\", \"enum_country_australia\");\n public static southAfrica = new EnumCountry(4, \"SouthAfrica\", \"enum_country_south_africa\");\n public static sweden = new EnumCountry(5, \"Sweden\", \"enum_country_sweden\");\n public static us = new EnumCountry(6, \"Us\", \"enum_country_us\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumCountry.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumCountry.none; }\n public isUk() { return this === EnumCountry.uk; }\n public isGermany() { return this === EnumCountry.germany; }\n public isAustralia() { return this === EnumCountry.australia; }\n public isSouthAfrica() { return this === EnumCountry.southAfrica; }\n public isSweden() { return this === EnumCountry.sweden; }\n public isUs() { return this === EnumCountry.us; }\n\n public static getValues(): readonly EnumCountry[] {\n return EnumCountry.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumCountry[] {\n return EnumCountry.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumCountry {\n const found = EnumCountry.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumCountry - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumCountry): EnumCountry {\n const found = name ? EnumCountry.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumCountry - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumCreditCalculationType implements BaseEnumType {\n private static allValues: EnumCreditCalculationType[] = []; // make sure this is top-most\n \n public static none = new EnumCreditCalculationType(0, \"None\", \"enum_credit_calculation_type_none\");\n public static ofFollowingMonth = new EnumCreditCalculationType(1, \"OfFollowingMonth\", \"enum_credit_calculation_type_of_following_month\");\n public static daysAfterInvoice = new EnumCreditCalculationType(2, \"DaysAfterInvoice\", \"enum_credit_calculation_type_days_after_invoice\");\n public static daysAfterInvoiceMonth = new EnumCreditCalculationType(3, \"DaysAfterInvoiceMonth\", \"enum_credit_calculation_type_days_after_invoice_month\");\n public static ofCurrentMonth = new EnumCreditCalculationType(4, \"OfCurrentMonth\", \"enum_credit_calculation_type_of_current_month\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumCreditCalculationType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumCreditCalculationType.none; }\n public isOfFollowingMonth() { return this === EnumCreditCalculationType.ofFollowingMonth; }\n public isDaysAfterInvoice() { return this === EnumCreditCalculationType.daysAfterInvoice; }\n public isDaysAfterInvoiceMonth() { return this === EnumCreditCalculationType.daysAfterInvoiceMonth; }\n public isOfCurrentMonth() { return this === EnumCreditCalculationType.ofCurrentMonth; }\n\n public static getValues(): readonly EnumCreditCalculationType[] {\n return EnumCreditCalculationType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumCreditCalculationType[] {\n return EnumCreditCalculationType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumCreditCalculationType {\n const found = EnumCreditCalculationType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumCreditCalculationType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumCreditCalculationType): EnumCreditCalculationType {\n const found = name ? EnumCreditCalculationType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumCreditCalculationType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumCreditType implements BaseEnumType {\n private static allValues: EnumCreditType[] = []; // make sure this is top-most\n \n public static none = new EnumCreditType(0, \"None\", \"enum_credit_type_none\");\n public static creditNoDutyReclaim = new EnumCreditType(1, \"CreditNoDutyReclaim\", \"enum_credit_type_credit_no_duty_reclaim\");\n public static dutyOnlyReclaim = new EnumCreditType(2, \"DutyOnlyReclaim\", \"enum_credit_type_duty_only_reclaim\");\n public static creditWithDutyReclaim = new EnumCreditType(3, \"CreditWithDutyReclaim\", \"enum_credit_type_credit_with_duty_reclaim\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumCreditType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumCreditType.none; }\n public isCreditNoDutyReclaim() { return this === EnumCreditType.creditNoDutyReclaim; }\n public isDutyOnlyReclaim() { return this === EnumCreditType.dutyOnlyReclaim; }\n public isCreditWithDutyReclaim() { return this === EnumCreditType.creditWithDutyReclaim; }\n\n public static getValues(): readonly EnumCreditType[] {\n return EnumCreditType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumCreditType[] {\n return EnumCreditType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumCreditType {\n const found = EnumCreditType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumCreditType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumCreditType): EnumCreditType {\n const found = name ? EnumCreditType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumCreditType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumCtVirtualNo implements BaseEnumType {\n private static allValues: EnumCtVirtualNo[] = []; // make sure this is top-most\n \n public static realAndVirtual = new EnumCtVirtualNo(0, \"RealAndVirtual\", \"enum_ct_virtual_no_real_and_virtual\");\n public static virtual = new EnumCtVirtualNo(1, \"Virtual\", \"enum_ct_virtual_no_virtual\");\n public static real = new EnumCtVirtualNo(2, \"Real\", \"enum_ct_virtual_no_real\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumCtVirtualNo.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isRealAndVirtual() { return this === EnumCtVirtualNo.realAndVirtual; }\n public isVirtual() { return this === EnumCtVirtualNo.virtual; }\n public isReal() { return this === EnumCtVirtualNo.real; }\n\n public static getValues(): readonly EnumCtVirtualNo[] {\n return EnumCtVirtualNo.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumCtVirtualNo[] {\n return EnumCtVirtualNo.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumCtVirtualNo {\n const found = EnumCtVirtualNo.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumCtVirtualNo - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumCtVirtualNo): EnumCtVirtualNo {\n const found = name ? EnumCtVirtualNo.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumCtVirtualNo - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumCustomerHappinessRating implements BaseEnumType {\n private static allValues: EnumCustomerHappinessRating[] = []; // make sure this is top-most\n \n public static neutral = new EnumCustomerHappinessRating(0, \"Neutral\", \"enum_customer_happiness_rating_neutral\");\n public static positive = new EnumCustomerHappinessRating(1, \"Positive\", \"enum_customer_happiness_rating_positive\");\n public static negative = new EnumCustomerHappinessRating(2, \"Negative\", \"enum_customer_happiness_rating_negative\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumCustomerHappinessRating.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNeutral() { return this === EnumCustomerHappinessRating.neutral; }\n public isPositive() { return this === EnumCustomerHappinessRating.positive; }\n public isNegative() { return this === EnumCustomerHappinessRating.negative; }\n\n public static getValues(): readonly EnumCustomerHappinessRating[] {\n return EnumCustomerHappinessRating.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumCustomerHappinessRating[] {\n return EnumCustomerHappinessRating.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumCustomerHappinessRating {\n const found = EnumCustomerHappinessRating.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumCustomerHappinessRating - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumCustomerHappinessRating): EnumCustomerHappinessRating {\n const found = name ? EnumCustomerHappinessRating.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumCustomerHappinessRating - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumDashboardComponent implements BaseEnumType {\n private static allValues: EnumDashboardComponent[] = []; // make sure this is top-most\n \n public static none = new EnumDashboardComponent(0, \"None\", \"enum_dashboard_component_none\");\n public static openOrders = new EnumDashboardComponent(1, \"OpenOrders\", \"enum_dashboard_component_open_orders\");\n public static ordersCreated = new EnumDashboardComponent(2, \"OrdersCreated\", \"enum_dashboard_component_orders_created\");\n public static inProgressAssemblies = new EnumDashboardComponent(3, \"InProgressAssemblies\", \"enum_dashboard_component_in_progress_assemblies\");\n public static activeLeads = new EnumDashboardComponent(4, \"ActiveLeads\", \"enum_dashboard_component_active_leads\");\n public static creditNotesCreated = new EnumDashboardComponent(5, \"CreditNotesCreated\", \"enum_dashboard_component_credit_notes_created\");\n public static openCreditNotes = new EnumDashboardComponent(6, \"OpenCreditNotes\", \"enum_dashboard_component_open_credit_notes\");\n public static totalAgeingCasks = new EnumDashboardComponent(7, \"TotalAgeingCasks\", \"enum_dashboard_component_total_ageing_casks\");\n public static vesselsInUse = new EnumDashboardComponent(8, \"VesselsInUse\", \"enum_dashboard_component_vessels_in_use\");\n public static totalLitreage = new EnumDashboardComponent(9, \"TotalLitreage\", \"enum_dashboard_component_total_litreage\");\n public static calendar = new EnumDashboardComponent(10, \"Calendar\", \"enum_dashboard_component_calendar\");\n public static overdueTasks = new EnumDashboardComponent(11, \"OverdueTasks\", \"enum_dashboard_component_overdue_tasks\");\n public static dueTasks = new EnumDashboardComponent(12, \"DueTasks\", \"enum_dashboard_component_due_tasks\");\n public static ordersOverdueForDispatch = new EnumDashboardComponent(13, \"OrdersOverdueForDispatch\", \"enum_dashboard_component_orders_overdue_for_dispatch\");\n public static ordersDueForDispatchToday = new EnumDashboardComponent(14, \"OrdersDueForDispatchToday\", \"enum_dashboard_component_orders_due_for_dispatch_today\");\n public static assembliesDueToStart = new EnumDashboardComponent(15, \"AssembliesDueToStart\", \"enum_dashboard_component_assemblies_due_to_start\");\n public static assembliesDueToEnd = new EnumDashboardComponent(16, \"AssembliesDueToEnd\", \"enum_dashboard_component_assemblies_due_to_end\");\n public static distributionPlanningMismatch = new EnumDashboardComponent(17, \"DistributionPlanningMismatch\", \"enum_dashboard_component_distribution_planning_mismatch\");\n public static distributionPlanningHasNotes = new EnumDashboardComponent(18, \"DistributionPlanningHasNotes\", \"enum_dashboard_component_distribution_planning_has_notes\");\n public static todaysPlannedJourneys = new EnumDashboardComponent(19, \"TodaysPlannedJourneys\", \"enum_dashboard_component_todays_planned_journeys\");\n public static courierPickups = new EnumDashboardComponent(20, \"CourierPickups\", \"enum_dashboard_component_courier_pickups\");\n public static collections = new EnumDashboardComponent(21, \"Collections\", \"enum_dashboard_component_collections\");\n public static stockReplenishment = new EnumDashboardComponent(22, \"StockReplenishment\", \"enum_dashboard_component_stock_replenishment\");\n public static stockAdjustment = new EnumDashboardComponent(23, \"StockAdjustment\", \"enum_dashboard_component_stock_adjustment\");\n public static stockTransfer = new EnumDashboardComponent(24, \"StockTransfer\", \"enum_dashboard_component_stock_transfer\");\n public static posDueForDelivery = new EnumDashboardComponent(25, \"PosDueForDelivery\", \"enum_dashboard_component_pos_due_for_delivery\");\n public static changelog = new EnumDashboardComponent(26, \"Changelog\", \"enum_dashboard_component_changelog\");\n public static christmas2024 = new EnumDashboardComponent(27, \"Christmas2024\", \"enum_dashboard_component_christmas2024\");\n public static christmasCountdown2024 = new EnumDashboardComponent(28, \"ChristmasCountdown2024\", \"enum_dashboard_component_christmas_countdown2024\");\n public static postingErrors = new EnumDashboardComponent(29, \"PostingErrors\", \"enum_dashboard_component_posting_errors\");\n public static openUllages = new EnumDashboardComponent(30, \"OpenUllages\", \"enum_dashboard_component_open_ullages\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDashboardComponent.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumDashboardComponent.none; }\n public isOpenOrders() { return this === EnumDashboardComponent.openOrders; }\n public isOrdersCreated() { return this === EnumDashboardComponent.ordersCreated; }\n public isInProgressAssemblies() { return this === EnumDashboardComponent.inProgressAssemblies; }\n public isActiveLeads() { return this === EnumDashboardComponent.activeLeads; }\n public isCreditNotesCreated() { return this === EnumDashboardComponent.creditNotesCreated; }\n public isOpenCreditNotes() { return this === EnumDashboardComponent.openCreditNotes; }\n public isTotalAgeingCasks() { return this === EnumDashboardComponent.totalAgeingCasks; }\n public isVesselsInUse() { return this === EnumDashboardComponent.vesselsInUse; }\n public isTotalLitreage() { return this === EnumDashboardComponent.totalLitreage; }\n public isCalendar() { return this === EnumDashboardComponent.calendar; }\n public isOverdueTasks() { return this === EnumDashboardComponent.overdueTasks; }\n public isDueTasks() { return this === EnumDashboardComponent.dueTasks; }\n public isOrdersOverdueForDispatch() { return this === EnumDashboardComponent.ordersOverdueForDispatch; }\n public isOrdersDueForDispatchToday() { return this === EnumDashboardComponent.ordersDueForDispatchToday; }\n public isAssembliesDueToStart() { return this === EnumDashboardComponent.assembliesDueToStart; }\n public isAssembliesDueToEnd() { return this === EnumDashboardComponent.assembliesDueToEnd; }\n public isDistributionPlanningMismatch() { return this === EnumDashboardComponent.distributionPlanningMismatch; }\n public isDistributionPlanningHasNotes() { return this === EnumDashboardComponent.distributionPlanningHasNotes; }\n public isTodaysPlannedJourneys() { return this === EnumDashboardComponent.todaysPlannedJourneys; }\n public isCourierPickups() { return this === EnumDashboardComponent.courierPickups; }\n public isCollections() { return this === EnumDashboardComponent.collections; }\n public isStockReplenishment() { return this === EnumDashboardComponent.stockReplenishment; }\n public isStockAdjustment() { return this === EnumDashboardComponent.stockAdjustment; }\n public isStockTransfer() { return this === EnumDashboardComponent.stockTransfer; }\n public isPosDueForDelivery() { return this === EnumDashboardComponent.posDueForDelivery; }\n public isChangelog() { return this === EnumDashboardComponent.changelog; }\n public isChristmas2024() { return this === EnumDashboardComponent.christmas2024; }\n public isChristmasCountdown2024() { return this === EnumDashboardComponent.christmasCountdown2024; }\n public isPostingErrors() { return this === EnumDashboardComponent.postingErrors; }\n public isOpenUllages() { return this === EnumDashboardComponent.openUllages; }\n\n public static getValues(): readonly EnumDashboardComponent[] {\n return EnumDashboardComponent.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumDashboardComponent[] {\n return EnumDashboardComponent.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumDashboardComponent {\n const found = EnumDashboardComponent.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDashboardComponent - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumDashboardComponent): EnumDashboardComponent {\n const found = name ? EnumDashboardComponent.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumDashboardComponent - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumDataImportAction implements BaseEnumType {\n private static allValues: EnumDataImportAction[] = []; // make sure this is top-most\n \n public static import = new EnumDataImportAction(0, \"Import\", \"enum_data_import_action_import\");\n public static bulkUpdate = new EnumDataImportAction(1, \"BulkUpdate\", \"enum_data_import_action_bulk_update\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDataImportAction.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isImport() { return this === EnumDataImportAction.import; }\n public isBulkUpdate() { return this === EnumDataImportAction.bulkUpdate; }\n\n public static getValues(): readonly EnumDataImportAction[] {\n return EnumDataImportAction.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumDataImportAction[] {\n return EnumDataImportAction.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumDataImportAction {\n const found = EnumDataImportAction.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDataImportAction - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumDataImportAction): EnumDataImportAction {\n const found = name ? EnumDataImportAction.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumDataImportAction - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumDataImportDateFormat implements BaseEnumType {\n private static allValues: EnumDataImportDateFormat[] = []; // make sure this is top-most\n \n public static yyyyMmDd = new EnumDataImportDateFormat(0, \"YyyyMmDd\", \"enum_data_import_date_format_yyyy_mm_dd\");\n public static ddMmYyyy = new EnumDataImportDateFormat(1, \"DdMmYyyy\", \"enum_data_import_date_format_dd_mm_yyyy\");\n public static ddMmYy = new EnumDataImportDateFormat(2, \"DdMmYy\", \"enum_data_import_date_format_dd_mm_yy\");\n public static mmDdYyyy = new EnumDataImportDateFormat(3, \"MmDdYyyy\", \"enum_data_import_date_format_mm_dd_yyyy\");\n public static mmDdYy = new EnumDataImportDateFormat(4, \"MmDdYy\", \"enum_data_import_date_format_mm_dd_yy\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDataImportDateFormat.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isYyyyMmDd() { return this === EnumDataImportDateFormat.yyyyMmDd; }\n public isDdMmYyyy() { return this === EnumDataImportDateFormat.ddMmYyyy; }\n public isDdMmYy() { return this === EnumDataImportDateFormat.ddMmYy; }\n public isMmDdYyyy() { return this === EnumDataImportDateFormat.mmDdYyyy; }\n public isMmDdYy() { return this === EnumDataImportDateFormat.mmDdYy; }\n\n public static getValues(): readonly EnumDataImportDateFormat[] {\n return EnumDataImportDateFormat.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumDataImportDateFormat[] {\n return EnumDataImportDateFormat.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumDataImportDateFormat {\n const found = EnumDataImportDateFormat.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDataImportDateFormat - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumDataImportDateFormat): EnumDataImportDateFormat {\n const found = name ? EnumDataImportDateFormat.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumDataImportDateFormat - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumDataImportTimestampFormat implements BaseEnumType {\n private static allValues: EnumDataImportTimestampFormat[] = []; // make sure this is top-most\n \n public static none = new EnumDataImportTimestampFormat(0, \"None\", \"enum_data_import_timestamp_format_none\");\n public static iso8601_2019 = new EnumDataImportTimestampFormat(1, \"Iso8601_2019\", \"enum_data_import_timestamp_format_iso8601_2019\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDataImportTimestampFormat.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumDataImportTimestampFormat.none; }\n public isIso8601_2019() { return this === EnumDataImportTimestampFormat.iso8601_2019; }\n\n public static getValues(): readonly EnumDataImportTimestampFormat[] {\n return EnumDataImportTimestampFormat.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumDataImportTimestampFormat[] {\n return EnumDataImportTimestampFormat.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumDataImportTimestampFormat {\n const found = EnumDataImportTimestampFormat.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDataImportTimestampFormat - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumDataImportTimestampFormat): EnumDataImportTimestampFormat {\n const found = name ? EnumDataImportTimestampFormat.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumDataImportTimestampFormat - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumDataImportType implements BaseEnumType {\n private static allValues: EnumDataImportType[] = []; // make sure this is top-most\n \n public static supplierManufacturers = new EnumDataImportType(0, \"SupplierManufacturers\", \"enum_data_import_type_supplier_manufacturers\");\n public static groups = new EnumDataImportType(1, \"Groups\", \"enum_data_import_type_groups\");\n public static products = new EnumDataImportType(2, \"Products\", \"enum_data_import_type_products\");\n public static materials = new EnumDataImportType(3, \"Materials\", \"enum_data_import_type_materials\");\n public static outlets = new EnumDataImportType(4, \"Outlets\", \"enum_data_import_type_outlets\");\n public static productGlCodes = new EnumDataImportType(5, \"ProductGlCodes\", \"enum_data_import_type_product_gl_codes\");\n public static outletContacts = new EnumDataImportType(6, \"OutletContacts\", \"enum_data_import_type_outlet_contacts\");\n public static groupContacts = new EnumDataImportType(7, \"GroupContacts\", \"enum_data_import_type_group_contacts\");\n public static priceListLines = new EnumDataImportType(8, \"PriceListLines\", \"enum_data_import_type_price_list_lines\");\n public static leads = new EnumDataImportType(9, \"Leads\", \"enum_data_import_type_leads\");\n public static orders = new EnumDataImportType(10, \"Orders\", \"enum_data_import_type_orders\");\n public static contactCodes = new EnumDataImportType(11, \"ContactCodes\", \"enum_data_import_type_contact_codes\");\n public static tasks = new EnumDataImportType(12, \"Tasks\", \"enum_data_import_type_tasks\");\n public static autoAssembledProducts = new EnumDataImportType(13, \"AutoAssembledProducts\", \"enum_data_import_type_auto_assembled_products\");\n public static shopifyOrders = new EnumDataImportType(14, \"ShopifyOrders\", \"enum_data_import_type_shopify_orders\");\n public static caskVessels = new EnumDataImportType(15, \"CaskVessels\", \"enum_data_import_type_cask_vessels\");\n public static stockAvailabilityAndReordering = new EnumDataImportType(16, \"StockAvailabilityAndReordering\", \"enum_data_import_type_stock_availability_and_reordering\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDataImportType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isSupplierManufacturers() { return this === EnumDataImportType.supplierManufacturers; }\n public isGroups() { return this === EnumDataImportType.groups; }\n public isProducts() { return this === EnumDataImportType.products; }\n public isMaterials() { return this === EnumDataImportType.materials; }\n public isOutlets() { return this === EnumDataImportType.outlets; }\n public isProductGlCodes() { return this === EnumDataImportType.productGlCodes; }\n public isOutletContacts() { return this === EnumDataImportType.outletContacts; }\n public isGroupContacts() { return this === EnumDataImportType.groupContacts; }\n public isPriceListLines() { return this === EnumDataImportType.priceListLines; }\n public isLeads() { return this === EnumDataImportType.leads; }\n public isOrders() { return this === EnumDataImportType.orders; }\n public isContactCodes() { return this === EnumDataImportType.contactCodes; }\n public isTasks() { return this === EnumDataImportType.tasks; }\n public isAutoAssembledProducts() { return this === EnumDataImportType.autoAssembledProducts; }\n public isShopifyOrders() { return this === EnumDataImportType.shopifyOrders; }\n public isCaskVessels() { return this === EnumDataImportType.caskVessels; }\n public isStockAvailabilityAndReordering() { return this === EnumDataImportType.stockAvailabilityAndReordering; }\n\n public static getValues(): readonly EnumDataImportType[] {\n return EnumDataImportType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumDataImportType[] {\n return EnumDataImportType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumDataImportType {\n const found = EnumDataImportType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDataImportType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumDataImportType): EnumDataImportType {\n const found = name ? EnumDataImportType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumDataImportType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumDateType implements BaseEnumType {\n private static allValues: EnumDateType[] = []; // make sure this is top-most\n \n public static despatch = new EnumDateType(1, \"Despatch\", \"enum_date_type_despatch\");\n public static delivery = new EnumDateType(2, \"Delivery\", \"enum_date_type_delivery\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDateType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isDespatch() { return this === EnumDateType.despatch; }\n public isDelivery() { return this === EnumDateType.delivery; }\n\n public static getValues(): readonly EnumDateType[] {\n return EnumDateType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumDateType[] {\n return EnumDateType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumDateType {\n const found = EnumDateType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDateType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumDateType): EnumDateType {\n const found = name ? EnumDateType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumDateType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumDeliveryNotificationSetting implements BaseEnumType {\n private static allValues: EnumDeliveryNotificationSetting[] = []; // make sure this is top-most\n \n public static unknown = new EnumDeliveryNotificationSetting(0, \"Unknown\", \"enum_delivery_notification_setting_unknown\");\n public static off = new EnumDeliveryNotificationSetting(1, \"Off\", \"enum_delivery_notification_setting_off\");\n public static toDeliveryRecipient = new EnumDeliveryNotificationSetting(2, \"ToDeliveryRecipient\", \"enum_delivery_notification_setting_to_delivery_recipient\");\n public static toSpecifiedAddress = new EnumDeliveryNotificationSetting(3, \"ToSpecifiedAddress\", \"enum_delivery_notification_setting_to_specified_address\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDeliveryNotificationSetting.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isUnknown() { return this === EnumDeliveryNotificationSetting.unknown; }\n public isOff() { return this === EnumDeliveryNotificationSetting.off; }\n public isToDeliveryRecipient() { return this === EnumDeliveryNotificationSetting.toDeliveryRecipient; }\n public isToSpecifiedAddress() { return this === EnumDeliveryNotificationSetting.toSpecifiedAddress; }\n\n public static getValues(): readonly EnumDeliveryNotificationSetting[] {\n return EnumDeliveryNotificationSetting.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumDeliveryNotificationSetting[] {\n return EnumDeliveryNotificationSetting.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumDeliveryNotificationSetting {\n const found = EnumDeliveryNotificationSetting.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDeliveryNotificationSetting - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumDeliveryNotificationSetting): EnumDeliveryNotificationSetting {\n const found = name ? EnumDeliveryNotificationSetting.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumDeliveryNotificationSetting - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumDiscountParent implements BaseEnumType {\n private static allValues: EnumDiscountParent[] = []; // make sure this is top-most\n \n public static none = new EnumDiscountParent(0, \"None\", \"enum_discount_parent_none\");\n public static group = new EnumDiscountParent(1, \"Group\", \"enum_discount_parent_group\");\n public static outlet = new EnumDiscountParent(2, \"Outlet\", \"enum_discount_parent_outlet\");\n public static priceList = new EnumDiscountParent(3, \"PriceList\", \"enum_discount_parent_price_list\");\n public static stockItem = new EnumDiscountParent(4, \"StockItem\", \"enum_discount_parent_stock_item\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDiscountParent.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumDiscountParent.none; }\n public isGroup() { return this === EnumDiscountParent.group; }\n public isOutlet() { return this === EnumDiscountParent.outlet; }\n public isPriceList() { return this === EnumDiscountParent.priceList; }\n public isStockItem() { return this === EnumDiscountParent.stockItem; }\n\n public static getValues(): readonly EnumDiscountParent[] {\n return EnumDiscountParent.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumDiscountParent[] {\n return EnumDiscountParent.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumDiscountParent {\n const found = EnumDiscountParent.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDiscountParent - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumDiscountParent): EnumDiscountParent {\n const found = name ? EnumDiscountParent.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumDiscountParent - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumDistributionType implements BaseEnumType {\n private static allValues: EnumDistributionType[] = []; // make sure this is top-most\n \n public static none = new EnumDistributionType(0, \"None\", \"enum_distribution_type_none\");\n public static delivery = new EnumDistributionType(1, \"Delivery\", \"enum_distribution_type_delivery\");\n public static courier = new EnumDistributionType(2, \"Courier\", \"enum_distribution_type_courier\");\n public static collection = new EnumDistributionType(3, \"Collection\", \"enum_distribution_type_collection\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDistributionType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumDistributionType.none; }\n public isDelivery() { return this === EnumDistributionType.delivery; }\n public isCourier() { return this === EnumDistributionType.courier; }\n public isCollection() { return this === EnumDistributionType.collection; }\n\n public static getValues(): readonly EnumDistributionType[] {\n return EnumDistributionType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumDistributionType[] {\n return EnumDistributionType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumDistributionType {\n const found = EnumDistributionType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDistributionType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumDistributionType): EnumDistributionType {\n const found = name ? EnumDistributionType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumDistributionType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumDocumentContextType implements BaseEnumType {\n private static allValues: EnumDocumentContextType[] = []; // make sure this is top-most\n \n public static outlet = new EnumDocumentContextType(0, \"Outlet\", \"enum_document_context_type_outlet\");\n public static supplierManufacturer = new EnumDocumentContextType(1, \"SupplierManufacturer\", \"enum_document_context_type_supplier_manufacturer\");\n public static stockItem = new EnumDocumentContextType(2, \"StockItem\", \"enum_document_context_type_stock_item\");\n public static lead = new EnumDocumentContextType(3, \"Lead\", \"enum_document_context_type_lead\");\n public static order = new EnumDocumentContextType(4, \"Order\", \"enum_document_context_type_order\");\n public static credit = new EnumDocumentContextType(5, \"Credit\", \"enum_document_context_type_credit\");\n public static outletGroup = new EnumDocumentContextType(6, \"OutletGroup\", \"enum_document_context_type_outlet_group\");\n public static purchaseOrder = new EnumDocumentContextType(7, \"PurchaseOrder\", \"enum_document_context_type_purchase_order\");\n public static stockTake = new EnumDocumentContextType(8, \"StockTake\", \"enum_document_context_type_stock_take\");\n public static stockTransfer = new EnumDocumentContextType(9, \"StockTransfer\", \"enum_document_context_type_stock_transfer\");\n public static stockAdjustment = new EnumDocumentContextType(10, \"StockAdjustment\", \"enum_document_context_type_stock_adjustment\");\n public static productBrand = new EnumDocumentContextType(11, \"ProductBrand\", \"enum_document_context_type_product_brand\");\n public static assembly = new EnumDocumentContextType(12, \"Assembly\", \"enum_document_context_type_assembly\");\n public static process = new EnumDocumentContextType(13, \"Process\", \"enum_document_context_type_process\");\n public static batch = new EnumDocumentContextType(14, \"Batch\", \"enum_document_context_type_batch\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDocumentContextType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isOutlet() { return this === EnumDocumentContextType.outlet; }\n public isSupplierManufacturer() { return this === EnumDocumentContextType.supplierManufacturer; }\n public isStockItem() { return this === EnumDocumentContextType.stockItem; }\n public isLead() { return this === EnumDocumentContextType.lead; }\n public isOrder() { return this === EnumDocumentContextType.order; }\n public isCredit() { return this === EnumDocumentContextType.credit; }\n public isOutletGroup() { return this === EnumDocumentContextType.outletGroup; }\n public isPurchaseOrder() { return this === EnumDocumentContextType.purchaseOrder; }\n public isStockTake() { return this === EnumDocumentContextType.stockTake; }\n public isStockTransfer() { return this === EnumDocumentContextType.stockTransfer; }\n public isStockAdjustment() { return this === EnumDocumentContextType.stockAdjustment; }\n public isProductBrand() { return this === EnumDocumentContextType.productBrand; }\n public isAssembly() { return this === EnumDocumentContextType.assembly; }\n public isProcess() { return this === EnumDocumentContextType.process; }\n public isBatch() { return this === EnumDocumentContextType.batch; }\n\n public static getValues(): readonly EnumDocumentContextType[] {\n return EnumDocumentContextType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumDocumentContextType[] {\n return EnumDocumentContextType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumDocumentContextType {\n const found = EnumDocumentContextType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDocumentContextType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumDocumentContextType): EnumDocumentContextType {\n const found = name ? EnumDocumentContextType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumDocumentContextType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumDocumentEmailTag implements BaseEnumType {\n private static allValues: EnumDocumentEmailTag[] = []; // make sure this is top-most\n \n public static none = new EnumDocumentEmailTag(0, \"None\", \"enum_document_email_tag_none\");\n public static documentIdSummary = new EnumDocumentEmailTag(1, \"DocumentIdSummary\", \"enum_document_email_tag_document_id_summary\");\n public static companyName = new EnumDocumentEmailTag(2, \"CompanyName\", \"enum_document_email_tag_company_name\");\n public static outletBusinessName = new EnumDocumentEmailTag(3, \"OutletBusinessName\", \"enum_document_email_tag_outlet_business_name\");\n public static totalNetPrice = new EnumDocumentEmailTag(4, \"TotalNetPrice\", \"enum_document_email_tag_total_net_price\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDocumentEmailTag.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumDocumentEmailTag.none; }\n public isDocumentIdSummary() { return this === EnumDocumentEmailTag.documentIdSummary; }\n public isCompanyName() { return this === EnumDocumentEmailTag.companyName; }\n public isOutletBusinessName() { return this === EnumDocumentEmailTag.outletBusinessName; }\n public isTotalNetPrice() { return this === EnumDocumentEmailTag.totalNetPrice; }\n\n public static getValues(): readonly EnumDocumentEmailTag[] {\n return EnumDocumentEmailTag.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumDocumentEmailTag[] {\n return EnumDocumentEmailTag.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumDocumentEmailTag {\n const found = EnumDocumentEmailTag.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDocumentEmailTag - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumDocumentEmailTag): EnumDocumentEmailTag {\n const found = name ? EnumDocumentEmailTag.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumDocumentEmailTag - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumDocumentFileType implements BaseEnumType {\n private static allValues: EnumDocumentFileType[] = []; // make sure this is top-most\n \n public static pdf = new EnumDocumentFileType(0, \"Pdf\", \"enum_document_file_type_pdf\");\n public static docx = new EnumDocumentFileType(1, \"Docx\", \"enum_document_file_type_docx\");\n public static png = new EnumDocumentFileType(2, \"Png\", \"enum_document_file_type_png\");\n public static jpeg = new EnumDocumentFileType(3, \"Jpeg\", \"enum_document_file_type_jpeg\");\n public static csv = new EnumDocumentFileType(4, \"Csv\", \"enum_document_file_type_csv\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDocumentFileType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isPdf() { return this === EnumDocumentFileType.pdf; }\n public isDocx() { return this === EnumDocumentFileType.docx; }\n public isPng() { return this === EnumDocumentFileType.png; }\n public isJpeg() { return this === EnumDocumentFileType.jpeg; }\n public isCsv() { return this === EnumDocumentFileType.csv; }\n\n public static getValues(): readonly EnumDocumentFileType[] {\n return EnumDocumentFileType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumDocumentFileType[] {\n return EnumDocumentFileType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumDocumentFileType {\n const found = EnumDocumentFileType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDocumentFileType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumDocumentFileType): EnumDocumentFileType {\n const found = name ? EnumDocumentFileType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumDocumentFileType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumDocumentGenerationOutputFileType implements BaseEnumType {\n private static allValues: EnumDocumentGenerationOutputFileType[] = []; // make sure this is top-most\n \n public static docx = new EnumDocumentGenerationOutputFileType(0, \"Docx\", \"enum_document_generation_output_file_type_docx\");\n public static csv = new EnumDocumentGenerationOutputFileType(1, \"Csv\", \"enum_document_generation_output_file_type_csv\");\n public static utf8 = new EnumDocumentGenerationOutputFileType(2, \"Utf8\", \"enum_document_generation_output_file_type_utf8\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDocumentGenerationOutputFileType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isDocx() { return this === EnumDocumentGenerationOutputFileType.docx; }\n public isCsv() { return this === EnumDocumentGenerationOutputFileType.csv; }\n public isUtf8() { return this === EnumDocumentGenerationOutputFileType.utf8; }\n\n public static getValues(): readonly EnumDocumentGenerationOutputFileType[] {\n return EnumDocumentGenerationOutputFileType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumDocumentGenerationOutputFileType[] {\n return EnumDocumentGenerationOutputFileType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumDocumentGenerationOutputFileType {\n const found = EnumDocumentGenerationOutputFileType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDocumentGenerationOutputFileType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumDocumentGenerationOutputFileType): EnumDocumentGenerationOutputFileType {\n const found = name ? EnumDocumentGenerationOutputFileType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumDocumentGenerationOutputFileType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumImageFormat implements BaseEnumType {\n private static allValues: EnumImageFormat[] = []; // make sure this is top-most\n \n public static png = new EnumImageFormat(0, \"Png\", \"enum_image_format_png\");\n public static jpeg = new EnumImageFormat(1, \"Jpeg\", \"enum_image_format_jpeg\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumImageFormat.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isPng() { return this === EnumImageFormat.png; }\n public isJpeg() { return this === EnumImageFormat.jpeg; }\n\n public static getValues(): readonly EnumImageFormat[] {\n return EnumImageFormat.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumImageFormat[] {\n return EnumImageFormat.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumImageFormat {\n const found = EnumImageFormat.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumImageFormat - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumImageFormat): EnumImageFormat {\n const found = name ? EnumImageFormat.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumImageFormat - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumDocumentTagType implements BaseEnumType {\n private static allValues: EnumDocumentTagType[] = []; // make sure this is top-most\n \n public static string = new EnumDocumentTagType(0, \"String\", \"enum_document_tag_type_string\");\n public static currency = new EnumDocumentTagType(1, \"Currency\", \"enum_document_tag_type_currency\");\n public static integer = new EnumDocumentTagType(2, \"Integer\", \"enum_document_tag_type_integer\");\n public static long = new EnumDocumentTagType(3, \"Long\", \"enum_document_tag_type_long\");\n public static double = new EnumDocumentTagType(4, \"Double\", \"enum_document_tag_type_double\");\n public static boolean = new EnumDocumentTagType(5, \"Boolean\", \"enum_document_tag_type_boolean\");\n public static date = new EnumDocumentTagType(6, \"Date\", \"enum_document_tag_type_date\");\n public static time = new EnumDocumentTagType(7, \"Time\", \"enum_document_tag_type_time\");\n public static timestamp = new EnumDocumentTagType(8, \"Timestamp\", \"enum_document_tag_type_timestamp\");\n public static image = new EnumDocumentTagType(9, \"Image\", \"enum_document_tag_type_image\");\n public static array = new EnumDocumentTagType(10, \"Array\", \"enum_document_tag_type_array\");\n public static svg = new EnumDocumentTagType(11, \"Svg\", \"enum_document_tag_type_svg\");\n public static object = new EnumDocumentTagType(12, \"Object\", \"enum_document_tag_type_object\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDocumentTagType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isString() { return this === EnumDocumentTagType.string; }\n public isCurrency() { return this === EnumDocumentTagType.currency; }\n public isInteger() { return this === EnumDocumentTagType.integer; }\n public isLong() { return this === EnumDocumentTagType.long; }\n public isDouble() { return this === EnumDocumentTagType.double; }\n public isBoolean() { return this === EnumDocumentTagType.boolean; }\n public isDate() { return this === EnumDocumentTagType.date; }\n public isTime() { return this === EnumDocumentTagType.time; }\n public isTimestamp() { return this === EnumDocumentTagType.timestamp; }\n public isImage() { return this === EnumDocumentTagType.image; }\n public isArray() { return this === EnumDocumentTagType.array; }\n public isSvg() { return this === EnumDocumentTagType.svg; }\n public isObject() { return this === EnumDocumentTagType.object; }\n\n public static getValues(): readonly EnumDocumentTagType[] {\n return EnumDocumentTagType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumDocumentTagType[] {\n return EnumDocumentTagType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumDocumentTagType {\n const found = EnumDocumentTagType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDocumentTagType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumDocumentTagType): EnumDocumentTagType {\n const found = name ? EnumDocumentTagType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumDocumentTagType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumDocumentType implements BaseEnumType {\n private static allValues: EnumDocumentType[] = []; // make sure this is top-most\n \n public static none = new EnumDocumentType(0, \"None\", \"enum_document_type_none\");\n public static invoice = new EnumDocumentType(1, \"Invoice\", \"enum_document_type_invoice\");\n public static creditNote = new EnumDocumentType(2, \"CreditNote\", \"enum_document_type_credit_note\");\n public static returnableLabel = new EnumDocumentType(3, \"ReturnableLabel\", \"enum_document_type_returnable_label\");\n public static nonReturnableLabel = new EnumDocumentType(4, \"NonReturnableLabel\", \"enum_document_type_non_returnable_label\");\n public static ullageLabel = new EnumDocumentType(5, \"UllageLabel\", \"enum_document_type_ullage_label\");\n public static stockTakeSheet = new EnumDocumentType(6, \"StockTakeSheet\", \"enum_document_type_stock_take_sheet\");\n public static purchaseOrder = new EnumDocumentType(7, \"PurchaseOrder\", \"enum_document_type_purchase_order\");\n public static despatchNote = new EnumDocumentType(8, \"DespatchNote\", \"enum_document_type_despatch_note\");\n public static dutyReturn = new EnumDocumentType(9, \"DutyReturn\", \"enum_document_type_duty_return\");\n public static flatGrid = new EnumDocumentType(10, \"FlatGrid\", \"enum_document_type_flat_grid\");\n public static groupGrid = new EnumDocumentType(11, \"GroupGrid\", \"enum_document_type_group_grid\");\n public static invoiceDataExchange = new EnumDocumentType(12, \"InvoiceDataExchange\", \"enum_document_type_invoice_data_exchange\");\n public static deliverySummarySheet = new EnumDocumentType(13, \"DeliverySummarySheet\", \"enum_document_type_delivery_summary_sheet\");\n public static driverManifest = new EnumDocumentType(14, \"DriverManifest\", \"enum_document_type_driver_manifest\");\n public static materialLabel = new EnumDocumentType(15, \"MaterialLabel\", \"enum_document_type_material_label\");\n public static beerflexDeliveryNote = new EnumDocumentType(16, \"BeerflexDeliveryNote\", \"enum_document_type_beerflex_delivery_note\");\n public static priceList = new EnumDocumentType(17, \"PriceList\", \"enum_document_type_price_list\");\n public static outletPriceList = new EnumDocumentType(18, \"OutletPriceList\", \"enum_document_type_outlet_price_list\");\n public static germanBeerDutyReturn = new EnumDocumentType(19, \"GermanBeerDutyReturn\", \"enum_document_type_german_beer_duty_return\");\n public static australianDutyReturn = new EnumDocumentType(20, \"AustralianDutyReturn\", \"enum_document_type_australian_duty_return\");\n public static accountsPackageCsv = new EnumDocumentType(21, \"AccountsPackageCsv\", \"enum_document_type_accounts_package_csv\");\n public static stockTransferNote = new EnumDocumentType(22, \"StockTransferNote\", \"enum_document_type_stock_transfer_note\");\n public static usSmallBrewersReport = new EnumDocumentType(23, \"UsSmallBrewersReport\", \"enum_document_type_us_small_brewers_report\");\n public static palletManifest = new EnumDocumentType(24, \"PalletManifest\", \"enum_document_type_pallet_manifest\");\n public static palletLabel = new EnumDocumentType(25, \"PalletLabel\", \"enum_document_type_pallet_label\");\n public static despatchNotification = new EnumDocumentType(26, \"DespatchNotification\", \"enum_document_type_despatch_notification\");\n public static assemblyControlSheet = new EnumDocumentType(27, \"AssemblyControlSheet\", \"enum_document_type_assembly_control_sheet\");\n public static taskCreatedNotification = new EnumDocumentType(28, \"TaskCreatedNotification\", \"enum_document_type_task_created_notification\");\n public static taskModifiedNotification = new EnumDocumentType(29, \"TaskModifiedNotification\", \"enum_document_type_task_modified_notification\");\n public static tasksDueNotification = new EnumDocumentType(30, \"TasksDueNotification\", \"enum_document_type_tasks_due_notification\");\n public static addressLabel = new EnumDocumentType(31, \"AddressLabel\", \"enum_document_type_address_label\");\n public static ukBeerNewDutyReturn = new EnumDocumentType(32, \"UkBeerNewDutyReturn\", \"enum_document_type_uk_beer_new_duty_return\");\n public static ukWineAndOtherNewDutyReturn = new EnumDocumentType(33, \"UkWineAndOtherNewDutyReturn\", \"enum_document_type_uk_wine_and_other_new_duty_return\");\n public static proFormaInvoice = new EnumDocumentType(34, \"ProFormaInvoice\", \"enum_document_type_pro_forma_invoice\");\n public static processControlSheet = new EnumDocumentType(35, \"ProcessControlSheet\", \"enum_document_type_process_control_sheet\");\n public static stockAdjustment = new EnumDocumentType(36, \"StockAdjustment\", \"enum_document_type_stock_adjustment\");\n public static batchControlSheet = new EnumDocumentType(37, \"BatchControlSheet\", \"enum_document_type_batch_control_sheet\");\n public static labelOrderInvoice = new EnumDocumentType(38, \"LabelOrderInvoice\", \"enum_document_type_label_order_invoice\");\n public static orderPickingList = new EnumDocumentType(39, \"OrderPickingList\", \"enum_document_type_order_picking_list\");\n public static groupedPriceList = new EnumDocumentType(40, \"GroupedPriceList\", \"enum_document_type_grouped_price_list\");\n public static groupedOutletPriceList = new EnumDocumentType(41, \"GroupedOutletPriceList\", \"enum_document_type_grouped_outlet_price_list\");\n public static ullageRecord = new EnumDocumentType(42, \"UllageRecord\", \"enum_document_type_ullage_record\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDocumentType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumDocumentType.none; }\n public isInvoice() { return this === EnumDocumentType.invoice; }\n public isCreditNote() { return this === EnumDocumentType.creditNote; }\n public isReturnableLabel() { return this === EnumDocumentType.returnableLabel; }\n public isNonReturnableLabel() { return this === EnumDocumentType.nonReturnableLabel; }\n public isUllageLabel() { return this === EnumDocumentType.ullageLabel; }\n public isStockTakeSheet() { return this === EnumDocumentType.stockTakeSheet; }\n public isPurchaseOrder() { return this === EnumDocumentType.purchaseOrder; }\n public isDespatchNote() { return this === EnumDocumentType.despatchNote; }\n public isDutyReturn() { return this === EnumDocumentType.dutyReturn; }\n public isFlatGrid() { return this === EnumDocumentType.flatGrid; }\n public isGroupGrid() { return this === EnumDocumentType.groupGrid; }\n public isInvoiceDataExchange() { return this === EnumDocumentType.invoiceDataExchange; }\n public isDeliverySummarySheet() { return this === EnumDocumentType.deliverySummarySheet; }\n public isDriverManifest() { return this === EnumDocumentType.driverManifest; }\n public isMaterialLabel() { return this === EnumDocumentType.materialLabel; }\n public isBeerflexDeliveryNote() { return this === EnumDocumentType.beerflexDeliveryNote; }\n public isPriceList() { return this === EnumDocumentType.priceList; }\n public isOutletPriceList() { return this === EnumDocumentType.outletPriceList; }\n public isGermanBeerDutyReturn() { return this === EnumDocumentType.germanBeerDutyReturn; }\n public isAustralianDutyReturn() { return this === EnumDocumentType.australianDutyReturn; }\n public isAccountsPackageCsv() { return this === EnumDocumentType.accountsPackageCsv; }\n public isStockTransferNote() { return this === EnumDocumentType.stockTransferNote; }\n public isUsSmallBrewersReport() { return this === EnumDocumentType.usSmallBrewersReport; }\n public isPalletManifest() { return this === EnumDocumentType.palletManifest; }\n public isPalletLabel() { return this === EnumDocumentType.palletLabel; }\n public isDespatchNotification() { return this === EnumDocumentType.despatchNotification; }\n public isAssemblyControlSheet() { return this === EnumDocumentType.assemblyControlSheet; }\n public isTaskCreatedNotification() { return this === EnumDocumentType.taskCreatedNotification; }\n public isTaskModifiedNotification() { return this === EnumDocumentType.taskModifiedNotification; }\n public isTasksDueNotification() { return this === EnumDocumentType.tasksDueNotification; }\n public isAddressLabel() { return this === EnumDocumentType.addressLabel; }\n public isUkBeerNewDutyReturn() { return this === EnumDocumentType.ukBeerNewDutyReturn; }\n public isUkWineAndOtherNewDutyReturn() { return this === EnumDocumentType.ukWineAndOtherNewDutyReturn; }\n public isProFormaInvoice() { return this === EnumDocumentType.proFormaInvoice; }\n public isProcessControlSheet() { return this === EnumDocumentType.processControlSheet; }\n public isStockAdjustment() { return this === EnumDocumentType.stockAdjustment; }\n public isBatchControlSheet() { return this === EnumDocumentType.batchControlSheet; }\n public isLabelOrderInvoice() { return this === EnumDocumentType.labelOrderInvoice; }\n public isOrderPickingList() { return this === EnumDocumentType.orderPickingList; }\n public isGroupedPriceList() { return this === EnumDocumentType.groupedPriceList; }\n public isGroupedOutletPriceList() { return this === EnumDocumentType.groupedOutletPriceList; }\n public isUllageRecord() { return this === EnumDocumentType.ullageRecord; }\n\n public static getValues(): readonly EnumDocumentType[] {\n return EnumDocumentType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumDocumentType[] {\n return EnumDocumentType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumDocumentType {\n const found = EnumDocumentType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDocumentType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumDocumentType): EnumDocumentType {\n const found = name ? EnumDocumentType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumDocumentType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumDocumentTypeGroup implements BaseEnumType {\n private static allValues: EnumDocumentTypeGroup[] = []; // make sure this is top-most\n \n public static other = new EnumDocumentTypeGroup(0, \"Other\", \"enum_document_type_group_other\");\n public static productionAndStock = new EnumDocumentTypeGroup(1, \"ProductionAndStock\", \"enum_document_type_group_production_and_stock\");\n public static salesAndDistribution = new EnumDocumentTypeGroup(2, \"SalesAndDistribution\", \"enum_document_type_group_sales_and_distribution\");\n public static duty = new EnumDocumentTypeGroup(3, \"Duty\", \"enum_document_type_group_duty\");\n public static hidden = new EnumDocumentTypeGroup(4, \"Hidden\", \"enum_document_type_group_hidden\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDocumentTypeGroup.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isOther() { return this === EnumDocumentTypeGroup.other; }\n public isProductionAndStock() { return this === EnumDocumentTypeGroup.productionAndStock; }\n public isSalesAndDistribution() { return this === EnumDocumentTypeGroup.salesAndDistribution; }\n public isDuty() { return this === EnumDocumentTypeGroup.duty; }\n public isHidden() { return this === EnumDocumentTypeGroup.hidden; }\n\n public static getValues(): readonly EnumDocumentTypeGroup[] {\n return EnumDocumentTypeGroup.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumDocumentTypeGroup[] {\n return EnumDocumentTypeGroup.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumDocumentTypeGroup {\n const found = EnumDocumentTypeGroup.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDocumentTypeGroup - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumDocumentTypeGroup): EnumDocumentTypeGroup {\n const found = name ? EnumDocumentTypeGroup.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumDocumentTypeGroup - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumDutyHslsRate implements BaseEnumType {\n private static allValues: EnumDutyHslsRate[] = []; // make sure this is top-most\n \n public static none = new EnumDutyHslsRate(0, \"None\", \"enum_duty_hsls_rate_none\");\n public static low = new EnumDutyHslsRate(1, \"Low\", \"enum_duty_hsls_rate_low\");\n public static high = new EnumDutyHslsRate(2, \"High\", \"enum_duty_hsls_rate_high\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDutyHslsRate.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumDutyHslsRate.none; }\n public isLow() { return this === EnumDutyHslsRate.low; }\n public isHigh() { return this === EnumDutyHslsRate.high; }\n\n public static getValues(): readonly EnumDutyHslsRate[] {\n return EnumDutyHslsRate.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumDutyHslsRate[] {\n return EnumDutyHslsRate.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumDutyHslsRate {\n const found = EnumDutyHslsRate.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDutyHslsRate - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumDutyHslsRate): EnumDutyHslsRate {\n const found = name ? EnumDutyHslsRate.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumDutyHslsRate - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumDutyRateBasis implements BaseEnumType {\n private static allValues: EnumDutyRateBasis[] = []; // make sure this is top-most\n \n public static none = new EnumDutyRateBasis(0, \"None\", \"enum_duty_rate_basis_none\");\n public static perHectolitrePercent = new EnumDutyRateBasis(1, \"PerHectolitrePercent\", \"enum_duty_rate_basis_per_hectolitre_percent\");\n public static perHectolitreOfProduct = new EnumDutyRateBasis(2, \"PerHectolitreOfProduct\", \"enum_duty_rate_basis_per_hectolitre_of_product\");\n public static perLitreOfAlcohol = new EnumDutyRateBasis(3, \"PerLitreOfAlcohol\", \"enum_duty_rate_basis_per_litre_of_alcohol\");\n public static perLitreOfProduct = new EnumDutyRateBasis(4, \"PerLitreOfProduct\", \"enum_duty_rate_basis_per_litre_of_product\");\n public static perLitreAbv = new EnumDutyRateBasis(5, \"PerLitreAbv\", \"enum_duty_rate_basis_per_litre_abv\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDutyRateBasis.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumDutyRateBasis.none; }\n public isPerHectolitrePercent() { return this === EnumDutyRateBasis.perHectolitrePercent; }\n public isPerHectolitreOfProduct() { return this === EnumDutyRateBasis.perHectolitreOfProduct; }\n public isPerLitreOfAlcohol() { return this === EnumDutyRateBasis.perLitreOfAlcohol; }\n public isPerLitreOfProduct() { return this === EnumDutyRateBasis.perLitreOfProduct; }\n public isPerLitreAbv() { return this === EnumDutyRateBasis.perLitreAbv; }\n\n public static getValues(): readonly EnumDutyRateBasis[] {\n return EnumDutyRateBasis.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumDutyRateBasis[] {\n return EnumDutyRateBasis.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumDutyRateBasis {\n const found = EnumDutyRateBasis.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDutyRateBasis - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumDutyRateBasis): EnumDutyRateBasis {\n const found = name ? EnumDutyRateBasis.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumDutyRateBasis - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumDutyScheme implements BaseEnumType {\n private static allValues: EnumDutyScheme[] = []; // make sure this is top-most\n \n public static none = new EnumDutyScheme(0, \"None\", \"enum_duty_scheme_none\");\n public static uk = new EnumDutyScheme(1, \"Uk\", \"enum_duty_scheme_uk\");\n public static germany = new EnumDutyScheme(2, \"Germany\", \"enum_duty_scheme_germany\");\n public static australia = new EnumDutyScheme(3, \"Australia\", \"enum_duty_scheme_australia\");\n public static southAfrica = new EnumDutyScheme(4, \"SouthAfrica\", \"enum_duty_scheme_south_africa\");\n public static sweden = new EnumDutyScheme(5, \"Sweden\", \"enum_duty_scheme_sweden\");\n public static us = new EnumDutyScheme(6, \"Us\", \"enum_duty_scheme_us\");\n public static eire = new EnumDutyScheme(7, \"Eire\", \"enum_duty_scheme_eire\");\n public static nz = new EnumDutyScheme(8, \"Nz\", \"enum_duty_scheme_nz\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDutyScheme.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumDutyScheme.none; }\n public isUk() { return this === EnumDutyScheme.uk; }\n public isGermany() { return this === EnumDutyScheme.germany; }\n public isAustralia() { return this === EnumDutyScheme.australia; }\n public isSouthAfrica() { return this === EnumDutyScheme.southAfrica; }\n public isSweden() { return this === EnumDutyScheme.sweden; }\n public isUs() { return this === EnumDutyScheme.us; }\n public isEire() { return this === EnumDutyScheme.eire; }\n public isNz() { return this === EnumDutyScheme.nz; }\n\n public static getValues(): readonly EnumDutyScheme[] {\n return EnumDutyScheme.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumDutyScheme[] {\n return EnumDutyScheme.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumDutyScheme {\n const found = EnumDutyScheme.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDutyScheme - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumDutyScheme): EnumDutyScheme {\n const found = name ? EnumDutyScheme.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumDutyScheme - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumDutySource implements BaseEnumType {\n private static allValues: EnumDutySource[] = []; // make sure this is top-most\n \n public static none = new EnumDutySource(0, \"None\", \"enum_duty_source_none\");\n public static order = new EnumDutySource(1, \"Order\", \"enum_duty_source_order\");\n public static credit = new EnumDutySource(2, \"Credit\", \"enum_duty_source_credit\");\n public static stockAudit = new EnumDutySource(3, \"StockAudit\", \"enum_duty_source_stock_audit\");\n public static stockTransferOut = new EnumDutySource(4, \"StockTransferOut\", \"enum_duty_source_stock_transfer_out\");\n public static purchaseOrder = new EnumDutySource(5, \"PurchaseOrder\", \"enum_duty_source_purchase_order\");\n public static stockTransferIn = new EnumDutySource(6, \"StockTransferIn\", \"enum_duty_source_stock_transfer_in\");\n public static ingredientUsed = new EnumDutySource(7, \"IngredientUsed\", \"enum_duty_source_ingredient_used\");\n public static assemblyOutput = new EnumDutySource(8, \"AssemblyOutput\", \"enum_duty_source_assembly_output\");\n public static stockTake = new EnumDutySource(9, \"StockTake\", \"enum_duty_source_stock_take\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDutySource.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumDutySource.none; }\n public isOrder() { return this === EnumDutySource.order; }\n public isCredit() { return this === EnumDutySource.credit; }\n public isStockAudit() { return this === EnumDutySource.stockAudit; }\n public isStockTransferOut() { return this === EnumDutySource.stockTransferOut; }\n public isPurchaseOrder() { return this === EnumDutySource.purchaseOrder; }\n public isStockTransferIn() { return this === EnumDutySource.stockTransferIn; }\n public isIngredientUsed() { return this === EnumDutySource.ingredientUsed; }\n public isAssemblyOutput() { return this === EnumDutySource.assemblyOutput; }\n public isStockTake() { return this === EnumDutySource.stockTake; }\n\n public static getValues(): readonly EnumDutySource[] {\n return EnumDutySource.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumDutySource[] {\n return EnumDutySource.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumDutySource {\n const found = EnumDutySource.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDutySource - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumDutySource): EnumDutySource {\n const found = name ? EnumDutySource.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumDutySource - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumEcommerceConnectionStatus implements BaseEnumType {\n private static allValues: EnumEcommerceConnectionStatus[] = []; // make sure this is top-most\n \n public static pendingAuthorisation = new EnumEcommerceConnectionStatus(0, \"PendingAuthorisation\", \"enum_ecommerce_connection_status_pending_authorisation\");\n public static connected = new EnumEcommerceConnectionStatus(1, \"Connected\", \"enum_ecommerce_connection_status_connected\");\n public static disconnected = new EnumEcommerceConnectionStatus(2, \"Disconnected\", \"enum_ecommerce_connection_status_disconnected\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumEcommerceConnectionStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isPendingAuthorisation() { return this === EnumEcommerceConnectionStatus.pendingAuthorisation; }\n public isConnected() { return this === EnumEcommerceConnectionStatus.connected; }\n public isDisconnected() { return this === EnumEcommerceConnectionStatus.disconnected; }\n\n public static getValues(): readonly EnumEcommerceConnectionStatus[] {\n return EnumEcommerceConnectionStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumEcommerceConnectionStatus[] {\n return EnumEcommerceConnectionStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumEcommerceConnectionStatus {\n const found = EnumEcommerceConnectionStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumEcommerceConnectionStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumEcommerceConnectionStatus): EnumEcommerceConnectionStatus {\n const found = name ? EnumEcommerceConnectionStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumEcommerceConnectionStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumEcommerceOrderOriginType implements BaseEnumType {\n private static allValues: EnumEcommerceOrderOriginType[] = []; // make sure this is top-most\n \n public static none = new EnumEcommerceOrderOriginType(0, \"None\", \"enum_ecommerce_order_origin_type_none\");\n public static shopify = new EnumEcommerceOrderOriginType(1, \"Shopify\", \"enum_ecommerce_order_origin_type_shopify\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumEcommerceOrderOriginType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumEcommerceOrderOriginType.none; }\n public isShopify() { return this === EnumEcommerceOrderOriginType.shopify; }\n\n public static getValues(): readonly EnumEcommerceOrderOriginType[] {\n return EnumEcommerceOrderOriginType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumEcommerceOrderOriginType[] {\n return EnumEcommerceOrderOriginType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumEcommerceOrderOriginType {\n const found = EnumEcommerceOrderOriginType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumEcommerceOrderOriginType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumEcommerceOrderOriginType): EnumEcommerceOrderOriginType {\n const found = name ? EnumEcommerceOrderOriginType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumEcommerceOrderOriginType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumEdiSource implements BaseEnumType {\n private static allValues: EnumEdiSource[] = []; // make sure this is top-most\n \n public static freeway = new EnumEdiSource(1, \"Freeway\", \"enum_edi_source_freeway\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumEdiSource.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isFreeway() { return this === EnumEdiSource.freeway; }\n\n public static getValues(): readonly EnumEdiSource[] {\n return EnumEdiSource.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumEdiSource[] {\n return EnumEdiSource.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumEdiSource {\n const found = EnumEdiSource.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumEdiSource - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumEdiSource): EnumEdiSource {\n const found = name ? EnumEdiSource.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumEdiSource - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumEireAlcoholCategory implements BaseEnumType {\n private static allValues: EnumEireAlcoholCategory[] = []; // make sure this is top-most\n \n public static none = new EnumEireAlcoholCategory(0, \"None\", \"enum_eire_alcohol_category_none\");\n public static spirits = new EnumEireAlcoholCategory(1, \"Spirits\", \"enum_eire_alcohol_category_spirits\");\n public static beer = new EnumEireAlcoholCategory(2, \"Beer\", \"enum_eire_alcohol_category_beer\");\n public static wine = new EnumEireAlcoholCategory(3, \"Wine\", \"enum_eire_alcohol_category_wine\");\n public static otherFermented = new EnumEireAlcoholCategory(4, \"OtherFermented\", \"enum_eire_alcohol_category_other_fermented\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumEireAlcoholCategory.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumEireAlcoholCategory.none; }\n public isSpirits() { return this === EnumEireAlcoholCategory.spirits; }\n public isBeer() { return this === EnumEireAlcoholCategory.beer; }\n public isWine() { return this === EnumEireAlcoholCategory.wine; }\n public isOtherFermented() { return this === EnumEireAlcoholCategory.otherFermented; }\n\n public static getValues(): readonly EnumEireAlcoholCategory[] {\n return EnumEireAlcoholCategory.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumEireAlcoholCategory[] {\n return EnumEireAlcoholCategory.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumEireAlcoholCategory {\n const found = EnumEireAlcoholCategory.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumEireAlcoholCategory - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumEireAlcoholCategory): EnumEireAlcoholCategory {\n const found = name ? EnumEireAlcoholCategory.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumEireAlcoholCategory - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumEireDutyRateBand implements BaseEnumType {\n private static allValues: EnumEireDutyRateBand[] = []; // make sure this is top-most\n \n public static notDutiable = new EnumEireDutyRateBand(0, \"NotDutiable\", \"enum_eire_duty_rate_band_not_dutiable\");\n public static spiritsFrom1_21 = new EnumEireDutyRateBand(1, \"SpiritsFrom1_21\", \"enum_eire_duty_rate_band_spirits_from1_21\");\n public static beerFrom0_51To1_20 = new EnumEireDutyRateBand(2, \"BeerFrom0_51To1_20\", \"enum_eire_duty_rate_band_beer_from0_51_to1_20\");\n public static beerFrom1_21To2_80 = new EnumEireDutyRateBand(3, \"BeerFrom1_21To2_80\", \"enum_eire_duty_rate_band_beer_from1_21_to2_80\");\n public static beerFrom2_81 = new EnumEireDutyRateBand(4, \"BeerFrom2_81\", \"enum_eire_duty_rate_band_beer_from2_81\");\n public static wineTo5_50 = new EnumEireDutyRateBand(5, \"WineTo5_50\", \"enum_eire_duty_rate_band_wine_to5_50\");\n public static stillWineFrom5_51To15_00 = new EnumEireDutyRateBand(6, \"StillWineFrom5_51To15_00\", \"enum_eire_duty_rate_band_still_wine_from5_51_to15_00\");\n public static stillWineFrom15_01 = new EnumEireDutyRateBand(7, \"StillWineFrom15_01\", \"enum_eire_duty_rate_band_still_wine_from15_01\");\n public static sparklingWineFrom5_51 = new EnumEireDutyRateBand(8, \"SparklingWineFrom5_51\", \"enum_eire_duty_rate_band_sparkling_wine_from5_51\");\n public static ciderPerryTo2_80 = new EnumEireDutyRateBand(9, \"CiderPerryTo2_80\", \"enum_eire_duty_rate_band_cider_perry_to2_80\");\n public static ciderPerryFrom2_81To6_00 = new EnumEireDutyRateBand(10, \"CiderPerryFrom2_81To6_00\", \"enum_eire_duty_rate_band_cider_perry_from2_81_to6_00\");\n public static ciderPerryFrom6_01To8_50 = new EnumEireDutyRateBand(11, \"CiderPerryFrom6_01To8_50\", \"enum_eire_duty_rate_band_cider_perry_from6_01_to8_50\");\n public static stillCiderPerryFrom8_51 = new EnumEireDutyRateBand(12, \"StillCiderPerryFrom8_51\", \"enum_eire_duty_rate_band_still_cider_perry_from8_51\");\n public static sparklingCiderPerryFrom8_51 = new EnumEireDutyRateBand(13, \"SparklingCiderPerryFrom8_51\", \"enum_eire_duty_rate_band_sparkling_cider_perry_from8_51\");\n public static otherFermentedTo5_50 = new EnumEireDutyRateBand(14, \"OtherFermentedTo5_50\", \"enum_eire_duty_rate_band_other_fermented_to5_50\");\n public static stillOtherFermentedFrom5_51 = new EnumEireDutyRateBand(15, \"StillOtherFermentedFrom5_51\", \"enum_eire_duty_rate_band_still_other_fermented_from5_51\");\n public static sparklingOtherFermentedFrom5_51 = new EnumEireDutyRateBand(16, \"SparklingOtherFermentedFrom5_51\", \"enum_eire_duty_rate_band_sparkling_other_fermented_from5_51\");\n public static stillIntermediateTo15_00 = new EnumEireDutyRateBand(17, \"StillIntermediateTo15_00\", \"enum_eire_duty_rate_band_still_intermediate_to15_00\");\n public static stillIntermediateFrom15_01 = new EnumEireDutyRateBand(18, \"StillIntermediateFrom15_01\", \"enum_eire_duty_rate_band_still_intermediate_from15_01\");\n public static sparklingIntermediate = new EnumEireDutyRateBand(19, \"SparklingIntermediate\", \"enum_eire_duty_rate_band_sparkling_intermediate\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumEireDutyRateBand.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNotDutiable() { return this === EnumEireDutyRateBand.notDutiable; }\n public isSpiritsFrom1_21() { return this === EnumEireDutyRateBand.spiritsFrom1_21; }\n public isBeerFrom0_51To1_20() { return this === EnumEireDutyRateBand.beerFrom0_51To1_20; }\n public isBeerFrom1_21To2_80() { return this === EnumEireDutyRateBand.beerFrom1_21To2_80; }\n public isBeerFrom2_81() { return this === EnumEireDutyRateBand.beerFrom2_81; }\n public isWineTo5_50() { return this === EnumEireDutyRateBand.wineTo5_50; }\n public isStillWineFrom5_51To15_00() { return this === EnumEireDutyRateBand.stillWineFrom5_51To15_00; }\n public isStillWineFrom15_01() { return this === EnumEireDutyRateBand.stillWineFrom15_01; }\n public isSparklingWineFrom5_51() { return this === EnumEireDutyRateBand.sparklingWineFrom5_51; }\n public isCiderPerryTo2_80() { return this === EnumEireDutyRateBand.ciderPerryTo2_80; }\n public isCiderPerryFrom2_81To6_00() { return this === EnumEireDutyRateBand.ciderPerryFrom2_81To6_00; }\n public isCiderPerryFrom6_01To8_50() { return this === EnumEireDutyRateBand.ciderPerryFrom6_01To8_50; }\n public isStillCiderPerryFrom8_51() { return this === EnumEireDutyRateBand.stillCiderPerryFrom8_51; }\n public isSparklingCiderPerryFrom8_51() { return this === EnumEireDutyRateBand.sparklingCiderPerryFrom8_51; }\n public isOtherFermentedTo5_50() { return this === EnumEireDutyRateBand.otherFermentedTo5_50; }\n public isStillOtherFermentedFrom5_51() { return this === EnumEireDutyRateBand.stillOtherFermentedFrom5_51; }\n public isSparklingOtherFermentedFrom5_51() { return this === EnumEireDutyRateBand.sparklingOtherFermentedFrom5_51; }\n public isStillIntermediateTo15_00() { return this === EnumEireDutyRateBand.stillIntermediateTo15_00; }\n public isStillIntermediateFrom15_01() { return this === EnumEireDutyRateBand.stillIntermediateFrom15_01; }\n public isSparklingIntermediate() { return this === EnumEireDutyRateBand.sparklingIntermediate; }\n\n public static getValues(): readonly EnumEireDutyRateBand[] {\n return EnumEireDutyRateBand.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumEireDutyRateBand[] {\n return EnumEireDutyRateBand.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumEireDutyRateBand {\n const found = EnumEireDutyRateBand.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumEireDutyRateBand - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumEireDutyRateBand): EnumEireDutyRateBand {\n const found = name ? EnumEireDutyRateBand.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumEireDutyRateBand - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumEireMovementType implements BaseEnumType {\n private static allValues: EnumEireMovementType[] = []; // make sure this is top-most\n \n public static unknown = new EnumEireMovementType(0, \"Unknown\", \"enum_eire_movement_type_unknown\");\n public static otherMemberStatesOfEu = new EnumEireMovementType(1, \"OtherMemberStatesOfEu\", \"enum_eire_movement_type_other_member_states_of_eu\");\n public static thirdCountries = new EnumEireMovementType(2, \"ThirdCountries\", \"enum_eire_movement_type_third_countries\");\n public static otherWarehouses = new EnumEireMovementType(3, \"OtherWarehouses\", \"enum_eire_movement_type_other_warehouses\");\n public static distillery = new EnumEireMovementType(4, \"Distillery\", \"enum_eire_movement_type_distillery\");\n public static operations = new EnumEireMovementType(5, \"Operations\", \"enum_eire_movement_type_operations\");\n public static increasesInOperations = new EnumEireMovementType(6, \"IncreasesInOperations\", \"enum_eire_movement_type_increases_in_operations\");\n public static deficienciesReturned = new EnumEireMovementType(7, \"DeficienciesReturned\", \"enum_eire_movement_type_deficiencies_returned\");\n public static homeConsumption = new EnumEireMovementType(8, \"HomeConsumption\", \"enum_eire_movement_type_home_consumption\");\n public static lossesInOperations = new EnumEireMovementType(9, \"LossesInOperations\", \"enum_eire_movement_type_losses_in_operations\");\n public static dutyFreeShops = new EnumEireMovementType(10, \"DutyFreeShops\", \"enum_eire_movement_type_duty_free_shops\");\n public static shipsStores = new EnumEireMovementType(11, \"ShipsStores\", \"enum_eire_movement_type_ships_stores\");\n public static inFlightCatering = new EnumEireMovementType(12, \"InFlightCatering\", \"enum_eire_movement_type_in_flight_catering\");\n public static diplomaticPrivilege = new EnumEireMovementType(13, \"DiplomaticPrivilege\", \"enum_eire_movement_type_diplomatic_privilege\");\n public static otherDutyFreeUse = new EnumEireMovementType(14, \"OtherDutyFreeUse\", \"enum_eire_movement_type_other_duty_free_use\");\n public static denaturing = new EnumEireMovementType(15, \"Denaturing\", \"enum_eire_movement_type_denaturing\");\n public static destruction = new EnumEireMovementType(16, \"Destruction\", \"enum_eire_movement_type_destruction\");\n public static dutiableDeficiencies = new EnumEireMovementType(17, \"DutiableDeficiencies\", \"enum_eire_movement_type_dutiable_deficiencies\");\n public static dutyExemptDeficiencies = new EnumEireMovementType(18, \"DutyExemptDeficiencies\", \"enum_eire_movement_type_duty_exempt_deficiencies\");\n public static other = new EnumEireMovementType(19, \"Other\", \"enum_eire_movement_type_other\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumEireMovementType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isUnknown() { return this === EnumEireMovementType.unknown; }\n public isOtherMemberStatesOfEu() { return this === EnumEireMovementType.otherMemberStatesOfEu; }\n public isThirdCountries() { return this === EnumEireMovementType.thirdCountries; }\n public isOtherWarehouses() { return this === EnumEireMovementType.otherWarehouses; }\n public isDistillery() { return this === EnumEireMovementType.distillery; }\n public isOperations() { return this === EnumEireMovementType.operations; }\n public isIncreasesInOperations() { return this === EnumEireMovementType.increasesInOperations; }\n public isDeficienciesReturned() { return this === EnumEireMovementType.deficienciesReturned; }\n public isHomeConsumption() { return this === EnumEireMovementType.homeConsumption; }\n public isLossesInOperations() { return this === EnumEireMovementType.lossesInOperations; }\n public isDutyFreeShops() { return this === EnumEireMovementType.dutyFreeShops; }\n public isShipsStores() { return this === EnumEireMovementType.shipsStores; }\n public isInFlightCatering() { return this === EnumEireMovementType.inFlightCatering; }\n public isDiplomaticPrivilege() { return this === EnumEireMovementType.diplomaticPrivilege; }\n public isOtherDutyFreeUse() { return this === EnumEireMovementType.otherDutyFreeUse; }\n public isDenaturing() { return this === EnumEireMovementType.denaturing; }\n public isDestruction() { return this === EnumEireMovementType.destruction; }\n public isDutiableDeficiencies() { return this === EnumEireMovementType.dutiableDeficiencies; }\n public isDutyExemptDeficiencies() { return this === EnumEireMovementType.dutyExemptDeficiencies; }\n public isOther() { return this === EnumEireMovementType.other; }\n\n public static getValues(): readonly EnumEireMovementType[] {\n return EnumEireMovementType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumEireMovementType[] {\n return EnumEireMovementType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumEireMovementType {\n const found = EnumEireMovementType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumEireMovementType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumEireMovementType): EnumEireMovementType {\n const found = name ? EnumEireMovementType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumEireMovementType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumEmailContext implements BaseEnumType {\n private static allValues: EnumEmailContext[] = []; // make sure this is top-most\n \n public static unknown = new EnumEmailContext(0, \"Unknown\", \"enum_email_context_unknown\");\n public static invoice = new EnumEmailContext(1, \"Invoice\", \"enum_email_context_invoice\");\n public static purchaseOrder = new EnumEmailContext(2, \"PurchaseOrder\", \"enum_email_context_purchase_order\");\n public static passwordReset = new EnumEmailContext(3, \"PasswordReset\", \"enum_email_context_password_reset\");\n public static despatchNote = new EnumEmailContext(4, \"DespatchNote\", \"enum_email_context_despatch_note\");\n public static userFeedback = new EnumEmailContext(5, \"UserFeedback\", \"enum_email_context_user_feedback\");\n public static creditNote = new EnumEmailContext(6, \"CreditNote\", \"enum_email_context_credit_note\");\n public static userInvitation = new EnumEmailContext(7, \"UserInvitation\", \"enum_email_context_user_invitation\");\n public static despatchNotification = new EnumEmailContext(8, \"DespatchNotification\", \"enum_email_context_despatch_notification\");\n public static taskNotification = new EnumEmailContext(9, \"TaskNotification\", \"enum_email_context_task_notification\");\n public static outletPriceList = new EnumEmailContext(10, \"OutletPriceList\", \"enum_email_context_outlet_price_list\");\n public static labelOrder = new EnumEmailContext(11, \"LabelOrder\", \"enum_email_context_label_order\");\n public static proFormaInvoice = new EnumEmailContext(12, \"ProFormaInvoice\", \"enum_email_context_pro_forma_invoice\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumEmailContext.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isUnknown() { return this === EnumEmailContext.unknown; }\n public isInvoice() { return this === EnumEmailContext.invoice; }\n public isPurchaseOrder() { return this === EnumEmailContext.purchaseOrder; }\n public isPasswordReset() { return this === EnumEmailContext.passwordReset; }\n public isDespatchNote() { return this === EnumEmailContext.despatchNote; }\n public isUserFeedback() { return this === EnumEmailContext.userFeedback; }\n public isCreditNote() { return this === EnumEmailContext.creditNote; }\n public isUserInvitation() { return this === EnumEmailContext.userInvitation; }\n public isDespatchNotification() { return this === EnumEmailContext.despatchNotification; }\n public isTaskNotification() { return this === EnumEmailContext.taskNotification; }\n public isOutletPriceList() { return this === EnumEmailContext.outletPriceList; }\n public isLabelOrder() { return this === EnumEmailContext.labelOrder; }\n public isProFormaInvoice() { return this === EnumEmailContext.proFormaInvoice; }\n\n public static getValues(): readonly EnumEmailContext[] {\n return EnumEmailContext.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumEmailContext[] {\n return EnumEmailContext.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumEmailContext {\n const found = EnumEmailContext.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumEmailContext - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumEmailContext): EnumEmailContext {\n const found = name ? EnumEmailContext.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumEmailContext - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumEmailDocumentGrouping implements BaseEnumType {\n private static allValues: EnumEmailDocumentGrouping[] = []; // make sure this is top-most\n \n public static unknown = new EnumEmailDocumentGrouping(0, \"Unknown\", \"enum_email_document_grouping_unknown\");\n public static multipleDocumentsPerAttachment = new EnumEmailDocumentGrouping(1, \"MultipleDocumentsPerAttachment\", \"enum_email_document_grouping_multiple_documents_per_attachment\");\n public static multipleSingleDocumentAttachmentsPerEmail = new EnumEmailDocumentGrouping(2, \"MultipleSingleDocumentAttachmentsPerEmail\", \"enum_email_document_grouping_multiple_single_document_attachments_per_email\");\n public static singleDocumentPerEmail = new EnumEmailDocumentGrouping(3, \"SingleDocumentPerEmail\", \"enum_email_document_grouping_single_document_per_email\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumEmailDocumentGrouping.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isUnknown() { return this === EnumEmailDocumentGrouping.unknown; }\n public isMultipleDocumentsPerAttachment() { return this === EnumEmailDocumentGrouping.multipleDocumentsPerAttachment; }\n public isMultipleSingleDocumentAttachmentsPerEmail() { return this === EnumEmailDocumentGrouping.multipleSingleDocumentAttachmentsPerEmail; }\n public isSingleDocumentPerEmail() { return this === EnumEmailDocumentGrouping.singleDocumentPerEmail; }\n\n public static getValues(): readonly EnumEmailDocumentGrouping[] {\n return EnumEmailDocumentGrouping.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumEmailDocumentGrouping[] {\n return EnumEmailDocumentGrouping.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumEmailDocumentGrouping {\n const found = EnumEmailDocumentGrouping.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumEmailDocumentGrouping - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumEmailDocumentGrouping): EnumEmailDocumentGrouping {\n const found = name ? EnumEmailDocumentGrouping.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumEmailDocumentGrouping - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumEmailType implements BaseEnumType {\n private static allValues: EnumEmailType[] = []; // make sure this is top-most\n \n public static mSOutlook = new EnumEmailType(0, \"MSOutlook\", \"enum_email_type_m_s_outlook\");\n public static sMTP = new EnumEmailType(1, \"SMTP\", \"enum_email_type_s_m_t_p\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumEmailType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isMSOutlook() { return this === EnumEmailType.mSOutlook; }\n public isSMTP() { return this === EnumEmailType.sMTP; }\n\n public static getValues(): readonly EnumEmailType[] {\n return EnumEmailType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumEmailType[] {\n return EnumEmailType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumEmailType {\n const found = EnumEmailType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumEmailType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumEmailType): EnumEmailType {\n const found = name ? EnumEmailType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumEmailType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumExportIncotermCode implements BaseEnumType {\n private static allValues: EnumExportIncotermCode[] = []; // make sure this is top-most\n \n public static none = new EnumExportIncotermCode(0, \"None\", \"enum_export_incoterm_code_none\");\n public static eXW = new EnumExportIncotermCode(1, \"EXW\", \"enum_export_incoterm_code_e_x_w\");\n public static fCA = new EnumExportIncotermCode(2, \"FCA\", \"enum_export_incoterm_code_f_c_a\");\n public static fAS = new EnumExportIncotermCode(3, \"FAS\", \"enum_export_incoterm_code_f_a_s\");\n public static fOB = new EnumExportIncotermCode(4, \"FOB\", \"enum_export_incoterm_code_f_o_b\");\n public static cFR = new EnumExportIncotermCode(5, \"CFR\", \"enum_export_incoterm_code_c_f_r\");\n public static cIF = new EnumExportIncotermCode(6, \"CIF\", \"enum_export_incoterm_code_c_i_f\");\n public static cIP = new EnumExportIncotermCode(7, \"CIP\", \"enum_export_incoterm_code_c_i_p\");\n public static dPU = new EnumExportIncotermCode(8, \"DPU\", \"enum_export_incoterm_code_d_p_u\");\n public static dDP = new EnumExportIncotermCode(9, \"DDP\", \"enum_export_incoterm_code_d_d_p\");\n public static cPT = new EnumExportIncotermCode(10, \"CPT\", \"enum_export_incoterm_code_c_p_t\");\n public static dAP = new EnumExportIncotermCode(11, \"DAP\", \"enum_export_incoterm_code_d_a_p\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumExportIncotermCode.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumExportIncotermCode.none; }\n public isEXW() { return this === EnumExportIncotermCode.eXW; }\n public isFCA() { return this === EnumExportIncotermCode.fCA; }\n public isFAS() { return this === EnumExportIncotermCode.fAS; }\n public isFOB() { return this === EnumExportIncotermCode.fOB; }\n public isCFR() { return this === EnumExportIncotermCode.cFR; }\n public isCIF() { return this === EnumExportIncotermCode.cIF; }\n public isCIP() { return this === EnumExportIncotermCode.cIP; }\n public isDPU() { return this === EnumExportIncotermCode.dPU; }\n public isDDP() { return this === EnumExportIncotermCode.dDP; }\n public isCPT() { return this === EnumExportIncotermCode.cPT; }\n public isDAP() { return this === EnumExportIncotermCode.dAP; }\n\n public static getValues(): readonly EnumExportIncotermCode[] {\n return EnumExportIncotermCode.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumExportIncotermCode[] {\n return EnumExportIncotermCode.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumExportIncotermCode {\n const found = EnumExportIncotermCode.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumExportIncotermCode - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumExportIncotermCode): EnumExportIncotermCode {\n const found = name ? EnumExportIncotermCode.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumExportIncotermCode - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumExternalCalendarProvider implements BaseEnumType {\n private static allValues: EnumExternalCalendarProvider[] = []; // make sure this is top-most\n \n public static none = new EnumExternalCalendarProvider(0, \"None\", \"enum_external_calendar_provider_none\");\n public static google = new EnumExternalCalendarProvider(1, \"Google\", \"enum_external_calendar_provider_google\");\n public static microsoft = new EnumExternalCalendarProvider(2, \"Microsoft\", \"enum_external_calendar_provider_microsoft\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumExternalCalendarProvider.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumExternalCalendarProvider.none; }\n public isGoogle() { return this === EnumExternalCalendarProvider.google; }\n public isMicrosoft() { return this === EnumExternalCalendarProvider.microsoft; }\n\n public static getValues(): readonly EnumExternalCalendarProvider[] {\n return EnumExternalCalendarProvider.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumExternalCalendarProvider[] {\n return EnumExternalCalendarProvider.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumExternalCalendarProvider {\n const found = EnumExternalCalendarProvider.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumExternalCalendarProvider - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumExternalCalendarProvider): EnumExternalCalendarProvider {\n const found = name ? EnumExternalCalendarProvider.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumExternalCalendarProvider - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumExternalOrderStatus implements BaseEnumType {\n private static allValues: EnumExternalOrderStatus[] = []; // make sure this is top-most\n \n public static newOrder = new EnumExternalOrderStatus(0, \"NewOrder\", \"enum_external_order_status_new_order\");\n public static inBrewMan = new EnumExternalOrderStatus(1, \"InBrewMan\", \"enum_external_order_status_in_brew_man\");\n public static delivered = new EnumExternalOrderStatus(2, \"Delivered\", \"enum_external_order_status_delivered\");\n public static complete = new EnumExternalOrderStatus(3, \"Complete\", \"enum_external_order_status_complete\");\n public static releasedToBrewMan = new EnumExternalOrderStatus(4, \"ReleasedToBrewMan\", \"enum_external_order_status_released_to_brew_man\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumExternalOrderStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNewOrder() { return this === EnumExternalOrderStatus.newOrder; }\n public isInBrewMan() { return this === EnumExternalOrderStatus.inBrewMan; }\n public isDelivered() { return this === EnumExternalOrderStatus.delivered; }\n public isComplete() { return this === EnumExternalOrderStatus.complete; }\n public isReleasedToBrewMan() { return this === EnumExternalOrderStatus.releasedToBrewMan; }\n\n public static getValues(): readonly EnumExternalOrderStatus[] {\n return EnumExternalOrderStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumExternalOrderStatus[] {\n return EnumExternalOrderStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumExternalOrderStatus {\n const found = EnumExternalOrderStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumExternalOrderStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumExternalOrderStatus): EnumExternalOrderStatus {\n const found = name ? EnumExternalOrderStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumExternalOrderStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumFileType implements BaseEnumType {\n private static allValues: EnumFileType[] = []; // make sure this is top-most\n \n public static image = new EnumFileType(0, \"Image\", \"enum_file_type_image\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumFileType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isImage() { return this === EnumFileType.image; }\n\n public static getValues(): readonly EnumFileType[] {\n return EnumFileType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumFileType[] {\n return EnumFileType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumFileType {\n const found = EnumFileType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumFileType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumFileType): EnumFileType {\n const found = name ? EnumFileType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumFileType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumFilteringOperation implements BaseEnumType {\n private static allValues: EnumFilteringOperation[] = []; // make sure this is top-most\n \n public static none = new EnumFilteringOperation(0, \"None\", \"enum_filtering_operation_none\");\n public static equals = new EnumFilteringOperation(1, \"Equals\", \"enum_filtering_operation_equals\");\n public static notEquals = new EnumFilteringOperation(2, \"NotEquals\", \"enum_filtering_operation_not_equals\");\n public static lessThan = new EnumFilteringOperation(3, \"LessThan\", \"enum_filtering_operation_less_than\");\n public static lessThanOrEquals = new EnumFilteringOperation(4, \"LessThanOrEquals\", \"enum_filtering_operation_less_than_or_equals\");\n public static greaterThan = new EnumFilteringOperation(5, \"GreaterThan\", \"enum_filtering_operation_greater_than\");\n public static greaterThanOrEquals = new EnumFilteringOperation(6, \"GreaterThanOrEquals\", \"enum_filtering_operation_greater_than_or_equals\");\n public static contains = new EnumFilteringOperation(7, \"Contains\", \"enum_filtering_operation_contains\");\n public static notContains = new EnumFilteringOperation(8, \"NotContains\", \"enum_filtering_operation_not_contains\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumFilteringOperation.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumFilteringOperation.none; }\n public isEquals() { return this === EnumFilteringOperation.equals; }\n public isNotEquals() { return this === EnumFilteringOperation.notEquals; }\n public isLessThan() { return this === EnumFilteringOperation.lessThan; }\n public isLessThanOrEquals() { return this === EnumFilteringOperation.lessThanOrEquals; }\n public isGreaterThan() { return this === EnumFilteringOperation.greaterThan; }\n public isGreaterThanOrEquals() { return this === EnumFilteringOperation.greaterThanOrEquals; }\n public isContains() { return this === EnumFilteringOperation.contains; }\n public isNotContains() { return this === EnumFilteringOperation.notContains; }\n\n public static getValues(): readonly EnumFilteringOperation[] {\n return EnumFilteringOperation.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumFilteringOperation[] {\n return EnumFilteringOperation.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumFilteringOperation {\n const found = EnumFilteringOperation.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumFilteringOperation - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumFilteringOperation): EnumFilteringOperation {\n const found = name ? EnumFilteringOperation.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumFilteringOperation - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumGermanBeerDutyMovementType implements BaseEnumType {\n private static allValues: EnumGermanBeerDutyMovementType[] = []; // make sure this is top-most\n \n public static none = new EnumGermanBeerDutyMovementType(0, \"None\", \"enum_german_beer_duty_movement_type_none\");\n public static dutiableRemoval = new EnumGermanBeerDutyMovementType(1, \"DutiableRemoval\", \"enum_german_beer_duty_movement_type_dutiable_removal\");\n public static dutyReclaimableReturn = new EnumGermanBeerDutyMovementType(2, \"DutyReclaimableReturn\", \"enum_german_beer_duty_movement_type_duty_reclaimable_return\");\n public static dutyExemptRemovalForEmployees = new EnumGermanBeerDutyMovementType(4, \"DutyExemptRemovalForEmployees\", \"enum_german_beer_duty_movement_type_duty_exempt_removal_for_employees\");\n public static dutySuspendedRemovalStayingInGermany = new EnumGermanBeerDutyMovementType(5, \"DutySuspendedRemovalStayingInGermany\", \"enum_german_beer_duty_movement_type_duty_suspended_removal_staying_in_germany\");\n public static dutyExemptRemovalGoingToEU = new EnumGermanBeerDutyMovementType(6, \"DutyExemptRemovalGoingToEU\", \"enum_german_beer_duty_movement_type_duty_exempt_removal_going_to_e_u\");\n public static otherDutyExemptRemoval = new EnumGermanBeerDutyMovementType(7, \"OtherDutyExemptRemoval\", \"enum_german_beer_duty_movement_type_other_duty_exempt_removal\");\n public static dutyUnpaidReturn = new EnumGermanBeerDutyMovementType(8, \"DutyUnpaidReturn\", \"enum_german_beer_duty_movement_type_duty_unpaid_return\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumGermanBeerDutyMovementType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumGermanBeerDutyMovementType.none; }\n public isDutiableRemoval() { return this === EnumGermanBeerDutyMovementType.dutiableRemoval; }\n public isDutyReclaimableReturn() { return this === EnumGermanBeerDutyMovementType.dutyReclaimableReturn; }\n public isDutyExemptRemovalForEmployees() { return this === EnumGermanBeerDutyMovementType.dutyExemptRemovalForEmployees; }\n public isDutySuspendedRemovalStayingInGermany() { return this === EnumGermanBeerDutyMovementType.dutySuspendedRemovalStayingInGermany; }\n public isDutyExemptRemovalGoingToEU() { return this === EnumGermanBeerDutyMovementType.dutyExemptRemovalGoingToEU; }\n public isOtherDutyExemptRemoval() { return this === EnumGermanBeerDutyMovementType.otherDutyExemptRemoval; }\n public isDutyUnpaidReturn() { return this === EnumGermanBeerDutyMovementType.dutyUnpaidReturn; }\n\n public static getValues(): readonly EnumGermanBeerDutyMovementType[] {\n return EnumGermanBeerDutyMovementType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumGermanBeerDutyMovementType[] {\n return EnumGermanBeerDutyMovementType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumGermanBeerDutyMovementType {\n const found = EnumGermanBeerDutyMovementType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumGermanBeerDutyMovementType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumGermanBeerDutyMovementType): EnumGermanBeerDutyMovementType {\n const found = name ? EnumGermanBeerDutyMovementType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumGermanBeerDutyMovementType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumGermanBeerDutyProductType implements BaseEnumType {\n private static allValues: EnumGermanBeerDutyProductType[] = []; // make sure this is top-most\n \n public static none = new EnumGermanBeerDutyProductType(0, \"None\", \"enum_german_beer_duty_product_type_none\");\n public static ownBrewedBeer_E = new EnumGermanBeerDutyProductType(1, \"OwnBrewedBeer_E\", \"enum_german_beer_duty_product_type_own_brewed_beer__e\");\n public static brewedByUsFor3rdParty_L = new EnumGermanBeerDutyProductType(2, \"BrewedByUsFor3rdParty_L\", \"enum_german_beer_duty_product_type_brewed_by_us_for3rd_party__l\");\n public static brewedBy3rdPartyForUs_F = new EnumGermanBeerDutyProductType(3, \"BrewedBy3rdPartyForUs_F\", \"enum_german_beer_duty_product_type_brewed_by3rd_party_for_us__f\");\n public static mixedProduct_M = new EnumGermanBeerDutyProductType(4, \"MixedProduct_M\", \"enum_german_beer_duty_product_type_mixed_product__m\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumGermanBeerDutyProductType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumGermanBeerDutyProductType.none; }\n public isOwnBrewedBeer_E() { return this === EnumGermanBeerDutyProductType.ownBrewedBeer_E; }\n public isBrewedByUsFor3rdParty_L() { return this === EnumGermanBeerDutyProductType.brewedByUsFor3rdParty_L; }\n public isBrewedBy3rdPartyForUs_F() { return this === EnumGermanBeerDutyProductType.brewedBy3rdPartyForUs_F; }\n public isMixedProduct_M() { return this === EnumGermanBeerDutyProductType.mixedProduct_M; }\n\n public static getValues(): readonly EnumGermanBeerDutyProductType[] {\n return EnumGermanBeerDutyProductType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumGermanBeerDutyProductType[] {\n return EnumGermanBeerDutyProductType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumGermanBeerDutyProductType {\n const found = EnumGermanBeerDutyProductType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumGermanBeerDutyProductType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumGermanBeerDutyProductType): EnumGermanBeerDutyProductType {\n const found = name ? EnumGermanBeerDutyProductType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumGermanBeerDutyProductType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumGermanBeerDutyReturnCellProductType implements BaseEnumType {\n private static allValues: EnumGermanBeerDutyReturnCellProductType[] = []; // make sure this is top-most\n \n public static none = new EnumGermanBeerDutyReturnCellProductType(0, \"None\", \"enum_german_beer_duty_return_cell_product_type_none\");\n public static ownBrewedBeer_E = new EnumGermanBeerDutyReturnCellProductType(1, \"OwnBrewedBeer_E\", \"enum_german_beer_duty_return_cell_product_type_own_brewed_beer__e\");\n public static brewedByUsFor3rdParty_L = new EnumGermanBeerDutyReturnCellProductType(2, \"BrewedByUsFor3rdParty_L\", \"enum_german_beer_duty_return_cell_product_type_brewed_by_us_for3rd_party__l\");\n public static brewedBy3rdPartyForUs_F = new EnumGermanBeerDutyReturnCellProductType(3, \"BrewedBy3rdPartyForUs_F\", \"enum_german_beer_duty_return_cell_product_type_brewed_by3rd_party_for_us__f\");\n public static mixedProduct_M = new EnumGermanBeerDutyReturnCellProductType(4, \"MixedProduct_M\", \"enum_german_beer_duty_return_cell_product_type_mixed_product__m\");\n public static ownBeerWithinMixedProduct_A = new EnumGermanBeerDutyReturnCellProductType(5, \"OwnBeerWithinMixedProduct_A\", \"enum_german_beer_duty_return_cell_product_type_own_beer_within_mixed_product__a\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumGermanBeerDutyReturnCellProductType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumGermanBeerDutyReturnCellProductType.none; }\n public isOwnBrewedBeer_E() { return this === EnumGermanBeerDutyReturnCellProductType.ownBrewedBeer_E; }\n public isBrewedByUsFor3rdParty_L() { return this === EnumGermanBeerDutyReturnCellProductType.brewedByUsFor3rdParty_L; }\n public isBrewedBy3rdPartyForUs_F() { return this === EnumGermanBeerDutyReturnCellProductType.brewedBy3rdPartyForUs_F; }\n public isMixedProduct_M() { return this === EnumGermanBeerDutyReturnCellProductType.mixedProduct_M; }\n public isOwnBeerWithinMixedProduct_A() { return this === EnumGermanBeerDutyReturnCellProductType.ownBeerWithinMixedProduct_A; }\n\n public static getValues(): readonly EnumGermanBeerDutyReturnCellProductType[] {\n return EnumGermanBeerDutyReturnCellProductType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumGermanBeerDutyReturnCellProductType[] {\n return EnumGermanBeerDutyReturnCellProductType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumGermanBeerDutyReturnCellProductType {\n const found = EnumGermanBeerDutyReturnCellProductType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumGermanBeerDutyReturnCellProductType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumGermanBeerDutyReturnCellProductType): EnumGermanBeerDutyReturnCellProductType {\n const found = name ? EnumGermanBeerDutyReturnCellProductType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumGermanBeerDutyReturnCellProductType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumGroupingOperation implements BaseEnumType {\n private static allValues: EnumGroupingOperation[] = []; // make sure this is top-most\n \n public static none = new EnumGroupingOperation(0, \"None\", \"enum_grouping_operation_none\");\n public static value = new EnumGroupingOperation(1, \"Value\", \"enum_grouping_operation_value\");\n public static year = new EnumGroupingOperation(2, \"Year\", \"enum_grouping_operation_year\");\n public static yearAndMonth = new EnumGroupingOperation(3, \"YearAndMonth\", \"enum_grouping_operation_year_and_month\");\n public static monthOfYear = new EnumGroupingOperation(4, \"MonthOfYear\", \"enum_grouping_operation_month_of_year\");\n public static dayOfWeek = new EnumGroupingOperation(5, \"DayOfWeek\", \"enum_grouping_operation_day_of_week\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumGroupingOperation.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumGroupingOperation.none; }\n public isValue() { return this === EnumGroupingOperation.value; }\n public isYear() { return this === EnumGroupingOperation.year; }\n public isYearAndMonth() { return this === EnumGroupingOperation.yearAndMonth; }\n public isMonthOfYear() { return this === EnumGroupingOperation.monthOfYear; }\n public isDayOfWeek() { return this === EnumGroupingOperation.dayOfWeek; }\n\n public static getValues(): readonly EnumGroupingOperation[] {\n return EnumGroupingOperation.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumGroupingOperation[] {\n return EnumGroupingOperation.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumGroupingOperation {\n const found = EnumGroupingOperation.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumGroupingOperation - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumGroupingOperation): EnumGroupingOperation {\n const found = name ? EnumGroupingOperation.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumGroupingOperation - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumHistoryDateRangePick implements BaseEnumType {\n private static allValues: EnumHistoryDateRangePick[] = []; // make sure this is top-most\n \n public static today = new EnumHistoryDateRangePick(1, \"Today\", \"enum_history_date_range_pick_today\");\n public static weekToDate = new EnumHistoryDateRangePick(2, \"WeekToDate\", \"enum_history_date_range_pick_week_to_date\");\n public static week = new EnumHistoryDateRangePick(3, \"Week\", \"enum_history_date_range_pick_week\");\n public static monthToDate = new EnumHistoryDateRangePick(4, \"MonthToDate\", \"enum_history_date_range_pick_month_to_date\");\n public static month = new EnumHistoryDateRangePick(5, \"Month\", \"enum_history_date_range_pick_month\");\n public static yearToDate = new EnumHistoryDateRangePick(6, \"YearToDate\", \"enum_history_date_range_pick_year_to_date\");\n public static year = new EnumHistoryDateRangePick(7, \"Year\", \"enum_history_date_range_pick_year\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumHistoryDateRangePick.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isToday() { return this === EnumHistoryDateRangePick.today; }\n public isWeekToDate() { return this === EnumHistoryDateRangePick.weekToDate; }\n public isWeek() { return this === EnumHistoryDateRangePick.week; }\n public isMonthToDate() { return this === EnumHistoryDateRangePick.monthToDate; }\n public isMonth() { return this === EnumHistoryDateRangePick.month; }\n public isYearToDate() { return this === EnumHistoryDateRangePick.yearToDate; }\n public isYear() { return this === EnumHistoryDateRangePick.year; }\n\n public static getValues(): readonly EnumHistoryDateRangePick[] {\n return EnumHistoryDateRangePick.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumHistoryDateRangePick[] {\n return EnumHistoryDateRangePick.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumHistoryDateRangePick {\n const found = EnumHistoryDateRangePick.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumHistoryDateRangePick - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumHistoryDateRangePick): EnumHistoryDateRangePick {\n const found = name ? EnumHistoryDateRangePick.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumHistoryDateRangePick - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumIntegrationType implements BaseEnumType {\n private static allValues: EnumIntegrationType[] = []; // make sure this is top-most\n \n public static unknown = new EnumIntegrationType(0, \"Unknown\", \"enum_integration_type_unknown\");\n public static sellar = new EnumIntegrationType(1, \"Sellar\", \"enum_integration_type_sellar\");\n public static shopify = new EnumIntegrationType(2, \"Shopify\", \"enum_integration_type_shopify\");\n public static wooCommerce = new EnumIntegrationType(3, \"WooCommerce\", \"enum_integration_type_woo_commerce\");\n public static zettle = new EnumIntegrationType(4, \"Zettle\", \"enum_integration_type_zettle\");\n public static eposNow = new EnumIntegrationType(5, \"EposNow\", \"enum_integration_type_epos_now\");\n public static beerflex = new EnumIntegrationType(6, \"Beerflex\", \"enum_integration_type_beerflex\");\n public static square = new EnumIntegrationType(7, \"Square\", \"enum_integration_type_square\");\n public static squarespace = new EnumIntegrationType(8, \"Squarespace\", \"enum_integration_type_squarespace\");\n public static integrateOnce = new EnumIntegrationType(9, \"IntegrateOnce\", \"enum_integration_type_integrate_once\");\n public static ecwid = new EnumIntegrationType(10, \"Ecwid\", \"enum_integration_type_ecwid\");\n public static eeBria = new EnumIntegrationType(11, \"EeBria\", \"enum_integration_type_ee_bria\");\n public static commerce7 = new EnumIntegrationType(12, \"Commerce7\", \"enum_integration_type_commerce7\");\n public static amazon = new EnumIntegrationType(13, \"Amazon\", \"enum_integration_type_amazon\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumIntegrationType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isUnknown() { return this === EnumIntegrationType.unknown; }\n public isSellar() { return this === EnumIntegrationType.sellar; }\n public isShopify() { return this === EnumIntegrationType.shopify; }\n public isWooCommerce() { return this === EnumIntegrationType.wooCommerce; }\n public isZettle() { return this === EnumIntegrationType.zettle; }\n public isEposNow() { return this === EnumIntegrationType.eposNow; }\n public isBeerflex() { return this === EnumIntegrationType.beerflex; }\n public isSquare() { return this === EnumIntegrationType.square; }\n public isSquarespace() { return this === EnumIntegrationType.squarespace; }\n public isIntegrateOnce() { return this === EnumIntegrationType.integrateOnce; }\n public isEcwid() { return this === EnumIntegrationType.ecwid; }\n public isEeBria() { return this === EnumIntegrationType.eeBria; }\n public isCommerce7() { return this === EnumIntegrationType.commerce7; }\n public isAmazon() { return this === EnumIntegrationType.amazon; }\n\n public static getValues(): readonly EnumIntegrationType[] {\n return EnumIntegrationType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumIntegrationType[] {\n return EnumIntegrationType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumIntegrationType {\n const found = EnumIntegrationType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumIntegrationType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumIntegrationType): EnumIntegrationType {\n const found = name ? EnumIntegrationType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumIntegrationType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumInvoicesOrCredits implements BaseEnumType {\n private static allValues: EnumInvoicesOrCredits[] = []; // make sure this is top-most\n \n public static invoicesAndCredits = new EnumInvoicesOrCredits(1, \"InvoicesAndCredits\", \"enum_invoices_or_credits_invoices_and_credits\");\n public static invoicesOnly = new EnumInvoicesOrCredits(2, \"InvoicesOnly\", \"enum_invoices_or_credits_invoices_only\");\n public static creditsOnly = new EnumInvoicesOrCredits(3, \"CreditsOnly\", \"enum_invoices_or_credits_credits_only\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumInvoicesOrCredits.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isInvoicesAndCredits() { return this === EnumInvoicesOrCredits.invoicesAndCredits; }\n public isInvoicesOnly() { return this === EnumInvoicesOrCredits.invoicesOnly; }\n public isCreditsOnly() { return this === EnumInvoicesOrCredits.creditsOnly; }\n\n public static getValues(): readonly EnumInvoicesOrCredits[] {\n return EnumInvoicesOrCredits.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumInvoicesOrCredits[] {\n return EnumInvoicesOrCredits.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumInvoicesOrCredits {\n const found = EnumInvoicesOrCredits.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumInvoicesOrCredits - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumInvoicesOrCredits): EnumInvoicesOrCredits {\n const found = name ? EnumInvoicesOrCredits.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumInvoicesOrCredits - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumItemMainPurpose implements BaseEnumType {\n private static allValues: EnumItemMainPurpose[] = []; // make sure this is top-most\n \n public static unknown = new EnumItemMainPurpose(0, \"Unknown\", \"enum_item_main_purpose_unknown\");\n public static material = new EnumItemMainPurpose(1, \"Material\", \"enum_item_main_purpose_material\");\n public static product = new EnumItemMainPurpose(2, \"Product\", \"enum_item_main_purpose_product\");\n public static deliveryService = new EnumItemMainPurpose(3, \"DeliveryService\", \"enum_item_main_purpose_delivery_service\");\n public static bottleDepositCharge = new EnumItemMainPurpose(4, \"BottleDepositCharge\", \"enum_item_main_purpose_bottle_deposit_charge\");\n public static bottleDepositRedemption = new EnumItemMainPurpose(5, \"BottleDepositRedemption\", \"enum_item_main_purpose_bottle_deposit_redemption\");\n public static autoAssembledItem = new EnumItemMainPurpose(6, \"AutoAssembledItem\", \"enum_item_main_purpose_auto_assembled_item\");\n public static poDeliveryService = new EnumItemMainPurpose(7, \"PoDeliveryService\", \"enum_item_main_purpose_po_delivery_service\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumItemMainPurpose.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isUnknown() { return this === EnumItemMainPurpose.unknown; }\n public isMaterial() { return this === EnumItemMainPurpose.material; }\n public isProduct() { return this === EnumItemMainPurpose.product; }\n public isDeliveryService() { return this === EnumItemMainPurpose.deliveryService; }\n public isBottleDepositCharge() { return this === EnumItemMainPurpose.bottleDepositCharge; }\n public isBottleDepositRedemption() { return this === EnumItemMainPurpose.bottleDepositRedemption; }\n public isAutoAssembledItem() { return this === EnumItemMainPurpose.autoAssembledItem; }\n public isPoDeliveryService() { return this === EnumItemMainPurpose.poDeliveryService; }\n\n public static getValues(): readonly EnumItemMainPurpose[] {\n return EnumItemMainPurpose.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumItemMainPurpose[] {\n return EnumItemMainPurpose.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumItemMainPurpose {\n const found = EnumItemMainPurpose.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumItemMainPurpose - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumItemMainPurpose): EnumItemMainPurpose {\n const found = name ? EnumItemMainPurpose.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumItemMainPurpose - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumJourneyLabelStatus implements BaseEnumType {\n private static allValues: EnumJourneyLabelStatus[] = []; // make sure this is top-most\n \n public static unused = new EnumJourneyLabelStatus(0, \"Unused\", \"enum_journey_label_status_unused\");\n public static racked = new EnumJourneyLabelStatus(1, \"Racked\", \"enum_journey_label_status_racked\");\n public static delivered = new EnumJourneyLabelStatus(2, \"Delivered\", \"enum_journey_label_status_delivered\");\n public static returned = new EnumJourneyLabelStatus(3, \"Returned\", \"enum_journey_label_status_returned\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumJourneyLabelStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isUnused() { return this === EnumJourneyLabelStatus.unused; }\n public isRacked() { return this === EnumJourneyLabelStatus.racked; }\n public isDelivered() { return this === EnumJourneyLabelStatus.delivered; }\n public isReturned() { return this === EnumJourneyLabelStatus.returned; }\n\n public static getValues(): readonly EnumJourneyLabelStatus[] {\n return EnumJourneyLabelStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumJourneyLabelStatus[] {\n return EnumJourneyLabelStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumJourneyLabelStatus {\n const found = EnumJourneyLabelStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumJourneyLabelStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumJourneyLabelStatus): EnumJourneyLabelStatus {\n const found = name ? EnumJourneyLabelStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumJourneyLabelStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumJourneyStopPlanningStatus implements BaseEnumType {\n private static allValues: EnumJourneyStopPlanningStatus[] = []; // make sure this is top-most\n \n public static unknown = new EnumJourneyStopPlanningStatus(0, \"Unknown\", \"enum_journey_stop_planning_status_unknown\");\n public static onFinishedJourney = new EnumJourneyStopPlanningStatus(1, \"OnFinishedJourney\", \"enum_journey_stop_planning_status_on_finished_journey\");\n public static onStartedJourney = new EnumJourneyStopPlanningStatus(2, \"OnStartedJourney\", \"enum_journey_stop_planning_status_on_started_journey\");\n public static onPlanningLockedJourney = new EnumJourneyStopPlanningStatus(3, \"OnPlanningLockedJourney\", \"enum_journey_stop_planning_status_on_planning_locked_journey\");\n public static onPlannedJourney = new EnumJourneyStopPlanningStatus(4, \"OnPlannedJourney\", \"enum_journey_stop_planning_status_on_planned_journey\");\n public static requiresPlanning = new EnumJourneyStopPlanningStatus(5, \"RequiresPlanning\", \"enum_journey_stop_planning_status_requires_planning\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumJourneyStopPlanningStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isUnknown() { return this === EnumJourneyStopPlanningStatus.unknown; }\n public isOnFinishedJourney() { return this === EnumJourneyStopPlanningStatus.onFinishedJourney; }\n public isOnStartedJourney() { return this === EnumJourneyStopPlanningStatus.onStartedJourney; }\n public isOnPlanningLockedJourney() { return this === EnumJourneyStopPlanningStatus.onPlanningLockedJourney; }\n public isOnPlannedJourney() { return this === EnumJourneyStopPlanningStatus.onPlannedJourney; }\n public isRequiresPlanning() { return this === EnumJourneyStopPlanningStatus.requiresPlanning; }\n\n public static getValues(): readonly EnumJourneyStopPlanningStatus[] {\n return EnumJourneyStopPlanningStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumJourneyStopPlanningStatus[] {\n return EnumJourneyStopPlanningStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumJourneyStopPlanningStatus {\n const found = EnumJourneyStopPlanningStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumJourneyStopPlanningStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumJourneyStopPlanningStatus): EnumJourneyStopPlanningStatus {\n const found = name ? EnumJourneyStopPlanningStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumJourneyStopPlanningStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumKegstarContainerType implements BaseEnumType {\n private static allValues: EnumKegstarContainerType[] = []; // make sure this is top-most\n \n public static none = new EnumKegstarContainerType(0, \"None\", \"enum_kegstar_container_type_none\");\n public static kegstarKeg50L = new EnumKegstarContainerType(1, \"KegstarKeg50L\", \"enum_kegstar_container_type_kegstar_keg50_l\");\n public static kegstarKeg30L = new EnumKegstarContainerType(2, \"KegstarKeg30L\", \"enum_kegstar_container_type_kegstar_keg30_l\");\n public static kegstarKeg20L = new EnumKegstarContainerType(3, \"KegstarKeg20L\", \"enum_kegstar_container_type_kegstar_keg20_l\");\n public static kegstarCask9G = new EnumKegstarContainerType(4, \"KegstarCask9G\", \"enum_kegstar_container_type_kegstar_cask9_g\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumKegstarContainerType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumKegstarContainerType.none; }\n public isKegstarKeg50L() { return this === EnumKegstarContainerType.kegstarKeg50L; }\n public isKegstarKeg30L() { return this === EnumKegstarContainerType.kegstarKeg30L; }\n public isKegstarKeg20L() { return this === EnumKegstarContainerType.kegstarKeg20L; }\n public isKegstarCask9G() { return this === EnumKegstarContainerType.kegstarCask9G; }\n\n public static getValues(): readonly EnumKegstarContainerType[] {\n return EnumKegstarContainerType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumKegstarContainerType[] {\n return EnumKegstarContainerType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumKegstarContainerType {\n const found = EnumKegstarContainerType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumKegstarContainerType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumKegstarContainerType): EnumKegstarContainerType {\n const found = name ? EnumKegstarContainerType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumKegstarContainerType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumLeadStatus implements BaseEnumType {\n private static allValues: EnumLeadStatus[] = []; // make sure this is top-most\n \n public static active = new EnumLeadStatus(0, \"Active\", \"enum_lead_status_active\");\n public static onHold = new EnumLeadStatus(1, \"OnHold\", \"enum_lead_status_on_hold\");\n public static lost = new EnumLeadStatus(2, \"Lost\", \"enum_lead_status_lost\");\n public static won = new EnumLeadStatus(3, \"Won\", \"enum_lead_status_won\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumLeadStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isActive() { return this === EnumLeadStatus.active; }\n public isOnHold() { return this === EnumLeadStatus.onHold; }\n public isLost() { return this === EnumLeadStatus.lost; }\n public isWon() { return this === EnumLeadStatus.won; }\n\n public static getValues(): readonly EnumLeadStatus[] {\n return EnumLeadStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumLeadStatus[] {\n return EnumLeadStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumLeadStatus {\n const found = EnumLeadStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumLeadStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumLeadStatus): EnumLeadStatus {\n const found = name ? EnumLeadStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumLeadStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumLocationBondedStatus implements BaseEnumType {\n private static allValues: EnumLocationBondedStatus[] = []; // make sure this is top-most\n \n public static unknown = new EnumLocationBondedStatus(0, \"Unknown\", \"enum_location_bonded_status_unknown\");\n public static breweryNonBonded = new EnumLocationBondedStatus(1, \"BreweryNonBonded\", \"enum_location_bonded_status_brewery_non_bonded\");\n public static breweryBonded = new EnumLocationBondedStatus(2, \"BreweryBonded\", \"enum_location_bonded_status_brewery_bonded\");\n public static externalNonBonded = new EnumLocationBondedStatus(3, \"ExternalNonBonded\", \"enum_location_bonded_status_external_non_bonded\");\n public static externalBonded = new EnumLocationBondedStatus(4, \"ExternalBonded\", \"enum_location_bonded_status_external_bonded\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumLocationBondedStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isUnknown() { return this === EnumLocationBondedStatus.unknown; }\n public isBreweryNonBonded() { return this === EnumLocationBondedStatus.breweryNonBonded; }\n public isBreweryBonded() { return this === EnumLocationBondedStatus.breweryBonded; }\n public isExternalNonBonded() { return this === EnumLocationBondedStatus.externalNonBonded; }\n public isExternalBonded() { return this === EnumLocationBondedStatus.externalBonded; }\n\n public static getValues(): readonly EnumLocationBondedStatus[] {\n return EnumLocationBondedStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumLocationBondedStatus[] {\n return EnumLocationBondedStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumLocationBondedStatus {\n const found = EnumLocationBondedStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumLocationBondedStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumLocationBondedStatus): EnumLocationBondedStatus {\n const found = name ? EnumLocationBondedStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumLocationBondedStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumMetricType implements BaseEnumType {\n private static allValues: EnumMetricType[] = []; // make sure this is top-most\n \n public static custom = new EnumMetricType(0, \"Custom\", \"enum_metric_type_custom\");\n public static customBoolean = new EnumMetricType(1, \"CustomBoolean\", \"enum_metric_type_custom_boolean\");\n public static customString = new EnumMetricType(2, \"CustomString\", \"enum_metric_type_custom_string\");\n public static temperatureCelsius = new EnumMetricType(3, \"TemperatureCelsius\", \"enum_metric_type_temperature_celsius\");\n public static temperatureFahrenheit = new EnumMetricType(4, \"TemperatureFahrenheit\", \"enum_metric_type_temperature_fahrenheit\");\n public static temperatureKelvin = new EnumMetricType(5, \"TemperatureKelvin\", \"enum_metric_type_temperature_kelvin\");\n public static gravityRelativeToWater = new EnumMetricType(6, \"GravityRelativeToWater\", \"enum_metric_type_gravity_relative_to_water\");\n public static gravityKgm3 = new EnumMetricType(7, \"GravityKgm3\", \"enum_metric_type_gravity_kgm3\");\n public static gravityKgm3ExcessOfWater = new EnumMetricType(8, \"GravityKgm3ExcessOfWater\", \"enum_metric_type_gravity_kgm3_excess_of_water\");\n public static gravityPlato = new EnumMetricType(9, \"GravityPlato\", \"enum_metric_type_gravity_plato\");\n public static ph = new EnumMetricType(10, \"Ph\", \"enum_metric_type_ph\");\n public static abv = new EnumMetricType(11, \"Abv\", \"enum_metric_type_abv\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumMetricType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isCustom() { return this === EnumMetricType.custom; }\n public isCustomBoolean() { return this === EnumMetricType.customBoolean; }\n public isCustomString() { return this === EnumMetricType.customString; }\n public isTemperatureCelsius() { return this === EnumMetricType.temperatureCelsius; }\n public isTemperatureFahrenheit() { return this === EnumMetricType.temperatureFahrenheit; }\n public isTemperatureKelvin() { return this === EnumMetricType.temperatureKelvin; }\n public isGravityRelativeToWater() { return this === EnumMetricType.gravityRelativeToWater; }\n public isGravityKgm3() { return this === EnumMetricType.gravityKgm3; }\n public isGravityKgm3ExcessOfWater() { return this === EnumMetricType.gravityKgm3ExcessOfWater; }\n public isGravityPlato() { return this === EnumMetricType.gravityPlato; }\n public isPh() { return this === EnumMetricType.ph; }\n public isAbv() { return this === EnumMetricType.abv; }\n\n public static getValues(): readonly EnumMetricType[] {\n return EnumMetricType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumMetricType[] {\n return EnumMetricType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumMetricType {\n const found = EnumMetricType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumMetricType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumMetricType): EnumMetricType {\n const found = name ? EnumMetricType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumMetricType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumNatureOfTransactionCode implements BaseEnumType {\n private static allValues: EnumNatureOfTransactionCode[] = []; // make sure this is top-most\n \n public static none = new EnumNatureOfTransactionCode(0, \"None\", \"enum_nature_of_transaction_code_none\");\n public static allTransactionsWithChangeOfOwnership_10 = new EnumNatureOfTransactionCode(10, \"AllTransactionsWithChangeOfOwnership_10\", \"enum_nature_of_transaction_code_all_transactions_with_change_of_ownership_10\");\n public static creditNotesWithNoReturnedGoods_16 = new EnumNatureOfTransactionCode(16, \"CreditNotesWithNoReturnedGoods_16\", \"enum_nature_of_transaction_code_credit_notes_with_no_returned_goods_16\");\n public static transactionsMustBeDeclaredOnSdNotIncludedInBox8Or9_17 = new EnumNatureOfTransactionCode(17, \"TransactionsMustBeDeclaredOnSdNotIncludedInBox8Or9_17\", \"enum_nature_of_transaction_code_transactions_must_be_declared_on_sd_not_included_in_box8_or9_17\");\n public static transactionsMustBeDeclaredInBox8Or9NotRequiredOnSd_18 = new EnumNatureOfTransactionCode(18, \"TransactionsMustBeDeclaredInBox8Or9NotRequiredOnSd_18\", \"enum_nature_of_transaction_code_transactions_must_be_declared_in_box8_or9_not_required_on_sd_18\");\n public static returnedGoodsAndReplacementGoods_20 = new EnumNatureOfTransactionCode(20, \"ReturnedGoodsAndReplacementGoods_20\", \"enum_nature_of_transaction_code_returned_goods_and_replacement_goods_20\");\n public static focTransactions_30 = new EnumNatureOfTransactionCode(30, \"FocTransactions_30\", \"enum_nature_of_transaction_code_foc_transactions_30\");\n public static focTransactionsMustBeDeclaredOnSdNotIncludedInBox8Or9_37 = new EnumNatureOfTransactionCode(37, \"FocTransactionsMustBeDeclaredOnSdNotIncludedInBox8Or9_37\", \"enum_nature_of_transaction_code_foc_transactions_must_be_declared_on_sd_not_included_in_box8_or9_37\");\n public static focTransactionsMustBeDeclaredInBox8Or9NotRequiredOnSd_38 = new EnumNatureOfTransactionCode(38, \"FocTransactionsMustBeDeclaredInBox8Or9NotRequiredOnSd_38\", \"enum_nature_of_transaction_code_foc_transactions_must_be_declared_in_box8_or9_not_required_on_sd_38\");\n public static goodsSentForProcessingOrRepair_40 = new EnumNatureOfTransactionCode(40, \"GoodsSentForProcessingOrRepair_40\", \"enum_nature_of_transaction_code_goods_sent_for_processing_or_repair_40\");\n public static goodsReturnedFollowingProcessOrRepair_50 = new EnumNatureOfTransactionCode(50, \"GoodsReturnedFollowingProcessOrRepair_50\", \"enum_nature_of_transaction_code_goods_returned_following_process_or_repair_50\");\n public static jointDefenceProjects_70 = new EnumNatureOfTransactionCode(70, \"JointDefenceProjects_70\", \"enum_nature_of_transaction_code_joint_defence_projects_70\");\n public static jointDefenceProjectsMustBeDeclaredOnSdNotIncludedInBox8Or9_77 = new EnumNatureOfTransactionCode(77, \"JointDefenceProjectsMustBeDeclaredOnSdNotIncludedInBox8Or9_77\", \"enum_nature_of_transaction_code_joint_defence_projects_must_be_declared_on_sd_not_included_in_box8_or9_77\");\n public static jointDefenceProjectsMustBeDeclaredInBox8Or9NotRequiredOnSd_78 = new EnumNatureOfTransactionCode(78, \"JointDefenceProjectsMustBeDeclaredInBox8Or9NotRequiredOnSd_78\", \"enum_nature_of_transaction_code_joint_defence_projects_must_be_declared_in_box8_or9_not_required_on_sd_78\");\n public static supplyOfMaterials_80 = new EnumNatureOfTransactionCode(80, \"SupplyOfMaterials_80\", \"enum_nature_of_transaction_code_supply_of_materials_80\");\n public static supplyOfMaterialsMustBeDeclaredOnSdNotIncludedInBox8Or9_87 = new EnumNatureOfTransactionCode(87, \"SupplyOfMaterialsMustBeDeclaredOnSdNotIncludedInBox8Or9_87\", \"enum_nature_of_transaction_code_supply_of_materials_must_be_declared_on_sd_not_included_in_box8_or9_87\");\n public static supplyOfMaterialsMustBeDeclaredInBox8Or9NotRequiredOnSd_88 = new EnumNatureOfTransactionCode(88, \"SupplyOfMaterialsMustBeDeclaredInBox8Or9NotRequiredOnSd_88\", \"enum_nature_of_transaction_code_supply_of_materials_must_be_declared_in_box8_or9_not_required_on_sd_88\");\n public static otherTransactions_90 = new EnumNatureOfTransactionCode(90, \"OtherTransactions_90\", \"enum_nature_of_transaction_code_other_transactions_90\");\n public static otherTransactionsMustBeDeclaredOnSdNotIncludedInBox8Or9_97 = new EnumNatureOfTransactionCode(97, \"OtherTransactionsMustBeDeclaredOnSdNotIncludedInBox8Or9_97\", \"enum_nature_of_transaction_code_other_transactions_must_be_declared_on_sd_not_included_in_box8_or9_97\");\n public static otherTransactionsMustBeDeclaredInBox8Or9NotRequiredOnSd_98 = new EnumNatureOfTransactionCode(98, \"OtherTransactionsMustBeDeclaredInBox8Or9NotRequiredOnSd_98\", \"enum_nature_of_transaction_code_other_transactions_must_be_declared_in_box8_or9_not_required_on_sd_98\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumNatureOfTransactionCode.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumNatureOfTransactionCode.none; }\n public isAllTransactionsWithChangeOfOwnership_10() { return this === EnumNatureOfTransactionCode.allTransactionsWithChangeOfOwnership_10; }\n public isCreditNotesWithNoReturnedGoods_16() { return this === EnumNatureOfTransactionCode.creditNotesWithNoReturnedGoods_16; }\n public isTransactionsMustBeDeclaredOnSdNotIncludedInBox8Or9_17() { return this === EnumNatureOfTransactionCode.transactionsMustBeDeclaredOnSdNotIncludedInBox8Or9_17; }\n public isTransactionsMustBeDeclaredInBox8Or9NotRequiredOnSd_18() { return this === EnumNatureOfTransactionCode.transactionsMustBeDeclaredInBox8Or9NotRequiredOnSd_18; }\n public isReturnedGoodsAndReplacementGoods_20() { return this === EnumNatureOfTransactionCode.returnedGoodsAndReplacementGoods_20; }\n public isFocTransactions_30() { return this === EnumNatureOfTransactionCode.focTransactions_30; }\n public isFocTransactionsMustBeDeclaredOnSdNotIncludedInBox8Or9_37() { return this === EnumNatureOfTransactionCode.focTransactionsMustBeDeclaredOnSdNotIncludedInBox8Or9_37; }\n public isFocTransactionsMustBeDeclaredInBox8Or9NotRequiredOnSd_38() { return this === EnumNatureOfTransactionCode.focTransactionsMustBeDeclaredInBox8Or9NotRequiredOnSd_38; }\n public isGoodsSentForProcessingOrRepair_40() { return this === EnumNatureOfTransactionCode.goodsSentForProcessingOrRepair_40; }\n public isGoodsReturnedFollowingProcessOrRepair_50() { return this === EnumNatureOfTransactionCode.goodsReturnedFollowingProcessOrRepair_50; }\n public isJointDefenceProjects_70() { return this === EnumNatureOfTransactionCode.jointDefenceProjects_70; }\n public isJointDefenceProjectsMustBeDeclaredOnSdNotIncludedInBox8Or9_77() { return this === EnumNatureOfTransactionCode.jointDefenceProjectsMustBeDeclaredOnSdNotIncludedInBox8Or9_77; }\n public isJointDefenceProjectsMustBeDeclaredInBox8Or9NotRequiredOnSd_78() { return this === EnumNatureOfTransactionCode.jointDefenceProjectsMustBeDeclaredInBox8Or9NotRequiredOnSd_78; }\n public isSupplyOfMaterials_80() { return this === EnumNatureOfTransactionCode.supplyOfMaterials_80; }\n public isSupplyOfMaterialsMustBeDeclaredOnSdNotIncludedInBox8Or9_87() { return this === EnumNatureOfTransactionCode.supplyOfMaterialsMustBeDeclaredOnSdNotIncludedInBox8Or9_87; }\n public isSupplyOfMaterialsMustBeDeclaredInBox8Or9NotRequiredOnSd_88() { return this === EnumNatureOfTransactionCode.supplyOfMaterialsMustBeDeclaredInBox8Or9NotRequiredOnSd_88; }\n public isOtherTransactions_90() { return this === EnumNatureOfTransactionCode.otherTransactions_90; }\n public isOtherTransactionsMustBeDeclaredOnSdNotIncludedInBox8Or9_97() { return this === EnumNatureOfTransactionCode.otherTransactionsMustBeDeclaredOnSdNotIncludedInBox8Or9_97; }\n public isOtherTransactionsMustBeDeclaredInBox8Or9NotRequiredOnSd_98() { return this === EnumNatureOfTransactionCode.otherTransactionsMustBeDeclaredInBox8Or9NotRequiredOnSd_98; }\n\n public static getValues(): readonly EnumNatureOfTransactionCode[] {\n return EnumNatureOfTransactionCode.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumNatureOfTransactionCode[] {\n return EnumNatureOfTransactionCode.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumNatureOfTransactionCode {\n const found = EnumNatureOfTransactionCode.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumNatureOfTransactionCode - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumNatureOfTransactionCode): EnumNatureOfTransactionCode {\n const found = name ? EnumNatureOfTransactionCode.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumNatureOfTransactionCode - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumNumberingType implements BaseEnumType {\n private static allValues: EnumNumberingType[] = []; // make sure this is top-most\n \n public static none = new EnumNumberingType(0, \"None\", \"enum_numbering_type_none\");\n public static orderNumber = new EnumNumberingType(1, \"OrderNumber\", \"enum_numbering_type_order_number\");\n public static tradeInvoice = new EnumNumberingType(2, \"TradeInvoice\", \"enum_numbering_type_trade_invoice\");\n public static creditNumber = new EnumNumberingType(4, \"CreditNumber\", \"enum_numbering_type_credit_number\");\n public static batchNumber = new EnumNumberingType(5, \"BatchNumber\", \"enum_numbering_type_batch_number\");\n public static productBatchCode = new EnumNumberingType(6, \"ProductBatchCode\", \"enum_numbering_type_product_batch_code\");\n public static assemblyNumber = new EnumNumberingType(7, \"AssemblyNumber\", \"enum_numbering_type_assembly_number\");\n public static stockTransfer = new EnumNumberingType(8, \"StockTransfer\", \"enum_numbering_type_stock_transfer\");\n public static ullageNumber = new EnumNumberingType(9, \"UllageNumber\", \"enum_numbering_type_ullage_number\");\n public static stockTakeNumber = new EnumNumberingType(10, \"StockTakeNumber\", \"enum_numbering_type_stock_take_number\");\n public static purchaseOrderNumber = new EnumNumberingType(11, \"PurchaseOrderNumber\", \"enum_numbering_type_purchase_order_number\");\n public static palletNumber = new EnumNumberingType(12, \"PalletNumber\", \"enum_numbering_type_pallet_number\");\n public static palletBarcode = new EnumNumberingType(13, \"PalletBarcode\", \"enum_numbering_type_pallet_barcode\");\n public static ullageBarcode = new EnumNumberingType(14, \"UllageBarcode\", \"enum_numbering_type_ullage_barcode\");\n public static stockAdjustmentNumber = new EnumNumberingType(15, \"StockAdjustmentNumber\", \"enum_numbering_type_stock_adjustment_number\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumNumberingType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumNumberingType.none; }\n public isOrderNumber() { return this === EnumNumberingType.orderNumber; }\n public isTradeInvoice() { return this === EnumNumberingType.tradeInvoice; }\n public isCreditNumber() { return this === EnumNumberingType.creditNumber; }\n public isBatchNumber() { return this === EnumNumberingType.batchNumber; }\n public isProductBatchCode() { return this === EnumNumberingType.productBatchCode; }\n public isAssemblyNumber() { return this === EnumNumberingType.assemblyNumber; }\n public isStockTransfer() { return this === EnumNumberingType.stockTransfer; }\n public isUllageNumber() { return this === EnumNumberingType.ullageNumber; }\n public isStockTakeNumber() { return this === EnumNumberingType.stockTakeNumber; }\n public isPurchaseOrderNumber() { return this === EnumNumberingType.purchaseOrderNumber; }\n public isPalletNumber() { return this === EnumNumberingType.palletNumber; }\n public isPalletBarcode() { return this === EnumNumberingType.palletBarcode; }\n public isUllageBarcode() { return this === EnumNumberingType.ullageBarcode; }\n public isStockAdjustmentNumber() { return this === EnumNumberingType.stockAdjustmentNumber; }\n\n public static getValues(): readonly EnumNumberingType[] {\n return EnumNumberingType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumNumberingType[] {\n return EnumNumberingType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumNumberingType {\n const found = EnumNumberingType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumNumberingType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumNumberingType): EnumNumberingType {\n const found = name ? EnumNumberingType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumNumberingType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumOneFreePeriod implements BaseEnumType {\n private static allValues: EnumOneFreePeriod[] = []; // make sure this is top-most\n \n public static day = new EnumOneFreePeriod(100, \"Day\", \"enum_one_free_period_day\");\n public static month = new EnumOneFreePeriod(109, \"Month\", \"enum_one_free_period_month\");\n public static week = new EnumOneFreePeriod(119, \"Week\", \"enum_one_free_period_week\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumOneFreePeriod.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isDay() { return this === EnumOneFreePeriod.day; }\n public isMonth() { return this === EnumOneFreePeriod.month; }\n public isWeek() { return this === EnumOneFreePeriod.week; }\n\n public static getValues(): readonly EnumOneFreePeriod[] {\n return EnumOneFreePeriod.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumOneFreePeriod[] {\n return EnumOneFreePeriod.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumOneFreePeriod {\n const found = EnumOneFreePeriod.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumOneFreePeriod - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumOneFreePeriod): EnumOneFreePeriod {\n const found = name ? EnumOneFreePeriod.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumOneFreePeriod - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumOrderSortBy implements BaseEnumType {\n private static allValues: EnumOrderSortBy[] = []; // make sure this is top-most\n \n public static none = new EnumOrderSortBy(0, \"None\", \"enum_order_sort_by_none\");\n public static id = new EnumOrderSortBy(1, \"Id\", \"enum_order_sort_by_id\");\n public static deliveryDate = new EnumOrderSortBy(2, \"DeliveryDate\", \"enum_order_sort_by_delivery_date\");\n public static despatchDate = new EnumOrderSortBy(3, \"DespatchDate\", \"enum_order_sort_by_despatch_date\");\n public static createdAt = new EnumOrderSortBy(4, \"CreatedAt\", \"enum_order_sort_by_created_at\");\n public static lastUpdatedAt = new EnumOrderSortBy(5, \"LastUpdatedAt\", \"enum_order_sort_by_last_updated_at\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumOrderSortBy.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumOrderSortBy.none; }\n public isId() { return this === EnumOrderSortBy.id; }\n public isDeliveryDate() { return this === EnumOrderSortBy.deliveryDate; }\n public isDespatchDate() { return this === EnumOrderSortBy.despatchDate; }\n public isCreatedAt() { return this === EnumOrderSortBy.createdAt; }\n public isLastUpdatedAt() { return this === EnumOrderSortBy.lastUpdatedAt; }\n\n public static getValues(): readonly EnumOrderSortBy[] {\n return EnumOrderSortBy.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumOrderSortBy[] {\n return EnumOrderSortBy.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumOrderSortBy {\n const found = EnumOrderSortBy.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumOrderSortBy - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumOrderSortBy): EnumOrderSortBy {\n const found = name ? EnumOrderSortBy.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumOrderSortBy - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumOrderSource implements BaseEnumType {\n private static allValues: EnumOrderSource[] = []; // make sure this is top-most\n \n public static none = new EnumOrderSource(0, \"None\", \"enum_order_source_none\");\n public static brewMan = new EnumOrderSource(1, \"BrewMan\", \"enum_order_source_brew_man\");\n public static wooCommerce = new EnumOrderSource(2, \"WooCommerce\", \"enum_order_source_woo_commerce\");\n public static shopify = new EnumOrderSource(3, \"Shopify\", \"enum_order_source_shopify\");\n public static sellar = new EnumOrderSource(4, \"Sellar\", \"enum_order_source_sellar\");\n public static zettle = new EnumOrderSource(5, \"Zettle\", \"enum_order_source_zettle\");\n public static other = new EnumOrderSource(6, \"Other\", \"enum_order_source_other\");\n public static eposNow = new EnumOrderSource(7, \"EposNow\", \"enum_order_source_epos_now\");\n public static beerflex = new EnumOrderSource(8, \"Beerflex\", \"enum_order_source_beerflex\");\n public static square = new EnumOrderSource(9, \"Square\", \"enum_order_source_square\");\n public static squarespace = new EnumOrderSource(10, \"Squarespace\", \"enum_order_source_squarespace\");\n public static ecwid = new EnumOrderSource(11, \"Ecwid\", \"enum_order_source_ecwid\");\n public static eeBria = new EnumOrderSource(12, \"EeBria\", \"enum_order_source_ee_bria\");\n public static commerce7 = new EnumOrderSource(13, \"Commerce7\", \"enum_order_source_commerce7\");\n public static tradePortal = new EnumOrderSource(14, \"TradePortal\", \"enum_order_source_trade_portal\");\n public static amazon = new EnumOrderSource(15, \"Amazon\", \"enum_order_source_amazon\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumOrderSource.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumOrderSource.none; }\n public isBrewMan() { return this === EnumOrderSource.brewMan; }\n public isWooCommerce() { return this === EnumOrderSource.wooCommerce; }\n public isShopify() { return this === EnumOrderSource.shopify; }\n public isSellar() { return this === EnumOrderSource.sellar; }\n public isZettle() { return this === EnumOrderSource.zettle; }\n public isOther() { return this === EnumOrderSource.other; }\n public isEposNow() { return this === EnumOrderSource.eposNow; }\n public isBeerflex() { return this === EnumOrderSource.beerflex; }\n public isSquare() { return this === EnumOrderSource.square; }\n public isSquarespace() { return this === EnumOrderSource.squarespace; }\n public isEcwid() { return this === EnumOrderSource.ecwid; }\n public isEeBria() { return this === EnumOrderSource.eeBria; }\n public isCommerce7() { return this === EnumOrderSource.commerce7; }\n public isTradePortal() { return this === EnumOrderSource.tradePortal; }\n public isAmazon() { return this === EnumOrderSource.amazon; }\n\n public static getValues(): readonly EnumOrderSource[] {\n return EnumOrderSource.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumOrderSource[] {\n return EnumOrderSource.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumOrderSource {\n const found = EnumOrderSource.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumOrderSource - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumOrderSource): EnumOrderSource {\n const found = name ? EnumOrderSource.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumOrderSource - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumOrderStatus implements BaseEnumType {\n private static allValues: EnumOrderStatus[] = []; // make sure this is top-most\n \n public static none = new EnumOrderStatus(0, \"None\", \"enum_order_status_none\");\n public static open = new EnumOrderStatus(1, \"Open\", \"enum_order_status_open\");\n public static complete = new EnumOrderStatus(2, \"Complete\", \"enum_order_status_complete\");\n public static historic = new EnumOrderStatus(3, \"Historic\", \"enum_order_status_historic\");\n public static cancelled = new EnumOrderStatus(4, \"Cancelled\", \"enum_order_status_cancelled\");\n public static posting = new EnumOrderStatus(5, \"Posting\", \"enum_order_status_posting\");\n public static draft = new EnumOrderStatus(6, \"Draft\", \"enum_order_status_draft\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumOrderStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumOrderStatus.none; }\n public isOpen() { return this === EnumOrderStatus.open; }\n public isComplete() { return this === EnumOrderStatus.complete; }\n public isHistoric() { return this === EnumOrderStatus.historic; }\n public isCancelled() { return this === EnumOrderStatus.cancelled; }\n public isPosting() { return this === EnumOrderStatus.posting; }\n public isDraft() { return this === EnumOrderStatus.draft; }\n\n public static getValues(): readonly EnumOrderStatus[] {\n return EnumOrderStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumOrderStatus[] {\n return EnumOrderStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumOrderStatus {\n const found = EnumOrderStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumOrderStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumOrderStatus): EnumOrderStatus {\n const found = name ? EnumOrderStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumOrderStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumOutletRatingExclusions implements BaseEnumType {\n private static allValues: EnumOutletRatingExclusions[] = []; // make sure this is top-most\n \n public static includedOnly = new EnumOutletRatingExclusions(1, \"IncludedOnly\", \"enum_outlet_rating_exclusions_included_only\");\n public static excludedOnly = new EnumOutletRatingExclusions(2, \"ExcludedOnly\", \"enum_outlet_rating_exclusions_excluded_only\");\n public static all = new EnumOutletRatingExclusions(3, \"All\", \"enum_outlet_rating_exclusions_all\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumOutletRatingExclusions.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isIncludedOnly() { return this === EnumOutletRatingExclusions.includedOnly; }\n public isExcludedOnly() { return this === EnumOutletRatingExclusions.excludedOnly; }\n public isAll() { return this === EnumOutletRatingExclusions.all; }\n\n public static getValues(): readonly EnumOutletRatingExclusions[] {\n return EnumOutletRatingExclusions.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumOutletRatingExclusions[] {\n return EnumOutletRatingExclusions.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumOutletRatingExclusions {\n const found = EnumOutletRatingExclusions.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumOutletRatingExclusions - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumOutletRatingExclusions): EnumOutletRatingExclusions {\n const found = name ? EnumOutletRatingExclusions.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumOutletRatingExclusions - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumPackageTypeCategoryType implements BaseEnumType {\n private static allValues: EnumPackageTypeCategoryType[] = []; // make sure this is top-most\n \n public static unknown = new EnumPackageTypeCategoryType(0, \"Unknown\", \"enum_package_type_category_type_unknown\");\n public static cask = new EnumPackageTypeCategoryType(1, \"Cask\", \"enum_package_type_category_type_cask\");\n public static keg = new EnumPackageTypeCategoryType(2, \"Keg\", \"enum_package_type_category_type_keg\");\n public static case = new EnumPackageTypeCategoryType(3, \"Case\", \"enum_package_type_category_type_case\");\n public static bottle = new EnumPackageTypeCategoryType(4, \"Bottle\", \"enum_package_type_category_type_bottle\");\n public static other = new EnumPackageTypeCategoryType(5, \"Other\", \"enum_package_type_category_type_other\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumPackageTypeCategoryType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isUnknown() { return this === EnumPackageTypeCategoryType.unknown; }\n public isCask() { return this === EnumPackageTypeCategoryType.cask; }\n public isKeg() { return this === EnumPackageTypeCategoryType.keg; }\n public isCase() { return this === EnumPackageTypeCategoryType.case; }\n public isBottle() { return this === EnumPackageTypeCategoryType.bottle; }\n public isOther() { return this === EnumPackageTypeCategoryType.other; }\n\n public static getValues(): readonly EnumPackageTypeCategoryType[] {\n return EnumPackageTypeCategoryType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumPackageTypeCategoryType[] {\n return EnumPackageTypeCategoryType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumPackageTypeCategoryType {\n const found = EnumPackageTypeCategoryType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumPackageTypeCategoryType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumPackageTypeCategoryType): EnumPackageTypeCategoryType {\n const found = name ? EnumPackageTypeCategoryType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumPackageTypeCategoryType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumPalletStatus implements BaseEnumType {\n private static allValues: EnumPalletStatus[] = []; // make sure this is top-most\n \n public static none = new EnumPalletStatus(0, \"None\", \"enum_pallet_status_none\");\n public static in = new EnumPalletStatus(1, \"In\", \"enum_pallet_status_in\");\n public static delivered = new EnumPalletStatus(2, \"Delivered\", \"enum_pallet_status_delivered\");\n public static disassembled = new EnumPalletStatus(3, \"Disassembled\", \"enum_pallet_status_disassembled\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumPalletStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumPalletStatus.none; }\n public isIn() { return this === EnumPalletStatus.in; }\n public isDelivered() { return this === EnumPalletStatus.delivered; }\n public isDisassembled() { return this === EnumPalletStatus.disassembled; }\n\n public static getValues(): readonly EnumPalletStatus[] {\n return EnumPalletStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumPalletStatus[] {\n return EnumPalletStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumPalletStatus {\n const found = EnumPalletStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumPalletStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumPalletStatus): EnumPalletStatus {\n const found = name ? EnumPalletStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumPalletStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumPlannedStockAction implements BaseEnumType {\n private static allValues: EnumPlannedStockAction[] = []; // make sure this is top-most\n \n public static enterIntoPlanned = new EnumPlannedStockAction(80, \"EnterIntoPlanned\", \"enum_planned_stock_action_enter_into_planned\");\n public static removeFromPlanned = new EnumPlannedStockAction(82, \"RemoveFromPlanned\", \"enum_planned_stock_action_remove_from_planned\");\n public static enterIntoStock = new EnumPlannedStockAction(83, \"EnterIntoStock\", \"enum_planned_stock_action_enter_into_stock\");\n public static removeFromStock = new EnumPlannedStockAction(88, \"RemoveFromStock\", \"enum_planned_stock_action_remove_from_stock\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumPlannedStockAction.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isEnterIntoPlanned() { return this === EnumPlannedStockAction.enterIntoPlanned; }\n public isRemoveFromPlanned() { return this === EnumPlannedStockAction.removeFromPlanned; }\n public isEnterIntoStock() { return this === EnumPlannedStockAction.enterIntoStock; }\n public isRemoveFromStock() { return this === EnumPlannedStockAction.removeFromStock; }\n\n public static getValues(): readonly EnumPlannedStockAction[] {\n return EnumPlannedStockAction.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumPlannedStockAction[] {\n return EnumPlannedStockAction.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumPlannedStockAction {\n const found = EnumPlannedStockAction.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumPlannedStockAction - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumPlannedStockAction): EnumPlannedStockAction {\n const found = name ? EnumPlannedStockAction.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumPlannedStockAction - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumPlannedStockFollowUpAction implements BaseEnumType {\n private static allValues: EnumPlannedStockFollowUpAction[] = []; // make sure this is top-most\n \n public static none = new EnumPlannedStockFollowUpAction(78, \"None\", \"enum_planned_stock_follow_up_action_none\");\n public static removeFromPlanned = new EnumPlannedStockFollowUpAction(82, \"RemoveFromPlanned\", \"enum_planned_stock_follow_up_action_remove_from_planned\");\n public static removeFromPlannedAndMoveToStock = new EnumPlannedStockFollowUpAction(85, \"RemoveFromPlannedAndMoveToStock\", \"enum_planned_stock_follow_up_action_remove_from_planned_and_move_to_stock\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumPlannedStockFollowUpAction.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumPlannedStockFollowUpAction.none; }\n public isRemoveFromPlanned() { return this === EnumPlannedStockFollowUpAction.removeFromPlanned; }\n public isRemoveFromPlannedAndMoveToStock() { return this === EnumPlannedStockFollowUpAction.removeFromPlannedAndMoveToStock; }\n\n public static getValues(): readonly EnumPlannedStockFollowUpAction[] {\n return EnumPlannedStockFollowUpAction.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumPlannedStockFollowUpAction[] {\n return EnumPlannedStockFollowUpAction.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumPlannedStockFollowUpAction {\n const found = EnumPlannedStockFollowUpAction.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumPlannedStockFollowUpAction - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumPlannedStockFollowUpAction): EnumPlannedStockFollowUpAction {\n const found = name ? EnumPlannedStockFollowUpAction.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumPlannedStockFollowUpAction - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumPlannedStockStatus implements BaseEnumType {\n private static allValues: EnumPlannedStockStatus[] = []; // make sure this is top-most\n \n public static awaitingAction = new EnumPlannedStockStatus(0, \"AwaitingAction\", \"enum_planned_stock_status_awaiting_action\");\n public static awaitingFollowUp = new EnumPlannedStockStatus(1, \"AwaitingFollowUp\", \"enum_planned_stock_status_awaiting_follow_up\");\n public static complete = new EnumPlannedStockStatus(9, \"Complete\", \"enum_planned_stock_status_complete\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumPlannedStockStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isAwaitingAction() { return this === EnumPlannedStockStatus.awaitingAction; }\n public isAwaitingFollowUp() { return this === EnumPlannedStockStatus.awaitingFollowUp; }\n public isComplete() { return this === EnumPlannedStockStatus.complete; }\n\n public static getValues(): readonly EnumPlannedStockStatus[] {\n return EnumPlannedStockStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumPlannedStockStatus[] {\n return EnumPlannedStockStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumPlannedStockStatus {\n const found = EnumPlannedStockStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumPlannedStockStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumPlannedStockStatus): EnumPlannedStockStatus {\n const found = name ? EnumPlannedStockStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumPlannedStockStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumPriceListGroupSortBy implements BaseEnumType {\n private static allValues: EnumPriceListGroupSortBy[] = []; // make sure this is top-most\n \n public static nameAsc = new EnumPriceListGroupSortBy(0, \"NameAsc\", \"enum_price_list_group_sort_by_name_asc\");\n public static nameDesc = new EnumPriceListGroupSortBy(1, \"NameDesc\", \"enum_price_list_group_sort_by_name_desc\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumPriceListGroupSortBy.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNameAsc() { return this === EnumPriceListGroupSortBy.nameAsc; }\n public isNameDesc() { return this === EnumPriceListGroupSortBy.nameDesc; }\n\n public static getValues(): readonly EnumPriceListGroupSortBy[] {\n return EnumPriceListGroupSortBy.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumPriceListGroupSortBy[] {\n return EnumPriceListGroupSortBy.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumPriceListGroupSortBy {\n const found = EnumPriceListGroupSortBy.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumPriceListGroupSortBy - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumPriceListGroupSortBy): EnumPriceListGroupSortBy {\n const found = name ? EnumPriceListGroupSortBy.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumPriceListGroupSortBy - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumPriceListLineSortBy implements BaseEnumType {\n private static allValues: EnumPriceListLineSortBy[] = []; // make sure this is top-most\n \n public static nameAsc = new EnumPriceListLineSortBy(0, \"NameAsc\", \"enum_price_list_line_sort_by_name_asc\");\n public static nameDesc = new EnumPriceListLineSortBy(1, \"NameDesc\", \"enum_price_list_line_sort_by_name_desc\");\n public static abvAsc = new EnumPriceListLineSortBy(3, \"AbvAsc\", \"enum_price_list_line_sort_by_abv_asc\");\n public static abvDesc = new EnumPriceListLineSortBy(4, \"AbvDesc\", \"enum_price_list_line_sort_by_abv_desc\");\n public static priceAsc = new EnumPriceListLineSortBy(5, \"PriceAsc\", \"enum_price_list_line_sort_by_price_asc\");\n public static priceDesc = new EnumPriceListLineSortBy(6, \"PriceDesc\", \"enum_price_list_line_sort_by_price_desc\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumPriceListLineSortBy.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNameAsc() { return this === EnumPriceListLineSortBy.nameAsc; }\n public isNameDesc() { return this === EnumPriceListLineSortBy.nameDesc; }\n public isAbvAsc() { return this === EnumPriceListLineSortBy.abvAsc; }\n public isAbvDesc() { return this === EnumPriceListLineSortBy.abvDesc; }\n public isPriceAsc() { return this === EnumPriceListLineSortBy.priceAsc; }\n public isPriceDesc() { return this === EnumPriceListLineSortBy.priceDesc; }\n\n public static getValues(): readonly EnumPriceListLineSortBy[] {\n return EnumPriceListLineSortBy.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumPriceListLineSortBy[] {\n return EnumPriceListLineSortBy.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumPriceListLineSortBy {\n const found = EnumPriceListLineSortBy.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumPriceListLineSortBy - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumPriceListLineSortBy): EnumPriceListLineSortBy {\n const found = name ? EnumPriceListLineSortBy.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumPriceListLineSortBy - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumPriceListSubGroup implements BaseEnumType {\n private static allValues: EnumPriceListSubGroup[] = []; // make sure this is top-most\n \n public static packageType = new EnumPriceListSubGroup(0, \"PackageType\", \"enum_price_list_sub_group_package_type\");\n public static pricingCategory = new EnumPriceListSubGroup(1, \"PricingCategory\", \"enum_price_list_sub_group_pricing_category\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumPriceListSubGroup.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isPackageType() { return this === EnumPriceListSubGroup.packageType; }\n public isPricingCategory() { return this === EnumPriceListSubGroup.pricingCategory; }\n\n public static getValues(): readonly EnumPriceListSubGroup[] {\n return EnumPriceListSubGroup.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumPriceListSubGroup[] {\n return EnumPriceListSubGroup.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumPriceListSubGroup {\n const found = EnumPriceListSubGroup.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumPriceListSubGroup - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumPriceListSubGroup): EnumPriceListSubGroup {\n const found = name ? EnumPriceListSubGroup.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumPriceListSubGroup - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumPrinterPreference implements BaseEnumType {\n private static allValues: EnumPrinterPreference[] = []; // make sure this is top-most\n \n public static invoice = new EnumPrinterPreference(1, \"Invoice\", \"enum_printer_preference_invoice\");\n public static creditNote = new EnumPrinterPreference(2, \"CreditNote\", \"enum_printer_preference_credit_note\");\n public static deliveryNote = new EnumPrinterPreference(3, \"DeliveryNote\", \"enum_printer_preference_delivery_note\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumPrinterPreference.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isInvoice() { return this === EnumPrinterPreference.invoice; }\n public isCreditNote() { return this === EnumPrinterPreference.creditNote; }\n public isDeliveryNote() { return this === EnumPrinterPreference.deliveryNote; }\n\n public static getValues(): readonly EnumPrinterPreference[] {\n return EnumPrinterPreference.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumPrinterPreference[] {\n return EnumPrinterPreference.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumPrinterPreference {\n const found = EnumPrinterPreference.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumPrinterPreference - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumPrinterPreference): EnumPrinterPreference {\n const found = name ? EnumPrinterPreference.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumPrinterPreference - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumProcessIngredientSource implements BaseEnumType {\n private static allValues: EnumProcessIngredientSource[] = []; // make sure this is top-most\n \n public static stock = new EnumProcessIngredientSource(0, \"Stock\", \"enum_process_ingredient_source_stock\");\n public static processSameBatch = new EnumProcessIngredientSource(1, \"ProcessSameBatch\", \"enum_process_ingredient_source_process_same_batch\");\n public static processOtherBatch = new EnumProcessIngredientSource(2, \"ProcessOtherBatch\", \"enum_process_ingredient_source_process_other_batch\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumProcessIngredientSource.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isStock() { return this === EnumProcessIngredientSource.stock; }\n public isProcessSameBatch() { return this === EnumProcessIngredientSource.processSameBatch; }\n public isProcessOtherBatch() { return this === EnumProcessIngredientSource.processOtherBatch; }\n\n public static getValues(): readonly EnumProcessIngredientSource[] {\n return EnumProcessIngredientSource.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumProcessIngredientSource[] {\n return EnumProcessIngredientSource.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumProcessIngredientSource {\n const found = EnumProcessIngredientSource.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumProcessIngredientSource - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumProcessIngredientSource): EnumProcessIngredientSource {\n const found = name ? EnumProcessIngredientSource.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumProcessIngredientSource - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumProcessOutputTarget implements BaseEnumType {\n private static allValues: EnumProcessOutputTarget[] = []; // make sure this is top-most\n \n public static stock = new EnumProcessOutputTarget(0, \"Stock\", \"enum_process_output_target_stock\");\n public static processSameBatch = new EnumProcessOutputTarget(1, \"ProcessSameBatch\", \"enum_process_output_target_process_same_batch\");\n public static processOtherBatch = new EnumProcessOutputTarget(2, \"ProcessOtherBatch\", \"enum_process_output_target_process_other_batch\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumProcessOutputTarget.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isStock() { return this === EnumProcessOutputTarget.stock; }\n public isProcessSameBatch() { return this === EnumProcessOutputTarget.processSameBatch; }\n public isProcessOtherBatch() { return this === EnumProcessOutputTarget.processOtherBatch; }\n\n public static getValues(): readonly EnumProcessOutputTarget[] {\n return EnumProcessOutputTarget.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumProcessOutputTarget[] {\n return EnumProcessOutputTarget.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumProcessOutputTarget {\n const found = EnumProcessOutputTarget.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumProcessOutputTarget - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumProcessOutputTarget): EnumProcessOutputTarget {\n const found = name ? EnumProcessOutputTarget.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumProcessOutputTarget - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumPurchaseOrderDeliveryDisbursement implements BaseEnumType {\n private static allValues: EnumPurchaseOrderDeliveryDisbursement[] = []; // make sure this is top-most\n \n public static none = new EnumPurchaseOrderDeliveryDisbursement(0, \"None\", \"enum_purchase_order_delivery_disbursement_none\");\n public static manual = new EnumPurchaseOrderDeliveryDisbursement(1, \"Manual\", \"enum_purchase_order_delivery_disbursement_manual\");\n public static byValue = new EnumPurchaseOrderDeliveryDisbursement(2, \"ByValue\", \"enum_purchase_order_delivery_disbursement_by_value\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumPurchaseOrderDeliveryDisbursement.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumPurchaseOrderDeliveryDisbursement.none; }\n public isManual() { return this === EnumPurchaseOrderDeliveryDisbursement.manual; }\n public isByValue() { return this === EnumPurchaseOrderDeliveryDisbursement.byValue; }\n\n public static getValues(): readonly EnumPurchaseOrderDeliveryDisbursement[] {\n return EnumPurchaseOrderDeliveryDisbursement.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumPurchaseOrderDeliveryDisbursement[] {\n return EnumPurchaseOrderDeliveryDisbursement.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumPurchaseOrderDeliveryDisbursement {\n const found = EnumPurchaseOrderDeliveryDisbursement.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumPurchaseOrderDeliveryDisbursement - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumPurchaseOrderDeliveryDisbursement): EnumPurchaseOrderDeliveryDisbursement {\n const found = name ? EnumPurchaseOrderDeliveryDisbursement.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumPurchaseOrderDeliveryDisbursement - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumPurchaseOrderDeliveryStatus implements BaseEnumType {\n private static allValues: EnumPurchaseOrderDeliveryStatus[] = []; // make sure this is top-most\n \n public static none = new EnumPurchaseOrderDeliveryStatus(0, \"None\", \"enum_purchase_order_delivery_status_none\");\n public static partial = new EnumPurchaseOrderDeliveryStatus(1, \"Partial\", \"enum_purchase_order_delivery_status_partial\");\n public static full = new EnumPurchaseOrderDeliveryStatus(2, \"Full\", \"enum_purchase_order_delivery_status_full\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumPurchaseOrderDeliveryStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumPurchaseOrderDeliveryStatus.none; }\n public isPartial() { return this === EnumPurchaseOrderDeliveryStatus.partial; }\n public isFull() { return this === EnumPurchaseOrderDeliveryStatus.full; }\n\n public static getValues(): readonly EnumPurchaseOrderDeliveryStatus[] {\n return EnumPurchaseOrderDeliveryStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumPurchaseOrderDeliveryStatus[] {\n return EnumPurchaseOrderDeliveryStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumPurchaseOrderDeliveryStatus {\n const found = EnumPurchaseOrderDeliveryStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumPurchaseOrderDeliveryStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumPurchaseOrderDeliveryStatus): EnumPurchaseOrderDeliveryStatus {\n const found = name ? EnumPurchaseOrderDeliveryStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumPurchaseOrderDeliveryStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumPurchaseOrderStatus implements BaseEnumType {\n private static allValues: EnumPurchaseOrderStatus[] = []; // make sure this is top-most\n \n public static open = new EnumPurchaseOrderStatus(0, \"Open\", \"enum_purchase_order_status_open\");\n public static awaitingConfirmation = new EnumPurchaseOrderStatus(1, \"AwaitingConfirmation\", \"enum_purchase_order_status_awaiting_confirmation\");\n public static awaitingCompletion = new EnumPurchaseOrderStatus(2, \"AwaitingCompletion\", \"enum_purchase_order_status_awaiting_completion\");\n public static complete = new EnumPurchaseOrderStatus(3, \"Complete\", \"enum_purchase_order_status_complete\");\n public static posting = new EnumPurchaseOrderStatus(4, \"Posting\", \"enum_purchase_order_status_posting\");\n public static historic = new EnumPurchaseOrderStatus(5, \"Historic\", \"enum_purchase_order_status_historic\");\n public static cancelled = new EnumPurchaseOrderStatus(6, \"Cancelled\", \"enum_purchase_order_status_cancelled\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumPurchaseOrderStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isOpen() { return this === EnumPurchaseOrderStatus.open; }\n public isAwaitingConfirmation() { return this === EnumPurchaseOrderStatus.awaitingConfirmation; }\n public isAwaitingCompletion() { return this === EnumPurchaseOrderStatus.awaitingCompletion; }\n public isComplete() { return this === EnumPurchaseOrderStatus.complete; }\n public isPosting() { return this === EnumPurchaseOrderStatus.posting; }\n public isHistoric() { return this === EnumPurchaseOrderStatus.historic; }\n public isCancelled() { return this === EnumPurchaseOrderStatus.cancelled; }\n\n public static getValues(): readonly EnumPurchaseOrderStatus[] {\n return EnumPurchaseOrderStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumPurchaseOrderStatus[] {\n return EnumPurchaseOrderStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumPurchaseOrderStatus {\n const found = EnumPurchaseOrderStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumPurchaseOrderStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumPurchaseOrderStatus): EnumPurchaseOrderStatus {\n const found = name ? EnumPurchaseOrderStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumPurchaseOrderStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumQcProbeProvider implements BaseEnumType {\n private static allValues: EnumQcProbeProvider[] = []; // make sure this is top-most\n \n public static none = new EnumQcProbeProvider(0, \"None\", \"enum_qc_probe_provider_none\");\n public static plaato = new EnumQcProbeProvider(1, \"Plaato\", \"enum_qc_probe_provider_plaato\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumQcProbeProvider.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumQcProbeProvider.none; }\n public isPlaato() { return this === EnumQcProbeProvider.plaato; }\n\n public static getValues(): readonly EnumQcProbeProvider[] {\n return EnumQcProbeProvider.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumQcProbeProvider[] {\n return EnumQcProbeProvider.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumQcProbeProvider {\n const found = EnumQcProbeProvider.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumQcProbeProvider - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumQcProbeProvider): EnumQcProbeProvider {\n const found = name ? EnumQcProbeProvider.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumQcProbeProvider - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumQueuedJobType implements BaseEnumType {\n private static allValues: EnumQueuedJobType[] = []; // make sure this is top-most\n \n public static none = new EnumQueuedJobType(0, \"None\", \"enum_queued_job_type_none\");\n public static squareDiscoverOrders = new EnumQueuedJobType(1, \"SquareDiscoverOrders\", \"enum_queued_job_type_square_discover_orders\");\n public static obsolete_SquareImportOrder = new EnumQueuedJobType(2, \"Obsolete_SquareImportOrder\", \"enum_queued_job_type_obsolete__square_import_order\");\n public static squareExportProductPrice = new EnumQueuedJobType(3, \"SquareExportProductPrice\", \"enum_queued_job_type_square_export_product_price\");\n public static squareExportProductStock = new EnumQueuedJobType(4, \"SquareExportProductStock\", \"enum_queued_job_type_square_export_product_stock\");\n public static beerflexDiscoverOrders = new EnumQueuedJobType(5, \"BeerflexDiscoverOrders\", \"enum_queued_job_type_beerflex_discover_orders\");\n public static beerflexSendConfirmations = new EnumQueuedJobType(6, \"BeerflexSendConfirmations\", \"enum_queued_job_type_beerflex_send_confirmations\");\n public static sellarDiscoverOrders = new EnumQueuedJobType(7, \"SellarDiscoverOrders\", \"enum_queued_job_type_sellar_discover_orders\");\n public static sellarImportOrder = new EnumQueuedJobType(8, \"SellarImportOrder\", \"enum_queued_job_type_sellar_import_order\");\n public static sellarExportProductStock = new EnumQueuedJobType(9, \"SellarExportProductStock\", \"enum_queued_job_type_sellar_export_product_stock\");\n public static zettleDiscoverOrders = new EnumQueuedJobType(10, \"ZettleDiscoverOrders\", \"enum_queued_job_type_zettle_discover_orders\");\n public static zettleImportOrder = new EnumQueuedJobType(11, \"ZettleImportOrder\", \"enum_queued_job_type_zettle_import_order\");\n public static zettleExportProductStock = new EnumQueuedJobType(12, \"ZettleExportProductStock\", \"enum_queued_job_type_zettle_export_product_stock\");\n public static wooCommerceDiscoverOrders = new EnumQueuedJobType(13, \"WooCommerceDiscoverOrders\", \"enum_queued_job_type_woo_commerce_discover_orders\");\n public static wooCommerceImportOrder = new EnumQueuedJobType(14, \"WooCommerceImportOrder\", \"enum_queued_job_type_woo_commerce_import_order\");\n public static eposNowDiscoverOrders = new EnumQueuedJobType(15, \"EposNowDiscoverOrders\", \"enum_queued_job_type_epos_now_discover_orders\");\n public static eposNowImportOrder = new EnumQueuedJobType(16, \"EposNowImportOrder\", \"enum_queued_job_type_epos_now_import_order\");\n public static eposNowExportProductPrice = new EnumQueuedJobType(17, \"EposNowExportProductPrice\", \"enum_queued_job_type_epos_now_export_product_price\");\n public static eposNowExportProductStock = new EnumQueuedJobType(18, \"EposNowExportProductStock\", \"enum_queued_job_type_epos_now_export_product_stock\");\n public static shopifyDiscoverOrders_Obsolete = new EnumQueuedJobType(19, \"ShopifyDiscoverOrders_Obsolete\", \"enum_queued_job_type_shopify_discover_orders__obsolete\");\n public static shopifyImportOrder_Obsolete = new EnumQueuedJobType(20, \"ShopifyImportOrder_Obsolete\", \"enum_queued_job_type_shopify_import_order__obsolete\");\n public static shopifyDiscoverProductUpdates_Obsolete = new EnumQueuedJobType(21, \"ShopifyDiscoverProductUpdates_Obsolete\", \"enum_queued_job_type_shopify_discover_product_updates__obsolete\");\n public static shopifyExportProductPrice_Obsolete = new EnumQueuedJobType(22, \"ShopifyExportProductPrice_Obsolete\", \"enum_queued_job_type_shopify_export_product_price__obsolete\");\n public static shopifyExportProductStock_Obsolete = new EnumQueuedJobType(23, \"ShopifyExportProductStock_Obsolete\", \"enum_queued_job_type_shopify_export_product_stock__obsolete\");\n public static plaatoReadProbes = new EnumQueuedJobType(24, \"PlaatoReadProbes\", \"enum_queued_job_type_plaato_read_probes\");\n public static outletLatLngUpdate = new EnumQueuedJobType(25, \"OutletLatLngUpdate\", \"enum_queued_job_type_outlet_lat_lng_update\");\n public static squarespaceDiscoverOrders = new EnumQueuedJobType(26, \"SquarespaceDiscoverOrders\", \"enum_queued_job_type_squarespace_discover_orders\");\n public static squarespaceImportOrder = new EnumQueuedJobType(27, \"SquarespaceImportOrder\", \"enum_queued_job_type_squarespace_import_order\");\n public static squarespaceExportProductPrice = new EnumQueuedJobType(28, \"SquarespaceExportProductPrice\", \"enum_queued_job_type_squarespace_export_product_price\");\n public static squarespaceExportProductStock = new EnumQueuedJobType(29, \"SquarespaceExportProductStock\", \"enum_queued_job_type_squarespace_export_product_stock\");\n public static ecommerceConnectionDiscoverOrders = new EnumQueuedJobType(30, \"EcommerceConnectionDiscoverOrders\", \"enum_queued_job_type_ecommerce_connection_discover_orders\");\n public static ecommerceConnectionImportOrder = new EnumQueuedJobType(31, \"EcommerceConnectionImportOrder\", \"enum_queued_job_type_ecommerce_connection_import_order\");\n public static ecommerceConnectionExportProductPrice = new EnumQueuedJobType(32, \"EcommerceConnectionExportProductPrice\", \"enum_queued_job_type_ecommerce_connection_export_product_price\");\n public static ecommerceConnectionExportProductStock = new EnumQueuedJobType(33, \"EcommerceConnectionExportProductStock\", \"enum_queued_job_type_ecommerce_connection_export_product_stock\");\n public static sendTaskDueNotifications = new EnumQueuedJobType(34, \"SendTaskDueNotifications\", \"enum_queued_job_type_send_task_due_notifications\");\n public static groupLatLngUpdate = new EnumQueuedJobType(35, \"GroupLatLngUpdate\", \"enum_queued_job_type_group_lat_lng_update\");\n public static leadLatLngUpdate = new EnumQueuedJobType(36, \"LeadLatLngUpdate\", \"enum_queued_job_type_lead_lat_lng_update\");\n public static createRefreshExternalCalendarSubscription = new EnumQueuedJobType(37, \"CreateRefreshExternalCalendarSubscription\", \"enum_queued_job_type_create_refresh_external_calendar_subscription\");\n public static ecwidDiscoverOrders = new EnumQueuedJobType(38, \"EcwidDiscoverOrders\", \"enum_queued_job_type_ecwid_discover_orders\");\n public static ecwidImportOrder = new EnumQueuedJobType(39, \"EcwidImportOrder\", \"enum_queued_job_type_ecwid_import_order\");\n public static ecwidExportProductPrice = new EnumQueuedJobType(40, \"EcwidExportProductPrice\", \"enum_queued_job_type_ecwid_export_product_price\");\n public static ecwidExportProductStock = new EnumQueuedJobType(41, \"EcwidExportProductStock\", \"enum_queued_job_type_ecwid_export_product_stock\");\n public static eeBriaDiscoverOrders = new EnumQueuedJobType(42, \"EeBriaDiscoverOrders\", \"enum_queued_job_type_ee_bria_discover_orders\");\n public static eeBriaImportOrder = new EnumQueuedJobType(43, \"EeBriaImportOrder\", \"enum_queued_job_type_ee_bria_import_order\");\n public static eeBriaExportProductStock = new EnumQueuedJobType(44, \"EeBriaExportProductStock\", \"enum_queued_job_type_ee_bria_export_product_stock\");\n public static oldDutyStockCapture = new EnumQueuedJobType(45, \"OldDutyStockCapture\", \"enum_queued_job_type_old_duty_stock_capture\");\n public static emailLabelOrderInvoice = new EnumQueuedJobType(46, \"EmailLabelOrderInvoice\", \"enum_queued_job_type_email_label_order_invoice\");\n public static commerce7DiscoverOrders = new EnumQueuedJobType(47, \"Commerce7DiscoverOrders\", \"enum_queued_job_type_commerce7_discover_orders\");\n public static commerce7ImportOrder = new EnumQueuedJobType(48, \"Commerce7ImportOrder\", \"enum_queued_job_type_commerce7_import_order\");\n public static commerce7ExportProductPrice = new EnumQueuedJobType(49, \"Commerce7ExportProductPrice\", \"enum_queued_job_type_commerce7_export_product_price\");\n public static commerce7ExportProductStock = new EnumQueuedJobType(50, \"Commerce7ExportProductStock\", \"enum_queued_job_type_commerce7_export_product_stock\");\n public static accountsDailyMaintenance = new EnumQueuedJobType(51, \"AccountsDailyMaintenance\", \"enum_queued_job_type_accounts_daily_maintenance\");\n public static amazonDiscoverOrders = new EnumQueuedJobType(52, \"AmazonDiscoverOrders\", \"enum_queued_job_type_amazon_discover_orders\");\n public static amazonImportOrder = new EnumQueuedJobType(53, \"AmazonImportOrder\", \"enum_queued_job_type_amazon_import_order\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumQueuedJobType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumQueuedJobType.none; }\n public isSquareDiscoverOrders() { return this === EnumQueuedJobType.squareDiscoverOrders; }\n public isObsolete_SquareImportOrder() { return this === EnumQueuedJobType.obsolete_SquareImportOrder; }\n public isSquareExportProductPrice() { return this === EnumQueuedJobType.squareExportProductPrice; }\n public isSquareExportProductStock() { return this === EnumQueuedJobType.squareExportProductStock; }\n public isBeerflexDiscoverOrders() { return this === EnumQueuedJobType.beerflexDiscoverOrders; }\n public isBeerflexSendConfirmations() { return this === EnumQueuedJobType.beerflexSendConfirmations; }\n public isSellarDiscoverOrders() { return this === EnumQueuedJobType.sellarDiscoverOrders; }\n public isSellarImportOrder() { return this === EnumQueuedJobType.sellarImportOrder; }\n public isSellarExportProductStock() { return this === EnumQueuedJobType.sellarExportProductStock; }\n public isZettleDiscoverOrders() { return this === EnumQueuedJobType.zettleDiscoverOrders; }\n public isZettleImportOrder() { return this === EnumQueuedJobType.zettleImportOrder; }\n public isZettleExportProductStock() { return this === EnumQueuedJobType.zettleExportProductStock; }\n public isWooCommerceDiscoverOrders() { return this === EnumQueuedJobType.wooCommerceDiscoverOrders; }\n public isWooCommerceImportOrder() { return this === EnumQueuedJobType.wooCommerceImportOrder; }\n public isEposNowDiscoverOrders() { return this === EnumQueuedJobType.eposNowDiscoverOrders; }\n public isEposNowImportOrder() { return this === EnumQueuedJobType.eposNowImportOrder; }\n public isEposNowExportProductPrice() { return this === EnumQueuedJobType.eposNowExportProductPrice; }\n public isEposNowExportProductStock() { return this === EnumQueuedJobType.eposNowExportProductStock; }\n public isShopifyDiscoverOrders_Obsolete() { return this === EnumQueuedJobType.shopifyDiscoverOrders_Obsolete; }\n public isShopifyImportOrder_Obsolete() { return this === EnumQueuedJobType.shopifyImportOrder_Obsolete; }\n public isShopifyDiscoverProductUpdates_Obsolete() { return this === EnumQueuedJobType.shopifyDiscoverProductUpdates_Obsolete; }\n public isShopifyExportProductPrice_Obsolete() { return this === EnumQueuedJobType.shopifyExportProductPrice_Obsolete; }\n public isShopifyExportProductStock_Obsolete() { return this === EnumQueuedJobType.shopifyExportProductStock_Obsolete; }\n public isPlaatoReadProbes() { return this === EnumQueuedJobType.plaatoReadProbes; }\n public isOutletLatLngUpdate() { return this === EnumQueuedJobType.outletLatLngUpdate; }\n public isSquarespaceDiscoverOrders() { return this === EnumQueuedJobType.squarespaceDiscoverOrders; }\n public isSquarespaceImportOrder() { return this === EnumQueuedJobType.squarespaceImportOrder; }\n public isSquarespaceExportProductPrice() { return this === EnumQueuedJobType.squarespaceExportProductPrice; }\n public isSquarespaceExportProductStock() { return this === EnumQueuedJobType.squarespaceExportProductStock; }\n public isEcommerceConnectionDiscoverOrders() { return this === EnumQueuedJobType.ecommerceConnectionDiscoverOrders; }\n public isEcommerceConnectionImportOrder() { return this === EnumQueuedJobType.ecommerceConnectionImportOrder; }\n public isEcommerceConnectionExportProductPrice() { return this === EnumQueuedJobType.ecommerceConnectionExportProductPrice; }\n public isEcommerceConnectionExportProductStock() { return this === EnumQueuedJobType.ecommerceConnectionExportProductStock; }\n public isSendTaskDueNotifications() { return this === EnumQueuedJobType.sendTaskDueNotifications; }\n public isGroupLatLngUpdate() { return this === EnumQueuedJobType.groupLatLngUpdate; }\n public isLeadLatLngUpdate() { return this === EnumQueuedJobType.leadLatLngUpdate; }\n public isCreateRefreshExternalCalendarSubscription() { return this === EnumQueuedJobType.createRefreshExternalCalendarSubscription; }\n public isEcwidDiscoverOrders() { return this === EnumQueuedJobType.ecwidDiscoverOrders; }\n public isEcwidImportOrder() { return this === EnumQueuedJobType.ecwidImportOrder; }\n public isEcwidExportProductPrice() { return this === EnumQueuedJobType.ecwidExportProductPrice; }\n public isEcwidExportProductStock() { return this === EnumQueuedJobType.ecwidExportProductStock; }\n public isEeBriaDiscoverOrders() { return this === EnumQueuedJobType.eeBriaDiscoverOrders; }\n public isEeBriaImportOrder() { return this === EnumQueuedJobType.eeBriaImportOrder; }\n public isEeBriaExportProductStock() { return this === EnumQueuedJobType.eeBriaExportProductStock; }\n public isOldDutyStockCapture() { return this === EnumQueuedJobType.oldDutyStockCapture; }\n public isEmailLabelOrderInvoice() { return this === EnumQueuedJobType.emailLabelOrderInvoice; }\n public isCommerce7DiscoverOrders() { return this === EnumQueuedJobType.commerce7DiscoverOrders; }\n public isCommerce7ImportOrder() { return this === EnumQueuedJobType.commerce7ImportOrder; }\n public isCommerce7ExportProductPrice() { return this === EnumQueuedJobType.commerce7ExportProductPrice; }\n public isCommerce7ExportProductStock() { return this === EnumQueuedJobType.commerce7ExportProductStock; }\n public isAccountsDailyMaintenance() { return this === EnumQueuedJobType.accountsDailyMaintenance; }\n public isAmazonDiscoverOrders() { return this === EnumQueuedJobType.amazonDiscoverOrders; }\n public isAmazonImportOrder() { return this === EnumQueuedJobType.amazonImportOrder; }\n\n public static getValues(): readonly EnumQueuedJobType[] {\n return EnumQueuedJobType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumQueuedJobType[] {\n return EnumQueuedJobType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumQueuedJobType {\n const found = EnumQueuedJobType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumQueuedJobType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumQueuedJobType): EnumQueuedJobType {\n const found = name ? EnumQueuedJobType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumQueuedJobType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumRecurringJobType implements BaseEnumType {\n private static allValues: EnumRecurringJobType[] = []; // make sure this is top-most\n \n public static none = new EnumRecurringJobType(0, \"None\", \"enum_recurring_job_type_none\");\n public static eposNowIntegrationQueueTenants = new EnumRecurringJobType(1, \"EposNowIntegrationQueueTenants\", \"enum_recurring_job_type_epos_now_integration_queue_tenants\");\n public static sellarIntegrationQueueTenants = new EnumRecurringJobType(2, \"SellarIntegrationQueueTenants\", \"enum_recurring_job_type_sellar_integration_queue_tenants\");\n public static shopifyIntegrationQueueTenants_Obsolete = new EnumRecurringJobType(3, \"ShopifyIntegrationQueueTenants_Obsolete\", \"enum_recurring_job_type_shopify_integration_queue_tenants__obsolete\");\n public static wooCommerceIntegrationQueueTenants = new EnumRecurringJobType(4, \"WooCommerceIntegrationQueueTenants\", \"enum_recurring_job_type_woo_commerce_integration_queue_tenants\");\n public static zettleIntegrationQueueTenants = new EnumRecurringJobType(5, \"ZettleIntegrationQueueTenants\", \"enum_recurring_job_type_zettle_integration_queue_tenants\");\n public static beerflexIntegrationQueueTenants = new EnumRecurringJobType(6, \"BeerflexIntegrationQueueTenants\", \"enum_recurring_job_type_beerflex_integration_queue_tenants\");\n public static squareIntegrationQueueTenants = new EnumRecurringJobType(7, \"SquareIntegrationQueueTenants\", \"enum_recurring_job_type_square_integration_queue_tenants\");\n public static plaatoIntegrationQueueTenants = new EnumRecurringJobType(8, \"PlaatoIntegrationQueueTenants\", \"enum_recurring_job_type_plaato_integration_queue_tenants\");\n public static usageBillingFlushQueueTenantGroups = new EnumRecurringJobType(9, \"UsageBillingFlushQueueTenantGroups\", \"enum_recurring_job_type_usage_billing_flush_queue_tenant_groups\");\n public static squarespaceIntegrationQueueTenants = new EnumRecurringJobType(10, \"SquarespaceIntegrationQueueTenants\", \"enum_recurring_job_type_squarespace_integration_queue_tenants\");\n public static integrateOnceIntegrationQueueTenants = new EnumRecurringJobType(11, \"IntegrateOnceIntegrationQueueTenants\", \"enum_recurring_job_type_integrate_once_integration_queue_tenants\");\n public static taskNotificationsQueueTenants = new EnumRecurringJobType(12, \"TaskNotificationsQueueTenants\", \"enum_recurring_job_type_task_notifications_queue_tenants\");\n public static createCalendarSubscriptionQueueUsers = new EnumRecurringJobType(13, \"CreateCalendarSubscriptionQueueUsers\", \"enum_recurring_job_type_create_calendar_subscription_queue_users\");\n public static ecwidIntegrationQueueTenants = new EnumRecurringJobType(14, \"EcwidIntegrationQueueTenants\", \"enum_recurring_job_type_ecwid_integration_queue_tenants\");\n public static eeBriaIntegrationQueueTenants = new EnumRecurringJobType(15, \"EeBriaIntegrationQueueTenants\", \"enum_recurring_job_type_ee_bria_integration_queue_tenants\");\n public static oldDutyStockCaptureQueueTenants = new EnumRecurringJobType(16, \"OldDutyStockCaptureQueueTenants\", \"enum_recurring_job_type_old_duty_stock_capture_queue_tenants\");\n public static commerce7IntegrationQueueTenants = new EnumRecurringJobType(17, \"Commerce7IntegrationQueueTenants\", \"enum_recurring_job_type_commerce7_integration_queue_tenants\");\n public static accountsDailyMaintenance = new EnumRecurringJobType(18, \"AccountsDailyMaintenance\", \"enum_recurring_job_type_accounts_daily_maintenance\");\n public static amazonIntegrationQueueTenants = new EnumRecurringJobType(19, \"AmazonIntegrationQueueTenants\", \"enum_recurring_job_type_amazon_integration_queue_tenants\");\n public static invoicesToXeroSync = new EnumRecurringJobType(20, \"InvoicesToXeroSync\", \"enum_recurring_job_type_invoices_to_xero_sync\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumRecurringJobType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumRecurringJobType.none; }\n public isEposNowIntegrationQueueTenants() { return this === EnumRecurringJobType.eposNowIntegrationQueueTenants; }\n public isSellarIntegrationQueueTenants() { return this === EnumRecurringJobType.sellarIntegrationQueueTenants; }\n public isShopifyIntegrationQueueTenants_Obsolete() { return this === EnumRecurringJobType.shopifyIntegrationQueueTenants_Obsolete; }\n public isWooCommerceIntegrationQueueTenants() { return this === EnumRecurringJobType.wooCommerceIntegrationQueueTenants; }\n public isZettleIntegrationQueueTenants() { return this === EnumRecurringJobType.zettleIntegrationQueueTenants; }\n public isBeerflexIntegrationQueueTenants() { return this === EnumRecurringJobType.beerflexIntegrationQueueTenants; }\n public isSquareIntegrationQueueTenants() { return this === EnumRecurringJobType.squareIntegrationQueueTenants; }\n public isPlaatoIntegrationQueueTenants() { return this === EnumRecurringJobType.plaatoIntegrationQueueTenants; }\n public isUsageBillingFlushQueueTenantGroups() { return this === EnumRecurringJobType.usageBillingFlushQueueTenantGroups; }\n public isSquarespaceIntegrationQueueTenants() { return this === EnumRecurringJobType.squarespaceIntegrationQueueTenants; }\n public isIntegrateOnceIntegrationQueueTenants() { return this === EnumRecurringJobType.integrateOnceIntegrationQueueTenants; }\n public isTaskNotificationsQueueTenants() { return this === EnumRecurringJobType.taskNotificationsQueueTenants; }\n public isCreateCalendarSubscriptionQueueUsers() { return this === EnumRecurringJobType.createCalendarSubscriptionQueueUsers; }\n public isEcwidIntegrationQueueTenants() { return this === EnumRecurringJobType.ecwidIntegrationQueueTenants; }\n public isEeBriaIntegrationQueueTenants() { return this === EnumRecurringJobType.eeBriaIntegrationQueueTenants; }\n public isOldDutyStockCaptureQueueTenants() { return this === EnumRecurringJobType.oldDutyStockCaptureQueueTenants; }\n public isCommerce7IntegrationQueueTenants() { return this === EnumRecurringJobType.commerce7IntegrationQueueTenants; }\n public isAccountsDailyMaintenance() { return this === EnumRecurringJobType.accountsDailyMaintenance; }\n public isAmazonIntegrationQueueTenants() { return this === EnumRecurringJobType.amazonIntegrationQueueTenants; }\n public isInvoicesToXeroSync() { return this === EnumRecurringJobType.invoicesToXeroSync; }\n\n public static getValues(): readonly EnumRecurringJobType[] {\n return EnumRecurringJobType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumRecurringJobType[] {\n return EnumRecurringJobType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumRecurringJobType {\n const found = EnumRecurringJobType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumRecurringJobType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumRecurringJobType): EnumRecurringJobType {\n const found = name ? EnumRecurringJobType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumRecurringJobType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumReportBuilder implements BaseEnumType {\n private static allValues: EnumReportBuilder[] = []; // make sure this is top-most\n \n public static none = new EnumReportBuilder(0, \"None\", \"enum_report_builder_none\");\n public static orders = new EnumReportBuilder(1, \"Orders\", \"enum_report_builder_orders\");\n public static orderLines = new EnumReportBuilder(2, \"OrderLines\", \"enum_report_builder_order_lines\");\n public static containers = new EnumReportBuilder(3, \"Containers\", \"enum_report_builder_containers\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumReportBuilder.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumReportBuilder.none; }\n public isOrders() { return this === EnumReportBuilder.orders; }\n public isOrderLines() { return this === EnumReportBuilder.orderLines; }\n public isContainers() { return this === EnumReportBuilder.containers; }\n\n public static getValues(): readonly EnumReportBuilder[] {\n return EnumReportBuilder.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumReportBuilder[] {\n return EnumReportBuilder.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumReportBuilder {\n const found = EnumReportBuilder.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumReportBuilder - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumReportBuilder): EnumReportBuilder {\n const found = name ? EnumReportBuilder.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumReportBuilder - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumRetailPaymentMethod implements BaseEnumType {\n private static allValues: EnumRetailPaymentMethod[] = []; // make sure this is top-most\n \n public static none = new EnumRetailPaymentMethod(0, \"None\", \"enum_retail_payment_method_none\");\n public static debitCreditCard = new EnumRetailPaymentMethod(1, \"DebitCreditCard\", \"enum_retail_payment_method_debit_credit_card\");\n public static other = new EnumRetailPaymentMethod(2, \"Other\", \"enum_retail_payment_method_other\");\n public static cash = new EnumRetailPaymentMethod(3, \"Cash\", \"enum_retail_payment_method_cash\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumRetailPaymentMethod.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumRetailPaymentMethod.none; }\n public isDebitCreditCard() { return this === EnumRetailPaymentMethod.debitCreditCard; }\n public isOther() { return this === EnumRetailPaymentMethod.other; }\n public isCash() { return this === EnumRetailPaymentMethod.cash; }\n\n public static getValues(): readonly EnumRetailPaymentMethod[] {\n return EnumRetailPaymentMethod.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumRetailPaymentMethod[] {\n return EnumRetailPaymentMethod.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumRetailPaymentMethod {\n const found = EnumRetailPaymentMethod.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumRetailPaymentMethod - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumRetailPaymentMethod): EnumRetailPaymentMethod {\n const found = name ? EnumRetailPaymentMethod.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumRetailPaymentMethod - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumSalesTextType implements BaseEnumType {\n private static allValues: EnumSalesTextType[] = []; // make sure this is top-most\n \n public static pseudoAll = new EnumSalesTextType(65, \"PseudoAll\", \"enum_sales_text_type_pseudo_all\");\n public static brewery = new EnumSalesTextType(66, \"Brewery\", \"enum_sales_text_type_brewery\");\n public static accounts = new EnumSalesTextType(67, \"Accounts\", \"enum_sales_text_type_accounts\");\n public static driver = new EnumSalesTextType(68, \"Driver\", \"enum_sales_text_type_driver\");\n public static letter = new EnumSalesTextType(76, \"Letter\", \"enum_sales_text_type_letter\");\n public static rep = new EnumSalesTextType(82, \"Rep\", \"enum_sales_text_type_rep\");\n public static telesales = new EnumSalesTextType(84, \"Telesales\", \"enum_sales_text_type_telesales\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumSalesTextType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isPseudoAll() { return this === EnumSalesTextType.pseudoAll; }\n public isBrewery() { return this === EnumSalesTextType.brewery; }\n public isAccounts() { return this === EnumSalesTextType.accounts; }\n public isDriver() { return this === EnumSalesTextType.driver; }\n public isLetter() { return this === EnumSalesTextType.letter; }\n public isRep() { return this === EnumSalesTextType.rep; }\n public isTelesales() { return this === EnumSalesTextType.telesales; }\n\n public static getValues(): readonly EnumSalesTextType[] {\n return EnumSalesTextType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumSalesTextType[] {\n return EnumSalesTextType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumSalesTextType {\n const found = EnumSalesTextType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumSalesTextType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumSalesTextType): EnumSalesTextType {\n const found = name ? EnumSalesTextType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumSalesTextType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumSalesVisitAssociatedEntityType implements BaseEnumType {\n private static allValues: EnumSalesVisitAssociatedEntityType[] = []; // make sure this is top-most\n \n public static outlet = new EnumSalesVisitAssociatedEntityType(0, \"Outlet\", \"enum_sales_visit_associated_entity_type_outlet\");\n public static group = new EnumSalesVisitAssociatedEntityType(1, \"Group\", \"enum_sales_visit_associated_entity_type_group\");\n public static lead = new EnumSalesVisitAssociatedEntityType(2, \"Lead\", \"enum_sales_visit_associated_entity_type_lead\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumSalesVisitAssociatedEntityType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isOutlet() { return this === EnumSalesVisitAssociatedEntityType.outlet; }\n public isGroup() { return this === EnumSalesVisitAssociatedEntityType.group; }\n public isLead() { return this === EnumSalesVisitAssociatedEntityType.lead; }\n\n public static getValues(): readonly EnumSalesVisitAssociatedEntityType[] {\n return EnumSalesVisitAssociatedEntityType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumSalesVisitAssociatedEntityType[] {\n return EnumSalesVisitAssociatedEntityType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumSalesVisitAssociatedEntityType {\n const found = EnumSalesVisitAssociatedEntityType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumSalesVisitAssociatedEntityType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumSalesVisitAssociatedEntityType): EnumSalesVisitAssociatedEntityType {\n const found = name ? EnumSalesVisitAssociatedEntityType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumSalesVisitAssociatedEntityType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumScannerInputType implements BaseEnumType {\n private static allValues: EnumScannerInputType[] = []; // make sure this is top-most\n \n public static unknown = new EnumScannerInputType(0, \"Unknown\", \"enum_scanner_input_type_unknown\");\n public static labelContainer = new EnumScannerInputType(1, \"LabelContainer\", \"enum_scanner_input_type_label_container\");\n public static containerNumbering = new EnumScannerInputType(2, \"ContainerNumbering\", \"enum_scanner_input_type_container_numbering\");\n public static labelling = new EnumScannerInputType(3, \"Labelling\", \"enum_scanner_input_type_labelling\");\n public static containerRacking = new EnumScannerInputType(4, \"ContainerRacking\", \"enum_scanner_input_type_container_racking\");\n public static racking = new EnumScannerInputType(5, \"Racking\", \"enum_scanner_input_type_racking\");\n public static containerOut = new EnumScannerInputType(6, \"ContainerOut\", \"enum_scanner_input_type_container_out\");\n public static delivery = new EnumScannerInputType(7, \"Delivery\", \"enum_scanner_input_type_delivery\");\n public static containerCheck = new EnumScannerInputType(8, \"ContainerCheck\", \"enum_scanner_input_type_container_check\");\n public static containerIn = new EnumScannerInputType(9, \"ContainerIn\", \"enum_scanner_input_type_container_in\");\n public static return = new EnumScannerInputType(10, \"Return\", \"enum_scanner_input_type_return\");\n public static pallet = new EnumScannerInputType(11, \"Pallet\", \"enum_scanner_input_type_pallet\");\n public static stockEntry = new EnumScannerInputType(12, \"StockEntry\", \"enum_scanner_input_type_stock_entry\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumScannerInputType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isUnknown() { return this === EnumScannerInputType.unknown; }\n public isLabelContainer() { return this === EnumScannerInputType.labelContainer; }\n public isContainerNumbering() { return this === EnumScannerInputType.containerNumbering; }\n public isLabelling() { return this === EnumScannerInputType.labelling; }\n public isContainerRacking() { return this === EnumScannerInputType.containerRacking; }\n public isRacking() { return this === EnumScannerInputType.racking; }\n public isContainerOut() { return this === EnumScannerInputType.containerOut; }\n public isDelivery() { return this === EnumScannerInputType.delivery; }\n public isContainerCheck() { return this === EnumScannerInputType.containerCheck; }\n public isContainerIn() { return this === EnumScannerInputType.containerIn; }\n public isReturn() { return this === EnumScannerInputType.return; }\n public isPallet() { return this === EnumScannerInputType.pallet; }\n public isStockEntry() { return this === EnumScannerInputType.stockEntry; }\n\n public static getValues(): readonly EnumScannerInputType[] {\n return EnumScannerInputType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumScannerInputType[] {\n return EnumScannerInputType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumScannerInputType {\n const found = EnumScannerInputType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumScannerInputType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumScannerInputType): EnumScannerInputType {\n const found = name ? EnumScannerInputType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumScannerInputType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumScannerType implements BaseEnumType {\n private static allValues: EnumScannerType[] = []; // make sure this is top-most\n \n public static optimus = new EnumScannerType(1, \"Optimus\", \"enum_scanner_type_optimus\");\n public static cipherLab8300 = new EnumScannerType(2, \"CipherLab8300\", \"enum_scanner_type_cipher_lab8300\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumScannerType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isOptimus() { return this === EnumScannerType.optimus; }\n public isCipherLab8300() { return this === EnumScannerType.cipherLab8300; }\n\n public static getValues(): readonly EnumScannerType[] {\n return EnumScannerType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumScannerType[] {\n return EnumScannerType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumScannerType {\n const found = EnumScannerType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumScannerType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumScannerType): EnumScannerType {\n const found = name ? EnumScannerType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumScannerType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumSecurityProduct implements BaseEnumType {\n private static allValues: EnumSecurityProduct[] = []; // make sure this is top-most\n \n public static none = new EnumSecurityProduct(0, \"None\", \"enum_security_product_none\");\n public static brewMan = new EnumSecurityProduct(1, \"BrewMan\", \"enum_security_product_brew_man\");\n public static accountsLink = new EnumSecurityProduct(2, \"AccountsLink\", \"enum_security_product_accounts_link\");\n public static brewRep = new EnumSecurityProduct(3, \"BrewRep\", \"enum_security_product_brew_rep\");\n public static production = new EnumSecurityProduct(4, \"Production\", \"enum_security_product_production\");\n public static deliveryApp = new EnumSecurityProduct(5, \"DeliveryApp\", \"enum_security_product_delivery_app\");\n public static bMArchive = new EnumSecurityProduct(6, \"BMArchive\", \"enum_security_product_b_m_archive\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumSecurityProduct.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumSecurityProduct.none; }\n public isBrewMan() { return this === EnumSecurityProduct.brewMan; }\n public isAccountsLink() { return this === EnumSecurityProduct.accountsLink; }\n public isBrewRep() { return this === EnumSecurityProduct.brewRep; }\n public isProduction() { return this === EnumSecurityProduct.production; }\n public isDeliveryApp() { return this === EnumSecurityProduct.deliveryApp; }\n public isBMArchive() { return this === EnumSecurityProduct.bMArchive; }\n\n public static getValues(): readonly EnumSecurityProduct[] {\n return EnumSecurityProduct.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumSecurityProduct[] {\n return EnumSecurityProduct.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumSecurityProduct {\n const found = EnumSecurityProduct.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumSecurityProduct - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumSecurityProduct): EnumSecurityProduct {\n const found = name ? EnumSecurityProduct.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumSecurityProduct - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumSessionStatus implements BaseEnumType {\n private static allValues: EnumSessionStatus[] = []; // make sure this is top-most\n \n public static none = new EnumSessionStatus(0, \"None\", \"enum_session_status_none\");\n public static allSessionsUsed = new EnumSessionStatus(1, \"AllSessionsUsed\", \"enum_session_status_all_sessions_used\");\n public static billingNotValid = new EnumSessionStatus(2, \"BillingNotValid\", \"enum_session_status_billing_not_valid\");\n public static success = new EnumSessionStatus(3, \"Success\", \"enum_session_status_success\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumSessionStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumSessionStatus.none; }\n public isAllSessionsUsed() { return this === EnumSessionStatus.allSessionsUsed; }\n public isBillingNotValid() { return this === EnumSessionStatus.billingNotValid; }\n public isSuccess() { return this === EnumSessionStatus.success; }\n\n public static getValues(): readonly EnumSessionStatus[] {\n return EnumSessionStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumSessionStatus[] {\n return EnumSessionStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumSessionStatus {\n const found = EnumSessionStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumSessionStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumSessionStatus): EnumSessionStatus {\n const found = name ? EnumSessionStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumSessionStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumShopifyOrderTag implements BaseEnumType {\n private static allValues: EnumShopifyOrderTag[] = []; // make sure this is top-most\n \n public static inBrewman = new EnumShopifyOrderTag(0, \"InBrewman\", \"enum_shopify_order_tag_in_brewman\");\n public static noBrewman = new EnumShopifyOrderTag(1, \"NoBrewman\", \"enum_shopify_order_tag_no_brewman\");\n public static badBrewmanProduct = new EnumShopifyOrderTag(2, \"BadBrewmanProduct\", \"enum_shopify_order_tag_bad_brewman_product\");\n public static allowBrewManMiscellaneous = new EnumShopifyOrderTag(3, \"AllowBrewManMiscellaneous\", \"enum_shopify_order_tag_allow_brew_man_miscellaneous\");\n public static badBrewmanDelivery = new EnumShopifyOrderTag(4, \"BadBrewmanDelivery\", \"enum_shopify_order_tag_bad_brewman_delivery\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumShopifyOrderTag.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isInBrewman() { return this === EnumShopifyOrderTag.inBrewman; }\n public isNoBrewman() { return this === EnumShopifyOrderTag.noBrewman; }\n public isBadBrewmanProduct() { return this === EnumShopifyOrderTag.badBrewmanProduct; }\n public isAllowBrewManMiscellaneous() { return this === EnumShopifyOrderTag.allowBrewManMiscellaneous; }\n public isBadBrewmanDelivery() { return this === EnumShopifyOrderTag.badBrewmanDelivery; }\n\n public static getValues(): readonly EnumShopifyOrderTag[] {\n return EnumShopifyOrderTag.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumShopifyOrderTag[] {\n return EnumShopifyOrderTag.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumShopifyOrderTag {\n const found = EnumShopifyOrderTag.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumShopifyOrderTag - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumShopifyOrderTag): EnumShopifyOrderTag {\n const found = name ? EnumShopifyOrderTag.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumShopifyOrderTag - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumSmsContext implements BaseEnumType {\n private static allValues: EnumSmsContext[] = []; // make sure this is top-most\n \n public static unknown = new EnumSmsContext(0, \"Unknown\", \"enum_sms_context_unknown\");\n public static despatchNotification = new EnumSmsContext(1, \"DespatchNotification\", \"enum_sms_context_despatch_notification\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumSmsContext.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isUnknown() { return this === EnumSmsContext.unknown; }\n public isDespatchNotification() { return this === EnumSmsContext.despatchNotification; }\n\n public static getValues(): readonly EnumSmsContext[] {\n return EnumSmsContext.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumSmsContext[] {\n return EnumSmsContext.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumSmsContext {\n const found = EnumSmsContext.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumSmsContext - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumSmsContext): EnumSmsContext {\n const found = name ? EnumSmsContext.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumSmsContext - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumSmsStatus implements BaseEnumType {\n private static allValues: EnumSmsStatus[] = []; // make sure this is top-most\n \n public static unknown = new EnumSmsStatus(0, \"Unknown\", \"enum_sms_status_unknown\");\n public static notSent = new EnumSmsStatus(1, \"NotSent\", \"enum_sms_status_not_sent\");\n public static sent = new EnumSmsStatus(2, \"Sent\", \"enum_sms_status_sent\");\n public static delivered = new EnumSmsStatus(3, \"Delivered\", \"enum_sms_status_delivered\");\n public static failed = new EnumSmsStatus(4, \"Failed\", \"enum_sms_status_failed\");\n public static unconfirmed = new EnumSmsStatus(5, \"Unconfirmed\", \"enum_sms_status_unconfirmed\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumSmsStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isUnknown() { return this === EnumSmsStatus.unknown; }\n public isNotSent() { return this === EnumSmsStatus.notSent; }\n public isSent() { return this === EnumSmsStatus.sent; }\n public isDelivered() { return this === EnumSmsStatus.delivered; }\n public isFailed() { return this === EnumSmsStatus.failed; }\n public isUnconfirmed() { return this === EnumSmsStatus.unconfirmed; }\n\n public static getValues(): readonly EnumSmsStatus[] {\n return EnumSmsStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumSmsStatus[] {\n return EnumSmsStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumSmsStatus {\n const found = EnumSmsStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumSmsStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumSmsStatus): EnumSmsStatus {\n const found = name ? EnumSmsStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumSmsStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumSouthAfricanDutyTariff implements BaseEnumType {\n private static allValues: EnumSouthAfricanDutyTariff[] = []; // make sure this is top-most\n \n public static none = new EnumSouthAfricanDutyTariff(0, \"None\", \"enum_south_african_duty_tariff_none\");\n public static unknown = new EnumSouthAfricanDutyTariff(1, \"Unknown\", \"enum_south_african_duty_tariff_unknown\");\n public static traditionalAfricanBeerFromMalt_Sa2203_00_05 = new EnumSouthAfricanDutyTariff(22030005, \"TraditionalAfricanBeerFromMalt_Sa2203_00_05\", \"enum_south_african_duty_tariff_traditional_african_beer_from_malt__sa2203_00_05\");\n public static otherBeerFromMalt_Sa2203_00_90 = new EnumSouthAfricanDutyTariff(22030090, \"OtherBeerFromMalt_Sa2203_00_90\", \"enum_south_african_duty_tariff_other_beer_from_malt__sa2203_00_90\");\n public static brandyUpTo2L_Sa2208_20_11 = new EnumSouthAfricanDutyTariff(22082011, \"BrandyUpTo2L_Sa2208_20_11\", \"enum_south_african_duty_tariff_brandy_up_to2_l__sa2208_20_11\");\n public static otherSpiritFromGrapeUpTo2L_Sa2208_20_19 = new EnumSouthAfricanDutyTariff(22082019, \"OtherSpiritFromGrapeUpTo2L_Sa2208_20_19\", \"enum_south_african_duty_tariff_other_spirit_from_grape_up_to2_l__sa2208_20_19\");\n public static brandyOver2L_Sa2208_20_91 = new EnumSouthAfricanDutyTariff(22082091, \"BrandyOver2L_Sa2208_20_91\", \"enum_south_african_duty_tariff_brandy_over2_l__sa2208_20_91\");\n public static otherSpiritFromGrapeOver2L_Sa2208_20_99 = new EnumSouthAfricanDutyTariff(22082099, \"OtherSpiritFromGrapeOver2L_Sa2208_20_99\", \"enum_south_african_duty_tariff_other_spirit_from_grape_over2_l__sa2208_20_99\");\n public static whiskyUpTo2L_Sa2208_30_10 = new EnumSouthAfricanDutyTariff(22083010, \"WhiskyUpTo2L_Sa2208_30_10\", \"enum_south_african_duty_tariff_whisky_up_to2_l__sa2208_30_10\");\n public static whiskyOver2L_Sa2208_30_90 = new EnumSouthAfricanDutyTariff(22083090, \"WhiskyOver2L_Sa2208_30_90\", \"enum_south_african_duty_tariff_whisky_over2_l__sa2208_30_90\");\n public static rumUpTo2L_Sa2208_40_10 = new EnumSouthAfricanDutyTariff(22084010, \"RumUpTo2L_Sa2208_40_10\", \"enum_south_african_duty_tariff_rum_up_to2_l__sa2208_40_10\");\n public static rumOver2L_Sa2208_40_90 = new EnumSouthAfricanDutyTariff(22084090, \"RumOver2L_Sa2208_40_90\", \"enum_south_african_duty_tariff_rum_over2_l__sa2208_40_90\");\n public static ginUpTo2L_Sa2208_50_10 = new EnumSouthAfricanDutyTariff(22085010, \"GinUpTo2L_Sa2208_50_10\", \"enum_south_african_duty_tariff_gin_up_to2_l__sa2208_50_10\");\n public static ginOver2L_Sa2208_50_90 = new EnumSouthAfricanDutyTariff(22085090, \"GinOver2L_Sa2208_50_90\", \"enum_south_african_duty_tariff_gin_over2_l__sa2208_50_90\");\n public static vodkaUpTo2L_Sa2208_60_10 = new EnumSouthAfricanDutyTariff(22086010, \"VodkaUpTo2L_Sa2208_60_10\", \"enum_south_african_duty_tariff_vodka_up_to2_l__sa2208_60_10\");\n public static vodkaOver2L_Sa2208_60_90 = new EnumSouthAfricanDutyTariff(22086090, \"VodkaOver2L_Sa2208_60_90\", \"enum_south_african_duty_tariff_vodka_over2_l__sa2208_60_90\");\n public static otherSpiritsUpTo2LWithAbv15_1To23_0_Sa2208_90_21 = new EnumSouthAfricanDutyTariff(22089021, \"OtherSpiritsUpTo2LWithAbv15_1To23_0_Sa2208_90_21\", \"enum_south_african_duty_tariff_other_spirits_up_to2_l_with_abv15_1_to23_0__sa2208_90_21\");\n public static otherSpiritsUpTo2L_Sa2208_90_22 = new EnumSouthAfricanDutyTariff(22089022, \"OtherSpiritsUpTo2L_Sa2208_90_22\", \"enum_south_african_duty_tariff_other_spirits_up_to2_l__sa2208_90_22\");\n public static otherSpiritsOver2LWithAbv15_1To23_0_Sa2208_90_91 = new EnumSouthAfricanDutyTariff(22089091, \"OtherSpiritsOver2LWithAbv15_1To23_0_Sa2208_90_91\", \"enum_south_african_duty_tariff_other_spirits_over2_l_with_abv15_1_to23_0__sa2208_90_91\");\n public static otherSpiritsOver2L_Sa2208_90_92 = new EnumSouthAfricanDutyTariff(22089092, \"OtherSpiritsOver2L_Sa2208_90_92\", \"enum_south_african_duty_tariff_other_spirits_over2_l__sa2208_90_92\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumSouthAfricanDutyTariff.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumSouthAfricanDutyTariff.none; }\n public isUnknown() { return this === EnumSouthAfricanDutyTariff.unknown; }\n public isTraditionalAfricanBeerFromMalt_Sa2203_00_05() { return this === EnumSouthAfricanDutyTariff.traditionalAfricanBeerFromMalt_Sa2203_00_05; }\n public isOtherBeerFromMalt_Sa2203_00_90() { return this === EnumSouthAfricanDutyTariff.otherBeerFromMalt_Sa2203_00_90; }\n public isBrandyUpTo2L_Sa2208_20_11() { return this === EnumSouthAfricanDutyTariff.brandyUpTo2L_Sa2208_20_11; }\n public isOtherSpiritFromGrapeUpTo2L_Sa2208_20_19() { return this === EnumSouthAfricanDutyTariff.otherSpiritFromGrapeUpTo2L_Sa2208_20_19; }\n public isBrandyOver2L_Sa2208_20_91() { return this === EnumSouthAfricanDutyTariff.brandyOver2L_Sa2208_20_91; }\n public isOtherSpiritFromGrapeOver2L_Sa2208_20_99() { return this === EnumSouthAfricanDutyTariff.otherSpiritFromGrapeOver2L_Sa2208_20_99; }\n public isWhiskyUpTo2L_Sa2208_30_10() { return this === EnumSouthAfricanDutyTariff.whiskyUpTo2L_Sa2208_30_10; }\n public isWhiskyOver2L_Sa2208_30_90() { return this === EnumSouthAfricanDutyTariff.whiskyOver2L_Sa2208_30_90; }\n public isRumUpTo2L_Sa2208_40_10() { return this === EnumSouthAfricanDutyTariff.rumUpTo2L_Sa2208_40_10; }\n public isRumOver2L_Sa2208_40_90() { return this === EnumSouthAfricanDutyTariff.rumOver2L_Sa2208_40_90; }\n public isGinUpTo2L_Sa2208_50_10() { return this === EnumSouthAfricanDutyTariff.ginUpTo2L_Sa2208_50_10; }\n public isGinOver2L_Sa2208_50_90() { return this === EnumSouthAfricanDutyTariff.ginOver2L_Sa2208_50_90; }\n public isVodkaUpTo2L_Sa2208_60_10() { return this === EnumSouthAfricanDutyTariff.vodkaUpTo2L_Sa2208_60_10; }\n public isVodkaOver2L_Sa2208_60_90() { return this === EnumSouthAfricanDutyTariff.vodkaOver2L_Sa2208_60_90; }\n public isOtherSpiritsUpTo2LWithAbv15_1To23_0_Sa2208_90_21() { return this === EnumSouthAfricanDutyTariff.otherSpiritsUpTo2LWithAbv15_1To23_0_Sa2208_90_21; }\n public isOtherSpiritsUpTo2L_Sa2208_90_22() { return this === EnumSouthAfricanDutyTariff.otherSpiritsUpTo2L_Sa2208_90_22; }\n public isOtherSpiritsOver2LWithAbv15_1To23_0_Sa2208_90_91() { return this === EnumSouthAfricanDutyTariff.otherSpiritsOver2LWithAbv15_1To23_0_Sa2208_90_91; }\n public isOtherSpiritsOver2L_Sa2208_90_92() { return this === EnumSouthAfricanDutyTariff.otherSpiritsOver2L_Sa2208_90_92; }\n\n public static getValues(): readonly EnumSouthAfricanDutyTariff[] {\n return EnumSouthAfricanDutyTariff.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumSouthAfricanDutyTariff[] {\n return EnumSouthAfricanDutyTariff.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumSouthAfricanDutyTariff {\n const found = EnumSouthAfricanDutyTariff.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumSouthAfricanDutyTariff - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumSouthAfricanDutyTariff): EnumSouthAfricanDutyTariff {\n const found = name ? EnumSouthAfricanDutyTariff.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumSouthAfricanDutyTariff - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumSpiritDutyExemptionReason implements BaseEnumType {\n private static allValues: EnumSpiritDutyExemptionReason[] = []; // make sure this is top-most\n \n public static none = new EnumSpiritDutyExemptionReason(0, \"None\", \"enum_spirit_duty_exemption_reason_none\");\n public static forFortifyingWine = new EnumSpiritDutyExemptionReason(1, \"ForFortifyingWine\", \"enum_spirit_duty_exemption_reason_for_fortifying_wine\");\n public static soldForExemptUse = new EnumSpiritDutyExemptionReason(2, \"SoldForExemptUse\", \"enum_spirit_duty_exemption_reason_sold_for_exempt_use\");\n public static forExemptUse = new EnumSpiritDutyExemptionReason(3, \"ForExemptUse\", \"enum_spirit_duty_exemption_reason_for_exempt_use\");\n public static denatured = new EnumSpiritDutyExemptionReason(4, \"Denatured\", \"enum_spirit_duty_exemption_reason_denatured\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumSpiritDutyExemptionReason.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumSpiritDutyExemptionReason.none; }\n public isForFortifyingWine() { return this === EnumSpiritDutyExemptionReason.forFortifyingWine; }\n public isSoldForExemptUse() { return this === EnumSpiritDutyExemptionReason.soldForExemptUse; }\n public isForExemptUse() { return this === EnumSpiritDutyExemptionReason.forExemptUse; }\n public isDenatured() { return this === EnumSpiritDutyExemptionReason.denatured; }\n\n public static getValues(): readonly EnumSpiritDutyExemptionReason[] {\n return EnumSpiritDutyExemptionReason.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumSpiritDutyExemptionReason[] {\n return EnumSpiritDutyExemptionReason.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumSpiritDutyExemptionReason {\n const found = EnumSpiritDutyExemptionReason.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumSpiritDutyExemptionReason - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumSpiritDutyExemptionReason): EnumSpiritDutyExemptionReason {\n const found = name ? EnumSpiritDutyExemptionReason.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumSpiritDutyExemptionReason - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumStandardOrder implements BaseEnumType {\n private static allValues: EnumStandardOrder[] = []; // make sure this is top-most\n \n public static fullPriceDutyPaid = new EnumStandardOrder(0, \"FullPriceDutyPaid\", \"enum_standard_order_full_price_duty_paid\");\n public static priceExcludingDutyDutySuspended = new EnumStandardOrder(1, \"PriceExcludingDutyDutySuspended\", \"enum_standard_order_price_excluding_duty_duty_suspended\");\n public static fullPriceDutyPaidElsewhere = new EnumStandardOrder(2, \"FullPriceDutyPaidElsewhere\", \"enum_standard_order_full_price_duty_paid_elsewhere\");\n public static exportDutySuspended = new EnumStandardOrder(3, \"ExportDutySuspended\", \"enum_standard_order_export_duty_suspended\");\n public static consumeOnPremisesNoDuty = new EnumStandardOrder(4, \"ConsumeOnPremisesNoDuty\", \"enum_standard_order_consume_on_premises_no_duty\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumStandardOrder.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isFullPriceDutyPaid() { return this === EnumStandardOrder.fullPriceDutyPaid; }\n public isPriceExcludingDutyDutySuspended() { return this === EnumStandardOrder.priceExcludingDutyDutySuspended; }\n public isFullPriceDutyPaidElsewhere() { return this === EnumStandardOrder.fullPriceDutyPaidElsewhere; }\n public isExportDutySuspended() { return this === EnumStandardOrder.exportDutySuspended; }\n public isConsumeOnPremisesNoDuty() { return this === EnumStandardOrder.consumeOnPremisesNoDuty; }\n\n public static getValues(): readonly EnumStandardOrder[] {\n return EnumStandardOrder.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumStandardOrder[] {\n return EnumStandardOrder.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumStandardOrder {\n const found = EnumStandardOrder.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumStandardOrder - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumStandardOrder): EnumStandardOrder {\n const found = name ? EnumStandardOrder.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumStandardOrder - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumStockAdjustDutyImplication implements BaseEnumType {\n private static allValues: EnumStockAdjustDutyImplication[] = []; // make sure this is top-most\n \n public static noDuty = new EnumStockAdjustDutyImplication(0, \"NoDuty\", \"enum_stock_adjust_duty_implication_no_duty\");\n public static dutiable = new EnumStockAdjustDutyImplication(1, \"Dutiable\", \"enum_stock_adjust_duty_implication_dutiable\");\n public static dutySuspended3rdParty = new EnumStockAdjustDutyImplication(2, \"DutySuspended3rdParty\", \"enum_stock_adjust_duty_implication_duty_suspended3rd_party\");\n public static produced = new EnumStockAdjustDutyImplication(3, \"Produced\", \"enum_stock_adjust_duty_implication_produced\");\n public static consumedOnPremisesNoDuty = new EnumStockAdjustDutyImplication(4, \"ConsumedOnPremisesNoDuty\", \"enum_stock_adjust_duty_implication_consumed_on_premises_no_duty\");\n public static destroyed = new EnumStockAdjustDutyImplication(5, \"Destroyed\", \"enum_stock_adjust_duty_implication_destroyed\");\n public static losses = new EnumStockAdjustDutyImplication(6, \"Losses\", \"enum_stock_adjust_duty_implication_losses\");\n public static theft = new EnumStockAdjustDutyImplication(7, \"Theft\", \"enum_stock_adjust_duty_implication_theft\");\n public static physicalStockCount = new EnumStockAdjustDutyImplication(8, \"PhysicalStockCount\", \"enum_stock_adjust_duty_implication_physical_stock_count\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumStockAdjustDutyImplication.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNoDuty() { return this === EnumStockAdjustDutyImplication.noDuty; }\n public isDutiable() { return this === EnumStockAdjustDutyImplication.dutiable; }\n public isDutySuspended3rdParty() { return this === EnumStockAdjustDutyImplication.dutySuspended3rdParty; }\n public isProduced() { return this === EnumStockAdjustDutyImplication.produced; }\n public isConsumedOnPremisesNoDuty() { return this === EnumStockAdjustDutyImplication.consumedOnPremisesNoDuty; }\n public isDestroyed() { return this === EnumStockAdjustDutyImplication.destroyed; }\n public isLosses() { return this === EnumStockAdjustDutyImplication.losses; }\n public isTheft() { return this === EnumStockAdjustDutyImplication.theft; }\n public isPhysicalStockCount() { return this === EnumStockAdjustDutyImplication.physicalStockCount; }\n\n public static getValues(): readonly EnumStockAdjustDutyImplication[] {\n return EnumStockAdjustDutyImplication.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumStockAdjustDutyImplication[] {\n return EnumStockAdjustDutyImplication.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumStockAdjustDutyImplication {\n const found = EnumStockAdjustDutyImplication.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumStockAdjustDutyImplication - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumStockAdjustDutyImplication): EnumStockAdjustDutyImplication {\n const found = name ? EnumStockAdjustDutyImplication.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumStockAdjustDutyImplication - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumStockChangeReason implements BaseEnumType {\n private static allValues: EnumStockChangeReason[] = []; // make sure this is top-most\n \n public static none = new EnumStockChangeReason(0, \"None\", \"enum_stock_change_reason_none\");\n public static adjustmentIn = new EnumStockChangeReason(1, \"AdjustmentIn\", \"enum_stock_change_reason_adjustment_in\");\n public static adjustmentOut = new EnumStockChangeReason(2, \"AdjustmentOut\", \"enum_stock_change_reason_adjustment_out\");\n public static goodsIn = new EnumStockChangeReason(3, \"GoodsIn\", \"enum_stock_change_reason_goods_in\");\n public static goodsOut = new EnumStockChangeReason(4, \"GoodsOut\", \"enum_stock_change_reason_goods_out\");\n public static goodsReturned = new EnumStockChangeReason(5, \"GoodsReturned\", \"enum_stock_change_reason_goods_returned\");\n public static movementIn = new EnumStockChangeReason(6, \"MovementIn\", \"enum_stock_change_reason_movement_in\");\n public static movementOut = new EnumStockChangeReason(7, \"MovementOut\", \"enum_stock_change_reason_movement_out\");\n public static recoveredIn = new EnumStockChangeReason(8, \"RecoveredIn\", \"enum_stock_change_reason_recovered_in\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumStockChangeReason.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumStockChangeReason.none; }\n public isAdjustmentIn() { return this === EnumStockChangeReason.adjustmentIn; }\n public isAdjustmentOut() { return this === EnumStockChangeReason.adjustmentOut; }\n public isGoodsIn() { return this === EnumStockChangeReason.goodsIn; }\n public isGoodsOut() { return this === EnumStockChangeReason.goodsOut; }\n public isGoodsReturned() { return this === EnumStockChangeReason.goodsReturned; }\n public isMovementIn() { return this === EnumStockChangeReason.movementIn; }\n public isMovementOut() { return this === EnumStockChangeReason.movementOut; }\n public isRecoveredIn() { return this === EnumStockChangeReason.recoveredIn; }\n\n public static getValues(): readonly EnumStockChangeReason[] {\n return EnumStockChangeReason.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumStockChangeReason[] {\n return EnumStockChangeReason.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumStockChangeReason {\n const found = EnumStockChangeReason.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumStockChangeReason - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumStockChangeReason): EnumStockChangeReason {\n const found = name ? EnumStockChangeReason.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumStockChangeReason - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumStockItemType implements BaseEnumType {\n private static allValues: EnumStockItemType[] = []; // make sure this is top-most\n \n public static unknown = new EnumStockItemType(0, \"Unknown\", \"enum_stock_item_type_unknown\");\n public static material = new EnumStockItemType(1, \"Material\", \"enum_stock_item_type_material\");\n public static product = new EnumStockItemType(2, \"Product\", \"enum_stock_item_type_product\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumStockItemType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isUnknown() { return this === EnumStockItemType.unknown; }\n public isMaterial() { return this === EnumStockItemType.material; }\n public isProduct() { return this === EnumStockItemType.product; }\n\n public static getValues(): readonly EnumStockItemType[] {\n return EnumStockItemType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumStockItemType[] {\n return EnumStockItemType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumStockItemType {\n const found = EnumStockItemType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumStockItemType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumStockItemType): EnumStockItemType {\n const found = name ? EnumStockItemType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumStockItemType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumStockMovementReferenceSource implements BaseEnumType {\n private static allValues: EnumStockMovementReferenceSource[] = []; // make sure this is top-most\n \n public static none = new EnumStockMovementReferenceSource(0, \"None\", \"enum_stock_movement_reference_source_none\");\n public static order = new EnumStockMovementReferenceSource(1, \"Order\", \"enum_stock_movement_reference_source_order\");\n public static credit = new EnumStockMovementReferenceSource(2, \"Credit\", \"enum_stock_movement_reference_source_credit\");\n public static transferFrom = new EnumStockMovementReferenceSource(3, \"TransferFrom\", \"enum_stock_movement_reference_source_transfer_from\");\n public static transferTo = new EnumStockMovementReferenceSource(4, \"TransferTo\", \"enum_stock_movement_reference_source_transfer_to\");\n public static assemblyInput = new EnumStockMovementReferenceSource(5, \"AssemblyInput\", \"enum_stock_movement_reference_source_assembly_input\");\n public static assemblyOutput = new EnumStockMovementReferenceSource(6, \"AssemblyOutput\", \"enum_stock_movement_reference_source_assembly_output\");\n public static purchaseOrder = new EnumStockMovementReferenceSource(7, \"PurchaseOrder\", \"enum_stock_movement_reference_source_purchase_order\");\n public static processInput = new EnumStockMovementReferenceSource(8, \"ProcessInput\", \"enum_stock_movement_reference_source_process_input\");\n public static processOutput = new EnumStockMovementReferenceSource(9, \"ProcessOutput\", \"enum_stock_movement_reference_source_process_output\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumStockMovementReferenceSource.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumStockMovementReferenceSource.none; }\n public isOrder() { return this === EnumStockMovementReferenceSource.order; }\n public isCredit() { return this === EnumStockMovementReferenceSource.credit; }\n public isTransferFrom() { return this === EnumStockMovementReferenceSource.transferFrom; }\n public isTransferTo() { return this === EnumStockMovementReferenceSource.transferTo; }\n public isAssemblyInput() { return this === EnumStockMovementReferenceSource.assemblyInput; }\n public isAssemblyOutput() { return this === EnumStockMovementReferenceSource.assemblyOutput; }\n public isPurchaseOrder() { return this === EnumStockMovementReferenceSource.purchaseOrder; }\n public isProcessInput() { return this === EnumStockMovementReferenceSource.processInput; }\n public isProcessOutput() { return this === EnumStockMovementReferenceSource.processOutput; }\n\n public static getValues(): readonly EnumStockMovementReferenceSource[] {\n return EnumStockMovementReferenceSource.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumStockMovementReferenceSource[] {\n return EnumStockMovementReferenceSource.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumStockMovementReferenceSource {\n const found = EnumStockMovementReferenceSource.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumStockMovementReferenceSource - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumStockMovementReferenceSource): EnumStockMovementReferenceSource {\n const found = name ? EnumStockMovementReferenceSource.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumStockMovementReferenceSource - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumStockTakeStatus implements BaseEnumType {\n private static allValues: EnumStockTakeStatus[] = []; // make sure this is top-most\n \n public static none = new EnumStockTakeStatus(0, \"None\", \"enum_stock_take_status_none\");\n public static open = new EnumStockTakeStatus(1, \"Open\", \"enum_stock_take_status_open\");\n public static inProgress = new EnumStockTakeStatus(2, \"InProgress\", \"enum_stock_take_status_in_progress\");\n public static cancelled = new EnumStockTakeStatus(3, \"Cancelled\", \"enum_stock_take_status_cancelled\");\n public static complete = new EnumStockTakeStatus(4, \"Complete\", \"enum_stock_take_status_complete\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumStockTakeStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumStockTakeStatus.none; }\n public isOpen() { return this === EnumStockTakeStatus.open; }\n public isInProgress() { return this === EnumStockTakeStatus.inProgress; }\n public isCancelled() { return this === EnumStockTakeStatus.cancelled; }\n public isComplete() { return this === EnumStockTakeStatus.complete; }\n\n public static getValues(): readonly EnumStockTakeStatus[] {\n return EnumStockTakeStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumStockTakeStatus[] {\n return EnumStockTakeStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumStockTakeStatus {\n const found = EnumStockTakeStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumStockTakeStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumStockTakeStatus): EnumStockTakeStatus {\n const found = name ? EnumStockTakeStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumStockTakeStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumStockTransferStatus implements BaseEnumType {\n private static allValues: EnumStockTransferStatus[] = []; // make sure this is top-most\n \n public static none = new EnumStockTransferStatus(0, \"None\", \"enum_stock_transfer_status_none\");\n public static open = new EnumStockTransferStatus(1, \"Open\", \"enum_stock_transfer_status_open\");\n public static cancelled = new EnumStockTransferStatus(2, \"Cancelled\", \"enum_stock_transfer_status_cancelled\");\n public static complete = new EnumStockTransferStatus(3, \"Complete\", \"enum_stock_transfer_status_complete\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumStockTransferStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumStockTransferStatus.none; }\n public isOpen() { return this === EnumStockTransferStatus.open; }\n public isCancelled() { return this === EnumStockTransferStatus.cancelled; }\n public isComplete() { return this === EnumStockTransferStatus.complete; }\n\n public static getValues(): readonly EnumStockTransferStatus[] {\n return EnumStockTransferStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumStockTransferStatus[] {\n return EnumStockTransferStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumStockTransferStatus {\n const found = EnumStockTransferStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumStockTransferStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumStockTransferStatus): EnumStockTransferStatus {\n const found = name ? EnumStockTransferStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumStockTransferStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumStockUom implements BaseEnumType {\n private static allValues: EnumStockUom[] = []; // make sure this is top-most\n \n public static units = new EnumStockUom(0, \"Units\", \"enum_stock_uom_units\");\n public static barrels = new EnumStockUom(1, \"Barrels\", \"enum_stock_uom_barrels\");\n public static litres = new EnumStockUom(2, \"Litres\", \"enum_stock_uom_litres\");\n public static hectolitres = new EnumStockUom(3, \"Hectolitres\", \"enum_stock_uom_hectolitres\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumStockUom.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isUnits() { return this === EnumStockUom.units; }\n public isBarrels() { return this === EnumStockUom.barrels; }\n public isLitres() { return this === EnumStockUom.litres; }\n public isHectolitres() { return this === EnumStockUom.hectolitres; }\n\n public static getValues(): readonly EnumStockUom[] {\n return EnumStockUom.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumStockUom[] {\n return EnumStockUom.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumStockUom {\n const found = EnumStockUom.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumStockUom - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumStockUom): EnumStockUom {\n const found = name ? EnumStockUom.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumStockUom - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumStripePaymentMethod implements BaseEnumType {\n private static allValues: EnumStripePaymentMethod[] = []; // make sure this is top-most\n \n public static card = new EnumStripePaymentMethod(0, \"Card\", \"enum_stripe_payment_method_card\");\n public static bacsDebit = new EnumStripePaymentMethod(1, \"BacsDebit\", \"enum_stripe_payment_method_bacs_debit\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumStripePaymentMethod.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isCard() { return this === EnumStripePaymentMethod.card; }\n public isBacsDebit() { return this === EnumStripePaymentMethod.bacsDebit; }\n\n public static getValues(): readonly EnumStripePaymentMethod[] {\n return EnumStripePaymentMethod.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumStripePaymentMethod[] {\n return EnumStripePaymentMethod.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumStripePaymentMethod {\n const found = EnumStripePaymentMethod.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumStripePaymentMethod - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumStripePaymentMethod): EnumStripePaymentMethod {\n const found = name ? EnumStripePaymentMethod.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumStripePaymentMethod - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumSwedishDutyTariff implements BaseEnumType {\n private static allValues: EnumSwedishDutyTariff[] = []; // make sure this is top-most\n \n public static none = new EnumSwedishDutyTariff(0, \"None\", \"enum_swedish_duty_tariff_none\");\n public static unknown = new EnumSwedishDutyTariff(1, \"Unknown\", \"enum_swedish_duty_tariff_unknown\");\n public static beer_B000 = new EnumSwedishDutyTariff(2, \"Beer_B000\", \"enum_swedish_duty_tariff_beer__b000\");\n public static stillWine_W200 = new EnumSwedishDutyTariff(3, \"StillWine_W200\", \"enum_swedish_duty_tariff_still_wine__w200\");\n public static sparklingWine_W300 = new EnumSwedishDutyTariff(4, \"SparklingWine_W300\", \"enum_swedish_duty_tariff_sparkling_wine__w300\");\n public static intermediate_I000 = new EnumSwedishDutyTariff(5, \"Intermediate_I000\", \"enum_swedish_duty_tariff_intermediate__i000\");\n public static spirits_S200 = new EnumSwedishDutyTariff(6, \"Spirits_S200\", \"enum_swedish_duty_tariff_spirits__s200\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumSwedishDutyTariff.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumSwedishDutyTariff.none; }\n public isUnknown() { return this === EnumSwedishDutyTariff.unknown; }\n public isBeer_B000() { return this === EnumSwedishDutyTariff.beer_B000; }\n public isStillWine_W200() { return this === EnumSwedishDutyTariff.stillWine_W200; }\n public isSparklingWine_W300() { return this === EnumSwedishDutyTariff.sparklingWine_W300; }\n public isIntermediate_I000() { return this === EnumSwedishDutyTariff.intermediate_I000; }\n public isSpirits_S200() { return this === EnumSwedishDutyTariff.spirits_S200; }\n\n public static getValues(): readonly EnumSwedishDutyTariff[] {\n return EnumSwedishDutyTariff.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumSwedishDutyTariff[] {\n return EnumSwedishDutyTariff.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumSwedishDutyTariff {\n const found = EnumSwedishDutyTariff.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumSwedishDutyTariff - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumSwedishDutyTariff): EnumSwedishDutyTariff {\n const found = name ? EnumSwedishDutyTariff.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumSwedishDutyTariff - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumTaskRepeatBasis implements BaseEnumType {\n private static allValues: EnumTaskRepeatBasis[] = []; // make sure this is top-most\n \n public static none = new EnumTaskRepeatBasis(0, \"None\", \"enum_task_repeat_basis_none\");\n public static everyDay = new EnumTaskRepeatBasis(1, \"EveryDay\", \"enum_task_repeat_basis_every_day\");\n public static everyWeekday = new EnumTaskRepeatBasis(2, \"EveryWeekday\", \"enum_task_repeat_basis_every_weekday\");\n public static everyNWeeks = new EnumTaskRepeatBasis(3, \"EveryNWeeks\", \"enum_task_repeat_basis_every_n_weeks\");\n public static everyNMonths = new EnumTaskRepeatBasis(4, \"EveryNMonths\", \"enum_task_repeat_basis_every_n_months\");\n public static lastMatchingDayOfEachMonth = new EnumTaskRepeatBasis(5, \"LastMatchingDayOfEachMonth\", \"enum_task_repeat_basis_last_matching_day_of_each_month\");\n public static nthMatchingDayOfEachMonth = new EnumTaskRepeatBasis(6, \"NthMatchingDayOfEachMonth\", \"enum_task_repeat_basis_nth_matching_day_of_each_month\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumTaskRepeatBasis.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumTaskRepeatBasis.none; }\n public isEveryDay() { return this === EnumTaskRepeatBasis.everyDay; }\n public isEveryWeekday() { return this === EnumTaskRepeatBasis.everyWeekday; }\n public isEveryNWeeks() { return this === EnumTaskRepeatBasis.everyNWeeks; }\n public isEveryNMonths() { return this === EnumTaskRepeatBasis.everyNMonths; }\n public isLastMatchingDayOfEachMonth() { return this === EnumTaskRepeatBasis.lastMatchingDayOfEachMonth; }\n public isNthMatchingDayOfEachMonth() { return this === EnumTaskRepeatBasis.nthMatchingDayOfEachMonth; }\n\n public static getValues(): readonly EnumTaskRepeatBasis[] {\n return EnumTaskRepeatBasis.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumTaskRepeatBasis[] {\n return EnumTaskRepeatBasis.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumTaskRepeatBasis {\n const found = EnumTaskRepeatBasis.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumTaskRepeatBasis - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumTaskRepeatBasis): EnumTaskRepeatBasis {\n const found = name ? EnumTaskRepeatBasis.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumTaskRepeatBasis - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumTaskStatus implements BaseEnumType {\n private static allValues: EnumTaskStatus[] = []; // make sure this is top-most\n \n public static open = new EnumTaskStatus(0, \"Open\", \"enum_task_status_open\");\n public static complete = new EnumTaskStatus(1, \"Complete\", \"enum_task_status_complete\");\n public static cancelled = new EnumTaskStatus(2, \"Cancelled\", \"enum_task_status_cancelled\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumTaskStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isOpen() { return this === EnumTaskStatus.open; }\n public isComplete() { return this === EnumTaskStatus.complete; }\n public isCancelled() { return this === EnumTaskStatus.cancelled; }\n\n public static getValues(): readonly EnumTaskStatus[] {\n return EnumTaskStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumTaskStatus[] {\n return EnumTaskStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumTaskStatus {\n const found = EnumTaskStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumTaskStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumTaskStatus): EnumTaskStatus {\n const found = name ? EnumTaskStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumTaskStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumTpPaymentMethod implements BaseEnumType {\n private static allValues: EnumTpPaymentMethod[] = []; // make sure this is top-most\n \n public static stripe = new EnumTpPaymentMethod(0, \"Stripe\", \"enum_tp_payment_method_stripe\");\n public static account = new EnumTpPaymentMethod(1, \"Account\", \"enum_tp_payment_method_account\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumTpPaymentMethod.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isStripe() { return this === EnumTpPaymentMethod.stripe; }\n public isAccount() { return this === EnumTpPaymentMethod.account; }\n\n public static getValues(): readonly EnumTpPaymentMethod[] {\n return EnumTpPaymentMethod.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumTpPaymentMethod[] {\n return EnumTpPaymentMethod.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumTpPaymentMethod {\n const found = EnumTpPaymentMethod.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumTpPaymentMethod - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumTpPaymentMethod): EnumTpPaymentMethod {\n const found = name ? EnumTpPaymentMethod.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumTpPaymentMethod - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumTpProductListSortOption implements BaseEnumType {\n private static allValues: EnumTpProductListSortOption[] = []; // make sure this is top-most\n \n public static abvLowToHigh = new EnumTpProductListSortOption(0, \"AbvLowToHigh\", \"enum_tp_product_list_sort_option_abv_low_to_high\");\n public static abvHighToLow = new EnumTpProductListSortOption(1, \"AbvHighToLow\", \"enum_tp_product_list_sort_option_abv_high_to_low\");\n public static priceLowToHigh = new EnumTpProductListSortOption(2, \"PriceLowToHigh\", \"enum_tp_product_list_sort_option_price_low_to_high\");\n public static priceHighToLow = new EnumTpProductListSortOption(3, \"PriceHighToLow\", \"enum_tp_product_list_sort_option_price_high_to_low\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumTpProductListSortOption.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isAbvLowToHigh() { return this === EnumTpProductListSortOption.abvLowToHigh; }\n public isAbvHighToLow() { return this === EnumTpProductListSortOption.abvHighToLow; }\n public isPriceLowToHigh() { return this === EnumTpProductListSortOption.priceLowToHigh; }\n public isPriceHighToLow() { return this === EnumTpProductListSortOption.priceHighToLow; }\n\n public static getValues(): readonly EnumTpProductListSortOption[] {\n return EnumTpProductListSortOption.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumTpProductListSortOption[] {\n return EnumTpProductListSortOption.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumTpProductListSortOption {\n const found = EnumTpProductListSortOption.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumTpProductListSortOption - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumTpProductListSortOption): EnumTpProductListSortOption {\n const found = name ? EnumTpProductListSortOption.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumTpProductListSortOption - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumTpSessionErrorReason implements BaseEnumType {\n private static allValues: EnumTpSessionErrorReason[] = []; // make sure this is top-most\n \n public static none = new EnumTpSessionErrorReason(0, \"None\", \"enum_tp_session_error_reason_none\");\n public static notFound = new EnumTpSessionErrorReason(1, \"NotFound\", \"enum_tp_session_error_reason_not_found\");\n public static onHold = new EnumTpSessionErrorReason(2, \"OnHold\", \"enum_tp_session_error_reason_on_hold\");\n public static invalidCredentials = new EnumTpSessionErrorReason(3, \"InvalidCredentials\", \"enum_tp_session_error_reason_invalid_credentials\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumTpSessionErrorReason.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumTpSessionErrorReason.none; }\n public isNotFound() { return this === EnumTpSessionErrorReason.notFound; }\n public isOnHold() { return this === EnumTpSessionErrorReason.onHold; }\n public isInvalidCredentials() { return this === EnumTpSessionErrorReason.invalidCredentials; }\n\n public static getValues(): readonly EnumTpSessionErrorReason[] {\n return EnumTpSessionErrorReason.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumTpSessionErrorReason[] {\n return EnumTpSessionErrorReason.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumTpSessionErrorReason {\n const found = EnumTpSessionErrorReason.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumTpSessionErrorReason - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumTpSessionErrorReason): EnumTpSessionErrorReason {\n const found = name ? EnumTpSessionErrorReason.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumTpSessionErrorReason - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumTransactionType implements BaseEnumType {\n private static allValues: EnumTransactionType[] = []; // make sure this is top-most\n \n public static credit = new EnumTransactionType(-1, \"Credit\", \"enum_transaction_type_credit\");\n public static order = new EnumTransactionType(1, \"Order\", \"enum_transaction_type_order\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumTransactionType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isCredit() { return this === EnumTransactionType.credit; }\n public isOrder() { return this === EnumTransactionType.order; }\n\n public static getValues(): readonly EnumTransactionType[] {\n return EnumTransactionType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumTransactionType[] {\n return EnumTransactionType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumTransactionType {\n const found = EnumTransactionType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumTransactionType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumTransactionType): EnumTransactionType {\n const found = name ? EnumTransactionType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumTransactionType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumUkBeerDutySection implements BaseEnumType {\n private static allValues: EnumUkBeerDutySection[] = []; // make sure this is top-most\n \n public static none = new EnumUkBeerDutySection(0, \"None\", \"enum_uk_beer_duty_section_none\");\n public static standardRate = new EnumUkBeerDutySection(1, \"StandardRate\", \"enum_uk_beer_duty_section_standard_rate\");\n public static lowStrength = new EnumUkBeerDutySection(2, \"LowStrength\", \"enum_uk_beer_duty_section_low_strength\");\n public static lowerRate = new EnumUkBeerDutySection(3, \"LowerRate\", \"enum_uk_beer_duty_section_lower_rate\");\n public static variableRate = new EnumUkBeerDutySection(4, \"VariableRate\", \"enum_uk_beer_duty_section_variable_rate\");\n public static highStrengthBeer = new EnumUkBeerDutySection(5, \"HighStrengthBeer\", \"enum_uk_beer_duty_section_high_strength_beer\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumUkBeerDutySection.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumUkBeerDutySection.none; }\n public isStandardRate() { return this === EnumUkBeerDutySection.standardRate; }\n public isLowStrength() { return this === EnumUkBeerDutySection.lowStrength; }\n public isLowerRate() { return this === EnumUkBeerDutySection.lowerRate; }\n public isVariableRate() { return this === EnumUkBeerDutySection.variableRate; }\n public isHighStrengthBeer() { return this === EnumUkBeerDutySection.highStrengthBeer; }\n\n public static getValues(): readonly EnumUkBeerDutySection[] {\n return EnumUkBeerDutySection.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumUkBeerDutySection[] {\n return EnumUkBeerDutySection.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumUkBeerDutySection {\n const found = EnumUkBeerDutySection.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumUkBeerDutySection - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumUkBeerDutySection): EnumUkBeerDutySection {\n const found = name ? EnumUkBeerDutySection.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumUkBeerDutySection - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumUkDutyRate implements BaseEnumType {\n private static allValues: EnumUkDutyRate[] = []; // make sure this is top-most\n \n public static none = new EnumUkDutyRate(0, \"None\", \"enum_uk_duty_rate_none\");\n public static beer = new EnumUkDutyRate(1, \"Beer\", \"enum_uk_duty_rate_beer\");\n public static lowStrengthBeer = new EnumUkDutyRate(2, \"LowStrengthBeer\", \"enum_uk_duty_rate_low_strength_beer\");\n public static highStrengthBeer = new EnumUkDutyRate(3, \"HighStrengthBeer\", \"enum_uk_duty_rate_high_strength_beer\");\n public static stillCiderPerry = new EnumUkDutyRate(4, \"StillCiderPerry\", \"enum_uk_duty_rate_still_cider_perry\");\n public static sparklingCiderPerry = new EnumUkDutyRate(5, \"SparklingCiderPerry\", \"enum_uk_duty_rate_sparkling_cider_perry\");\n public static stillWine = new EnumUkDutyRate(6, \"StillWine\", \"enum_uk_duty_rate_still_wine\");\n public static sparklingWine = new EnumUkDutyRate(7, \"SparklingWine\", \"enum_uk_duty_rate_sparkling_wine\");\n public static spirits = new EnumUkDutyRate(8, \"Spirits\", \"enum_uk_duty_rate_spirits\");\n public static wineAsSpirit = new EnumUkDutyRate(9, \"WineAsSpirit\", \"enum_uk_duty_rate_wine_as_spirit\");\n public static scotchWhisky = new EnumUkDutyRate(10, \"ScotchWhisky\", \"enum_uk_duty_rate_scotch_whisky\");\n public static irishWhiskey = new EnumUkDutyRate(11, \"IrishWhiskey\", \"enum_uk_duty_rate_irish_whiskey\");\n public static generalPerL = new EnumUkDutyRate(12, \"GeneralPerL\", \"enum_uk_duty_rate_general_per_l\");\n public static generalPerLaa = new EnumUkDutyRate(13, \"GeneralPerLaa\", \"enum_uk_duty_rate_general_per_laa\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumUkDutyRate.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumUkDutyRate.none; }\n public isBeer() { return this === EnumUkDutyRate.beer; }\n public isLowStrengthBeer() { return this === EnumUkDutyRate.lowStrengthBeer; }\n public isHighStrengthBeer() { return this === EnumUkDutyRate.highStrengthBeer; }\n public isStillCiderPerry() { return this === EnumUkDutyRate.stillCiderPerry; }\n public isSparklingCiderPerry() { return this === EnumUkDutyRate.sparklingCiderPerry; }\n public isStillWine() { return this === EnumUkDutyRate.stillWine; }\n public isSparklingWine() { return this === EnumUkDutyRate.sparklingWine; }\n public isSpirits() { return this === EnumUkDutyRate.spirits; }\n public isWineAsSpirit() { return this === EnumUkDutyRate.wineAsSpirit; }\n public isScotchWhisky() { return this === EnumUkDutyRate.scotchWhisky; }\n public isIrishWhiskey() { return this === EnumUkDutyRate.irishWhiskey; }\n public isGeneralPerL() { return this === EnumUkDutyRate.generalPerL; }\n public isGeneralPerLaa() { return this === EnumUkDutyRate.generalPerLaa; }\n\n public static getValues(): readonly EnumUkDutyRate[] {\n return EnumUkDutyRate.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumUkDutyRate[] {\n return EnumUkDutyRate.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumUkDutyRate {\n const found = EnumUkDutyRate.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumUkDutyRate - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumUkDutyRate): EnumUkDutyRate {\n const found = name ? EnumUkDutyRate.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumUkDutyRate - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumUkDutyReturnType implements BaseEnumType {\n private static allValues: EnumUkDutyReturnType[] = []; // make sure this is top-most\n \n public static none = new EnumUkDutyReturnType(0, \"None\", \"enum_uk_duty_return_type_none\");\n public static beforeAug1DutyReturn = new EnumUkDutyReturnType(1, \"BeforeAug1DutyReturn\", \"enum_uk_duty_return_type_before_aug1_duty_return\");\n public static afterAug1DutyReturn = new EnumUkDutyReturnType(2, \"AfterAug1DutyReturn\", \"enum_uk_duty_return_type_after_aug1_duty_return\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumUkDutyReturnType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumUkDutyReturnType.none; }\n public isBeforeAug1DutyReturn() { return this === EnumUkDutyReturnType.beforeAug1DutyReturn; }\n public isAfterAug1DutyReturn() { return this === EnumUkDutyReturnType.afterAug1DutyReturn; }\n\n public static getValues(): readonly EnumUkDutyReturnType[] {\n return EnumUkDutyReturnType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumUkDutyReturnType[] {\n return EnumUkDutyReturnType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumUkDutyReturnType {\n const found = EnumUkDutyReturnType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumUkDutyReturnType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumUkDutyReturnType): EnumUkDutyReturnType {\n const found = name ? EnumUkDutyReturnType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumUkDutyReturnType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumUkNewDutyAbvRange implements BaseEnumType {\n private static allValues: EnumUkNewDutyAbvRange[] = []; // make sure this is top-most\n \n public static none = new EnumUkNewDutyAbvRange(0, \"None\", \"enum_uk_new_duty_abv_range_none\");\n public static to3_4 = new EnumUkNewDutyAbvRange(1, \"To3_4\", \"enum_uk_new_duty_abv_range_to3_4\");\n public static from3_5To8_4 = new EnumUkNewDutyAbvRange(2, \"From3_5To8_4\", \"enum_uk_new_duty_abv_range_from3_5_to8_4\");\n public static from8_5To22 = new EnumUkNewDutyAbvRange(3, \"From8_5To22\", \"enum_uk_new_duty_abv_range_from8_5_to22\");\n public static from23 = new EnumUkNewDutyAbvRange(4, \"From23\", \"enum_uk_new_duty_abv_range_from23\");\n public static from3_5To5_5 = new EnumUkNewDutyAbvRange(5, \"From3_5To5_5\", \"enum_uk_new_duty_abv_range_from3_5_to5_5\");\n public static from5_6To8_4 = new EnumUkNewDutyAbvRange(6, \"From5_6To8_4\", \"enum_uk_new_duty_abv_range_from5_6_to8_4\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumUkNewDutyAbvRange.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumUkNewDutyAbvRange.none; }\n public isTo3_4() { return this === EnumUkNewDutyAbvRange.to3_4; }\n public isFrom3_5To8_4() { return this === EnumUkNewDutyAbvRange.from3_5To8_4; }\n public isFrom8_5To22() { return this === EnumUkNewDutyAbvRange.from8_5To22; }\n public isFrom23() { return this === EnumUkNewDutyAbvRange.from23; }\n public isFrom3_5To5_5() { return this === EnumUkNewDutyAbvRange.from3_5To5_5; }\n public isFrom5_6To8_4() { return this === EnumUkNewDutyAbvRange.from5_6To8_4; }\n\n public static getValues(): readonly EnumUkNewDutyAbvRange[] {\n return EnumUkNewDutyAbvRange.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumUkNewDutyAbvRange[] {\n return EnumUkNewDutyAbvRange.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumUkNewDutyAbvRange {\n const found = EnumUkNewDutyAbvRange.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumUkNewDutyAbvRange - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumUkNewDutyAbvRange): EnumUkNewDutyAbvRange {\n const found = name ? EnumUkNewDutyAbvRange.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumUkNewDutyAbvRange - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumUkNewDutyProductType implements BaseEnumType {\n private static allValues: EnumUkNewDutyProductType[] = []; // make sure this is top-most\n \n public static none = new EnumUkNewDutyProductType(0, \"None\", \"enum_uk_new_duty_product_type_none\");\n public static beer = new EnumUkNewDutyProductType(1, \"Beer\", \"enum_uk_new_duty_product_type_beer\");\n public static wine = new EnumUkNewDutyProductType(2, \"Wine\", \"enum_uk_new_duty_product_type_wine\");\n public static spirits = new EnumUkNewDutyProductType(3, \"Spirits\", \"enum_uk_new_duty_product_type_spirits\");\n public static stillCider = new EnumUkNewDutyProductType(4, \"StillCider\", \"enum_uk_new_duty_product_type_still_cider\");\n public static sparklingCider = new EnumUkNewDutyProductType(5, \"SparklingCider\", \"enum_uk_new_duty_product_type_sparkling_cider\");\n public static otherFermented = new EnumUkNewDutyProductType(6, \"OtherFermented\", \"enum_uk_new_duty_product_type_other_fermented\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumUkNewDutyProductType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumUkNewDutyProductType.none; }\n public isBeer() { return this === EnumUkNewDutyProductType.beer; }\n public isWine() { return this === EnumUkNewDutyProductType.wine; }\n public isSpirits() { return this === EnumUkNewDutyProductType.spirits; }\n public isStillCider() { return this === EnumUkNewDutyProductType.stillCider; }\n public isSparklingCider() { return this === EnumUkNewDutyProductType.sparklingCider; }\n public isOtherFermented() { return this === EnumUkNewDutyProductType.otherFermented; }\n\n public static getValues(): readonly EnumUkNewDutyProductType[] {\n return EnumUkNewDutyProductType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumUkNewDutyProductType[] {\n return EnumUkNewDutyProductType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumUkNewDutyProductType {\n const found = EnumUkNewDutyProductType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumUkNewDutyProductType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumUkNewDutyProductType): EnumUkNewDutyProductType {\n const found = name ? EnumUkNewDutyProductType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumUkNewDutyProductType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumUkNewDutyRate implements BaseEnumType {\n private static allValues: EnumUkNewDutyRate[] = []; // make sure this is top-most\n \n public static none = new EnumUkNewDutyRate(0, \"None\", \"enum_uk_new_duty_rate_none\");\n public static nonSpiritsAbvTo3_4NotDraught = new EnumUkNewDutyRate(1, \"NonSpiritsAbvTo3_4NotDraught\", \"enum_uk_new_duty_rate_non_spirits_abv_to3_4_not_draught\");\n public static nonSpiritsAbvTo3_4Draught = new EnumUkNewDutyRate(2, \"NonSpiritsAbvTo3_4Draught\", \"enum_uk_new_duty_rate_non_spirits_abv_to3_4_draught\");\n public static spiritsAbvTo3_4NotDraught = new EnumUkNewDutyRate(3, \"SpiritsAbvTo3_4NotDraught\", \"enum_uk_new_duty_rate_spirits_abv_to3_4_not_draught\");\n public static spiritsAbvTo3_4Draught = new EnumUkNewDutyRate(4, \"SpiritsAbvTo3_4Draught\", \"enum_uk_new_duty_rate_spirits_abv_to3_4_draught\");\n public static mediumCiderNotDraught = new EnumUkNewDutyRate(5, \"MediumCiderNotDraught\", \"enum_uk_new_duty_rate_medium_cider_not_draught\");\n public static mediumCiderDraught = new EnumUkNewDutyRate(6, \"MediumCiderDraught\", \"enum_uk_new_duty_rate_medium_cider_draught\");\n public static mediumBeerNotDraught = new EnumUkNewDutyRate(7, \"MediumBeerNotDraught\", \"enum_uk_new_duty_rate_medium_beer_not_draught\");\n public static mediumBeerDraught = new EnumUkNewDutyRate(8, \"MediumBeerDraught\", \"enum_uk_new_duty_rate_medium_beer_draught\");\n public static mediumWineNotDraught = new EnumUkNewDutyRate(9, \"MediumWineNotDraught\", \"enum_uk_new_duty_rate_medium_wine_not_draught\");\n public static mediumWineDraught = new EnumUkNewDutyRate(10, \"MediumWineDraught\", \"enum_uk_new_duty_rate_medium_wine_draught\");\n public static mediumSpiritsNotDraught = new EnumUkNewDutyRate(11, \"MediumSpiritsNotDraught\", \"enum_uk_new_duty_rate_medium_spirits_not_draught\");\n public static mediumSpiritsDraught = new EnumUkNewDutyRate(12, \"MediumSpiritsDraught\", \"enum_uk_new_duty_rate_medium_spirits_draught\");\n public static abv8_5To22_0 = new EnumUkNewDutyRate(13, \"Abv8_5To22_0\", \"enum_uk_new_duty_rate_abv8_5_to22_0\");\n public static abvFrom22_1 = new EnumUkNewDutyRate(14, \"AbvFrom22_1\", \"enum_uk_new_duty_rate_abv_from22_1\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumUkNewDutyRate.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumUkNewDutyRate.none; }\n public isNonSpiritsAbvTo3_4NotDraught() { return this === EnumUkNewDutyRate.nonSpiritsAbvTo3_4NotDraught; }\n public isNonSpiritsAbvTo3_4Draught() { return this === EnumUkNewDutyRate.nonSpiritsAbvTo3_4Draught; }\n public isSpiritsAbvTo3_4NotDraught() { return this === EnumUkNewDutyRate.spiritsAbvTo3_4NotDraught; }\n public isSpiritsAbvTo3_4Draught() { return this === EnumUkNewDutyRate.spiritsAbvTo3_4Draught; }\n public isMediumCiderNotDraught() { return this === EnumUkNewDutyRate.mediumCiderNotDraught; }\n public isMediumCiderDraught() { return this === EnumUkNewDutyRate.mediumCiderDraught; }\n public isMediumBeerNotDraught() { return this === EnumUkNewDutyRate.mediumBeerNotDraught; }\n public isMediumBeerDraught() { return this === EnumUkNewDutyRate.mediumBeerDraught; }\n public isMediumWineNotDraught() { return this === EnumUkNewDutyRate.mediumWineNotDraught; }\n public isMediumWineDraught() { return this === EnumUkNewDutyRate.mediumWineDraught; }\n public isMediumSpiritsNotDraught() { return this === EnumUkNewDutyRate.mediumSpiritsNotDraught; }\n public isMediumSpiritsDraught() { return this === EnumUkNewDutyRate.mediumSpiritsDraught; }\n public isAbv8_5To22_0() { return this === EnumUkNewDutyRate.abv8_5To22_0; }\n public isAbvFrom22_1() { return this === EnumUkNewDutyRate.abvFrom22_1; }\n\n public static getValues(): readonly EnumUkNewDutyRate[] {\n return EnumUkNewDutyRate.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumUkNewDutyRate[] {\n return EnumUkNewDutyRate.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumUkNewDutyRate {\n const found = EnumUkNewDutyRate.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumUkNewDutyRate - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumUkNewDutyRate): EnumUkNewDutyRate {\n const found = name ? EnumUkNewDutyRate.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumUkNewDutyRate - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumUllageReturnMethod implements BaseEnumType {\n private static allValues: EnumUllageReturnMethod[] = []; // make sure this is top-most\n \n public static none = new EnumUllageReturnMethod(0, \"None\", \"enum_ullage_return_method_none\");\n public static driverPickup = new EnumUllageReturnMethod(1, \"DriverPickup\", \"enum_ullage_return_method_driver_pickup\");\n public static courier = new EnumUllageReturnMethod(2, \"Courier\", \"enum_ullage_return_method_courier\");\n public static customerDropOff = new EnumUllageReturnMethod(3, \"CustomerDropOff\", \"enum_ullage_return_method_customer_drop_off\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumUllageReturnMethod.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumUllageReturnMethod.none; }\n public isDriverPickup() { return this === EnumUllageReturnMethod.driverPickup; }\n public isCourier() { return this === EnumUllageReturnMethod.courier; }\n public isCustomerDropOff() { return this === EnumUllageReturnMethod.customerDropOff; }\n\n public static getValues(): readonly EnumUllageReturnMethod[] {\n return EnumUllageReturnMethod.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumUllageReturnMethod[] {\n return EnumUllageReturnMethod.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumUllageReturnMethod {\n const found = EnumUllageReturnMethod.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumUllageReturnMethod - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumUllageReturnMethod): EnumUllageReturnMethod {\n const found = name ? EnumUllageReturnMethod.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumUllageReturnMethod - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumUllageStatus implements BaseEnumType {\n private static allValues: EnumUllageStatus[] = []; // make sure this is top-most\n \n public static unknown = new EnumUllageStatus(0, \"Unknown\", \"enum_ullage_status_unknown\");\n public static open = new EnumUllageStatus(1, \"Open\", \"enum_ullage_status_open\");\n public static completed = new EnumUllageStatus(2, \"Completed\", \"enum_ullage_status_completed\");\n public static cancelled = new EnumUllageStatus(5, \"Cancelled\", \"enum_ullage_status_cancelled\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumUllageStatus.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isUnknown() { return this === EnumUllageStatus.unknown; }\n public isOpen() { return this === EnumUllageStatus.open; }\n public isCompleted() { return this === EnumUllageStatus.completed; }\n public isCancelled() { return this === EnumUllageStatus.cancelled; }\n\n public static getValues(): readonly EnumUllageStatus[] {\n return EnumUllageStatus.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumUllageStatus[] {\n return EnumUllageStatus.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumUllageStatus {\n const found = EnumUllageStatus.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumUllageStatus - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumUllageStatus): EnumUllageStatus {\n const found = name ? EnumUllageStatus.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumUllageStatus - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumUsageType implements BaseEnumType {\n private static allValues: EnumUsageType[] = []; // make sure this is top-most\n \n public static none = new EnumUsageType(0, \"None\", \"enum_usage_type_none\");\n public static sms = new EnumUsageType(1, \"Sms\", \"enum_usage_type_sms\");\n public static addressAutocomplete = new EnumUsageType(2, \"AddressAutocomplete\", \"enum_usage_type_address_autocomplete\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumUsageType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumUsageType.none; }\n public isSms() { return this === EnumUsageType.sms; }\n public isAddressAutocomplete() { return this === EnumUsageType.addressAutocomplete; }\n\n public static getValues(): readonly EnumUsageType[] {\n return EnumUsageType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumUsageType[] {\n return EnumUsageType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumUsageType {\n const found = EnumUsageType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumUsageType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumUsageType): EnumUsageType {\n const found = name ? EnumUsageType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumUsageType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumUserTenantRole implements BaseEnumType {\n private static allValues: EnumUserTenantRole[] = []; // make sure this is top-most\n \n public static outletsAndGroupsView = new EnumUserTenantRole(0, \"OutletsAndGroupsView\", \"enum_user_tenant_role_outlets_and_groups_view\");\n public static outletsAndGroupsEdit = new EnumUserTenantRole(1, \"OutletsAndGroupsEdit\", \"enum_user_tenant_role_outlets_and_groups_edit\");\n public static outletsAndGroupsAdmin = new EnumUserTenantRole(2, \"OutletsAndGroupsAdmin\", \"enum_user_tenant_role_outlets_and_groups_admin\");\n public static tenantsView = new EnumUserTenantRole(3, \"TenantsView\", \"enum_user_tenant_role_tenants_view\");\n public static tenantsEdit = new EnumUserTenantRole(4, \"TenantsEdit\", \"enum_user_tenant_role_tenants_edit\");\n public static productsView = new EnumUserTenantRole(5, \"ProductsView\", \"enum_user_tenant_role_products_view\");\n public static productsEdit = new EnumUserTenantRole(6, \"ProductsEdit\", \"enum_user_tenant_role_products_edit\");\n public static productsAdmin = new EnumUserTenantRole(7, \"ProductsAdmin\", \"enum_user_tenant_role_products_admin\");\n public static pricesView = new EnumUserTenantRole(8, \"PricesView\", \"enum_user_tenant_role_prices_view\");\n public static pricesEdit = new EnumUserTenantRole(9, \"PricesEdit\", \"enum_user_tenant_role_prices_edit\");\n public static pricesAdmin = new EnumUserTenantRole(10, \"PricesAdmin\", \"enum_user_tenant_role_prices_admin\");\n public static stockView = new EnumUserTenantRole(11, \"StockView\", \"enum_user_tenant_role_stock_view\");\n public static stockEdit = new EnumUserTenantRole(12, \"StockEdit\", \"enum_user_tenant_role_stock_edit\");\n public static stockAdmin = new EnumUserTenantRole(13, \"StockAdmin\", \"enum_user_tenant_role_stock_admin\");\n public static allUsers = new EnumUserTenantRole(14, \"AllUsers\", \"enum_user_tenant_role_all_users\");\n public static containersView = new EnumUserTenantRole(15, \"ContainersView\", \"enum_user_tenant_role_containers_view\");\n public static containersAdmin = new EnumUserTenantRole(16, \"ContainersAdmin\", \"enum_user_tenant_role_containers_admin\");\n public static ordersView = new EnumUserTenantRole(17, \"OrdersView\", \"enum_user_tenant_role_orders_view\");\n public static ordersAdmin = new EnumUserTenantRole(18, \"OrdersAdmin\", \"enum_user_tenant_role_orders_admin\");\n public static distributionView = new EnumUserTenantRole(19, \"DistributionView\", \"enum_user_tenant_role_distribution_view\");\n public static distributionAdmin = new EnumUserTenantRole(20, \"DistributionAdmin\", \"enum_user_tenant_role_distribution_admin\");\n public static premierSystemsAdmin = new EnumUserTenantRole(21, \"PremierSystemsAdmin\", \"enum_user_tenant_role_premier_systems_admin\");\n public static companyAdmin = new EnumUserTenantRole(22, \"CompanyAdmin\", \"enum_user_tenant_role_company_admin\");\n public static usersView = new EnumUserTenantRole(23, \"UsersView\", \"enum_user_tenant_role_users_view\");\n public static usersAdmin = new EnumUserTenantRole(24, \"UsersAdmin\", \"enum_user_tenant_role_users_admin\");\n public static dutyView = new EnumUserTenantRole(25, \"DutyView\", \"enum_user_tenant_role_duty_view\");\n public static dutyAdmin = new EnumUserTenantRole(26, \"DutyAdmin\", \"enum_user_tenant_role_duty_admin\");\n public static accountPostingView = new EnumUserTenantRole(27, \"AccountPostingView\", \"enum_user_tenant_role_account_posting_view\");\n public static accountPostingAdmin = new EnumUserTenantRole(28, \"AccountPostingAdmin\", \"enum_user_tenant_role_account_posting_admin\");\n public static reportsView = new EnumUserTenantRole(29, \"ReportsView\", \"enum_user_tenant_role_reports_view\");\n public static systemInternal = new EnumUserTenantRole(30, \"SystemInternal\", \"enum_user_tenant_role_system_internal\");\n public static billingAdmin = new EnumUserTenantRole(31, \"BillingAdmin\", \"enum_user_tenant_role_billing_admin\");\n public static ullagesView = new EnumUserTenantRole(32, \"UllagesView\", \"enum_user_tenant_role_ullages_view\");\n public static ullagesAdmin = new EnumUserTenantRole(33, \"UllagesAdmin\", \"enum_user_tenant_role_ullages_admin\");\n public static purchaseOrdersView = new EnumUserTenantRole(34, \"PurchaseOrdersView\", \"enum_user_tenant_role_purchase_orders_view\");\n public static purchaseOrdersAdmin = new EnumUserTenantRole(35, \"PurchaseOrdersAdmin\", \"enum_user_tenant_role_purchase_orders_admin\");\n public static tenantDocumentView = new EnumUserTenantRole(36, \"TenantDocumentView\", \"enum_user_tenant_role_tenant_document_view\");\n public static tenantDocumentAdmin = new EnumUserTenantRole(37, \"TenantDocumentAdmin\", \"enum_user_tenant_role_tenant_document_admin\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumUserTenantRole.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isOutletsAndGroupsView() { return this === EnumUserTenantRole.outletsAndGroupsView; }\n public isOutletsAndGroupsEdit() { return this === EnumUserTenantRole.outletsAndGroupsEdit; }\n public isOutletsAndGroupsAdmin() { return this === EnumUserTenantRole.outletsAndGroupsAdmin; }\n public isTenantsView() { return this === EnumUserTenantRole.tenantsView; }\n public isTenantsEdit() { return this === EnumUserTenantRole.tenantsEdit; }\n public isProductsView() { return this === EnumUserTenantRole.productsView; }\n public isProductsEdit() { return this === EnumUserTenantRole.productsEdit; }\n public isProductsAdmin() { return this === EnumUserTenantRole.productsAdmin; }\n public isPricesView() { return this === EnumUserTenantRole.pricesView; }\n public isPricesEdit() { return this === EnumUserTenantRole.pricesEdit; }\n public isPricesAdmin() { return this === EnumUserTenantRole.pricesAdmin; }\n public isStockView() { return this === EnumUserTenantRole.stockView; }\n public isStockEdit() { return this === EnumUserTenantRole.stockEdit; }\n public isStockAdmin() { return this === EnumUserTenantRole.stockAdmin; }\n public isAllUsers() { return this === EnumUserTenantRole.allUsers; }\n public isContainersView() { return this === EnumUserTenantRole.containersView; }\n public isContainersAdmin() { return this === EnumUserTenantRole.containersAdmin; }\n public isOrdersView() { return this === EnumUserTenantRole.ordersView; }\n public isOrdersAdmin() { return this === EnumUserTenantRole.ordersAdmin; }\n public isDistributionView() { return this === EnumUserTenantRole.distributionView; }\n public isDistributionAdmin() { return this === EnumUserTenantRole.distributionAdmin; }\n public isPremierSystemsAdmin() { return this === EnumUserTenantRole.premierSystemsAdmin; }\n public isCompanyAdmin() { return this === EnumUserTenantRole.companyAdmin; }\n public isUsersView() { return this === EnumUserTenantRole.usersView; }\n public isUsersAdmin() { return this === EnumUserTenantRole.usersAdmin; }\n public isDutyView() { return this === EnumUserTenantRole.dutyView; }\n public isDutyAdmin() { return this === EnumUserTenantRole.dutyAdmin; }\n public isAccountPostingView() { return this === EnumUserTenantRole.accountPostingView; }\n public isAccountPostingAdmin() { return this === EnumUserTenantRole.accountPostingAdmin; }\n public isReportsView() { return this === EnumUserTenantRole.reportsView; }\n public isSystemInternal() { return this === EnumUserTenantRole.systemInternal; }\n public isBillingAdmin() { return this === EnumUserTenantRole.billingAdmin; }\n public isUllagesView() { return this === EnumUserTenantRole.ullagesView; }\n public isUllagesAdmin() { return this === EnumUserTenantRole.ullagesAdmin; }\n public isPurchaseOrdersView() { return this === EnumUserTenantRole.purchaseOrdersView; }\n public isPurchaseOrdersAdmin() { return this === EnumUserTenantRole.purchaseOrdersAdmin; }\n public isTenantDocumentView() { return this === EnumUserTenantRole.tenantDocumentView; }\n public isTenantDocumentAdmin() { return this === EnumUserTenantRole.tenantDocumentAdmin; }\n\n public static getValues(): readonly EnumUserTenantRole[] {\n return EnumUserTenantRole.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumUserTenantRole[] {\n return EnumUserTenantRole.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumUserTenantRole {\n const found = EnumUserTenantRole.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumUserTenantRole - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumUserTenantRole): EnumUserTenantRole {\n const found = name ? EnumUserTenantRole.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumUserTenantRole - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumVehicleProfile implements BaseEnumType {\n private static allValues: EnumVehicleProfile[] = []; // make sure this is top-most\n \n public static none = new EnumVehicleProfile(0, \"None\", \"enum_vehicle_profile_none\");\n public static van = new EnumVehicleProfile(1, \"Van\", \"enum_vehicle_profile_van\");\n public static hgv = new EnumVehicleProfile(2, \"Hgv\", \"enum_vehicle_profile_hgv\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumVehicleProfile.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumVehicleProfile.none; }\n public isVan() { return this === EnumVehicleProfile.van; }\n public isHgv() { return this === EnumVehicleProfile.hgv; }\n\n public static getValues(): readonly EnumVehicleProfile[] {\n return EnumVehicleProfile.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumVehicleProfile[] {\n return EnumVehicleProfile.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumVehicleProfile {\n const found = EnumVehicleProfile.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumVehicleProfile - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumVehicleProfile): EnumVehicleProfile {\n const found = name ? EnumVehicleProfile.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumVehicleProfile - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumVesselAvailability implements BaseEnumType {\n private static allValues: EnumVesselAvailability[] = []; // make sure this is top-most\n \n public static available = new EnumVesselAvailability(0, \"Available\", \"enum_vessel_availability_available\");\n public static inUse = new EnumVesselAvailability(1, \"InUse\", \"enum_vessel_availability_in_use\");\n public static requiresMaintenance = new EnumVesselAvailability(2, \"RequiresMaintenance\", \"enum_vessel_availability_requires_maintenance\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumVesselAvailability.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isAvailable() { return this === EnumVesselAvailability.available; }\n public isInUse() { return this === EnumVesselAvailability.inUse; }\n public isRequiresMaintenance() { return this === EnumVesselAvailability.requiresMaintenance; }\n\n public static getValues(): readonly EnumVesselAvailability[] {\n return EnumVesselAvailability.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumVesselAvailability[] {\n return EnumVesselAvailability.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumVesselAvailability {\n const found = EnumVesselAvailability.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumVesselAvailability - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumVesselAvailability): EnumVesselAvailability {\n const found = name ? EnumVesselAvailability.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumVesselAvailability - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumVesselMainPurpose implements BaseEnumType {\n private static allValues: EnumVesselMainPurpose[] = []; // make sure this is top-most\n \n public static unknown = new EnumVesselMainPurpose(0, \"Unknown\", \"enum_vessel_main_purpose_unknown\");\n public static productionVessel = new EnumVesselMainPurpose(1, \"ProductionVessel\", \"enum_vessel_main_purpose_production_vessel\");\n public static caskVessel = new EnumVesselMainPurpose(2, \"CaskVessel\", \"enum_vessel_main_purpose_cask_vessel\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumVesselMainPurpose.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isUnknown() { return this === EnumVesselMainPurpose.unknown; }\n public isProductionVessel() { return this === EnumVesselMainPurpose.productionVessel; }\n public isCaskVessel() { return this === EnumVesselMainPurpose.caskVessel; }\n\n public static getValues(): readonly EnumVesselMainPurpose[] {\n return EnumVesselMainPurpose.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumVesselMainPurpose[] {\n return EnumVesselMainPurpose.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumVesselMainPurpose {\n const found = EnumVesselMainPurpose.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumVesselMainPurpose - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumVesselMainPurpose): EnumVesselMainPurpose {\n const found = name ? EnumVesselMainPurpose.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumVesselMainPurpose - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumVesselMaintenancePeriodBasis implements BaseEnumType {\n private static allValues: EnumVesselMaintenancePeriodBasis[] = []; // make sure this is top-most\n \n public static uses = new EnumVesselMaintenancePeriodBasis(0, \"Uses\", \"enum_vessel_maintenance_period_basis_uses\");\n public static days = new EnumVesselMaintenancePeriodBasis(1, \"Days\", \"enum_vessel_maintenance_period_basis_days\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumVesselMaintenancePeriodBasis.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isUses() { return this === EnumVesselMaintenancePeriodBasis.uses; }\n public isDays() { return this === EnumVesselMaintenancePeriodBasis.days; }\n\n public static getValues(): readonly EnumVesselMaintenancePeriodBasis[] {\n return EnumVesselMaintenancePeriodBasis.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumVesselMaintenancePeriodBasis[] {\n return EnumVesselMaintenancePeriodBasis.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumVesselMaintenancePeriodBasis {\n const found = EnumVesselMaintenancePeriodBasis.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumVesselMaintenancePeriodBasis - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumVesselMaintenancePeriodBasis): EnumVesselMaintenancePeriodBasis {\n const found = name ? EnumVesselMaintenancePeriodBasis.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumVesselMaintenancePeriodBasis - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumVesselMovementSourceType implements BaseEnumType {\n private static allValues: EnumVesselMovementSourceType[] = []; // make sure this is top-most\n \n public static ingredients = new EnumVesselMovementSourceType(0, \"Ingredients\", \"enum_vessel_movement_source_type_ingredients\");\n public static vessel = new EnumVesselMovementSourceType(1, \"Vessel\", \"enum_vessel_movement_source_type_vessel\");\n public static measurement = new EnumVesselMovementSourceType(2, \"Measurement\", \"enum_vessel_movement_source_type_measurement\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumVesselMovementSourceType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isIngredients() { return this === EnumVesselMovementSourceType.ingredients; }\n public isVessel() { return this === EnumVesselMovementSourceType.vessel; }\n public isMeasurement() { return this === EnumVesselMovementSourceType.measurement; }\n\n public static getValues(): readonly EnumVesselMovementSourceType[] {\n return EnumVesselMovementSourceType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumVesselMovementSourceType[] {\n return EnumVesselMovementSourceType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumVesselMovementSourceType {\n const found = EnumVesselMovementSourceType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumVesselMovementSourceType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumVesselMovementSourceType): EnumVesselMovementSourceType {\n const found = name ? EnumVesselMovementSourceType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumVesselMovementSourceType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumVesselMovementTargetType implements BaseEnumType {\n private static allValues: EnumVesselMovementTargetType[] = []; // make sure this is top-most\n \n public static drain = new EnumVesselMovementTargetType(0, \"Drain\", \"enum_vessel_movement_target_type_drain\");\n public static vessel = new EnumVesselMovementTargetType(1, \"Vessel\", \"enum_vessel_movement_target_type_vessel\");\n public static output = new EnumVesselMovementTargetType(2, \"Output\", \"enum_vessel_movement_target_type_output\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumVesselMovementTargetType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isDrain() { return this === EnumVesselMovementTargetType.drain; }\n public isVessel() { return this === EnumVesselMovementTargetType.vessel; }\n public isOutput() { return this === EnumVesselMovementTargetType.output; }\n\n public static getValues(): readonly EnumVesselMovementTargetType[] {\n return EnumVesselMovementTargetType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumVesselMovementTargetType[] {\n return EnumVesselMovementTargetType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumVesselMovementTargetType {\n const found = EnumVesselMovementTargetType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumVesselMovementTargetType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumVesselMovementTargetType): EnumVesselMovementTargetType {\n const found = name ? EnumVesselMovementTargetType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumVesselMovementTargetType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumVesselStateIcon implements BaseEnumType {\n private static allValues: EnumVesselStateIcon[] = []; // make sure this is top-most\n \n public static none = new EnumVesselStateIcon(0, \"None\", \"enum_vessel_state_icon_none\");\n public static tick = new EnumVesselStateIcon(1, \"Tick\", \"enum_vessel_state_icon_tick\");\n public static bubbles = new EnumVesselStateIcon(2, \"Bubbles\", \"enum_vessel_state_icon_bubbles\");\n public static snowflake = new EnumVesselStateIcon(3, \"Snowflake\", \"enum_vessel_state_icon_snowflake\");\n public static hops = new EnumVesselStateIcon(4, \"Hops\", \"enum_vessel_state_icon_hops\");\n public static fire = new EnumVesselStateIcon(5, \"Fire\", \"enum_vessel_state_icon_fire\");\n public static grainEar = new EnumVesselStateIcon(6, \"GrainEar\", \"enum_vessel_state_icon_grain_ear\");\n public static liquid = new EnumVesselStateIcon(7, \"Liquid\", \"enum_vessel_state_icon_liquid\");\n public static funnel = new EnumVesselStateIcon(8, \"Funnel\", \"enum_vessel_state_icon_funnel\");\n public static grain = new EnumVesselStateIcon(9, \"Grain\", \"enum_vessel_state_icon_grain\");\n public static yeast = new EnumVesselStateIcon(10, \"Yeast\", \"enum_vessel_state_icon_yeast\");\n public static apple = new EnumVesselStateIcon(11, \"Apple\", \"enum_vessel_state_icon_apple\");\n public static mop = new EnumVesselStateIcon(12, \"Mop\", \"enum_vessel_state_icon_mop\");\n public static stop = new EnumVesselStateIcon(13, \"Stop\", \"enum_vessel_state_icon_stop\");\n public static spanner = new EnumVesselStateIcon(14, \"Spanner\", \"enum_vessel_state_icon_spanner\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumVesselStateIcon.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isNone() { return this === EnumVesselStateIcon.none; }\n public isTick() { return this === EnumVesselStateIcon.tick; }\n public isBubbles() { return this === EnumVesselStateIcon.bubbles; }\n public isSnowflake() { return this === EnumVesselStateIcon.snowflake; }\n public isHops() { return this === EnumVesselStateIcon.hops; }\n public isFire() { return this === EnumVesselStateIcon.fire; }\n public isGrainEar() { return this === EnumVesselStateIcon.grainEar; }\n public isLiquid() { return this === EnumVesselStateIcon.liquid; }\n public isFunnel() { return this === EnumVesselStateIcon.funnel; }\n public isGrain() { return this === EnumVesselStateIcon.grain; }\n public isYeast() { return this === EnumVesselStateIcon.yeast; }\n public isApple() { return this === EnumVesselStateIcon.apple; }\n public isMop() { return this === EnumVesselStateIcon.mop; }\n public isStop() { return this === EnumVesselStateIcon.stop; }\n public isSpanner() { return this === EnumVesselStateIcon.spanner; }\n\n public static getValues(): readonly EnumVesselStateIcon[] {\n return EnumVesselStateIcon.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumVesselStateIcon[] {\n return EnumVesselStateIcon.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumVesselStateIcon {\n const found = EnumVesselStateIcon.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumVesselStateIcon - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumVesselStateIcon): EnumVesselStateIcon {\n const found = name ? EnumVesselStateIcon.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumVesselStateIcon - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumVesselSummaryField implements BaseEnumType {\n private static allValues: EnumVesselSummaryField[] = []; // make sure this is top-most\n \n public static output = new EnumVesselSummaryField(0, \"Output\", \"enum_vessel_summary_field_output\");\n public static recipe = new EnumVesselSummaryField(1, \"Recipe\", \"enum_vessel_summary_field_recipe\");\n public static batchNumber = new EnumVesselSummaryField(2, \"BatchNumber\", \"enum_vessel_summary_field_batch_number\");\n public static startDate = new EnumVesselSummaryField(3, \"StartDate\", \"enum_vessel_summary_field_start_date\");\n public static assemblyName = new EnumVesselSummaryField(4, \"AssemblyName\", \"enum_vessel_summary_field_assembly_name\");\n public static expectedEndDate = new EnumVesselSummaryField(5, \"ExpectedEndDate\", \"enum_vessel_summary_field_expected_end_date\");\n public static currentOutput = new EnumVesselSummaryField(6, \"CurrentOutput\", \"enum_vessel_summary_field_current_output\");\n public static remainingExpectedOutput = new EnumVesselSummaryField(7, \"RemainingExpectedOutput\", \"enum_vessel_summary_field_remaining_expected_output\");\n public static assemblyType = new EnumVesselSummaryField(8, \"AssemblyType\", \"enum_vessel_summary_field_assembly_type\");\n public static costSoFar = new EnumVesselSummaryField(9, \"CostSoFar\", \"enum_vessel_summary_field_cost_so_far\");\n public static expectedCost = new EnumVesselSummaryField(10, \"ExpectedCost\", \"enum_vessel_summary_field_expected_cost\");\n public static vesselState = new EnumVesselSummaryField(11, \"VesselState\", \"enum_vessel_summary_field_vessel_state\");\n public static produceMaterial = new EnumVesselSummaryField(12, \"ProduceMaterial\", \"enum_vessel_summary_field_produce_material\");\n public static processSubBatch = new EnumVesselSummaryField(13, \"ProcessSubBatch\", \"enum_vessel_summary_field_process_sub_batch\");\n public static obsolete_BatchName = new EnumVesselSummaryField(14, \"Obsolete_BatchName\", \"enum_vessel_summary_field_obsolete__batch_name\");\n public static obsolete_VesselValuation = new EnumVesselSummaryField(15, \"Obsolete_VesselValuation\", \"enum_vessel_summary_field_obsolete__vessel_valuation\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumVesselSummaryField.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isOutput() { return this === EnumVesselSummaryField.output; }\n public isRecipe() { return this === EnumVesselSummaryField.recipe; }\n public isBatchNumber() { return this === EnumVesselSummaryField.batchNumber; }\n public isStartDate() { return this === EnumVesselSummaryField.startDate; }\n public isAssemblyName() { return this === EnumVesselSummaryField.assemblyName; }\n public isExpectedEndDate() { return this === EnumVesselSummaryField.expectedEndDate; }\n public isCurrentOutput() { return this === EnumVesselSummaryField.currentOutput; }\n public isRemainingExpectedOutput() { return this === EnumVesselSummaryField.remainingExpectedOutput; }\n public isAssemblyType() { return this === EnumVesselSummaryField.assemblyType; }\n public isCostSoFar() { return this === EnumVesselSummaryField.costSoFar; }\n public isExpectedCost() { return this === EnumVesselSummaryField.expectedCost; }\n public isVesselState() { return this === EnumVesselSummaryField.vesselState; }\n public isProduceMaterial() { return this === EnumVesselSummaryField.produceMaterial; }\n public isProcessSubBatch() { return this === EnumVesselSummaryField.processSubBatch; }\n public isObsolete_BatchName() { return this === EnumVesselSummaryField.obsolete_BatchName; }\n public isObsolete_VesselValuation() { return this === EnumVesselSummaryField.obsolete_VesselValuation; }\n\n public static getValues(): readonly EnumVesselSummaryField[] {\n return EnumVesselSummaryField.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumVesselSummaryField[] {\n return EnumVesselSummaryField.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumVesselSummaryField {\n const found = EnumVesselSummaryField.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumVesselSummaryField - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumVesselSummaryField): EnumVesselSummaryField {\n const found = name ? EnumVesselSummaryField.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumVesselSummaryField - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumVesselTypeIcon implements BaseEnumType {\n private static allValues: EnumVesselTypeIcon[] = []; // make sure this is top-most\n \n public static cylindrocononical = new EnumVesselTypeIcon(0, \"Cylindrocononical\", \"enum_vessel_type_icon_cylindrocononical\");\n public static inverseCylindrocononical = new EnumVesselTypeIcon(1, \"InverseCylindrocononical\", \"enum_vessel_type_icon_inverse_cylindrocononical\");\n public static mashTun = new EnumVesselTypeIcon(2, \"MashTun\", \"enum_vessel_type_icon_mash_tun\");\n public static cylindrical = new EnumVesselTypeIcon(3, \"Cylindrical\", \"enum_vessel_type_icon_cylindrical\");\n public static barrel = new EnumVesselTypeIcon(4, \"Barrel\", \"enum_vessel_type_icon_barrel\");\n public static still = new EnumVesselTypeIcon(5, \"Still\", \"enum_vessel_type_icon_still\");\n public static rectangle = new EnumVesselTypeIcon(6, \"Rectangle\", \"enum_vessel_type_icon_rectangle\");\n public static oval = new EnumVesselTypeIcon(7, \"Oval\", \"enum_vessel_type_icon_oval\");\n public static square = new EnumVesselTypeIcon(8, \"Square\", \"enum_vessel_type_icon_square\");\n public static circle = new EnumVesselTypeIcon(9, \"Circle\", \"enum_vessel_type_icon_circle\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumVesselTypeIcon.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isCylindrocononical() { return this === EnumVesselTypeIcon.cylindrocononical; }\n public isInverseCylindrocononical() { return this === EnumVesselTypeIcon.inverseCylindrocononical; }\n public isMashTun() { return this === EnumVesselTypeIcon.mashTun; }\n public isCylindrical() { return this === EnumVesselTypeIcon.cylindrical; }\n public isBarrel() { return this === EnumVesselTypeIcon.barrel; }\n public isStill() { return this === EnumVesselTypeIcon.still; }\n public isRectangle() { return this === EnumVesselTypeIcon.rectangle; }\n public isOval() { return this === EnumVesselTypeIcon.oval; }\n public isSquare() { return this === EnumVesselTypeIcon.square; }\n public isCircle() { return this === EnumVesselTypeIcon.circle; }\n\n public static getValues(): readonly EnumVesselTypeIcon[] {\n return EnumVesselTypeIcon.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumVesselTypeIcon[] {\n return EnumVesselTypeIcon.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumVesselTypeIcon {\n const found = EnumVesselTypeIcon.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumVesselTypeIcon - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumVesselTypeIcon): EnumVesselTypeIcon {\n const found = name ? EnumVesselTypeIcon.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumVesselTypeIcon - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumWidgetDragType implements BaseEnumType {\n private static allValues: EnumWidgetDragType[] = []; // make sure this is top-most\n \n public static move = new EnumWidgetDragType(1, \"Move\", \"enum_widget_drag_type_move\");\n public static resize = new EnumWidgetDragType(2, \"Resize\", \"enum_widget_drag_type_resize\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumWidgetDragType.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isMove() { return this === EnumWidgetDragType.move; }\n public isResize() { return this === EnumWidgetDragType.resize; }\n\n public static getValues(): readonly EnumWidgetDragType[] {\n return EnumWidgetDragType.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumWidgetDragType[] {\n return EnumWidgetDragType.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumWidgetDragType {\n const found = EnumWidgetDragType.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumWidgetDragType - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumWidgetDragType): EnumWidgetDragType {\n const found = name ? EnumWidgetDragType.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumWidgetDragType - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumWidgetSize implements BaseEnumType {\n private static allValues: EnumWidgetSize[] = []; // make sure this is top-most\n \n public static small = new EnumWidgetSize(1, \"Small\", \"enum_widget_size_small\");\n public static medium = new EnumWidgetSize(2, \"Medium\", \"enum_widget_size_medium\");\n public static large = new EnumWidgetSize(3, \"Large\", \"enum_widget_size_large\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumWidgetSize.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isSmall() { return this === EnumWidgetSize.small; }\n public isMedium() { return this === EnumWidgetSize.medium; }\n public isLarge() { return this === EnumWidgetSize.large; }\n\n public static getValues(): readonly EnumWidgetSize[] {\n return EnumWidgetSize.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumWidgetSize[] {\n return EnumWidgetSize.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumWidgetSize {\n const found = EnumWidgetSize.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumWidgetSize - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumWidgetSize): EnumWidgetSize {\n const found = name ? EnumWidgetSize.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumWidgetSize - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import { translate } from \"@/plugins/i18n\";\nimport BaseEnumType from \"../../baseEnumType\";\nimport Key from \"@/app/types/common/key\";\n\nexport class EnumYesNoEither implements BaseEnumType {\n private static allValues: EnumYesNoEither[] = []; // make sure this is top-most\n \n public static either = new EnumYesNoEither(0, \"Either\", \"enum_yes_no_either_either\");\n public static yes = new EnumYesNoEither(1, \"Yes\", \"enum_yes_no_either_yes\");\n public static no = new EnumYesNoEither(2, \"No\", \"enum_yes_no_either_no\");\n \n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumYesNoEither.allValues.push(this);\n }\n\n public get translation() { return translate(Key.fromString(this.translationKey)); }\n\n public isEither() { return this === EnumYesNoEither.either; }\n public isYes() { return this === EnumYesNoEither.yes; }\n public isNo() { return this === EnumYesNoEither.no; }\n\n public static getValues(): readonly EnumYesNoEither[] {\n return EnumYesNoEither.allValues;\n }\n\n public static getValuesExcept0(): readonly EnumYesNoEither[] {\n return EnumYesNoEither.allValues.filter((x) => x.key !== 0);\n }\n\n public static getByKey(key: number): EnumYesNoEither {\n const found = EnumYesNoEither.allValues.find(e => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumYesNoEither - Key not found: ${ key }`);\n }\n\n return found;\n }\n\n public static getByValue(name: string, def?: EnumYesNoEither): EnumYesNoEither {\n const found = name ? EnumYesNoEither.allValues.find(e => e.value.toLowerCase() === name.toLowerCase()) : null;\n if (!found) {\n if (def) {\n return def;\n }\n throw new Error(`EnumYesNoEither - Value not found: ${ name }`);\n }\n\n return found;\n }\n}","import BaseEnumType from \"@/app/services/baseEnumType\";\nimport { EnumAccountPostingLineType } from \"@/app/services/generated/enums/enumAccountPostingLineType.generated\";\nimport { EnumAccountPostingStatus } from \"@/app/services/generated/enums/enumAccountPostingStatus.generated\";\nimport { EnumAccountsPackageType } from \"@/app/services/generated/enums/enumAccountsPackageType.generated\";\nimport { EnumActivityLogType } from \"@/app/services/generated/enums/enumActivityLogType.generated\";\nimport { EnumAggregatingOperation } from \"@/app/services/generated/enums/enumAggregatingOperation.generated\";\nimport { EnumAlcoholType } from \"@/app/services/generated/enums/enumAlcoholType.generated\";\nimport { EnumAssemblyIngredientSource } from \"@/app/services/generated/enums/enumAssemblyIngredientSource.generated\";\nimport { EnumAssemblyOutputTarget } from \"@/app/services/generated/enums/enumAssemblyOutputTarget.generated\";\nimport { EnumAssemblyRecipeType } from \"@/app/services/generated/enums/enumAssemblyRecipeType.generated\";\nimport { EnumAssemblyStatus } from \"@/app/services/generated/enums/enumAssemblyStatus.generated\";\nimport { EnumAssemblyType } from \"@/app/services/generated/enums/enumAssemblyType.generated\";\nimport { EnumAustralianAlcoholTariff } from \"@/app/services/generated/enums/enumAustralianAlcoholTariff.generated\";\nimport { EnumBeerflexOrderConfirmationStatus } from \"@/app/services/generated/enums/enumBeerflexOrderConfirmationStatus.generated\";\nimport { EnumBeerflexOrderType } from \"@/app/services/generated/enums/enumBeerflexOrderType.generated\";\nimport { EnumBillingPlanStatus } from \"@/app/services/generated/enums/enumBillingPlanStatus.generated\";\nimport { EnumBmEntityType } from \"@/app/services/generated/enums/enumBmEntityType.generated\";\nimport { EnumBogofQuantityBasis } from \"@/app/services/generated/enums/enumBogofQuantityBasis.generated\";\nimport { EnumBottleDepositBalanceChangeReason } from \"@/app/services/generated/enums/enumBottleDepositBalanceChangeReason.generated\";\nimport { EnumBrewmanBarcodeType } from \"@/app/services/generated/enums/enumBrewmanBarcodeType.generated\";\nimport { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport { EnumCaseLabelWeightType } from \"@/app/services/generated/enums/enumCaseLabelWeightType.generated\";\nimport { EnumChangeLogLineType } from \"@/app/services/generated/enums/enumChangeLogLineType.generated\";\nimport { EnumChangeSection } from \"@/app/services/generated/enums/enumChangeSection.generated\";\nimport { EnumChangeType } from \"@/app/services/generated/enums/enumChangeType.generated\";\nimport { EnumColumnType } from \"@/app/services/generated/enums/enumColumnType.generated\";\nimport { EnumConsumableType } from \"@/app/services/generated/enums/enumConsumableType.generated\";\nimport { EnumContainerStatus } from \"@/app/services/generated/enums/enumContainerStatus.generated\";\nimport { EnumCountry } from \"@/app/services/generated/enums/enumCountry.generated\";\nimport { EnumCreditCalculationType } from \"@/app/services/generated/enums/enumCreditCalculationType.generated\";\nimport { EnumCreditType } from \"@/app/services/generated/enums/enumCreditType.generated\";\nimport { EnumCtVirtualNo } from \"@/app/services/generated/enums/enumCtVirtualNo.generated\";\nimport { EnumCustomerHappinessRating } from \"@/app/services/generated/enums/enumCustomerHappinessRating.generated\";\nimport { EnumDashboardComponent } from \"@/app/services/generated/enums/enumDashboardComponent.generated\";\nimport { EnumDataImportAction } from \"@/app/services/generated/enums/enumDataImportAction.generated\";\nimport { EnumDataImportDateFormat } from \"@/app/services/generated/enums/enumDataImportDateFormat.generated\";\nimport { EnumDataImportTimestampFormat } from \"@/app/services/generated/enums/enumDataImportTimestampFormat.generated\";\nimport { EnumDataImportType } from \"@/app/services/generated/enums/enumDataImportType.generated\";\nimport { EnumDateFormat } from \"@/app/services/generated/enums/enumDateFormat.generated\";\nimport { EnumDateType } from \"@/app/services/generated/enums/enumDateType.generated\";\nimport { EnumDayOfWeek } from \"@/app/services/generated/enums/enumDayOfWeek.generated\";\nimport { EnumDeliveryNotificationSetting } from \"@/app/services/generated/enums/enumDeliveryNotificationSetting.generated\";\nimport { EnumDiscountBasis } from \"@/app/services/generated/enums/enumDiscountBasis.generated\";\nimport { EnumDiscountParent } from \"@/app/services/generated/enums/enumDiscountParent.generated\";\nimport { EnumDiscountTierBasis } from \"@/app/services/generated/enums/enumDiscountTierBasis.generated\";\nimport { EnumDistributionType } from \"@/app/services/generated/enums/enumDistributionType.generated\";\nimport { EnumDocumentContextType } from \"@/app/services/generated/enums/enumDocumentContextType.generated\";\nimport { EnumDocumentEmailTag } from \"@/app/services/generated/enums/enumDocumentEmailTag.generated\";\nimport { EnumDocumentFileType } from \"@/app/services/generated/enums/enumDocumentFileType.generated\";\nimport { EnumDocumentGenerationOutputFileType } from \"@/app/services/generated/enums/enumDocumentGenerationOutputFileType.generated\";\nimport { EnumImageFormat } from \"@/app/services/generated/enums/enumImageFormat.generated\";\nimport { EnumDocumentTagType } from \"@/app/services/generated/enums/enumDocumentTagType.generated\";\nimport { EnumDocumentType } from \"@/app/services/generated/enums/enumDocumentType.generated\";\nimport { EnumDocumentTypeGroup } from \"@/app/services/generated/enums/enumDocumentTypeGroup.generated\";\nimport { EnumDutyHslsRate } from \"@/app/services/generated/enums/enumDutyHslsRate.generated\";\nimport { EnumDutyRateBasis } from \"@/app/services/generated/enums/enumDutyRateBasis.generated\";\nimport { EnumDutyScheme } from \"@/app/services/generated/enums/enumDutyScheme.generated\";\nimport { EnumDutySource } from \"@/app/services/generated/enums/enumDutySource.generated\";\nimport { EnumEcommerceConnectionStatus } from \"@/app/services/generated/enums/enumEcommerceConnectionStatus.generated\";\nimport { EnumEcommerceOrderOriginType } from \"@/app/services/generated/enums/enumEcommerceOrderOriginType.generated\";\nimport { EnumEdiSource } from \"@/app/services/generated/enums/enumEdiSource.generated\";\nimport { EnumEireAlcoholCategory } from \"@/app/services/generated/enums/enumEireAlcoholCategory.generated\";\nimport { EnumEireDutyRateBand } from \"@/app/services/generated/enums/enumEireDutyRateBand.generated\";\nimport { EnumEireMovementType } from \"@/app/services/generated/enums/enumEireMovementType.generated\";\nimport { EnumEmailContext } from \"@/app/services/generated/enums/enumEmailContext.generated\";\nimport { EnumEmailDocumentGrouping } from \"@/app/services/generated/enums/enumEmailDocumentGrouping.generated\";\nimport { EnumEmailType } from \"@/app/services/generated/enums/enumEmailType.generated\";\nimport { EnumExportIncotermCode } from \"@/app/services/generated/enums/enumExportIncotermCode.generated\";\nimport { EnumExternalCalendarProvider } from \"@/app/services/generated/enums/enumExternalCalendarProvider.generated\";\nimport { EnumExternalOrderStatus } from \"@/app/services/generated/enums/enumExternalOrderStatus.generated\";\nimport { EnumFeatureFlag } from \"@/app/services/generated/enums/enumFeatureFlag.generated\";\nimport { EnumFileType } from \"@/app/services/generated/enums/enumFileType.generated\";\nimport { EnumFilteringOperation } from \"@/app/services/generated/enums/enumFilteringOperation.generated\";\nimport { EnumGermanBeerDutyMovementType } from \"@/app/services/generated/enums/enumGermanBeerDutyMovementType.generated\";\nimport { EnumGermanBeerDutyProductType } from \"@/app/services/generated/enums/enumGermanBeerDutyProductType.generated\";\nimport { EnumGermanBeerDutyReturnCellProductType } from \"@/app/services/generated/enums/enumGermanBeerDutyReturnCellProductType.generated\";\nimport { EnumGetUserByCredentialStatus } from \"@/app/services/generated/enums/enumGetUserByCredentialStatus.generated\";\nimport { EnumGroupingOperation } from \"@/app/services/generated/enums/enumGroupingOperation.generated\";\nimport { EnumHistoryDateRangePick } from \"@/app/services/generated/enums/enumHistoryDateRangePick.generated\";\nimport { EnumIntegrationType } from \"@/app/services/generated/enums/enumIntegrationType.generated\";\nimport { EnumInvoicesOrCredits } from \"@/app/services/generated/enums/enumInvoicesOrCredits.generated\";\nimport { EnumItemMainPurpose } from \"@/app/services/generated/enums/enumItemMainPurpose.generated\";\nimport { EnumJourneyLabelStatus } from \"@/app/services/generated/enums/enumJourneyLabelStatus.generated\";\nimport { EnumJourneyStopPlanningStatus } from \"@/app/services/generated/enums/enumJourneyStopPlanningStatus.generated\";\nimport { EnumKegstarContainerType } from \"@/app/services/generated/enums/enumKegstarContainerType.generated\";\nimport { EnumLeadStatus } from \"@/app/services/generated/enums/enumLeadStatus.generated\";\nimport { EnumLocationBondedStatus } from \"@/app/services/generated/enums/enumLocationBondedStatus.generated\";\nimport { EnumMetricType } from \"@/app/services/generated/enums/enumMetricType.generated\";\nimport { EnumNatureOfTransactionCode } from \"@/app/services/generated/enums/enumNatureOfTransactionCode.generated\";\nimport { EnumNumberingType } from \"@/app/services/generated/enums/enumNumberingType.generated\";\nimport { EnumOneFreePeriod } from \"@/app/services/generated/enums/enumOneFreePeriod.generated\";\nimport { EnumOrderSortBy } from \"@/app/services/generated/enums/enumOrderSortBy.generated\";\nimport { EnumOrderSource } from \"@/app/services/generated/enums/enumOrderSource.generated\";\nimport { EnumOrderStatus } from \"@/app/services/generated/enums/enumOrderStatus.generated\";\nimport { EnumOutletRatingExclusions } from \"@/app/services/generated/enums/enumOutletRatingExclusions.generated\";\nimport { EnumPackageTypeCategoryType } from \"@/app/services/generated/enums/enumPackageTypeCategoryType.generated\";\nimport { EnumPalletStatus } from \"@/app/services/generated/enums/enumPalletStatus.generated\";\nimport { EnumPlannedStockAction } from \"@/app/services/generated/enums/enumPlannedStockAction.generated\";\nimport { EnumPlannedStockFollowUpAction } from \"@/app/services/generated/enums/enumPlannedStockFollowUpAction.generated\";\nimport { EnumPlannedStockStatus } from \"@/app/services/generated/enums/enumPlannedStockStatus.generated\";\nimport { EnumPriceListGroupSortBy } from \"@/app/services/generated/enums/enumPriceListGroupSortBy.generated\";\nimport { EnumPriceListLineSortBy } from \"@/app/services/generated/enums/enumPriceListLineSortBy.generated\";\nimport { EnumPriceListSubGroup } from \"@/app/services/generated/enums/enumPriceListSubGroup.generated\";\nimport { EnumPrinterPreference } from \"@/app/services/generated/enums/enumPrinterPreference.generated\";\nimport { EnumProcessIngredientSource } from \"@/app/services/generated/enums/enumProcessIngredientSource.generated\";\nimport { EnumProcessOutputTarget } from \"@/app/services/generated/enums/enumProcessOutputTarget.generated\";\nimport { EnumPurchaseOrderDeliveryDisbursement } from \"@/app/services/generated/enums/enumPurchaseOrderDeliveryDisbursement.generated\";\nimport { EnumPurchaseOrderDeliveryStatus } from \"@/app/services/generated/enums/enumPurchaseOrderDeliveryStatus.generated\";\nimport { EnumPurchaseOrderStatus } from \"@/app/services/generated/enums/enumPurchaseOrderStatus.generated\";\nimport { EnumQcProbeProvider } from \"@/app/services/generated/enums/enumQcProbeProvider.generated\";\nimport { EnumQueuedJobType } from \"@/app/services/generated/enums/enumQueuedJobType.generated\";\nimport { EnumRecurringJobType } from \"@/app/services/generated/enums/enumRecurringJobType.generated\";\nimport { EnumReportBuilder } from \"@/app/services/generated/enums/enumReportBuilder.generated\";\nimport { EnumRetailPaymentMethod } from \"@/app/services/generated/enums/enumRetailPaymentMethod.generated\";\nimport { EnumSalesTextType } from \"@/app/services/generated/enums/enumSalesTextType.generated\";\nimport { EnumSalesVisitAssociatedEntityType } from \"@/app/services/generated/enums/enumSalesVisitAssociatedEntityType.generated\";\nimport { EnumScannerInputType } from \"@/app/services/generated/enums/enumScannerInputType.generated\";\nimport { EnumScannerType } from \"@/app/services/generated/enums/enumScannerType.generated\";\nimport { EnumSecurityProduct } from \"@/app/services/generated/enums/enumSecurityProduct.generated\";\nimport { EnumSessionStatus } from \"@/app/services/generated/enums/enumSessionStatus.generated\";\nimport { EnumShopifyOrderTag } from \"@/app/services/generated/enums/enumShopifyOrderTag.generated\";\nimport { EnumSmsContext } from \"@/app/services/generated/enums/enumSmsContext.generated\";\nimport { EnumSmsStatus } from \"@/app/services/generated/enums/enumSmsStatus.generated\";\nimport { EnumSouthAfricanDutyTariff } from \"@/app/services/generated/enums/enumSouthAfricanDutyTariff.generated\";\nimport { EnumSpiritDutyExemptionReason } from \"@/app/services/generated/enums/enumSpiritDutyExemptionReason.generated\";\nimport { EnumStandardOrder } from \"@/app/services/generated/enums/enumStandardOrder.generated\";\nimport { EnumStockAdjustDutyImplication } from \"@/app/services/generated/enums/enumStockAdjustDutyImplication.generated\";\nimport { EnumStockChangeReason } from \"@/app/services/generated/enums/enumStockChangeReason.generated\";\nimport { EnumStockItemType } from \"@/app/services/generated/enums/enumStockItemType.generated\";\nimport { EnumStockLevelDisplay } from \"@/app/services/generated/enums/enumStockLevelDisplay.generated\";\nimport { EnumStockMovementReferenceSource } from \"@/app/services/generated/enums/enumStockMovementReferenceSource.generated\";\nimport { EnumStockTakeStatus } from \"@/app/services/generated/enums/enumStockTakeStatus.generated\";\nimport { EnumStockTransferStatus } from \"@/app/services/generated/enums/enumStockTransferStatus.generated\";\nimport { EnumStockUom } from \"@/app/services/generated/enums/enumStockUom.generated\";\nimport { EnumStripePaymentMethod } from \"@/app/services/generated/enums/enumStripePaymentMethod.generated\";\nimport { EnumSwedishDutyTariff } from \"@/app/services/generated/enums/enumSwedishDutyTariff.generated\";\nimport { EnumTaskRepeatBasis } from \"@/app/services/generated/enums/enumTaskRepeatBasis.generated\";\nimport { EnumTaskStatus } from \"@/app/services/generated/enums/enumTaskStatus.generated\";\nimport { EnumTpPaymentMethod } from \"@/app/services/generated/enums/enumTpPaymentMethod.generated\";\nimport { EnumTpProductListSortOption } from \"@/app/services/generated/enums/enumTpProductListSortOption.generated\";\nimport { EnumTpSessionErrorReason } from \"@/app/services/generated/enums/enumTpSessionErrorReason.generated\";\nimport { EnumTransactionType } from \"@/app/services/generated/enums/enumTransactionType.generated\";\nimport { EnumTransportationDistanceUnit } from \"@/app/services/generated/enums/enumTransportationDistanceUnit.generated\";\nimport { EnumUkBeerDutySection } from \"@/app/services/generated/enums/enumUkBeerDutySection.generated\";\nimport { EnumUkDutyRate } from \"@/app/services/generated/enums/enumUkDutyRate.generated\";\nimport { EnumUkDutyReturnType } from \"@/app/services/generated/enums/enumUkDutyReturnType.generated\";\nimport { EnumUkNewDutyAbvRange } from \"@/app/services/generated/enums/enumUkNewDutyAbvRange.generated\";\nimport { EnumUkNewDutyProductType } from \"@/app/services/generated/enums/enumUkNewDutyProductType.generated\";\nimport { EnumUkNewDutyRate } from \"@/app/services/generated/enums/enumUkNewDutyRate.generated\";\nimport { EnumUllageReturnMethod } from \"@/app/services/generated/enums/enumUllageReturnMethod.generated\";\nimport { EnumUllageStatus } from \"@/app/services/generated/enums/enumUllageStatus.generated\";\nimport { EnumUsageType } from \"@/app/services/generated/enums/enumUsageType.generated\";\nimport { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { EnumUserTenantGroupLevel } from \"@/app/services/generated/enums/enumUserTenantGroupLevel.generated\";\nimport { EnumUserTenantRole } from \"@/app/services/generated/enums/enumUserTenantRole.generated\";\nimport { EnumVehicleProfile } from \"@/app/services/generated/enums/enumVehicleProfile.generated\";\nimport { EnumVesselAvailability } from \"@/app/services/generated/enums/enumVesselAvailability.generated\";\nimport { EnumVesselMainPurpose } from \"@/app/services/generated/enums/enumVesselMainPurpose.generated\";\nimport { EnumVesselMaintenancePeriodBasis } from \"@/app/services/generated/enums/enumVesselMaintenancePeriodBasis.generated\";\nimport { EnumVesselMovementSourceType } from \"@/app/services/generated/enums/enumVesselMovementSourceType.generated\";\nimport { EnumVesselMovementTargetType } from \"@/app/services/generated/enums/enumVesselMovementTargetType.generated\";\nimport { EnumVesselStateIcon } from \"@/app/services/generated/enums/enumVesselStateIcon.generated\";\nimport { EnumVesselSummaryField } from \"@/app/services/generated/enums/enumVesselSummaryField.generated\";\nimport { EnumVesselTypeIcon } from \"@/app/services/generated/enums/enumVesselTypeIcon.generated\";\nimport { EnumVolumeUnit } from \"@/app/services/generated/enums/enumVolumeUnit.generated\";\nimport { EnumWeightUnit } from \"@/app/services/generated/enums/enumWeightUnit.generated\";\nimport { EnumWidgetDragType } from \"@/app/services/generated/enums/enumWidgetDragType.generated\";\nimport { EnumWidgetSize } from \"@/app/services/generated/enums/enumWidgetSize.generated\";\nimport { EnumYesNoEither } from \"@/app/services/generated/enums/enumYesNoEither.generated\";\n\nexport function getAllGeneratedEnumValues() : readonly BaseEnumType[] {\n const allEnumValues = [\n EnumAccountPostingLineType.getValues(),\n EnumAccountPostingStatus.getValues(),\n EnumAccountsPackageType.getValues(),\n EnumActivityLogType.getValues(),\n EnumAggregatingOperation.getValues(),\n EnumAlcoholType.getValues(),\n EnumAssemblyIngredientSource.getValues(),\n EnumAssemblyOutputTarget.getValues(),\n EnumAssemblyRecipeType.getValues(),\n EnumAssemblyStatus.getValues(),\n EnumAssemblyType.getValues(),\n EnumAustralianAlcoholTariff.getValues(),\n EnumBeerflexOrderConfirmationStatus.getValues(),\n EnumBeerflexOrderType.getValues(),\n EnumBillingPlanStatus.getValues(),\n EnumBmEntityType.getValues(),\n EnumBogofQuantityBasis.getValues(),\n EnumBottleDepositBalanceChangeReason.getValues(),\n EnumBrewmanBarcodeType.getValues(),\n EnumCacheEntityType.getValues(),\n EnumCaseLabelWeightType.getValues(),\n EnumChangeLogLineType.getValues(),\n EnumChangeSection.getValues(),\n EnumChangeType.getValues(),\n EnumColumnType.getValues(),\n EnumConsumableType.getValues(),\n EnumContainerStatus.getValues(),\n EnumCountry.getValues(),\n EnumCreditCalculationType.getValues(),\n EnumCreditType.getValues(),\n EnumCtVirtualNo.getValues(),\n EnumCustomerHappinessRating.getValues(),\n EnumDashboardComponent.getValues(),\n EnumDataImportAction.getValues(),\n EnumDataImportDateFormat.getValues(),\n EnumDataImportTimestampFormat.getValues(),\n EnumDataImportType.getValues(),\n EnumDateFormat.getValues(),\n EnumDateType.getValues(),\n EnumDayOfWeek.getValues(),\n EnumDeliveryNotificationSetting.getValues(),\n EnumDiscountBasis.getValues(),\n EnumDiscountParent.getValues(),\n EnumDiscountTierBasis.getValues(),\n EnumDistributionType.getValues(),\n EnumDocumentContextType.getValues(),\n EnumDocumentEmailTag.getValues(),\n EnumDocumentFileType.getValues(),\n EnumDocumentGenerationOutputFileType.getValues(),\n EnumImageFormat.getValues(),\n EnumDocumentTagType.getValues(),\n EnumDocumentType.getValues(),\n EnumDocumentTypeGroup.getValues(),\n EnumDutyHslsRate.getValues(),\n EnumDutyRateBasis.getValues(),\n EnumDutyScheme.getValues(),\n EnumDutySource.getValues(),\n EnumEcommerceConnectionStatus.getValues(),\n EnumEcommerceOrderOriginType.getValues(),\n EnumEdiSource.getValues(),\n EnumEireAlcoholCategory.getValues(),\n EnumEireDutyRateBand.getValues(),\n EnumEireMovementType.getValues(),\n EnumEmailContext.getValues(),\n EnumEmailDocumentGrouping.getValues(),\n EnumEmailType.getValues(),\n EnumExportIncotermCode.getValues(),\n EnumExternalCalendarProvider.getValues(),\n EnumExternalOrderStatus.getValues(),\n EnumFeatureFlag.getValues(),\n EnumFileType.getValues(),\n EnumFilteringOperation.getValues(),\n EnumGermanBeerDutyMovementType.getValues(),\n EnumGermanBeerDutyProductType.getValues(),\n EnumGermanBeerDutyReturnCellProductType.getValues(),\n EnumGetUserByCredentialStatus.getValues(),\n EnumGroupingOperation.getValues(),\n EnumHistoryDateRangePick.getValues(),\n EnumIntegrationType.getValues(),\n EnumInvoicesOrCredits.getValues(),\n EnumItemMainPurpose.getValues(),\n EnumJourneyLabelStatus.getValues(),\n EnumJourneyStopPlanningStatus.getValues(),\n EnumKegstarContainerType.getValues(),\n EnumLeadStatus.getValues(),\n EnumLocationBondedStatus.getValues(),\n EnumMetricType.getValues(),\n EnumNatureOfTransactionCode.getValues(),\n EnumNumberingType.getValues(),\n EnumOneFreePeriod.getValues(),\n EnumOrderSortBy.getValues(),\n EnumOrderSource.getValues(),\n EnumOrderStatus.getValues(),\n EnumOutletRatingExclusions.getValues(),\n EnumPackageTypeCategoryType.getValues(),\n EnumPalletStatus.getValues(),\n EnumPlannedStockAction.getValues(),\n EnumPlannedStockFollowUpAction.getValues(),\n EnumPlannedStockStatus.getValues(),\n EnumPriceListGroupSortBy.getValues(),\n EnumPriceListLineSortBy.getValues(),\n EnumPriceListSubGroup.getValues(),\n EnumPrinterPreference.getValues(),\n EnumProcessIngredientSource.getValues(),\n EnumProcessOutputTarget.getValues(),\n EnumPurchaseOrderDeliveryDisbursement.getValues(),\n EnumPurchaseOrderDeliveryStatus.getValues(),\n EnumPurchaseOrderStatus.getValues(),\n EnumQcProbeProvider.getValues(),\n EnumQueuedJobType.getValues(),\n EnumRecurringJobType.getValues(),\n EnumReportBuilder.getValues(),\n EnumRetailPaymentMethod.getValues(),\n EnumSalesTextType.getValues(),\n EnumSalesVisitAssociatedEntityType.getValues(),\n EnumScannerInputType.getValues(),\n EnumScannerType.getValues(),\n EnumSecurityProduct.getValues(),\n EnumSessionStatus.getValues(),\n EnumShopifyOrderTag.getValues(),\n EnumSmsContext.getValues(),\n EnumSmsStatus.getValues(),\n EnumSouthAfricanDutyTariff.getValues(),\n EnumSpiritDutyExemptionReason.getValues(),\n EnumStandardOrder.getValues(),\n EnumStockAdjustDutyImplication.getValues(),\n EnumStockChangeReason.getValues(),\n EnumStockItemType.getValues(),\n EnumStockLevelDisplay.getValues(),\n EnumStockMovementReferenceSource.getValues(),\n EnumStockTakeStatus.getValues(),\n EnumStockTransferStatus.getValues(),\n EnumStockUom.getValues(),\n EnumStripePaymentMethod.getValues(),\n EnumSwedishDutyTariff.getValues(),\n EnumTaskRepeatBasis.getValues(),\n EnumTaskStatus.getValues(),\n EnumTpPaymentMethod.getValues(),\n EnumTpProductListSortOption.getValues(),\n EnumTpSessionErrorReason.getValues(),\n EnumTransactionType.getValues(),\n EnumTransportationDistanceUnit.getValues(),\n EnumUkBeerDutySection.getValues(),\n EnumUkDutyRate.getValues(),\n EnumUkDutyReturnType.getValues(),\n EnumUkNewDutyAbvRange.getValues(),\n EnumUkNewDutyProductType.getValues(),\n EnumUkNewDutyRate.getValues(),\n EnumUllageReturnMethod.getValues(),\n EnumUllageStatus.getValues(),\n EnumUsageType.getValues(),\n EnumUserPermission.getValues(),\n EnumUserTenantGroupLevel.getValues(),\n EnumUserTenantRole.getValues(),\n EnumVehicleProfile.getValues(),\n EnumVesselAvailability.getValues(),\n EnumVesselMainPurpose.getValues(),\n EnumVesselMaintenancePeriodBasis.getValues(),\n EnumVesselMovementSourceType.getValues(),\n EnumVesselMovementTargetType.getValues(),\n EnumVesselStateIcon.getValues(),\n EnumVesselSummaryField.getValues(),\n EnumVesselTypeIcon.getValues(),\n EnumVolumeUnit.getValues(),\n EnumWeightUnit.getValues(),\n EnumWidgetDragType.getValues(),\n EnumWidgetSize.getValues(),\n EnumYesNoEither.getValues(),\n ].flat();\n\n return allEnumValues;\n}\n","import type BaseEnumType from \"@/app/services/baseEnumType\";\n\nexport class EnumDistributionStatus implements BaseEnumType {\n private static allValues: EnumDistributionStatus[] = []; // make sure this is top-most\n\n public static pending = new EnumDistributionStatus(\n 1,\n \"Pending\",\n \"enum_distribution_status_pending\"\n );\n public static successful = new EnumDistributionStatus(\n 2,\n \"Successful\",\n \"enum_distribution_status_successful\"\n );\n public static outForDelivery = new EnumDistributionStatus(\n 3,\n \"OutForDelivery\",\n \"enum_distribution_status_out_for_delivery\"\n );\n public static exception = new EnumDistributionStatus(\n 4,\n \"Exception\",\n \"enum_distribution_status_exception\"\n );\n public static failed = new EnumDistributionStatus(\n 5,\n \"Failed\",\n \"enum_distribution_status_failed\"\n );\n public static hasNotes = new EnumDistributionStatus(\n 6,\n \"HasNotes\",\n \"enum_distribution_status_has_notes\"\n );\n\n public key: number;\n public value: string;\n public translationKey?: string;\n\n private constructor(key: number, value: string, translationKey?: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDistributionStatus.allValues.push(this);\n }\n\n public static getValues(): EnumDistributionStatus[] {\n return EnumDistributionStatus.allValues;\n }\n\n public static getByKey(key: number): EnumDistributionStatus {\n const found = EnumDistributionStatus.allValues.find((e) => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDistributionStatus - Key not found: ${key}`);\n }\n\n return found;\n }\n}\n","import type BaseEnumType from \"@/app/services/baseEnumType\";\n\nexport class EnumListItemStatus implements BaseEnumType {\n private static allValues: EnumListItemStatus[] = [];\n\n public static none = new EnumListItemStatus(0, \"\", \"\");\n public static warn = new EnumListItemStatus(1, \"error\", \"icon-warn-medium\");\n public static in_progress = new EnumListItemStatus(\n 2,\n \"check_circle\",\n \"icon-warn-medium\"\n );\n public static ok = new EnumListItemStatus(\n 3,\n \"check_circle\",\n \"icon-successful-medium\"\n );\n public static failed = new EnumListItemStatus(\n 4,\n \"error\",\n \"icon-error-medium\"\n );\n public static locked = new EnumListItemStatus(5, \"lock\", \"icon-error-medium\");\n public static offline = new EnumListItemStatus(6, \"signal_wifi_off\", \"\");\n\n public key: number;\n public value: string;\n public className: string;\n\n private constructor(key: number, value: string, className: string) {\n this.key = key;\n this.value = value;\n this.className = className;\n EnumListItemStatus.allValues.push(this);\n }\n\n public static getValues(): EnumListItemStatus[] {\n return EnumListItemStatus.allValues;\n }\n\n public static getByKey(key: number): EnumListItemStatus {\n const found = EnumListItemStatus.allValues.find((e) => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumListItemStatus - Key not found: ${key}`);\n }\n\n return found;\n }\n}\n\nexport interface IListItem {\n key: string;\n title: string;\n subtitle?: string;\n text?: string;\n status?: EnumListItemStatus;\n disabled?: boolean;\n action?: () => void;\n}\n","import type BaseEnumType from \"@/app/services/baseEnumType\";\n\nexport interface BmConfirmationDialogOptions {\n type: EnumDialogType;\n width: number;\n customConfirmButtonText: string;\n customCancelButtonText: string;\n closeable: boolean;\n isBodyHtml: boolean;\n large: boolean;\n}\nexport interface BmConfirmationDialogInterface {\n open(\n title: string,\n message: string,\n options?: Partial\n ): Promise;\n}\n\nexport interface BmInformationDialogOptions {\n type: EnumDialogType;\n width: number;\n customCloseButtonText: string;\n large: boolean;\n preserveWhitespace: boolean;\n isBodyHtml: boolean;\n}\n\nexport interface BmInformationDialogInterface {\n open(\n title: string,\n message: string,\n options?: Partial\n ): Promise;\n}\n\n// Enum handling different Dialog status, and their classes/colours.\nexport class EnumDialogType implements BaseEnumType {\n private static allValues: EnumDialogType[] = []; // make sure this is top-most\n\n public static none = new EnumDialogType(0, \"None\", \"\", \"primary\");\n public static error = new EnumDialogType(\n 1,\n \"Error\",\n \"bm-card-error\",\n \"primary-danger\"\n );\n public static warning = new EnumDialogType(\n 2,\n \"Warning\",\n \"bm-card-warning\",\n \"primary\"\n );\n public static success = new EnumDialogType(\n 3,\n \"Success\",\n \"bm-card-success\",\n \"primary\"\n );\n public static info = new EnumDialogType(4, \"Info\", \"bm-card-info\", \"primary\");\n\n public key: number;\n public value: string;\n public dialogClass: string;\n public confirmButtonClass: string;\n\n private constructor(\n key: number,\n value: string,\n dialogClass: string,\n confirmButtonClass: string\n ) {\n this.key = key;\n this.value = value;\n this.dialogClass = dialogClass;\n this.confirmButtonClass = confirmButtonClass;\n EnumDialogType.allValues.push(this);\n }\n\n public static getValues(): EnumDialogType[] {\n return EnumDialogType.allValues;\n }\n\n public static getByKey(key: number): EnumDialogType {\n const found = EnumDialogType.allValues.find((e) => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDialogType - Key not found: ${key}`);\n }\n\n return found;\n }\n}\n","import type BaseEnumType from \"@/app/services/baseEnumType\";\n\nexport default class EnumUserPermissionAccess implements BaseEnumType {\n private static allValues: EnumUserPermissionAccess[] = [];\n\n public static noAccess = new EnumUserPermissionAccess(\n 0,\n \"NoAccess\",\n \"user_roles_no_access\",\n \"close\",\n \"error\"\n );\n public static readOnly = new EnumUserPermissionAccess(\n 1,\n \"ReadOnly\",\n \"user_roles_read_only\",\n \"visibility\",\n \"grey lighten-1\"\n );\n public static fullAccess = new EnumUserPermissionAccess(\n 2,\n \"FullAccess\",\n \"user_roles_full_access\",\n \"check\",\n \"success lighten-3\"\n );\n\n public key: number;\n public value: string;\n public translationKey: string;\n public icon: string;\n public colour: string;\n\n private constructor(\n key: number,\n value: string,\n translationKey: string,\n icon: string,\n colour: string\n ) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n this.icon = icon;\n this.colour = colour;\n EnumUserPermissionAccess.allValues.push(this);\n }\n\n public static getValues(): EnumUserPermissionAccess[] {\n return EnumUserPermissionAccess.allValues;\n }\n\n public static getByKey(key: number): EnumUserPermissionAccess {\n const found = EnumUserPermissionAccess.allValues.find((e) => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumUserPermissionAccess - Key not found: ${key}`);\n }\n\n return found;\n }\n}\n","import type BaseEnumType from \"@/app/services/baseEnumType\";\nimport { EnumProcessOutputTarget } from \"@/app/services/generated/enums/enumProcessOutputTarget.generated\";\nimport { keys } from \"@/plugins/i18n\";\n\nexport class EnumProcessOutputMovementType implements BaseEnumType {\n private static allValues: EnumProcessOutputMovementType[] = [];\n\n public static stock = new EnumProcessOutputMovementType(\n 0,\n \"Stock\",\n keys.process_output_movement_type_stock.value,\n EnumProcessOutputTarget.stock\n );\n public static processSameBatch = new EnumProcessOutputMovementType(\n 1,\n \"Process of Same Batch\",\n keys.process_output_movement_type_process_same_batch.value,\n EnumProcessOutputTarget.processSameBatch\n );\n public static processOtherBatch = new EnumProcessOutputMovementType(\n 2,\n \"Process of Other Batch\",\n keys.process_output_movement_type_process_other_batch.value,\n EnumProcessOutputTarget.processOtherBatch\n );\n\n public static scanAndFillTrackedContainers =\n new EnumProcessOutputMovementType(\n 3,\n \"Scan and Fill Tracked Containers\",\n keys.process_output_movement_type_scan_and_fill_tracked_containers.value,\n EnumProcessOutputTarget.stock\n );\n\n public key: number;\n public value: string;\n public translationKey: string;\n public processOutputTarget: EnumProcessOutputTarget;\n\n private constructor(\n key: number,\n value: string,\n translationKey: string,\n processOutputTarget: EnumProcessOutputTarget\n ) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n this.processOutputTarget = processOutputTarget;\n\n EnumProcessOutputMovementType.allValues.push(this);\n }\n\n public isStock() {\n return this === EnumProcessOutputMovementType.stock;\n }\n public isProcessSameBatch() {\n return this === EnumProcessOutputMovementType.processSameBatch;\n }\n public isProcessOtherBatch() {\n return this === EnumProcessOutputMovementType.processOtherBatch;\n }\n public isScanAndFillTrackedContainers() {\n return this === EnumProcessOutputMovementType.scanAndFillTrackedContainers;\n }\n\n public static getValues(): EnumProcessOutputMovementType[] {\n return EnumProcessOutputMovementType.allValues;\n }\n\n public static getByKey(key: number): EnumProcessOutputMovementType {\n const found = EnumProcessOutputMovementType.allValues.find(\n (e) => e.key === key\n );\n if (found === undefined) {\n throw new Error(`EnumProcessOutputMovementType - Key not found: ${key}`);\n }\n\n return found;\n }\n}\n","import type BaseEnumType from \"@/app/services/baseEnumType\";\nimport type { Order } from \"@/app/services/generated/orderService\";\nimport type { Visit } from \"@/app/services/generated/visitService\";\nimport Key from \"@/app/types/common/key\";\nimport { translate } from \"@/plugins/i18n\";\n\nexport enum JourneyPanelTypeEnum {\n allOrders = 0,\n collection = 1,\n courier = 2,\n}\n\nexport interface JourneyPanelTab {\n journeyPanelType: JourneyPanelTypeEnum;\n label: string;\n numberOfOrders?: number;\n}\n\nexport interface OrderVisits {\n orders: Order[];\n visits: Visit[];\n}\n\nexport class EnumDistributionItemAction implements BaseEnumType {\n private static allValues: EnumDistributionItemAction[] = []; // make sure this is top-most\n\n public static completeOrder = new EnumDistributionItemAction(\n 1,\n \"CompleteOrder\",\n \"enum_distribution_item_actions_mark_as_complete\"\n );\n public static cancelOrder = new EnumDistributionItemAction(\n 2,\n \"CancelOrder\",\n \"enum_distribution_item_actions_cancel_order\"\n );\n public static uncompleteOrder = new EnumDistributionItemAction(\n 3,\n \"UncompleteOrder\",\n \"enum_distribution_item_actions_uncomplete_order\"\n );\n public static rescheduleOrder = new EnumDistributionItemAction(\n 4,\n \"RescheduleOrder\",\n \"enum_distribution_item_actions_reschedule_order\"\n );\n public static completeVisit = new EnumDistributionItemAction(\n 5,\n \"CompleteVisit\",\n \"enum_distribution_item_actions_complete_visit\"\n );\n public static cancelVisit = new EnumDistributionItemAction(\n 6,\n \"CancelVisit\",\n \"enum_distribution_item_actions_cancel_visit\"\n );\n public static uncompleteVisit = new EnumDistributionItemAction(\n 7,\n \"UncompleteVisit\",\n \"enum_distribution_item_actions_uncomplete_visit\"\n );\n public static rescheduleVisit = new EnumDistributionItemAction(\n 8,\n \"RescheduleVisit\",\n \"enum_distribution_item_actions_reschedule_visit\"\n );\n public static viewDelivery = new EnumDistributionItemAction(\n 9,\n \"ViewDelivery\",\n \"enum_distribution_item_actions_view_delivery\",\n true\n );\n public static viewVisit = new EnumDistributionItemAction(\n 10,\n \"ViewVisit\",\n \"enum_distribution_item_actions_view_visit\",\n true\n );\n public static viewOrder = new EnumDistributionItemAction(\n 11,\n \"ViewOrder\",\n \"enum_distribution_item_actions_view_order\",\n true\n );\n public static changeStatus = new EnumDistributionItemAction(\n 12,\n \"ChangeStatus\",\n \"enum_distribution_item_actions_change_status\"\n );\n public static clearVisit = new EnumDistributionItemAction(\n 13,\n \"ClearVisit\",\n \"enum_distribution_item_actions_clear_visit\"\n );\n public static resolveAndCompleteOrder = new EnumDistributionItemAction(\n 14,\n \"ResolveAndCompleteOrder\",\n \"enum_distribution_item_actions_resolve_and_mark_as_complete\"\n );\n public static ignoreAndCompleteOrder = new EnumDistributionItemAction(\n 15,\n \"ResolveAndCompleteOrder\",\n \"enum_distribution_item_actions_ignore_and_mark_as_complete\"\n );\n public static editVisit = new EnumDistributionItemAction(\n 16,\n \"EditVisit\",\n \"enum_distribution_item_actions_edit_visit\",\n false\n );\n\n public key: number;\n public value: string;\n public translationKey: string;\n public isRoutingAction?: boolean;\n\n private constructor(\n key: number,\n value: string,\n translationKey: string,\n isRoutingAction?: boolean\n ) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n this.isRoutingAction = isRoutingAction;\n EnumDistributionItemAction.allValues.push(this);\n }\n\n public get translation() {\n return translate(Key.fromString(this.translationKey));\n }\n\n public static getValues(): EnumDistributionItemAction[] {\n return EnumDistributionItemAction.allValues;\n }\n\n public static getByKey(key: number): EnumDistributionItemAction {\n const found = EnumDistributionItemAction.allValues.find(\n (e) => e.key === key\n );\n if (found === undefined) {\n throw new Error(`EnumDistributionItemAction - Key not found: ${key}`);\n }\n\n return found;\n }\n}\n\nexport class EnumDistributionItemType implements BaseEnumType {\n private static allValues: EnumDistributionItemType[] = []; // make sure this is top-most\n\n public static order = new EnumDistributionItemType(\n 1,\n \"Order\",\n \"enum_distribution_item_type_order\"\n );\n public static visit = new EnumDistributionItemType(\n 1,\n \"Visit\",\n \"enum_distribution_item_type_visit\"\n );\n\n public key: number;\n public value: string;\n public translationKey?: string;\n\n private constructor(key: number, value: string, translationKey?: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumDistributionItemType.allValues.push(this);\n }\n\n public static getValues(): EnumDistributionItemType[] {\n return EnumDistributionItemType.allValues;\n }\n\n public static getByKey(key: number): EnumDistributionItemType {\n const found = EnumDistributionItemType.allValues.find((e) => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumDistributionItemType - Key not found: ${key}`);\n }\n\n return found;\n }\n}\n","import type BaseEnumType from \"@/app/services/baseEnumType\";\nimport { keys } from \"@/plugins/i18n\";\n\nexport class EnumIntegrationStatus implements BaseEnumType {\n private static allValues: EnumIntegrationStatus[] = []; // make sure this is top-most\n\n public static inactive = new EnumIntegrationStatus(\n 0,\n \"Inactive\",\n \"primary\",\n keys.integrations_activate.value\n );\n public static unauthenticated = new EnumIntegrationStatus(\n 1,\n \"Unauthenticated\",\n \"primary-warn\",\n keys.integrations_unauthenticated.value\n );\n public static active = new EnumIntegrationStatus(\n 2,\n \"Active\",\n \"primary-success\",\n keys.integrations_activated.value\n );\n\n public key: number;\n public value: string;\n public buttonType: string;\n public buttonTextKey: string;\n\n private constructor(\n key: number,\n value: string,\n buttonType: string,\n buttonTextKey: string\n ) {\n this.key = key;\n this.value = value;\n this.buttonType = buttonType;\n this.buttonTextKey = buttonTextKey;\n EnumIntegrationStatus.allValues.push(this);\n }\n\n public isInactive() {\n return this === EnumIntegrationStatus.inactive;\n }\n\n public isUnauthenticated() {\n return this === EnumIntegrationStatus.unauthenticated;\n }\n\n public isActive() {\n return this === EnumIntegrationStatus.active;\n }\n\n public static getValues(): EnumIntegrationStatus[] {\n return EnumIntegrationStatus.allValues;\n }\n\n public static getByKey(key: number): EnumIntegrationStatus {\n const found = EnumIntegrationStatus.allValues.find((e) => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumIntegrationStatus - Key not found: ${key}`);\n }\n\n return found;\n }\n}\nexport interface OrderImporterFunction {\n (maximumCount: number | null): Promise;\n}\n\nexport interface OrderImporterResults {\n importedCount: number;\n processedButNotImported: number;\n remainingToProcessCount: number;\n}\n","import type BaseEnumType from \"@/app/services/baseEnumType\";\n\nexport class EnumChangelogEntryType implements BaseEnumType {\n private static allValues: EnumChangelogEntryType[] = []; // make sure this is top-most\n\n public static bug = new EnumChangelogEntryType(\n 1,\n \"Bug\",\n \"enum_changelog_entry_type_bug\"\n );\n public static minor = new EnumChangelogEntryType(\n 2,\n \"Minor\",\n \"enum_changelog_entry_type_minor\"\n );\n public static major = new EnumChangelogEntryType(\n 3,\n \"Major\",\n \"enum_changelog_entry_type_major\"\n );\n\n public key: number;\n public value: string;\n public translationKey?: string;\n\n private constructor(key: number, value: string, translationKey?: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumChangelogEntryType.allValues.push(this);\n }\n\n public static getValues(): EnumChangelogEntryType[] {\n return EnumChangelogEntryType.allValues;\n }\n\n public static getByKey(key: number): EnumChangelogEntryType {\n const found = EnumChangelogEntryType.allValues.find((e) => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumChangelogEntryType - Key not found: ${key}`);\n }\n\n return found;\n }\n}\n","import type BaseEnumType from \"@/app/services/baseEnumType\";\nimport Key from \"@/app/types/common/key\";\nimport { translate, useI18n } from \"@/plugins/i18n\";\n\nconst { $m } = useI18n();\n\n// Probably overkill\nexport class EnumCommunicationLogLineType implements BaseEnumType {\n private static allValues: EnumCommunicationLogLineType[] = []; // make sure this is top-most\n\n public static lead = new EnumCommunicationLogLineType(\n 0,\n \"Lead\",\n \"leads_noun\"\n );\n public static outlet = new EnumCommunicationLogLineType(\n 1,\n \"Outlet\",\n \"outlet\"\n );\n\n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumCommunicationLogLineType.allValues.push(this);\n }\n\n public get translation() {\n return translate(Key.fromString(this.translationKey));\n }\n\n public static getValues(): EnumCommunicationLogLineType[] {\n return EnumCommunicationLogLineType.allValues;\n }\n\n public static getByKey(key: number): EnumCommunicationLogLineType {\n const found = EnumCommunicationLogLineType.allValues.find(\n (e) => e.key === key\n );\n if (found === undefined) {\n throw new Error(`EnumCommunicationLogLineType - Key not found: ${key}`);\n }\n\n return found;\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumBmEntityType } from \"./enums/enumBmEntityType.generated\";\nimport { EnumTaskRepeatBasis } from \"./enums/enumTaskRepeatBasis.generated\";\nimport { EnumTaskStatus } from \"./enums/enumTaskStatus.generated\";\n\n// Model Objects\n\nexport class BmTaskReadOnly extends ModelObject {\n\n private _cancelledAt: Instant | null = null;\n /**\n * Timestamp at which the task was cancelled on the system. Captured by system not user editable.\n */\n public get cancelledAt(): Instant | null { return this._cancelledAt }\n public set cancelledAt(value: Instant | null) {\n this._cancelledAt = value === undefined ? null : value;\n }\n private _cancelledByUserId: Guid | null = null;\n /**\n * User Id of the user who cancelled the task (if cancelled). Captured by system not user editable.\n */\n public get cancelledByUserId(): Guid | null { return this._cancelledByUserId }\n public set cancelledByUserId(value: Guid | null) {\n this._cancelledByUserId = value === undefined ? null : value;\n }\n private _completedAt: Instant | null = null;\n /**\n * Timestamp at which the task was completed on the system. Captured by system not user editable.\n */\n public get completedAt(): Instant | null { return this._completedAt }\n public set completedAt(value: Instant | null) {\n this._completedAt = value === undefined ? null : value;\n }\n private _completedByUserId: Guid | null = null;\n /**\n * User Id of the user who completed the task (if complete). Captured by system not user editable.\n */\n public get completedByUserId(): Guid | null { return this._completedByUserId }\n public set completedByUserId(value: Guid | null) {\n this._completedByUserId = value === undefined ? null : value;\n }\n /**\n * Timestamp at which the task was created on the system. Captured by system not user editable.\n */\n public createdAt: Instant = Instant.ofEpochMilli(0);\n /**\n * User Id of the creating user. Captured by system not user editable.\n */\n public createdByUserId: Guid = Guid.createEmpty();\n private _notifiedDueSoonAt: Instant | null = null;\n /**\n * Timestamp at which DueSoon notifications were last sent. Captured by system not user editable.\n */\n public get notifiedDueSoonAt(): Instant | null { return this._notifiedDueSoonAt }\n public set notifiedDueSoonAt(value: Instant | null) {\n this._notifiedDueSoonAt = value === undefined ? null : value;\n }\n private _notifiedOverdueAt: Instant | null = null;\n /**\n * Timestamp at which OverDue notifications were last sent. Captured by system not user editable.\n */\n public get notifiedOverdueAt(): Instant | null { return this._notifiedOverdueAt }\n public set notifiedOverdueAt(value: Instant | null) {\n this._notifiedOverdueAt = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.cancelledAt = jsonSerializedObject.cancelledAt == null ? null : Instant.parse(jsonSerializedObject.cancelledAt);\n this.cancelledByUserId = jsonSerializedObject.cancelledByUserId == null ? null : Guid.fromString(jsonSerializedObject.cancelledByUserId);\n this.completedAt = jsonSerializedObject.completedAt == null ? null : Instant.parse(jsonSerializedObject.completedAt);\n this.completedByUserId = jsonSerializedObject.completedByUserId == null ? null : Guid.fromString(jsonSerializedObject.completedByUserId);\n this.createdAt = Instant.parse(jsonSerializedObject.createdAt);\n this.createdByUserId = Guid.fromString(jsonSerializedObject.createdByUserId);\n this.notifiedDueSoonAt = jsonSerializedObject.notifiedDueSoonAt == null ? null : Instant.parse(jsonSerializedObject.notifiedDueSoonAt);\n this.notifiedOverdueAt = jsonSerializedObject.notifiedOverdueAt == null ? null : Instant.parse(jsonSerializedObject.notifiedOverdueAt);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.cancelledAt = this.cancelledAt == null ? null : this.cancelledAt.toString();\n toRet.cancelledByUserId = this.cancelledByUserId == null ? null : this.cancelledByUserId.toString();\n toRet.completedAt = this.completedAt == null ? null : this.completedAt.toString();\n toRet.completedByUserId = this.completedByUserId == null ? null : this.completedByUserId.toString();\n toRet.createdAt = this.createdAt.toString();\n toRet.createdByUserId = this.createdByUserId.toString();\n toRet.notifiedDueSoonAt = this.notifiedDueSoonAt == null ? null : this.notifiedDueSoonAt.toString();\n toRet.notifiedOverdueAt = this.notifiedOverdueAt == null ? null : this.notifiedOverdueAt.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"cancelledByUserId\", rule: (v: any) => v == null || !v.isEmpty() || \"BmTaskReadOnly.CancelledByUserId cannot be empty\"},\n {field: \"completedByUserId\", rule: (v: any) => v == null || !v.isEmpty() || \"BmTaskReadOnly.CompletedByUserId cannot be empty\"},\n {field: \"createdByUserId\", rule: (v: any) => !v.isEmpty() || \"BmTaskReadOnly.CreatedByUserId cannot be empty\"},\n ];\n}\n\n\nexport class BmTaskCalculated extends ModelObject {\n\n public status: EnumTaskStatus = EnumTaskStatus.open;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.status = EnumTaskStatus.getByValue(jsonSerializedObject.status, this.status);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.status = this.status.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class BmTask extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n public version: number = 0;\n private _assignedToUserId: Guid | null = null;\n /**\n * User, if any, currently assigned to perform the task.\n */\n public get assignedToUserId(): Guid | null { return this._assignedToUserId }\n public set assignedToUserId(value: Guid | null) {\n this._assignedToUserId = value === undefined ? null : value;\n }\n private _associatedBmEntityId: Guid | null = null;\n /**\n * Id of the entity with which the task is associated, if any.\n */\n public get associatedBmEntityId(): Guid | null { return this._associatedBmEntityId }\n public set associatedBmEntityId(value: Guid | null) {\n this._associatedBmEntityId = value === undefined ? null : value;\n }\n /**\n * Task Description\n * Not Nullable\n * Max Length : 100000\n */\n public description: string = \"\";\n private _dueDate: LocalDate | null = null;\n /**\n * Date by which the task should be done, if specified.\n */\n public get dueDate(): LocalDate | null { return this._dueDate }\n public set dueDate(value: LocalDate | null) {\n this._dueDate = value === undefined ? null : value;\n }\n private _dueTime: LocalTime | null = null;\n /**\n * Time on due date by which the task should be done, if specified. Not relevant if Due Date is null.\n */\n public get dueTime(): LocalTime | null { return this._dueTime }\n public set dueTime(value: LocalTime | null) {\n this._dueTime = value === undefined ? null : value;\n }\n public taskQueueId: Guid = Guid.createEmpty();\n /**\n * Basis for repeating task once completed. Should be None if DueDate is not null.\n */\n public taskRepeatBasis: EnumTaskRepeatBasis = EnumTaskRepeatBasis.none;\n /**\n * Parameter for task repeat schedule. Only relevant if TaskRepeatBasis is a basis which uses a parameter.\n */\n public taskRepeatParameter: number = 0;\n public taskTypeId: Guid = Guid.createEmpty();\n public readOnly: BmTaskReadOnly = new BmTaskReadOnly();\n public calculated: BmTaskCalculated = new BmTaskCalculated();\n /**\n * Type of the entity with which the task is associated, or enum value none. Association is only supported to entity types which are tenant-level with a single guid id.\n */\n public associatedBmEntityType: EnumBmEntityType = EnumBmEntityType.none;\n /**\n * Task Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n /**\n * Duration of this task in minutes.\n * Minimum : 1\n */\n public durationMinutes: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.version = jsonSerializedObject.version;\n this.assignedToUserId = jsonSerializedObject.assignedToUserId == null ? null : Guid.fromString(jsonSerializedObject.assignedToUserId);\n this.associatedBmEntityId = jsonSerializedObject.associatedBmEntityId == null ? null : Guid.fromString(jsonSerializedObject.associatedBmEntityId);\n this.description = jsonSerializedObject.description;\n this.dueDate = jsonSerializedObject.dueDate == null ? null : LocalDate.parse(jsonSerializedObject.dueDate);\n this.dueTime = jsonSerializedObject.dueTime == null ? null : LocalTime.parse(jsonSerializedObject.dueTime);\n this.taskQueueId = Guid.fromString(jsonSerializedObject.taskQueueId);\n this.taskRepeatBasis = EnumTaskRepeatBasis.getByValue(jsonSerializedObject.taskRepeatBasis, this.taskRepeatBasis);\n this.taskRepeatParameter = jsonSerializedObject.taskRepeatParameter;\n this.taskTypeId = Guid.fromString(jsonSerializedObject.taskTypeId);\n this.readOnly = new BmTaskReadOnly(jsonSerializedObject.readOnly);\n this.calculated = new BmTaskCalculated(jsonSerializedObject.calculated);\n this.associatedBmEntityType = EnumBmEntityType.getByValue(jsonSerializedObject.associatedBmEntityType, this.associatedBmEntityType);\n this.notes = jsonSerializedObject.notes;\n this.durationMinutes = jsonSerializedObject.durationMinutes;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.version = this.version;\n toRet.assignedToUserId = this.assignedToUserId == null ? null : this.assignedToUserId.toString();\n toRet.associatedBmEntityId = this.associatedBmEntityId == null ? null : this.associatedBmEntityId.toString();\n toRet.description = this.description;\n toRet.dueDate = this.dueDate == null ? null : this.dueDate.toString();\n toRet.dueTime = this.dueTime == null ? null : this.dueTime.toString();\n toRet.taskQueueId = this.taskQueueId.toString();\n toRet.taskRepeatBasis = this.taskRepeatBasis.value;\n toRet.taskRepeatParameter = this.taskRepeatParameter;\n toRet.taskTypeId = this.taskTypeId.toString();\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.calculated = this.calculated.toJsonSerializedObject();\n toRet.associatedBmEntityType = this.associatedBmEntityType.value;\n toRet.notes = this.notes;\n toRet.durationMinutes = this.durationMinutes;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"BmTask.Id cannot be empty\"},\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"assignedToUserId\", rule: (v: any) => v == null || !v.isEmpty() || \"BmTask.AssignedToUserId cannot be empty\"},\n {field: \"associatedBmEntityId\", rule: (v: any) => v == null || !v.isEmpty() || \"BmTask.AssociatedBmEntityId cannot be empty\"},\n {field: \"description\", rule: (v: any) => v == null || v.length <= 100000 || \"Description has too many characters (100000)\"},\n {field: \"taskQueueId\", rule: (v: any) => !v.isEmpty() || \"BmTask.TaskQueueId cannot be empty\"},\n {field: \"taskRepeatParameter\", rule: (v: any) => v == null || v >= -2147483648 || \"TaskRepeatParameter is not greater than minimum allowed value: -2147483648\"},\n {field: \"taskRepeatParameter\", rule: (v: any) => v == null || v <= 2147483647 || \"TaskRepeatParameter is above maximum allowed value: 2147483647\"},\n {field: \"taskTypeId\", rule: (v: any) => !v.isEmpty() || \"BmTask.TaskTypeId cannot be empty\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"calculated\", rule: (v: any) => !!v || \"calculated is required\"},\n {field: \"calculated\", rule: (v: any) => v.validate()},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"durationMinutes\", rule: (v: any) => v == null || v >= 1 || \"DurationMinutes is not greater than minimum allowed value: 1\"},\n {field: \"durationMinutes\", rule: (v: any) => v == null || v <= 2147483647 || \"DurationMinutes is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class BmTaskFilterAssociatedEntity extends ModelObject {\n\n public entityType: EnumBmEntityType = EnumBmEntityType.none;\n public entityId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.entityType = EnumBmEntityType.getByValue(jsonSerializedObject.entityType, this.entityType);\n this.entityId = Guid.fromString(jsonSerializedObject.entityId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.entityType = this.entityType.value;\n toRet.entityId = this.entityId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"entityId\", rule: (v: any) => !v.isEmpty() || \"BmTaskFilterAssociatedEntity.EntityId cannot be empty\"},\n ];\n}\n\n\nexport class BmTaskFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _limitStatuses: EnumTaskStatus[] | null = null;\n public get limitStatuses(): EnumTaskStatus[] | null { return this._limitStatuses }\n public set limitStatuses(value: EnumTaskStatus[] | null) {\n this._limitStatuses = value === undefined ? null : value;\n }\n private _limitTaskTypeIds: Guid[] | null = null;\n public get limitTaskTypeIds(): Guid[] | null { return this._limitTaskTypeIds }\n public set limitTaskTypeIds(value: Guid[] | null) {\n this._limitTaskTypeIds = value === undefined ? null : value;\n }\n private _limitTaskQueueIds: Guid[] | null = null;\n public get limitTaskQueueIds(): Guid[] | null { return this._limitTaskQueueIds }\n public set limitTaskQueueIds(value: Guid[] | null) {\n this._limitTaskQueueIds = value === undefined ? null : value;\n }\n private _limitAssignedUserIds: Guid[] | null = null;\n public get limitAssignedUserIds(): Guid[] | null { return this._limitAssignedUserIds }\n public set limitAssignedUserIds(value: Guid[] | null) {\n this._limitAssignedUserIds = value === undefined ? null : value;\n }\n private _fromDueDate: LocalDate | null = null;\n /**\n * Minimum (inclusive) due date. Note tasks with due date null will be allowed by this filter.\n */\n public get fromDueDate(): LocalDate | null { return this._fromDueDate }\n public set fromDueDate(value: LocalDate | null) {\n this._fromDueDate = value === undefined ? null : value;\n }\n private _toDueDate: LocalDate | null = null;\n /**\n * Maximum (inclusive) due date. Note tasks with due date null will be rejected by this filter.\n */\n public get toDueDate(): LocalDate | null { return this._toDueDate }\n public set toDueDate(value: LocalDate | null) {\n this._toDueDate = value === undefined ? null : value;\n }\n private _limitAssociatedEntities: BmTaskFilterAssociatedEntity[] | null = null;\n public get limitAssociatedEntities(): BmTaskFilterAssociatedEntity[] | null { return this._limitAssociatedEntities }\n public set limitAssociatedEntities(value: BmTaskFilterAssociatedEntity[] | null) {\n this._limitAssociatedEntities = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.limitStatuses = jsonSerializedObject.limitStatuses == null ? null : jsonSerializedObject.limitStatuses.map((v: any) => EnumTaskStatus.getByValue(v));\n this.limitTaskTypeIds = jsonSerializedObject.limitTaskTypeIds == null ? null : jsonSerializedObject.limitTaskTypeIds.map((v: any) => Guid.fromString(v));\n this.limitTaskQueueIds = jsonSerializedObject.limitTaskQueueIds == null ? null : jsonSerializedObject.limitTaskQueueIds.map((v: any) => Guid.fromString(v));\n this.limitAssignedUserIds = jsonSerializedObject.limitAssignedUserIds == null ? null : jsonSerializedObject.limitAssignedUserIds.map((v: any) => Guid.fromString(v));\n this.fromDueDate = jsonSerializedObject.fromDueDate == null ? null : LocalDate.parse(jsonSerializedObject.fromDueDate);\n this.toDueDate = jsonSerializedObject.toDueDate == null ? null : LocalDate.parse(jsonSerializedObject.toDueDate);\n this.limitAssociatedEntities = jsonSerializedObject.limitAssociatedEntities == null ? null : jsonSerializedObject.limitAssociatedEntities.map((v: any) => new BmTaskFilterAssociatedEntity(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.limitStatuses = this.limitStatuses == null ? null : this.limitStatuses.map(v => v.value);\n toRet.limitTaskTypeIds = this.limitTaskTypeIds == null ? null : this.limitTaskTypeIds.map(v => v.toString());\n toRet.limitTaskQueueIds = this.limitTaskQueueIds == null ? null : this.limitTaskQueueIds.map(v => v.toString());\n toRet.limitAssignedUserIds = this.limitAssignedUserIds == null ? null : this.limitAssignedUserIds.map(v => v.toString());\n toRet.fromDueDate = this.fromDueDate == null ? null : this.fromDueDate.toString();\n toRet.toDueDate = this.toDueDate == null ? null : this.toDueDate.toString();\n toRet.limitAssociatedEntities = this.limitAssociatedEntities == null ? null : this.limitAssociatedEntities.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n {field: \"limitAssociatedEntities\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as BmTaskFilterAssociatedEntity[]).reduce((acc: Array, curr: BmTaskFilterAssociatedEntity) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class FilteredBmTaskResults extends ModelObject {\n\n public matchingCount: number = 0;\n public bmTasks: BmTask[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.bmTasks = jsonSerializedObject.bmTasks.map((v: any) => new BmTask(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.bmTasks = this.bmTasks.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"bmTasks\", rule: (v: any) => !!v || \"bmTasks is required\"},\n {field: \"bmTasks\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as BmTask[]).reduce((acc: Array, curr: BmTask) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetBmTaskRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public bmTaskId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.bmTaskId = Guid.fromString(jsonSerializedObject.bmTaskId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.bmTaskId = this.bmTaskId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"bmTaskId\", rule: (v: any) => !v.isEmpty() || \".BmTaskId cannot be empty\"},\n ];\n}\n\n\nexport class GetBmTaskResponse extends ModelObject {\n\n public bmTask: BmTask = new BmTask();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.bmTask = new BmTask(jsonSerializedObject.bmTask);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.bmTask = this.bmTask.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"bmTask\", rule: (v: any) => !!v || \"bmTask is required\"},\n {field: \"bmTask\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetBmTasksRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public bmTaskIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.bmTaskIds = jsonSerializedObject.bmTaskIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.bmTaskIds = this.bmTaskIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetBmTasksResponse extends ModelObject {\n\n public bmTasks: BmTask[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.bmTasks = jsonSerializedObject.bmTasks.map((v: any) => new BmTask(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.bmTasks = this.bmTasks.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"bmTasks\", rule: (v: any) => !!v || \"bmTasks is required\"},\n {field: \"bmTasks\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as BmTask[]).reduce((acc: Array, curr: BmTask) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetBmTasksByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: BmTaskFilter = new BmTaskFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new BmTaskFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetBmTasksByFilterResponse extends ModelObject {\n\n public results: FilteredBmTaskResults = new FilteredBmTaskResults();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredBmTaskResults(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveBmTaskRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public bmTask: BmTask = new BmTask();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.bmTask = new BmTask(jsonSerializedObject.bmTask);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.bmTask = this.bmTask.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"bmTask\", rule: (v: any) => !!v || \"bmTask is required\"},\n {field: \"bmTask\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveBmTasksRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public bmTasks: readonly BmTask[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.bmTasks = jsonSerializedObject.bmTasks.map((v: any) => new BmTask(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.bmTasks = this.bmTasks.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"bmTasks\", rule: (v: any) => !!v || \"bmTasks is required\"},\n {field: \"bmTasks\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as BmTask[]).reduce((acc: Array, curr: BmTask) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class CancelBmTaskRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public bmTaskId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.bmTaskId = Guid.fromString(jsonSerializedObject.bmTaskId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.bmTaskId = this.bmTaskId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"bmTaskId\", rule: (v: any) => !v.isEmpty() || \".BmTaskId cannot be empty\"},\n ];\n}\n\n\nexport class CompleteBmTaskRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public bmTaskId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.bmTaskId = Guid.fromString(jsonSerializedObject.bmTaskId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.bmTaskId = this.bmTaskId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"bmTaskId\", rule: (v: any) => !v.isEmpty() || \".BmTaskId cannot be empty\"},\n ];\n}\n\n\nexport class CompleteBmTasksRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public bmTaskIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.bmTaskIds = jsonSerializedObject.bmTaskIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.bmTaskIds = this.bmTaskIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class BmTaskService extends ServiceBase {\n\n public async getBmTask(tenantId: Guid, bmTaskId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetBmTaskRequest();\n req.tenantId = tenantId;\n req.bmTaskId = bmTaskId;\n const extractor = (response:any) => new GetBmTaskResponse(response).bmTask;\n return this.makeJsonRequest(\"bmTask/v1/getBmTask\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getBmTasks(tenantId: Guid, bmTaskIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetBmTasksRequest();\n req.tenantId = tenantId;\n req.bmTaskIds = bmTaskIds;\n const extractor = (response:any) => new GetBmTasksResponse(response).bmTasks;\n return this.makeJsonRequest(\"bmTask/v1/getBmTasks\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getBmTasksByFilter(tenantId: Guid, filter: BmTaskFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetBmTasksByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetBmTasksByFilterResponse(response).results;\n return this.makeJsonRequest(\"bmTask/v1/getBmTasksByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveBmTask(tenantId: Guid, bmTask: BmTask, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveBmTaskRequest();\n req.tenantId = tenantId;\n req.bmTask = bmTask;\n const extractor = null;\n return this.makeJsonRequest(\"bmTask/v1/saveBmTask\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveBmTasks(tenantId: Guid, bmTasks: readonly BmTask[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveBmTasksRequest();\n req.tenantId = tenantId;\n req.bmTasks = bmTasks;\n const extractor = null;\n return this.makeJsonRequest(\"bmTask/v1/saveBmTasks\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async cancelBmTask(tenantId: Guid, bmTaskId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CancelBmTaskRequest();\n req.tenantId = tenantId;\n req.bmTaskId = bmTaskId;\n const extractor = null;\n return this.makeJsonRequest(\"bmTask/v1/cancelBmTask\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async completeBmTask(tenantId: Guid, bmTaskId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CompleteBmTaskRequest();\n req.tenantId = tenantId;\n req.bmTaskId = bmTaskId;\n const extractor = null;\n return this.makeJsonRequest(\"bmTask/v1/completeBmTask\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async completeBmTasks(tenantId: Guid, bmTaskIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CompleteBmTasksRequest();\n req.tenantId = tenantId;\n req.bmTaskIds = bmTaskIds;\n const extractor = null;\n return this.makeJsonRequest(\"bmTask/v1/completeBmTasks\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const bmTaskService = new BmTaskService();","/**\n * Base64 handling in browser in not straight forward. See:\n * https://developer.mozilla.org/en-US/docs/Glossary/Base64\n */\n\n// @ts-nocheck\n/* eslint-disable */\n\n/**\n * base64.ts\n *\n * Licensed under the BSD 3-Clause License.\n * http://opensource.org/licenses/BSD-3-Clause\n *\n * References:\n * http://en.wikipedia.org/wiki/Base64\n *\n * @author Dan Kogai (https://github.com/dankogai)\n */\nconst version = \"3.7.5\";\n/**\n * @deprecated use lowercase `version`.\n */\nconst VERSION = version;\nconst _hasatob = typeof atob === \"function\";\nconst _hasbtoa = typeof btoa === \"function\";\nconst _hasBuffer = typeof Buffer === \"function\";\nconst _TD = typeof TextDecoder === \"function\" ? new TextDecoder() : undefined;\nconst _TE = typeof TextEncoder === \"function\" ? new TextEncoder() : undefined;\nconst b64ch =\n \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\";\nconst b64chs = Array.prototype.slice.call(b64ch);\nconst b64tab = ((a) => {\n let tab = {};\n a.forEach((c, i) => (tab[c] = i));\n return tab;\n})(b64chs);\nconst b64re =\n /^(?:[A-Za-z\\d+\\/]{4})*?(?:[A-Za-z\\d+\\/]{2}(?:==)?|[A-Za-z\\d+\\/]{3}=?)?$/;\nconst _fromCC = String.fromCharCode.bind(String);\nconst _U8Afrom =\n typeof Uint8Array.from === \"function\"\n ? Uint8Array.from.bind(Uint8Array)\n : (it) => new Uint8Array(Array.prototype.slice.call(it, 0));\nconst _mkUriSafe = (src: string) =>\n src.replace(/=/g, \"\").replace(/[+\\/]/g, (m0) => (m0 == \"+\" ? \"-\" : \"_\"));\nconst _tidyB64 = (s: string) => s.replace(/[^A-Za-z0-9\\+\\/]/g, \"\");\n/**\n * polyfill version of `btoa`\n */\nconst btoaPolyfill = (bin: string) => {\n // console.log('polyfilled');\n let u32,\n c0,\n c1,\n c2,\n asc = \"\";\n const pad = bin.length % 3;\n for (let i = 0; i < bin.length; ) {\n if (\n (c0 = bin.charCodeAt(i++)) > 255 ||\n (c1 = bin.charCodeAt(i++)) > 255 ||\n (c2 = bin.charCodeAt(i++)) > 255\n )\n throw new TypeError(\"invalid character found\");\n u32 = (c0 << 16) | (c1 << 8) | c2;\n asc +=\n b64chs[(u32 >> 18) & 63] +\n b64chs[(u32 >> 12) & 63] +\n b64chs[(u32 >> 6) & 63] +\n b64chs[u32 & 63];\n }\n return pad ? asc.slice(0, pad - 3) + \"===\".substring(pad) : asc;\n};\n/**\n * does what `window.btoa` of web browsers do.\n * @param {String} bin binary string\n * @returns {string} Base64-encoded string\n */\nconst _btoa = _hasbtoa\n ? (bin: string) => btoa(bin)\n : _hasBuffer\n ? (bin: string) => Buffer.from(bin, \"binary\").toString(\"base64\")\n : btoaPolyfill;\nconst _fromUint8Array = _hasBuffer\n ? (u8a: Uint8Array) => Buffer.from(u8a).toString(\"base64\")\n : (u8a: Uint8Array) => {\n // cf. https://stackoverflow.com/questions/12710001/how-to-convert-uint8-array-to-base64-encoded-string/12713326#12713326\n const maxargs = 0x1000;\n let strs: string[] = [];\n for (let i = 0, l = u8a.length; i < l; i += maxargs) {\n strs.push(_fromCC.apply(null, u8a.subarray(i, i + maxargs)));\n }\n return _btoa(strs.join(\"\"));\n };\n/**\n * converts a Uint8Array to a Base64 string.\n * @param {boolean} [urlsafe] URL-and-filename-safe a la RFC4648 §5\n * @returns {string} Base64 string\n */\nconst fromUint8Array = (u8a: Uint8Array, urlsafe = false) =>\n urlsafe ? _mkUriSafe(_fromUint8Array(u8a)) : _fromUint8Array(u8a);\n// This trick is found broken https://github.com/dankogai/js-base64/issues/130\n// const utob = (src: string) => unescape(encodeURIComponent(src));\n// reverting good old fationed regexp\nconst cb_utob = (c: string) => {\n if (c.length < 2) {\n var cc = c.charCodeAt(0);\n return cc < 0x80\n ? c\n : cc < 0x800\n ? _fromCC(0xc0 | (cc >>> 6)) + _fromCC(0x80 | (cc & 0x3f))\n : _fromCC(0xe0 | ((cc >>> 12) & 0x0f)) +\n _fromCC(0x80 | ((cc >>> 6) & 0x3f)) +\n _fromCC(0x80 | (cc & 0x3f));\n } else {\n var cc =\n 0x10000 + (c.charCodeAt(0) - 0xd800) * 0x400 + (c.charCodeAt(1) - 0xdc00);\n return (\n _fromCC(0xf0 | ((cc >>> 18) & 0x07)) +\n _fromCC(0x80 | ((cc >>> 12) & 0x3f)) +\n _fromCC(0x80 | ((cc >>> 6) & 0x3f)) +\n _fromCC(0x80 | (cc & 0x3f))\n );\n }\n};\nconst re_utob = /[\\uD800-\\uDBFF][\\uDC00-\\uDFFFF]|[^\\x00-\\x7F]/g;\n/**\n * @deprecated should have been internal use only.\n * @param {string} src UTF-8 string\n * @returns {string} UTF-16 string\n */\nconst utob = (u: string) => u.replace(re_utob, cb_utob);\n//\nconst _encode = _hasBuffer\n ? (s: string) => Buffer.from(s, \"utf8\").toString(\"base64\")\n : _TE\n ? (s: string) => _fromUint8Array(_TE.encode(s))\n : (s: string) => _btoa(utob(s));\n/**\n * converts a UTF-8-encoded string to a Base64 string.\n * @param {boolean} [urlsafe] if `true` make the result URL-safe\n * @returns {string} Base64 string\n */\nconst encode = (src: string, urlsafe = false) =>\n urlsafe ? _mkUriSafe(_encode(src)) : _encode(src);\n/**\n * converts a UTF-8-encoded string to URL-safe Base64 RFC4648 §5.\n * @returns {string} Base64 string\n */\nconst encodeURI = (src: string) => encode(src, true);\n// This trick is found broken https://github.com/dankogai/js-base64/issues/130\n// const btou = (src: string) => decodeURIComponent(escape(src));\n// reverting good old fationed regexp\nconst re_btou =\n /[\\xC0-\\xDF][\\x80-\\xBF]|[\\xE0-\\xEF][\\x80-\\xBF]{2}|[\\xF0-\\xF7][\\x80-\\xBF]{3}/g;\nconst cb_btou = (cccc: string) => {\n switch (cccc.length) {\n case 4:\n var cp =\n ((0x07 & cccc.charCodeAt(0)) << 18) |\n ((0x3f & cccc.charCodeAt(1)) << 12) |\n ((0x3f & cccc.charCodeAt(2)) << 6) |\n (0x3f & cccc.charCodeAt(3)),\n offset = cp - 0x10000;\n return (\n _fromCC((offset >>> 10) + 0xd800) + _fromCC((offset & 0x3ff) + 0xdc00)\n );\n case 3:\n return _fromCC(\n ((0x0f & cccc.charCodeAt(0)) << 12) |\n ((0x3f & cccc.charCodeAt(1)) << 6) |\n (0x3f & cccc.charCodeAt(2))\n );\n default:\n return _fromCC(\n ((0x1f & cccc.charCodeAt(0)) << 6) | (0x3f & cccc.charCodeAt(1))\n );\n }\n};\n/**\n * @deprecated should have been internal use only.\n * @param {string} src UTF-16 string\n * @returns {string} UTF-8 string\n */\nconst btou = (b: string) => b.replace(re_btou, cb_btou);\n/**\n * polyfill version of `atob`\n */\nconst atobPolyfill = (asc: string) => {\n // console.log('polyfilled');\n asc = asc.replace(/\\s+/g, \"\");\n if (!b64re.test(asc)) throw new TypeError(\"malformed base64.\");\n asc += \"==\".slice(2 - (asc.length & 3));\n let u24,\n bin = \"\",\n r1,\n r2;\n for (let i = 0; i < asc.length; ) {\n u24 =\n (b64tab[asc.charAt(i++)] << 18) |\n (b64tab[asc.charAt(i++)] << 12) |\n ((r1 = b64tab[asc.charAt(i++)]) << 6) |\n (r2 = b64tab[asc.charAt(i++)]);\n bin +=\n r1 === 64\n ? _fromCC((u24 >> 16) & 255)\n : r2 === 64\n ? _fromCC((u24 >> 16) & 255, (u24 >> 8) & 255)\n : _fromCC((u24 >> 16) & 255, (u24 >> 8) & 255, u24 & 255);\n }\n return bin;\n};\n/**\n * does what `window.atob` of web browsers do.\n * @param {String} asc Base64-encoded string\n * @returns {string} binary string\n */\nconst _atob = _hasatob\n ? (asc: string) => atob(_tidyB64(asc))\n : _hasBuffer\n ? (asc: string) => Buffer.from(asc, \"base64\").toString(\"binary\")\n : atobPolyfill;\n//\nconst _toUint8Array = _hasBuffer\n ? (a: string) => _U8Afrom(Buffer.from(a, \"base64\"))\n : (a: string) =>\n _U8Afrom(\n _atob(a)\n .split(\"\")\n .map((c) => c.charCodeAt(0))\n );\n/**\n * converts a Base64 string to a Uint8Array.\n */\nconst toUint8Array = (a: string): Uint8Array => _toUint8Array(_unURI(a));\n//\nconst _decode = _hasBuffer\n ? (a: string) => Buffer.from(a, \"base64\").toString(\"utf8\")\n : _TD\n ? (a: string) => _TD.decode(_toUint8Array(a))\n : (a: string) => btou(_atob(a));\nconst _unURI = (a: string) =>\n _tidyB64(a.replace(/[-_]/g, (m0) => (m0 == \"-\" ? \"+\" : \"/\")));\n/**\n * converts a Base64 string to a UTF-8 string.\n * @param {String} src Base64 string. Both normal and URL-safe are supported\n * @returns {string} UTF-8 string\n */\nconst decode = (src: string) => _decode(_unURI(src));\n/**\n * check if a value is a valid Base64 string\n * @param {String} src a value to check\n */\nconst isValid = (src: any) => {\n if (typeof src !== \"string\") return false;\n const s = src.replace(/\\s+/g, \"\").replace(/={0,2}$/, \"\");\n return !/[^\\s0-9a-zA-Z\\+/]/.test(s) || !/[^\\s0-9a-zA-Z\\-_]/.test(s);\n};\n//\nconst _noEnum = (v) => {\n return {\n value: v,\n enumerable: false,\n writable: true,\n configurable: true,\n };\n};\n/**\n * extend String.prototype with relevant methods\n */\nconst extendString = function () {\n const _add = (name, body) =>\n Object.defineProperty(String.prototype, name, _noEnum(body));\n _add(\"fromBase64\", function () {\n return decode(this);\n });\n _add(\"toBase64\", function (urlsafe) {\n return encode(this, urlsafe);\n });\n _add(\"toBase64URI\", function () {\n return encode(this, true);\n });\n _add(\"toBase64URL\", function () {\n return encode(this, true);\n });\n _add(\"toUint8Array\", function () {\n return toUint8Array(this);\n });\n};\n/**\n * extend Uint8Array.prototype with relevant methods\n */\nconst extendUint8Array = function () {\n const _add = (name, body) =>\n Object.defineProperty(Uint8Array.prototype, name, _noEnum(body));\n _add(\"toBase64\", function (urlsafe) {\n return fromUint8Array(this, urlsafe);\n });\n _add(\"toBase64URI\", function () {\n return fromUint8Array(this, true);\n });\n _add(\"toBase64URL\", function () {\n return fromUint8Array(this, true);\n });\n};\n/**\n * extend Builtin prototypes with relevant methods\n */\nconst extendBuiltins = () => {\n extendString();\n extendUint8Array();\n};\nconst gBase64 = {\n version: version,\n VERSION: VERSION,\n atob: _atob,\n atobPolyfill: atobPolyfill,\n btoa: _btoa,\n btoaPolyfill: btoaPolyfill,\n fromBase64: decode,\n toBase64: encode,\n encode: encode,\n encodeURI: encodeURI,\n encodeURL: encodeURI,\n utob: utob,\n btou: btou,\n decode: decode,\n isValid: isValid,\n fromUint8Array: fromUint8Array,\n toUint8Array: toUint8Array,\n extendString: extendString,\n extendUint8Array: extendUint8Array,\n extendBuiltins: extendBuiltins,\n};\n// makecjs:CUT //\nexport { version };\nexport { VERSION };\nexport { _atob as atob };\nexport { atobPolyfill };\nexport { _btoa as btoa };\nexport { btoaPolyfill };\nexport { decode as fromBase64 };\nexport { encode as toBase64 };\nexport { utob };\nexport { encode };\nexport { encodeURI };\nexport { encodeURI as encodeURL };\nexport { btou };\nexport { decode };\nexport { isValid };\nexport { fromUint8Array };\nexport { toUint8Array };\nexport { extendString };\nexport { extendUint8Array };\nexport { extendBuiltins };\n// and finally,\nexport { gBase64 as Base64 };\n","import { Base64 } from \"@/app/base64\";\n\nfunction base64ToUint8Array(base64: string): Uint8Array;\nfunction base64ToUint8Array(\n base64: string | null | undefined\n): Uint8Array | null {\n if (base64 === null || base64 === undefined) {\n return null;\n }\n return Base64.toUint8Array(base64);\n}\n\nexport default {\n base64ToUint8Array,\n uint8ArrayToBase64(\n arrayBuffer: Uint8Array | undefined | null\n ): string | undefined {\n return arrayBuffer ? Base64.fromUint8Array(arrayBuffer) : undefined;\n },\n};\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumAlcoholType } from \"./enums/enumAlcoholType.generated\";\nimport { EnumCreditType } from \"./enums/enumCreditType.generated\";\nimport { EnumDocumentFileType } from \"./enums/enumDocumentFileType.generated\";\nimport { EnumEireMovementType } from \"./enums/enumEireMovementType.generated\";\nimport { EnumGermanBeerDutyMovementType } from \"./enums/enumGermanBeerDutyMovementType.generated\";\nimport { EnumGermanBeerDutyProductType } from \"./enums/enumGermanBeerDutyProductType.generated\";\nimport { EnumOrderStatus } from \"./enums/enumOrderStatus.generated\";\nimport { EnumSpiritDutyExemptionReason } from \"./enums/enumSpiritDutyExemptionReason.generated\";\nimport { EnumStandardOrder } from \"./enums/enumStandardOrder.generated\";\n\n// Model Objects\n\nexport class CreditSummary extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Credit Number\n * Not Nullable\n */\n public creditNumber: string = \"\";\n /**\n * Outlet ID\n */\n public outletId: Guid = Guid.createEmpty();\n private _cancelledAt: Instant | null = null;\n /**\n * Timestamp at which the credit was cancelled.\n */\n public get cancelledAt(): Instant | null { return this._cancelledAt }\n public set cancelledAt(value: Instant | null) {\n this._cancelledAt = value === undefined ? null : value;\n }\n /**\n * Effective Date of the Credit - Ie the accounting Date. This is also the date at which duty would be claimed, but not the date which would be the basis of the duty rate calculation (see OriginalDespatchDate).\n */\n public creditDate: LocalDate = LocalDate.ofEpochDay(0);\n /**\n * Date of Original Despatch. This is the date used as the basis for the duty rate calculation.\n */\n public originalDespatchDate: LocalDate = LocalDate.ofEpochDay(0);\n /**\n * Status : 0 = None, 1 = Open, 2 = Complete, 3 = Historic, 4 = Cancelled, 5 = Posting, 6 = Draft\n */\n public status: EnumOrderStatus = EnumOrderStatus.none;\n /**\n * Our Reference\n * Not Nullable\n * Max Length : 1000\n */\n public ourReference: string = \"\";\n private _orderHeaderId: Guid | null = null;\n /**\n * Order header id of which the credit is associated to.\n */\n public get orderHeaderId(): Guid | null { return this._orderHeaderId }\n public set orderHeaderId(value: Guid | null) {\n this._orderHeaderId = value === undefined ? null : value;\n }\n private _ullageId: Guid | null = null;\n /**\n * Optional Ullage ID to link to where the spoilt product came from.\n */\n public get ullageId(): Guid | null { return this._ullageId }\n public set ullageId(value: Guid | null) {\n this._ullageId = value === undefined ? null : value;\n }\n public germanBeerDutyMovementType: EnumGermanBeerDutyMovementType = EnumGermanBeerDutyMovementType.none;\n /**\n * Reference name or number from the Accounts Link posting.\n * Not Nullable\n * Max Length : 1000\n */\n public accountsLinkReferenceName: string = \"\";\n /**\n * User who initially created the credit. Captured by system not user editable.\n */\n public createdByUserId: Guid = Guid.createEmpty();\n /**\n * Timestamp at which the credit was created on the system. Captured by system not user editable.\n */\n public createdAt: Instant = Instant.ofEpochMilli(0);\n public eireDutyMovementType: EnumEireMovementType = EnumEireMovementType.unknown;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.creditNumber = jsonSerializedObject.creditNumber;\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n this.cancelledAt = jsonSerializedObject.cancelledAt == null ? null : Instant.parse(jsonSerializedObject.cancelledAt);\n this.creditDate = LocalDate.parse(jsonSerializedObject.creditDate);\n this.originalDespatchDate = LocalDate.parse(jsonSerializedObject.originalDespatchDate);\n this.status = EnumOrderStatus.getByValue(jsonSerializedObject.status, this.status);\n this.ourReference = jsonSerializedObject.ourReference;\n this.orderHeaderId = jsonSerializedObject.orderHeaderId == null ? null : Guid.fromString(jsonSerializedObject.orderHeaderId);\n this.ullageId = jsonSerializedObject.ullageId == null ? null : Guid.fromString(jsonSerializedObject.ullageId);\n this.germanBeerDutyMovementType = EnumGermanBeerDutyMovementType.getByValue(jsonSerializedObject.germanBeerDutyMovementType, this.germanBeerDutyMovementType);\n this.accountsLinkReferenceName = jsonSerializedObject.accountsLinkReferenceName;\n this.createdByUserId = Guid.fromString(jsonSerializedObject.createdByUserId);\n this.createdAt = Instant.parse(jsonSerializedObject.createdAt);\n this.eireDutyMovementType = EnumEireMovementType.getByValue(jsonSerializedObject.eireDutyMovementType, this.eireDutyMovementType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.creditNumber = this.creditNumber;\n toRet.outletId = this.outletId.toString();\n toRet.cancelledAt = this.cancelledAt == null ? null : this.cancelledAt.toString();\n toRet.creditDate = this.creditDate.toString();\n toRet.originalDespatchDate = this.originalDespatchDate.toString();\n toRet.status = this.status.value;\n toRet.ourReference = this.ourReference;\n toRet.orderHeaderId = this.orderHeaderId == null ? null : this.orderHeaderId.toString();\n toRet.ullageId = this.ullageId == null ? null : this.ullageId.toString();\n toRet.germanBeerDutyMovementType = this.germanBeerDutyMovementType.value;\n toRet.accountsLinkReferenceName = this.accountsLinkReferenceName;\n toRet.createdByUserId = this.createdByUserId.toString();\n toRet.createdAt = this.createdAt.toString();\n toRet.eireDutyMovementType = this.eireDutyMovementType.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"CreditSummary.Id cannot be empty\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \"CreditSummary.OutletId cannot be empty\"},\n {field: \"ourReference\", rule: (v: any) => v == null || v.length <= 1000 || \"OurReference has too many characters (1000)\"},\n {field: \"orderHeaderId\", rule: (v: any) => v == null || !v.isEmpty() || \"CreditSummary.OrderHeaderId cannot be empty\"},\n {field: \"ullageId\", rule: (v: any) => v == null || !v.isEmpty() || \"CreditSummary.UllageId cannot be empty\"},\n {field: \"accountsLinkReferenceName\", rule: (v: any) => v == null || v.length <= 1000 || \"AccountsLinkReferenceName has too many characters (1000)\"},\n {field: \"createdByUserId\", rule: (v: any) => !v.isEmpty() || \"CreditSummary.CreatedByUserId cannot be empty\"},\n ];\n}\n\n\nexport class CreditSummariesResult extends ModelObject {\n\n public matchingCount: number = 0;\n public credits: CreditSummary[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.credits = jsonSerializedObject.credits.map((v: any) => new CreditSummary(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.credits = this.credits.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"credits\", rule: (v: any) => !!v || \"credits is required\"},\n {field: \"credits\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as CreditSummary[]).reduce((acc: Array, curr: CreditSummary) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class CreditFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _singleOutletId: Guid | null = null;\n public get singleOutletId(): Guid | null { return this._singleOutletId }\n public set singleOutletId(value: Guid | null) {\n this._singleOutletId = value === undefined ? null : value;\n }\n private _singleGroupId: Guid | null = null;\n public get singleGroupId(): Guid | null { return this._singleGroupId }\n public set singleGroupId(value: Guid | null) {\n this._singleGroupId = value === undefined ? null : value;\n }\n public singleCreditNumber: string = \"\";\n private _fromCreditDate: LocalDate | null = null;\n /**\n * Minimum (inclusive) credit date\n */\n public get fromCreditDate(): LocalDate | null { return this._fromCreditDate }\n public set fromCreditDate(value: LocalDate | null) {\n this._fromCreditDate = value === undefined ? null : value;\n }\n private _toCreditDate: LocalDate | null = null;\n /**\n * Maximum (inclusive) credit date\n */\n public get toCreditDate(): LocalDate | null { return this._toCreditDate }\n public set toCreditDate(value: LocalDate | null) {\n this._toCreditDate = value === undefined ? null : value;\n }\n private _limitStatuses: EnumOrderStatus[] | null = null;\n /**\n * If provided only matching statuses are returned\n */\n public get limitStatuses(): EnumOrderStatus[] | null { return this._limitStatuses }\n public set limitStatuses(value: EnumOrderStatus[] | null) {\n this._limitStatuses = value === undefined ? null : value;\n }\n private _limitCreditIds: Guid[] | null = null;\n public get limitCreditIds(): Guid[] | null { return this._limitCreditIds }\n public set limitCreditIds(value: Guid[] | null) {\n this._limitCreditIds = value === undefined ? null : value;\n }\n private _limitUllageIds: Guid[] | null = null;\n public get limitUllageIds(): Guid[] | null { return this._limitUllageIds }\n public set limitUllageIds(value: Guid[] | null) {\n this._limitUllageIds = value === undefined ? null : value;\n }\n private _standardOrderTypes: EnumStandardOrder[] | null = null;\n public get standardOrderTypes(): EnumStandardOrder[] | null { return this._standardOrderTypes }\n public set standardOrderTypes(value: EnumStandardOrder[] | null) {\n this._standardOrderTypes = value === undefined ? null : value;\n }\n private _fromCreatedAt: Instant | null = null;\n public get fromCreatedAt(): Instant | null { return this._fromCreatedAt }\n public set fromCreatedAt(value: Instant | null) {\n this._fromCreatedAt = value === undefined ? null : value;\n }\n private _toCreatedAt: Instant | null = null;\n public get toCreatedAt(): Instant | null { return this._toCreatedAt }\n public set toCreatedAt(value: Instant | null) {\n this._toCreatedAt = value === undefined ? null : value;\n }\n private _fromCancelledAt: Instant | null = null;\n public get fromCancelledAt(): Instant | null { return this._fromCancelledAt }\n public set fromCancelledAt(value: Instant | null) {\n this._fromCancelledAt = value === undefined ? null : value;\n }\n private _toCancelledAt: Instant | null = null;\n public get toCancelledAt(): Instant | null { return this._toCancelledAt }\n public set toCancelledAt(value: Instant | null) {\n this._toCancelledAt = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.singleOutletId = jsonSerializedObject.singleOutletId == null ? null : Guid.fromString(jsonSerializedObject.singleOutletId);\n this.singleGroupId = jsonSerializedObject.singleGroupId == null ? null : Guid.fromString(jsonSerializedObject.singleGroupId);\n this.singleCreditNumber = jsonSerializedObject.singleCreditNumber;\n this.fromCreditDate = jsonSerializedObject.fromCreditDate == null ? null : LocalDate.parse(jsonSerializedObject.fromCreditDate);\n this.toCreditDate = jsonSerializedObject.toCreditDate == null ? null : LocalDate.parse(jsonSerializedObject.toCreditDate);\n this.limitStatuses = jsonSerializedObject.limitStatuses == null ? null : jsonSerializedObject.limitStatuses.map((v: any) => EnumOrderStatus.getByValue(v));\n this.limitCreditIds = jsonSerializedObject.limitCreditIds == null ? null : jsonSerializedObject.limitCreditIds.map((v: any) => Guid.fromString(v));\n this.limitUllageIds = jsonSerializedObject.limitUllageIds == null ? null : jsonSerializedObject.limitUllageIds.map((v: any) => Guid.fromString(v));\n this.standardOrderTypes = jsonSerializedObject.standardOrderTypes == null ? null : jsonSerializedObject.standardOrderTypes.map((v: any) => EnumStandardOrder.getByValue(v));\n this.fromCreatedAt = jsonSerializedObject.fromCreatedAt == null ? null : Instant.parse(jsonSerializedObject.fromCreatedAt);\n this.toCreatedAt = jsonSerializedObject.toCreatedAt == null ? null : Instant.parse(jsonSerializedObject.toCreatedAt);\n this.fromCancelledAt = jsonSerializedObject.fromCancelledAt == null ? null : Instant.parse(jsonSerializedObject.fromCancelledAt);\n this.toCancelledAt = jsonSerializedObject.toCancelledAt == null ? null : Instant.parse(jsonSerializedObject.toCancelledAt);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.singleOutletId = this.singleOutletId == null ? null : this.singleOutletId.toString();\n toRet.singleGroupId = this.singleGroupId == null ? null : this.singleGroupId.toString();\n toRet.singleCreditNumber = this.singleCreditNumber;\n toRet.fromCreditDate = this.fromCreditDate == null ? null : this.fromCreditDate.toString();\n toRet.toCreditDate = this.toCreditDate == null ? null : this.toCreditDate.toString();\n toRet.limitStatuses = this.limitStatuses == null ? null : this.limitStatuses.map(v => v.value);\n toRet.limitCreditIds = this.limitCreditIds == null ? null : this.limitCreditIds.map(v => v.toString());\n toRet.limitUllageIds = this.limitUllageIds == null ? null : this.limitUllageIds.map(v => v.toString());\n toRet.standardOrderTypes = this.standardOrderTypes == null ? null : this.standardOrderTypes.map(v => v.value);\n toRet.fromCreatedAt = this.fromCreatedAt == null ? null : this.fromCreatedAt.toString();\n toRet.toCreatedAt = this.toCreatedAt == null ? null : this.toCreatedAt.toString();\n toRet.fromCancelledAt = this.fromCancelledAt == null ? null : this.fromCancelledAt.toString();\n toRet.toCancelledAt = this.toCancelledAt == null ? null : this.toCancelledAt.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n {field: \"singleOutletId\", rule: (v: any) => v == null || !v.isEmpty() || \"CreditFilter.SingleOutletId cannot be empty\"},\n {field: \"singleGroupId\", rule: (v: any) => v == null || !v.isEmpty() || \"CreditFilter.SingleGroupId cannot be empty\"},\n ];\n}\n\n\nexport class CreditHeaderReadOnly extends ModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Reason Credit Cancelled\n * Not Nullable\n * Max Length : 100000\n */\n public cancellationReason: string = \"\";\n private _cancelledAt: Instant | null = null;\n /**\n * Timestamp at which the credit was cancelled.\n */\n public get cancelledAt(): Instant | null { return this._cancelledAt }\n public set cancelledAt(value: Instant | null) {\n this._cancelledAt = value === undefined ? null : value;\n }\n private _cancelledByUserId: Guid | null = null;\n /**\n * User who cancelled the credit.\n */\n public get cancelledByUserId(): Guid | null { return this._cancelledByUserId }\n public set cancelledByUserId(value: Guid | null) {\n this._cancelledByUserId = value === undefined ? null : value;\n }\n /**\n * Credit Number\n * Not Nullable\n */\n public creditNumber: string = \"\";\n /**\n * Credit Terms Description - Frozen at credit entry so historic invoices can print original details.\n * Not Nullable\n * Max Length : 1000\n */\n public creditTermsDescription: string = \"\";\n /**\n * Credit Type : 0 = None, 1 = CreditNoDutyReclaim, 2 = DutyOnlyReclaim, 3 = CreditWithDutyReclaim\n */\n public creditType: EnumCreditType = EnumCreditType.none;\n private _groupId: Guid | null = null;\n /**\n * Group (if any)\n */\n public get groupId(): Guid | null { return this._groupId }\n public set groupId(value: Guid | null) {\n this._groupId = value === undefined ? null : value;\n }\n /**\n * Is this a BeerflexOrder (DDS) Credit\n */\n public isBeerflexCredit: boolean = false;\n /**\n * Outlet ID\n */\n public outletId: Guid = Guid.createEmpty();\n /**\n * Outlet Name\n * Not Nullable\n * Max Length : 1000\n */\n public outletName: string = \"\";\n /**\n * Outlet Rating of Outlet at Time of credit. Stored for potential future reporting.\n */\n public outletRatingId: Guid = Guid.createEmpty();\n private _outletTypeId: Guid | null = null;\n /**\n * Outlet Type of Outlet at Time of credit. Stored for potential future reporting.\n */\n public get outletTypeId(): Guid | null { return this._outletTypeId }\n public set outletTypeId(value: Guid | null) {\n this._outletTypeId = value === undefined ? null : value;\n }\n private _salesAreaId: Guid | null = null;\n /**\n * The Sales Area which the outlet was in at the time of the credit. Stored for potential future reporting.\n */\n public get salesAreaId(): Guid | null { return this._salesAreaId }\n public set salesAreaId(value: Guid | null) {\n this._salesAreaId = value === undefined ? null : value;\n }\n private _salesCodeId: Guid | null = null;\n /**\n * The Sales Code which the outlet was in at the time of the credit. Stored for potential future reporting.\n */\n public get salesCodeId(): Guid | null { return this._salesCodeId }\n public set salesCodeId(value: Guid | null) {\n this._salesCodeId = value === undefined ? null : value;\n }\n /**\n * Status : 0 = None, 1 = Open, 2 = Complete, 3 = Historic, 4 = Cancelled, 5 = Posting, 6 = Draft\n */\n public status: EnumOrderStatus = EnumOrderStatus.none;\n /**\n * Total Cost Price of Credit. (Inc Duty as applicable, Ex VAT).\n */\n public totalCostNet: number = 0;\n /**\n * Total Net Price of Credit.\n */\n public totalNetPrice: number = 0;\n /**\n * Total VAT of Credit.\n */\n public totalVat: number = 0;\n /**\n * Timestamp at which the credit was created on the system. Captured by system not user editable.\n */\n public createdAt: Instant = Instant.ofEpochMilli(0);\n /**\n * Description of the current error which is preventing this credit from being posted to accounts. Ie the error (if any) which occurred when this was last attempted to post. The presence of text in this field implies there is a known current error so posting will not be reattempted. To reattempt posting this field must be cleared.\n * Not Nullable\n * Max Length : 100000\n */\n public currentPostingError: string = \"\";\n /**\n * Set to true when stock is adjusted for this credit (occurs once posting to accounts succeeds). When true it implies that the items on the credit should not be modified.\n */\n public hasStockBeenAdjusted: boolean = false;\n /**\n * The approximate amount of duty which has/will be reclaimed in fulfilling this credit. This represents the amount of duty included in the total net price, regardless of whether that duty would be reclaimed directly due to this specific credit. For example, if the credit is to non-bonded then the duty is not being reclaimed but that duty element will be included in the duty cost of sale. It is approximate because actual duty return calculations will be rounded across multiple orders/credits so cannot be exactly attributed to each individual credit. \n */\n public totalApproximateDutyCostOfSale: number = 0;\n /**\n * User who initially created the credit. Captured by system not user editable.\n */\n public createdByUserId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.cancellationReason = jsonSerializedObject.cancellationReason;\n this.cancelledAt = jsonSerializedObject.cancelledAt == null ? null : Instant.parse(jsonSerializedObject.cancelledAt);\n this.cancelledByUserId = jsonSerializedObject.cancelledByUserId == null ? null : Guid.fromString(jsonSerializedObject.cancelledByUserId);\n this.creditNumber = jsonSerializedObject.creditNumber;\n this.creditTermsDescription = jsonSerializedObject.creditTermsDescription;\n this.creditType = EnumCreditType.getByValue(jsonSerializedObject.creditType, this.creditType);\n this.groupId = jsonSerializedObject.groupId == null ? null : Guid.fromString(jsonSerializedObject.groupId);\n this.isBeerflexCredit = jsonSerializedObject.isBeerflexCredit;\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n this.outletName = jsonSerializedObject.outletName;\n this.outletRatingId = Guid.fromString(jsonSerializedObject.outletRatingId);\n this.outletTypeId = jsonSerializedObject.outletTypeId == null ? null : Guid.fromString(jsonSerializedObject.outletTypeId);\n this.salesAreaId = jsonSerializedObject.salesAreaId == null ? null : Guid.fromString(jsonSerializedObject.salesAreaId);\n this.salesCodeId = jsonSerializedObject.salesCodeId == null ? null : Guid.fromString(jsonSerializedObject.salesCodeId);\n this.status = EnumOrderStatus.getByValue(jsonSerializedObject.status, this.status);\n this.totalCostNet = jsonSerializedObject.totalCostNet;\n this.totalNetPrice = jsonSerializedObject.totalNetPrice;\n this.totalVat = jsonSerializedObject.totalVat;\n this.createdAt = Instant.parse(jsonSerializedObject.createdAt);\n this.currentPostingError = jsonSerializedObject.currentPostingError;\n this.hasStockBeenAdjusted = jsonSerializedObject.hasStockBeenAdjusted;\n this.totalApproximateDutyCostOfSale = jsonSerializedObject.totalApproximateDutyCostOfSale;\n this.createdByUserId = Guid.fromString(jsonSerializedObject.createdByUserId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.cancellationReason = this.cancellationReason;\n toRet.cancelledAt = this.cancelledAt == null ? null : this.cancelledAt.toString();\n toRet.cancelledByUserId = this.cancelledByUserId == null ? null : this.cancelledByUserId.toString();\n toRet.creditNumber = this.creditNumber;\n toRet.creditTermsDescription = this.creditTermsDescription;\n toRet.creditType = this.creditType.value;\n toRet.groupId = this.groupId == null ? null : this.groupId.toString();\n toRet.isBeerflexCredit = this.isBeerflexCredit;\n toRet.outletId = this.outletId.toString();\n toRet.outletName = this.outletName;\n toRet.outletRatingId = this.outletRatingId.toString();\n toRet.outletTypeId = this.outletTypeId == null ? null : this.outletTypeId.toString();\n toRet.salesAreaId = this.salesAreaId == null ? null : this.salesAreaId.toString();\n toRet.salesCodeId = this.salesCodeId == null ? null : this.salesCodeId.toString();\n toRet.status = this.status.value;\n toRet.totalCostNet = this.totalCostNet;\n toRet.totalNetPrice = this.totalNetPrice;\n toRet.totalVat = this.totalVat;\n toRet.createdAt = this.createdAt.toString();\n toRet.currentPostingError = this.currentPostingError;\n toRet.hasStockBeenAdjusted = this.hasStockBeenAdjusted;\n toRet.totalApproximateDutyCostOfSale = this.totalApproximateDutyCostOfSale;\n toRet.createdByUserId = this.createdByUserId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"CreditHeaderReadOnly.Id cannot be empty\"},\n {field: \"cancellationReason\", rule: (v: any) => v == null || v.length <= 100000 || \"CancellationReason has too many characters (100000)\"},\n {field: \"cancelledByUserId\", rule: (v: any) => v == null || !v.isEmpty() || \"CreditHeaderReadOnly.CancelledByUserId cannot be empty\"},\n {field: \"creditTermsDescription\", rule: (v: any) => v == null || v.length <= 1000 || \"CreditTermsDescription has too many characters (1000)\"},\n {field: \"groupId\", rule: (v: any) => v == null || !v.isEmpty() || \"CreditHeaderReadOnly.GroupId cannot be empty\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \"CreditHeaderReadOnly.OutletId cannot be empty\"},\n {field: \"outletName\", rule: (v: any) => v == null || v.length <= 1000 || \"OutletName has too many characters (1000)\"},\n {field: \"outletRatingId\", rule: (v: any) => !v.isEmpty() || \"CreditHeaderReadOnly.OutletRatingId cannot be empty\"},\n {field: \"outletTypeId\", rule: (v: any) => v == null || !v.isEmpty() || \"CreditHeaderReadOnly.OutletTypeId cannot be empty\"},\n {field: \"salesAreaId\", rule: (v: any) => v == null || !v.isEmpty() || \"CreditHeaderReadOnly.SalesAreaId cannot be empty\"},\n {field: \"salesCodeId\", rule: (v: any) => v == null || !v.isEmpty() || \"CreditHeaderReadOnly.SalesCodeId cannot be empty\"},\n {field: \"currentPostingError\", rule: (v: any) => v == null || v.length <= 100000 || \"CurrentPostingError has too many characters (100000)\"},\n {field: \"createdByUserId\", rule: (v: any) => !v.isEmpty() || \"CreditHeaderReadOnly.CreatedByUserId cannot be empty\"},\n ];\n}\n\n\nexport class CreditHeader extends BaseModelObject {\n\n /**\n * Effective Date of the Credit - Ie the accounting Date. This is also the date at which duty would be claimed, but not the date which would be the basis of the duty rate calculation (see OriginalDespatchDate).\n */\n public creditDate: LocalDate = LocalDate.ofEpochDay(0);\n /**\n * Credit Address Line 1\n * Not Nullable\n * Max Length : 1000\n */\n public creditAddress1: string = \"\";\n /**\n * Credit Address Line 2\n * Not Nullable\n * Max Length : 1000\n */\n public creditAddress2: string = \"\";\n /**\n * Credit Address Line 3\n * Not Nullable\n * Max Length : 1000\n */\n public creditAddress3: string = \"\";\n /**\n * Credit Address Line 4\n * Not Nullable\n * Max Length : 1000\n */\n public creditAddress4: string = \"\";\n /**\n * Credit Address Line 5\n * Not Nullable\n * Max Length : 1000\n */\n public creditAddress5: string = \"\";\n /**\n * Credit Address Line 6\n * Not Nullable\n * Max Length : 1000\n */\n public creditAddress6: string = \"\";\n /**\n * Credit Business Name\n * Not Nullable\n * Max Length : 1000\n */\n public creditAddressBusiness: string = \"\";\n /**\n * Credit Recipient Name\n * Not Nullable\n * Max Length : 1000\n */\n public creditAddressRecipient: string = \"\";\n /**\n * Credit Post Code\n * Not Nullable\n * Max Length : 1000\n */\n public creditPostcode: string = \"\";\n /**\n * Credit Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n /**\n * Date of Original Despatch. This is the date used as the basis for the duty rate calculation.\n */\n public originalDespatchDate: LocalDate = LocalDate.ofEpochDay(0);\n /**\n * Our Reference\n * Not Nullable\n * Max Length : 1000\n */\n public ourReference: string = \"\";\n /**\n * Price List used for the credit. Stored for potential future reporting.\n */\n public priceListId: Guid = Guid.createEmpty();\n /**\n * Order Type 0;Full Price - Duty Paid;1;Price Excluding Duty - Duty Suspended;2;Full Price - Duty Paid Elsewhere;3;Export\n */\n public standardOrderType: EnumStandardOrder = EnumStandardOrder.fullPriceDutyPaid;\n /**\n * VAT Code\n */\n public vatCodeId: Guid = Guid.createEmpty();\n public readOnly: CreditHeaderReadOnly = new CreditHeaderReadOnly();\n /**\n * The email address credit notes will be sent to. Copied from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public emailAddress: string = \"\";\n /**\n * Email Recipient Name. Copied from Outlet / Group by default.\n * Not Nullable\n * Max Length : 1000\n */\n public emailRecipient: string = \"\";\n private _orderHeaderId: Guid | null = null;\n /**\n * Order header id of which the credit is associated to.\n */\n public get orderHeaderId(): Guid | null { return this._orderHeaderId }\n public set orderHeaderId(value: Guid | null) {\n this._orderHeaderId = value === undefined ? null : value;\n }\n private _ullageId: Guid | null = null;\n /**\n * Optional Ullage ID to link to where the spoilt product came from.\n */\n public get ullageId(): Guid | null { return this._ullageId }\n public set ullageId(value: Guid | null) {\n this._ullageId = value === undefined ? null : value;\n }\n /**\n * Whether an credit note has been sent for this credit.\n */\n public creditNoteSent: boolean = false;\n public germanBeerDutyMovementType: EnumGermanBeerDutyMovementType = EnumGermanBeerDutyMovementType.none;\n /**\n * Reference name or number from the Accounts Link posting.\n * Not Nullable\n * Max Length : 1000\n */\n public accountsLinkReferenceName: string = \"\";\n public eireDutyMovementType: EnumEireMovementType = EnumEireMovementType.unknown;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.creditDate = LocalDate.parse(jsonSerializedObject.creditDate);\n this.creditAddress1 = jsonSerializedObject.creditAddress1;\n this.creditAddress2 = jsonSerializedObject.creditAddress2;\n this.creditAddress3 = jsonSerializedObject.creditAddress3;\n this.creditAddress4 = jsonSerializedObject.creditAddress4;\n this.creditAddress5 = jsonSerializedObject.creditAddress5;\n this.creditAddress6 = jsonSerializedObject.creditAddress6;\n this.creditAddressBusiness = jsonSerializedObject.creditAddressBusiness;\n this.creditAddressRecipient = jsonSerializedObject.creditAddressRecipient;\n this.creditPostcode = jsonSerializedObject.creditPostcode;\n this.notes = jsonSerializedObject.notes;\n this.originalDespatchDate = LocalDate.parse(jsonSerializedObject.originalDespatchDate);\n this.ourReference = jsonSerializedObject.ourReference;\n this.priceListId = Guid.fromString(jsonSerializedObject.priceListId);\n this.standardOrderType = EnumStandardOrder.getByValue(jsonSerializedObject.standardOrderType, this.standardOrderType);\n this.vatCodeId = Guid.fromString(jsonSerializedObject.vatCodeId);\n this.readOnly = new CreditHeaderReadOnly(jsonSerializedObject.readOnly);\n this.emailAddress = jsonSerializedObject.emailAddress;\n this.emailRecipient = jsonSerializedObject.emailRecipient;\n this.orderHeaderId = jsonSerializedObject.orderHeaderId == null ? null : Guid.fromString(jsonSerializedObject.orderHeaderId);\n this.ullageId = jsonSerializedObject.ullageId == null ? null : Guid.fromString(jsonSerializedObject.ullageId);\n this.creditNoteSent = jsonSerializedObject.creditNoteSent;\n this.germanBeerDutyMovementType = EnumGermanBeerDutyMovementType.getByValue(jsonSerializedObject.germanBeerDutyMovementType, this.germanBeerDutyMovementType);\n this.accountsLinkReferenceName = jsonSerializedObject.accountsLinkReferenceName;\n this.eireDutyMovementType = EnumEireMovementType.getByValue(jsonSerializedObject.eireDutyMovementType, this.eireDutyMovementType);\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.creditDate = this.creditDate.toString();\n toRet.creditAddress1 = this.creditAddress1;\n toRet.creditAddress2 = this.creditAddress2;\n toRet.creditAddress3 = this.creditAddress3;\n toRet.creditAddress4 = this.creditAddress4;\n toRet.creditAddress5 = this.creditAddress5;\n toRet.creditAddress6 = this.creditAddress6;\n toRet.creditAddressBusiness = this.creditAddressBusiness;\n toRet.creditAddressRecipient = this.creditAddressRecipient;\n toRet.creditPostcode = this.creditPostcode;\n toRet.notes = this.notes;\n toRet.originalDespatchDate = this.originalDespatchDate.toString();\n toRet.ourReference = this.ourReference;\n toRet.priceListId = this.priceListId.toString();\n toRet.standardOrderType = this.standardOrderType.value;\n toRet.vatCodeId = this.vatCodeId.toString();\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.emailAddress = this.emailAddress;\n toRet.emailRecipient = this.emailRecipient;\n toRet.orderHeaderId = this.orderHeaderId == null ? null : this.orderHeaderId.toString();\n toRet.ullageId = this.ullageId == null ? null : this.ullageId.toString();\n toRet.creditNoteSent = this.creditNoteSent;\n toRet.germanBeerDutyMovementType = this.germanBeerDutyMovementType.value;\n toRet.accountsLinkReferenceName = this.accountsLinkReferenceName;\n toRet.eireDutyMovementType = this.eireDutyMovementType.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"creditAddress1\", rule: (v: any) => v == null || v.length <= 1000 || \"CreditAddress1 has too many characters (1000)\"},\n {field: \"creditAddress2\", rule: (v: any) => v == null || v.length <= 1000 || \"CreditAddress2 has too many characters (1000)\"},\n {field: \"creditAddress3\", rule: (v: any) => v == null || v.length <= 1000 || \"CreditAddress3 has too many characters (1000)\"},\n {field: \"creditAddress4\", rule: (v: any) => v == null || v.length <= 1000 || \"CreditAddress4 has too many characters (1000)\"},\n {field: \"creditAddress5\", rule: (v: any) => v == null || v.length <= 1000 || \"CreditAddress5 has too many characters (1000)\"},\n {field: \"creditAddress6\", rule: (v: any) => v == null || v.length <= 1000 || \"CreditAddress6 has too many characters (1000)\"},\n {field: \"creditAddressBusiness\", rule: (v: any) => v == null || v.length <= 1000 || \"CreditAddressBusiness has too many characters (1000)\"},\n {field: \"creditAddressRecipient\", rule: (v: any) => v == null || v.length <= 1000 || \"CreditAddressRecipient has too many characters (1000)\"},\n {field: \"creditPostcode\", rule: (v: any) => v == null || v.length <= 1000 || \"CreditPostcode has too many characters (1000)\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"ourReference\", rule: (v: any) => v == null || v.length <= 1000 || \"OurReference has too many characters (1000)\"},\n {field: \"priceListId\", rule: (v: any) => !v.isEmpty() || \"CreditHeader.PriceListId cannot be empty\"},\n {field: \"vatCodeId\", rule: (v: any) => !v.isEmpty() || \"CreditHeader.VatCodeId cannot be empty\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"emailAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"EmailAddress has too many characters (1000)\"},\n {field: \"emailRecipient\", rule: (v: any) => v == null || v.length <= 1000 || \"EmailRecipient has too many characters (1000)\"},\n {field: \"orderHeaderId\", rule: (v: any) => v == null || !v.isEmpty() || \"CreditHeader.OrderHeaderId cannot be empty\"},\n {field: \"ullageId\", rule: (v: any) => v == null || !v.isEmpty() || \"CreditHeader.UllageId cannot be empty\"},\n {field: \"accountsLinkReferenceName\", rule: (v: any) => v == null || v.length <= 1000 || \"AccountsLinkReferenceName has too many characters (1000)\"},\n ];\n}\n\n\nexport class CreditLineReadOnly extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Product ABV\n * Not Negative\n */\n public abv: number = 0;\n /**\n * Alcohol Type\n */\n public alcoholType: EnumAlcoholType = EnumAlcoholType.none;\n /**\n * Credit ID\n */\n public creditId: Guid = Guid.createEmpty();\n /**\n * General Ledger Code of Product at time of credit. Stored for potential future reporting.\n */\n public glCodeId: Guid = Guid.createEmpty();\n /**\n * Line Cost Price (Inc Duty, Exc Vat)\n * Not Negative\n */\n public lineCostNetPrice: number = 0;\n /**\n * Net (no VAT) Price refunded for the line.\n * Not Negative\n */\n public lineNetPrice: number = 0;\n /**\n * Total VAT\n * Not Negative\n */\n public lineVat: number = 0;\n private _manufacturerId: Guid | null = null;\n /**\n * Manufacturer of the product - Required for lines with Alcohol.\n */\n public get manufacturerId(): Guid | null { return this._manufacturerId }\n public set manufacturerId(value: Guid | null) {\n this._manufacturerId = value === undefined ? null : value;\n }\n private _productBrandId: Guid | null = null;\n /**\n * Product Brand at time of Credit. Stored for potential future reporting.\n */\n public get productBrandId(): Guid | null { return this._productBrandId }\n public set productBrandId(value: Guid | null) {\n this._productBrandId = value === undefined ? null : value;\n }\n /**\n * Product Code\n * Not Nullable\n * Max Length : 1000\n */\n public productCode: string = \"\";\n /**\n * Stock Item Id\n */\n public stockItemId: Guid = Guid.createEmpty();\n /**\n * Product Cost Price\n */\n public unitCostNetPrice: number = 0;\n /**\n * Product Dutyable Litres\n * Not Negative\n */\n public unitDutiableLitres: number = 0;\n /**\n * Product Litres\n * Not Negative\n */\n public unitLitres: number = 0;\n /**\n * Product VAT percentage\n * Not Negative\n */\n public vatPercentage: number = 0;\n /**\n * Vat Code Applicable to the line. May come from Product or Order Header.\n */\n public vatCodeId: Guid = Guid.createEmpty();\n /**\n * Quantity for Duty Reclaim\n * Not Negative\n */\n public quantityForDutyReclaim: number = 0;\n private _pricingCategoryId: Guid | null = null;\n /**\n * Pricing Category.\n */\n public get pricingCategoryId(): Guid | null { return this._pricingCategoryId }\n public set pricingCategoryId(value: Guid | null) {\n this._pricingCategoryId = value === undefined ? null : value;\n }\n /**\n * The approximate amount of duty which has/will be reclaimed in fulfilling this credit. This represents the amount of duty included in the total net price, regardless of whether that duty would be reclaimed directly due to this specific credit. For example, if the credit is to non-bonded then the duty is not being reclaimed but that duty element will be included in the duty cost of sale. It is approximate because actual duty return calculations will be rounded across multiple orders/credits so cannot be exactly attributed to each individual credit. \n */\n public approximateDutyCostOfSale: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.abv = jsonSerializedObject.abv;\n this.alcoholType = EnumAlcoholType.getByValue(jsonSerializedObject.alcoholType, this.alcoholType);\n this.creditId = Guid.fromString(jsonSerializedObject.creditId);\n this.glCodeId = Guid.fromString(jsonSerializedObject.glCodeId);\n this.lineCostNetPrice = jsonSerializedObject.lineCostNetPrice;\n this.lineNetPrice = jsonSerializedObject.lineNetPrice;\n this.lineVat = jsonSerializedObject.lineVat;\n this.manufacturerId = jsonSerializedObject.manufacturerId == null ? null : Guid.fromString(jsonSerializedObject.manufacturerId);\n this.productBrandId = jsonSerializedObject.productBrandId == null ? null : Guid.fromString(jsonSerializedObject.productBrandId);\n this.productCode = jsonSerializedObject.productCode;\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.unitCostNetPrice = jsonSerializedObject.unitCostNetPrice;\n this.unitDutiableLitres = jsonSerializedObject.unitDutiableLitres;\n this.unitLitres = jsonSerializedObject.unitLitres;\n this.vatPercentage = jsonSerializedObject.vatPercentage;\n this.vatCodeId = Guid.fromString(jsonSerializedObject.vatCodeId);\n this.quantityForDutyReclaim = jsonSerializedObject.quantityForDutyReclaim;\n this.pricingCategoryId = jsonSerializedObject.pricingCategoryId == null ? null : Guid.fromString(jsonSerializedObject.pricingCategoryId);\n this.approximateDutyCostOfSale = jsonSerializedObject.approximateDutyCostOfSale;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.abv = this.abv;\n toRet.alcoholType = this.alcoholType.value;\n toRet.creditId = this.creditId.toString();\n toRet.glCodeId = this.glCodeId.toString();\n toRet.lineCostNetPrice = this.lineCostNetPrice;\n toRet.lineNetPrice = this.lineNetPrice;\n toRet.lineVat = this.lineVat;\n toRet.manufacturerId = this.manufacturerId == null ? null : this.manufacturerId.toString();\n toRet.productBrandId = this.productBrandId == null ? null : this.productBrandId.toString();\n toRet.productCode = this.productCode;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.unitCostNetPrice = this.unitCostNetPrice;\n toRet.unitDutiableLitres = this.unitDutiableLitres;\n toRet.unitLitres = this.unitLitres;\n toRet.vatPercentage = this.vatPercentage;\n toRet.vatCodeId = this.vatCodeId.toString();\n toRet.quantityForDutyReclaim = this.quantityForDutyReclaim;\n toRet.pricingCategoryId = this.pricingCategoryId == null ? null : this.pricingCategoryId.toString();\n toRet.approximateDutyCostOfSale = this.approximateDutyCostOfSale;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"CreditLineReadOnly.Id cannot be empty\"},\n {field: \"creditId\", rule: (v: any) => !v.isEmpty() || \"CreditLineReadOnly.CreditId cannot be empty\"},\n {field: \"glCodeId\", rule: (v: any) => !v.isEmpty() || \"CreditLineReadOnly.GlCodeId cannot be empty\"},\n {field: \"manufacturerId\", rule: (v: any) => v == null || !v.isEmpty() || \"CreditLineReadOnly.ManufacturerId cannot be empty\"},\n {field: \"productBrandId\", rule: (v: any) => v == null || !v.isEmpty() || \"CreditLineReadOnly.ProductBrandId cannot be empty\"},\n {field: \"productCode\", rule: (v: any) => v == null || v.length <= 1000 || \"ProductCode has too many characters (1000)\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"CreditLineReadOnly.StockItemId cannot be empty\"},\n {field: \"vatCodeId\", rule: (v: any) => !v.isEmpty() || \"CreditLineReadOnly.VatCodeId cannot be empty\"},\n {field: \"pricingCategoryId\", rule: (v: any) => v == null || !v.isEmpty() || \"CreditLineReadOnly.PricingCategoryId cannot be empty\"},\n ];\n}\n\n\nexport class CreditLine extends ModelObject {\n\n /**\n * This is Spoilt Beer - Duty reclaimable\n */\n public isSpoilt: boolean = false;\n /**\n * Quantity Credited\n * Not Negative\n */\n public quantity: number = 0;\n /**\n * Quantity to Re-Stock\n * Not Negative\n */\n public quantityToRestock: number = 0;\n private _stockLocationId: Guid | null = null;\n /**\n * Stock Location Id - For Restocking.\n */\n public get stockLocationId(): Guid | null { return this._stockLocationId }\n public set stockLocationId(value: Guid | null) {\n this._stockLocationId = value === undefined ? null : value;\n }\n /**\n * Product Unit List Price\n * Not Negative\n */\n public unitListNetPrice: number = 0;\n /**\n * Unit Discount Price\n * Not Negative\n */\n public unitNetPrice: number = 0;\n /**\n * Unit of Measure Id\n */\n public unitOfMeasureId: Guid = Guid.createEmpty();\n public readOnly: CreditLineReadOnly = new CreditLineReadOnly();\n public version: number = 0;\n private _plato: number | null = null;\n /**\n * Plato Value\n */\n public get plato(): number | null { return this._plato }\n public set plato(value: number | null) {\n this._plato = value === undefined ? null : value;\n }\n public germanBeerDutyProductType: EnumGermanBeerDutyProductType = EnumGermanBeerDutyProductType.none;\n private _germanBeerMixedProductPercentageA: number | null = null;\n public get germanBeerMixedProductPercentageA(): number | null { return this._germanBeerMixedProductPercentageA }\n public set germanBeerMixedProductPercentageA(value: number | null) {\n this._germanBeerMixedProductPercentageA = value === undefined ? null : value;\n }\n /**\n * Set true if this item is brewed by members of the public for their personal use by borrowing the Brewery's equipment. This is a service offered by breweries in some countries, such as Australia, and can affect duty.\n */\n public isBrewedForPersonalUse: boolean = false;\n /**\n * Set true if this item is designed to be connected to a pump or pressurised gas system, such as those used in pubs. Some duty systems have different duty rates for beer packaged in these manners for selling to pubs.\n */\n public isDesignedForPump: boolean = false;\n private _finalUnitLitres: number | null = null;\n /**\n * Litres held by the final consumable packaged unit, if relevant. For example, a case of 12 x 500ml bottles would have a final unit litres of 0.5. Some duty systems have different rates depending upon this value.\n * Greater Than : 0\n */\n public get finalUnitLitres(): number | null { return this._finalUnitLitres }\n public set finalUnitLitres(value: number | null) {\n this._finalUnitLitres = value === undefined ? null : value;\n }\n public spiritDutyExemptionReason: EnumSpiritDutyExemptionReason = EnumSpiritDutyExemptionReason.none;\n /**\n * Product Name\n * Not Nullable\n * Max Length : 1000\n */\n public productName: string = \"\";\n /**\n * True if the credit line was entered by volume, and should be shown as by volume when edited.\n */\n public showAsByVolume: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.isSpoilt = jsonSerializedObject.isSpoilt;\n this.quantity = jsonSerializedObject.quantity;\n this.quantityToRestock = jsonSerializedObject.quantityToRestock;\n this.stockLocationId = jsonSerializedObject.stockLocationId == null ? null : Guid.fromString(jsonSerializedObject.stockLocationId);\n this.unitListNetPrice = jsonSerializedObject.unitListNetPrice;\n this.unitNetPrice = jsonSerializedObject.unitNetPrice;\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n this.readOnly = new CreditLineReadOnly(jsonSerializedObject.readOnly);\n this.version = jsonSerializedObject.version;\n this.plato = jsonSerializedObject.plato == null ? null : jsonSerializedObject.plato;\n this.germanBeerDutyProductType = EnumGermanBeerDutyProductType.getByValue(jsonSerializedObject.germanBeerDutyProductType, this.germanBeerDutyProductType);\n this.germanBeerMixedProductPercentageA = jsonSerializedObject.germanBeerMixedProductPercentageA == null ? null : jsonSerializedObject.germanBeerMixedProductPercentageA;\n this.isBrewedForPersonalUse = jsonSerializedObject.isBrewedForPersonalUse;\n this.isDesignedForPump = jsonSerializedObject.isDesignedForPump;\n this.finalUnitLitres = jsonSerializedObject.finalUnitLitres == null ? null : jsonSerializedObject.finalUnitLitres;\n this.spiritDutyExemptionReason = EnumSpiritDutyExemptionReason.getByValue(jsonSerializedObject.spiritDutyExemptionReason, this.spiritDutyExemptionReason);\n this.productName = jsonSerializedObject.productName;\n this.showAsByVolume = jsonSerializedObject.showAsByVolume;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.isSpoilt = this.isSpoilt;\n toRet.quantity = this.quantity;\n toRet.quantityToRestock = this.quantityToRestock;\n toRet.stockLocationId = this.stockLocationId == null ? null : this.stockLocationId.toString();\n toRet.unitListNetPrice = this.unitListNetPrice;\n toRet.unitNetPrice = this.unitNetPrice;\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.version = this.version;\n toRet.plato = this.plato == null ? null : this.plato;\n toRet.germanBeerDutyProductType = this.germanBeerDutyProductType.value;\n toRet.germanBeerMixedProductPercentageA = this.germanBeerMixedProductPercentageA == null ? null : this.germanBeerMixedProductPercentageA;\n toRet.isBrewedForPersonalUse = this.isBrewedForPersonalUse;\n toRet.isDesignedForPump = this.isDesignedForPump;\n toRet.finalUnitLitres = this.finalUnitLitres == null ? null : this.finalUnitLitres;\n toRet.spiritDutyExemptionReason = this.spiritDutyExemptionReason.value;\n toRet.productName = this.productName;\n toRet.showAsByVolume = this.showAsByVolume;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockLocationId\", rule: (v: any) => v == null || !v.isEmpty() || \"CreditLine.StockLocationId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"CreditLine.UnitOfMeasureId cannot be empty\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"finalUnitLitres\", rule: (v: any) => v == null || v > 0 || \"FinalUnitLitres is not greater than minimum allowed value: 0\"},\n {field: \"productName\", rule: (v: any) => v == null || v.length <= 1000 || \"ProductName has too many characters (1000)\"},\n ];\n}\n\n\nexport class Credit extends BaseModelObject {\n\n public header: CreditHeader = new CreditHeader();\n public lines: CreditLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.header = new CreditHeader(jsonSerializedObject.header);\n this.lines = jsonSerializedObject.lines.map((v: any) => new CreditLine(v));\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.header = this.header.toJsonSerializedObject();\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as CreditLine[]).reduce((acc: Array, curr: CreditLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class FilteredCreditsResult extends ModelObject {\n\n public matchingCount: number = 0;\n public credits: Credit[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.credits = jsonSerializedObject.credits.map((v: any) => new Credit(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.credits = this.credits.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"credits\", rule: (v: any) => !!v || \"credits is required\"},\n {field: \"credits\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Credit[]).reduce((acc: Array, curr: Credit) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class DutySuspendedCreditsResultSet extends ModelObject {\n\n public alcoholType: EnumAlcoholType = EnumAlcoholType.none;\n public dutySuspendedCreditedLitres: number = 0;\n public dutySuspendedCreditedLitresOfAlcohol: number = 0;\n public orderType: EnumStandardOrder = EnumStandardOrder.fullPriceDutyPaid;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.alcoholType = EnumAlcoholType.getByValue(jsonSerializedObject.alcoholType, this.alcoholType);\n this.dutySuspendedCreditedLitres = jsonSerializedObject.dutySuspendedCreditedLitres;\n this.dutySuspendedCreditedLitresOfAlcohol = jsonSerializedObject.dutySuspendedCreditedLitresOfAlcohol;\n this.orderType = EnumStandardOrder.getByValue(jsonSerializedObject.orderType, this.orderType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.alcoholType = this.alcoholType.value;\n toRet.dutySuspendedCreditedLitres = this.dutySuspendedCreditedLitres;\n toRet.dutySuspendedCreditedLitresOfAlcohol = this.dutySuspendedCreditedLitresOfAlcohol;\n toRet.orderType = this.orderType.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class PartialCredit extends ModelObject {\n\n public header: CreditHeader = new CreditHeader();\n public lines: CreditLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.header = new CreditHeader(jsonSerializedObject.header);\n this.lines = jsonSerializedObject.lines.map((v: any) => new CreditLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.header = this.header.toJsonSerializedObject();\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as CreditLine[]).reduce((acc: Array, curr: CreditLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetCreditSummariesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: CreditFilter = new CreditFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new CreditFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetCreditSummariesResponse extends ModelObject {\n\n public results: CreditSummariesResult = new CreditSummariesResult();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new CreditSummariesResult(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetCreditsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditIds = jsonSerializedObject.creditIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditIds = this.creditIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetCreditsResponse extends ModelObject {\n\n public credits: Credit[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.credits = jsonSerializedObject.credits.map((v: any) => new Credit(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.credits = this.credits.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"credits\", rule: (v: any) => !!v || \"credits is required\"},\n {field: \"credits\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Credit[]).reduce((acc: Array, curr: Credit) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetCreditsByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: CreditFilter = new CreditFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new CreditFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetCreditsByFilterResponse extends ModelObject {\n\n public results: FilteredCreditsResult = new FilteredCreditsResult();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredCreditsResult(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class CreateCreditRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n /**\n * Outlet ID\n */\n public outletId: Guid = Guid.createEmpty();\n /**\n * Order Type 0;Full Price - Duty Paid;1;Price Excluding Duty - Duty Suspended;2;Full Price - Duty Paid Elsewhere;3;Export\n */\n public standardOrderType: EnumStandardOrder = EnumStandardOrder.fullPriceDutyPaid;\n /**\n * Date of Original Despatch. This is the date used as the basis for the duty rate calculation.\n */\n public originalDespatchDate: LocalDate = LocalDate.ofEpochDay(0);\n /**\n * Price List used for the credit. Stored for potential future reporting.\n */\n public priceListId: Guid = Guid.createEmpty();\n /**\n * Credit Type : 0 = None, 1 = CreditNoDutyReclaim, 2 = DutyOnlyReclaim, 3 = CreditWithDutyReclaim\n */\n public creditType: EnumCreditType = EnumCreditType.none;\n private _orderHeaderId: Guid | null = null;\n /**\n * Order header id of which the credit is associated to.\n */\n public get orderHeaderId(): Guid | null { return this._orderHeaderId }\n public set orderHeaderId(value: Guid | null) {\n this._orderHeaderId = value === undefined ? null : value;\n }\n private _ullageId: Guid | null = null;\n /**\n * Optional Ullage ID to link to where the spoilt product came from.\n */\n public get ullageId(): Guid | null { return this._ullageId }\n public set ullageId(value: Guid | null) {\n this._ullageId = value === undefined ? null : value;\n }\n public germanBeerDutyMovementType: EnumGermanBeerDutyMovementType = EnumGermanBeerDutyMovementType.none;\n public eireDutyMovementType: EnumEireMovementType = EnumEireMovementType.unknown;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n this.standardOrderType = EnumStandardOrder.getByValue(jsonSerializedObject.standardOrderType, this.standardOrderType);\n this.originalDespatchDate = LocalDate.parse(jsonSerializedObject.originalDespatchDate);\n this.priceListId = Guid.fromString(jsonSerializedObject.priceListId);\n this.creditType = EnumCreditType.getByValue(jsonSerializedObject.creditType, this.creditType);\n this.orderHeaderId = jsonSerializedObject.orderHeaderId == null ? null : Guid.fromString(jsonSerializedObject.orderHeaderId);\n this.ullageId = jsonSerializedObject.ullageId == null ? null : Guid.fromString(jsonSerializedObject.ullageId);\n this.germanBeerDutyMovementType = EnumGermanBeerDutyMovementType.getByValue(jsonSerializedObject.germanBeerDutyMovementType, this.germanBeerDutyMovementType);\n this.eireDutyMovementType = EnumEireMovementType.getByValue(jsonSerializedObject.eireDutyMovementType, this.eireDutyMovementType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletId = this.outletId.toString();\n toRet.standardOrderType = this.standardOrderType.value;\n toRet.originalDespatchDate = this.originalDespatchDate.toString();\n toRet.priceListId = this.priceListId.toString();\n toRet.creditType = this.creditType.value;\n toRet.orderHeaderId = this.orderHeaderId == null ? null : this.orderHeaderId.toString();\n toRet.ullageId = this.ullageId == null ? null : this.ullageId.toString();\n toRet.germanBeerDutyMovementType = this.germanBeerDutyMovementType.value;\n toRet.eireDutyMovementType = this.eireDutyMovementType.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \".OutletId cannot be empty\"},\n {field: \"priceListId\", rule: (v: any) => !v.isEmpty() || \".PriceListId cannot be empty\"},\n {field: \"orderHeaderId\", rule: (v: any) => v == null || !v.isEmpty() || \".OrderHeaderId cannot be empty\"},\n {field: \"ullageId\", rule: (v: any) => v == null || !v.isEmpty() || \".UllageId cannot be empty\"},\n ];\n}\n\n\nexport class CreateCreditResponse extends ModelObject {\n\n public credit: Credit = new Credit();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.credit = new Credit(jsonSerializedObject.credit);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.credit = this.credit.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"credit\", rule: (v: any) => !!v || \"credit is required\"},\n {field: \"credit\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class BuildCreditHeaderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletId = this.outletId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \".OutletId cannot be empty\"},\n ];\n}\n\n\nexport class BuildCreditHeaderResponse extends ModelObject {\n\n public header: CreditHeader = new CreditHeader();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.header = new CreditHeader(jsonSerializedObject.header);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.header = this.header.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class UpdateCreditRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditId: Guid = Guid.createEmpty();\n public creditHeader: CreditHeader = new CreditHeader();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditId = Guid.fromString(jsonSerializedObject.creditId);\n this.creditHeader = new CreditHeader(jsonSerializedObject.creditHeader);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditId = this.creditId.toString();\n toRet.creditHeader = this.creditHeader.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"creditId\", rule: (v: any) => !v.isEmpty() || \".CreditId cannot be empty\"},\n {field: \"creditHeader\", rule: (v: any) => !!v || \"creditHeader is required\"},\n {field: \"creditHeader\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class UpdateCreditResponse extends ModelObject {\n\n public credit: Credit = new Credit();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.credit = new Credit(jsonSerializedObject.credit);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.credit = this.credit.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"credit\", rule: (v: any) => !!v || \"credit is required\"},\n {field: \"credit\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class AddLineToCreditRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditId: Guid = Guid.createEmpty();\n public creditLineId: Guid = Guid.createEmpty();\n public stockItemId: Guid = Guid.createEmpty();\n public creditLine: CreditLine = new CreditLine();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditId = Guid.fromString(jsonSerializedObject.creditId);\n this.creditLineId = Guid.fromString(jsonSerializedObject.creditLineId);\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.creditLine = new CreditLine(jsonSerializedObject.creditLine);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditId = this.creditId.toString();\n toRet.creditLineId = this.creditLineId.toString();\n toRet.stockItemId = this.stockItemId.toString();\n toRet.creditLine = this.creditLine.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"creditId\", rule: (v: any) => !v.isEmpty() || \".CreditId cannot be empty\"},\n {field: \"creditLineId\", rule: (v: any) => !v.isEmpty() || \".CreditLineId cannot be empty\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \".StockItemId cannot be empty\"},\n {field: \"creditLine\", rule: (v: any) => !!v || \"creditLine is required\"},\n {field: \"creditLine\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class AddLineToCreditResponse extends ModelObject {\n\n public credit: Credit = new Credit();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.credit = new Credit(jsonSerializedObject.credit);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.credit = this.credit.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"credit\", rule: (v: any) => !!v || \"credit is required\"},\n {field: \"credit\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class UpdateCreditLineRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditId: Guid = Guid.createEmpty();\n public creditLineId: Guid = Guid.createEmpty();\n public creditLine: CreditLine = new CreditLine();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditId = Guid.fromString(jsonSerializedObject.creditId);\n this.creditLineId = Guid.fromString(jsonSerializedObject.creditLineId);\n this.creditLine = new CreditLine(jsonSerializedObject.creditLine);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditId = this.creditId.toString();\n toRet.creditLineId = this.creditLineId.toString();\n toRet.creditLine = this.creditLine.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"creditId\", rule: (v: any) => !v.isEmpty() || \".CreditId cannot be empty\"},\n {field: \"creditLineId\", rule: (v: any) => !v.isEmpty() || \".CreditLineId cannot be empty\"},\n {field: \"creditLine\", rule: (v: any) => !!v || \"creditLine is required\"},\n {field: \"creditLine\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class UpdateCreditLineResponse extends ModelObject {\n\n public credit: Credit = new Credit();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.credit = new Credit(jsonSerializedObject.credit);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.credit = this.credit.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"credit\", rule: (v: any) => !!v || \"credit is required\"},\n {field: \"credit\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class DeleteLinesFromCreditRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditId: Guid = Guid.createEmpty();\n public creditLineIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditId = Guid.fromString(jsonSerializedObject.creditId);\n this.creditLineIds = jsonSerializedObject.creditLineIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditId = this.creditId.toString();\n toRet.creditLineIds = this.creditLineIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"creditId\", rule: (v: any) => !v.isEmpty() || \".CreditId cannot be empty\"},\n ];\n}\n\n\nexport class DeleteLinesFromCreditResponse extends ModelObject {\n\n public credit: Credit = new Credit();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.credit = new Credit(jsonSerializedObject.credit);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.credit = this.credit.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"credit\", rule: (v: any) => !!v || \"credit is required\"},\n {field: \"credit\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class CancelCreditRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditId: Guid = Guid.createEmpty();\n /**\n * Reason Credit Cancelled\n * Not Nullable\n * Not Empty\n * Max Length : 100000\n */\n public cancellationReason: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditId = Guid.fromString(jsonSerializedObject.creditId);\n this.cancellationReason = jsonSerializedObject.cancellationReason;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditId = this.creditId.toString();\n toRet.cancellationReason = this.cancellationReason;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"creditId\", rule: (v: any) => !v.isEmpty() || \".CreditId cannot be empty\"},\n {field: \"cancellationReason\", rule: (v: any) => v == null || v.length !== 0 || \"CancellationReason cannot be empty\"},\n {field: \"cancellationReason\", rule: (v: any) => v == null || v.length <= 100000 || \"CancellationReason has too many characters (100000)\"},\n ];\n}\n\n\nexport class CancelCreditResponse extends ModelObject {\n\n public credit: Credit = new Credit();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.credit = new Credit(jsonSerializedObject.credit);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.credit = this.credit.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"credit\", rule: (v: any) => !!v || \"credit is required\"},\n {field: \"credit\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class CompleteCreditRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditId = Guid.fromString(jsonSerializedObject.creditId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditId = this.creditId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"creditId\", rule: (v: any) => !v.isEmpty() || \".CreditId cannot be empty\"},\n ];\n}\n\n\nexport class CompleteCreditResponse extends ModelObject {\n\n public credit: Credit = new Credit();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.credit = new Credit(jsonSerializedObject.credit);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.credit = this.credit.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"credit\", rule: (v: any) => !!v || \"credit is required\"},\n {field: \"credit\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class UncompleteCreditRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditId = Guid.fromString(jsonSerializedObject.creditId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditId = this.creditId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"creditId\", rule: (v: any) => !v.isEmpty() || \".CreditId cannot be empty\"},\n ];\n}\n\n\nexport class UncompleteCreditResponse extends ModelObject {\n\n public credit: Credit = new Credit();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.credit = new Credit(jsonSerializedObject.credit);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.credit = this.credit.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"credit\", rule: (v: any) => !!v || \"credit is required\"},\n {field: \"credit\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class ArchiveCreditsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditIds = jsonSerializedObject.creditIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditIds = this.creditIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class EvaluateDutySuspendedCreditsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public fromDutyDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public toDutyDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public limitToGivenAlcoholTypes: boolean = false;\n public limitedAlcoholTypes: readonly EnumAlcoholType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.fromDutyDateInclusive = LocalDate.parse(jsonSerializedObject.fromDutyDateInclusive);\n this.toDutyDateInclusive = LocalDate.parse(jsonSerializedObject.toDutyDateInclusive);\n this.limitToGivenAlcoholTypes = jsonSerializedObject.limitToGivenAlcoholTypes;\n this.limitedAlcoholTypes = jsonSerializedObject.limitedAlcoholTypes.map((v: any) => EnumAlcoholType.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.fromDutyDateInclusive = this.fromDutyDateInclusive.toString();\n toRet.toDutyDateInclusive = this.toDutyDateInclusive.toString();\n toRet.limitToGivenAlcoholTypes = this.limitToGivenAlcoholTypes;\n toRet.limitedAlcoholTypes = this.limitedAlcoholTypes.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class EvaluateDutySuspendedCreditsResponse extends ModelObject {\n\n public results: DutySuspendedCreditsResultSet[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new DutySuspendedCreditsResultSet(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as DutySuspendedCreditsResultSet[]).reduce((acc: Array, curr: DutySuspendedCreditsResultSet) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetPossibleCreditDutyLinesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public fromDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public toDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public limitedAlcoholTypes: readonly EnumAlcoholType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.fromDateInclusive = LocalDate.parse(jsonSerializedObject.fromDateInclusive);\n this.toDateInclusive = LocalDate.parse(jsonSerializedObject.toDateInclusive);\n this.limitedAlcoholTypes = jsonSerializedObject.limitedAlcoholTypes.map((v: any) => EnumAlcoholType.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.fromDateInclusive = this.fromDateInclusive.toString();\n toRet.toDateInclusive = this.toDateInclusive.toString();\n toRet.limitedAlcoholTypes = this.limitedAlcoholTypes.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetPossibleCreditDutyLinesResponse extends ModelObject {\n\n public results: PartialCredit[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new PartialCredit(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PartialCredit[]).reduce((acc: Array, curr: PartialCredit) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GenerateCreditNoteDocumentsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditNoteIds: readonly Guid[] = [];\n public documentFormat: EnumDocumentFileType = EnumDocumentFileType.pdf;\n private _documentTemplateIdOverride: Guid | null = null;\n /**\n * If set, this template will be used in place of any default template\n */\n public get documentTemplateIdOverride(): Guid | null { return this._documentTemplateIdOverride }\n public set documentTemplateIdOverride(value: Guid | null) {\n this._documentTemplateIdOverride = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditNoteIds = jsonSerializedObject.creditNoteIds.map((v: any) => Guid.fromString(v));\n this.documentFormat = EnumDocumentFileType.getByValue(jsonSerializedObject.documentFormat, this.documentFormat);\n this.documentTemplateIdOverride = jsonSerializedObject.documentTemplateIdOverride == null ? null : Guid.fromString(jsonSerializedObject.documentTemplateIdOverride);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditNoteIds = this.creditNoteIds.map(v => v.toString());\n toRet.documentFormat = this.documentFormat.value;\n toRet.documentTemplateIdOverride = this.documentTemplateIdOverride == null ? null : this.documentTemplateIdOverride.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"documentTemplateIdOverride\", rule: (v: any) => v == null || !v.isEmpty() || \".DocumentTemplateIdOverride cannot be empty\"},\n ];\n}\n\n\nexport class GenerateCreditNoteDocumentsResponse extends ModelObject {\n\n public documentBytes: Uint8Array = new Uint8Array();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.documentBytes = converters.base64ToUint8Array(jsonSerializedObject.documentBytes);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.documentBytes = converters.uint8ArrayToBase64(this.documentBytes);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class MarkCreditsForPostingRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditNoteIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditNoteIds = jsonSerializedObject.creditNoteIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditNoteIds = this.creditNoteIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class UnmarkCreditsForPostingRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditNoteIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditNoteIds = jsonSerializedObject.creditNoteIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditNoteIds = this.creditNoteIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class RecordCreditPostingResultRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditNoteId: Guid = Guid.createEmpty();\n /**\n * Error text, if any. Empty implies posting was successful.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public postingError: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditNoteId = Guid.fromString(jsonSerializedObject.creditNoteId);\n this.postingError = jsonSerializedObject.postingError;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditNoteId = this.creditNoteId.toString();\n toRet.postingError = this.postingError;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"creditNoteId\", rule: (v: any) => !v.isEmpty() || \".CreditNoteId cannot be empty\"},\n ];\n}\n\n\nexport class EmailCreditNoteRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditNoteId: Guid = Guid.createEmpty();\n public documentFormat: EnumDocumentFileType = EnumDocumentFileType.pdf;\n private _specifiedEmailAddresses: readonly string[] | null = null;\n /**\n * If not null then email will be sent to these addresses rather than the credit note's EmailAddress\n */\n public get specifiedEmailAddresses(): readonly string[] | null { return this._specifiedEmailAddresses }\n public set specifiedEmailAddresses(value: readonly string[] | null) {\n this._specifiedEmailAddresses = value === undefined ? null : value;\n }\n private _emailSubject: string | null = null;\n /**\n * If null, the default credit note email subject will be sent\n * Nullable\n * Preserves leading and trailing whitespce.\n */\n public get emailSubject(): string | null { return this._emailSubject }\n public set emailSubject(value: string | null) {\n this._emailSubject = value === undefined ? null : value;\n }\n private _emailBody: string | null = null;\n /**\n * If null, the default credit note email body will be sent\n * Nullable\n * Preserves leading and trailing whitespce.\n */\n public get emailBody(): string | null { return this._emailBody }\n public set emailBody(value: string | null) {\n this._emailBody = value === undefined ? null : value;\n }\n private _emailAddressesToCc: readonly string[] | null = null;\n /**\n * If not null then email will be CC'd to these addresses\n */\n public get emailAddressesToCc(): readonly string[] | null { return this._emailAddressesToCc }\n public set emailAddressesToCc(value: readonly string[] | null) {\n this._emailAddressesToCc = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditNoteId = Guid.fromString(jsonSerializedObject.creditNoteId);\n this.documentFormat = EnumDocumentFileType.getByValue(jsonSerializedObject.documentFormat, this.documentFormat);\n this.specifiedEmailAddresses = jsonSerializedObject.specifiedEmailAddresses == null ? null : jsonSerializedObject.specifiedEmailAddresses.map((v: any) => v);\n this.emailSubject = jsonSerializedObject.emailSubject == null ? null : jsonSerializedObject.emailSubject;\n this.emailBody = jsonSerializedObject.emailBody == null ? null : jsonSerializedObject.emailBody;\n this.emailAddressesToCc = jsonSerializedObject.emailAddressesToCc == null ? null : jsonSerializedObject.emailAddressesToCc.map((v: any) => v);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditNoteId = this.creditNoteId.toString();\n toRet.documentFormat = this.documentFormat.value;\n toRet.specifiedEmailAddresses = this.specifiedEmailAddresses == null ? null : this.specifiedEmailAddresses.map(v => v);\n toRet.emailSubject = this.emailSubject == null ? null : this.emailSubject;\n toRet.emailBody = this.emailBody == null ? null : this.emailBody;\n toRet.emailAddressesToCc = this.emailAddressesToCc == null ? null : this.emailAddressesToCc.map(v => v);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"creditNoteId\", rule: (v: any) => !v.isEmpty() || \".CreditNoteId cannot be empty\"},\n ];\n}\n\n\nexport class UpdateCreditApproximateDutyCostsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditIds = jsonSerializedObject.creditIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditIds = this.creditIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class UpdateCreditApproximateDutyCostsResponse extends ModelObject {\n\n public affectedCreditIds: Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.affectedCreditIds = jsonSerializedObject.affectedCreditIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.affectedCreditIds = this.affectedCreditIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class UpdateAccountsLinkReferenceNameRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditId: Guid = Guid.createEmpty();\n public accountsLinkReferenceName: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditId = Guid.fromString(jsonSerializedObject.creditId);\n this.accountsLinkReferenceName = jsonSerializedObject.accountsLinkReferenceName;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditId = this.creditId.toString();\n toRet.accountsLinkReferenceName = this.accountsLinkReferenceName;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"creditId\", rule: (v: any) => !v.isEmpty() || \".CreditId cannot be empty\"},\n ];\n}\n\n\nexport class CreditService extends ServiceBase {\n\n public async getCreditSummaries(tenantId: Guid, filter: CreditFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetCreditSummariesRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetCreditSummariesResponse(response).results;\n return this.makeJsonRequest(\"credit/v1/getCreditSummaries\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getCredits(tenantId: Guid, creditIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetCreditsRequest();\n req.tenantId = tenantId;\n req.creditIds = creditIds;\n const extractor = (response:any) => new GetCreditsResponse(response).credits;\n return this.makeJsonRequest(\"credit/v1/getCredits\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getCreditsByFilter(tenantId: Guid, filter: CreditFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetCreditsByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetCreditsByFilterResponse(response).results;\n return this.makeJsonRequest(\"credit/v1/getCreditsByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async createCredit(tenantId: Guid, outletId: Guid, standardOrderType: EnumStandardOrder, originalDespatchDate: LocalDate, priceListId: Guid, creditType: EnumCreditType, orderHeaderId: Guid | null, ullageId: Guid | null, germanBeerDutyMovementType: EnumGermanBeerDutyMovementType, eireDutyMovementType: EnumEireMovementType, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CreateCreditRequest();\n req.tenantId = tenantId;\n req.outletId = outletId;\n req.standardOrderType = standardOrderType;\n req.originalDespatchDate = originalDespatchDate;\n req.priceListId = priceListId;\n req.creditType = creditType;\n req.orderHeaderId = orderHeaderId;\n req.ullageId = ullageId;\n req.germanBeerDutyMovementType = germanBeerDutyMovementType;\n req.eireDutyMovementType = eireDutyMovementType;\n const extractor = (response:any) => new CreateCreditResponse(response).credit;\n return this.makeJsonRequest(\"credit/v1/createCredit\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async buildCreditHeader(tenantId: Guid, outletId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new BuildCreditHeaderRequest();\n req.tenantId = tenantId;\n req.outletId = outletId;\n const extractor = (response:any) => new BuildCreditHeaderResponse(response).header;\n return this.makeJsonRequest(\"credit/v1/buildCreditHeader\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updateCredit(tenantId: Guid, creditId: Guid, creditHeader: CreditHeader, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdateCreditRequest();\n req.tenantId = tenantId;\n req.creditId = creditId;\n req.creditHeader = creditHeader;\n const extractor = (response:any) => new UpdateCreditResponse(response).credit;\n return this.makeJsonRequest(\"credit/v1/updateCredit\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async addLineToCredit(tenantId: Guid, creditId: Guid, creditLineId: Guid, stockItemId: Guid, creditLine: CreditLine, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new AddLineToCreditRequest();\n req.tenantId = tenantId;\n req.creditId = creditId;\n req.creditLineId = creditLineId;\n req.stockItemId = stockItemId;\n req.creditLine = creditLine;\n const extractor = (response:any) => new AddLineToCreditResponse(response).credit;\n return this.makeJsonRequest(\"credit/v1/addLineToCredit\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updateCreditLine(tenantId: Guid, creditId: Guid, creditLineId: Guid, creditLine: CreditLine, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdateCreditLineRequest();\n req.tenantId = tenantId;\n req.creditId = creditId;\n req.creditLineId = creditLineId;\n req.creditLine = creditLine;\n const extractor = (response:any) => new UpdateCreditLineResponse(response).credit;\n return this.makeJsonRequest(\"credit/v1/updateCreditLine\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async deleteLinesFromCredit(tenantId: Guid, creditId: Guid, creditLineIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new DeleteLinesFromCreditRequest();\n req.tenantId = tenantId;\n req.creditId = creditId;\n req.creditLineIds = creditLineIds;\n const extractor = (response:any) => new DeleteLinesFromCreditResponse(response).credit;\n return this.makeJsonRequest(\"credit/v1/deleteLinesFromCredit\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async cancelCredit(tenantId: Guid, creditId: Guid, cancellationReason: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CancelCreditRequest();\n req.tenantId = tenantId;\n req.creditId = creditId;\n req.cancellationReason = cancellationReason;\n const extractor = (response:any) => new CancelCreditResponse(response).credit;\n return this.makeJsonRequest(\"credit/v1/cancelCredit\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async completeCredit(tenantId: Guid, creditId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CompleteCreditRequest();\n req.tenantId = tenantId;\n req.creditId = creditId;\n const extractor = (response:any) => new CompleteCreditResponse(response).credit;\n return this.makeJsonRequest(\"credit/v1/completeCredit\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async uncompleteCredit(tenantId: Guid, creditId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UncompleteCreditRequest();\n req.tenantId = tenantId;\n req.creditId = creditId;\n const extractor = (response:any) => new UncompleteCreditResponse(response).credit;\n return this.makeJsonRequest(\"credit/v1/uncompleteCredit\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async archiveCredits(tenantId: Guid, creditIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new ArchiveCreditsRequest();\n req.tenantId = tenantId;\n req.creditIds = creditIds;\n const extractor = null;\n return this.makeJsonRequest(\"credit/v1/archiveCredits\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async evaluateDutySuspendedCredits(tenantId: Guid, fromDutyDateInclusive: LocalDate, toDutyDateInclusive: LocalDate, limitToGivenAlcoholTypes: boolean, limitedAlcoholTypes: readonly EnumAlcoholType[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new EvaluateDutySuspendedCreditsRequest();\n req.tenantId = tenantId;\n req.fromDutyDateInclusive = fromDutyDateInclusive;\n req.toDutyDateInclusive = toDutyDateInclusive;\n req.limitToGivenAlcoholTypes = limitToGivenAlcoholTypes;\n req.limitedAlcoholTypes = limitedAlcoholTypes;\n const extractor = (response:any) => new EvaluateDutySuspendedCreditsResponse(response).results;\n return this.makeJsonRequest(\"credit/v1/evaluateDutySuspendedCredits\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async generateCreditNoteDocuments(tenantId: Guid, creditNoteIds: readonly Guid[], documentFormat: EnumDocumentFileType, documentTemplateIdOverride: Guid | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GenerateCreditNoteDocumentsRequest();\n req.tenantId = tenantId;\n req.creditNoteIds = creditNoteIds;\n req.documentFormat = documentFormat;\n req.documentTemplateIdOverride = documentTemplateIdOverride;\n const extractor = (response:any) => new GenerateCreditNoteDocumentsResponse(response).documentBytes;\n return this.makeJsonRequest(\"credit/v1/generateCreditNoteDocuments\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async markCreditsForPosting(tenantId: Guid, creditNoteIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new MarkCreditsForPostingRequest();\n req.tenantId = tenantId;\n req.creditNoteIds = creditNoteIds;\n const extractor = null;\n return this.makeJsonRequest(\"credit/v1/markCreditsForPosting\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async unmarkCreditsForPosting(tenantId: Guid, creditNoteIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UnmarkCreditsForPostingRequest();\n req.tenantId = tenantId;\n req.creditNoteIds = creditNoteIds;\n const extractor = null;\n return this.makeJsonRequest(\"credit/v1/unmarkCreditsForPosting\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async recordCreditPostingResult(tenantId: Guid, creditNoteId: Guid, postingError: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new RecordCreditPostingResultRequest();\n req.tenantId = tenantId;\n req.creditNoteId = creditNoteId;\n req.postingError = postingError;\n const extractor = null;\n return this.makeJsonRequest(\"credit/v1/recordCreditPostingResult\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async emailCreditNote(tenantId: Guid, creditNoteId: Guid, documentFormat: EnumDocumentFileType, specifiedEmailAddresses: readonly string[] | null, emailSubject: string | null, emailBody: string | null, emailAddressesToCc: readonly string[] | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new EmailCreditNoteRequest();\n req.tenantId = tenantId;\n req.creditNoteId = creditNoteId;\n req.documentFormat = documentFormat;\n req.specifiedEmailAddresses = specifiedEmailAddresses;\n req.emailSubject = emailSubject;\n req.emailBody = emailBody;\n req.emailAddressesToCc = emailAddressesToCc;\n const extractor = null;\n return this.makeJsonRequest(\"credit/v1/emailCreditNote\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const creditService = new CreditService();","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumCustomerHappinessRating } from \"./enums/enumCustomerHappinessRating.generated\";\n\n// Model Objects\n\nexport class OutletCommunicationLogEntry extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Id of the communication log's communication subject.\n */\n public communicationSubjectId: Guid = Guid.createEmpty();\n /**\n * Id of the communication log's communication type.\n */\n public communicationTypeId: Guid = Guid.createEmpty();\n /**\n * Rating of the customer happiness.\n */\n public customerHappinessRating: EnumCustomerHappinessRating = EnumCustomerHappinessRating.neutral;\n /**\n * Description of the communication log entry.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public description: string = \"\";\n /**\n * Outlet relating to which the communication occurred.\n */\n public outletId: Guid = Guid.createEmpty();\n /**\n * Timestamp at which the communication occurred.\n */\n public timestamp: Instant = Instant.ofEpochMilli(0);\n /**\n * User who created the communication log entry.\n */\n public userId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.communicationSubjectId = Guid.fromString(jsonSerializedObject.communicationSubjectId);\n this.communicationTypeId = Guid.fromString(jsonSerializedObject.communicationTypeId);\n this.customerHappinessRating = EnumCustomerHappinessRating.getByValue(jsonSerializedObject.customerHappinessRating, this.customerHappinessRating);\n this.description = jsonSerializedObject.description;\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n this.timestamp = Instant.parse(jsonSerializedObject.timestamp);\n this.userId = Guid.fromString(jsonSerializedObject.userId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.communicationSubjectId = this.communicationSubjectId.toString();\n toRet.communicationTypeId = this.communicationTypeId.toString();\n toRet.customerHappinessRating = this.customerHappinessRating.value;\n toRet.description = this.description;\n toRet.outletId = this.outletId.toString();\n toRet.timestamp = this.timestamp.toString();\n toRet.userId = this.userId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"OutletCommunicationLogEntry.Id cannot be empty\"},\n {field: \"communicationSubjectId\", rule: (v: any) => !v.isEmpty() || \"OutletCommunicationLogEntry.CommunicationSubjectId cannot be empty\"},\n {field: \"communicationTypeId\", rule: (v: any) => !v.isEmpty() || \"OutletCommunicationLogEntry.CommunicationTypeId cannot be empty\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \"OutletCommunicationLogEntry.OutletId cannot be empty\"},\n {field: \"userId\", rule: (v: any) => !v.isEmpty() || \"OutletCommunicationLogEntry.UserId cannot be empty\"},\n ];\n}\n\n\nexport class OutletLogEntryFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _limitOutletIds: Guid[] | null = null;\n public get limitOutletIds(): Guid[] | null { return this._limitOutletIds }\n public set limitOutletIds(value: Guid[] | null) {\n this._limitOutletIds = value === undefined ? null : value;\n }\n private _limitUserIds: Guid[] | null = null;\n public get limitUserIds(): Guid[] | null { return this._limitUserIds }\n public set limitUserIds(value: Guid[] | null) {\n this._limitUserIds = value === undefined ? null : value;\n }\n private _fromTimestamp: Instant | null = null;\n /**\n * Minimum (inclusive) timestamp.\n */\n public get fromTimestamp(): Instant | null { return this._fromTimestamp }\n public set fromTimestamp(value: Instant | null) {\n this._fromTimestamp = value === undefined ? null : value;\n }\n private _toTimestamp: Instant | null = null;\n /**\n * Maximum (inclusive) timestamp.\n */\n public get toTimestamp(): Instant | null { return this._toTimestamp }\n public set toTimestamp(value: Instant | null) {\n this._toTimestamp = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.limitOutletIds = jsonSerializedObject.limitOutletIds == null ? null : jsonSerializedObject.limitOutletIds.map((v: any) => Guid.fromString(v));\n this.limitUserIds = jsonSerializedObject.limitUserIds == null ? null : jsonSerializedObject.limitUserIds.map((v: any) => Guid.fromString(v));\n this.fromTimestamp = jsonSerializedObject.fromTimestamp == null ? null : Instant.parse(jsonSerializedObject.fromTimestamp);\n this.toTimestamp = jsonSerializedObject.toTimestamp == null ? null : Instant.parse(jsonSerializedObject.toTimestamp);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.limitOutletIds = this.limitOutletIds == null ? null : this.limitOutletIds.map(v => v.toString());\n toRet.limitUserIds = this.limitUserIds == null ? null : this.limitUserIds.map(v => v.toString());\n toRet.fromTimestamp = this.fromTimestamp == null ? null : this.fromTimestamp.toString();\n toRet.toTimestamp = this.toTimestamp == null ? null : this.toTimestamp.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class FilteredOutletLogEntryResults extends ModelObject {\n\n public matchingCount: number = 0;\n public outletLogEntries: OutletCommunicationLogEntry[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.outletLogEntries = jsonSerializedObject.outletLogEntries.map((v: any) => new OutletCommunicationLogEntry(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.outletLogEntries = this.outletLogEntries.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"outletLogEntries\", rule: (v: any) => !!v || \"outletLogEntries is required\"},\n {field: \"outletLogEntries\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OutletCommunicationLogEntry[]).reduce((acc: Array, curr: OutletCommunicationLogEntry) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class AddOutletLogEntryRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n /**\n * Id of the communication log's communication subject.\n */\n public communicationSubjectId: Guid = Guid.createEmpty();\n /**\n * Id of the communication log's communication type.\n */\n public communicationTypeId: Guid = Guid.createEmpty();\n /**\n * Rating of the customer happiness.\n */\n public customerHappinessRating: EnumCustomerHappinessRating = EnumCustomerHappinessRating.neutral;\n /**\n * Description of the communication log entry.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public description: string = \"\";\n /**\n * Outlet relating to which the communication occurred.\n */\n public outletId: Guid = Guid.createEmpty();\n /**\n * User who created the communication log entry.\n */\n public userId: Guid = Guid.createEmpty();\n private _timestampIfNotDbNow: Instant | null = null;\n public get timestampIfNotDbNow(): Instant | null { return this._timestampIfNotDbNow }\n public set timestampIfNotDbNow(value: Instant | null) {\n this._timestampIfNotDbNow = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.communicationSubjectId = Guid.fromString(jsonSerializedObject.communicationSubjectId);\n this.communicationTypeId = Guid.fromString(jsonSerializedObject.communicationTypeId);\n this.customerHappinessRating = EnumCustomerHappinessRating.getByValue(jsonSerializedObject.customerHappinessRating, this.customerHappinessRating);\n this.description = jsonSerializedObject.description;\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n this.userId = Guid.fromString(jsonSerializedObject.userId);\n this.timestampIfNotDbNow = jsonSerializedObject.timestampIfNotDbNow == null ? null : Instant.parse(jsonSerializedObject.timestampIfNotDbNow);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.communicationSubjectId = this.communicationSubjectId.toString();\n toRet.communicationTypeId = this.communicationTypeId.toString();\n toRet.customerHappinessRating = this.customerHappinessRating.value;\n toRet.description = this.description;\n toRet.outletId = this.outletId.toString();\n toRet.userId = this.userId.toString();\n toRet.timestampIfNotDbNow = this.timestampIfNotDbNow == null ? null : this.timestampIfNotDbNow.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"communicationSubjectId\", rule: (v: any) => !v.isEmpty() || \".CommunicationSubjectId cannot be empty\"},\n {field: \"communicationTypeId\", rule: (v: any) => !v.isEmpty() || \".CommunicationTypeId cannot be empty\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \".OutletId cannot be empty\"},\n {field: \"userId\", rule: (v: any) => !v.isEmpty() || \".UserId cannot be empty\"},\n ];\n}\n\n\nexport class AddOutletLogEntryResponse extends ModelObject {\n\n public outletLogEntry: OutletCommunicationLogEntry = new OutletCommunicationLogEntry();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outletLogEntry = new OutletCommunicationLogEntry(jsonSerializedObject.outletLogEntry);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outletLogEntry = this.outletLogEntry.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outletLogEntry\", rule: (v: any) => !!v || \"outletLogEntry is required\"},\n {field: \"outletLogEntry\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetOutletLogEntryRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletLogEntryId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletLogEntryId = Guid.fromString(jsonSerializedObject.outletLogEntryId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletLogEntryId = this.outletLogEntryId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletLogEntryId\", rule: (v: any) => !v.isEmpty() || \".OutletLogEntryId cannot be empty\"},\n ];\n}\n\n\nexport class GetOutletLogEntryResponse extends ModelObject {\n\n public outletLogEntry: OutletCommunicationLogEntry = new OutletCommunicationLogEntry();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outletLogEntry = new OutletCommunicationLogEntry(jsonSerializedObject.outletLogEntry);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outletLogEntry = this.outletLogEntry.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outletLogEntry\", rule: (v: any) => !!v || \"outletLogEntry is required\"},\n {field: \"outletLogEntry\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetOutletLogEntriesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletLogEntryIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletLogEntryIds = jsonSerializedObject.outletLogEntryIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletLogEntryIds = this.outletLogEntryIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetOutletLogEntriesResponse extends ModelObject {\n\n public outletLogEntries: OutletCommunicationLogEntry[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outletLogEntries = jsonSerializedObject.outletLogEntries.map((v: any) => new OutletCommunicationLogEntry(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outletLogEntries = this.outletLogEntries.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outletLogEntries\", rule: (v: any) => !!v || \"outletLogEntries is required\"},\n {field: \"outletLogEntries\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OutletCommunicationLogEntry[]).reduce((acc: Array, curr: OutletCommunicationLogEntry) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetOutletLogEntriesByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: OutletLogEntryFilter = new OutletLogEntryFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new OutletLogEntryFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetOutletLogEntriesByFilterResponse extends ModelObject {\n\n public results: FilteredOutletLogEntryResults = new FilteredOutletLogEntryResults();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredOutletLogEntryResults(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class OutletCommunicationLogService extends ServiceBase {\n\n public async addOutletLogEntry(tenantId: Guid, communicationSubjectId: Guid, communicationTypeId: Guid, customerHappinessRating: EnumCustomerHappinessRating, description: string, outletId: Guid, userId: Guid, timestampIfNotDbNow: Instant | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new AddOutletLogEntryRequest();\n req.tenantId = tenantId;\n req.communicationSubjectId = communicationSubjectId;\n req.communicationTypeId = communicationTypeId;\n req.customerHappinessRating = customerHappinessRating;\n req.description = description;\n req.outletId = outletId;\n req.userId = userId;\n req.timestampIfNotDbNow = timestampIfNotDbNow;\n const extractor = (response:any) => new AddOutletLogEntryResponse(response).outletLogEntry;\n return this.makeJsonRequest(\"outletCommunicationLog/v1/addOutletLogEntry\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getOutletLogEntry(tenantId: Guid, outletLogEntryId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetOutletLogEntryRequest();\n req.tenantId = tenantId;\n req.outletLogEntryId = outletLogEntryId;\n const extractor = (response:any) => new GetOutletLogEntryResponse(response).outletLogEntry;\n return this.makeJsonRequest(\"outletCommunicationLog/v1/getOutletLogEntry\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getOutletLogEntries(tenantId: Guid, outletLogEntryIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetOutletLogEntriesRequest();\n req.tenantId = tenantId;\n req.outletLogEntryIds = outletLogEntryIds;\n const extractor = (response:any) => new GetOutletLogEntriesResponse(response).outletLogEntries;\n return this.makeJsonRequest(\"outletCommunicationLog/v1/getOutletLogEntries\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getOutletLogEntriesByFilter(tenantId: Guid, filter: OutletLogEntryFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetOutletLogEntriesByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetOutletLogEntriesByFilterResponse(response).results;\n return this.makeJsonRequest(\"outletCommunicationLog/v1/getOutletLogEntriesByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const outletCommunicationLogService = new OutletCommunicationLogService();","/**\n * Configures the menu layout.\n */\nimport type { RouteConfig } from \"vue-router\";\nimport type { Location, RoutePropsFunction } from \"vue-router/types/router\";\nimport type { VueConstructor } from \"vue\";\nimport type { EnumFeatureFlag } from \"@/app/services/generated/enums/enumFeatureFlag.generated\";\nimport type { ComponentPublicInstanceConstructor } from \"vue/types/v3-component-public-instance\";\nimport type { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport Key from \"@/app/types/common/key\";\nimport { translate } from \"@/plugins/i18n\";\n\nexport interface RouteMetadata {\n preSession?: boolean;\n helpUrl?: string;\n target?: string;\n\n // We need to use a key when parent-level components are the same, as it may cause data issues when Vue reuses the component\n // this was only noticeable on DutyAudit. Adding a key forces Vue not to re-use the component.\n key?: string;\n}\n\nexport interface IRouteItem {\n name?: string;\n // TODO - make url mandatory for routes once they are properly split from menus.\n url?: string;\n view?: () => Promise;\n routeMetadata: RouteMetadata;\n childRoutes: RouteConfig[];\n componentProps?: boolean | Record | RoutePropsFunction;\n requiredUserPermissions?: EnumUserPermission[];\n\n // TODO - Not sure what functionality this gives, should try to remove it.\n redirect?: string;\n\n // TODO - This should not be here. It is included as a small step of migrating from\n // the old menus, but should be flattened out when the available routes are evaluated\n // not included within a route.\n subMenus?: IRouteItem[];\n}\n\nexport interface IRouteWithLocation extends IRouteItem {\n location: (...params: TParams) => Location;\n}\n\ninterface RequiredMenuLeafOptions {\n url: string;\n view: () => Promise;\n}\n\ninterface MenuOptions {\n name: string;\n icon: string;\n routeMetadata: RouteMetadata;\n requiredFeatureFlag: EnumFeatureFlag;\n visible: boolean | (() => boolean);\n childRoutes: RouteConfig[];\n breadcrumbParentName: string;\n componentProps?: boolean | Record | RoutePropsFunction;\n menuComponent?: VueConstructor | ComponentPublicInstanceConstructor;\n // This is rather confusing. Code used to accept translationKey as a string, and it was generally\n // passed as a string but then looked up as a translation, which was very not type-safe on the translations\n // lookups. Hoewever, it is also used for other things, such as Vue id tags and data-qa tags so it is\n // very difficult to remove.\n // Taking small steps I have decided to introduce \"label\", which is typed as a string or Key (string being a literal)\n // so it is hopefully clearer. If label is not provided it will get populated based on the translation key\n // for backwards compatibility.\n translationKey: string;\n label: Key | string;\n requiredUserPermissions?: EnumUserPermission[];\n redirect?: string;\n}\n\nexport class MenuItem {\n public isActive: boolean = false;\n public translationKey?: string;\n private label: Key | string;\n\n public constructor(\n public name: string | undefined,\n public icon: string,\n public url?: string,\n public subMenus?: MenuItem[],\n public view?: () => Promise,\n public routeMetadata: RouteMetadata = {},\n public requiredFeatureFlag?: EnumFeatureFlag,\n public visible: boolean | (() => boolean) = true,\n public childRoutes: RouteConfig[] = [],\n public breadcrumbParentName?: string,\n public componentProps?: boolean | Record | RoutePropsFunction,\n public menuComponent?: VueConstructor | ComponentPublicInstanceConstructor,\n translationKey?: string,\n label?: Key | string,\n public requiredUserPermissions?: EnumUserPermission[],\n public redirect?: string\n ) {\n this.translationKey =\n translationKey ?? (label instanceof Key ? label.value : label);\n this.label =\n label ?? (translationKey ? Key.fromString(translationKey) : \"\");\n }\n\n public static fromOpts(opts: RequiredMenuLeafOptions & Partial) {\n return new MenuItem(\n opts.name,\n opts.icon || \"\",\n opts.url,\n undefined,\n opts.view,\n opts.routeMetadata,\n opts.requiredFeatureFlag,\n opts.visible,\n opts.childRoutes,\n opts.breadcrumbParentName,\n opts.componentProps,\n opts.menuComponent,\n opts.translationKey || opts.name,\n opts.label,\n opts.requiredUserPermissions,\n opts.redirect\n );\n }\n\n public displayText() {\n return this.label instanceof Key ? translate(this.label) : this.label;\n }\n\n public static forBranch(opts: {\n name?: string;\n icon?: string;\n subMenus: MenuItem[];\n requiredFeatureFlag?: EnumFeatureFlag;\n visible?: boolean | (() => boolean);\n menuComponent?: VueConstructor | ComponentPublicInstanceConstructor;\n translationKey?: string;\n requiredUserPermissions?: EnumUserPermission[];\n }) {\n return new MenuItem(\n opts.name,\n opts.icon || \"\",\n undefined,\n opts.subMenus,\n undefined,\n undefined,\n opts.requiredFeatureFlag,\n opts.visible,\n undefined,\n undefined,\n undefined,\n opts.menuComponent,\n opts.translationKey || opts.name,\n undefined,\n opts.requiredUserPermissions,\n undefined\n );\n }\n\n public static forRoute(\n label: Key | string,\n route: IRouteItem,\n opts?: {\n icon?: string;\n requiredFeatureFlag?: EnumFeatureFlag;\n visible?: boolean | (() => boolean);\n menuComponent?: VueConstructor | ComponentPublicInstanceConstructor;\n requiredUserPermissions?: EnumUserPermission[];\n }\n ) {\n return new MenuItem(\n route.name,\n opts?.icon || \"\",\n route.url,\n undefined,\n route.view,\n route.routeMetadata,\n opts?.requiredFeatureFlag,\n opts?.visible,\n undefined,\n undefined,\n route.componentProps,\n opts?.menuComponent,\n undefined,\n label,\n opts?.requiredUserPermissions,\n undefined\n );\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumAlcoholType } from \"./enums/enumAlcoholType.generated\";\nimport { EnumDocumentFileType } from \"./enums/enumDocumentFileType.generated\";\nimport { EnumEireMovementType } from \"./enums/enumEireMovementType.generated\";\nimport { EnumGermanBeerDutyMovementType } from \"./enums/enumGermanBeerDutyMovementType.generated\";\nimport { EnumGermanBeerDutyProductType } from \"./enums/enumGermanBeerDutyProductType.generated\";\nimport { EnumPurchaseOrderDeliveryDisbursement } from \"./enums/enumPurchaseOrderDeliveryDisbursement.generated\";\nimport { EnumPurchaseOrderDeliveryStatus } from \"./enums/enumPurchaseOrderDeliveryStatus.generated\";\nimport { EnumPurchaseOrderStatus } from \"./enums/enumPurchaseOrderStatus.generated\";\n\n// Model Objects\n\nexport class PurchaseOrderHeaderReadOnly extends ModelObject {\n\n /**\n * User who created the purchase order. Captured by system not user editable.\n */\n public createdByUserId: Guid = Guid.createEmpty();\n /**\n * DeliveryStatus : 0 = None, 1 = Partial, 2 = Full\n */\n public deliveryStatus: EnumPurchaseOrderDeliveryStatus = EnumPurchaseOrderDeliveryStatus.none;\n /**\n * Purchase Order Number\n * Not Nullable\n */\n public number: string = \"\";\n /**\n * Total Net Price of Purchase Order.\n */\n public totalNetPrice: number = 0;\n /**\n * Total VAT of Purchase Order.\n */\n public totalVat: number = 0;\n /**\n * Timestamp at which the purchase order was created on the system. Captured by system not user editable.\n */\n public createdAt: Instant = Instant.ofEpochMilli(0);\n /**\n * Description of the current error which is preventing this purchase order from being posted to accounts. Ie the error (if any) which occurred when this was last attempted to post. The presence of text in this field implies there is a known current error so posting will not be reattempted. To reattempt posting this field must be cleared.\n * Not Nullable\n * Max Length : 100000\n */\n public currentPostingError: string = \"\";\n private _cancelledAt: Instant | null = null;\n /**\n * Timestamp at which the purchase order was cancelled. (If cancelled). Captured by system not user editable.\n */\n public get cancelledAt(): Instant | null { return this._cancelledAt }\n public set cancelledAt(value: Instant | null) {\n this._cancelledAt = value === undefined ? null : value;\n }\n private _cancelledByUserId: Guid | null = null;\n /**\n * User who cancelled the purchase order. (If cancelled). Captured by system not user editable.\n */\n public get cancelledByUserId(): Guid | null { return this._cancelledByUserId }\n public set cancelledByUserId(value: Guid | null) {\n this._cancelledByUserId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.createdByUserId = Guid.fromString(jsonSerializedObject.createdByUserId);\n this.deliveryStatus = EnumPurchaseOrderDeliveryStatus.getByValue(jsonSerializedObject.deliveryStatus, this.deliveryStatus);\n this.number = jsonSerializedObject.number;\n this.totalNetPrice = jsonSerializedObject.totalNetPrice;\n this.totalVat = jsonSerializedObject.totalVat;\n this.createdAt = Instant.parse(jsonSerializedObject.createdAt);\n this.currentPostingError = jsonSerializedObject.currentPostingError;\n this.cancelledAt = jsonSerializedObject.cancelledAt == null ? null : Instant.parse(jsonSerializedObject.cancelledAt);\n this.cancelledByUserId = jsonSerializedObject.cancelledByUserId == null ? null : Guid.fromString(jsonSerializedObject.cancelledByUserId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.createdByUserId = this.createdByUserId.toString();\n toRet.deliveryStatus = this.deliveryStatus.value;\n toRet.number = this.number;\n toRet.totalNetPrice = this.totalNetPrice;\n toRet.totalVat = this.totalVat;\n toRet.createdAt = this.createdAt.toString();\n toRet.currentPostingError = this.currentPostingError;\n toRet.cancelledAt = this.cancelledAt == null ? null : this.cancelledAt.toString();\n toRet.cancelledByUserId = this.cancelledByUserId == null ? null : this.cancelledByUserId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"createdByUserId\", rule: (v: any) => !v.isEmpty() || \"PurchaseOrderHeaderReadOnly.CreatedByUserId cannot be empty\"},\n {field: \"currentPostingError\", rule: (v: any) => v == null || v.length <= 100000 || \"CurrentPostingError has too many characters (100000)\"},\n {field: \"cancelledByUserId\", rule: (v: any) => v == null || !v.isEmpty() || \"PurchaseOrderHeaderReadOnly.CancelledByUserId cannot be empty\"},\n ];\n}\n\n\nexport class PurchaseOrderHeader extends ModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * The stock location to which the goods should be delivered. This is not necessarily where the goods will be stocked, each line will identify where the goods will be placed.\n */\n public deliverToStockLocationId: Guid = Guid.createEmpty();\n /**\n * Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n /**\n * Status : 0 = Open, 1 = AwaitingConfirmation, 2 = AwaitingCompletion, 3 = Complete, 4 = Posting, 5 = Historic, 6 = Cancelled\n */\n public status: EnumPurchaseOrderStatus = EnumPurchaseOrderStatus.open;\n /**\n * The supplier this Purchase Order if for.\n */\n public supplierId: Guid = Guid.createEmpty();\n public readOnly: PurchaseOrderHeaderReadOnly = new PurchaseOrderHeaderReadOnly();\n public germanBeerDutyMovementType: EnumGermanBeerDutyMovementType = EnumGermanBeerDutyMovementType.none;\n private _expectedDeliveryDate: LocalDate | null = null;\n /**\n * Date the Purchase Order is expected to arrive (Informational only).\n */\n public get expectedDeliveryDate(): LocalDate | null { return this._expectedDeliveryDate }\n public set expectedDeliveryDate(value: LocalDate | null) {\n this._expectedDeliveryDate = value === undefined ? null : value;\n }\n public eireDutyMovementType: EnumEireMovementType = EnumEireMovementType.unknown;\n public cancellationReason: string = \"\";\n public extraDisbursementBasis: EnumPurchaseOrderDeliveryDisbursement = EnumPurchaseOrderDeliveryDisbursement.none;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.deliverToStockLocationId = Guid.fromString(jsonSerializedObject.deliverToStockLocationId);\n this.notes = jsonSerializedObject.notes;\n this.status = EnumPurchaseOrderStatus.getByValue(jsonSerializedObject.status, this.status);\n this.supplierId = Guid.fromString(jsonSerializedObject.supplierId);\n this.readOnly = new PurchaseOrderHeaderReadOnly(jsonSerializedObject.readOnly);\n this.germanBeerDutyMovementType = EnumGermanBeerDutyMovementType.getByValue(jsonSerializedObject.germanBeerDutyMovementType, this.germanBeerDutyMovementType);\n this.expectedDeliveryDate = jsonSerializedObject.expectedDeliveryDate == null ? null : LocalDate.parse(jsonSerializedObject.expectedDeliveryDate);\n this.eireDutyMovementType = EnumEireMovementType.getByValue(jsonSerializedObject.eireDutyMovementType, this.eireDutyMovementType);\n this.cancellationReason = jsonSerializedObject.cancellationReason;\n this.extraDisbursementBasis = EnumPurchaseOrderDeliveryDisbursement.getByValue(jsonSerializedObject.extraDisbursementBasis, this.extraDisbursementBasis);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.deliverToStockLocationId = this.deliverToStockLocationId.toString();\n toRet.notes = this.notes;\n toRet.status = this.status.value;\n toRet.supplierId = this.supplierId.toString();\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.germanBeerDutyMovementType = this.germanBeerDutyMovementType.value;\n toRet.expectedDeliveryDate = this.expectedDeliveryDate == null ? null : this.expectedDeliveryDate.toString();\n toRet.eireDutyMovementType = this.eireDutyMovementType.value;\n toRet.cancellationReason = this.cancellationReason;\n toRet.extraDisbursementBasis = this.extraDisbursementBasis.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"PurchaseOrderHeader.Id cannot be empty\"},\n {field: \"deliverToStockLocationId\", rule: (v: any) => !v.isEmpty() || \"PurchaseOrderHeader.DeliverToStockLocationId cannot be empty\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"supplierId\", rule: (v: any) => !v.isEmpty() || \"PurchaseOrderHeader.SupplierId cannot be empty\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"cancellationReason\", rule: (v: any) => v == null || v.length <= 100000 || \"CancellationReason has too many characters (100000)\"},\n ];\n}\n\n\nexport class PurchaseOrderLineReadOnly extends ModelObject {\n\n private _glCodeId: Guid | null = null;\n /**\n * The GlCode of the stock item. Captured at time of adding to order for future display / reports.\n */\n public get glCodeId(): Guid | null { return this._glCodeId }\n public set glCodeId(value: Guid | null) {\n this._glCodeId = value === undefined ? null : value;\n }\n /**\n * Total VAT for the Line. Calculated from the LineTotalNet and vat rate, but stored as a stamped result of when the calculation was applied.\n */\n public lineTotalVat: number = 0;\n /**\n * The purchase order id to which this line belongs.\n */\n public purchaseOrderId: Guid = Guid.createEmpty();\n /**\n * Vat Rate Percentage at time of order.\n * Not Negative\n */\n public vatPercentage: number = 0;\n /**\n * Vat Code Applicable to the line. May come from Stock Item or Supplier.\n */\n public vatCodeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.glCodeId = jsonSerializedObject.glCodeId == null ? null : Guid.fromString(jsonSerializedObject.glCodeId);\n this.lineTotalVat = jsonSerializedObject.lineTotalVat;\n this.purchaseOrderId = Guid.fromString(jsonSerializedObject.purchaseOrderId);\n this.vatPercentage = jsonSerializedObject.vatPercentage;\n this.vatCodeId = Guid.fromString(jsonSerializedObject.vatCodeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.glCodeId = this.glCodeId == null ? null : this.glCodeId.toString();\n toRet.lineTotalVat = this.lineTotalVat;\n toRet.purchaseOrderId = this.purchaseOrderId.toString();\n toRet.vatPercentage = this.vatPercentage;\n toRet.vatCodeId = this.vatCodeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"glCodeId\", rule: (v: any) => v == null || !v.isEmpty() || \"PurchaseOrderLineReadOnly.GlCodeId cannot be empty\"},\n {field: \"purchaseOrderId\", rule: (v: any) => !v.isEmpty() || \"PurchaseOrderLineReadOnly.PurchaseOrderId cannot be empty\"},\n {field: \"vatCodeId\", rule: (v: any) => !v.isEmpty() || \"PurchaseOrderLineReadOnly.VatCodeId cannot be empty\"},\n ];\n}\n\n\nexport class PurchaseOrderLine extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * The stock location where the goods will be placed in stock. This is not necessarily where the goods will be delivered, as goods may be recieved at one location but placed into stock at another.\n */\n public destinationStockLocationId: Guid = Guid.createEmpty();\n /**\n * Quantity being ordered.\n */\n public quantity: number = 0;\n /**\n * The stock item being purchased.\n */\n public stockItemId: Guid = Guid.createEmpty();\n /**\n * Total Net Price of the Line.\n */\n public lineTotalNet: number = 0;\n /**\n * The Unit Of Measure of the quantity (from stock item).\n */\n public unitOfMeasureId: Guid = Guid.createEmpty();\n public readOnly: PurchaseOrderLineReadOnly = new PurchaseOrderLineReadOnly();\n /**\n * Item Abv. Used largely in duty calculations.\n * Not Negative\n * Maximum : 100\n */\n public abv: number = 0;\n /**\n * Alcohol Type. Used largely in duty calculations.\n */\n public alcoholType: EnumAlcoholType = EnumAlcoholType.none;\n private _manufacturerId: Guid | null = null;\n /**\n * Manufacturer of the product. Can affect duty (particularly Beer Duty).\n */\n public get manufacturerId(): Guid | null { return this._manufacturerId }\n public set manufacturerId(value: Guid | null) {\n this._manufacturerId = value === undefined ? null : value;\n }\n /**\n * Dutiable Litres per unit. Used largely in duty calculations.\n * Not Negative\n */\n public unitDutiableLitres: number = 0;\n private _plato: number | null = null;\n /**\n * Plato Value\n * Not Negative\n */\n public get plato(): number | null { return this._plato }\n public set plato(value: number | null) {\n this._plato = value === undefined ? null : value;\n }\n public germanBeerDutyProductType: EnumGermanBeerDutyProductType = EnumGermanBeerDutyProductType.none;\n private _germanBeerMixedProductPercentageA: number | null = null;\n public get germanBeerMixedProductPercentageA(): number | null { return this._germanBeerMixedProductPercentageA }\n public set germanBeerMixedProductPercentageA(value: number | null) {\n this._germanBeerMixedProductPercentageA = value === undefined ? null : value;\n }\n /**\n * Stock Item Name. Stored so purchase order can be recreated. Defaults to name of product when line is added to order.\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public itemName: string = \"\";\n /**\n * Extra Cost Attributed to this line. Typically a portion of delivery charges. This cost is not charged against the line, but is considered when updating cost prices.\n */\n public attributedExtraCost: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.destinationStockLocationId = Guid.fromString(jsonSerializedObject.destinationStockLocationId);\n this.quantity = jsonSerializedObject.quantity;\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.lineTotalNet = jsonSerializedObject.lineTotalNet;\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n this.readOnly = new PurchaseOrderLineReadOnly(jsonSerializedObject.readOnly);\n this.abv = jsonSerializedObject.abv;\n this.alcoholType = EnumAlcoholType.getByValue(jsonSerializedObject.alcoholType, this.alcoholType);\n this.manufacturerId = jsonSerializedObject.manufacturerId == null ? null : Guid.fromString(jsonSerializedObject.manufacturerId);\n this.unitDutiableLitres = jsonSerializedObject.unitDutiableLitres;\n this.plato = jsonSerializedObject.plato == null ? null : jsonSerializedObject.plato;\n this.germanBeerDutyProductType = EnumGermanBeerDutyProductType.getByValue(jsonSerializedObject.germanBeerDutyProductType, this.germanBeerDutyProductType);\n this.germanBeerMixedProductPercentageA = jsonSerializedObject.germanBeerMixedProductPercentageA == null ? null : jsonSerializedObject.germanBeerMixedProductPercentageA;\n this.itemName = jsonSerializedObject.itemName;\n this.attributedExtraCost = jsonSerializedObject.attributedExtraCost;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.destinationStockLocationId = this.destinationStockLocationId.toString();\n toRet.quantity = this.quantity;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.lineTotalNet = this.lineTotalNet;\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.abv = this.abv;\n toRet.alcoholType = this.alcoholType.value;\n toRet.manufacturerId = this.manufacturerId == null ? null : this.manufacturerId.toString();\n toRet.unitDutiableLitres = this.unitDutiableLitres;\n toRet.plato = this.plato == null ? null : this.plato;\n toRet.germanBeerDutyProductType = this.germanBeerDutyProductType.value;\n toRet.germanBeerMixedProductPercentageA = this.germanBeerMixedProductPercentageA == null ? null : this.germanBeerMixedProductPercentageA;\n toRet.itemName = this.itemName;\n toRet.attributedExtraCost = this.attributedExtraCost;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"PurchaseOrderLine.Id cannot be empty\"},\n {field: \"destinationStockLocationId\", rule: (v: any) => !v.isEmpty() || \"PurchaseOrderLine.DestinationStockLocationId cannot be empty\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"PurchaseOrderLine.StockItemId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"PurchaseOrderLine.UnitOfMeasureId cannot be empty\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"manufacturerId\", rule: (v: any) => v == null || !v.isEmpty() || \"PurchaseOrderLine.ManufacturerId cannot be empty\"},\n {field: \"itemName\", rule: (v: any) => v == null || v.length !== 0 || \"ItemName cannot be empty\"},\n {field: \"itemName\", rule: (v: any) => v == null || v.length <= 1000 || \"ItemName has too many characters (1000)\"},\n ];\n}\n\n\nexport class PurchaseOrderGoodsReceivedLine extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Were the goods received in a good condition.\n */\n public isGoodCondition: boolean = false;\n /**\n * The line for which goods were received.\n */\n public purchaseOrderLineId: Guid = Guid.createEmpty();\n /**\n * Quantity being ordered.\n */\n public quantity: number = 0;\n /**\n * Date on which the goods were received.\n */\n public receivedDate: LocalDate = LocalDate.ofEpochDay(0);\n /**\n * The Stock Batch which was received.\n */\n public stockBatchId: Guid = Guid.createEmpty();\n /**\n * The Unit Of Measure of the quantity (from stock item).\n */\n public unitOfMeasureId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.isGoodCondition = jsonSerializedObject.isGoodCondition;\n this.purchaseOrderLineId = Guid.fromString(jsonSerializedObject.purchaseOrderLineId);\n this.quantity = jsonSerializedObject.quantity;\n this.receivedDate = LocalDate.parse(jsonSerializedObject.receivedDate);\n this.stockBatchId = Guid.fromString(jsonSerializedObject.stockBatchId);\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.isGoodCondition = this.isGoodCondition;\n toRet.purchaseOrderLineId = this.purchaseOrderLineId.toString();\n toRet.quantity = this.quantity;\n toRet.receivedDate = this.receivedDate.toString();\n toRet.stockBatchId = this.stockBatchId.toString();\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"PurchaseOrderGoodsReceivedLine.Id cannot be empty\"},\n {field: \"purchaseOrderLineId\", rule: (v: any) => !v.isEmpty() || \"PurchaseOrderGoodsReceivedLine.PurchaseOrderLineId cannot be empty\"},\n {field: \"stockBatchId\", rule: (v: any) => !v.isEmpty() || \"PurchaseOrderGoodsReceivedLine.StockBatchId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"PurchaseOrderGoodsReceivedLine.UnitOfMeasureId cannot be empty\"},\n ];\n}\n\n\nexport class PurchaseOrderLineWithReceipts extends ModelObject {\n\n public line: PurchaseOrderLine = new PurchaseOrderLine();\n public goodsReceivedLines: PurchaseOrderGoodsReceivedLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.line = new PurchaseOrderLine(jsonSerializedObject.line);\n this.goodsReceivedLines = jsonSerializedObject.goodsReceivedLines.map((v: any) => new PurchaseOrderGoodsReceivedLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.line = this.line.toJsonSerializedObject();\n toRet.goodsReceivedLines = this.goodsReceivedLines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"line\", rule: (v: any) => !!v || \"line is required\"},\n {field: \"line\", rule: (v: any) => v.validate()},\n {field: \"goodsReceivedLines\", rule: (v: any) => !!v || \"goodsReceivedLines is required\"},\n {field: \"goodsReceivedLines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PurchaseOrderGoodsReceivedLine[]).reduce((acc: Array, curr: PurchaseOrderGoodsReceivedLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class PurchaseOrder extends BaseModelObject {\n\n public header: PurchaseOrderHeader = new PurchaseOrderHeader();\n public lines: PurchaseOrderLineWithReceipts[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.header = new PurchaseOrderHeader(jsonSerializedObject.header);\n this.lines = jsonSerializedObject.lines.map((v: any) => new PurchaseOrderLineWithReceipts(v));\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.header = this.header.toJsonSerializedObject();\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PurchaseOrderLineWithReceipts[]).reduce((acc: Array, curr: PurchaseOrderLineWithReceipts) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class QuantityOnPurchaseOrder extends ModelObject {\n\n public stockItemId: Guid = Guid.createEmpty();\n public destinationStockLocationId: Guid = Guid.createEmpty();\n /**\n * Total quantity on orders not yet delivered. Note that this could be -ve if a purchase order has been marked as receiving more than was ordered.\n */\n public totalQuantityOutstanding: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.destinationStockLocationId = Guid.fromString(jsonSerializedObject.destinationStockLocationId);\n this.totalQuantityOutstanding = jsonSerializedObject.totalQuantityOutstanding;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.destinationStockLocationId = this.destinationStockLocationId.toString();\n toRet.totalQuantityOutstanding = this.totalQuantityOutstanding;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"QuantityOnPurchaseOrder.StockItemId cannot be empty\"},\n {field: \"destinationStockLocationId\", rule: (v: any) => !v.isEmpty() || \"QuantityOnPurchaseOrder.DestinationStockLocationId cannot be empty\"},\n ];\n}\n\n\nexport class PurchaseOrderFilterDateRange extends ModelObject {\n\n public from: LocalDate = LocalDate.ofEpochDay(0);\n public to: LocalDate = LocalDate.ofEpochDay(0);\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.from = LocalDate.parse(jsonSerializedObject.from);\n this.to = LocalDate.parse(jsonSerializedObject.to);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.from = this.from.toString();\n toRet.to = this.to.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class PurchaseOrderFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _purchaseOrderNumbers: string[] | null = null;\n public get purchaseOrderNumbers(): string[] | null { return this._purchaseOrderNumbers }\n public set purchaseOrderNumbers(value: string[] | null) {\n this._purchaseOrderNumbers = value === undefined ? null : value;\n }\n private _statuses: EnumPurchaseOrderStatus[] | null = null;\n public get statuses(): EnumPurchaseOrderStatus[] | null { return this._statuses }\n public set statuses(value: EnumPurchaseOrderStatus[] | null) {\n this._statuses = value === undefined ? null : value;\n }\n private _createdFrom: LocalDate | null = null;\n public get createdFrom(): LocalDate | null { return this._createdFrom }\n public set createdFrom(value: LocalDate | null) {\n this._createdFrom = value === undefined ? null : value;\n }\n private _createdTo: LocalDate | null = null;\n public get createdTo(): LocalDate | null { return this._createdTo }\n public set createdTo(value: LocalDate | null) {\n this._createdTo = value === undefined ? null : value;\n }\n private _expectedDeliveryDateFrom: LocalDate | null = null;\n public get expectedDeliveryDateFrom(): LocalDate | null { return this._expectedDeliveryDateFrom }\n public set expectedDeliveryDateFrom(value: LocalDate | null) {\n this._expectedDeliveryDateFrom = value === undefined ? null : value;\n }\n private _expectedDeliveryDateTo: LocalDate | null = null;\n public get expectedDeliveryDateTo(): LocalDate | null { return this._expectedDeliveryDateTo }\n public set expectedDeliveryDateTo(value: LocalDate | null) {\n this._expectedDeliveryDateTo = value === undefined ? null : value;\n }\n private _receiptWithin: PurchaseOrderFilterDateRange | null = null;\n public get receiptWithin(): PurchaseOrderFilterDateRange | null { return this._receiptWithin }\n public set receiptWithin(value: PurchaseOrderFilterDateRange | null) {\n this._receiptWithin = value === undefined ? null : value;\n }\n private _purchaseOrderIds: Guid[] | null = null;\n public get purchaseOrderIds(): Guid[] | null { return this._purchaseOrderIds }\n public set purchaseOrderIds(value: Guid[] | null) {\n this._purchaseOrderIds = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.purchaseOrderNumbers = jsonSerializedObject.purchaseOrderNumbers == null ? null : jsonSerializedObject.purchaseOrderNumbers.map((v: any) => v);\n this.statuses = jsonSerializedObject.statuses == null ? null : jsonSerializedObject.statuses.map((v: any) => EnumPurchaseOrderStatus.getByValue(v));\n this.createdFrom = jsonSerializedObject.createdFrom == null ? null : LocalDate.parse(jsonSerializedObject.createdFrom);\n this.createdTo = jsonSerializedObject.createdTo == null ? null : LocalDate.parse(jsonSerializedObject.createdTo);\n this.expectedDeliveryDateFrom = jsonSerializedObject.expectedDeliveryDateFrom == null ? null : LocalDate.parse(jsonSerializedObject.expectedDeliveryDateFrom);\n this.expectedDeliveryDateTo = jsonSerializedObject.expectedDeliveryDateTo == null ? null : LocalDate.parse(jsonSerializedObject.expectedDeliveryDateTo);\n this.receiptWithin = jsonSerializedObject.receiptWithin == null ? null : new PurchaseOrderFilterDateRange(jsonSerializedObject.receiptWithin);\n this.purchaseOrderIds = jsonSerializedObject.purchaseOrderIds == null ? null : jsonSerializedObject.purchaseOrderIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.purchaseOrderNumbers = this.purchaseOrderNumbers == null ? null : this.purchaseOrderNumbers.map(v => v);\n toRet.statuses = this.statuses == null ? null : this.statuses.map(v => v.value);\n toRet.createdFrom = this.createdFrom == null ? null : this.createdFrom.toString();\n toRet.createdTo = this.createdTo == null ? null : this.createdTo.toString();\n toRet.expectedDeliveryDateFrom = this.expectedDeliveryDateFrom == null ? null : this.expectedDeliveryDateFrom.toString();\n toRet.expectedDeliveryDateTo = this.expectedDeliveryDateTo == null ? null : this.expectedDeliveryDateTo.toString();\n toRet.receiptWithin = this.receiptWithin == null ? null : this.receiptWithin?.toJsonSerializedObject() ?? null;\n toRet.purchaseOrderIds = this.purchaseOrderIds == null ? null : this.purchaseOrderIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n {field: \"receiptWithin\", rule: (v: any) => (v === null) || v.validate()},\n ];\n}\n\n\nexport class FilteredPurchaseOrderHeaders extends ModelObject {\n\n public matchingCount: number = 0;\n public purchaseOrderHeaders: PurchaseOrderHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.purchaseOrderHeaders = jsonSerializedObject.purchaseOrderHeaders.map((v: any) => new PurchaseOrderHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.purchaseOrderHeaders = this.purchaseOrderHeaders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"purchaseOrderHeaders\", rule: (v: any) => !!v || \"purchaseOrderHeaders is required\"},\n {field: \"purchaseOrderHeaders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PurchaseOrderHeader[]).reduce((acc: Array, curr: PurchaseOrderHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class FilteredPurchaseOrders extends ModelObject {\n\n public matchingCount: number = 0;\n public purchaseOrders: PurchaseOrder[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.purchaseOrders = jsonSerializedObject.purchaseOrders.map((v: any) => new PurchaseOrder(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.purchaseOrders = this.purchaseOrders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"purchaseOrders\", rule: (v: any) => !!v || \"purchaseOrders is required\"},\n {field: \"purchaseOrders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PurchaseOrder[]).reduce((acc: Array, curr: PurchaseOrder) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class PartialPurchaseOrder extends ModelObject {\n\n public header: PurchaseOrderHeader = new PurchaseOrderHeader();\n public lines: PurchaseOrderLineWithReceipts[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.header = new PurchaseOrderHeader(jsonSerializedObject.header);\n this.lines = jsonSerializedObject.lines.map((v: any) => new PurchaseOrderLineWithReceipts(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.header = this.header.toJsonSerializedObject();\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PurchaseOrderLineWithReceipts[]).reduce((acc: Array, curr: PurchaseOrderLineWithReceipts) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllPurchaseOrderHeadersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllPurchaseOrderHeadersResponse extends ModelObject {\n\n public purchaseOrderHeaders: PurchaseOrderHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.purchaseOrderHeaders = jsonSerializedObject.purchaseOrderHeaders.map((v: any) => new PurchaseOrderHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.purchaseOrderHeaders = this.purchaseOrderHeaders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"purchaseOrderHeaders\", rule: (v: any) => !!v || \"purchaseOrderHeaders is required\"},\n {field: \"purchaseOrderHeaders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PurchaseOrderHeader[]).reduce((acc: Array, curr: PurchaseOrderHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetPurchaseOrderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public purchaseOrderId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.purchaseOrderId = Guid.fromString(jsonSerializedObject.purchaseOrderId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.purchaseOrderId = this.purchaseOrderId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"purchaseOrderId\", rule: (v: any) => !v.isEmpty() || \".PurchaseOrderId cannot be empty\"},\n ];\n}\n\n\nexport class GetPurchaseOrderResponse extends ModelObject {\n\n public purchaseOrder: PurchaseOrder = new PurchaseOrder();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.purchaseOrder = new PurchaseOrder(jsonSerializedObject.purchaseOrder);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.purchaseOrder = this.purchaseOrder.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"purchaseOrder\", rule: (v: any) => !!v || \"purchaseOrder is required\"},\n {field: \"purchaseOrder\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetPurchaseOrdersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public purchaseOrderIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.purchaseOrderIds = jsonSerializedObject.purchaseOrderIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.purchaseOrderIds = this.purchaseOrderIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetPurchaseOrdersResponse extends ModelObject {\n\n public purchaseOrder: PurchaseOrder[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.purchaseOrder = jsonSerializedObject.purchaseOrder.map((v: any) => new PurchaseOrder(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.purchaseOrder = this.purchaseOrder.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"purchaseOrder\", rule: (v: any) => !!v || \"purchaseOrder is required\"},\n {field: \"purchaseOrder\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PurchaseOrder[]).reduce((acc: Array, curr: PurchaseOrder) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SavePurchaseOrderHeaderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public header: PurchaseOrderHeader = new PurchaseOrderHeader();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.header = new PurchaseOrderHeader(jsonSerializedObject.header);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.header = this.header.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SavePurchaseOrderHeaderResponse extends ModelObject {\n\n public purchaseOrder: PurchaseOrder = new PurchaseOrder();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.purchaseOrder = new PurchaseOrder(jsonSerializedObject.purchaseOrder);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.purchaseOrder = this.purchaseOrder.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"purchaseOrder\", rule: (v: any) => !!v || \"purchaseOrder is required\"},\n {field: \"purchaseOrder\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SavePurchaseOrderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public header: PurchaseOrderHeader = new PurchaseOrderHeader();\n public lines: readonly PurchaseOrderLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.header = new PurchaseOrderHeader(jsonSerializedObject.header);\n this.lines = jsonSerializedObject.lines.map((v: any) => new PurchaseOrderLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.header = this.header.toJsonSerializedObject();\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PurchaseOrderLine[]).reduce((acc: Array, curr: PurchaseOrderLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SavePurchaseOrderResponse extends ModelObject {\n\n public purchaseOrder: PurchaseOrder = new PurchaseOrder();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.purchaseOrder = new PurchaseOrder(jsonSerializedObject.purchaseOrder);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.purchaseOrder = this.purchaseOrder.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"purchaseOrder\", rule: (v: any) => !!v || \"purchaseOrder is required\"},\n {field: \"purchaseOrder\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class AddPurchaseOrderGoodsReceivedLinesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public purchaseOrderId: Guid = Guid.createEmpty();\n public goodsReceivedLines: readonly PurchaseOrderGoodsReceivedLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.purchaseOrderId = Guid.fromString(jsonSerializedObject.purchaseOrderId);\n this.goodsReceivedLines = jsonSerializedObject.goodsReceivedLines.map((v: any) => new PurchaseOrderGoodsReceivedLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.purchaseOrderId = this.purchaseOrderId.toString();\n toRet.goodsReceivedLines = this.goodsReceivedLines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"purchaseOrderId\", rule: (v: any) => !v.isEmpty() || \".PurchaseOrderId cannot be empty\"},\n {field: \"goodsReceivedLines\", rule: (v: any) => !!v || \"goodsReceivedLines is required\"},\n {field: \"goodsReceivedLines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PurchaseOrderGoodsReceivedLine[]).reduce((acc: Array, curr: PurchaseOrderGoodsReceivedLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class AddPurchaseOrderGoodsReceivedLinesResponse extends ModelObject {\n\n public purchaseOrder: PurchaseOrder = new PurchaseOrder();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.purchaseOrder = new PurchaseOrder(jsonSerializedObject.purchaseOrder);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.purchaseOrder = this.purchaseOrder.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"purchaseOrder\", rule: (v: any) => !!v || \"purchaseOrder is required\"},\n {field: \"purchaseOrder\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class CancelPurchaseOrderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public purchaseOrderId: Guid = Guid.createEmpty();\n public cancellationReason: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.purchaseOrderId = Guid.fromString(jsonSerializedObject.purchaseOrderId);\n this.cancellationReason = jsonSerializedObject.cancellationReason;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.purchaseOrderId = this.purchaseOrderId.toString();\n toRet.cancellationReason = this.cancellationReason;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"purchaseOrderId\", rule: (v: any) => !v.isEmpty() || \".PurchaseOrderId cannot be empty\"},\n ];\n}\n\n\nexport class GeneratePurchaseOrderDocumentRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public purchaseOrderId: Guid = Guid.createEmpty();\n public documentFormat: EnumDocumentFileType = EnumDocumentFileType.pdf;\n private _documentTemplateIdOverride: Guid | null = null;\n /**\n * Used for printing specific document template on preview\n */\n public get documentTemplateIdOverride(): Guid | null { return this._documentTemplateIdOverride }\n public set documentTemplateIdOverride(value: Guid | null) {\n this._documentTemplateIdOverride = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.purchaseOrderId = Guid.fromString(jsonSerializedObject.purchaseOrderId);\n this.documentFormat = EnumDocumentFileType.getByValue(jsonSerializedObject.documentFormat, this.documentFormat);\n this.documentTemplateIdOverride = jsonSerializedObject.documentTemplateIdOverride == null ? null : Guid.fromString(jsonSerializedObject.documentTemplateIdOverride);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.purchaseOrderId = this.purchaseOrderId.toString();\n toRet.documentFormat = this.documentFormat.value;\n toRet.documentTemplateIdOverride = this.documentTemplateIdOverride == null ? null : this.documentTemplateIdOverride.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"purchaseOrderId\", rule: (v: any) => !v.isEmpty() || \".PurchaseOrderId cannot be empty\"},\n {field: \"documentTemplateIdOverride\", rule: (v: any) => v == null || !v.isEmpty() || \".DocumentTemplateIdOverride cannot be empty\"},\n ];\n}\n\n\nexport class GeneratePurchaseOrderDocumentResponse extends ModelObject {\n\n public documentBytes: Uint8Array = new Uint8Array();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.documentBytes = converters.base64ToUint8Array(jsonSerializedObject.documentBytes);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.documentBytes = converters.uint8ArrayToBase64(this.documentBytes);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class EmailPurchaseOrderDocumentRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public purchaseOrderId: Guid = Guid.createEmpty();\n public documentFormat: EnumDocumentFileType = EnumDocumentFileType.pdf;\n private _specifiedEmailAddresses: readonly string[] | null = null;\n /**\n * If not null then email will be sent to these addresses rather than the purchase order's EmailAddress\n */\n public get specifiedEmailAddresses(): readonly string[] | null { return this._specifiedEmailAddresses }\n public set specifiedEmailAddresses(value: readonly string[] | null) {\n this._specifiedEmailAddresses = value === undefined ? null : value;\n }\n private _emailSubject: string | null = null;\n /**\n * If null, the default purchase order email subject will be sent\n * Nullable\n * Preserves leading and trailing whitespce.\n */\n public get emailSubject(): string | null { return this._emailSubject }\n public set emailSubject(value: string | null) {\n this._emailSubject = value === undefined ? null : value;\n }\n private _emailBody: string | null = null;\n /**\n * If null, the default purchase order email body will be sent\n * Nullable\n * Preserves leading and trailing whitespce.\n */\n public get emailBody(): string | null { return this._emailBody }\n public set emailBody(value: string | null) {\n this._emailBody = value === undefined ? null : value;\n }\n private _emailAddressesToCc: readonly string[] | null = null;\n /**\n * If not null then email will be CC'd to these addresses\n */\n public get emailAddressesToCc(): readonly string[] | null { return this._emailAddressesToCc }\n public set emailAddressesToCc(value: readonly string[] | null) {\n this._emailAddressesToCc = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.purchaseOrderId = Guid.fromString(jsonSerializedObject.purchaseOrderId);\n this.documentFormat = EnumDocumentFileType.getByValue(jsonSerializedObject.documentFormat, this.documentFormat);\n this.specifiedEmailAddresses = jsonSerializedObject.specifiedEmailAddresses == null ? null : jsonSerializedObject.specifiedEmailAddresses.map((v: any) => v);\n this.emailSubject = jsonSerializedObject.emailSubject == null ? null : jsonSerializedObject.emailSubject;\n this.emailBody = jsonSerializedObject.emailBody == null ? null : jsonSerializedObject.emailBody;\n this.emailAddressesToCc = jsonSerializedObject.emailAddressesToCc == null ? null : jsonSerializedObject.emailAddressesToCc.map((v: any) => v);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.purchaseOrderId = this.purchaseOrderId.toString();\n toRet.documentFormat = this.documentFormat.value;\n toRet.specifiedEmailAddresses = this.specifiedEmailAddresses == null ? null : this.specifiedEmailAddresses.map(v => v);\n toRet.emailSubject = this.emailSubject == null ? null : this.emailSubject;\n toRet.emailBody = this.emailBody == null ? null : this.emailBody;\n toRet.emailAddressesToCc = this.emailAddressesToCc == null ? null : this.emailAddressesToCc.map(v => v);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"purchaseOrderId\", rule: (v: any) => !v.isEmpty() || \".PurchaseOrderId cannot be empty\"},\n ];\n}\n\n\nexport class GetQuantitiesOnPurchaseOrderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n private _limitStockItemIds: readonly Guid[] | null = null;\n public get limitStockItemIds(): readonly Guid[] | null { return this._limitStockItemIds }\n public set limitStockItemIds(value: readonly Guid[] | null) {\n this._limitStockItemIds = value === undefined ? null : value;\n }\n private _limitDestinationStockLocationIds: readonly Guid[] | null = null;\n public get limitDestinationStockLocationIds(): readonly Guid[] | null { return this._limitDestinationStockLocationIds }\n public set limitDestinationStockLocationIds(value: readonly Guid[] | null) {\n this._limitDestinationStockLocationIds = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.limitStockItemIds = jsonSerializedObject.limitStockItemIds == null ? null : jsonSerializedObject.limitStockItemIds.map((v: any) => Guid.fromString(v));\n this.limitDestinationStockLocationIds = jsonSerializedObject.limitDestinationStockLocationIds == null ? null : jsonSerializedObject.limitDestinationStockLocationIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.limitStockItemIds = this.limitStockItemIds == null ? null : this.limitStockItemIds.map(v => v.toString());\n toRet.limitDestinationStockLocationIds = this.limitDestinationStockLocationIds == null ? null : this.limitDestinationStockLocationIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetQuantitiesOnPurchaseOrderResponse extends ModelObject {\n\n public results: QuantityOnPurchaseOrder[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new QuantityOnPurchaseOrder(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as QuantityOnPurchaseOrder[]).reduce((acc: Array, curr: QuantityOnPurchaseOrder) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetPurchaseOrderHeadersByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: PurchaseOrderFilter = new PurchaseOrderFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new PurchaseOrderFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetPurchaseOrderHeadersByFilterResponse extends ModelObject {\n\n public results: FilteredPurchaseOrderHeaders = new FilteredPurchaseOrderHeaders();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredPurchaseOrderHeaders(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetPurchaseOrdersByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: PurchaseOrderFilter = new PurchaseOrderFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new PurchaseOrderFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetPurchaseOrdersByFilterResponse extends ModelObject {\n\n public results: FilteredPurchaseOrders = new FilteredPurchaseOrders();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredPurchaseOrders(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class MarkPurchaseOrdersForPostingRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public purchaseOrderIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.purchaseOrderIds = jsonSerializedObject.purchaseOrderIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.purchaseOrderIds = this.purchaseOrderIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class UnmarkPurchaseOrdersForPostingRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public purchaseOrderIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.purchaseOrderIds = jsonSerializedObject.purchaseOrderIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.purchaseOrderIds = this.purchaseOrderIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class RecordPurchaseOrderPostingResultRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public purchaseOrderId: Guid = Guid.createEmpty();\n /**\n * Error text, if any. Empty implies posting was successful.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public postingError: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.purchaseOrderId = Guid.fromString(jsonSerializedObject.purchaseOrderId);\n this.postingError = jsonSerializedObject.postingError;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.purchaseOrderId = this.purchaseOrderId.toString();\n toRet.postingError = this.postingError;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"purchaseOrderId\", rule: (v: any) => !v.isEmpty() || \".PurchaseOrderId cannot be empty\"},\n ];\n}\n\n\nexport class GetPossiblePurchaseOrderDutyLinesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public fromDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public toDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public limitedAlcoholTypes: readonly EnumAlcoholType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.fromDateInclusive = LocalDate.parse(jsonSerializedObject.fromDateInclusive);\n this.toDateInclusive = LocalDate.parse(jsonSerializedObject.toDateInclusive);\n this.limitedAlcoholTypes = jsonSerializedObject.limitedAlcoholTypes.map((v: any) => EnumAlcoholType.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.fromDateInclusive = this.fromDateInclusive.toString();\n toRet.toDateInclusive = this.toDateInclusive.toString();\n toRet.limitedAlcoholTypes = this.limitedAlcoholTypes.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetPossiblePurchaseOrderDutyLinesResponse extends ModelObject {\n\n public results: PartialPurchaseOrder[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new PartialPurchaseOrder(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PartialPurchaseOrder[]).reduce((acc: Array, curr: PartialPurchaseOrder) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class UpdatePurchaseOrderNotesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public purchaseOrderId: Guid = Guid.createEmpty();\n public notes: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.purchaseOrderId = Guid.fromString(jsonSerializedObject.purchaseOrderId);\n this.notes = jsonSerializedObject.notes;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.purchaseOrderId = this.purchaseOrderId.toString();\n toRet.notes = this.notes;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"purchaseOrderId\", rule: (v: any) => !v.isEmpty() || \".PurchaseOrderId cannot be empty\"},\n ];\n}\n\n\nexport class PurchaseOrderService extends ServiceBase {\n\n public async getAllPurchaseOrderHeaders(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllPurchaseOrderHeadersRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllPurchaseOrderHeadersResponse(response).purchaseOrderHeaders;\n return this.makeJsonRequest(\"purchaseOrder/v1/getAllPurchaseOrderHeaders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getPurchaseOrder(tenantId: Guid, purchaseOrderId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPurchaseOrderRequest();\n req.tenantId = tenantId;\n req.purchaseOrderId = purchaseOrderId;\n const extractor = (response:any) => new GetPurchaseOrderResponse(response).purchaseOrder;\n return this.makeJsonRequest(\"purchaseOrder/v1/getPurchaseOrder\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getPurchaseOrders(tenantId: Guid, purchaseOrderIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPurchaseOrdersRequest();\n req.tenantId = tenantId;\n req.purchaseOrderIds = purchaseOrderIds;\n const extractor = (response:any) => new GetPurchaseOrdersResponse(response).purchaseOrder;\n return this.makeJsonRequest(\"purchaseOrder/v1/getPurchaseOrders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async savePurchaseOrderHeader(tenantId: Guid, header: PurchaseOrderHeader, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SavePurchaseOrderHeaderRequest();\n req.tenantId = tenantId;\n req.header = header;\n const extractor = (response:any) => new SavePurchaseOrderHeaderResponse(response).purchaseOrder;\n return this.makeJsonRequest(\"purchaseOrder/v1/savePurchaseOrderHeader\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async savePurchaseOrder(tenantId: Guid, header: PurchaseOrderHeader, lines: readonly PurchaseOrderLine[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SavePurchaseOrderRequest();\n req.tenantId = tenantId;\n req.header = header;\n req.lines = lines;\n const extractor = (response:any) => new SavePurchaseOrderResponse(response).purchaseOrder;\n return this.makeJsonRequest(\"purchaseOrder/v1/savePurchaseOrder\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async addPurchaseOrderGoodsReceivedLines(tenantId: Guid, purchaseOrderId: Guid, goodsReceivedLines: readonly PurchaseOrderGoodsReceivedLine[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new AddPurchaseOrderGoodsReceivedLinesRequest();\n req.tenantId = tenantId;\n req.purchaseOrderId = purchaseOrderId;\n req.goodsReceivedLines = goodsReceivedLines;\n const extractor = (response:any) => new AddPurchaseOrderGoodsReceivedLinesResponse(response).purchaseOrder;\n return this.makeJsonRequest(\"purchaseOrder/v1/addPurchaseOrderGoodsReceivedLines\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async cancelPurchaseOrder(tenantId: Guid, purchaseOrderId: Guid, cancellationReason: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CancelPurchaseOrderRequest();\n req.tenantId = tenantId;\n req.purchaseOrderId = purchaseOrderId;\n req.cancellationReason = cancellationReason;\n const extractor = null;\n return this.makeJsonRequest(\"purchaseOrder/v1/cancelPurchaseOrder\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async generatePurchaseOrderDocument(tenantId: Guid, purchaseOrderId: Guid, documentFormat: EnumDocumentFileType, documentTemplateIdOverride: Guid | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GeneratePurchaseOrderDocumentRequest();\n req.tenantId = tenantId;\n req.purchaseOrderId = purchaseOrderId;\n req.documentFormat = documentFormat;\n req.documentTemplateIdOverride = documentTemplateIdOverride;\n const extractor = (response:any) => new GeneratePurchaseOrderDocumentResponse(response).documentBytes;\n return this.makeJsonRequest(\"purchaseOrder/v1/generatePurchaseOrderDocument\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async emailPurchaseOrderDocument(tenantId: Guid, purchaseOrderId: Guid, documentFormat: EnumDocumentFileType, specifiedEmailAddresses: readonly string[] | null, emailSubject: string | null, emailBody: string | null, emailAddressesToCc: readonly string[] | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new EmailPurchaseOrderDocumentRequest();\n req.tenantId = tenantId;\n req.purchaseOrderId = purchaseOrderId;\n req.documentFormat = documentFormat;\n req.specifiedEmailAddresses = specifiedEmailAddresses;\n req.emailSubject = emailSubject;\n req.emailBody = emailBody;\n req.emailAddressesToCc = emailAddressesToCc;\n const extractor = null;\n return this.makeJsonRequest(\"purchaseOrder/v1/emailPurchaseOrderDocument\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getQuantitiesOnPurchaseOrder(tenantId: Guid, limitStockItemIds: readonly Guid[] | null, limitDestinationStockLocationIds: readonly Guid[] | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetQuantitiesOnPurchaseOrderRequest();\n req.tenantId = tenantId;\n req.limitStockItemIds = limitStockItemIds;\n req.limitDestinationStockLocationIds = limitDestinationStockLocationIds;\n const extractor = (response:any) => new GetQuantitiesOnPurchaseOrderResponse(response).results;\n return this.makeJsonRequest(\"purchaseOrder/v1/getQuantitiesOnPurchaseOrder\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getPurchaseOrderHeadersByFilter(tenantId: Guid, filter: PurchaseOrderFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPurchaseOrderHeadersByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetPurchaseOrderHeadersByFilterResponse(response).results;\n return this.makeJsonRequest(\"purchaseOrder/v1/getPurchaseOrderHeadersByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getPurchaseOrdersByFilter(tenantId: Guid, filter: PurchaseOrderFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPurchaseOrdersByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetPurchaseOrdersByFilterResponse(response).results;\n return this.makeJsonRequest(\"purchaseOrder/v1/getPurchaseOrdersByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async markPurchaseOrdersForPosting(tenantId: Guid, purchaseOrderIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new MarkPurchaseOrdersForPostingRequest();\n req.tenantId = tenantId;\n req.purchaseOrderIds = purchaseOrderIds;\n const extractor = null;\n return this.makeJsonRequest(\"purchaseOrder/v1/markPurchaseOrdersForPosting\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async unmarkPurchaseOrdersForPosting(tenantId: Guid, purchaseOrderIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UnmarkPurchaseOrdersForPostingRequest();\n req.tenantId = tenantId;\n req.purchaseOrderIds = purchaseOrderIds;\n const extractor = null;\n return this.makeJsonRequest(\"purchaseOrder/v1/unmarkPurchaseOrdersForPosting\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async recordPurchaseOrderPostingResult(tenantId: Guid, purchaseOrderId: Guid, postingError: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new RecordPurchaseOrderPostingResultRequest();\n req.tenantId = tenantId;\n req.purchaseOrderId = purchaseOrderId;\n req.postingError = postingError;\n const extractor = null;\n return this.makeJsonRequest(\"purchaseOrder/v1/recordPurchaseOrderPostingResult\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updatePurchaseOrderNotes(tenantId: Guid, purchaseOrderId: Guid, notes: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdatePurchaseOrderNotesRequest();\n req.tenantId = tenantId;\n req.purchaseOrderId = purchaseOrderId;\n req.notes = notes;\n const extractor = null;\n return this.makeJsonRequest(\"purchaseOrder/v1/updatePurchaseOrderNotes\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const purchaseOrderService = new PurchaseOrderService();","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumDocumentFileType } from \"./enums/enumDocumentFileType.generated\";\nimport { EnumStockTakeStatus } from \"./enums/enumStockTakeStatus.generated\";\n\n// Model Objects\n\nexport class StockTakeHeaderReadOnly extends ModelObject {\n\n private _completedAt: Instant | null = null;\n /**\n * Timestamp at which stock take was completed. (Null means not yet completed).\n */\n public get completedAt(): Instant | null { return this._completedAt }\n public set completedAt(value: Instant | null) {\n this._completedAt = value === undefined ? null : value;\n }\n /**\n * User Id of the creating user.\n */\n public createdByUserId: Guid = Guid.createEmpty();\n /**\n * Stock Take Number\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public number: string = \"\";\n /**\n * Number of lines which have a count entered by the user different to the frozen stock level, Ie requiring an adjustment.\n */\n public numberOfAdjustments: number = 0;\n /**\n * Number of lines which have a count entered by the user performing the stock take.\n */\n public numberOfEnteredCounts: number = 0;\n private _startedAt: Instant | null = null;\n /**\n * Timestamp at which stock take was started (and levels frozen). (Null means not yet started).\n */\n public get startedAt(): Instant | null { return this._startedAt }\n public set startedAt(value: Instant | null) {\n this._startedAt = value === undefined ? null : value;\n }\n /**\n * Timestamp at which the stock take was created on the system. Captured by system not user editable.\n */\n public createdAt: Instant = Instant.ofEpochMilli(0);\n private _cancelledAt: Instant | null = null;\n /**\n * Timestamp at which stock take was completed. (Null means not cancelled).\n */\n public get cancelledAt(): Instant | null { return this._cancelledAt }\n public set cancelledAt(value: Instant | null) {\n this._cancelledAt = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.completedAt = jsonSerializedObject.completedAt == null ? null : Instant.parse(jsonSerializedObject.completedAt);\n this.createdByUserId = Guid.fromString(jsonSerializedObject.createdByUserId);\n this.number = jsonSerializedObject.number;\n this.numberOfAdjustments = jsonSerializedObject.numberOfAdjustments;\n this.numberOfEnteredCounts = jsonSerializedObject.numberOfEnteredCounts;\n this.startedAt = jsonSerializedObject.startedAt == null ? null : Instant.parse(jsonSerializedObject.startedAt);\n this.createdAt = Instant.parse(jsonSerializedObject.createdAt);\n this.cancelledAt = jsonSerializedObject.cancelledAt == null ? null : Instant.parse(jsonSerializedObject.cancelledAt);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.completedAt = this.completedAt == null ? null : this.completedAt.toString();\n toRet.createdByUserId = this.createdByUserId.toString();\n toRet.number = this.number;\n toRet.numberOfAdjustments = this.numberOfAdjustments;\n toRet.numberOfEnteredCounts = this.numberOfEnteredCounts;\n toRet.startedAt = this.startedAt == null ? null : this.startedAt.toString();\n toRet.createdAt = this.createdAt.toString();\n toRet.cancelledAt = this.cancelledAt == null ? null : this.cancelledAt.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"createdByUserId\", rule: (v: any) => !v.isEmpty() || \"StockTakeHeaderReadOnly.CreatedByUserId cannot be empty\"},\n {field: \"numberOfAdjustments\", rule: (v: any) => v == null || v >= -2147483648 || \"NumberOfAdjustments is not greater than minimum allowed value: -2147483648\"},\n {field: \"numberOfAdjustments\", rule: (v: any) => v == null || v <= 2147483647 || \"NumberOfAdjustments is above maximum allowed value: 2147483647\"},\n {field: \"numberOfEnteredCounts\", rule: (v: any) => v == null || v >= -2147483648 || \"NumberOfEnteredCounts is not greater than minimum allowed value: -2147483648\"},\n {field: \"numberOfEnteredCounts\", rule: (v: any) => v == null || v <= 2147483647 || \"NumberOfEnteredCounts is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class StockTakeHeaderCalculated extends ModelObject {\n\n public status: EnumStockTakeStatus = EnumStockTakeStatus.none;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.status = EnumStockTakeStatus.getByValue(jsonSerializedObject.status, this.status);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.status = this.status.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class StockTakeHeader extends ModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Include Materials in the stock take. (Either this or IncludeProducts or both should be true).\n */\n public includeMaterials: boolean = false;\n /**\n * Include Products in the stock take. (Either this or IncludeMaterials or both should be true).\n */\n public includeProducts: boolean = false;\n /**\n * Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n private _stockGroupIds: Guid[] | null = null;\n /**\n * Ids of the stock group being counted, if stock take is being done for limited stock groups.\n */\n public get stockGroupIds(): Guid[] | null { return this._stockGroupIds }\n public set stockGroupIds(value: Guid[] | null) {\n this._stockGroupIds = value === undefined ? null : value;\n }\n /**\n * Id of the stock location where stock is being counted.\n */\n public stockLocationId: Guid = Guid.createEmpty();\n private _supplierIds: Guid[] | null = null;\n /**\n * Ids of the suppliers whose stock items are being counted, if stock take is being done for limited suppliers.\n */\n public get supplierIds(): Guid[] | null { return this._supplierIds }\n public set supplierIds(value: Guid[] | null) {\n this._supplierIds = value === undefined ? null : value;\n }\n public readOnly: StockTakeHeaderReadOnly = new StockTakeHeaderReadOnly();\n /**\n * Reason\n * Not Nullable\n * Max Length : 100000\n */\n public reason: string = \"\";\n public calculated: StockTakeHeaderCalculated = new StockTakeHeaderCalculated();\n /**\n * Include stock items with zero quantity in the stock take.\n */\n public includeQuantitiesOfZero: boolean = false;\n /**\n * Include stock items with negative quantities in the stock take.\n */\n public includeNegativeQuantities: boolean = false;\n /**\n * Include stock items which are hidden in the stock take.\n */\n public includeHiddenItems: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.includeMaterials = jsonSerializedObject.includeMaterials;\n this.includeProducts = jsonSerializedObject.includeProducts;\n this.notes = jsonSerializedObject.notes;\n this.stockGroupIds = jsonSerializedObject.stockGroupIds == null ? null : jsonSerializedObject.stockGroupIds.map((v: any) => Guid.fromString(v));\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.supplierIds = jsonSerializedObject.supplierIds == null ? null : jsonSerializedObject.supplierIds.map((v: any) => Guid.fromString(v));\n this.readOnly = new StockTakeHeaderReadOnly(jsonSerializedObject.readOnly);\n this.reason = jsonSerializedObject.reason;\n this.calculated = new StockTakeHeaderCalculated(jsonSerializedObject.calculated);\n this.includeQuantitiesOfZero = jsonSerializedObject.includeQuantitiesOfZero;\n this.includeNegativeQuantities = jsonSerializedObject.includeNegativeQuantities;\n this.includeHiddenItems = jsonSerializedObject.includeHiddenItems;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.includeMaterials = this.includeMaterials;\n toRet.includeProducts = this.includeProducts;\n toRet.notes = this.notes;\n toRet.stockGroupIds = this.stockGroupIds == null ? null : this.stockGroupIds.map(v => v.toString());\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.supplierIds = this.supplierIds == null ? null : this.supplierIds.map(v => v.toString());\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.reason = this.reason;\n toRet.calculated = this.calculated.toJsonSerializedObject();\n toRet.includeQuantitiesOfZero = this.includeQuantitiesOfZero;\n toRet.includeNegativeQuantities = this.includeNegativeQuantities;\n toRet.includeHiddenItems = this.includeHiddenItems;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"StockTakeHeader.Id cannot be empty\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \"StockTakeHeader.StockLocationId cannot be empty\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"reason\", rule: (v: any) => v == null || v.length <= 100000 || \"Reason has too many characters (100000)\"},\n {field: \"calculated\", rule: (v: any) => !!v || \"calculated is required\"},\n {field: \"calculated\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class StockTakeLineReadOnly extends ModelObject {\n\n /**\n * Quantity BrewMan believed was in stock at the time stock count was started.\n */\n public frozenStockLevel: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.frozenStockLevel = jsonSerializedObject.frozenStockLevel;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.frozenStockLevel = this.frozenStockLevel;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class StockTakeLine extends ModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Stock Take to which this line belongs.\n */\n public stockTakeId: Guid = Guid.createEmpty();\n private _countedStockLevel: number | null = null;\n /**\n * Quantity Counted as physically in stock at the time stock count was started, adjusted for any movements which had not been processed in BrewMan by that time.\n */\n public get countedStockLevel(): number | null { return this._countedStockLevel }\n public set countedStockLevel(value: number | null) {\n this._countedStockLevel = value === undefined ? null : value;\n }\n /**\n * Batch of stock which is counted by this line.\n */\n public stockBatchId: Guid = Guid.createEmpty();\n /**\n * Unit of measure in which this line is counting. Taken from the stock item.\n */\n public unitOfMeasureId: Guid = Guid.createEmpty();\n public readOnly: StockTakeLineReadOnly = new StockTakeLineReadOnly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.stockTakeId = Guid.fromString(jsonSerializedObject.stockTakeId);\n this.countedStockLevel = jsonSerializedObject.countedStockLevel == null ? null : jsonSerializedObject.countedStockLevel;\n this.stockBatchId = Guid.fromString(jsonSerializedObject.stockBatchId);\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n this.readOnly = new StockTakeLineReadOnly(jsonSerializedObject.readOnly);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.stockTakeId = this.stockTakeId.toString();\n toRet.countedStockLevel = this.countedStockLevel == null ? null : this.countedStockLevel;\n toRet.stockBatchId = this.stockBatchId.toString();\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"StockTakeLine.Id cannot be empty\"},\n {field: \"stockTakeId\", rule: (v: any) => !v.isEmpty() || \"StockTakeLine.StockTakeId cannot be empty\"},\n {field: \"stockBatchId\", rule: (v: any) => !v.isEmpty() || \"StockTakeLine.StockBatchId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"StockTakeLine.UnitOfMeasureId cannot be empty\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class StockTake extends BaseModelObject {\n\n public header: StockTakeHeader = new StockTakeHeader();\n public lines: StockTakeLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.header = new StockTakeHeader(jsonSerializedObject.header);\n this.lines = jsonSerializedObject.lines.map((v: any) => new StockTakeLine(v));\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.header = this.header.toJsonSerializedObject();\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockTakeLine[]).reduce((acc: Array, curr: StockTakeLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class StockTakeFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _stockLocationIds: Guid[] | null = null;\n public get stockLocationIds(): Guid[] | null { return this._stockLocationIds }\n public set stockLocationIds(value: Guid[] | null) {\n this._stockLocationIds = value === undefined ? null : value;\n }\n private _completedFrom: LocalDate | null = null;\n public get completedFrom(): LocalDate | null { return this._completedFrom }\n public set completedFrom(value: LocalDate | null) {\n this._completedFrom = value === undefined ? null : value;\n }\n private _completedTo: LocalDate | null = null;\n public get completedTo(): LocalDate | null { return this._completedTo }\n public set completedTo(value: LocalDate | null) {\n this._completedTo = value === undefined ? null : value;\n }\n private _statuses: EnumStockTakeStatus[] | null = null;\n public get statuses(): EnumStockTakeStatus[] | null { return this._statuses }\n public set statuses(value: EnumStockTakeStatus[] | null) {\n this._statuses = value === undefined ? null : value;\n }\n private _stockTakeIds: Guid[] | null = null;\n public get stockTakeIds(): Guid[] | null { return this._stockTakeIds }\n public set stockTakeIds(value: Guid[] | null) {\n this._stockTakeIds = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.stockLocationIds = jsonSerializedObject.stockLocationIds == null ? null : jsonSerializedObject.stockLocationIds.map((v: any) => Guid.fromString(v));\n this.completedFrom = jsonSerializedObject.completedFrom == null ? null : LocalDate.parse(jsonSerializedObject.completedFrom);\n this.completedTo = jsonSerializedObject.completedTo == null ? null : LocalDate.parse(jsonSerializedObject.completedTo);\n this.statuses = jsonSerializedObject.statuses == null ? null : jsonSerializedObject.statuses.map((v: any) => EnumStockTakeStatus.getByValue(v));\n this.stockTakeIds = jsonSerializedObject.stockTakeIds == null ? null : jsonSerializedObject.stockTakeIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.stockLocationIds = this.stockLocationIds == null ? null : this.stockLocationIds.map(v => v.toString());\n toRet.completedFrom = this.completedFrom == null ? null : this.completedFrom.toString();\n toRet.completedTo = this.completedTo == null ? null : this.completedTo.toString();\n toRet.statuses = this.statuses == null ? null : this.statuses.map(v => v.value);\n toRet.stockTakeIds = this.stockTakeIds == null ? null : this.stockTakeIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class FilteredStockTakeHeaders extends ModelObject {\n\n public matchingCount: number = 0;\n public stockTakeHeaders: StockTakeHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.stockTakeHeaders = jsonSerializedObject.stockTakeHeaders.map((v: any) => new StockTakeHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.stockTakeHeaders = this.stockTakeHeaders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"stockTakeHeaders\", rule: (v: any) => !!v || \"stockTakeHeaders is required\"},\n {field: \"stockTakeHeaders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockTakeHeader[]).reduce((acc: Array, curr: StockTakeHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class FilteredStockTakes extends ModelObject {\n\n public matchingCount: number = 0;\n public stockTakes: StockTake[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.stockTakes = jsonSerializedObject.stockTakes.map((v: any) => new StockTake(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.stockTakes = this.stockTakes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"stockTakes\", rule: (v: any) => !!v || \"stockTakes is required\"},\n {field: \"stockTakes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockTake[]).reduce((acc: Array, curr: StockTake) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveStockTakeHeaderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public header: StockTakeHeader = new StockTakeHeader();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.header = new StockTakeHeader(jsonSerializedObject.header);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.header = this.header.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveStockTakeHeaderResponse extends ModelObject {\n\n public stockTake: StockTake = new StockTake();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockTake = new StockTake(jsonSerializedObject.stockTake);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockTake = this.stockTake.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockTake\", rule: (v: any) => !!v || \"stockTake is required\"},\n {field: \"stockTake\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveStockTakeLinesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockTakeId: Guid = Guid.createEmpty();\n public lines: readonly StockTakeLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockTakeId = Guid.fromString(jsonSerializedObject.stockTakeId);\n this.lines = jsonSerializedObject.lines.map((v: any) => new StockTakeLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockTakeId = this.stockTakeId.toString();\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockTakeId\", rule: (v: any) => !v.isEmpty() || \".StockTakeId cannot be empty\"},\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockTakeLine[]).reduce((acc: Array, curr: StockTakeLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveStockTakeLinesResponse extends ModelObject {\n\n public stockTake: StockTake = new StockTake();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockTake = new StockTake(jsonSerializedObject.stockTake);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockTake = this.stockTake.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockTake\", rule: (v: any) => !!v || \"stockTake is required\"},\n {field: \"stockTake\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetStockTakeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockTakeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockTakeId = Guid.fromString(jsonSerializedObject.stockTakeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockTakeId = this.stockTakeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockTakeId\", rule: (v: any) => !v.isEmpty() || \".StockTakeId cannot be empty\"},\n ];\n}\n\n\nexport class GetStockTakeResponse extends ModelObject {\n\n public stockTake: StockTake = new StockTake();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockTake = new StockTake(jsonSerializedObject.stockTake);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockTake = this.stockTake.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockTake\", rule: (v: any) => !!v || \"stockTake is required\"},\n {field: \"stockTake\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetStockTakesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockTakeIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockTakeIds = jsonSerializedObject.stockTakeIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockTakeIds = this.stockTakeIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetStockTakesResponse extends ModelObject {\n\n public stockTakes: StockTake[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockTakes = jsonSerializedObject.stockTakes.map((v: any) => new StockTake(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockTakes = this.stockTakes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockTakes\", rule: (v: any) => !!v || \"stockTakes is required\"},\n {field: \"stockTakes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockTake[]).reduce((acc: Array, curr: StockTake) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllStockTakeHeadersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllStockTakeHeadersResponse extends ModelObject {\n\n public headers: StockTakeHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.headers = jsonSerializedObject.headers.map((v: any) => new StockTakeHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.headers = this.headers.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"headers\", rule: (v: any) => !!v || \"headers is required\"},\n {field: \"headers\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockTakeHeader[]).reduce((acc: Array, curr: StockTakeHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class CancelStockTakeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockTakeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockTakeId = Guid.fromString(jsonSerializedObject.stockTakeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockTakeId = this.stockTakeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockTakeId\", rule: (v: any) => !v.isEmpty() || \".StockTakeId cannot be empty\"},\n ];\n}\n\n\nexport class StartStockTakeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockTakeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockTakeId = Guid.fromString(jsonSerializedObject.stockTakeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockTakeId = this.stockTakeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockTakeId\", rule: (v: any) => !v.isEmpty() || \".StockTakeId cannot be empty\"},\n ];\n}\n\n\nexport class StartStockTakeResponse extends ModelObject {\n\n public stockTake: StockTake = new StockTake();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockTake = new StockTake(jsonSerializedObject.stockTake);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockTake = this.stockTake.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockTake\", rule: (v: any) => !!v || \"stockTake is required\"},\n {field: \"stockTake\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class CompleteStockTakeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockTakeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockTakeId = Guid.fromString(jsonSerializedObject.stockTakeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockTakeId = this.stockTakeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockTakeId\", rule: (v: any) => !v.isEmpty() || \".StockTakeId cannot be empty\"},\n ];\n}\n\n\nexport class GenerateStockTakeSheetRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public documentFormat: EnumDocumentFileType = EnumDocumentFileType.pdf;\n public stockTakeId: Guid = Guid.createEmpty();\n public documentTemplateId: Guid = Guid.createEmpty();\n public quantity: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.documentFormat = EnumDocumentFileType.getByValue(jsonSerializedObject.documentFormat, this.documentFormat);\n this.stockTakeId = Guid.fromString(jsonSerializedObject.stockTakeId);\n this.documentTemplateId = Guid.fromString(jsonSerializedObject.documentTemplateId);\n this.quantity = jsonSerializedObject.quantity;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.documentFormat = this.documentFormat.value;\n toRet.stockTakeId = this.stockTakeId.toString();\n toRet.documentTemplateId = this.documentTemplateId.toString();\n toRet.quantity = this.quantity;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockTakeId\", rule: (v: any) => !v.isEmpty() || \".StockTakeId cannot be empty\"},\n {field: \"documentTemplateId\", rule: (v: any) => !v.isEmpty() || \".DocumentTemplateId cannot be empty\"},\n {field: \"quantity\", rule: (v: any) => v == null || v >= -2147483648 || \"Quantity is not greater than minimum allowed value: -2147483648\"},\n {field: \"quantity\", rule: (v: any) => v == null || v <= 2147483647 || \"Quantity is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class GenerateStockTakeSheetResponse extends ModelObject {\n\n public documentBytes: Uint8Array = new Uint8Array();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.documentBytes = converters.base64ToUint8Array(jsonSerializedObject.documentBytes);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.documentBytes = converters.uint8ArrayToBase64(this.documentBytes);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GetStockTakeHeadersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockTakeIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockTakeIds = jsonSerializedObject.stockTakeIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockTakeIds = this.stockTakeIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetStockTakeHeadersResponse extends ModelObject {\n\n public headers: StockTakeHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.headers = jsonSerializedObject.headers.map((v: any) => new StockTakeHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.headers = this.headers.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"headers\", rule: (v: any) => !!v || \"headers is required\"},\n {field: \"headers\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockTakeHeader[]).reduce((acc: Array, curr: StockTakeHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetStockTakeHeadersByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: StockTakeFilter = new StockTakeFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new StockTakeFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetStockTakeHeadersByFilterResponse extends ModelObject {\n\n public results: FilteredStockTakeHeaders = new FilteredStockTakeHeaders();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredStockTakeHeaders(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetStockTakesByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: StockTakeFilter = new StockTakeFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new StockTakeFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetStockTakesByFilterResponse extends ModelObject {\n\n public results: FilteredStockTakes = new FilteredStockTakes();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredStockTakes(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class StockTakeService extends ServiceBase {\n\n public async saveStockTakeHeader(tenantId: Guid, header: StockTakeHeader, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveStockTakeHeaderRequest();\n req.tenantId = tenantId;\n req.header = header;\n const extractor = (response:any) => new SaveStockTakeHeaderResponse(response).stockTake;\n return this.makeJsonRequest(\"stockTake/v1/saveStockTakeHeader\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveStockTakeLines(tenantId: Guid, stockTakeId: Guid, lines: readonly StockTakeLine[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveStockTakeLinesRequest();\n req.tenantId = tenantId;\n req.stockTakeId = stockTakeId;\n req.lines = lines;\n const extractor = (response:any) => new SaveStockTakeLinesResponse(response).stockTake;\n return this.makeJsonRequest(\"stockTake/v1/saveStockTakeLines\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getStockTake(tenantId: Guid, stockTakeId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetStockTakeRequest();\n req.tenantId = tenantId;\n req.stockTakeId = stockTakeId;\n const extractor = (response:any) => new GetStockTakeResponse(response).stockTake;\n return this.makeJsonRequest(\"stockTake/v1/getStockTake\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getStockTakes(tenantId: Guid, stockTakeIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetStockTakesRequest();\n req.tenantId = tenantId;\n req.stockTakeIds = stockTakeIds;\n const extractor = (response:any) => new GetStockTakesResponse(response).stockTakes;\n return this.makeJsonRequest(\"stockTake/v1/getStockTakes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllStockTakeHeaders(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllStockTakeHeadersRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllStockTakeHeadersResponse(response).headers;\n return this.makeJsonRequest(\"stockTake/v1/getAllStockTakeHeaders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async cancelStockTake(tenantId: Guid, stockTakeId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CancelStockTakeRequest();\n req.tenantId = tenantId;\n req.stockTakeId = stockTakeId;\n const extractor = null;\n return this.makeJsonRequest(\"stockTake/v1/cancelStockTake\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async startStockTake(tenantId: Guid, stockTakeId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new StartStockTakeRequest();\n req.tenantId = tenantId;\n req.stockTakeId = stockTakeId;\n const extractor = (response:any) => new StartStockTakeResponse(response).stockTake;\n return this.makeJsonRequest(\"stockTake/v1/startStockTake\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async completeStockTake(tenantId: Guid, stockTakeId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CompleteStockTakeRequest();\n req.tenantId = tenantId;\n req.stockTakeId = stockTakeId;\n const extractor = null;\n return this.makeJsonRequest(\"stockTake/v1/completeStockTake\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async generateStockTakeSheet(tenantId: Guid, documentFormat: EnumDocumentFileType, stockTakeId: Guid, documentTemplateId: Guid, quantity: number, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GenerateStockTakeSheetRequest();\n req.tenantId = tenantId;\n req.documentFormat = documentFormat;\n req.stockTakeId = stockTakeId;\n req.documentTemplateId = documentTemplateId;\n req.quantity = quantity;\n const extractor = (response:any) => new GenerateStockTakeSheetResponse(response).documentBytes;\n return this.makeJsonRequest(\"stockTake/v1/generateStockTakeSheet\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getStockTakeHeaders(tenantId: Guid, stockTakeIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetStockTakeHeadersRequest();\n req.tenantId = tenantId;\n req.stockTakeIds = stockTakeIds;\n const extractor = (response:any) => new GetStockTakeHeadersResponse(response).headers;\n return this.makeJsonRequest(\"stockTake/v1/getStockTakeHeaders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getStockTakeHeadersByFilter(tenantId: Guid, filter: StockTakeFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetStockTakeHeadersByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetStockTakeHeadersByFilterResponse(response).results;\n return this.makeJsonRequest(\"stockTake/v1/getStockTakeHeadersByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getStockTakesByFilter(tenantId: Guid, filter: StockTakeFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetStockTakesByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetStockTakesByFilterResponse(response).results;\n return this.makeJsonRequest(\"stockTake/v1/getStockTakesByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const stockTakeService = new StockTakeService();","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumAlcoholType } from \"./enums/enumAlcoholType.generated\";\nimport { EnumCreditType } from \"./enums/enumCreditType.generated\";\nimport { EnumUkDutyReturnType } from \"./enums/enumUkDutyReturnType.generated\";\nimport { EnumUllageReturnMethod } from \"./enums/enumUllageReturnMethod.generated\";\nimport { EnumUllageStatus } from \"./enums/enumUllageStatus.generated\";\n\n// Model Objects\n\nexport class UllageHeaderReadOnly extends ModelObject {\n\n private _completedAt: Instant | null = null;\n /**\n * Timestamp at which ullage was marked complete (if completed). Captured by system not user editable.\n */\n public get completedAt(): Instant | null { return this._completedAt }\n public set completedAt(value: Instant | null) {\n this._completedAt = value === undefined ? null : value;\n }\n /**\n * User who created the ullage. Captured by system not user editable.\n */\n public createdByUserId: Guid = Guid.createEmpty();\n /**\n * Ullage Number\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public ullageNumber: string = \"\";\n /**\n * Timestamp at which the ullage was created on the system. Captured by system not user editable.\n */\n public createdAt: Instant = Instant.ofEpochMilli(0);\n private _cancelledAt: Instant | null = null;\n /**\n * Timestamp at which the ullage was cancelled on the system (if cancelled). Captured by system not user editable.\n */\n public get cancelledAt(): Instant | null { return this._cancelledAt }\n public set cancelledAt(value: Instant | null) {\n this._cancelledAt = value === undefined ? null : value;\n }\n private _cancelledByUserId: Guid | null = null;\n /**\n * User who cancelled the ullage (if cancelled). Captured by system not user editable.\n */\n public get cancelledByUserId(): Guid | null { return this._cancelledByUserId }\n public set cancelledByUserId(value: Guid | null) {\n this._cancelledByUserId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.completedAt = jsonSerializedObject.completedAt == null ? null : Instant.parse(jsonSerializedObject.completedAt);\n this.createdByUserId = Guid.fromString(jsonSerializedObject.createdByUserId);\n this.ullageNumber = jsonSerializedObject.ullageNumber;\n this.createdAt = Instant.parse(jsonSerializedObject.createdAt);\n this.cancelledAt = jsonSerializedObject.cancelledAt == null ? null : Instant.parse(jsonSerializedObject.cancelledAt);\n this.cancelledByUserId = jsonSerializedObject.cancelledByUserId == null ? null : Guid.fromString(jsonSerializedObject.cancelledByUserId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.completedAt = this.completedAt == null ? null : this.completedAt.toString();\n toRet.createdByUserId = this.createdByUserId.toString();\n toRet.ullageNumber = this.ullageNumber;\n toRet.createdAt = this.createdAt.toString();\n toRet.cancelledAt = this.cancelledAt == null ? null : this.cancelledAt.toString();\n toRet.cancelledByUserId = this.cancelledByUserId == null ? null : this.cancelledByUserId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"createdByUserId\", rule: (v: any) => !v.isEmpty() || \"UllageHeaderReadOnly.CreatedByUserId cannot be empty\"},\n {field: \"cancelledByUserId\", rule: (v: any) => v == null || !v.isEmpty() || \"UllageHeaderReadOnly.CancelledByUserId cannot be empty\"},\n ];\n}\n\n\nexport class UllageHeader extends ModelObject {\n\n public version: number = 0;\n /**\n * Notes relating to the authorisation of a credit.\n * Not Nullable\n * Max Length : 100000\n */\n public creditAuthorisationNotes: string = \"\";\n private _creditAuthorisedByUserId: Guid | null = null;\n /**\n * User who authorised the creation of a credit for this ullage (if any).\n */\n public get creditAuthorisedByUserId(): Guid | null { return this._creditAuthorisedByUserId }\n public set creditAuthorisedByUserId(value: Guid | null) {\n this._creditAuthorisedByUserId = value === undefined ? null : value;\n }\n /**\n * Credit Type to Create. : 0 = None, 1 = CreditNoDutyReclaim, 2 = DutyOnlyReclaim, 3 = CreditWithDutyReclaim\n */\n public creditTypeToCreate: EnumCreditType = EnumCreditType.none;\n /**\n * Customer Reference\n * Not Nullable\n * Max Length : 1000\n */\n public customerReference: string = \"\";\n public id: Guid = Guid.createEmpty();\n /**\n * Number of Items reported by the outlet as being retuned.\n */\n public numberOfItemsReported: number = 0;\n /**\n * Our Reference\n * Not Nullable\n * Max Length : 1000\n */\n public ourReference: string = \"\";\n private _pickupDate: LocalDate | null = null;\n /**\n * Date on which the Ullage should be picked up. Required when ReturnMethod=Pickup\n */\n public get pickupDate(): LocalDate | null { return this._pickupDate }\n public set pickupDate(value: LocalDate | null) {\n this._pickupDate = value === undefined ? null : value;\n }\n /**\n * Notes for the driver performing Pickup.\n * Not Nullable\n * Max Length : 100000\n */\n public pickupNotesForDriver: string = \"\";\n /**\n * The expected duration required for the pickup.\n */\n public pickupStopMinutes: number = 0;\n private _pickupWindowEnd: LocalTime | null = null;\n /**\n * The end time of the Pickup window. Optional even if ReturnMethod=Pickup\n */\n public get pickupWindowEnd(): LocalTime | null { return this._pickupWindowEnd }\n public set pickupWindowEnd(value: LocalTime | null) {\n this._pickupWindowEnd = value === undefined ? null : value;\n }\n private _pickupWindowStart: LocalTime | null = null;\n /**\n * The start time of the Pickup window. Optional even if ReturnMethod=Pickup\n */\n public get pickupWindowStart(): LocalTime | null { return this._pickupWindowStart }\n public set pickupWindowStart(value: LocalTime | null) {\n this._pickupWindowStart = value === undefined ? null : value;\n }\n /**\n * Ullage Return Method : 0 = None, 1 = DriverPickup, 2 = Courier, 3 = CustomerDropOff\n */\n public returnMethod: EnumUllageReturnMethod = EnumUllageReturnMethod.none;\n /**\n * Expected Weight to be picked up.\n * Not Negative\n */\n public pickupWeightKg: number = 0;\n public readOnly: UllageHeaderReadOnly = new UllageHeaderReadOnly();\n private _originalDutyPaidDate: LocalDate | null = null;\n /**\n * Date when duty was originally paid. Null if duty was not paid (eg is being ullaged from a bonded stock location). Required for Outlet ullages and ullages from non-bonded stock locations.\n */\n public get originalDutyPaidDate(): LocalDate | null { return this._originalDutyPaidDate }\n public set originalDutyPaidDate(value: LocalDate | null) {\n this._originalDutyPaidDate = value === undefined ? null : value;\n }\n private _outletId: Guid | null = null;\n /**\n * Outlet which reported the Ullage, if this is an outlet ullage.\n */\n public get outletId(): Guid | null { return this._outletId }\n public set outletId(value: Guid | null) {\n this._outletId = value === undefined ? null : value;\n }\n private _ullageFromStockLocationId: Guid | null = null;\n /**\n * Contains the stock location from which the beer is being destroyed, if this is direct destruction from stock.\n */\n public get ullageFromStockLocationId(): Guid | null { return this._ullageFromStockLocationId }\n public set ullageFromStockLocationId(value: Guid | null) {\n this._ullageFromStockLocationId = value === undefined ? null : value;\n }\n /**\n * Ullage Reason\n * Not Nullable\n * Max Length : 1000\n */\n public ullageReason: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.creditAuthorisationNotes = jsonSerializedObject.creditAuthorisationNotes;\n this.creditAuthorisedByUserId = jsonSerializedObject.creditAuthorisedByUserId == null ? null : Guid.fromString(jsonSerializedObject.creditAuthorisedByUserId);\n this.creditTypeToCreate = EnumCreditType.getByValue(jsonSerializedObject.creditTypeToCreate, this.creditTypeToCreate);\n this.customerReference = jsonSerializedObject.customerReference;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.numberOfItemsReported = jsonSerializedObject.numberOfItemsReported;\n this.ourReference = jsonSerializedObject.ourReference;\n this.pickupDate = jsonSerializedObject.pickupDate == null ? null : LocalDate.parse(jsonSerializedObject.pickupDate);\n this.pickupNotesForDriver = jsonSerializedObject.pickupNotesForDriver;\n this.pickupStopMinutes = jsonSerializedObject.pickupStopMinutes;\n this.pickupWindowEnd = jsonSerializedObject.pickupWindowEnd == null ? null : LocalTime.parse(jsonSerializedObject.pickupWindowEnd);\n this.pickupWindowStart = jsonSerializedObject.pickupWindowStart == null ? null : LocalTime.parse(jsonSerializedObject.pickupWindowStart);\n this.returnMethod = EnumUllageReturnMethod.getByValue(jsonSerializedObject.returnMethod, this.returnMethod);\n this.pickupWeightKg = jsonSerializedObject.pickupWeightKg;\n this.readOnly = new UllageHeaderReadOnly(jsonSerializedObject.readOnly);\n this.originalDutyPaidDate = jsonSerializedObject.originalDutyPaidDate == null ? null : LocalDate.parse(jsonSerializedObject.originalDutyPaidDate);\n this.outletId = jsonSerializedObject.outletId == null ? null : Guid.fromString(jsonSerializedObject.outletId);\n this.ullageFromStockLocationId = jsonSerializedObject.ullageFromStockLocationId == null ? null : Guid.fromString(jsonSerializedObject.ullageFromStockLocationId);\n this.ullageReason = jsonSerializedObject.ullageReason;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.creditAuthorisationNotes = this.creditAuthorisationNotes;\n toRet.creditAuthorisedByUserId = this.creditAuthorisedByUserId == null ? null : this.creditAuthorisedByUserId.toString();\n toRet.creditTypeToCreate = this.creditTypeToCreate.value;\n toRet.customerReference = this.customerReference;\n toRet.id = this.id.toString();\n toRet.numberOfItemsReported = this.numberOfItemsReported;\n toRet.ourReference = this.ourReference;\n toRet.pickupDate = this.pickupDate == null ? null : this.pickupDate.toString();\n toRet.pickupNotesForDriver = this.pickupNotesForDriver;\n toRet.pickupStopMinutes = this.pickupStopMinutes;\n toRet.pickupWindowEnd = this.pickupWindowEnd == null ? null : this.pickupWindowEnd.toString();\n toRet.pickupWindowStart = this.pickupWindowStart == null ? null : this.pickupWindowStart.toString();\n toRet.returnMethod = this.returnMethod.value;\n toRet.pickupWeightKg = this.pickupWeightKg;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.originalDutyPaidDate = this.originalDutyPaidDate == null ? null : this.originalDutyPaidDate.toString();\n toRet.outletId = this.outletId == null ? null : this.outletId.toString();\n toRet.ullageFromStockLocationId = this.ullageFromStockLocationId == null ? null : this.ullageFromStockLocationId.toString();\n toRet.ullageReason = this.ullageReason;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"creditAuthorisationNotes\", rule: (v: any) => v == null || v.length <= 100000 || \"CreditAuthorisationNotes has too many characters (100000)\"},\n {field: \"creditAuthorisedByUserId\", rule: (v: any) => v == null || !v.isEmpty() || \"UllageHeader.CreditAuthorisedByUserId cannot be empty\"},\n {field: \"customerReference\", rule: (v: any) => v == null || v.length <= 1000 || \"CustomerReference has too many characters (1000)\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"UllageHeader.Id cannot be empty\"},\n {field: \"numberOfItemsReported\", rule: (v: any) => v == null || v >= -2147483648 || \"NumberOfItemsReported is not greater than minimum allowed value: -2147483648\"},\n {field: \"numberOfItemsReported\", rule: (v: any) => v == null || v <= 2147483647 || \"NumberOfItemsReported is above maximum allowed value: 2147483647\"},\n {field: \"ourReference\", rule: (v: any) => v == null || v.length <= 1000 || \"OurReference has too many characters (1000)\"},\n {field: \"pickupNotesForDriver\", rule: (v: any) => v == null || v.length <= 100000 || \"PickupNotesForDriver has too many characters (100000)\"},\n {field: \"pickupStopMinutes\", rule: (v: any) => v == null || v >= -2147483648 || \"PickupStopMinutes is not greater than minimum allowed value: -2147483648\"},\n {field: \"pickupStopMinutes\", rule: (v: any) => v == null || v <= 2147483647 || \"PickupStopMinutes is above maximum allowed value: 2147483647\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"outletId\", rule: (v: any) => v == null || !v.isEmpty() || \"UllageHeader.OutletId cannot be empty\"},\n {field: \"ullageFromStockLocationId\", rule: (v: any) => v == null || !v.isEmpty() || \"UllageHeader.UllageFromStockLocationId cannot be empty\"},\n {field: \"ullageReason\", rule: (v: any) => v == null || v.length <= 1000 || \"UllageReason has too many characters (1000)\"},\n ];\n}\n\n\nexport class UllageLineReadOnly extends ModelObject {\n\n private _spoiltClaimDutyReturnId: Guid | null = null;\n /**\n * Spoilt Beer Return Id\n */\n public get spoiltClaimDutyReturnId(): Guid | null { return this._spoiltClaimDutyReturnId }\n public set spoiltClaimDutyReturnId(value: Guid | null) {\n this._spoiltClaimDutyReturnId = value === undefined ? null : value;\n }\n /**\n * Duty Type of the SpoiltClaimDutyReturnId\n */\n public spoiltClaimDutyReturnType: EnumUkDutyReturnType = EnumUkDutyReturnType.none;\n private _manufacturerId: Guid | null = null;\n /**\n * Manufacturer of the product - Required for Uk Beer Duty products.\n */\n public get manufacturerId(): Guid | null { return this._manufacturerId }\n public set manufacturerId(value: Guid | null) {\n this._manufacturerId = value === undefined ? null : value;\n }\n /**\n * Dutiable Volume (litres) of a single unit of this product\n * Not Negative\n */\n public unitDutiableLitres: number = 0;\n private _unitLitres: number | null = null;\n /**\n * Volume (litres) of a single unit of this product, if known. Ullage cannot be processed if not known.\n * Not Negative\n */\n public get unitLitres(): number | null { return this._unitLitres }\n public set unitLitres(value: number | null) {\n this._unitLitres = value === undefined ? null : value;\n }\n /**\n * Header to which this line belongs.\n */\n public ullageHeaderId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.spoiltClaimDutyReturnId = jsonSerializedObject.spoiltClaimDutyReturnId == null ? null : Guid.fromString(jsonSerializedObject.spoiltClaimDutyReturnId);\n this.spoiltClaimDutyReturnType = EnumUkDutyReturnType.getByValue(jsonSerializedObject.spoiltClaimDutyReturnType, this.spoiltClaimDutyReturnType);\n this.manufacturerId = jsonSerializedObject.manufacturerId == null ? null : Guid.fromString(jsonSerializedObject.manufacturerId);\n this.unitDutiableLitres = jsonSerializedObject.unitDutiableLitres;\n this.unitLitres = jsonSerializedObject.unitLitres == null ? null : jsonSerializedObject.unitLitres;\n this.ullageHeaderId = Guid.fromString(jsonSerializedObject.ullageHeaderId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.spoiltClaimDutyReturnId = this.spoiltClaimDutyReturnId == null ? null : this.spoiltClaimDutyReturnId.toString();\n toRet.spoiltClaimDutyReturnType = this.spoiltClaimDutyReturnType.value;\n toRet.manufacturerId = this.manufacturerId == null ? null : this.manufacturerId.toString();\n toRet.unitDutiableLitres = this.unitDutiableLitres;\n toRet.unitLitres = this.unitLitres == null ? null : this.unitLitres;\n toRet.ullageHeaderId = this.ullageHeaderId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"spoiltClaimDutyReturnId\", rule: (v: any) => v == null || !v.isEmpty() || \"UllageLineReadOnly.SpoiltClaimDutyReturnId cannot be empty\"},\n {field: \"manufacturerId\", rule: (v: any) => v == null || !v.isEmpty() || \"UllageLineReadOnly.ManufacturerId cannot be empty\"},\n {field: \"ullageHeaderId\", rule: (v: any) => !v.isEmpty() || \"UllageLineReadOnly.UllageHeaderId cannot be empty\"},\n ];\n}\n\n\nexport class UllageLine extends BaseModelObject {\n\n public version: number = 0;\n /**\n * Product ABV\n * Not Negative\n */\n public abv: number = 0;\n /**\n * Alcohol Type\n */\n public alcoholType: EnumAlcoholType = EnumAlcoholType.none;\n private _containerId: Guid | null = null;\n /**\n * The trackable container (if any and known) which contains the ullaged goods.\n */\n public get containerId(): Guid | null { return this._containerId }\n public set containerId(value: Guid | null) {\n this._containerId = value === undefined ? null : value;\n }\n private _destroyedAt: Instant | null = null;\n /**\n * Timestamp at which destruction occurred.\n */\n public get destroyedAt(): Instant | null { return this._destroyedAt }\n public set destroyedAt(value: Instant | null) {\n this._destroyedAt = value === undefined ? null : value;\n }\n /**\n * Notes relating to the destruction of the spoilt goods.\n * Not Nullable\n * Max Length : 100000\n */\n public destructionNotes: string = \"\";\n public id: Guid = Guid.createEmpty();\n private _dateReturned: LocalDate | null = null;\n /**\n * Date on which the item was returned (if it has been returned).\n */\n public get dateReturned(): LocalDate | null { return this._dateReturned }\n public set dateReturned(value: LocalDate | null) {\n this._dateReturned = value === undefined ? null : value;\n }\n /**\n * Notes from production checking the container.\n * Not Nullable\n * Max Length : 100000\n */\n public productionCheck: string = \"\";\n /**\n * Product which is being ullaged.\n */\n public stockItemId: Guid = Guid.createEmpty();\n /**\n * The ullage label scanned for this returned item (if any).\n * Not Nullable\n * Max Length : 1000\n */\n public ullageLabel: string = \"\";\n /**\n * The Urn of the item being ullaged.\n * Not Nullable\n * Max Length : 1000\n */\n public urn: string = \"\";\n /**\n * Volume (litres) of spoilt liquid being Ullaged\n * Not Negative\n */\n public volumeLitres: number = 0;\n public readOnly: UllageLineReadOnly = new UllageLineReadOnly();\n /**\n * Ullage Reason if different to the header.\n * Not Nullable\n * Max Length : 1000\n */\n public ullageReason: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.abv = jsonSerializedObject.abv;\n this.alcoholType = EnumAlcoholType.getByValue(jsonSerializedObject.alcoholType, this.alcoholType);\n this.containerId = jsonSerializedObject.containerId == null ? null : Guid.fromString(jsonSerializedObject.containerId);\n this.destroyedAt = jsonSerializedObject.destroyedAt == null ? null : Instant.parse(jsonSerializedObject.destroyedAt);\n this.destructionNotes = jsonSerializedObject.destructionNotes;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.dateReturned = jsonSerializedObject.dateReturned == null ? null : LocalDate.parse(jsonSerializedObject.dateReturned);\n this.productionCheck = jsonSerializedObject.productionCheck;\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.ullageLabel = jsonSerializedObject.ullageLabel;\n this.urn = jsonSerializedObject.urn;\n this.volumeLitres = jsonSerializedObject.volumeLitres;\n this.readOnly = new UllageLineReadOnly(jsonSerializedObject.readOnly);\n this.ullageReason = jsonSerializedObject.ullageReason;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.abv = this.abv;\n toRet.alcoholType = this.alcoholType.value;\n toRet.containerId = this.containerId == null ? null : this.containerId.toString();\n toRet.destroyedAt = this.destroyedAt == null ? null : this.destroyedAt.toString();\n toRet.destructionNotes = this.destructionNotes;\n toRet.id = this.id.toString();\n toRet.dateReturned = this.dateReturned == null ? null : this.dateReturned.toString();\n toRet.productionCheck = this.productionCheck;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.ullageLabel = this.ullageLabel;\n toRet.urn = this.urn;\n toRet.volumeLitres = this.volumeLitres;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.ullageReason = this.ullageReason;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"containerId\", rule: (v: any) => v == null || !v.isEmpty() || \"UllageLine.ContainerId cannot be empty\"},\n {field: \"destructionNotes\", rule: (v: any) => v == null || v.length <= 100000 || \"DestructionNotes has too many characters (100000)\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"UllageLine.Id cannot be empty\"},\n {field: \"productionCheck\", rule: (v: any) => v == null || v.length <= 100000 || \"ProductionCheck has too many characters (100000)\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"UllageLine.StockItemId cannot be empty\"},\n {field: \"ullageLabel\", rule: (v: any) => v == null || v.length <= 1000 || \"UllageLabel has too many characters (1000)\"},\n {field: \"urn\", rule: (v: any) => v == null || v.length <= 1000 || \"Urn has too many characters (1000)\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"ullageReason\", rule: (v: any) => v == null || v.length <= 1000 || \"UllageReason has too many characters (1000)\"},\n ];\n}\n\n\nexport class Ullage extends BaseModelObject {\n\n public header: UllageHeader = new UllageHeader();\n public lines: UllageLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.header = new UllageHeader(jsonSerializedObject.header);\n this.lines = jsonSerializedObject.lines.map((v: any) => new UllageLine(v));\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.header = this.header.toJsonSerializedObject();\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as UllageLine[]).reduce((acc: Array, curr: UllageLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class UllageBulkAddItem extends ModelObject {\n\n public ullageHeaderId: Guid = Guid.createEmpty();\n public stockItemId: Guid = Guid.createEmpty();\n private _containerId: Guid | null = null;\n public get containerId(): Guid | null { return this._containerId }\n public set containerId(value: Guid | null) {\n this._containerId = value === undefined ? null : value;\n }\n private _urn: string | null = null;\n public get urn(): string | null { return this._urn }\n public set urn(value: string | null) {\n this._urn = value === undefined ? null : value;\n }\n public quantity: number = 0;\n private _ullageLabel: string | null = null;\n public get ullageLabel(): string | null { return this._ullageLabel }\n public set ullageLabel(value: string | null) {\n this._ullageLabel = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.ullageHeaderId = Guid.fromString(jsonSerializedObject.ullageHeaderId);\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.containerId = jsonSerializedObject.containerId == null ? null : Guid.fromString(jsonSerializedObject.containerId);\n this.urn = jsonSerializedObject.urn == null ? null : jsonSerializedObject.urn;\n this.quantity = jsonSerializedObject.quantity;\n this.ullageLabel = jsonSerializedObject.ullageLabel == null ? null : jsonSerializedObject.ullageLabel;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.ullageHeaderId = this.ullageHeaderId.toString();\n toRet.stockItemId = this.stockItemId.toString();\n toRet.containerId = this.containerId == null ? null : this.containerId.toString();\n toRet.urn = this.urn == null ? null : this.urn;\n toRet.quantity = this.quantity;\n toRet.ullageLabel = this.ullageLabel == null ? null : this.ullageLabel;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"ullageHeaderId\", rule: (v: any) => !v.isEmpty() || \"UllageBulkAddItem.UllageHeaderId cannot be empty\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"UllageBulkAddItem.StockItemId cannot be empty\"},\n {field: \"containerId\", rule: (v: any) => v == null || !v.isEmpty() || \"UllageBulkAddItem.ContainerId cannot be empty\"},\n ];\n}\n\n\nexport class FilteredUllagesResult extends ModelObject {\n\n public matchingCount: number = 0;\n public ullages: Ullage[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.ullages = jsonSerializedObject.ullages.map((v: any) => new Ullage(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.ullages = this.ullages.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"ullages\", rule: (v: any) => !!v || \"ullages is required\"},\n {field: \"ullages\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Ullage[]).reduce((acc: Array, curr: Ullage) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class UllageFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _fromDate: LocalDate | null = null;\n /**\n * Minimum (inclusive) ullage pickup date\n */\n public get fromDate(): LocalDate | null { return this._fromDate }\n public set fromDate(value: LocalDate | null) {\n this._fromDate = value === undefined ? null : value;\n }\n private _toDate: LocalDate | null = null;\n /**\n * Maximum (inclusive) ullage pickup date\n */\n public get toDate(): LocalDate | null { return this._toDate }\n public set toDate(value: LocalDate | null) {\n this._toDate = value === undefined ? null : value;\n }\n private _fromCreatedDate: LocalDate | null = null;\n /**\n * Minimum (inclusive) ullage created date\n */\n public get fromCreatedDate(): LocalDate | null { return this._fromCreatedDate }\n public set fromCreatedDate(value: LocalDate | null) {\n this._fromCreatedDate = value === undefined ? null : value;\n }\n private _toCreatedDate: LocalDate | null = null;\n /**\n * Maximum (inclusive) ullage created date\n */\n public get toCreatedDate(): LocalDate | null { return this._toCreatedDate }\n public set toCreatedDate(value: LocalDate | null) {\n this._toCreatedDate = value === undefined ? null : value;\n }\n private _outletIds: Guid[] | null = null;\n public get outletIds(): Guid[] | null { return this._outletIds }\n public set outletIds(value: Guid[] | null) {\n this._outletIds = value === undefined ? null : value;\n }\n private _statuses: EnumUllageStatus[] | null = null;\n public get statuses(): EnumUllageStatus[] | null { return this._statuses }\n public set statuses(value: EnumUllageStatus[] | null) {\n this._statuses = value === undefined ? null : value;\n }\n private _ullageIds: Guid[] | null = null;\n public get ullageIds(): Guid[] | null { return this._ullageIds }\n public set ullageIds(value: Guid[] | null) {\n this._ullageIds = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.fromDate = jsonSerializedObject.fromDate == null ? null : LocalDate.parse(jsonSerializedObject.fromDate);\n this.toDate = jsonSerializedObject.toDate == null ? null : LocalDate.parse(jsonSerializedObject.toDate);\n this.fromCreatedDate = jsonSerializedObject.fromCreatedDate == null ? null : LocalDate.parse(jsonSerializedObject.fromCreatedDate);\n this.toCreatedDate = jsonSerializedObject.toCreatedDate == null ? null : LocalDate.parse(jsonSerializedObject.toCreatedDate);\n this.outletIds = jsonSerializedObject.outletIds == null ? null : jsonSerializedObject.outletIds.map((v: any) => Guid.fromString(v));\n this.statuses = jsonSerializedObject.statuses == null ? null : jsonSerializedObject.statuses.map((v: any) => EnumUllageStatus.getByValue(v));\n this.ullageIds = jsonSerializedObject.ullageIds == null ? null : jsonSerializedObject.ullageIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.fromDate = this.fromDate == null ? null : this.fromDate.toString();\n toRet.toDate = this.toDate == null ? null : this.toDate.toString();\n toRet.fromCreatedDate = this.fromCreatedDate == null ? null : this.fromCreatedDate.toString();\n toRet.toCreatedDate = this.toCreatedDate == null ? null : this.toCreatedDate.toString();\n toRet.outletIds = this.outletIds == null ? null : this.outletIds.map(v => v.toString());\n toRet.statuses = this.statuses == null ? null : this.statuses.map(v => v.value);\n toRet.ullageIds = this.ullageIds == null ? null : this.ullageIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class SpoiltItemLine extends ModelObject {\n\n public header: UllageHeader = new UllageHeader();\n public line: UllageLine = new UllageLine();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.header = new UllageHeader(jsonSerializedObject.header);\n this.line = new UllageLine(jsonSerializedObject.line);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.header = this.header.toJsonSerializedObject();\n toRet.line = this.line.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n {field: \"line\", rule: (v: any) => !!v || \"line is required\"},\n {field: \"line\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class UllageLineApproximateDuty extends ModelObject {\n\n public lineId: Guid = Guid.createEmpty();\n public approximateDuty: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.lineId = Guid.fromString(jsonSerializedObject.lineId);\n this.approximateDuty = jsonSerializedObject.approximateDuty;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.lineId = this.lineId.toString();\n toRet.approximateDuty = this.approximateDuty;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"lineId\", rule: (v: any) => !v.isEmpty() || \"UllageLineApproximateDuty.LineId cannot be empty\"},\n ];\n}\n\n\nexport class UllageApproximateDuty extends ModelObject {\n\n public ullageId: Guid = Guid.createEmpty();\n public approximateDuty: number = 0;\n public lines: UllageLineApproximateDuty[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.ullageId = Guid.fromString(jsonSerializedObject.ullageId);\n this.approximateDuty = jsonSerializedObject.approximateDuty;\n this.lines = jsonSerializedObject.lines.map((v: any) => new UllageLineApproximateDuty(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.ullageId = this.ullageId.toString();\n toRet.approximateDuty = this.approximateDuty;\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"ullageId\", rule: (v: any) => !v.isEmpty() || \"UllageApproximateDuty.UllageId cannot be empty\"},\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as UllageLineApproximateDuty[]).reduce((acc: Array, curr: UllageLineApproximateDuty) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class CreateUllageRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public header: UllageHeader = new UllageHeader();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.header = new UllageHeader(jsonSerializedObject.header);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.header = this.header.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class CreateUllageResponse extends ModelObject {\n\n public ullage: Ullage = new Ullage();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.ullage = new Ullage(jsonSerializedObject.ullage);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.ullage = this.ullage.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"ullage\", rule: (v: any) => !!v || \"ullage is required\"},\n {field: \"ullage\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetAllUllageHeadersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllUllageHeadersResponse extends ModelObject {\n\n public ullageHeaders: UllageHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.ullageHeaders = jsonSerializedObject.ullageHeaders.map((v: any) => new UllageHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.ullageHeaders = this.ullageHeaders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"ullageHeaders\", rule: (v: any) => !!v || \"ullageHeaders is required\"},\n {field: \"ullageHeaders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as UllageHeader[]).reduce((acc: Array, curr: UllageHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class UpdateUllageHeaderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public header: UllageHeader = new UllageHeader();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.header = new UllageHeader(jsonSerializedObject.header);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.header = this.header.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class UpdateUllageHeaderResponse extends ModelObject {\n\n public ullage: Ullage = new Ullage();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.ullage = new Ullage(jsonSerializedObject.ullage);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.ullage = this.ullage.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"ullage\", rule: (v: any) => !!v || \"ullage is required\"},\n {field: \"ullage\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetUllageRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public ullageHeaderId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.ullageHeaderId = Guid.fromString(jsonSerializedObject.ullageHeaderId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.ullageHeaderId = this.ullageHeaderId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"ullageHeaderId\", rule: (v: any) => !v.isEmpty() || \".UllageHeaderId cannot be empty\"},\n ];\n}\n\n\nexport class GetUllageResponse extends ModelObject {\n\n public ullage: Ullage = new Ullage();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.ullage = new Ullage(jsonSerializedObject.ullage);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.ullage = this.ullage.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"ullage\", rule: (v: any) => !!v || \"ullage is required\"},\n {field: \"ullage\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class CancelUllageRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public ullageHeaderId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.ullageHeaderId = Guid.fromString(jsonSerializedObject.ullageHeaderId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.ullageHeaderId = this.ullageHeaderId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"ullageHeaderId\", rule: (v: any) => !v.isEmpty() || \".UllageHeaderId cannot be empty\"},\n ];\n}\n\n\nexport class CompleteUllageRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public ullageHeaderId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.ullageHeaderId = Guid.fromString(jsonSerializedObject.ullageHeaderId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.ullageHeaderId = this.ullageHeaderId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"ullageHeaderId\", rule: (v: any) => !v.isEmpty() || \".UllageHeaderId cannot be empty\"},\n ];\n}\n\n\nexport class CompleteUllageResponse extends ModelObject {\n\n public ullage: Ullage = new Ullage();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.ullage = new Ullage(jsonSerializedObject.ullage);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.ullage = this.ullage.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"ullage\", rule: (v: any) => !!v || \"ullage is required\"},\n {field: \"ullage\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveUllageLineRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public ullageHeaderId: Guid = Guid.createEmpty();\n public line: UllageLine = new UllageLine();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.ullageHeaderId = Guid.fromString(jsonSerializedObject.ullageHeaderId);\n this.line = new UllageLine(jsonSerializedObject.line);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.ullageHeaderId = this.ullageHeaderId.toString();\n toRet.line = this.line.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"ullageHeaderId\", rule: (v: any) => !v.isEmpty() || \".UllageHeaderId cannot be empty\"},\n {field: \"line\", rule: (v: any) => !!v || \"line is required\"},\n {field: \"line\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveUllageLineResponse extends ModelObject {\n\n public ullage: Ullage = new Ullage();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.ullage = new Ullage(jsonSerializedObject.ullage);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.ullage = this.ullage.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"ullage\", rule: (v: any) => !!v || \"ullage is required\"},\n {field: \"ullage\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class CreateCreditForUllageRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public ullageHeaderId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.ullageHeaderId = Guid.fromString(jsonSerializedObject.ullageHeaderId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.ullageHeaderId = this.ullageHeaderId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"ullageHeaderId\", rule: (v: any) => !v.isEmpty() || \".UllageHeaderId cannot be empty\"},\n ];\n}\n\n\nexport class CreateCreditForUllageResponse extends ModelObject {\n\n public ullage: Ullage = new Ullage();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.ullage = new Ullage(jsonSerializedObject.ullage);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.ullage = this.ullage.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"ullage\", rule: (v: any) => !!v || \"ullage is required\"},\n {field: \"ullage\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveUllageLinesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public ullageHeaderId: Guid = Guid.createEmpty();\n public ullageLines: readonly UllageLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.ullageHeaderId = Guid.fromString(jsonSerializedObject.ullageHeaderId);\n this.ullageLines = jsonSerializedObject.ullageLines.map((v: any) => new UllageLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.ullageHeaderId = this.ullageHeaderId.toString();\n toRet.ullageLines = this.ullageLines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"ullageHeaderId\", rule: (v: any) => !v.isEmpty() || \".UllageHeaderId cannot be empty\"},\n {field: \"ullageLines\", rule: (v: any) => !!v || \"ullageLines is required\"},\n {field: \"ullageLines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as UllageLine[]).reduce((acc: Array, curr: UllageLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveUllageLinesResponse extends ModelObject {\n\n public ullage: Ullage = new Ullage();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.ullage = new Ullage(jsonSerializedObject.ullage);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.ullage = this.ullage.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"ullage\", rule: (v: any) => !!v || \"ullage is required\"},\n {field: \"ullage\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class DeleteUllageLineRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public ullageHeaderId: Guid = Guid.createEmpty();\n public ullageLineId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.ullageHeaderId = Guid.fromString(jsonSerializedObject.ullageHeaderId);\n this.ullageLineId = Guid.fromString(jsonSerializedObject.ullageLineId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.ullageHeaderId = this.ullageHeaderId.toString();\n toRet.ullageLineId = this.ullageLineId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"ullageHeaderId\", rule: (v: any) => !v.isEmpty() || \".UllageHeaderId cannot be empty\"},\n {field: \"ullageLineId\", rule: (v: any) => !v.isEmpty() || \".UllageLineId cannot be empty\"},\n ];\n}\n\n\nexport class DeleteUllageLineResponse extends ModelObject {\n\n public ullage: Ullage = new Ullage();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.ullage = new Ullage(jsonSerializedObject.ullage);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.ullage = this.ullage.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"ullage\", rule: (v: any) => !!v || \"ullage is required\"},\n {field: \"ullage\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class BulkAddReturnedItemsToUllagesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public items: readonly UllageBulkAddItem[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.items = jsonSerializedObject.items.map((v: any) => new UllageBulkAddItem(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.items = this.items.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"items\", rule: (v: any) => !!v || \"items is required\"},\n {field: \"items\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as UllageBulkAddItem[]).reduce((acc: Array, curr: UllageBulkAddItem) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetUllageHeadersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public ullageHeaderIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.ullageHeaderIds = jsonSerializedObject.ullageHeaderIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.ullageHeaderIds = this.ullageHeaderIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetUllageHeadersResponse extends ModelObject {\n\n public ullageHeaders: UllageHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.ullageHeaders = jsonSerializedObject.ullageHeaders.map((v: any) => new UllageHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.ullageHeaders = this.ullageHeaders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"ullageHeaders\", rule: (v: any) => !!v || \"ullageHeaders is required\"},\n {field: \"ullageHeaders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as UllageHeader[]).reduce((acc: Array, curr: UllageHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetUllagesByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: UllageFilter = new UllageFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new UllageFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetUllagesByFilterResponse extends ModelObject {\n\n public results: FilteredUllagesResult = new FilteredUllagesResult();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredUllagesResult(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetSpoiltItemDutyReturnIdsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public limitToGivenReturns: boolean = false;\n public limitReturnIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.limitToGivenReturns = jsonSerializedObject.limitToGivenReturns;\n this.limitReturnIds = jsonSerializedObject.limitReturnIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.limitToGivenReturns = this.limitToGivenReturns;\n toRet.limitReturnIds = this.limitReturnIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetSpoiltItemDutyReturnIdsResponse extends ModelObject {\n\n public returnIds: Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.returnIds = jsonSerializedObject.returnIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.returnIds = this.returnIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GetUnclaimedSpoiltItemsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public includeOpenUllages: boolean = false;\n public limitedAlcoholTypes: readonly EnumAlcoholType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.includeOpenUllages = jsonSerializedObject.includeOpenUllages;\n this.limitedAlcoholTypes = jsonSerializedObject.limitedAlcoholTypes.map((v: any) => EnumAlcoholType.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.includeOpenUllages = this.includeOpenUllages;\n toRet.limitedAlcoholTypes = this.limitedAlcoholTypes.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetUnclaimedSpoiltItemsResponse extends ModelObject {\n\n public results: SpoiltItemLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new SpoiltItemLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as SpoiltItemLine[]).reduce((acc: Array, curr: SpoiltItemLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetClaimedSpoiltItemsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public limitToGivenReturns: boolean = false;\n public limitReturnIds: readonly Guid[] = [];\n public limitedAlcoholTypes: readonly EnumAlcoholType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.limitToGivenReturns = jsonSerializedObject.limitToGivenReturns;\n this.limitReturnIds = jsonSerializedObject.limitReturnIds.map((v: any) => Guid.fromString(v));\n this.limitedAlcoholTypes = jsonSerializedObject.limitedAlcoholTypes.map((v: any) => EnumAlcoholType.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.limitToGivenReturns = this.limitToGivenReturns;\n toRet.limitReturnIds = this.limitReturnIds.map(v => v.toString());\n toRet.limitedAlcoholTypes = this.limitedAlcoholTypes.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetClaimedSpoiltItemsResponse extends ModelObject {\n\n public results: SpoiltItemLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new SpoiltItemLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as SpoiltItemLine[]).reduce((acc: Array, curr: SpoiltItemLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class ClaimSpoiltItemsOnDutyReturnRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public ullageLineIds: readonly Guid[] = [];\n public dutyReturnId: Guid = Guid.createEmpty();\n public dutyReturnType: EnumUkDutyReturnType = EnumUkDutyReturnType.none;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.ullageLineIds = jsonSerializedObject.ullageLineIds.map((v: any) => Guid.fromString(v));\n this.dutyReturnId = Guid.fromString(jsonSerializedObject.dutyReturnId);\n this.dutyReturnType = EnumUkDutyReturnType.getByValue(jsonSerializedObject.dutyReturnType, this.dutyReturnType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.ullageLineIds = this.ullageLineIds.map(v => v.toString());\n toRet.dutyReturnId = this.dutyReturnId.toString();\n toRet.dutyReturnType = this.dutyReturnType.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"dutyReturnId\", rule: (v: any) => !v.isEmpty() || \".DutyReturnId cannot be empty\"},\n ];\n}\n\n\nexport class GetUllagesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public ullageHeaderIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.ullageHeaderIds = jsonSerializedObject.ullageHeaderIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.ullageHeaderIds = this.ullageHeaderIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetUllagesResponse extends ModelObject {\n\n public ullage: Ullage[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.ullage = jsonSerializedObject.ullage.map((v: any) => new Ullage(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.ullage = this.ullage.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"ullage\", rule: (v: any) => !!v || \"ullage is required\"},\n {field: \"ullage\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Ullage[]).reduce((acc: Array, curr: Ullage) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class UncompleteUllageRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public ullageId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.ullageId = Guid.fromString(jsonSerializedObject.ullageId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.ullageId = this.ullageId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"ullageId\", rule: (v: any) => !v.isEmpty() || \".UllageId cannot be empty\"},\n ];\n}\n\n\nexport class GetApproximateDutyForUllagesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public ullages: readonly Ullage[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.ullages = jsonSerializedObject.ullages.map((v: any) => new Ullage(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.ullages = this.ullages.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"ullages\", rule: (v: any) => !!v || \"ullages is required\"},\n {field: \"ullages\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Ullage[]).reduce((acc: Array, curr: Ullage) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetApproximateDutyForUllagesResponse extends ModelObject {\n\n public results: UllageApproximateDuty[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new UllageApproximateDuty(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as UllageApproximateDuty[]).reduce((acc: Array, curr: UllageApproximateDuty) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetApproximateDutyForUllageIdsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public ullageIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.ullageIds = jsonSerializedObject.ullageIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.ullageIds = this.ullageIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetApproximateDutyForUllageIdsResponse extends ModelObject {\n\n public results: UllageApproximateDuty[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new UllageApproximateDuty(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as UllageApproximateDuty[]).reduce((acc: Array, curr: UllageApproximateDuty) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class UllageService extends ServiceBase {\n\n public async createUllage(tenantId: Guid, header: UllageHeader, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CreateUllageRequest();\n req.tenantId = tenantId;\n req.header = header;\n const extractor = (response:any) => new CreateUllageResponse(response).ullage;\n return this.makeJsonRequest(\"ullage/v1/createUllage\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllUllageHeaders(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllUllageHeadersRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllUllageHeadersResponse(response).ullageHeaders;\n return this.makeJsonRequest(\"ullage/v1/getAllUllageHeaders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updateUllageHeader(tenantId: Guid, header: UllageHeader, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdateUllageHeaderRequest();\n req.tenantId = tenantId;\n req.header = header;\n const extractor = (response:any) => new UpdateUllageHeaderResponse(response).ullage;\n return this.makeJsonRequest(\"ullage/v1/updateUllageHeader\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getUllage(tenantId: Guid, ullageHeaderId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetUllageRequest();\n req.tenantId = tenantId;\n req.ullageHeaderId = ullageHeaderId;\n const extractor = (response:any) => new GetUllageResponse(response).ullage;\n return this.makeJsonRequest(\"ullage/v1/getUllage\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async cancelUllage(tenantId: Guid, ullageHeaderId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CancelUllageRequest();\n req.tenantId = tenantId;\n req.ullageHeaderId = ullageHeaderId;\n const extractor = null;\n return this.makeJsonRequest(\"ullage/v1/cancelUllage\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async completeUllage(tenantId: Guid, ullageHeaderId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CompleteUllageRequest();\n req.tenantId = tenantId;\n req.ullageHeaderId = ullageHeaderId;\n const extractor = (response:any) => new CompleteUllageResponse(response).ullage;\n return this.makeJsonRequest(\"ullage/v1/completeUllage\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveUllageLine(tenantId: Guid, ullageHeaderId: Guid, line: UllageLine, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveUllageLineRequest();\n req.tenantId = tenantId;\n req.ullageHeaderId = ullageHeaderId;\n req.line = line;\n const extractor = (response:any) => new SaveUllageLineResponse(response).ullage;\n return this.makeJsonRequest(\"ullage/v1/saveUllageLine\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async createCreditForUllage(tenantId: Guid, ullageHeaderId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CreateCreditForUllageRequest();\n req.tenantId = tenantId;\n req.ullageHeaderId = ullageHeaderId;\n const extractor = (response:any) => new CreateCreditForUllageResponse(response).ullage;\n return this.makeJsonRequest(\"ullage/v1/createCreditForUllage\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveUllageLines(tenantId: Guid, ullageHeaderId: Guid, ullageLines: readonly UllageLine[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveUllageLinesRequest();\n req.tenantId = tenantId;\n req.ullageHeaderId = ullageHeaderId;\n req.ullageLines = ullageLines;\n const extractor = (response:any) => new SaveUllageLinesResponse(response).ullage;\n return this.makeJsonRequest(\"ullage/v1/saveUllageLines\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async deleteUllageLine(tenantId: Guid, ullageHeaderId: Guid, ullageLineId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new DeleteUllageLineRequest();\n req.tenantId = tenantId;\n req.ullageHeaderId = ullageHeaderId;\n req.ullageLineId = ullageLineId;\n const extractor = (response:any) => new DeleteUllageLineResponse(response).ullage;\n return this.makeJsonRequest(\"ullage/v1/deleteUllageLine\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async bulkAddReturnedItemsToUllages(tenantId: Guid, items: readonly UllageBulkAddItem[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new BulkAddReturnedItemsToUllagesRequest();\n req.tenantId = tenantId;\n req.items = items;\n const extractor = null;\n return this.makeJsonRequest(\"ullage/v1/bulkAddReturnedItemsToUllages\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getUllageHeaders(tenantId: Guid, ullageHeaderIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetUllageHeadersRequest();\n req.tenantId = tenantId;\n req.ullageHeaderIds = ullageHeaderIds;\n const extractor = (response:any) => new GetUllageHeadersResponse(response).ullageHeaders;\n return this.makeJsonRequest(\"ullage/v1/getUllageHeaders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getUllagesByFilter(tenantId: Guid, filter: UllageFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetUllagesByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetUllagesByFilterResponse(response).results;\n return this.makeJsonRequest(\"ullage/v1/getUllagesByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getSpoiltItemDutyReturnIds(tenantId: Guid, limitToGivenReturns: boolean, limitReturnIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetSpoiltItemDutyReturnIdsRequest();\n req.tenantId = tenantId;\n req.limitToGivenReturns = limitToGivenReturns;\n req.limitReturnIds = limitReturnIds;\n const extractor = (response:any) => new GetSpoiltItemDutyReturnIdsResponse(response).returnIds;\n return this.makeJsonRequest(\"ullage/v1/getSpoiltItemDutyReturnIds\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getUnclaimedSpoiltItems(tenantId: Guid, includeOpenUllages: boolean, limitedAlcoholTypes: readonly EnumAlcoholType[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetUnclaimedSpoiltItemsRequest();\n req.tenantId = tenantId;\n req.includeOpenUllages = includeOpenUllages;\n req.limitedAlcoholTypes = limitedAlcoholTypes;\n const extractor = (response:any) => new GetUnclaimedSpoiltItemsResponse(response).results;\n return this.makeJsonRequest(\"ullage/v1/getUnclaimedSpoiltItems\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getClaimedSpoiltItems(tenantId: Guid, limitToGivenReturns: boolean, limitReturnIds: readonly Guid[], limitedAlcoholTypes: readonly EnumAlcoholType[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetClaimedSpoiltItemsRequest();\n req.tenantId = tenantId;\n req.limitToGivenReturns = limitToGivenReturns;\n req.limitReturnIds = limitReturnIds;\n req.limitedAlcoholTypes = limitedAlcoholTypes;\n const extractor = (response:any) => new GetClaimedSpoiltItemsResponse(response).results;\n return this.makeJsonRequest(\"ullage/v1/getClaimedSpoiltItems\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async claimSpoiltItemsOnDutyReturn(tenantId: Guid, ullageLineIds: readonly Guid[], dutyReturnId: Guid, dutyReturnType: EnumUkDutyReturnType, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new ClaimSpoiltItemsOnDutyReturnRequest();\n req.tenantId = tenantId;\n req.ullageLineIds = ullageLineIds;\n req.dutyReturnId = dutyReturnId;\n req.dutyReturnType = dutyReturnType;\n const extractor = null;\n return this.makeJsonRequest(\"ullage/v1/claimSpoiltItemsOnDutyReturn\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getUllages(tenantId: Guid, ullageHeaderIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetUllagesRequest();\n req.tenantId = tenantId;\n req.ullageHeaderIds = ullageHeaderIds;\n const extractor = (response:any) => new GetUllagesResponse(response).ullage;\n return this.makeJsonRequest(\"ullage/v1/getUllages\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async uncompleteUllage(tenantId: Guid, ullageId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UncompleteUllageRequest();\n req.tenantId = tenantId;\n req.ullageId = ullageId;\n const extractor = null;\n return this.makeJsonRequest(\"ullage/v1/uncompleteUllage\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getApproximateDutyForUllages(tenantId: Guid, ullages: readonly Ullage[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetApproximateDutyForUllagesRequest();\n req.tenantId = tenantId;\n req.ullages = ullages;\n const extractor = (response:any) => new GetApproximateDutyForUllagesResponse(response).results;\n return this.makeJsonRequest(\"ullage/v1/getApproximateDutyForUllages\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getApproximateDutyForUllageIds(tenantId: Guid, ullageIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetApproximateDutyForUllageIdsRequest();\n req.tenantId = tenantId;\n req.ullageIds = ullageIds;\n const extractor = (response:any) => new GetApproximateDutyForUllageIdsResponse(response).results;\n return this.makeJsonRequest(\"ullage/v1/getApproximateDutyForUllageIds\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const ullageService = new UllageService();","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumAlcoholType } from \"./enums/enumAlcoholType.generated\";\nimport { EnumAssemblyIngredientSource } from \"./enums/enumAssemblyIngredientSource.generated\";\nimport { EnumAssemblyOutputTarget } from \"./enums/enumAssemblyOutputTarget.generated\";\nimport { EnumAssemblyStatus } from \"./enums/enumAssemblyStatus.generated\";\nimport { EnumAssemblyType } from \"./enums/enumAssemblyType.generated\";\nimport { EnumYesNoEither } from \"./enums/enumYesNoEither.generated\";\n\n// Model Objects\n\nexport class AssemblyOutput extends ModelObject {\n\n public quantity: number = 0;\n public stockItemId: Guid = Guid.createEmpty();\n public unitOfMeasureId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.quantity = jsonSerializedObject.quantity;\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.quantity = this.quantity;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"AssemblyOutput.StockItemId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"AssemblyOutput.UnitOfMeasureId cannot be empty\"},\n ];\n}\n\n\nexport class AssemblyHeaderReadOnly extends ModelObject {\n\n private _startedAt: Instant | null = null;\n /**\n * Timestamp at which the assembly was started.\n */\n public get startedAt(): Instant | null { return this._startedAt }\n public set startedAt(value: Instant | null) {\n this._startedAt = value === undefined ? null : value;\n }\n private _completedAt: Instant | null = null;\n /**\n * Timestamp at which the assembly was completed.\n */\n public get completedAt(): Instant | null { return this._completedAt }\n public set completedAt(value: Instant | null) {\n this._completedAt = value === undefined ? null : value;\n }\n private _expectedCompletionDateAtStart: LocalDate | null = null;\n /**\n * Expected Completion Date At Start\n */\n public get expectedCompletionDateAtStart(): LocalDate | null { return this._expectedCompletionDateAtStart }\n public set expectedCompletionDateAtStart(value: LocalDate | null) {\n this._expectedCompletionDateAtStart = value === undefined ? null : value;\n }\n /**\n * Cost of ingredients already used in assembly. (Will be 0 if not yet started)\n */\n public costSoFar: number = 0;\n private _costExpectedAtStart: number | null = null;\n /**\n * The cost which was expected as captured when the assembly was started.\n */\n public get costExpectedAtStart(): number | null { return this._costExpectedAtStart }\n public set costExpectedAtStart(value: number | null) {\n this._costExpectedAtStart = value === undefined ? null : value;\n }\n private _cancelledAt: Instant | null = null;\n /**\n * Timestamp at which the assembly was cancelled.\n */\n public get cancelledAt(): Instant | null { return this._cancelledAt }\n public set cancelledAt(value: Instant | null) {\n this._cancelledAt = value === undefined ? null : value;\n }\n /**\n * True if this assembly has been previously completed, and then un-completed.\n */\n public hasBeenPreviouslyCompleted: boolean = false;\n /**\n * Total Litres of all ingredients already used in assembly. (Will be 0 if not yet started)\n */\n public totalIngredientUsedLitres: number = 0;\n private _startedBy: Guid | null = null;\n /**\n * User who has started the assembly.\n */\n public get startedBy(): Guid | null { return this._startedBy }\n public set startedBy(value: Guid | null) {\n this._startedBy = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.startedAt = jsonSerializedObject.startedAt == null ? null : Instant.parse(jsonSerializedObject.startedAt);\n this.completedAt = jsonSerializedObject.completedAt == null ? null : Instant.parse(jsonSerializedObject.completedAt);\n this.expectedCompletionDateAtStart = jsonSerializedObject.expectedCompletionDateAtStart == null ? null : LocalDate.parse(jsonSerializedObject.expectedCompletionDateAtStart);\n this.costSoFar = jsonSerializedObject.costSoFar;\n this.costExpectedAtStart = jsonSerializedObject.costExpectedAtStart == null ? null : jsonSerializedObject.costExpectedAtStart;\n this.cancelledAt = jsonSerializedObject.cancelledAt == null ? null : Instant.parse(jsonSerializedObject.cancelledAt);\n this.hasBeenPreviouslyCompleted = jsonSerializedObject.hasBeenPreviouslyCompleted;\n this.totalIngredientUsedLitres = jsonSerializedObject.totalIngredientUsedLitres;\n this.startedBy = jsonSerializedObject.startedBy == null ? null : Guid.fromString(jsonSerializedObject.startedBy);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.startedAt = this.startedAt == null ? null : this.startedAt.toString();\n toRet.completedAt = this.completedAt == null ? null : this.completedAt.toString();\n toRet.expectedCompletionDateAtStart = this.expectedCompletionDateAtStart == null ? null : this.expectedCompletionDateAtStart.toString();\n toRet.costSoFar = this.costSoFar;\n toRet.costExpectedAtStart = this.costExpectedAtStart == null ? null : this.costExpectedAtStart;\n toRet.cancelledAt = this.cancelledAt == null ? null : this.cancelledAt.toString();\n toRet.hasBeenPreviouslyCompleted = this.hasBeenPreviouslyCompleted;\n toRet.totalIngredientUsedLitres = this.totalIngredientUsedLitres;\n toRet.startedBy = this.startedBy == null ? null : this.startedBy.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"startedBy\", rule: (v: any) => v == null || !v.isEmpty() || \"AssemblyHeaderReadOnly.StartedBy cannot be empty\"},\n ];\n}\n\n\nexport class AssemblyHeaderCalculated extends ModelObject {\n\n public status: EnumAssemblyStatus = EnumAssemblyStatus.open;\n private _outputExpectedAtStart: AssemblyOutput | null = null;\n public get outputExpectedAtStart(): AssemblyOutput | null { return this._outputExpectedAtStart }\n public set outputExpectedAtStart(value: AssemblyOutput | null) {\n this._outputExpectedAtStart = value === undefined ? null : value;\n }\n private _outputProduced: AssemblyOutput | null = null;\n public get outputProduced(): AssemblyOutput | null { return this._outputProduced }\n public set outputProduced(value: AssemblyOutput | null) {\n this._outputProduced = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.status = EnumAssemblyStatus.getByValue(jsonSerializedObject.status, this.status);\n this.outputExpectedAtStart = jsonSerializedObject.outputExpectedAtStart == null ? null : new AssemblyOutput(jsonSerializedObject.outputExpectedAtStart);\n this.outputProduced = jsonSerializedObject.outputProduced == null ? null : new AssemblyOutput(jsonSerializedObject.outputProduced);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.status = this.status.value;\n toRet.outputExpectedAtStart = this.outputExpectedAtStart == null ? null : this.outputExpectedAtStart?.toJsonSerializedObject() ?? null;\n toRet.outputProduced = this.outputProduced == null ? null : this.outputProduced?.toJsonSerializedObject() ?? null;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outputExpectedAtStart\", rule: (v: any) => (v === null) || v.validate()},\n {field: \"outputProduced\", rule: (v: any) => (v === null) || v.validate()},\n ];\n}\n\n\nexport class AssemblyHeader extends ModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Assembly Type. : 0 = MaterialProduction, 1 = ProductPackaging, 2 = Maintenance\n */\n public assemblyType: EnumAssemblyType = EnumAssemblyType.materialProduction;\n private _bestBefore: LocalDate | null = null;\n /**\n * Best Before Date\n */\n public get bestBefore(): LocalDate | null { return this._bestBefore }\n public set bestBefore(value: LocalDate | null) {\n this._bestBefore = value === undefined ? null : value;\n }\n /**\n * Current Expected Completion Date\n */\n public currentExpectedCompletionDate: LocalDate = LocalDate.ofEpochDay(0);\n /**\n * Name. Defaults to using sequence numbering.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public name: string = \"\";\n /**\n * Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n private _recipeId: Guid | null = null;\n /**\n * Recipe from which this assembly was initially created (if any). Does not drive any functionality, just for future reference really.\n */\n public get recipeId(): Guid | null { return this._recipeId }\n public set recipeId(value: Guid | null) {\n this._recipeId = value === undefined ? null : value;\n }\n /**\n * Stock Location Id\n */\n public stockLocationId: Guid = Guid.createEmpty();\n /**\n * Urn. Will be either allocated at begin assembly, or will be provided by user, or left blank.\n * Not Nullable\n * Max Length : 1000\n */\n public urn: string = \"\";\n /**\n * When True, Urn will be system allocated at begin assembly, When false, Urn must be provided by user if needed.\n */\n public autoAllocateUrnAtStart: boolean = false;\n /**\n * Cannot be unset once set.\n */\n public hasPrintedLabels: boolean = false;\n private _outputStillExpected: AssemblyOutput | null = null;\n public get outputStillExpected(): AssemblyOutput | null { return this._outputStillExpected }\n public set outputStillExpected(value: AssemblyOutput | null) {\n this._outputStillExpected = value === undefined ? null : value;\n }\n public readOnly: AssemblyHeaderReadOnly = new AssemblyHeaderReadOnly();\n public isHidden: boolean = false;\n public calculated: AssemblyHeaderCalculated = new AssemblyHeaderCalculated();\n private _plannedStartDate: LocalDate | null = null;\n /**\n * Date at which the assembly was planned to start.\n */\n public get plannedStartDate(): LocalDate | null { return this._plannedStartDate }\n public set plannedStartDate(value: LocalDate | null) {\n this._plannedStartDate = value === undefined ? null : value;\n }\n private _startDate: LocalDate | null = null;\n /**\n * Date at which the assembly was actually started - user editable (not captured by system). Not applicable to unstarted assemblies.\n */\n public get startDate(): LocalDate | null { return this._startDate }\n public set startDate(value: LocalDate | null) {\n this._startDate = value === undefined ? null : value;\n }\n /**\n * Vessel Fill Colour\n * Not Nullable\n */\n public vesselFillColour: string = \"\";\n private _currentProcessGroupId: Guid | null = null;\n /**\n * The ProcessGroup (if any) currently in progress.\n */\n public get currentProcessGroupId(): Guid | null { return this._currentProcessGroupId }\n public set currentProcessGroupId(value: Guid | null) {\n this._currentProcessGroupId = value === undefined ? null : value;\n }\n private _currentProcessGroupLikelyFinishDate: LocalDate | null = null;\n /**\n * The date on which the ProcessGroup (if any) currently in progress is likely to be completed. This represents the view of reality as estimated by the person performing the assembly.\n */\n public get currentProcessGroupLikelyFinishDate(): LocalDate | null { return this._currentProcessGroupLikelyFinishDate }\n public set currentProcessGroupLikelyFinishDate(value: LocalDate | null) {\n this._currentProcessGroupLikelyFinishDate = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.assemblyType = EnumAssemblyType.getByValue(jsonSerializedObject.assemblyType, this.assemblyType);\n this.bestBefore = jsonSerializedObject.bestBefore == null ? null : LocalDate.parse(jsonSerializedObject.bestBefore);\n this.currentExpectedCompletionDate = LocalDate.parse(jsonSerializedObject.currentExpectedCompletionDate);\n this.name = jsonSerializedObject.name;\n this.notes = jsonSerializedObject.notes;\n this.recipeId = jsonSerializedObject.recipeId == null ? null : Guid.fromString(jsonSerializedObject.recipeId);\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.urn = jsonSerializedObject.urn;\n this.autoAllocateUrnAtStart = jsonSerializedObject.autoAllocateUrnAtStart;\n this.hasPrintedLabels = jsonSerializedObject.hasPrintedLabels;\n this.outputStillExpected = jsonSerializedObject.outputStillExpected == null ? null : new AssemblyOutput(jsonSerializedObject.outputStillExpected);\n this.readOnly = new AssemblyHeaderReadOnly(jsonSerializedObject.readOnly);\n this.isHidden = jsonSerializedObject.isHidden;\n this.calculated = new AssemblyHeaderCalculated(jsonSerializedObject.calculated);\n this.plannedStartDate = jsonSerializedObject.plannedStartDate == null ? null : LocalDate.parse(jsonSerializedObject.plannedStartDate);\n this.startDate = jsonSerializedObject.startDate == null ? null : LocalDate.parse(jsonSerializedObject.startDate);\n this.vesselFillColour = jsonSerializedObject.vesselFillColour;\n this.currentProcessGroupId = jsonSerializedObject.currentProcessGroupId == null ? null : Guid.fromString(jsonSerializedObject.currentProcessGroupId);\n this.currentProcessGroupLikelyFinishDate = jsonSerializedObject.currentProcessGroupLikelyFinishDate == null ? null : LocalDate.parse(jsonSerializedObject.currentProcessGroupLikelyFinishDate);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.assemblyType = this.assemblyType.value;\n toRet.bestBefore = this.bestBefore == null ? null : this.bestBefore.toString();\n toRet.currentExpectedCompletionDate = this.currentExpectedCompletionDate.toString();\n toRet.name = this.name;\n toRet.notes = this.notes;\n toRet.recipeId = this.recipeId == null ? null : this.recipeId.toString();\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.urn = this.urn;\n toRet.autoAllocateUrnAtStart = this.autoAllocateUrnAtStart;\n toRet.hasPrintedLabels = this.hasPrintedLabels;\n toRet.outputStillExpected = this.outputStillExpected == null ? null : this.outputStillExpected?.toJsonSerializedObject() ?? null;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.isHidden = this.isHidden;\n toRet.calculated = this.calculated.toJsonSerializedObject();\n toRet.plannedStartDate = this.plannedStartDate == null ? null : this.plannedStartDate.toString();\n toRet.startDate = this.startDate == null ? null : this.startDate.toString();\n toRet.vesselFillColour = this.vesselFillColour;\n toRet.currentProcessGroupId = this.currentProcessGroupId == null ? null : this.currentProcessGroupId.toString();\n toRet.currentProcessGroupLikelyFinishDate = this.currentProcessGroupLikelyFinishDate == null ? null : this.currentProcessGroupLikelyFinishDate.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"AssemblyHeader.Id cannot be empty\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"recipeId\", rule: (v: any) => v == null || !v.isEmpty() || \"AssemblyHeader.RecipeId cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \"AssemblyHeader.StockLocationId cannot be empty\"},\n {field: \"urn\", rule: (v: any) => v == null || v.length <= 1000 || \"Urn has too many characters (1000)\"},\n {field: \"outputStillExpected\", rule: (v: any) => (v === null) || v.validate()},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"calculated\", rule: (v: any) => !!v || \"calculated is required\"},\n {field: \"calculated\", rule: (v: any) => v.validate()},\n {field: \"currentProcessGroupId\", rule: (v: any) => v == null || !v.isEmpty() || \"AssemblyHeader.CurrentProcessGroupId cannot be empty\"},\n ];\n}\n\n\nexport class AssemblyIngredientLineReadOnly extends ModelObject {\n\n /**\n * Assembly Id\n */\n public assemblyId: Guid = Guid.createEmpty();\n private _quantityExpectedAtStart: number | null = null;\n /**\n * Quantity expected to be used as captured at the time the assembly was started (null if not started).\n */\n public get quantityExpectedAtStart(): number | null { return this._quantityExpectedAtStart }\n public set quantityExpectedAtStart(value: number | null) {\n this._quantityExpectedAtStart = value === undefined ? null : value;\n }\n private _totalCostExpectedAtStart: number | null = null;\n /**\n * Total cost of ingredient expected as captured at the time the assembly was started. (Quantity * StockItem Cost Price at time of start). (null if not started).\n */\n public get totalCostExpectedAtStart(): number | null { return this._totalCostExpectedAtStart }\n public set totalCostExpectedAtStart(value: number | null) {\n this._totalCostExpectedAtStart = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.assemblyId = Guid.fromString(jsonSerializedObject.assemblyId);\n this.quantityExpectedAtStart = jsonSerializedObject.quantityExpectedAtStart == null ? null : jsonSerializedObject.quantityExpectedAtStart;\n this.totalCostExpectedAtStart = jsonSerializedObject.totalCostExpectedAtStart == null ? null : jsonSerializedObject.totalCostExpectedAtStart;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.assemblyId = this.assemblyId.toString();\n toRet.quantityExpectedAtStart = this.quantityExpectedAtStart == null ? null : this.quantityExpectedAtStart;\n toRet.totalCostExpectedAtStart = this.totalCostExpectedAtStart == null ? null : this.totalCostExpectedAtStart;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"assemblyId\", rule: (v: any) => !v.isEmpty() || \"AssemblyIngredientLineReadOnly.AssemblyId cannot be empty\"},\n ];\n}\n\n\nexport class AssemblyIngredientLine extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Quantity Still expected to be used.\n */\n public quantityStillExpected: number = 0;\n /**\n * Sequence (for ordering Lines).\n */\n public sequence: number = 0;\n /**\n * Stock Item Id Being Used.\n */\n public stockItemId: Guid = Guid.createEmpty();\n /**\n * Unit of Measure\n */\n public unitOfMeasureId: Guid = Guid.createEmpty();\n /**\n * Whether this ingredient is fixed to its current quantity regardless of adjustments to assembly output.If set to true, the ingredient required quantity will not be multiplied when adjusting planned assembly output quantities.\n */\n public fixedQuantity: boolean = false;\n /**\n * Notes.\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n public readOnly: AssemblyIngredientLineReadOnly = new AssemblyIngredientLineReadOnly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.quantityStillExpected = jsonSerializedObject.quantityStillExpected;\n this.sequence = jsonSerializedObject.sequence;\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n this.fixedQuantity = jsonSerializedObject.fixedQuantity;\n this.notes = jsonSerializedObject.notes;\n this.readOnly = new AssemblyIngredientLineReadOnly(jsonSerializedObject.readOnly);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.quantityStillExpected = this.quantityStillExpected;\n toRet.sequence = this.sequence;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n toRet.fixedQuantity = this.fixedQuantity;\n toRet.notes = this.notes;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"AssemblyIngredientLine.Id cannot be empty\"},\n {field: \"sequence\", rule: (v: any) => v == null || v >= -2147483648 || \"Sequence is not greater than minimum allowed value: -2147483648\"},\n {field: \"sequence\", rule: (v: any) => v == null || v <= 2147483647 || \"Sequence is above maximum allowed value: 2147483647\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"AssemblyIngredientLine.StockItemId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"AssemblyIngredientLine.UnitOfMeasureId cannot be empty\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class AssemblyIngredientUsedLineReadOnly extends ModelObject {\n\n /**\n * Timestamp at which the ingredient used line was created on the system. Captured by system not user editable.\n */\n public createdAt: Instant = Instant.ofEpochMilli(0);\n /**\n * Source Type this ingredient came from. : 0 = Stock, 1 = Assembly\n */\n public sourceType: EnumAssemblyIngredientSource = EnumAssemblyIngredientSource.stock;\n private _sourceAssemblyId: Guid | null = null;\n /**\n * Id of Source Assembly if this ingredient came from another assembly. Required if SourceType=Assembly.\n */\n public get sourceAssemblyId(): Guid | null { return this._sourceAssemblyId }\n public set sourceAssemblyId(value: Guid | null) {\n this._sourceAssemblyId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.createdAt = Instant.parse(jsonSerializedObject.createdAt);\n this.sourceType = EnumAssemblyIngredientSource.getByValue(jsonSerializedObject.sourceType, this.sourceType);\n this.sourceAssemblyId = jsonSerializedObject.sourceAssemblyId == null ? null : Guid.fromString(jsonSerializedObject.sourceAssemblyId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.createdAt = this.createdAt.toString();\n toRet.sourceType = this.sourceType.value;\n toRet.sourceAssemblyId = this.sourceAssemblyId == null ? null : this.sourceAssemblyId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"sourceAssemblyId\", rule: (v: any) => v == null || !v.isEmpty() || \"AssemblyIngredientUsedLineReadOnly.SourceAssemblyId cannot be empty\"},\n ];\n}\n\n\nexport class AssemblyIngredientUsedLine extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Assembly Ingredient Line Id for which this usage occurred.\n */\n public assemblyIngredientLineId: Guid = Guid.createEmpty();\n /**\n * Quantity Used\n */\n public quantityUsed: number = 0;\n /**\n * Unit of Measure\n */\n public unitOfMeasureId: Guid = Guid.createEmpty();\n /**\n * Total cost of ingredients used in this line.\n */\n public totalCost: number = 0;\n /**\n * Stock batch/delivery tracking URN.\n * Not Nullable\n * Max Length : 1000\n */\n public urn: string = \"\";\n public readOnly: AssemblyIngredientUsedLineReadOnly = new AssemblyIngredientUsedLineReadOnly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.assemblyIngredientLineId = Guid.fromString(jsonSerializedObject.assemblyIngredientLineId);\n this.quantityUsed = jsonSerializedObject.quantityUsed;\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n this.totalCost = jsonSerializedObject.totalCost;\n this.urn = jsonSerializedObject.urn;\n this.readOnly = new AssemblyIngredientUsedLineReadOnly(jsonSerializedObject.readOnly);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.assemblyIngredientLineId = this.assemblyIngredientLineId.toString();\n toRet.quantityUsed = this.quantityUsed;\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n toRet.totalCost = this.totalCost;\n toRet.urn = this.urn;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"AssemblyIngredientUsedLine.Id cannot be empty\"},\n {field: \"assemblyIngredientLineId\", rule: (v: any) => !v.isEmpty() || \"AssemblyIngredientUsedLine.AssemblyIngredientLineId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"AssemblyIngredientUsedLine.UnitOfMeasureId cannot be empty\"},\n {field: \"urn\", rule: (v: any) => v == null || v.length <= 1000 || \"Urn has too many characters (1000)\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class AssemblyIngredientLineWithUsed extends ModelObject {\n\n public ingredient: AssemblyIngredientLine = new AssemblyIngredientLine();\n public ingredientUsedLines: AssemblyIngredientUsedLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.ingredient = new AssemblyIngredientLine(jsonSerializedObject.ingredient);\n this.ingredientUsedLines = jsonSerializedObject.ingredientUsedLines.map((v: any) => new AssemblyIngredientUsedLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.ingredient = this.ingredient.toJsonSerializedObject();\n toRet.ingredientUsedLines = this.ingredientUsedLines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"ingredient\", rule: (v: any) => !!v || \"ingredient is required\"},\n {field: \"ingredient\", rule: (v: any) => v.validate()},\n {field: \"ingredientUsedLines\", rule: (v: any) => !!v || \"ingredientUsedLines is required\"},\n {field: \"ingredientUsedLines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AssemblyIngredientUsedLine[]).reduce((acc: Array, curr: AssemblyIngredientUsedLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class AssemblyItemProducedLineReadOnly extends ModelObject {\n\n /**\n * Timestamp at which the item produced line was created on the system. Captured by system not user editable.\n */\n public createdAt: Instant = Instant.ofEpochMilli(0);\n /**\n * Assembly Id\n */\n public assemblyId: Guid = Guid.createEmpty();\n /**\n * Target Type this output went to. : 0 = Stock, 1 = Assembly\n */\n public targetType: EnumAssemblyOutputTarget = EnumAssemblyOutputTarget.stock;\n private _targetAssemblyId: Guid | null = null;\n /**\n * Id of Target Assembly if this output went to another assembly. Required if TargetType=Assembly.\n */\n public get targetAssemblyId(): Guid | null { return this._targetAssemblyId }\n public set targetAssemblyId(value: Guid | null) {\n this._targetAssemblyId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.createdAt = Instant.parse(jsonSerializedObject.createdAt);\n this.assemblyId = Guid.fromString(jsonSerializedObject.assemblyId);\n this.targetType = EnumAssemblyOutputTarget.getByValue(jsonSerializedObject.targetType, this.targetType);\n this.targetAssemblyId = jsonSerializedObject.targetAssemblyId == null ? null : Guid.fromString(jsonSerializedObject.targetAssemblyId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.createdAt = this.createdAt.toString();\n toRet.assemblyId = this.assemblyId.toString();\n toRet.targetType = this.targetType.value;\n toRet.targetAssemblyId = this.targetAssemblyId == null ? null : this.targetAssemblyId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"assemblyId\", rule: (v: any) => !v.isEmpty() || \"AssemblyItemProducedLineReadOnly.AssemblyId cannot be empty\"},\n {field: \"targetAssemblyId\", rule: (v: any) => v == null || !v.isEmpty() || \"AssemblyItemProducedLineReadOnly.TargetAssemblyId cannot be empty\"},\n ];\n}\n\n\nexport class AssemblyItemProducedLine extends ModelObject {\n\n /**\n * Stock item Id. All lines in one assembly must be for the same stock item.\n */\n public stockItemId: Guid = Guid.createEmpty();\n /**\n * Quantity Produced. A -ve value can act as a correction to a previous entry.\n */\n public quantityProduced: number = 0;\n /**\n * Unit of Measure\n */\n public unitOfMeasureId: Guid = Guid.createEmpty();\n /**\n * Whether this output was a by-product of the assembly rather than the main output item.\n */\n public isByProduct: boolean = false;\n public readOnly: AssemblyItemProducedLineReadOnly = new AssemblyItemProducedLineReadOnly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.quantityProduced = jsonSerializedObject.quantityProduced;\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n this.isByProduct = jsonSerializedObject.isByProduct;\n this.readOnly = new AssemblyItemProducedLineReadOnly(jsonSerializedObject.readOnly);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.quantityProduced = this.quantityProduced;\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n toRet.isByProduct = this.isByProduct;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"AssemblyItemProducedLine.StockItemId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"AssemblyItemProducedLine.UnitOfMeasureId cannot be empty\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class AssemblyCalculatedCosts extends ModelObject {\n\n /**\n * Cost of ingredients still expected to be used. (Will be 0 if assembly is completed)\n */\n public costStillExpected: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.costStillExpected = jsonSerializedObject.costStillExpected;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.costStillExpected = this.costStillExpected;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class AssemblyProcessLineReadOnly extends ModelObject {\n\n /**\n * Parent ProcessGroup.\n */\n public assemblyProcessGroupId: Guid = Guid.createEmpty();\n private _completedAt: Instant | null = null;\n /**\n * Timestamp at which the process line was completed on the system. Captured by system not user editable.\n */\n public get completedAt(): Instant | null { return this._completedAt }\n public set completedAt(value: Instant | null) {\n this._completedAt = value === undefined ? null : value;\n }\n private _completedByUserId: Guid | null = null;\n /**\n * User Id of the user who completed the process line. Captured by system not user editable.\n */\n public get completedByUserId(): Guid | null { return this._completedByUserId }\n public set completedByUserId(value: Guid | null) {\n this._completedByUserId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.assemblyProcessGroupId = Guid.fromString(jsonSerializedObject.assemblyProcessGroupId);\n this.completedAt = jsonSerializedObject.completedAt == null ? null : Instant.parse(jsonSerializedObject.completedAt);\n this.completedByUserId = jsonSerializedObject.completedByUserId == null ? null : Guid.fromString(jsonSerializedObject.completedByUserId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.assemblyProcessGroupId = this.assemblyProcessGroupId.toString();\n toRet.completedAt = this.completedAt == null ? null : this.completedAt.toString();\n toRet.completedByUserId = this.completedByUserId == null ? null : this.completedByUserId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"assemblyProcessGroupId\", rule: (v: any) => !v.isEmpty() || \"AssemblyProcessLineReadOnly.AssemblyProcessGroupId cannot be empty\"},\n {field: \"completedByUserId\", rule: (v: any) => v == null || !v.isEmpty() || \"AssemblyProcessLineReadOnly.CompletedByUserId cannot be empty\"},\n ];\n}\n\n\nexport class AssemblyProcessLine extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Is locked. Set to true if process came from recipe.\n */\n public isLocked: boolean = false;\n /**\n * Sequence\n */\n public sequence: number = 0;\n /**\n * Instruction\n * Not Nullable\n * Max Length : 100000\n */\n public instruction: string = \"\";\n /**\n * Instruction Notes\n * Not Nullable\n * Max Length : 100000\n */\n public instructionNotes: string = \"\";\n /**\n * Execution Notes\n * Not Nullable\n * Max Length : 100000\n */\n public executionNotes: string = \"\";\n /**\n * Complete\n */\n public complete: boolean = false;\n public readOnly: AssemblyProcessLineReadOnly = new AssemblyProcessLineReadOnly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.isLocked = jsonSerializedObject.isLocked;\n this.sequence = jsonSerializedObject.sequence;\n this.instruction = jsonSerializedObject.instruction;\n this.instructionNotes = jsonSerializedObject.instructionNotes;\n this.executionNotes = jsonSerializedObject.executionNotes;\n this.complete = jsonSerializedObject.complete;\n this.readOnly = new AssemblyProcessLineReadOnly(jsonSerializedObject.readOnly);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.isLocked = this.isLocked;\n toRet.sequence = this.sequence;\n toRet.instruction = this.instruction;\n toRet.instructionNotes = this.instructionNotes;\n toRet.executionNotes = this.executionNotes;\n toRet.complete = this.complete;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"AssemblyProcessLine.Id cannot be empty\"},\n {field: \"sequence\", rule: (v: any) => v == null || v >= -2147483648 || \"Sequence is not greater than minimum allowed value: -2147483648\"},\n {field: \"sequence\", rule: (v: any) => v == null || v <= 2147483647 || \"Sequence is above maximum allowed value: 2147483647\"},\n {field: \"instruction\", rule: (v: any) => v == null || v.length <= 100000 || \"Instruction has too many characters (100000)\"},\n {field: \"instructionNotes\", rule: (v: any) => v == null || v.length <= 100000 || \"InstructionNotes has too many characters (100000)\"},\n {field: \"executionNotes\", rule: (v: any) => v == null || v.length <= 100000 || \"ExecutionNotes has too many characters (100000)\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class AssemblyVesselRequirementReadOnly extends ModelObject {\n\n /**\n * Parent ProcessGroup.\n */\n public assemblyProcessGroupId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.assemblyProcessGroupId = Guid.fromString(jsonSerializedObject.assemblyProcessGroupId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.assemblyProcessGroupId = this.assemblyProcessGroupId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"assemblyProcessGroupId\", rule: (v: any) => !v.isEmpty() || \"AssemblyVesselRequirementReadOnly.AssemblyProcessGroupId cannot be empty\"},\n ];\n}\n\n\nexport class AssemblyVesselRequirement extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Required Vessel Capability.\n */\n public vesselCapabilityId: Guid = Guid.createEmpty();\n /**\n * Required minimum capacity of Vessel in Litres\n * Not Negative\n */\n public capacityLitres: number = 0;\n public readOnly: AssemblyVesselRequirementReadOnly = new AssemblyVesselRequirementReadOnly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.vesselCapabilityId = Guid.fromString(jsonSerializedObject.vesselCapabilityId);\n this.capacityLitres = jsonSerializedObject.capacityLitres;\n this.readOnly = new AssemblyVesselRequirementReadOnly(jsonSerializedObject.readOnly);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.vesselCapabilityId = this.vesselCapabilityId.toString();\n toRet.capacityLitres = this.capacityLitres;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"AssemblyVesselRequirement.Id cannot be empty\"},\n {field: \"vesselCapabilityId\", rule: (v: any) => !v.isEmpty() || \"AssemblyVesselRequirement.VesselCapabilityId cannot be empty\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class AssemblyProcessGroupReadOnly extends ModelObject {\n\n /**\n * Assembly Id\n */\n public assemblyId: Guid = Guid.createEmpty();\n /**\n * Sequence (for ordering Lines).\n */\n public sequence: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.assemblyId = Guid.fromString(jsonSerializedObject.assemblyId);\n this.sequence = jsonSerializedObject.sequence;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.assemblyId = this.assemblyId.toString();\n toRet.sequence = this.sequence;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"assemblyId\", rule: (v: any) => !v.isEmpty() || \"AssemblyProcessGroupReadOnly.AssemblyId cannot be empty\"},\n {field: \"sequence\", rule: (v: any) => v == null || v >= -2147483648 || \"Sequence is not greater than minimum allowed value: -2147483648\"},\n {field: \"sequence\", rule: (v: any) => v == null || v <= 2147483647 || \"Sequence is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class AssemblyProcessGroup extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Name\n * Not Nullable\n * Max Length : 1000\n */\n public name: string = \"\";\n /**\n * Duration in days this process group is planned to take.\n * Not Negative\n */\n public plannedDurationDays: number = 0;\n public readOnly: AssemblyProcessGroupReadOnly = new AssemblyProcessGroupReadOnly();\n public lines: AssemblyProcessLine[] = [];\n public vesselRequirements: AssemblyVesselRequirement[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.name = jsonSerializedObject.name;\n this.plannedDurationDays = jsonSerializedObject.plannedDurationDays;\n this.readOnly = new AssemblyProcessGroupReadOnly(jsonSerializedObject.readOnly);\n this.lines = jsonSerializedObject.lines.map((v: any) => new AssemblyProcessLine(v));\n this.vesselRequirements = jsonSerializedObject.vesselRequirements.map((v: any) => new AssemblyVesselRequirement(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.name = this.name;\n toRet.plannedDurationDays = this.plannedDurationDays;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n toRet.vesselRequirements = this.vesselRequirements.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"AssemblyProcessGroup.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"plannedDurationDays\", rule: (v: any) => v == null || v >= 0 || \"PlannedDurationDays is not greater than minimum allowed value: 0\"},\n {field: \"plannedDurationDays\", rule: (v: any) => v == null || v <= 2147483647 || \"PlannedDurationDays is above maximum allowed value: 2147483647\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AssemblyProcessLine[]).reduce((acc: Array, curr: AssemblyProcessLine) => acc.concat(curr.validate()), new Array());\n }},\n {field: \"vesselRequirements\", rule: (v: any) => !!v || \"vesselRequirements is required\"},\n {field: \"vesselRequirements\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AssemblyVesselRequirement[]).reduce((acc: Array, curr: AssemblyVesselRequirement) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class Assembly extends BaseModelObject {\n\n public header: AssemblyHeader = new AssemblyHeader();\n public ingredients: AssemblyIngredientLineWithUsed[] = [];\n public itemsProduced: AssemblyItemProducedLine[] = [];\n public calculatedCosts: AssemblyCalculatedCosts = new AssemblyCalculatedCosts();\n public processGroups: AssemblyProcessGroup[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.header = new AssemblyHeader(jsonSerializedObject.header);\n this.ingredients = jsonSerializedObject.ingredients.map((v: any) => new AssemblyIngredientLineWithUsed(v));\n this.itemsProduced = jsonSerializedObject.itemsProduced.map((v: any) => new AssemblyItemProducedLine(v));\n this.calculatedCosts = new AssemblyCalculatedCosts(jsonSerializedObject.calculatedCosts);\n this.processGroups = jsonSerializedObject.processGroups.map((v: any) => new AssemblyProcessGroup(v));\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.header = this.header.toJsonSerializedObject();\n toRet.ingredients = this.ingredients.map(v => v.toJsonSerializedObject());\n toRet.itemsProduced = this.itemsProduced.map(v => v.toJsonSerializedObject());\n toRet.calculatedCosts = this.calculatedCosts.toJsonSerializedObject();\n toRet.processGroups = this.processGroups.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n {field: \"ingredients\", rule: (v: any) => !!v || \"ingredients is required\"},\n {field: \"ingredients\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AssemblyIngredientLineWithUsed[]).reduce((acc: Array, curr: AssemblyIngredientLineWithUsed) => acc.concat(curr.validate()), new Array());\n }},\n {field: \"itemsProduced\", rule: (v: any) => !!v || \"itemsProduced is required\"},\n {field: \"itemsProduced\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AssemblyItemProducedLine[]).reduce((acc: Array, curr: AssemblyItemProducedLine) => acc.concat(curr.validate()), new Array());\n }},\n {field: \"calculatedCosts\", rule: (v: any) => !!v || \"calculatedCosts is required\"},\n {field: \"calculatedCosts\", rule: (v: any) => v.validate()},\n {field: \"processGroups\", rule: (v: any) => !!v || \"processGroups is required\"},\n {field: \"processGroups\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AssemblyProcessGroup[]).reduce((acc: Array, curr: AssemblyProcessGroup) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class IngredientUsedModification extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Total cost of ingredients used in this line.\n */\n public totalCost: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.totalCost = jsonSerializedObject.totalCost;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.totalCost = this.totalCost;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"IngredientUsedModification.Id cannot be empty\"},\n ];\n}\n\n\nexport class AssemblySummary extends ModelObject {\n\n public header: AssemblyHeader = new AssemblyHeader();\n public calculatedCosts: AssemblyCalculatedCosts = new AssemblyCalculatedCosts();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.header = new AssemblyHeader(jsonSerializedObject.header);\n this.calculatedCosts = new AssemblyCalculatedCosts(jsonSerializedObject.calculatedCosts);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.header = this.header.toJsonSerializedObject();\n toRet.calculatedCosts = this.calculatedCosts.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n {field: \"calculatedCosts\", rule: (v: any) => !!v || \"calculatedCosts is required\"},\n {field: \"calculatedCosts\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class AssemblyFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _statuses: EnumAssemblyStatus[] | null = null;\n /**\n * If provided only matching statuses are returned\n */\n public get statuses(): EnumAssemblyStatus[] | null { return this._statuses }\n public set statuses(value: EnumAssemblyStatus[] | null) {\n this._statuses = value === undefined ? null : value;\n }\n private _assemblyTypes: EnumAssemblyType[] | null = null;\n /**\n * If provided only matching types are returned\n */\n public get assemblyTypes(): EnumAssemblyType[] | null { return this._assemblyTypes }\n public set assemblyTypes(value: EnumAssemblyType[] | null) {\n this._assemblyTypes = value === undefined ? null : value;\n }\n private _fromTargetDateInclusive: LocalDate | null = null;\n /**\n * Minimum Due Date\n */\n public get fromTargetDateInclusive(): LocalDate | null { return this._fromTargetDateInclusive }\n public set fromTargetDateInclusive(value: LocalDate | null) {\n this._fromTargetDateInclusive = value === undefined ? null : value;\n }\n private _toTargetDateInclusive: LocalDate | null = null;\n /**\n * Maximum Due Date\n */\n public get toTargetDateInclusive(): LocalDate | null { return this._toTargetDateInclusive }\n public set toTargetDateInclusive(value: LocalDate | null) {\n this._toTargetDateInclusive = value === undefined ? null : value;\n }\n private _fromPlannedStartDateInclusive: LocalDate | null = null;\n /**\n * Minimum Planned Start Date\n */\n public get fromPlannedStartDateInclusive(): LocalDate | null { return this._fromPlannedStartDateInclusive }\n public set fromPlannedStartDateInclusive(value: LocalDate | null) {\n this._fromPlannedStartDateInclusive = value === undefined ? null : value;\n }\n private _toPlannedStartDateInclusive: LocalDate | null = null;\n /**\n * Maximum Planned Start Date\n */\n public get toPlannedStartDateInclusive(): LocalDate | null { return this._toPlannedStartDateInclusive }\n public set toPlannedStartDateInclusive(value: LocalDate | null) {\n this._toPlannedStartDateInclusive = value === undefined ? null : value;\n }\n private _stockLocations: Guid[] | null = null;\n public get stockLocations(): Guid[] | null { return this._stockLocations }\n public set stockLocations(value: Guid[] | null) {\n this._stockLocations = value === undefined ? null : value;\n }\n /**\n * Yes = Hidden Only, No = Not Hidden Only, Either = Either\n */\n public hiddenOrNot: EnumYesNoEither = EnumYesNoEither.either;\n private _fromCompletedAt: Instant | null = null;\n public get fromCompletedAt(): Instant | null { return this._fromCompletedAt }\n public set fromCompletedAt(value: Instant | null) {\n this._fromCompletedAt = value === undefined ? null : value;\n }\n private _toCompletedAt: Instant | null = null;\n public get toCompletedAt(): Instant | null { return this._toCompletedAt }\n public set toCompletedAt(value: Instant | null) {\n this._toCompletedAt = value === undefined ? null : value;\n }\n private _fromStartedAt: Instant | null = null;\n public get fromStartedAt(): Instant | null { return this._fromStartedAt }\n public set fromStartedAt(value: Instant | null) {\n this._fromStartedAt = value === undefined ? null : value;\n }\n private _toStartedAt: Instant | null = null;\n public get toStartedAt(): Instant | null { return this._toStartedAt }\n public set toStartedAt(value: Instant | null) {\n this._toStartedAt = value === undefined ? null : value;\n }\n private _hasOutput: boolean | null = null;\n public get hasOutput(): boolean | null { return this._hasOutput }\n public set hasOutput(value: boolean | null) {\n this._hasOutput = value === undefined ? null : value;\n }\n private _hasUrn: boolean | null = null;\n public get hasUrn(): boolean | null { return this._hasUrn }\n public set hasUrn(value: boolean | null) {\n this._hasUrn = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.statuses = jsonSerializedObject.statuses == null ? null : jsonSerializedObject.statuses.map((v: any) => EnumAssemblyStatus.getByValue(v));\n this.assemblyTypes = jsonSerializedObject.assemblyTypes == null ? null : jsonSerializedObject.assemblyTypes.map((v: any) => EnumAssemblyType.getByValue(v));\n this.fromTargetDateInclusive = jsonSerializedObject.fromTargetDateInclusive == null ? null : LocalDate.parse(jsonSerializedObject.fromTargetDateInclusive);\n this.toTargetDateInclusive = jsonSerializedObject.toTargetDateInclusive == null ? null : LocalDate.parse(jsonSerializedObject.toTargetDateInclusive);\n this.fromPlannedStartDateInclusive = jsonSerializedObject.fromPlannedStartDateInclusive == null ? null : LocalDate.parse(jsonSerializedObject.fromPlannedStartDateInclusive);\n this.toPlannedStartDateInclusive = jsonSerializedObject.toPlannedStartDateInclusive == null ? null : LocalDate.parse(jsonSerializedObject.toPlannedStartDateInclusive);\n this.stockLocations = jsonSerializedObject.stockLocations == null ? null : jsonSerializedObject.stockLocations.map((v: any) => Guid.fromString(v));\n this.hiddenOrNot = EnumYesNoEither.getByValue(jsonSerializedObject.hiddenOrNot, this.hiddenOrNot);\n this.fromCompletedAt = jsonSerializedObject.fromCompletedAt == null ? null : Instant.parse(jsonSerializedObject.fromCompletedAt);\n this.toCompletedAt = jsonSerializedObject.toCompletedAt == null ? null : Instant.parse(jsonSerializedObject.toCompletedAt);\n this.fromStartedAt = jsonSerializedObject.fromStartedAt == null ? null : Instant.parse(jsonSerializedObject.fromStartedAt);\n this.toStartedAt = jsonSerializedObject.toStartedAt == null ? null : Instant.parse(jsonSerializedObject.toStartedAt);\n this.hasOutput = jsonSerializedObject.hasOutput == null ? null : jsonSerializedObject.hasOutput;\n this.hasUrn = jsonSerializedObject.hasUrn == null ? null : jsonSerializedObject.hasUrn;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.statuses = this.statuses == null ? null : this.statuses.map(v => v.value);\n toRet.assemblyTypes = this.assemblyTypes == null ? null : this.assemblyTypes.map(v => v.value);\n toRet.fromTargetDateInclusive = this.fromTargetDateInclusive == null ? null : this.fromTargetDateInclusive.toString();\n toRet.toTargetDateInclusive = this.toTargetDateInclusive == null ? null : this.toTargetDateInclusive.toString();\n toRet.fromPlannedStartDateInclusive = this.fromPlannedStartDateInclusive == null ? null : this.fromPlannedStartDateInclusive.toString();\n toRet.toPlannedStartDateInclusive = this.toPlannedStartDateInclusive == null ? null : this.toPlannedStartDateInclusive.toString();\n toRet.stockLocations = this.stockLocations == null ? null : this.stockLocations.map(v => v.toString());\n toRet.hiddenOrNot = this.hiddenOrNot.value;\n toRet.fromCompletedAt = this.fromCompletedAt == null ? null : this.fromCompletedAt.toString();\n toRet.toCompletedAt = this.toCompletedAt == null ? null : this.toCompletedAt.toString();\n toRet.fromStartedAt = this.fromStartedAt == null ? null : this.fromStartedAt.toString();\n toRet.toStartedAt = this.toStartedAt == null ? null : this.toStartedAt.toString();\n toRet.hasOutput = this.hasOutput == null ? null : this.hasOutput;\n toRet.hasUrn = this.hasUrn == null ? null : this.hasUrn;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class FilteredAssemblySummaries extends ModelObject {\n\n public matchingCount: number = 0;\n public assemblySummaries: AssemblySummary[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.assemblySummaries = jsonSerializedObject.assemblySummaries.map((v: any) => new AssemblySummary(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.assemblySummaries = this.assemblySummaries.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"assemblySummaries\", rule: (v: any) => !!v || \"assemblySummaries is required\"},\n {field: \"assemblySummaries\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AssemblySummary[]).reduce((acc: Array, curr: AssemblySummary) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class AssemblyStockTimeRange extends ModelObject {\n\n public includeIngredientsUsedFromStock: boolean = false;\n public includeOutputsToStock: boolean = false;\n private _fromInstant: Instant | null = null;\n public get fromInstant(): Instant | null { return this._fromInstant }\n public set fromInstant(value: Instant | null) {\n this._fromInstant = value === undefined ? null : value;\n }\n private _beforeInstant: Instant | null = null;\n public get beforeInstant(): Instant | null { return this._beforeInstant }\n public set beforeInstant(value: Instant | null) {\n this._beforeInstant = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.includeIngredientsUsedFromStock = jsonSerializedObject.includeIngredientsUsedFromStock;\n this.includeOutputsToStock = jsonSerializedObject.includeOutputsToStock;\n this.fromInstant = jsonSerializedObject.fromInstant == null ? null : Instant.parse(jsonSerializedObject.fromInstant);\n this.beforeInstant = jsonSerializedObject.beforeInstant == null ? null : Instant.parse(jsonSerializedObject.beforeInstant);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.includeIngredientsUsedFromStock = this.includeIngredientsUsedFromStock;\n toRet.includeOutputsToStock = this.includeOutputsToStock;\n toRet.fromInstant = this.fromInstant == null ? null : this.fromInstant.toString();\n toRet.beforeInstant = this.beforeInstant == null ? null : this.beforeInstant.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class FilteredAssemblyHeaders extends ModelObject {\n\n public matchingCount: number = 0;\n public assemblyHeaders: AssemblyHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.assemblyHeaders = jsonSerializedObject.assemblyHeaders.map((v: any) => new AssemblyHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.assemblyHeaders = this.assemblyHeaders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"assemblyHeaders\", rule: (v: any) => !!v || \"assemblyHeaders is required\"},\n {field: \"assemblyHeaders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AssemblyHeader[]).reduce((acc: Array, curr: AssemblyHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class AssembledBatchDetails extends ModelObject {\n\n public stockItemId: Guid = Guid.createEmpty();\n public urn: string = \"\";\n public oldestAssembledDate: LocalDate = LocalDate.ofEpochDay(0);\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.urn = jsonSerializedObject.urn;\n this.oldestAssembledDate = LocalDate.parse(jsonSerializedObject.oldestAssembledDate);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.urn = this.urn;\n toRet.oldestAssembledDate = this.oldestAssembledDate.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"AssembledBatchDetails.StockItemId cannot be empty\"},\n ];\n}\n\n\nexport class AssemblyStockExpectationLine extends ModelObject {\n\n public assemblyId: Guid = Guid.createEmpty();\n public status: EnumAssemblyStatus = EnumAssemblyStatus.open;\n public expectedCompletionDate: LocalDate = LocalDate.ofEpochDay(0);\n public stockLocationId: Guid = Guid.createEmpty();\n /**\n * Expected stock change. +ve means stock will increase.\n */\n public signedQuantity: number = 0;\n /**\n * Identifies if this is an expected ingredient (opposed to expected output). Explicit as sign of SignedQuantity may not correlate.\n */\n public isIngredient: boolean = false;\n public stockItemId: Guid = Guid.createEmpty();\n public unitOfMeasureId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.assemblyId = Guid.fromString(jsonSerializedObject.assemblyId);\n this.status = EnumAssemblyStatus.getByValue(jsonSerializedObject.status, this.status);\n this.expectedCompletionDate = LocalDate.parse(jsonSerializedObject.expectedCompletionDate);\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.signedQuantity = jsonSerializedObject.signedQuantity;\n this.isIngredient = jsonSerializedObject.isIngredient;\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.assemblyId = this.assemblyId.toString();\n toRet.status = this.status.value;\n toRet.expectedCompletionDate = this.expectedCompletionDate.toString();\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.signedQuantity = this.signedQuantity;\n toRet.isIngredient = this.isIngredient;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"assemblyId\", rule: (v: any) => !v.isEmpty() || \"AssemblyStockExpectationLine.AssemblyId cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \"AssemblyStockExpectationLine.StockLocationId cannot be empty\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"AssemblyStockExpectationLine.StockItemId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"AssemblyStockExpectationLine.UnitOfMeasureId cannot be empty\"},\n ];\n}\n\n\nexport class ProcessLineForAssembly extends ModelObject {\n\n public assemblyId: Guid = Guid.createEmpty();\n public processLine: AssemblyProcessLine = new AssemblyProcessLine();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.assemblyId = Guid.fromString(jsonSerializedObject.assemblyId);\n this.processLine = new AssemblyProcessLine(jsonSerializedObject.processLine);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.assemblyId = this.assemblyId.toString();\n toRet.processLine = this.processLine.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"assemblyId\", rule: (v: any) => !v.isEmpty() || \"ProcessLineForAssembly.AssemblyId cannot be empty\"},\n {field: \"processLine\", rule: (v: any) => !!v || \"processLine is required\"},\n {field: \"processLine\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class AssemblyLiquidEvaluation extends ModelObject {\n\n public assemblyId: Guid = Guid.createEmpty();\n public stockLocationId: Guid = Guid.createEmpty();\n public heldAtStartOfPeriodLitres: number = 0;\n public heldAtEndOfPeriodLitres: number = 0;\n public producedLitres: number = 0;\n public reprocessedLitres: number = 0;\n public discardedLitres: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.assemblyId = Guid.fromString(jsonSerializedObject.assemblyId);\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.heldAtStartOfPeriodLitres = jsonSerializedObject.heldAtStartOfPeriodLitres;\n this.heldAtEndOfPeriodLitres = jsonSerializedObject.heldAtEndOfPeriodLitres;\n this.producedLitres = jsonSerializedObject.producedLitres;\n this.reprocessedLitres = jsonSerializedObject.reprocessedLitres;\n this.discardedLitres = jsonSerializedObject.discardedLitres;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.assemblyId = this.assemblyId.toString();\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.heldAtStartOfPeriodLitres = this.heldAtStartOfPeriodLitres;\n toRet.heldAtEndOfPeriodLitres = this.heldAtEndOfPeriodLitres;\n toRet.producedLitres = this.producedLitres;\n toRet.reprocessedLitres = this.reprocessedLitres;\n toRet.discardedLitres = this.discardedLitres;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"assemblyId\", rule: (v: any) => !v.isEmpty() || \"AssemblyLiquidEvaluation.AssemblyId cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \"AssemblyLiquidEvaluation.StockLocationId cannot be empty\"},\n ];\n}\n\n\nexport class GetAssemblyRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public assemblyId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.assemblyId = Guid.fromString(jsonSerializedObject.assemblyId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.assemblyId = this.assemblyId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"assemblyId\", rule: (v: any) => !v.isEmpty() || \".AssemblyId cannot be empty\"},\n ];\n}\n\n\nexport class GetAssemblyResponse extends ModelObject {\n\n public assembly: Assembly = new Assembly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.assembly = new Assembly(jsonSerializedObject.assembly);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.assembly = this.assembly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"assembly\", rule: (v: any) => !!v || \"assembly is required\"},\n {field: \"assembly\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetAssembliesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public assemblyIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.assemblyIds = jsonSerializedObject.assemblyIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.assemblyIds = this.assemblyIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAssembliesResponse extends ModelObject {\n\n public assemblies: Assembly[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.assemblies = jsonSerializedObject.assemblies.map((v: any) => new Assembly(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.assemblies = this.assemblies.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"assemblies\", rule: (v: any) => !!v || \"assemblies is required\"},\n {field: \"assemblies\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Assembly[]).reduce((acc: Array, curr: Assembly) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SavePlannedAssemblyRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public header: AssemblyHeader = new AssemblyHeader();\n public ingredients: readonly AssemblyIngredientLine[] = [];\n public processGroups: readonly AssemblyProcessGroup[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.header = new AssemblyHeader(jsonSerializedObject.header);\n this.ingredients = jsonSerializedObject.ingredients.map((v: any) => new AssemblyIngredientLine(v));\n this.processGroups = jsonSerializedObject.processGroups.map((v: any) => new AssemblyProcessGroup(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.header = this.header.toJsonSerializedObject();\n toRet.ingredients = this.ingredients.map(v => v.toJsonSerializedObject());\n toRet.processGroups = this.processGroups.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n {field: \"ingredients\", rule: (v: any) => !!v || \"ingredients is required\"},\n {field: \"ingredients\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AssemblyIngredientLine[]).reduce((acc: Array, curr: AssemblyIngredientLine) => acc.concat(curr.validate()), new Array());\n }},\n {field: \"processGroups\", rule: (v: any) => !!v || \"processGroups is required\"},\n {field: \"processGroups\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AssemblyProcessGroup[]).reduce((acc: Array, curr: AssemblyProcessGroup) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SavePlannedAssemblyResponse extends ModelObject {\n\n public assembly: Assembly = new Assembly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.assembly = new Assembly(jsonSerializedObject.assembly);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.assembly = this.assembly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"assembly\", rule: (v: any) => !!v || \"assembly is required\"},\n {field: \"assembly\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetAssemblyIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public assemblyId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.assemblyId = Guid.fromString(jsonSerializedObject.assemblyId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.assemblyId = this.assemblyId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"assemblyId\", rule: (v: any) => !v.isEmpty() || \".AssemblyId cannot be empty\"},\n ];\n}\n\n\nexport class CancelAssemblyRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public assemblyId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.assemblyId = Guid.fromString(jsonSerializedObject.assemblyId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.assemblyId = this.assemblyId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"assemblyId\", rule: (v: any) => !v.isEmpty() || \".AssemblyId cannot be empty\"},\n ];\n}\n\n\nexport class BeginAssemblyRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public assemblyId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.assemblyId = Guid.fromString(jsonSerializedObject.assemblyId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.assemblyId = this.assemblyId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"assemblyId\", rule: (v: any) => !v.isEmpty() || \".AssemblyId cannot be empty\"},\n ];\n}\n\n\nexport class BeginAssemblyResponse extends ModelObject {\n\n public assembly: Assembly = new Assembly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.assembly = new Assembly(jsonSerializedObject.assembly);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.assembly = this.assembly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"assembly\", rule: (v: any) => !!v || \"assembly is required\"},\n {field: \"assembly\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveAssemblyProgressRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public assemblyHeader: AssemblyHeader = new AssemblyHeader();\n public ingredients: readonly AssemblyIngredientLine[] = [];\n public ingredientsToAddToUsedList: readonly AssemblyIngredientUsedLine[] = [];\n public processGroups: readonly AssemblyProcessGroup[] = [];\n public complete: boolean = false;\n public ingredientUsedModifications: readonly IngredientUsedModification[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.assemblyHeader = new AssemblyHeader(jsonSerializedObject.assemblyHeader);\n this.ingredients = jsonSerializedObject.ingredients.map((v: any) => new AssemblyIngredientLine(v));\n this.ingredientsToAddToUsedList = jsonSerializedObject.ingredientsToAddToUsedList.map((v: any) => new AssemblyIngredientUsedLine(v));\n this.processGroups = jsonSerializedObject.processGroups.map((v: any) => new AssemblyProcessGroup(v));\n this.complete = jsonSerializedObject.complete;\n this.ingredientUsedModifications = jsonSerializedObject.ingredientUsedModifications.map((v: any) => new IngredientUsedModification(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.assemblyHeader = this.assemblyHeader.toJsonSerializedObject();\n toRet.ingredients = this.ingredients.map(v => v.toJsonSerializedObject());\n toRet.ingredientsToAddToUsedList = this.ingredientsToAddToUsedList.map(v => v.toJsonSerializedObject());\n toRet.processGroups = this.processGroups.map(v => v.toJsonSerializedObject());\n toRet.complete = this.complete;\n toRet.ingredientUsedModifications = this.ingredientUsedModifications.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"assemblyHeader\", rule: (v: any) => !!v || \"assemblyHeader is required\"},\n {field: \"assemblyHeader\", rule: (v: any) => v.validate()},\n {field: \"ingredients\", rule: (v: any) => !!v || \"ingredients is required\"},\n {field: \"ingredients\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AssemblyIngredientLine[]).reduce((acc: Array, curr: AssemblyIngredientLine) => acc.concat(curr.validate()), new Array());\n }},\n {field: \"ingredientsToAddToUsedList\", rule: (v: any) => !!v || \"ingredientsToAddToUsedList is required\"},\n {field: \"ingredientsToAddToUsedList\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AssemblyIngredientUsedLine[]).reduce((acc: Array, curr: AssemblyIngredientUsedLine) => acc.concat(curr.validate()), new Array());\n }},\n {field: \"processGroups\", rule: (v: any) => !!v || \"processGroups is required\"},\n {field: \"processGroups\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AssemblyProcessGroup[]).reduce((acc: Array, curr: AssemblyProcessGroup) => acc.concat(curr.validate()), new Array());\n }},\n {field: \"ingredientUsedModifications\", rule: (v: any) => !!v || \"ingredientUsedModifications is required\"},\n {field: \"ingredientUsedModifications\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as IngredientUsedModification[]).reduce((acc: Array, curr: IngredientUsedModification) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class UncompleteAssemblyRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public assemblyId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.assemblyId = Guid.fromString(jsonSerializedObject.assemblyId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.assemblyId = this.assemblyId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"assemblyId\", rule: (v: any) => !v.isEmpty() || \".AssemblyId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllAssemblySummariesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllAssemblySummariesResponse extends ModelObject {\n\n public assemblySummaries: AssemblySummary[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.assemblySummaries = jsonSerializedObject.assemblySummaries.map((v: any) => new AssemblySummary(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.assemblySummaries = this.assemblySummaries.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"assemblySummaries\", rule: (v: any) => !!v || \"assemblySummaries is required\"},\n {field: \"assemblySummaries\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AssemblySummary[]).reduce((acc: Array, curr: AssemblySummary) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetFilteredAssemblySummariesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: AssemblyFilter = new AssemblyFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new AssemblyFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetFilteredAssemblySummariesResponse extends ModelObject {\n\n public results: FilteredAssemblySummaries = new FilteredAssemblySummaries();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredAssemblySummaries(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetAssemblyHeadersByFilterAndStockTimeRangeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: AssemblyFilter = new AssemblyFilter();\n public stockTimeRange: AssemblyStockTimeRange = new AssemblyStockTimeRange();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new AssemblyFilter(jsonSerializedObject.filter);\n this.stockTimeRange = new AssemblyStockTimeRange(jsonSerializedObject.stockTimeRange);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n toRet.stockTimeRange = this.stockTimeRange.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n {field: \"stockTimeRange\", rule: (v: any) => !!v || \"stockTimeRange is required\"},\n {field: \"stockTimeRange\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetAssemblyHeadersByFilterAndStockTimeRangeResponse extends ModelObject {\n\n public results: FilteredAssemblyHeaders = new FilteredAssemblyHeaders();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredAssemblyHeaders(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetAssembledBatchDetailsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockItemIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockItemIds = jsonSerializedObject.stockItemIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockItemIds = this.stockItemIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAssembledBatchDetailsResponse extends ModelObject {\n\n public assembledBatchDetails: AssembledBatchDetails[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.assembledBatchDetails = jsonSerializedObject.assembledBatchDetails.map((v: any) => new AssembledBatchDetails(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.assembledBatchDetails = this.assembledBatchDetails.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"assembledBatchDetails\", rule: (v: any) => !!v || \"assembledBatchDetails is required\"},\n {field: \"assembledBatchDetails\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AssembledBatchDetails[]).reduce((acc: Array, curr: AssembledBatchDetails) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class AddOutputToAnotherAssemblyRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n /**\n * Source Assembly, which must be InProgress.\n */\n public sourceAssemblyId: Guid = Guid.createEmpty();\n /**\n * Target Assembly, which must be InProgress.\n */\n public targetAssemblyId: Guid = Guid.createEmpty();\n /**\n * StockItem. If not a by-product then must match any expected or previous output of Source Assembly.\n */\n public stockItemId: Guid = Guid.createEmpty();\n public quantity: number = 0;\n /**\n * Unit Cost Price of output StockItem.\n */\n public stockItemCostPrice: number = 0;\n public unitOfMeasureId: Guid = Guid.createEmpty();\n /**\n * If true, the expected output of source assembly (if not null) will be reduced by the quantity.\n */\n public adjustSourceExpectedOutput: boolean = false;\n /**\n * If true, the expected ingredient of this stock item of target assembly (if any) will be reduced by the quantity.\n */\n public adjustTargetExpectedIngredients: boolean = false;\n /**\n * Whether this output was a by-product of the assembly rather than the main output item.\n */\n public isByProduct: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.sourceAssemblyId = Guid.fromString(jsonSerializedObject.sourceAssemblyId);\n this.targetAssemblyId = Guid.fromString(jsonSerializedObject.targetAssemblyId);\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.quantity = jsonSerializedObject.quantity;\n this.stockItemCostPrice = jsonSerializedObject.stockItemCostPrice;\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n this.adjustSourceExpectedOutput = jsonSerializedObject.adjustSourceExpectedOutput;\n this.adjustTargetExpectedIngredients = jsonSerializedObject.adjustTargetExpectedIngredients;\n this.isByProduct = jsonSerializedObject.isByProduct;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.sourceAssemblyId = this.sourceAssemblyId.toString();\n toRet.targetAssemblyId = this.targetAssemblyId.toString();\n toRet.stockItemId = this.stockItemId.toString();\n toRet.quantity = this.quantity;\n toRet.stockItemCostPrice = this.stockItemCostPrice;\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n toRet.adjustSourceExpectedOutput = this.adjustSourceExpectedOutput;\n toRet.adjustTargetExpectedIngredients = this.adjustTargetExpectedIngredients;\n toRet.isByProduct = this.isByProduct;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"sourceAssemblyId\", rule: (v: any) => !v.isEmpty() || \".SourceAssemblyId cannot be empty\"},\n {field: \"targetAssemblyId\", rule: (v: any) => !v.isEmpty() || \".TargetAssemblyId cannot be empty\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \".StockItemId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \".UnitOfMeasureId cannot be empty\"},\n ];\n}\n\n\nexport class GetAssemblyStockExpectationsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n private _limitStockLocationIds: readonly Guid[] | null = null;\n public get limitStockLocationIds(): readonly Guid[] | null { return this._limitStockLocationIds }\n public set limitStockLocationIds(value: readonly Guid[] | null) {\n this._limitStockLocationIds = value === undefined ? null : value;\n }\n private _limitStockItemIds: readonly Guid[] | null = null;\n public get limitStockItemIds(): readonly Guid[] | null { return this._limitStockItemIds }\n public set limitStockItemIds(value: readonly Guid[] | null) {\n this._limitStockItemIds = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.limitStockLocationIds = jsonSerializedObject.limitStockLocationIds == null ? null : jsonSerializedObject.limitStockLocationIds.map((v: any) => Guid.fromString(v));\n this.limitStockItemIds = jsonSerializedObject.limitStockItemIds == null ? null : jsonSerializedObject.limitStockItemIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.limitStockLocationIds = this.limitStockLocationIds == null ? null : this.limitStockLocationIds.map(v => v.toString());\n toRet.limitStockItemIds = this.limitStockItemIds == null ? null : this.limitStockItemIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAssemblyStockExpectationsResponse extends ModelObject {\n\n public results: AssemblyStockExpectationLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new AssemblyStockExpectationLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AssemblyStockExpectationLine[]).reduce((acc: Array, curr: AssemblyStockExpectationLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAssemblyHeadersByIdsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public assemblyIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.assemblyIds = jsonSerializedObject.assemblyIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.assemblyIds = this.assemblyIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAssemblyHeadersByIdsResponse extends ModelObject {\n\n public assemblyHeaders: AssemblyHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.assemblyHeaders = jsonSerializedObject.assemblyHeaders.map((v: any) => new AssemblyHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.assemblyHeaders = this.assemblyHeaders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"assemblyHeaders\", rule: (v: any) => !!v || \"assemblyHeaders is required\"},\n {field: \"assemblyHeaders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AssemblyHeader[]).reduce((acc: Array, curr: AssemblyHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllAssemblyProcessLinesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllAssemblyProcessLinesResponse extends ModelObject {\n\n public processes: ProcessLineForAssembly[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.processes = jsonSerializedObject.processes.map((v: any) => new ProcessLineForAssembly(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.processes = this.processes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"processes\", rule: (v: any) => !!v || \"processes is required\"},\n {field: \"processes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessLineForAssembly[]).reduce((acc: Array, curr: ProcessLineForAssembly) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAssemblyProcessLinesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processIds = jsonSerializedObject.processIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processIds = this.processIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAssemblyProcessLinesResponse extends ModelObject {\n\n public processes: ProcessLineForAssembly[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.processes = jsonSerializedObject.processes.map((v: any) => new ProcessLineForAssembly(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.processes = this.processes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"processes\", rule: (v: any) => !!v || \"processes is required\"},\n {field: \"processes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessLineForAssembly[]).reduce((acc: Array, curr: ProcessLineForAssembly) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAssemblyIngredientsStillExpectedRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public assemblyIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.assemblyIds = jsonSerializedObject.assemblyIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.assemblyIds = this.assemblyIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAssemblyIngredientsStillExpectedResponse extends ModelObject {\n\n public ingredients: AssemblyIngredientLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.ingredients = jsonSerializedObject.ingredients.map((v: any) => new AssemblyIngredientLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.ingredients = this.ingredients.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"ingredients\", rule: (v: any) => !!v || \"ingredients is required\"},\n {field: \"ingredients\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AssemblyIngredientLine[]).reduce((acc: Array, curr: AssemblyIngredientLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SavePrintUpdatesForAssemblyRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public assemblyId: Guid = Guid.createEmpty();\n public hasPrintedLabels: boolean = false;\n private _bestBeforeDate: LocalDate | null = null;\n public get bestBeforeDate(): LocalDate | null { return this._bestBeforeDate }\n public set bestBeforeDate(value: LocalDate | null) {\n this._bestBeforeDate = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.assemblyId = Guid.fromString(jsonSerializedObject.assemblyId);\n this.hasPrintedLabels = jsonSerializedObject.hasPrintedLabels;\n this.bestBeforeDate = jsonSerializedObject.bestBeforeDate == null ? null : LocalDate.parse(jsonSerializedObject.bestBeforeDate);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.assemblyId = this.assemblyId.toString();\n toRet.hasPrintedLabels = this.hasPrintedLabels;\n toRet.bestBeforeDate = this.bestBeforeDate == null ? null : this.bestBeforeDate.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"assemblyId\", rule: (v: any) => !v.isEmpty() || \".AssemblyId cannot be empty\"},\n ];\n}\n\n\nexport class EvaluateLiquidProductionRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public fromDate: LocalDate = LocalDate.ofEpochDay(0);\n public toDate: LocalDate = LocalDate.ofEpochDay(0);\n public alcoholTypes: readonly EnumAlcoholType[] = [];\n private _stockLocations: readonly Guid[] | null = null;\n public get stockLocations(): readonly Guid[] | null { return this._stockLocations }\n public set stockLocations(value: readonly Guid[] | null) {\n this._stockLocations = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.fromDate = LocalDate.parse(jsonSerializedObject.fromDate);\n this.toDate = LocalDate.parse(jsonSerializedObject.toDate);\n this.alcoholTypes = jsonSerializedObject.alcoholTypes.map((v: any) => EnumAlcoholType.getByValue(v));\n this.stockLocations = jsonSerializedObject.stockLocations == null ? null : jsonSerializedObject.stockLocations.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.fromDate = this.fromDate.toString();\n toRet.toDate = this.toDate.toString();\n toRet.alcoholTypes = this.alcoholTypes.map(v => v.value);\n toRet.stockLocations = this.stockLocations == null ? null : this.stockLocations.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class EvaluateLiquidProductionResponse extends ModelObject {\n\n public results: AssemblyLiquidEvaluation[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new AssemblyLiquidEvaluation(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AssemblyLiquidEvaluation[]).reduce((acc: Array, curr: AssemblyLiquidEvaluation) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class AddOutputToAssemblyRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public assemblyHeader: AssemblyHeader = new AssemblyHeader();\n public itemsToAddToProducedList: readonly AssemblyItemProducedLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.assemblyHeader = new AssemblyHeader(jsonSerializedObject.assemblyHeader);\n this.itemsToAddToProducedList = jsonSerializedObject.itemsToAddToProducedList.map((v: any) => new AssemblyItemProducedLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.assemblyHeader = this.assemblyHeader.toJsonSerializedObject();\n toRet.itemsToAddToProducedList = this.itemsToAddToProducedList.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"assemblyHeader\", rule: (v: any) => !!v || \"assemblyHeader is required\"},\n {field: \"assemblyHeader\", rule: (v: any) => v.validate()},\n {field: \"itemsToAddToProducedList\", rule: (v: any) => !!v || \"itemsToAddToProducedList is required\"},\n {field: \"itemsToAddToProducedList\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AssemblyItemProducedLine[]).reduce((acc: Array, curr: AssemblyItemProducedLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllAssembliesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllAssembliesResponse extends ModelObject {\n\n public assemblies: Assembly[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.assemblies = jsonSerializedObject.assemblies.map((v: any) => new Assembly(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.assemblies = this.assemblies.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"assemblies\", rule: (v: any) => !!v || \"assemblies is required\"},\n {field: \"assemblies\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Assembly[]).reduce((acc: Array, curr: Assembly) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class AssemblyService extends ServiceBase {\n\n public async getAssembly(tenantId: Guid, assemblyId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAssemblyRequest();\n req.tenantId = tenantId;\n req.assemblyId = assemblyId;\n const extractor = (response:any) => new GetAssemblyResponse(response).assembly;\n return this.makeJsonRequest(\"assembly/v1/getAssembly\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAssemblies(tenantId: Guid, assemblyIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAssembliesRequest();\n req.tenantId = tenantId;\n req.assemblyIds = assemblyIds;\n const extractor = (response:any) => new GetAssembliesResponse(response).assemblies;\n return this.makeJsonRequest(\"assembly/v1/getAssemblies\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async savePlannedAssembly(tenantId: Guid, header: AssemblyHeader, ingredients: readonly AssemblyIngredientLine[], processGroups: readonly AssemblyProcessGroup[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SavePlannedAssemblyRequest();\n req.tenantId = tenantId;\n req.header = header;\n req.ingredients = ingredients;\n req.processGroups = processGroups;\n const extractor = (response:any) => new SavePlannedAssemblyResponse(response).assembly;\n return this.makeJsonRequest(\"assembly/v1/savePlannedAssembly\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setAssemblyIsHidden(tenantId: Guid, assemblyId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetAssemblyIsHiddenRequest();\n req.tenantId = tenantId;\n req.assemblyId = assemblyId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"assembly/v1/setAssemblyIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async cancelAssembly(tenantId: Guid, assemblyId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CancelAssemblyRequest();\n req.tenantId = tenantId;\n req.assemblyId = assemblyId;\n const extractor = null;\n return this.makeJsonRequest(\"assembly/v1/cancelAssembly\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async beginAssembly(tenantId: Guid, assemblyId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new BeginAssemblyRequest();\n req.tenantId = tenantId;\n req.assemblyId = assemblyId;\n const extractor = (response:any) => new BeginAssemblyResponse(response).assembly;\n return this.makeJsonRequest(\"assembly/v1/beginAssembly\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveAssemblyProgress(tenantId: Guid, assemblyHeader: AssemblyHeader, ingredients: readonly AssemblyIngredientLine[], ingredientsToAddToUsedList: readonly AssemblyIngredientUsedLine[], processGroups: readonly AssemblyProcessGroup[], complete: boolean, ingredientUsedModifications: readonly IngredientUsedModification[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveAssemblyProgressRequest();\n req.tenantId = tenantId;\n req.assemblyHeader = assemblyHeader;\n req.ingredients = ingredients;\n req.ingredientsToAddToUsedList = ingredientsToAddToUsedList;\n req.processGroups = processGroups;\n req.complete = complete;\n req.ingredientUsedModifications = ingredientUsedModifications;\n const extractor = null;\n return this.makeJsonRequest(\"assembly/v1/saveAssemblyProgress\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async uncompleteAssembly(tenantId: Guid, assemblyId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UncompleteAssemblyRequest();\n req.tenantId = tenantId;\n req.assemblyId = assemblyId;\n const extractor = null;\n return this.makeJsonRequest(\"assembly/v1/uncompleteAssembly\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllAssemblySummaries(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllAssemblySummariesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllAssemblySummariesResponse(response).assemblySummaries;\n return this.makeJsonRequest(\"assembly/v1/getAllAssemblySummaries\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getFilteredAssemblySummaries(tenantId: Guid, filter: AssemblyFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetFilteredAssemblySummariesRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetFilteredAssemblySummariesResponse(response).results;\n return this.makeJsonRequest(\"assembly/v1/getFilteredAssemblySummaries\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAssembledBatchDetails(tenantId: Guid, stockItemIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAssembledBatchDetailsRequest();\n req.tenantId = tenantId;\n req.stockItemIds = stockItemIds;\n const extractor = (response:any) => new GetAssembledBatchDetailsResponse(response).assembledBatchDetails;\n return this.makeJsonRequest(\"assembly/v1/getAssembledBatchDetails\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async addOutputToAnotherAssembly(tenantId: Guid, sourceAssemblyId: Guid, targetAssemblyId: Guid, stockItemId: Guid, quantity: number, stockItemCostPrice: number, unitOfMeasureId: Guid, adjustSourceExpectedOutput: boolean, adjustTargetExpectedIngredients: boolean, isByProduct: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new AddOutputToAnotherAssemblyRequest();\n req.tenantId = tenantId;\n req.sourceAssemblyId = sourceAssemblyId;\n req.targetAssemblyId = targetAssemblyId;\n req.stockItemId = stockItemId;\n req.quantity = quantity;\n req.stockItemCostPrice = stockItemCostPrice;\n req.unitOfMeasureId = unitOfMeasureId;\n req.adjustSourceExpectedOutput = adjustSourceExpectedOutput;\n req.adjustTargetExpectedIngredients = adjustTargetExpectedIngredients;\n req.isByProduct = isByProduct;\n const extractor = null;\n return this.makeJsonRequest(\"assembly/v1/addOutputToAnotherAssembly\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAssemblyStockExpectations(tenantId: Guid, limitStockLocationIds: readonly Guid[] | null, limitStockItemIds: readonly Guid[] | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAssemblyStockExpectationsRequest();\n req.tenantId = tenantId;\n req.limitStockLocationIds = limitStockLocationIds;\n req.limitStockItemIds = limitStockItemIds;\n const extractor = (response:any) => new GetAssemblyStockExpectationsResponse(response).results;\n return this.makeJsonRequest(\"assembly/v1/getAssemblyStockExpectations\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAssemblyHeadersByIds(tenantId: Guid, assemblyIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAssemblyHeadersByIdsRequest();\n req.tenantId = tenantId;\n req.assemblyIds = assemblyIds;\n const extractor = (response:any) => new GetAssemblyHeadersByIdsResponse(response).assemblyHeaders;\n return this.makeJsonRequest(\"assembly/v1/getAssemblyHeadersByIds\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllAssemblyProcessLines(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllAssemblyProcessLinesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllAssemblyProcessLinesResponse(response).processes;\n return this.makeJsonRequest(\"assembly/v1/getAllAssemblyProcessLines\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAssemblyProcessLines(tenantId: Guid, processIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAssemblyProcessLinesRequest();\n req.tenantId = tenantId;\n req.processIds = processIds;\n const extractor = (response:any) => new GetAssemblyProcessLinesResponse(response).processes;\n return this.makeJsonRequest(\"assembly/v1/getAssemblyProcessLines\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAssemblyIngredientsStillExpected(tenantId: Guid, assemblyIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAssemblyIngredientsStillExpectedRequest();\n req.tenantId = tenantId;\n req.assemblyIds = assemblyIds;\n const extractor = (response:any) => new GetAssemblyIngredientsStillExpectedResponse(response).ingredients;\n return this.makeJsonRequest(\"assembly/v1/getAssemblyIngredientsStillExpected\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async savePrintUpdatesForAssembly(tenantId: Guid, assemblyId: Guid, hasPrintedLabels: boolean, bestBeforeDate: LocalDate | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SavePrintUpdatesForAssemblyRequest();\n req.tenantId = tenantId;\n req.assemblyId = assemblyId;\n req.hasPrintedLabels = hasPrintedLabels;\n req.bestBeforeDate = bestBeforeDate;\n const extractor = null;\n return this.makeJsonRequest(\"assembly/v1/savePrintUpdatesForAssembly\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async evaluateLiquidProduction(tenantId: Guid, fromDate: LocalDate, toDate: LocalDate, alcoholTypes: readonly EnumAlcoholType[], stockLocations: readonly Guid[] | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new EvaluateLiquidProductionRequest();\n req.tenantId = tenantId;\n req.fromDate = fromDate;\n req.toDate = toDate;\n req.alcoholTypes = alcoholTypes;\n req.stockLocations = stockLocations;\n const extractor = (response:any) => new EvaluateLiquidProductionResponse(response).results;\n return this.makeJsonRequest(\"assembly/v1/evaluateLiquidProduction\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async addOutputToAssembly(tenantId: Guid, assemblyHeader: AssemblyHeader, itemsToAddToProducedList: readonly AssemblyItemProducedLine[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new AddOutputToAssemblyRequest();\n req.tenantId = tenantId;\n req.assemblyHeader = assemblyHeader;\n req.itemsToAddToProducedList = itemsToAddToProducedList;\n const extractor = null;\n return this.makeJsonRequest(\"assembly/v1/addOutputToAssembly\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllAssemblies(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllAssembliesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllAssembliesResponse(response).assemblies;\n return this.makeJsonRequest(\"assembly/v1/getAllAssemblies\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const assemblyService = new AssemblyService();","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumAlcoholType } from \"./enums/enumAlcoholType.generated\";\nimport { EnumDiscountBasis } from \"./enums/enumDiscountBasis.generated\";\nimport { EnumDistributionType } from \"./enums/enumDistributionType.generated\";\nimport { EnumEireMovementType } from \"./enums/enumEireMovementType.generated\";\nimport { EnumGermanBeerDutyMovementType } from \"./enums/enumGermanBeerDutyMovementType.generated\";\nimport { EnumGermanBeerDutyProductType } from \"./enums/enumGermanBeerDutyProductType.generated\";\nimport { EnumNatureOfTransactionCode } from \"./enums/enumNatureOfTransactionCode.generated\";\nimport { EnumOrderSource } from \"./enums/enumOrderSource.generated\";\nimport { EnumOrderStatus } from \"./enums/enumOrderStatus.generated\";\nimport { EnumRetailPaymentMethod } from \"./enums/enumRetailPaymentMethod.generated\";\nimport { EnumSpiritDutyExemptionReason } from \"./enums/enumSpiritDutyExemptionReason.generated\";\nimport { EnumStandardOrder } from \"./enums/enumStandardOrder.generated\";\nimport { EnumStockMovementReferenceSource } from \"./enums/enumStockMovementReferenceSource.generated\";\n\n// Model Objects\n\nexport class OrderSummary extends ModelObject {\n\n /**\n * Timestamp at which the order was created on the system. Captured by system not user editable.\n */\n public createdAt: Instant = Instant.ofEpochMilli(0);\n public id: Guid = Guid.createEmpty();\n /**\n * Order Number. Assigned at order creation. Not editable.\n * Not Nullable\n */\n public orderNumber: string = \"\";\n /**\n * Outlet which the order is for. Shown on docs. Used to determine which contact in accounts the order is sent to (if not invoiced to group). Outlet is required at order create and then Not editable.\n */\n public outletId: Guid = Guid.createEmpty();\n private _cancelledAt: Instant | null = null;\n /**\n * Timestamp at which the order was cancelled. Captured by system not user editable. (Null if not cancelled).\n */\n public get cancelledAt(): Instant | null { return this._cancelledAt }\n public set cancelledAt(value: Instant | null) {\n this._cancelledAt = value === undefined ? null : value;\n }\n /**\n * Date the order was/will be despatched for delivery. This is also the date at which any duty liability for the order occurs.\n */\n public despatchDate: LocalDate = LocalDate.ofEpochDay(0);\n /**\n * Date the order will be / was Delivered. Sent to accounts as the Invoice Date for the order.\n */\n public deliveryDate: LocalDate = LocalDate.ofEpochDay(0);\n /**\n * Processing Status Of the order. Not directly editable, but updated as explicit state change operations (complete/cancel/archive) are invoked. Orders are created with Status Open. : 0 = None, 1 = Open, 2 = Complete, 3 = Historic, 4 = Cancelled, 5 = Posting, 6 = Draft\n */\n public status: EnumOrderStatus = EnumOrderStatus.none;\n /**\n * Whether an invoice has been sent for this order. Just for user information. \n */\n public invoiceSent: boolean = false;\n /**\n * The email address invoices will be sent to. Shown on docs. Used when invoices auto-emailed. Copied from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public invoiceEmailAddress: string = \"\";\n /**\n * Invoice Number. Assigned on accounts posting or invoice document generation. InvoiceNumber is the key for sending the invoice to accounts packages. Not user editable. \n * Not Nullable\n * Max Length : 1000\n */\n public invoiceNumber: string = \"\";\n /**\n * Customer Reference. Displays on documents, sent to accounts packages.\n * Not Nullable\n * Max Length : 1000\n */\n public customerReference: string = \"\";\n /**\n * Our Reference. Just for user information.\n * Not Nullable\n * Max Length : 1000\n */\n public ourReference: string = \"\";\n /**\n * User who initially created the order. Captured by system not user editable.\n */\n public createdByUserId: Guid = Guid.createEmpty();\n /**\n * Delivery Address Line 1. Displays in delivery app and documents. Sent to accounts. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public deliveryAddress1: string = \"\";\n /**\n * Delivery Address Line 2. Displays in delivery app and documents. Sent to accounts. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public deliveryAddress2: string = \"\";\n /**\n * Delivery Address Line 3. Displays in delivery app and documents. Sent to accounts. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public deliveryAddress3: string = \"\";\n /**\n * Delivery Address Line 4. Displays in delivery app and documents. Sent to accounts. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public deliveryAddress4: string = \"\";\n /**\n * Delivery Address Line 5 - County. Displays in delivery app and documents. Sent to accounts. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public deliveryAddress5: string = \"\";\n /**\n * Delivery Address Line 6 - Country. Displays in delivery app and documents. Sent to accounts. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public deliveryAddress6: string = \"\";\n /**\n * Delivery Post Code. Displays in delivery app and documents. Sent to accounts. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public deliveryPostcode: string = \"\";\n private _deliveryAreaId: Guid | null = null;\n /**\n * Delivery Area. Displays in Delivery App. Copies from Outlet by default.\n */\n public get deliveryAreaId(): Guid | null { return this._deliveryAreaId }\n public set deliveryAreaId(value: Guid | null) {\n this._deliveryAreaId = value === undefined ? null : value;\n }\n /**\n * Order Source. Assigned at order creation. Not editable. : 0 = None, 1 = BrewMan, 2 = WooCommerce, 3 = Shopify, 4 = Sellar, 5 = Zettle, 6 = Other, 7 = EposNow, 8 = Beerflex, 9 = Square, 10 = Squarespace, 11 = Ecwid, 12 = EeBria, 13 = Commerce7, 14 = TradePortal, 15 = Amazon\n */\n public orderSource: EnumOrderSource = EnumOrderSource.none;\n /**\n * Reference of Order in External system. (OrderSource identifies which system the order was imported from eg WooCommerce / Shopify). Not editable.\n * Not Nullable\n * Max Length : 1000\n */\n public externalReference: string = \"\";\n /**\n * Timestamp at which the order was last updated on the system. Captured by system not user editable.\n */\n public lastUpdatedAt: Instant = Instant.ofEpochMilli(0);\n /**\n * Total Net Price of Order. Essentially a cached value of the sum of NetPrice of lines. Updated when lines changed. Not editable.\n */\n public totalNetPrice: number = 0;\n /**\n * Total VAT of Order. Essentially a cached value of the sum of Vat of lines. Updated when lines changed. Not editable.\n */\n public totalVat: number = 0;\n /**\n * Reason Order Cancelled. Expected to be provided at time of cancelling an order.\n * Not Nullable\n * Max Length : 100000\n */\n public cancellationReason: string = \"\";\n /**\n * Distribution Type. Drives the manner of distribution, particularly type Delivery which is included in the distribution planning and delivery app. Copied from Outlet by default. : 0 = None, 1 = Delivery, 2 = Courier, 3 = Collection\n */\n public distributionType: EnumDistributionType = EnumDistributionType.none;\n /**\n * Private notes relating to dispatch of this order. Not displayed to customer. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 100000\n */\n public internalDispatchNotes: string = \"\";\n /**\n * The phone number to use for delivery issues and updates. Just for user information. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public deliveryTelephoneNumber: string = \"\";\n /**\n * Order Type. Determines the duty implication of the order. Affects weight allocated to lines (export/normal). Can be changed, but all Order Lines should be removed if StandardOrderType is changed. : 0 = FullPriceDutyPaid, 1 = PriceExcludingDutyDutySuspended, 2 = FullPriceDutyPaidElsewhere, 3 = ExportDutySuspended, 4 = ConsumeOnPremisesNoDuty\n */\n public standardOrderType: EnumStandardOrder = EnumStandardOrder.fullPriceDutyPaid;\n /**\n * User notes relating to dispatch of this order. Displays on documents. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 100000\n */\n public externalDispatchNotes: string = \"\";\n public germanBeerDutyMovementType: EnumGermanBeerDutyMovementType = EnumGermanBeerDutyMovementType.none;\n private _courierId: Guid | null = null;\n /**\n * Courier. Defaults to Courier chosen for relevant Outlet. Required if distribution type is Courier.\n */\n public get courierId(): Guid | null { return this._courierId }\n public set courierId(value: Guid | null) {\n this._courierId = value === undefined ? null : value;\n }\n /**\n * Reference name or number from the Accounts Link posting.\n * Not Nullable\n * Max Length : 1000\n */\n public accountsLinkReferenceName: string = \"\";\n /**\n * Delivery Recipient Name. Just for user information. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public deliveryRecipient: string = \"\";\n public eireDutyMovementType: EnumEireMovementType = EnumEireMovementType.unknown;\n private _validUntilDate: LocalDate | null = null;\n /**\n * Date until which a draft order is valid.\n */\n public get validUntilDate(): LocalDate | null { return this._validUntilDate }\n public set validUntilDate(value: LocalDate | null) {\n this._validUntilDate = value === undefined ? null : value;\n }\n /**\n * Whether an invoice has been printed or downloaded for this order. Just for user information. \n */\n public invoicePrinted: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.createdAt = Instant.parse(jsonSerializedObject.createdAt);\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.orderNumber = jsonSerializedObject.orderNumber;\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n this.cancelledAt = jsonSerializedObject.cancelledAt == null ? null : Instant.parse(jsonSerializedObject.cancelledAt);\n this.despatchDate = LocalDate.parse(jsonSerializedObject.despatchDate);\n this.deliveryDate = LocalDate.parse(jsonSerializedObject.deliveryDate);\n this.status = EnumOrderStatus.getByValue(jsonSerializedObject.status, this.status);\n this.invoiceSent = jsonSerializedObject.invoiceSent;\n this.invoiceEmailAddress = jsonSerializedObject.invoiceEmailAddress;\n this.invoiceNumber = jsonSerializedObject.invoiceNumber;\n this.customerReference = jsonSerializedObject.customerReference;\n this.ourReference = jsonSerializedObject.ourReference;\n this.createdByUserId = Guid.fromString(jsonSerializedObject.createdByUserId);\n this.deliveryAddress1 = jsonSerializedObject.deliveryAddress1;\n this.deliveryAddress2 = jsonSerializedObject.deliveryAddress2;\n this.deliveryAddress3 = jsonSerializedObject.deliveryAddress3;\n this.deliveryAddress4 = jsonSerializedObject.deliveryAddress4;\n this.deliveryAddress5 = jsonSerializedObject.deliveryAddress5;\n this.deliveryAddress6 = jsonSerializedObject.deliveryAddress6;\n this.deliveryPostcode = jsonSerializedObject.deliveryPostcode;\n this.deliveryAreaId = jsonSerializedObject.deliveryAreaId == null ? null : Guid.fromString(jsonSerializedObject.deliveryAreaId);\n this.orderSource = EnumOrderSource.getByValue(jsonSerializedObject.orderSource, this.orderSource);\n this.externalReference = jsonSerializedObject.externalReference;\n this.lastUpdatedAt = Instant.parse(jsonSerializedObject.lastUpdatedAt);\n this.totalNetPrice = jsonSerializedObject.totalNetPrice;\n this.totalVat = jsonSerializedObject.totalVat;\n this.cancellationReason = jsonSerializedObject.cancellationReason;\n this.distributionType = EnumDistributionType.getByValue(jsonSerializedObject.distributionType, this.distributionType);\n this.internalDispatchNotes = jsonSerializedObject.internalDispatchNotes;\n this.deliveryTelephoneNumber = jsonSerializedObject.deliveryTelephoneNumber;\n this.standardOrderType = EnumStandardOrder.getByValue(jsonSerializedObject.standardOrderType, this.standardOrderType);\n this.externalDispatchNotes = jsonSerializedObject.externalDispatchNotes;\n this.germanBeerDutyMovementType = EnumGermanBeerDutyMovementType.getByValue(jsonSerializedObject.germanBeerDutyMovementType, this.germanBeerDutyMovementType);\n this.courierId = jsonSerializedObject.courierId == null ? null : Guid.fromString(jsonSerializedObject.courierId);\n this.accountsLinkReferenceName = jsonSerializedObject.accountsLinkReferenceName;\n this.deliveryRecipient = jsonSerializedObject.deliveryRecipient;\n this.eireDutyMovementType = EnumEireMovementType.getByValue(jsonSerializedObject.eireDutyMovementType, this.eireDutyMovementType);\n this.validUntilDate = jsonSerializedObject.validUntilDate == null ? null : LocalDate.parse(jsonSerializedObject.validUntilDate);\n this.invoicePrinted = jsonSerializedObject.invoicePrinted;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.createdAt = this.createdAt.toString();\n toRet.id = this.id.toString();\n toRet.orderNumber = this.orderNumber;\n toRet.outletId = this.outletId.toString();\n toRet.cancelledAt = this.cancelledAt == null ? null : this.cancelledAt.toString();\n toRet.despatchDate = this.despatchDate.toString();\n toRet.deliveryDate = this.deliveryDate.toString();\n toRet.status = this.status.value;\n toRet.invoiceSent = this.invoiceSent;\n toRet.invoiceEmailAddress = this.invoiceEmailAddress;\n toRet.invoiceNumber = this.invoiceNumber;\n toRet.customerReference = this.customerReference;\n toRet.ourReference = this.ourReference;\n toRet.createdByUserId = this.createdByUserId.toString();\n toRet.deliveryAddress1 = this.deliveryAddress1;\n toRet.deliveryAddress2 = this.deliveryAddress2;\n toRet.deliveryAddress3 = this.deliveryAddress3;\n toRet.deliveryAddress4 = this.deliveryAddress4;\n toRet.deliveryAddress5 = this.deliveryAddress5;\n toRet.deliveryAddress6 = this.deliveryAddress6;\n toRet.deliveryPostcode = this.deliveryPostcode;\n toRet.deliveryAreaId = this.deliveryAreaId == null ? null : this.deliveryAreaId.toString();\n toRet.orderSource = this.orderSource.value;\n toRet.externalReference = this.externalReference;\n toRet.lastUpdatedAt = this.lastUpdatedAt.toString();\n toRet.totalNetPrice = this.totalNetPrice;\n toRet.totalVat = this.totalVat;\n toRet.cancellationReason = this.cancellationReason;\n toRet.distributionType = this.distributionType.value;\n toRet.internalDispatchNotes = this.internalDispatchNotes;\n toRet.deliveryTelephoneNumber = this.deliveryTelephoneNumber;\n toRet.standardOrderType = this.standardOrderType.value;\n toRet.externalDispatchNotes = this.externalDispatchNotes;\n toRet.germanBeerDutyMovementType = this.germanBeerDutyMovementType.value;\n toRet.courierId = this.courierId == null ? null : this.courierId.toString();\n toRet.accountsLinkReferenceName = this.accountsLinkReferenceName;\n toRet.deliveryRecipient = this.deliveryRecipient;\n toRet.eireDutyMovementType = this.eireDutyMovementType.value;\n toRet.validUntilDate = this.validUntilDate == null ? null : this.validUntilDate.toString();\n toRet.invoicePrinted = this.invoicePrinted;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"OrderSummary.Id cannot be empty\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \"OrderSummary.OutletId cannot be empty\"},\n {field: \"invoiceEmailAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"InvoiceEmailAddress has too many characters (1000)\"},\n {field: \"invoiceNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"InvoiceNumber has too many characters (1000)\"},\n {field: \"customerReference\", rule: (v: any) => v == null || v.length <= 1000 || \"CustomerReference has too many characters (1000)\"},\n {field: \"ourReference\", rule: (v: any) => v == null || v.length <= 1000 || \"OurReference has too many characters (1000)\"},\n {field: \"createdByUserId\", rule: (v: any) => !v.isEmpty() || \"OrderSummary.CreatedByUserId cannot be empty\"},\n {field: \"deliveryAddress1\", rule: (v: any) => v == null || v.length <= 1000 || \"DeliveryAddress1 has too many characters (1000)\"},\n {field: \"deliveryAddress2\", rule: (v: any) => v == null || v.length <= 1000 || \"DeliveryAddress2 has too many characters (1000)\"},\n {field: \"deliveryAddress3\", rule: (v: any) => v == null || v.length <= 1000 || \"DeliveryAddress3 has too many characters (1000)\"},\n {field: \"deliveryAddress4\", rule: (v: any) => v == null || v.length <= 1000 || \"DeliveryAddress4 has too many characters (1000)\"},\n {field: \"deliveryAddress5\", rule: (v: any) => v == null || v.length <= 1000 || \"DeliveryAddress5 has too many characters (1000)\"},\n {field: \"deliveryAddress6\", rule: (v: any) => v == null || v.length <= 1000 || \"DeliveryAddress6 has too many characters (1000)\"},\n {field: \"deliveryPostcode\", rule: (v: any) => v == null || v.length <= 1000 || \"DeliveryPostcode has too many characters (1000)\"},\n {field: \"deliveryAreaId\", rule: (v: any) => v == null || !v.isEmpty() || \"OrderSummary.DeliveryAreaId cannot be empty\"},\n {field: \"externalReference\", rule: (v: any) => v == null || v.length <= 1000 || \"ExternalReference has too many characters (1000)\"},\n {field: \"cancellationReason\", rule: (v: any) => v == null || v.length <= 100000 || \"CancellationReason has too many characters (100000)\"},\n {field: \"internalDispatchNotes\", rule: (v: any) => v == null || v.length <= 100000 || \"InternalDispatchNotes has too many characters (100000)\"},\n {field: \"deliveryTelephoneNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"DeliveryTelephoneNumber has too many characters (1000)\"},\n {field: \"externalDispatchNotes\", rule: (v: any) => v == null || v.length <= 100000 || \"ExternalDispatchNotes has too many characters (100000)\"},\n {field: \"courierId\", rule: (v: any) => v == null || !v.isEmpty() || \"OrderSummary.CourierId cannot be empty\"},\n {field: \"accountsLinkReferenceName\", rule: (v: any) => v == null || v.length <= 1000 || \"AccountsLinkReferenceName has too many characters (1000)\"},\n {field: \"deliveryRecipient\", rule: (v: any) => v == null || v.length <= 1000 || \"DeliveryRecipient has too many characters (1000)\"},\n ];\n}\n\n\nexport class OrderSummariesResult extends ModelObject {\n\n public matchingCount: number = 0;\n public orders: OrderSummary[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.orders = jsonSerializedObject.orders.map((v: any) => new OrderSummary(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.orders = this.orders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"orders\", rule: (v: any) => !!v || \"orders is required\"},\n {field: \"orders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OrderSummary[]).reduce((acc: Array, curr: OrderSummary) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class OrderFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _singleOutletId: Guid | null = null;\n public get singleOutletId(): Guid | null { return this._singleOutletId }\n public set singleOutletId(value: Guid | null) {\n this._singleOutletId = value === undefined ? null : value;\n }\n private _singleGroupId: Guid | null = null;\n public get singleGroupId(): Guid | null { return this._singleGroupId }\n public set singleGroupId(value: Guid | null) {\n this._singleGroupId = value === undefined ? null : value;\n }\n private _fromDeliveryDate: LocalDate | null = null;\n /**\n * Minimum (inclusive) delivery date\n */\n public get fromDeliveryDate(): LocalDate | null { return this._fromDeliveryDate }\n public set fromDeliveryDate(value: LocalDate | null) {\n this._fromDeliveryDate = value === undefined ? null : value;\n }\n private _toDeliveryDate: LocalDate | null = null;\n /**\n * Maximum (inclusive) delivery date\n */\n public get toDeliveryDate(): LocalDate | null { return this._toDeliveryDate }\n public set toDeliveryDate(value: LocalDate | null) {\n this._toDeliveryDate = value === undefined ? null : value;\n }\n private _fromDutyReturnDate: LocalDate | null = null;\n /**\n * Minimum (inclusive) effective duty return date. (Usually DespatchDate but possibly overriden by DutyReturnDateOverride).\n */\n public get fromDutyReturnDate(): LocalDate | null { return this._fromDutyReturnDate }\n public set fromDutyReturnDate(value: LocalDate | null) {\n this._fromDutyReturnDate = value === undefined ? null : value;\n }\n private _toDutyReturnDate: LocalDate | null = null;\n /**\n * Maximum (inclusive) effective duty return date. (Usually DespatchDate but possibly overriden by DutyReturnDateOverride).\n */\n public get toDutyReturnDate(): LocalDate | null { return this._toDutyReturnDate }\n public set toDutyReturnDate(value: LocalDate | null) {\n this._toDutyReturnDate = value === undefined ? null : value;\n }\n private _fromDespatchDate: LocalDate | null = null;\n /**\n * Minimum (inclusive) despatch date\n */\n public get fromDespatchDate(): LocalDate | null { return this._fromDespatchDate }\n public set fromDespatchDate(value: LocalDate | null) {\n this._fromDespatchDate = value === undefined ? null : value;\n }\n private _toDespatchDate: LocalDate | null = null;\n /**\n * Maximum (inclusive) despatch date\n */\n public get toDespatchDate(): LocalDate | null { return this._toDespatchDate }\n public set toDespatchDate(value: LocalDate | null) {\n this._toDespatchDate = value === undefined ? null : value;\n }\n private _sources: EnumOrderSource[] | null = null;\n public get sources(): EnumOrderSource[] | null { return this._sources }\n public set sources(value: EnumOrderSource[] | null) {\n this._sources = value === undefined ? null : value;\n }\n private _distributionTypes: EnumDistributionType[] | null = null;\n public get distributionTypes(): EnumDistributionType[] | null { return this._distributionTypes }\n public set distributionTypes(value: EnumDistributionType[] | null) {\n this._distributionTypes = value === undefined ? null : value;\n }\n private _limitCourierIdsForCourierOrders: Guid[] | null = null;\n public get limitCourierIdsForCourierOrders(): Guid[] | null { return this._limitCourierIdsForCourierOrders }\n public set limitCourierIdsForCourierOrders(value: Guid[] | null) {\n this._limitCourierIdsForCourierOrders = value === undefined ? null : value;\n }\n private _externalReferences: string[] | null = null;\n public get externalReferences(): string[] | null { return this._externalReferences }\n public set externalReferences(value: string[] | null) {\n this._externalReferences = value === undefined ? null : value;\n }\n private _orderNumbers: string[] | null = null;\n public get orderNumbers(): string[] | null { return this._orderNumbers }\n public set orderNumbers(value: string[] | null) {\n this._orderNumbers = value === undefined ? null : value;\n }\n private _invoiceNumbers: string[] | null = null;\n public get invoiceNumbers(): string[] | null { return this._invoiceNumbers }\n public set invoiceNumbers(value: string[] | null) {\n this._invoiceNumbers = value === undefined ? null : value;\n }\n private _limitStatuses: EnumOrderStatus[] | null = null;\n /**\n * If provided only matching statuses are returned\n */\n public get limitStatuses(): EnumOrderStatus[] | null { return this._limitStatuses }\n public set limitStatuses(value: EnumOrderStatus[] | null) {\n this._limitStatuses = value === undefined ? null : value;\n }\n private _limitOrderHeaderIds: Guid[] | null = null;\n public get limitOrderHeaderIds(): Guid[] | null { return this._limitOrderHeaderIds }\n public set limitOrderHeaderIds(value: Guid[] | null) {\n this._limitOrderHeaderIds = value === undefined ? null : value;\n }\n private _standardOrderTypes: EnumStandardOrder[] | null = null;\n public get standardOrderTypes(): EnumStandardOrder[] | null { return this._standardOrderTypes }\n public set standardOrderTypes(value: EnumStandardOrder[] | null) {\n this._standardOrderTypes = value === undefined ? null : value;\n }\n private _fromCancelledAt: Instant | null = null;\n public get fromCancelledAt(): Instant | null { return this._fromCancelledAt }\n public set fromCancelledAt(value: Instant | null) {\n this._fromCancelledAt = value === undefined ? null : value;\n }\n private _toCancelledAt: Instant | null = null;\n public get toCancelledAt(): Instant | null { return this._toCancelledAt }\n public set toCancelledAt(value: Instant | null) {\n this._toCancelledAt = value === undefined ? null : value;\n }\n private _fromCreatedAt: Instant | null = null;\n public get fromCreatedAt(): Instant | null { return this._fromCreatedAt }\n public set fromCreatedAt(value: Instant | null) {\n this._fromCreatedAt = value === undefined ? null : value;\n }\n private _toCreatedAt: Instant | null = null;\n public get toCreatedAt(): Instant | null { return this._toCreatedAt }\n public set toCreatedAt(value: Instant | null) {\n this._toCreatedAt = value === undefined ? null : value;\n }\n private _fromLastUpdatedAt: Instant | null = null;\n /**\n * Minimum (inclusive) last updated at.\n */\n public get fromLastUpdatedAt(): Instant | null { return this._fromLastUpdatedAt }\n public set fromLastUpdatedAt(value: Instant | null) {\n this._fromLastUpdatedAt = value === undefined ? null : value;\n }\n private _toLastUpdatedAt: Instant | null = null;\n /**\n * Maximum (inclusive) last updated at.\n */\n public get toLastUpdatedAt(): Instant | null { return this._toLastUpdatedAt }\n public set toLastUpdatedAt(value: Instant | null) {\n this._toLastUpdatedAt = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.singleOutletId = jsonSerializedObject.singleOutletId == null ? null : Guid.fromString(jsonSerializedObject.singleOutletId);\n this.singleGroupId = jsonSerializedObject.singleGroupId == null ? null : Guid.fromString(jsonSerializedObject.singleGroupId);\n this.fromDeliveryDate = jsonSerializedObject.fromDeliveryDate == null ? null : LocalDate.parse(jsonSerializedObject.fromDeliveryDate);\n this.toDeliveryDate = jsonSerializedObject.toDeliveryDate == null ? null : LocalDate.parse(jsonSerializedObject.toDeliveryDate);\n this.fromDutyReturnDate = jsonSerializedObject.fromDutyReturnDate == null ? null : LocalDate.parse(jsonSerializedObject.fromDutyReturnDate);\n this.toDutyReturnDate = jsonSerializedObject.toDutyReturnDate == null ? null : LocalDate.parse(jsonSerializedObject.toDutyReturnDate);\n this.fromDespatchDate = jsonSerializedObject.fromDespatchDate == null ? null : LocalDate.parse(jsonSerializedObject.fromDespatchDate);\n this.toDespatchDate = jsonSerializedObject.toDespatchDate == null ? null : LocalDate.parse(jsonSerializedObject.toDespatchDate);\n this.sources = jsonSerializedObject.sources == null ? null : jsonSerializedObject.sources.map((v: any) => EnumOrderSource.getByValue(v));\n this.distributionTypes = jsonSerializedObject.distributionTypes == null ? null : jsonSerializedObject.distributionTypes.map((v: any) => EnumDistributionType.getByValue(v));\n this.limitCourierIdsForCourierOrders = jsonSerializedObject.limitCourierIdsForCourierOrders == null ? null : jsonSerializedObject.limitCourierIdsForCourierOrders.map((v: any) => Guid.fromString(v));\n this.externalReferences = jsonSerializedObject.externalReferences == null ? null : jsonSerializedObject.externalReferences.map((v: any) => v);\n this.orderNumbers = jsonSerializedObject.orderNumbers == null ? null : jsonSerializedObject.orderNumbers.map((v: any) => v);\n this.invoiceNumbers = jsonSerializedObject.invoiceNumbers == null ? null : jsonSerializedObject.invoiceNumbers.map((v: any) => v);\n this.limitStatuses = jsonSerializedObject.limitStatuses == null ? null : jsonSerializedObject.limitStatuses.map((v: any) => EnumOrderStatus.getByValue(v));\n this.limitOrderHeaderIds = jsonSerializedObject.limitOrderHeaderIds == null ? null : jsonSerializedObject.limitOrderHeaderIds.map((v: any) => Guid.fromString(v));\n this.standardOrderTypes = jsonSerializedObject.standardOrderTypes == null ? null : jsonSerializedObject.standardOrderTypes.map((v: any) => EnumStandardOrder.getByValue(v));\n this.fromCancelledAt = jsonSerializedObject.fromCancelledAt == null ? null : Instant.parse(jsonSerializedObject.fromCancelledAt);\n this.toCancelledAt = jsonSerializedObject.toCancelledAt == null ? null : Instant.parse(jsonSerializedObject.toCancelledAt);\n this.fromCreatedAt = jsonSerializedObject.fromCreatedAt == null ? null : Instant.parse(jsonSerializedObject.fromCreatedAt);\n this.toCreatedAt = jsonSerializedObject.toCreatedAt == null ? null : Instant.parse(jsonSerializedObject.toCreatedAt);\n this.fromLastUpdatedAt = jsonSerializedObject.fromLastUpdatedAt == null ? null : Instant.parse(jsonSerializedObject.fromLastUpdatedAt);\n this.toLastUpdatedAt = jsonSerializedObject.toLastUpdatedAt == null ? null : Instant.parse(jsonSerializedObject.toLastUpdatedAt);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.singleOutletId = this.singleOutletId == null ? null : this.singleOutletId.toString();\n toRet.singleGroupId = this.singleGroupId == null ? null : this.singleGroupId.toString();\n toRet.fromDeliveryDate = this.fromDeliveryDate == null ? null : this.fromDeliveryDate.toString();\n toRet.toDeliveryDate = this.toDeliveryDate == null ? null : this.toDeliveryDate.toString();\n toRet.fromDutyReturnDate = this.fromDutyReturnDate == null ? null : this.fromDutyReturnDate.toString();\n toRet.toDutyReturnDate = this.toDutyReturnDate == null ? null : this.toDutyReturnDate.toString();\n toRet.fromDespatchDate = this.fromDespatchDate == null ? null : this.fromDespatchDate.toString();\n toRet.toDespatchDate = this.toDespatchDate == null ? null : this.toDespatchDate.toString();\n toRet.sources = this.sources == null ? null : this.sources.map(v => v.value);\n toRet.distributionTypes = this.distributionTypes == null ? null : this.distributionTypes.map(v => v.value);\n toRet.limitCourierIdsForCourierOrders = this.limitCourierIdsForCourierOrders == null ? null : this.limitCourierIdsForCourierOrders.map(v => v.toString());\n toRet.externalReferences = this.externalReferences == null ? null : this.externalReferences.map(v => v);\n toRet.orderNumbers = this.orderNumbers == null ? null : this.orderNumbers.map(v => v);\n toRet.invoiceNumbers = this.invoiceNumbers == null ? null : this.invoiceNumbers.map(v => v);\n toRet.limitStatuses = this.limitStatuses == null ? null : this.limitStatuses.map(v => v.value);\n toRet.limitOrderHeaderIds = this.limitOrderHeaderIds == null ? null : this.limitOrderHeaderIds.map(v => v.toString());\n toRet.standardOrderTypes = this.standardOrderTypes == null ? null : this.standardOrderTypes.map(v => v.value);\n toRet.fromCancelledAt = this.fromCancelledAt == null ? null : this.fromCancelledAt.toString();\n toRet.toCancelledAt = this.toCancelledAt == null ? null : this.toCancelledAt.toString();\n toRet.fromCreatedAt = this.fromCreatedAt == null ? null : this.fromCreatedAt.toString();\n toRet.toCreatedAt = this.toCreatedAt == null ? null : this.toCreatedAt.toString();\n toRet.fromLastUpdatedAt = this.fromLastUpdatedAt == null ? null : this.fromLastUpdatedAt.toString();\n toRet.toLastUpdatedAt = this.toLastUpdatedAt == null ? null : this.toLastUpdatedAt.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n {field: \"singleOutletId\", rule: (v: any) => v == null || !v.isEmpty() || \"OrderFilter.SingleOutletId cannot be empty\"},\n {field: \"singleGroupId\", rule: (v: any) => v == null || !v.isEmpty() || \"OrderFilter.SingleGroupId cannot be empty\"},\n ];\n}\n\n\nexport class OrderHeaderReadOnly extends ModelObject {\n\n /**\n * Timestamp at which the order was created on the system. Captured by system not user editable.\n */\n public createdAt: Instant = Instant.ofEpochMilli(0);\n /**\n * Timestamp at which the order was last updated on the system. Captured by system not user editable.\n */\n public lastUpdatedAt: Instant = Instant.ofEpochMilli(0);\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Reason Order Cancelled. Expected to be provided at time of cancelling an order.\n * Not Nullable\n * Max Length : 100000\n */\n public cancellationReason: string = \"\";\n private _cancelledByUserId: Guid | null = null;\n /**\n * User who cancelled the order. Captured by system not user editable. (Null if not cancelled).\n */\n public get cancelledByUserId(): Guid | null { return this._cancelledByUserId }\n public set cancelledByUserId(value: Guid | null) {\n this._cancelledByUserId = value === undefined ? null : value;\n }\n private _cancelledAt: Instant | null = null;\n /**\n * Timestamp at which the order was cancelled. Captured by system not user editable. (Null if not cancelled).\n */\n public get cancelledAt(): Instant | null { return this._cancelledAt }\n public set cancelledAt(value: Instant | null) {\n this._cancelledAt = value === undefined ? null : value;\n }\n /**\n * Credit Terms Description. Frozen at order entry so historic invoices can print original details. Copied from Outlets Credit terms at order creation and not editable.\n * Not Nullable\n * Max Length : 1000\n */\n public creditTermsDescription: string = \"\";\n private _deliveryLatitude: number | null = null;\n /**\n * Latitude of delviery address (if known). Used for distribution planning, routing, mapping. Copies from Outlet by default. Not directly editable by user, but updated automatically when order delivery address changed.\n */\n public get deliveryLatitude(): number | null { return this._deliveryLatitude }\n public set deliveryLatitude(value: number | null) {\n this._deliveryLatitude = value === undefined ? null : value;\n }\n private _deliveryLongitude: number | null = null;\n /**\n * Longitude of delviery address (if known). Used for distribution planning, routing, mapping. Copies from Outlet by default. Not directly editable by user, but updated automatically when order delivery address changed.\n */\n public get deliveryLongitude(): number | null { return this._deliveryLongitude }\n public set deliveryLongitude(value: number | null) {\n this._deliveryLongitude = value === undefined ? null : value;\n }\n /**\n * Reference of Order in External system. (OrderSource identifies which system the order was imported from eg WooCommerce / Shopify). Not editable.\n * Not Nullable\n * Max Length : 1000\n */\n public externalReference: string = \"\";\n private _groupId: Guid | null = null;\n /**\n * Group (if any). Affects Discounts. Used for accounts posting (invoices post to the group not outlet unless group is marked as SendInvoicesToOutlet). Captured from outlet at order creation. Not editable.\n */\n public get groupId(): Guid | null { return this._groupId }\n public set groupId(value: Guid | null) {\n this._groupId = value === undefined ? null : value;\n }\n /**\n * Invoice Number. Assigned on accounts posting or invoice document generation. InvoiceNumber is the key for sending the invoice to accounts packages. Not user editable. \n * Not Nullable\n * Max Length : 1000\n */\n public invoiceNumber: string = \"\";\n /**\n * Identified the order as a Retail Order. Retail orders are not sent to accounts individually, but instead are packaged (typically daily) into a single summary which is sent to accounts. Retail orders present differently to Trade on UI. Captured from outlet at order creation. Not editable.\n */\n public isRetailOrder: boolean = false;\n /**\n * Order Number. Assigned at order creation. Not editable.\n * Not Nullable\n */\n public orderNumber: string = \"\";\n /**\n * Order Source. Assigned at order creation. Not editable. : 0 = None, 1 = BrewMan, 2 = WooCommerce, 3 = Shopify, 4 = Sellar, 5 = Zettle, 6 = Other, 7 = EposNow, 8 = Beerflex, 9 = Square, 10 = Squarespace, 11 = Ecwid, 12 = EeBria, 13 = Commerce7, 14 = TradePortal, 15 = Amazon\n */\n public orderSource: EnumOrderSource = EnumOrderSource.none;\n /**\n * Outlet which the order is for. Shown on docs. Used to determine which contact in accounts the order is sent to (if not invoiced to group). Outlet is required at order create and then Not editable.\n */\n public outletId: Guid = Guid.createEmpty();\n /**\n * Outlet Name. Used in distribution planning / delivery app. Captured from outlet at order creation. Not editable.\n * Not Nullable\n * Max Length : 1000\n */\n public outletName: string = \"\";\n /**\n * Outlet Rating of Outlet at Time of order. No current Function - Stored for potential future reporting. Captured from outlet at order creation. Not editable.\n */\n public outletRatingId: Guid = Guid.createEmpty();\n private _outletTypeId: Guid | null = null;\n /**\n * Outlet Type of Outlet at Time of order. Stored for potential future reporting. Also used for GlCode resolution when lines added. Captured from outlet at order creation. Not editable.\n */\n public get outletTypeId(): Guid | null { return this._outletTypeId }\n public set outletTypeId(value: Guid | null) {\n this._outletTypeId = value === undefined ? null : value;\n }\n private _salesAreaId: Guid | null = null;\n /**\n * The Sales Area which the outlet was in at the time of the order. No current Function - Stored for potential future reporting. Captured from outlet at order creation. Not editable.\n */\n public get salesAreaId(): Guid | null { return this._salesAreaId }\n public set salesAreaId(value: Guid | null) {\n this._salesAreaId = value === undefined ? null : value;\n }\n private _salesCodeId: Guid | null = null;\n /**\n * The Sales Code which the outlet was in at the time of the order. No current Function - Stored for potential future reporting. Captured from outlet at order creation. Not editable.\n */\n public get salesCodeId(): Guid | null { return this._salesCodeId }\n public set salesCodeId(value: Guid | null) {\n this._salesCodeId = value === undefined ? null : value;\n }\n /**\n * Processing Status Of the order. Not directly editable, but updated as explicit state change operations (complete/cancel/archive) are invoked. Orders are created with Status Open. : 0 = None, 1 = Open, 2 = Complete, 3 = Historic, 4 = Cancelled, 5 = Posting, 6 = Draft\n */\n public status: EnumOrderStatus = EnumOrderStatus.none;\n /**\n * Total Cost Price of Order. (Inc Duty as applicable, Ex VAT). Essentially a cached value of the sum of NetCost of lines. Updated when lines changed. Not editable.\n */\n public totalCostNet: number = 0;\n /**\n * Total Net Price of Order. Essentially a cached value of the sum of NetPrice of lines. Updated when lines changed. Not editable.\n */\n public totalNetPrice: number = 0;\n /**\n * Total VAT of Order. Essentially a cached value of the sum of Vat of lines. Updated when lines changed. Not editable.\n */\n public totalVat: number = 0;\n /**\n * User who initially created the order. Captured by system not user editable.\n */\n public createdByUserId: Guid = Guid.createEmpty();\n /**\n * Description of the current error which is preventing this credit from being posted to accounts. Ie the error (if any) which occurred when this was last attempted to post. The presence of text in this field implies there is a known current error so posting will not be reattempted. To reattempt posting this field must be cleared.\n * Not Nullable\n * Max Length : 100000\n */\n public currentPostingError: string = \"\";\n /**\n * Set to true when stock is adjusted for this order (occurs once posting to accounts succeeds). When true it implies that the items on the order should not be modified.\n */\n public hasStockBeenAdjusted: boolean = false;\n /**\n * The approximate amount of duty which has/will be paid in fulfilling this order. This represents the amount of duty included in the total net price, regardless of whether that duty would be chargeable directly due to this specific sale. For example, if the sale is from non-bonded then the duty has already been paid as part of the stock transfer to non-bonded so this sale will not cause a direct duty liability but that duty element will be included in the duty cost of sale. It is approximate because actual duty return calculations will be rounded across multiple orders so cannot be exactly attributed to each individual order. \n */\n public totalApproximateDutyCostOfSale: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.createdAt = Instant.parse(jsonSerializedObject.createdAt);\n this.lastUpdatedAt = Instant.parse(jsonSerializedObject.lastUpdatedAt);\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.cancellationReason = jsonSerializedObject.cancellationReason;\n this.cancelledByUserId = jsonSerializedObject.cancelledByUserId == null ? null : Guid.fromString(jsonSerializedObject.cancelledByUserId);\n this.cancelledAt = jsonSerializedObject.cancelledAt == null ? null : Instant.parse(jsonSerializedObject.cancelledAt);\n this.creditTermsDescription = jsonSerializedObject.creditTermsDescription;\n this.deliveryLatitude = jsonSerializedObject.deliveryLatitude == null ? null : jsonSerializedObject.deliveryLatitude;\n this.deliveryLongitude = jsonSerializedObject.deliveryLongitude == null ? null : jsonSerializedObject.deliveryLongitude;\n this.externalReference = jsonSerializedObject.externalReference;\n this.groupId = jsonSerializedObject.groupId == null ? null : Guid.fromString(jsonSerializedObject.groupId);\n this.invoiceNumber = jsonSerializedObject.invoiceNumber;\n this.isRetailOrder = jsonSerializedObject.isRetailOrder;\n this.orderNumber = jsonSerializedObject.orderNumber;\n this.orderSource = EnumOrderSource.getByValue(jsonSerializedObject.orderSource, this.orderSource);\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n this.outletName = jsonSerializedObject.outletName;\n this.outletRatingId = Guid.fromString(jsonSerializedObject.outletRatingId);\n this.outletTypeId = jsonSerializedObject.outletTypeId == null ? null : Guid.fromString(jsonSerializedObject.outletTypeId);\n this.salesAreaId = jsonSerializedObject.salesAreaId == null ? null : Guid.fromString(jsonSerializedObject.salesAreaId);\n this.salesCodeId = jsonSerializedObject.salesCodeId == null ? null : Guid.fromString(jsonSerializedObject.salesCodeId);\n this.status = EnumOrderStatus.getByValue(jsonSerializedObject.status, this.status);\n this.totalCostNet = jsonSerializedObject.totalCostNet;\n this.totalNetPrice = jsonSerializedObject.totalNetPrice;\n this.totalVat = jsonSerializedObject.totalVat;\n this.createdByUserId = Guid.fromString(jsonSerializedObject.createdByUserId);\n this.currentPostingError = jsonSerializedObject.currentPostingError;\n this.hasStockBeenAdjusted = jsonSerializedObject.hasStockBeenAdjusted;\n this.totalApproximateDutyCostOfSale = jsonSerializedObject.totalApproximateDutyCostOfSale;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.createdAt = this.createdAt.toString();\n toRet.lastUpdatedAt = this.lastUpdatedAt.toString();\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.cancellationReason = this.cancellationReason;\n toRet.cancelledByUserId = this.cancelledByUserId == null ? null : this.cancelledByUserId.toString();\n toRet.cancelledAt = this.cancelledAt == null ? null : this.cancelledAt.toString();\n toRet.creditTermsDescription = this.creditTermsDescription;\n toRet.deliveryLatitude = this.deliveryLatitude == null ? null : this.deliveryLatitude;\n toRet.deliveryLongitude = this.deliveryLongitude == null ? null : this.deliveryLongitude;\n toRet.externalReference = this.externalReference;\n toRet.groupId = this.groupId == null ? null : this.groupId.toString();\n toRet.invoiceNumber = this.invoiceNumber;\n toRet.isRetailOrder = this.isRetailOrder;\n toRet.orderNumber = this.orderNumber;\n toRet.orderSource = this.orderSource.value;\n toRet.outletId = this.outletId.toString();\n toRet.outletName = this.outletName;\n toRet.outletRatingId = this.outletRatingId.toString();\n toRet.outletTypeId = this.outletTypeId == null ? null : this.outletTypeId.toString();\n toRet.salesAreaId = this.salesAreaId == null ? null : this.salesAreaId.toString();\n toRet.salesCodeId = this.salesCodeId == null ? null : this.salesCodeId.toString();\n toRet.status = this.status.value;\n toRet.totalCostNet = this.totalCostNet;\n toRet.totalNetPrice = this.totalNetPrice;\n toRet.totalVat = this.totalVat;\n toRet.createdByUserId = this.createdByUserId.toString();\n toRet.currentPostingError = this.currentPostingError;\n toRet.hasStockBeenAdjusted = this.hasStockBeenAdjusted;\n toRet.totalApproximateDutyCostOfSale = this.totalApproximateDutyCostOfSale;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"OrderHeaderReadOnly.Id cannot be empty\"},\n {field: \"cancellationReason\", rule: (v: any) => v == null || v.length <= 100000 || \"CancellationReason has too many characters (100000)\"},\n {field: \"cancelledByUserId\", rule: (v: any) => v == null || !v.isEmpty() || \"OrderHeaderReadOnly.CancelledByUserId cannot be empty\"},\n {field: \"creditTermsDescription\", rule: (v: any) => v == null || v.length <= 1000 || \"CreditTermsDescription has too many characters (1000)\"},\n {field: \"externalReference\", rule: (v: any) => v == null || v.length <= 1000 || \"ExternalReference has too many characters (1000)\"},\n {field: \"groupId\", rule: (v: any) => v == null || !v.isEmpty() || \"OrderHeaderReadOnly.GroupId cannot be empty\"},\n {field: \"invoiceNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"InvoiceNumber has too many characters (1000)\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \"OrderHeaderReadOnly.OutletId cannot be empty\"},\n {field: \"outletName\", rule: (v: any) => v == null || v.length <= 1000 || \"OutletName has too many characters (1000)\"},\n {field: \"outletRatingId\", rule: (v: any) => !v.isEmpty() || \"OrderHeaderReadOnly.OutletRatingId cannot be empty\"},\n {field: \"outletTypeId\", rule: (v: any) => v == null || !v.isEmpty() || \"OrderHeaderReadOnly.OutletTypeId cannot be empty\"},\n {field: \"salesAreaId\", rule: (v: any) => v == null || !v.isEmpty() || \"OrderHeaderReadOnly.SalesAreaId cannot be empty\"},\n {field: \"salesCodeId\", rule: (v: any) => v == null || !v.isEmpty() || \"OrderHeaderReadOnly.SalesCodeId cannot be empty\"},\n {field: \"createdByUserId\", rule: (v: any) => !v.isEmpty() || \"OrderHeaderReadOnly.CreatedByUserId cannot be empty\"},\n {field: \"currentPostingError\", rule: (v: any) => v == null || v.length <= 100000 || \"CurrentPostingError has too many characters (100000)\"},\n ];\n}\n\n\nexport class OrderHeader extends BaseModelObject {\n\n private _collectionTimeId: Guid | null = null;\n /**\n * Collection Time. Just for user information.\n */\n public get collectionTimeId(): Guid | null { return this._collectionTimeId }\n public set collectionTimeId(value: Guid | null) {\n this._collectionTimeId = value === undefined ? null : value;\n }\n private _courierId: Guid | null = null;\n /**\n * Courier. Defaults to Courier chosen for relevant Outlet. Required if distribution type is Courier.\n */\n public get courierId(): Guid | null { return this._courierId }\n public set courierId(value: Guid | null) {\n this._courierId = value === undefined ? null : value;\n }\n /**\n * Customer Reference. Displays on documents, sent to accounts packages.\n * Not Nullable\n * Max Length : 1000\n */\n public customerReference: string = \"\";\n /**\n * Delivery Recipient Name. Just for user information. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public deliveryRecipient: string = \"\";\n /**\n * The email address to use for delivery issues and updates. Just for user information. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public deliveryEmailAddress: string = \"\";\n /**\n * The phone number to use for delivery issues and updates. Just for user information. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public deliveryTelephoneNumber: string = \"\";\n /**\n * Delivery Business Name. Displays on documents. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public deliveryAddressBusiness: string = \"\";\n /**\n * Delivery Address Line 1. Displays in delivery app and documents. Sent to accounts. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public deliveryAddress1: string = \"\";\n /**\n * Delivery Address Line 2. Displays in delivery app and documents. Sent to accounts. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public deliveryAddress2: string = \"\";\n /**\n * Delivery Address Line 3. Displays in delivery app and documents. Sent to accounts. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public deliveryAddress3: string = \"\";\n /**\n * Delivery Address Line 4. Displays in delivery app and documents. Sent to accounts. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public deliveryAddress4: string = \"\";\n /**\n * Delivery Address Line 5 - County. Displays in delivery app and documents. Sent to accounts. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public deliveryAddress5: string = \"\";\n /**\n * Delivery Address Line 6 - Country. Displays in delivery app and documents. Sent to accounts. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public deliveryAddress6: string = \"\";\n private _deliveryAreaId: Guid | null = null;\n /**\n * Delivery Area. Displays in Delivery App. Copies from Outlet by default.\n */\n public get deliveryAreaId(): Guid | null { return this._deliveryAreaId }\n public set deliveryAreaId(value: Guid | null) {\n this._deliveryAreaId = value === undefined ? null : value;\n }\n /**\n * Delivery Post Code. Displays in delivery app and documents. Sent to accounts. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public deliveryPostcode: string = \"\";\n /**\n * User notes relating to dispatch of this order. Displays on documents. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 100000\n */\n public externalDispatchNotes: string = \"\";\n /**\n * Date the order will be / was Delivered. Sent to accounts as the Invoice Date for the order.\n */\n public deliveryDate: LocalDate = LocalDate.ofEpochDay(0);\n private _deliveryTimeEnd: LocalTime | null = null;\n /**\n * End of delivery window. Used for distribution planning and shown in delivery app. Copies from Outlet by default.\n */\n public get deliveryTimeEnd(): LocalTime | null { return this._deliveryTimeEnd }\n public set deliveryTimeEnd(value: LocalTime | null) {\n this._deliveryTimeEnd = value === undefined ? null : value;\n }\n private _deliveryTimeStart: LocalTime | null = null;\n /**\n * Start of delivery window. Used for distribution planning and shown in delivery app. Copies from Outlet by default.\n */\n public get deliveryTimeStart(): LocalTime | null { return this._deliveryTimeStart }\n public set deliveryTimeStart(value: LocalTime | null) {\n this._deliveryTimeStart = value === undefined ? null : value;\n }\n /**\n * Date the order was/will be despatched for delivery. This is also the date at which any duty liability for the order occurs.\n */\n public despatchDate: LocalDate = LocalDate.ofEpochDay(0);\n /**\n * Distribution Type. Drives the manner of distribution, particularly type Delivery which is included in the distribution planning and delivery app. Copied from Outlet by default. : 0 = None, 1 = Delivery, 2 = Courier, 3 = Collection\n */\n public distributionType: EnumDistributionType = EnumDistributionType.none;\n private _dutyReturnDateOverride: LocalDate | null = null;\n /**\n * Special Effective Duty Date for this order. Normally will be null, but can be set if the order is put on BrewMan after the natural duty return has been submitted.\n */\n public get dutyReturnDateOverride(): LocalDate | null { return this._dutyReturnDateOverride }\n public set dutyReturnDateOverride(value: LocalDate | null) {\n this._dutyReturnDateOverride = value === undefined ? null : value;\n }\n /**\n * Whether an invoice has been sent for this order. Just for user information. \n */\n public invoiceSent: boolean = false;\n /**\n * The email address invoices will be sent to. Shown on docs. Used when invoices auto-emailed. Copied from Outlet by default.\n * Not Nullable\n * Max Length : 1000\n */\n public invoiceEmailAddress: string = \"\";\n /**\n * Invoice Recipient Name. Just for user information. Copied from Outlet / Group by default.\n * Not Nullable\n * Max Length : 1000\n */\n public invoiceRecipient: string = \"\";\n /**\n * Invoice Business Name. Shown on docs. Copied from Outlet / Group by default.\n * Not Nullable\n * Max Length : 1000\n */\n public invoiceAddressBusiness: string = \"\";\n /**\n * Invoice Address Line 1. Shown on docs. Sent to accounts. Copied from Outlet / Group by default.\n * Not Nullable\n * Max Length : 1000\n */\n public invoiceAddress1: string = \"\";\n /**\n * Invoice Address Line 2. Shown on docs. Sent to accounts. Copied from Outlet / Group by default.\n * Not Nullable\n * Max Length : 1000\n */\n public invoiceAddress2: string = \"\";\n /**\n * Invoice Address Line 3. Shown on docs. Sent to accounts. Copied from Outlet / Group by default.\n * Not Nullable\n * Max Length : 1000\n */\n public invoiceAddress3: string = \"\";\n /**\n * Invoice Address Line 4. Shown on docs. Sent to accounts. Copied from Outlet / Group by default.\n * Not Nullable\n * Max Length : 1000\n */\n public invoiceAddress4: string = \"\";\n /**\n * Invoice Address Line 5 - County. Shown on docs. Sent to accounts. Copied from Outlet / Group by default.\n * Not Nullable\n * Max Length : 1000\n */\n public invoiceAddress5: string = \"\";\n /**\n * Invoice Address Line 6 - Country. Shown on docs. Sent to accounts. Copied from Outlet / Group by default.\n * Not Nullable\n * Max Length : 1000\n */\n public invoiceAddress6: string = \"\";\n /**\n * Invoice Post Code. Shown on docs. Sent to accounts. Copied from Outlet / Group by default.\n * Not Nullable\n * Max Length : 1000\n */\n public invoicePostcode: string = \"\";\n /**\n * Our Reference. Just for user information.\n * Not Nullable\n * Max Length : 1000\n */\n public ourReference: string = \"\";\n /**\n * Price List used for the order. Affects price calculations and discounts. Controls which products are allowed.\n */\n public priceListId: Guid = Guid.createEmpty();\n /**\n * Retail Payment Method. Used for grouping retail orders when creating summaries to post to accounts. : 0 = None, 1 = DebitCreditCard, 2 = Other, 3 = Cash\n */\n public retailPaymentMethod: EnumRetailPaymentMethod = EnumRetailPaymentMethod.none;\n /**\n * Sales Order Notes. Shown on docs. Sent to accounts.\n * Not Nullable\n * Max Length : 100000\n */\n public salesOrderNotes: string = \"\";\n /**\n * Order Type. Determines the duty implication of the order. Affects weight allocated to lines (export/normal). Can be changed, but all Order Lines should be removed if StandardOrderType is changed. : 0 = FullPriceDutyPaid, 1 = PriceExcludingDutyDutySuspended, 2 = FullPriceDutyPaidElsewhere, 3 = ExportDutySuspended, 4 = ConsumeOnPremisesNoDuty\n */\n public standardOrderType: EnumStandardOrder = EnumStandardOrder.fullPriceDutyPaid;\n /**\n * Expected duration required for a delivery stop, in minutes. Used in distribution planning. Copied from Outlet by default.\n */\n public stopMinutes: number = 0;\n /**\n * Tracking Reference. Just for user information.\n * Not Nullable\n * Max Length : 1000\n */\n public trackingReference: string = \"\";\n /**\n * Vat Code Id applicable to the order. If this is zero-rated then it will be used for lines added to the order instead of the individual product's Vat Code Id. Copied from Outlet by default. \n */\n public vatCodeId: Guid = Guid.createEmpty();\n public readOnly: OrderHeaderReadOnly = new OrderHeaderReadOnly();\n /**\n * Private notes relating to dispatch of this order. Not displayed to customer. Copies from Outlet by default.\n * Not Nullable\n * Max Length : 100000\n */\n public internalDispatchNotes: string = \"\";\n public germanBeerDutyMovementType: EnumGermanBeerDutyMovementType = EnumGermanBeerDutyMovementType.none;\n /**\n * Reference name or number from the Accounts Link posting.\n * Not Nullable\n * Max Length : 1000\n */\n public accountsLinkReferenceName: string = \"\";\n public eireDutyMovementType: EnumEireMovementType = EnumEireMovementType.unknown;\n private _validUntilDate: LocalDate | null = null;\n /**\n * Date until which a draft order is valid.\n */\n public get validUntilDate(): LocalDate | null { return this._validUntilDate }\n public set validUntilDate(value: LocalDate | null) {\n this._validUntilDate = value === undefined ? null : value;\n }\n /**\n * Nature of transaction code.\n */\n public natureOfTransactionCode: EnumNatureOfTransactionCode = EnumNatureOfTransactionCode.none;\n /**\n * Whether an invoice has been printed or downloaded for this order. Just for user information. \n */\n public invoicePrinted: boolean = false;\n private _discountPercentage: number | null = null;\n /**\n * Discount in percentage applied to the whole order and on top of line discounts.\n */\n public get discountPercentage(): number | null { return this._discountPercentage }\n public set discountPercentage(value: number | null) {\n this._discountPercentage = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.collectionTimeId = jsonSerializedObject.collectionTimeId == null ? null : Guid.fromString(jsonSerializedObject.collectionTimeId);\n this.courierId = jsonSerializedObject.courierId == null ? null : Guid.fromString(jsonSerializedObject.courierId);\n this.customerReference = jsonSerializedObject.customerReference;\n this.deliveryRecipient = jsonSerializedObject.deliveryRecipient;\n this.deliveryEmailAddress = jsonSerializedObject.deliveryEmailAddress;\n this.deliveryTelephoneNumber = jsonSerializedObject.deliveryTelephoneNumber;\n this.deliveryAddressBusiness = jsonSerializedObject.deliveryAddressBusiness;\n this.deliveryAddress1 = jsonSerializedObject.deliveryAddress1;\n this.deliveryAddress2 = jsonSerializedObject.deliveryAddress2;\n this.deliveryAddress3 = jsonSerializedObject.deliveryAddress3;\n this.deliveryAddress4 = jsonSerializedObject.deliveryAddress4;\n this.deliveryAddress5 = jsonSerializedObject.deliveryAddress5;\n this.deliveryAddress6 = jsonSerializedObject.deliveryAddress6;\n this.deliveryAreaId = jsonSerializedObject.deliveryAreaId == null ? null : Guid.fromString(jsonSerializedObject.deliveryAreaId);\n this.deliveryPostcode = jsonSerializedObject.deliveryPostcode;\n this.externalDispatchNotes = jsonSerializedObject.externalDispatchNotes;\n this.deliveryDate = LocalDate.parse(jsonSerializedObject.deliveryDate);\n this.deliveryTimeEnd = jsonSerializedObject.deliveryTimeEnd == null ? null : LocalTime.parse(jsonSerializedObject.deliveryTimeEnd);\n this.deliveryTimeStart = jsonSerializedObject.deliveryTimeStart == null ? null : LocalTime.parse(jsonSerializedObject.deliveryTimeStart);\n this.despatchDate = LocalDate.parse(jsonSerializedObject.despatchDate);\n this.distributionType = EnumDistributionType.getByValue(jsonSerializedObject.distributionType, this.distributionType);\n this.dutyReturnDateOverride = jsonSerializedObject.dutyReturnDateOverride == null ? null : LocalDate.parse(jsonSerializedObject.dutyReturnDateOverride);\n this.invoiceSent = jsonSerializedObject.invoiceSent;\n this.invoiceEmailAddress = jsonSerializedObject.invoiceEmailAddress;\n this.invoiceRecipient = jsonSerializedObject.invoiceRecipient;\n this.invoiceAddressBusiness = jsonSerializedObject.invoiceAddressBusiness;\n this.invoiceAddress1 = jsonSerializedObject.invoiceAddress1;\n this.invoiceAddress2 = jsonSerializedObject.invoiceAddress2;\n this.invoiceAddress3 = jsonSerializedObject.invoiceAddress3;\n this.invoiceAddress4 = jsonSerializedObject.invoiceAddress4;\n this.invoiceAddress5 = jsonSerializedObject.invoiceAddress5;\n this.invoiceAddress6 = jsonSerializedObject.invoiceAddress6;\n this.invoicePostcode = jsonSerializedObject.invoicePostcode;\n this.ourReference = jsonSerializedObject.ourReference;\n this.priceListId = Guid.fromString(jsonSerializedObject.priceListId);\n this.retailPaymentMethod = EnumRetailPaymentMethod.getByValue(jsonSerializedObject.retailPaymentMethod, this.retailPaymentMethod);\n this.salesOrderNotes = jsonSerializedObject.salesOrderNotes;\n this.standardOrderType = EnumStandardOrder.getByValue(jsonSerializedObject.standardOrderType, this.standardOrderType);\n this.stopMinutes = jsonSerializedObject.stopMinutes;\n this.trackingReference = jsonSerializedObject.trackingReference;\n this.vatCodeId = Guid.fromString(jsonSerializedObject.vatCodeId);\n this.readOnly = new OrderHeaderReadOnly(jsonSerializedObject.readOnly);\n this.internalDispatchNotes = jsonSerializedObject.internalDispatchNotes;\n this.germanBeerDutyMovementType = EnumGermanBeerDutyMovementType.getByValue(jsonSerializedObject.germanBeerDutyMovementType, this.germanBeerDutyMovementType);\n this.accountsLinkReferenceName = jsonSerializedObject.accountsLinkReferenceName;\n this.eireDutyMovementType = EnumEireMovementType.getByValue(jsonSerializedObject.eireDutyMovementType, this.eireDutyMovementType);\n this.validUntilDate = jsonSerializedObject.validUntilDate == null ? null : LocalDate.parse(jsonSerializedObject.validUntilDate);\n this.natureOfTransactionCode = EnumNatureOfTransactionCode.getByValue(jsonSerializedObject.natureOfTransactionCode, this.natureOfTransactionCode);\n this.invoicePrinted = jsonSerializedObject.invoicePrinted;\n this.discountPercentage = jsonSerializedObject.discountPercentage == null ? null : jsonSerializedObject.discountPercentage;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.collectionTimeId = this.collectionTimeId == null ? null : this.collectionTimeId.toString();\n toRet.courierId = this.courierId == null ? null : this.courierId.toString();\n toRet.customerReference = this.customerReference;\n toRet.deliveryRecipient = this.deliveryRecipient;\n toRet.deliveryEmailAddress = this.deliveryEmailAddress;\n toRet.deliveryTelephoneNumber = this.deliveryTelephoneNumber;\n toRet.deliveryAddressBusiness = this.deliveryAddressBusiness;\n toRet.deliveryAddress1 = this.deliveryAddress1;\n toRet.deliveryAddress2 = this.deliveryAddress2;\n toRet.deliveryAddress3 = this.deliveryAddress3;\n toRet.deliveryAddress4 = this.deliveryAddress4;\n toRet.deliveryAddress5 = this.deliveryAddress5;\n toRet.deliveryAddress6 = this.deliveryAddress6;\n toRet.deliveryAreaId = this.deliveryAreaId == null ? null : this.deliveryAreaId.toString();\n toRet.deliveryPostcode = this.deliveryPostcode;\n toRet.externalDispatchNotes = this.externalDispatchNotes;\n toRet.deliveryDate = this.deliveryDate.toString();\n toRet.deliveryTimeEnd = this.deliveryTimeEnd == null ? null : this.deliveryTimeEnd.toString();\n toRet.deliveryTimeStart = this.deliveryTimeStart == null ? null : this.deliveryTimeStart.toString();\n toRet.despatchDate = this.despatchDate.toString();\n toRet.distributionType = this.distributionType.value;\n toRet.dutyReturnDateOverride = this.dutyReturnDateOverride == null ? null : this.dutyReturnDateOverride.toString();\n toRet.invoiceSent = this.invoiceSent;\n toRet.invoiceEmailAddress = this.invoiceEmailAddress;\n toRet.invoiceRecipient = this.invoiceRecipient;\n toRet.invoiceAddressBusiness = this.invoiceAddressBusiness;\n toRet.invoiceAddress1 = this.invoiceAddress1;\n toRet.invoiceAddress2 = this.invoiceAddress2;\n toRet.invoiceAddress3 = this.invoiceAddress3;\n toRet.invoiceAddress4 = this.invoiceAddress4;\n toRet.invoiceAddress5 = this.invoiceAddress5;\n toRet.invoiceAddress6 = this.invoiceAddress6;\n toRet.invoicePostcode = this.invoicePostcode;\n toRet.ourReference = this.ourReference;\n toRet.priceListId = this.priceListId.toString();\n toRet.retailPaymentMethod = this.retailPaymentMethod.value;\n toRet.salesOrderNotes = this.salesOrderNotes;\n toRet.standardOrderType = this.standardOrderType.value;\n toRet.stopMinutes = this.stopMinutes;\n toRet.trackingReference = this.trackingReference;\n toRet.vatCodeId = this.vatCodeId.toString();\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.internalDispatchNotes = this.internalDispatchNotes;\n toRet.germanBeerDutyMovementType = this.germanBeerDutyMovementType.value;\n toRet.accountsLinkReferenceName = this.accountsLinkReferenceName;\n toRet.eireDutyMovementType = this.eireDutyMovementType.value;\n toRet.validUntilDate = this.validUntilDate == null ? null : this.validUntilDate.toString();\n toRet.natureOfTransactionCode = this.natureOfTransactionCode.value;\n toRet.invoicePrinted = this.invoicePrinted;\n toRet.discountPercentage = this.discountPercentage == null ? null : this.discountPercentage;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"collectionTimeId\", rule: (v: any) => v == null || !v.isEmpty() || \"OrderHeader.CollectionTimeId cannot be empty\"},\n {field: \"courierId\", rule: (v: any) => v == null || !v.isEmpty() || \"OrderHeader.CourierId cannot be empty\"},\n {field: \"customerReference\", rule: (v: any) => v == null || v.length <= 1000 || \"CustomerReference has too many characters (1000)\"},\n {field: \"deliveryRecipient\", rule: (v: any) => v == null || v.length <= 1000 || \"DeliveryRecipient has too many characters (1000)\"},\n {field: \"deliveryEmailAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"DeliveryEmailAddress has too many characters (1000)\"},\n {field: \"deliveryTelephoneNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"DeliveryTelephoneNumber has too many characters (1000)\"},\n {field: \"deliveryAddressBusiness\", rule: (v: any) => v == null || v.length <= 1000 || \"DeliveryAddressBusiness has too many characters (1000)\"},\n {field: \"deliveryAddress1\", rule: (v: any) => v == null || v.length <= 1000 || \"DeliveryAddress1 has too many characters (1000)\"},\n {field: \"deliveryAddress2\", rule: (v: any) => v == null || v.length <= 1000 || \"DeliveryAddress2 has too many characters (1000)\"},\n {field: \"deliveryAddress3\", rule: (v: any) => v == null || v.length <= 1000 || \"DeliveryAddress3 has too many characters (1000)\"},\n {field: \"deliveryAddress4\", rule: (v: any) => v == null || v.length <= 1000 || \"DeliveryAddress4 has too many characters (1000)\"},\n {field: \"deliveryAddress5\", rule: (v: any) => v == null || v.length <= 1000 || \"DeliveryAddress5 has too many characters (1000)\"},\n {field: \"deliveryAddress6\", rule: (v: any) => v == null || v.length <= 1000 || \"DeliveryAddress6 has too many characters (1000)\"},\n {field: \"deliveryAreaId\", rule: (v: any) => v == null || !v.isEmpty() || \"OrderHeader.DeliveryAreaId cannot be empty\"},\n {field: \"deliveryPostcode\", rule: (v: any) => v == null || v.length <= 1000 || \"DeliveryPostcode has too many characters (1000)\"},\n {field: \"externalDispatchNotes\", rule: (v: any) => v == null || v.length <= 100000 || \"ExternalDispatchNotes has too many characters (100000)\"},\n {field: \"invoiceEmailAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"InvoiceEmailAddress has too many characters (1000)\"},\n {field: \"invoiceRecipient\", rule: (v: any) => v == null || v.length <= 1000 || \"InvoiceRecipient has too many characters (1000)\"},\n {field: \"invoiceAddressBusiness\", rule: (v: any) => v == null || v.length <= 1000 || \"InvoiceAddressBusiness has too many characters (1000)\"},\n {field: \"invoiceAddress1\", rule: (v: any) => v == null || v.length <= 1000 || \"InvoiceAddress1 has too many characters (1000)\"},\n {field: \"invoiceAddress2\", rule: (v: any) => v == null || v.length <= 1000 || \"InvoiceAddress2 has too many characters (1000)\"},\n {field: \"invoiceAddress3\", rule: (v: any) => v == null || v.length <= 1000 || \"InvoiceAddress3 has too many characters (1000)\"},\n {field: \"invoiceAddress4\", rule: (v: any) => v == null || v.length <= 1000 || \"InvoiceAddress4 has too many characters (1000)\"},\n {field: \"invoiceAddress5\", rule: (v: any) => v == null || v.length <= 1000 || \"InvoiceAddress5 has too many characters (1000)\"},\n {field: \"invoiceAddress6\", rule: (v: any) => v == null || v.length <= 1000 || \"InvoiceAddress6 has too many characters (1000)\"},\n {field: \"invoicePostcode\", rule: (v: any) => v == null || v.length <= 1000 || \"InvoicePostcode has too many characters (1000)\"},\n {field: \"ourReference\", rule: (v: any) => v == null || v.length <= 1000 || \"OurReference has too many characters (1000)\"},\n {field: \"priceListId\", rule: (v: any) => !v.isEmpty() || \"OrderHeader.PriceListId cannot be empty\"},\n {field: \"salesOrderNotes\", rule: (v: any) => v == null || v.length <= 100000 || \"SalesOrderNotes has too many characters (100000)\"},\n {field: \"stopMinutes\", rule: (v: any) => v == null || v >= -2147483648 || \"StopMinutes is not greater than minimum allowed value: -2147483648\"},\n {field: \"stopMinutes\", rule: (v: any) => v == null || v <= 2147483647 || \"StopMinutes is above maximum allowed value: 2147483647\"},\n {field: \"trackingReference\", rule: (v: any) => v == null || v.length <= 1000 || \"TrackingReference has too many characters (1000)\"},\n {field: \"vatCodeId\", rule: (v: any) => !v.isEmpty() || \"OrderHeader.VatCodeId cannot be empty\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"internalDispatchNotes\", rule: (v: any) => v == null || v.length <= 100000 || \"InternalDispatchNotes has too many characters (100000)\"},\n {field: \"accountsLinkReferenceName\", rule: (v: any) => v == null || v.length <= 1000 || \"AccountsLinkReferenceName has too many characters (1000)\"},\n ];\n}\n\n\nexport class OrderLineReadOnly extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Product Abv. Used largely in duty calculations. Captured from product when adding line to order. Not editable.\n * Not Negative\n */\n public abv: number = 0;\n /**\n * Alcohol Type. Used largely in duty calculations. Captured from product when adding line to order. Not editable.\n */\n public alcoholType: EnumAlcoholType = EnumAlcoholType.none;\n /**\n * Discount Basis. Determines the meaning of UnitDiscount (or UnitDiscountOverride). Captured from the discount applicable when the line was added to the order. Not editable. : 0 = None, 1 = Percent, 2 = CurrencyPerUnit, 3 = CurrencyPerBarrel\n */\n public discountBasis: EnumDiscountBasis = EnumDiscountBasis.none;\n /**\n * Line Cost Price (Inc Duty, Exc Vat). Used for profit calculations. Calculated when line is added to order, or order lines are edited. Not editable.\n */\n public lineCostNetPrice: number = 0;\n /**\n * Net (no VAT) Price charged for the line. Not directly editable, calculated from other line properties (List Price, Discount)\n */\n public lineNetPrice: number = 0;\n /**\n * Total VAT for the line. Not directly editable, calculated from other line properties (List Price, Discount)\n */\n public lineVat: number = 0;\n private _manufacturerId: Guid | null = null;\n /**\n * Manufacturer of the product. Can affect duty (particularly UK Beer Duty). Required if AlcoholType is not None. Copied from Product when line added to order. Not editable.\n */\n public get manufacturerId(): Guid | null { return this._manufacturerId }\n public set manufacturerId(value: Guid | null) {\n this._manufacturerId = value === undefined ? null : value;\n }\n /**\n * Order Header Id\n */\n public orderHeaderId: Guid = Guid.createEmpty();\n private _productBrandId: Guid | null = null;\n /**\n * Product Brand at time of Order. No current functionality. Stored for potential future reporting. Captured from product when line is added to order. Not editable.\n */\n public get productBrandId(): Guid | null { return this._productBrandId }\n public set productBrandId(value: Guid | null) {\n this._productBrandId = value === undefined ? null : value;\n }\n /**\n * Product Code at time of adding line to order. Captured so reprinted invoices etc show original code. Captured from product when line is added to order. Not editable.\n * Not Nullable\n * Max Length : 1000\n */\n public productCode: string = \"\";\n /**\n * Stock Item Id. Given when line is added to order. Not editable.\n */\n public stockItemId: Guid = Guid.createEmpty();\n /**\n * Product Cost Price. Calculated when line is added to order, or order lines are edited. Not editable.\n */\n public unitCostNetPrice: number = 0;\n /**\n * Product Dutiable Litres.\n * Not Negative\n */\n public unitDutiableLitres: number = 0;\n /**\n * Auto-Calculated Discount amount per unit. DiscountBasis identifies how this is interpreted (eg % discount or CurrencyPerUnit Ignored if UnitDiscountOverride is specified. Calculated when line is added to order, or order lines are edited. Not editable.\n * Not Negative\n */\n public unitDiscount: number = 0;\n /**\n * Product Unit Litres. Affects liquid-volume based discounts. Captured from the package type of the product when line is added to order. Not editable.\n * Not Negative\n */\n public unitLitres: number = 0;\n /**\n * Unit Net Price. Evaluated from other pricing information. Not editable.\n */\n public unitNetPrice: number = 0;\n private _pricingCategoryId: Guid | null = null;\n /**\n * Pricing Category. Used for evaluating and reevaluating price/discounts. Captured from product when line is added to order. Not editable\n */\n public get pricingCategoryId(): Guid | null { return this._pricingCategoryId }\n public set pricingCategoryId(value: Guid | null) {\n this._pricingCategoryId = value === undefined ? null : value;\n }\n /**\n * The approximate amount of duty which has/will be paid in fulfilling this order line. This represents the amount of duty included in the line net price, regardless of whether that duty would be chargeable directly due to this specific sale. For example, if the sale is from non-bonded then the duty has already been paid as part of the stock transfer to non-bonded so this sale will not cause a direct duty liability but that duty element will be included in the duty cost of sale. It is approximate because actual duty return calculations will be rounded across multiple orders so cannot be exactly attributed to each individual order. \n */\n public approximateDutyCostOfSale: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.abv = jsonSerializedObject.abv;\n this.alcoholType = EnumAlcoholType.getByValue(jsonSerializedObject.alcoholType, this.alcoholType);\n this.discountBasis = EnumDiscountBasis.getByValue(jsonSerializedObject.discountBasis, this.discountBasis);\n this.lineCostNetPrice = jsonSerializedObject.lineCostNetPrice;\n this.lineNetPrice = jsonSerializedObject.lineNetPrice;\n this.lineVat = jsonSerializedObject.lineVat;\n this.manufacturerId = jsonSerializedObject.manufacturerId == null ? null : Guid.fromString(jsonSerializedObject.manufacturerId);\n this.orderHeaderId = Guid.fromString(jsonSerializedObject.orderHeaderId);\n this.productBrandId = jsonSerializedObject.productBrandId == null ? null : Guid.fromString(jsonSerializedObject.productBrandId);\n this.productCode = jsonSerializedObject.productCode;\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.unitCostNetPrice = jsonSerializedObject.unitCostNetPrice;\n this.unitDutiableLitres = jsonSerializedObject.unitDutiableLitres;\n this.unitDiscount = jsonSerializedObject.unitDiscount;\n this.unitLitres = jsonSerializedObject.unitLitres;\n this.unitNetPrice = jsonSerializedObject.unitNetPrice;\n this.pricingCategoryId = jsonSerializedObject.pricingCategoryId == null ? null : Guid.fromString(jsonSerializedObject.pricingCategoryId);\n this.approximateDutyCostOfSale = jsonSerializedObject.approximateDutyCostOfSale;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.abv = this.abv;\n toRet.alcoholType = this.alcoholType.value;\n toRet.discountBasis = this.discountBasis.value;\n toRet.lineCostNetPrice = this.lineCostNetPrice;\n toRet.lineNetPrice = this.lineNetPrice;\n toRet.lineVat = this.lineVat;\n toRet.manufacturerId = this.manufacturerId == null ? null : this.manufacturerId.toString();\n toRet.orderHeaderId = this.orderHeaderId.toString();\n toRet.productBrandId = this.productBrandId == null ? null : this.productBrandId.toString();\n toRet.productCode = this.productCode;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.unitCostNetPrice = this.unitCostNetPrice;\n toRet.unitDutiableLitres = this.unitDutiableLitres;\n toRet.unitDiscount = this.unitDiscount;\n toRet.unitLitres = this.unitLitres;\n toRet.unitNetPrice = this.unitNetPrice;\n toRet.pricingCategoryId = this.pricingCategoryId == null ? null : this.pricingCategoryId.toString();\n toRet.approximateDutyCostOfSale = this.approximateDutyCostOfSale;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"OrderLineReadOnly.Id cannot be empty\"},\n {field: \"manufacturerId\", rule: (v: any) => v == null || !v.isEmpty() || \"OrderLineReadOnly.ManufacturerId cannot be empty\"},\n {field: \"orderHeaderId\", rule: (v: any) => !v.isEmpty() || \"OrderLineReadOnly.OrderHeaderId cannot be empty\"},\n {field: \"productBrandId\", rule: (v: any) => v == null || !v.isEmpty() || \"OrderLineReadOnly.ProductBrandId cannot be empty\"},\n {field: \"productCode\", rule: (v: any) => v == null || v.length <= 1000 || \"ProductCode has too many characters (1000)\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"OrderLineReadOnly.StockItemId cannot be empty\"},\n {field: \"pricingCategoryId\", rule: (v: any) => v == null || !v.isEmpty() || \"OrderLineReadOnly.PricingCategoryId cannot be empty\"},\n ];\n}\n\n\nexport class OrderLineCalculated extends ModelObject {\n\n private _availableQuantity: number | null = null;\n /**\n * Maximum Quantity which line can be changed to without causing over-commitment. Null if stock not checked or not applicable.\n */\n public get availableQuantity(): number | null { return this._availableQuantity }\n public set availableQuantity(value: number | null) {\n this._availableQuantity = value === undefined ? null : value;\n }\n /**\n * True if the cumulative discount which could apply has been evaluated. False if not checked or not applicable.\n */\n public availableDiscountEvaluated: boolean = false;\n private _availableCumulativeDiscountId: Guid | null = null;\n public get availableCumulativeDiscountId(): Guid | null { return this._availableCumulativeDiscountId }\n public set availableCumulativeDiscountId(value: Guid | null) {\n this._availableCumulativeDiscountId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.availableQuantity = jsonSerializedObject.availableQuantity == null ? null : jsonSerializedObject.availableQuantity;\n this.availableDiscountEvaluated = jsonSerializedObject.availableDiscountEvaluated;\n this.availableCumulativeDiscountId = jsonSerializedObject.availableCumulativeDiscountId == null ? null : Guid.fromString(jsonSerializedObject.availableCumulativeDiscountId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.availableQuantity = this.availableQuantity == null ? null : this.availableQuantity;\n toRet.availableDiscountEvaluated = this.availableDiscountEvaluated;\n toRet.availableCumulativeDiscountId = this.availableCumulativeDiscountId == null ? null : this.availableCumulativeDiscountId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"availableCumulativeDiscountId\", rule: (v: any) => v == null || !v.isEmpty() || \"OrderLineCalculated.AvailableCumulativeDiscountId cannot be empty\"},\n ];\n}\n\n\nexport class OrderLine extends ModelObject {\n\n /**\n * Product Name. Stored so invoice can be recreated. Can be edited (useful for eg Miscellaneous / Guest products). Defaults to name of product when line is added to order.\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public productName: string = \"\";\n /**\n * Quantity Ordered\n * Not Negative\n */\n public quantity: number = 0;\n /**\n * Stock Location Id from which this line is despatched.\n */\n public stockLocationId: Guid = Guid.createEmpty();\n private _unitDiscountOverride: number | null = null;\n /**\n * Unit Discount Override. If not null then this discount level is applied (with meaning given by DiscountBasis) instead of the auto-calculated UnitDiscount.\n */\n public get unitDiscountOverride(): number | null { return this._unitDiscountOverride }\n public set unitDiscountOverride(value: number | null) {\n this._unitDiscountOverride = value === undefined ? null : value;\n }\n /**\n * Discount Override Basis. Determines the meaning of UnitDiscountOverride. : 0 = None, 1 = Percent, 2 = CurrencyPerUnit, 3 = CurrencyPerBarrel\n */\n public discountOverrideBasis: EnumDiscountBasis = EnumDiscountBasis.none;\n /**\n * Unit List Net Price. This is the base list price before any applicable discount. Captured from Price List when line is added to order, but can be edited.\n */\n public unitListNetPrice: number = 0;\n private _unitListGrossPriceForRounding: number | null = null;\n /**\n * Populated with gross product list price from the price list. Used to ensure tax calculations round to the gross value correctly. Null if no rounding is necessary.\n */\n public get unitListGrossPriceForRounding(): number | null { return this._unitListGrossPriceForRounding }\n public set unitListGrossPriceForRounding(value: number | null) {\n this._unitListGrossPriceForRounding = value === undefined ? null : value;\n }\n /**\n * Unit of Measure Id. Captured from product when line is added to order. Not editable.\n */\n public unitOfMeasureId: Guid = Guid.createEmpty();\n public readOnly: OrderLineReadOnly = new OrderLineReadOnly();\n private _calculated: OrderLineCalculated | null = null;\n public get calculated(): OrderLineCalculated | null { return this._calculated }\n public set calculated(value: OrderLineCalculated | null) {\n this._calculated = value === undefined ? null : value;\n }\n public version: number = 0;\n /**\n * Sequence for ordering lines.\n */\n public sequence: number = 0;\n private _bogofId: Guid | null = null;\n /**\n * The Bogof offer, if any, for which this is the free product.\n */\n public get bogofId(): Guid | null { return this._bogofId }\n public set bogofId(value: Guid | null) {\n this._bogofId = value === undefined ? null : value;\n }\n private _plato: number | null = null;\n /**\n * Plato Value\n */\n public get plato(): number | null { return this._plato }\n public set plato(value: number | null) {\n this._plato = value === undefined ? null : value;\n }\n public germanBeerDutyProductType: EnumGermanBeerDutyProductType = EnumGermanBeerDutyProductType.none;\n private _germanBeerMixedProductPercentageA: number | null = null;\n public get germanBeerMixedProductPercentageA(): number | null { return this._germanBeerMixedProductPercentageA }\n public set germanBeerMixedProductPercentageA(value: number | null) {\n this._germanBeerMixedProductPercentageA = value === undefined ? null : value;\n }\n /**\n * Set true if this item is brewed by members of the public for their personal use by borrowing the Brewery's equipment. This is a service offered by breweries in some countries, such as Australia, and can affect duty.\n */\n public isBrewedForPersonalUse: boolean = false;\n /**\n * Set true if this item is designed to be connected to a pump or pressurised gas system, such as those used in pubs. Some duty systems have different duty rates for beer packaged in these manners for selling to pubs.\n */\n public isDesignedForPump: boolean = false;\n private _finalUnitLitres: number | null = null;\n /**\n * Litres held by the final consumable packaged unit, if relevant. For example, a case of 12 x 500ml bottles would have a final unit litres of 0.5. Some duty systems have different rates depending upon this value.\n * Greater Than : 0\n */\n public get finalUnitLitres(): number | null { return this._finalUnitLitres }\n public set finalUnitLitres(value: number | null) {\n this._finalUnitLitres = value === undefined ? null : value;\n }\n public spiritDutyExemptionReason: EnumSpiritDutyExemptionReason = EnumSpiritDutyExemptionReason.none;\n /**\n * Vat Percentage at time of order.\n * Not Negative\n */\n public vatPercentage: number = 0;\n /**\n * Vat Code Applicable to the line.\n */\n public vatCodeId: Guid = Guid.createEmpty();\n /**\n * General Ledger Code of Line. Sent to accounts (currently Xero only). Captured from Product (and possibly override for order OutletTypeId) when line is added to order. Not editable.\n */\n public glCodeId: Guid = Guid.createEmpty();\n private _dateOfProductionDutyRate: LocalDate | null = null;\n /**\n * An optional date identifying the duty rate in force at the time the item was produced. Used for UK alcohol duty, where products qualifying for SPR are charged at the rate in force at date of production, not date of crossing duty boundary. To make management easier we only track the date to granularity of rate changes, So eg a value of 2023-08-01 would represent the period from 2023-08-01 to 2024-01-31 because rates did not change in this period.\n */\n public get dateOfProductionDutyRate(): LocalDate | null { return this._dateOfProductionDutyRate }\n public set dateOfProductionDutyRate(value: LocalDate | null) {\n this._dateOfProductionDutyRate = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.productName = jsonSerializedObject.productName;\n this.quantity = jsonSerializedObject.quantity;\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.unitDiscountOverride = jsonSerializedObject.unitDiscountOverride == null ? null : jsonSerializedObject.unitDiscountOverride;\n this.discountOverrideBasis = EnumDiscountBasis.getByValue(jsonSerializedObject.discountOverrideBasis, this.discountOverrideBasis);\n this.unitListNetPrice = jsonSerializedObject.unitListNetPrice;\n this.unitListGrossPriceForRounding = jsonSerializedObject.unitListGrossPriceForRounding == null ? null : jsonSerializedObject.unitListGrossPriceForRounding;\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n this.readOnly = new OrderLineReadOnly(jsonSerializedObject.readOnly);\n this.calculated = jsonSerializedObject.calculated == null ? null : new OrderLineCalculated(jsonSerializedObject.calculated);\n this.version = jsonSerializedObject.version;\n this.sequence = jsonSerializedObject.sequence;\n this.bogofId = jsonSerializedObject.bogofId == null ? null : Guid.fromString(jsonSerializedObject.bogofId);\n this.plato = jsonSerializedObject.plato == null ? null : jsonSerializedObject.plato;\n this.germanBeerDutyProductType = EnumGermanBeerDutyProductType.getByValue(jsonSerializedObject.germanBeerDutyProductType, this.germanBeerDutyProductType);\n this.germanBeerMixedProductPercentageA = jsonSerializedObject.germanBeerMixedProductPercentageA == null ? null : jsonSerializedObject.germanBeerMixedProductPercentageA;\n this.isBrewedForPersonalUse = jsonSerializedObject.isBrewedForPersonalUse;\n this.isDesignedForPump = jsonSerializedObject.isDesignedForPump;\n this.finalUnitLitres = jsonSerializedObject.finalUnitLitres == null ? null : jsonSerializedObject.finalUnitLitres;\n this.spiritDutyExemptionReason = EnumSpiritDutyExemptionReason.getByValue(jsonSerializedObject.spiritDutyExemptionReason, this.spiritDutyExemptionReason);\n this.vatPercentage = jsonSerializedObject.vatPercentage;\n this.vatCodeId = Guid.fromString(jsonSerializedObject.vatCodeId);\n this.glCodeId = Guid.fromString(jsonSerializedObject.glCodeId);\n this.dateOfProductionDutyRate = jsonSerializedObject.dateOfProductionDutyRate == null ? null : LocalDate.parse(jsonSerializedObject.dateOfProductionDutyRate);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.productName = this.productName;\n toRet.quantity = this.quantity;\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.unitDiscountOverride = this.unitDiscountOverride == null ? null : this.unitDiscountOverride;\n toRet.discountOverrideBasis = this.discountOverrideBasis.value;\n toRet.unitListNetPrice = this.unitListNetPrice;\n toRet.unitListGrossPriceForRounding = this.unitListGrossPriceForRounding == null ? null : this.unitListGrossPriceForRounding;\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.calculated = this.calculated == null ? null : this.calculated?.toJsonSerializedObject() ?? null;\n toRet.version = this.version;\n toRet.sequence = this.sequence;\n toRet.bogofId = this.bogofId == null ? null : this.bogofId.toString();\n toRet.plato = this.plato == null ? null : this.plato;\n toRet.germanBeerDutyProductType = this.germanBeerDutyProductType.value;\n toRet.germanBeerMixedProductPercentageA = this.germanBeerMixedProductPercentageA == null ? null : this.germanBeerMixedProductPercentageA;\n toRet.isBrewedForPersonalUse = this.isBrewedForPersonalUse;\n toRet.isDesignedForPump = this.isDesignedForPump;\n toRet.finalUnitLitres = this.finalUnitLitres == null ? null : this.finalUnitLitres;\n toRet.spiritDutyExemptionReason = this.spiritDutyExemptionReason.value;\n toRet.vatPercentage = this.vatPercentage;\n toRet.vatCodeId = this.vatCodeId.toString();\n toRet.glCodeId = this.glCodeId.toString();\n toRet.dateOfProductionDutyRate = this.dateOfProductionDutyRate == null ? null : this.dateOfProductionDutyRate.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"productName\", rule: (v: any) => v == null || v.length !== 0 || \"ProductName cannot be empty\"},\n {field: \"productName\", rule: (v: any) => v == null || v.length <= 1000 || \"ProductName has too many characters (1000)\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \"OrderLine.StockLocationId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"OrderLine.UnitOfMeasureId cannot be empty\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"calculated\", rule: (v: any) => (v === null) || v.validate()},\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"sequence\", rule: (v: any) => v == null || v >= -2147483648 || \"Sequence is not greater than minimum allowed value: -2147483648\"},\n {field: \"sequence\", rule: (v: any) => v == null || v <= 2147483647 || \"Sequence is above maximum allowed value: 2147483647\"},\n {field: \"bogofId\", rule: (v: any) => v == null || !v.isEmpty() || \"OrderLine.BogofId cannot be empty\"},\n {field: \"finalUnitLitres\", rule: (v: any) => v == null || v > 0 || \"FinalUnitLitres is not greater than minimum allowed value: 0\"},\n {field: \"vatCodeId\", rule: (v: any) => !v.isEmpty() || \"OrderLine.VatCodeId cannot be empty\"},\n {field: \"glCodeId\", rule: (v: any) => !v.isEmpty() || \"OrderLine.GlCodeId cannot be empty\"},\n ];\n}\n\n\nexport class Order extends BaseModelObject {\n\n public header: OrderHeader = new OrderHeader();\n public lines: OrderLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.header = new OrderHeader(jsonSerializedObject.header);\n this.lines = jsonSerializedObject.lines.map((v: any) => new OrderLine(v));\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.header = this.header.toJsonSerializedObject();\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OrderLine[]).reduce((acc: Array, curr: OrderLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class FilteredOrdersResult extends ModelObject {\n\n public matchingCount: number = 0;\n public orders: Order[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.orders = jsonSerializedObject.orders.map((v: any) => new Order(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.orders = this.orders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"orders\", rule: (v: any) => !!v || \"orders is required\"},\n {field: \"orders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Order[]).reduce((acc: Array, curr: Order) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class AdvancedProductSearchResult extends ModelObject {\n\n public stockItemId: Guid = Guid.createEmpty();\n public stockItemCode: string = \"\";\n public stockItemName: string = \"\";\n public listPrice: number = 0;\n private _discountId: Guid | null = null;\n public get discountId(): Guid | null { return this._discountId }\n public set discountId(value: Guid | null) {\n this._discountId = value === undefined ? null : value;\n }\n private _availableQuantity: number | null = null;\n /**\n * Maximum number which can be added without being oversubscribed. Null if not stock tracked\n */\n public get availableQuantity(): number | null { return this._availableQuantity }\n public set availableQuantity(value: number | null) {\n this._availableQuantity = value === undefined ? null : value;\n }\n public isHidden: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.stockItemCode = jsonSerializedObject.stockItemCode;\n this.stockItemName = jsonSerializedObject.stockItemName;\n this.listPrice = jsonSerializedObject.listPrice;\n this.discountId = jsonSerializedObject.discountId == null ? null : Guid.fromString(jsonSerializedObject.discountId);\n this.availableQuantity = jsonSerializedObject.availableQuantity == null ? null : jsonSerializedObject.availableQuantity;\n this.isHidden = jsonSerializedObject.isHidden;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.stockItemCode = this.stockItemCode;\n toRet.stockItemName = this.stockItemName;\n toRet.listPrice = this.listPrice;\n toRet.discountId = this.discountId == null ? null : this.discountId.toString();\n toRet.availableQuantity = this.availableQuantity == null ? null : this.availableQuantity;\n toRet.isHidden = this.isHidden;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"AdvancedProductSearchResult.StockItemId cannot be empty\"},\n {field: \"discountId\", rule: (v: any) => v == null || !v.isEmpty() || \"AdvancedProductSearchResult.DiscountId cannot be empty\"},\n ];\n}\n\n\nexport class FindItemsAllowedOnOrderResult extends ModelObject {\n\n public itemId: Guid = Guid.createEmpty();\n public itemCode: string = \"\";\n public itemName: string = \"\";\n public listPrice: number = 0;\n private _discountId: Guid | null = null;\n public get discountId(): Guid | null { return this._discountId }\n public set discountId(value: Guid | null) {\n this._discountId = value === undefined ? null : value;\n }\n private _availableQuantity: number | null = null;\n /**\n * Maximum number which can be added without being oversubscribed. Null if not stock tracked\n */\n public get availableQuantity(): number | null { return this._availableQuantity }\n public set availableQuantity(value: number | null) {\n this._availableQuantity = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.itemId = Guid.fromString(jsonSerializedObject.itemId);\n this.itemCode = jsonSerializedObject.itemCode;\n this.itemName = jsonSerializedObject.itemName;\n this.listPrice = jsonSerializedObject.listPrice;\n this.discountId = jsonSerializedObject.discountId == null ? null : Guid.fromString(jsonSerializedObject.discountId);\n this.availableQuantity = jsonSerializedObject.availableQuantity == null ? null : jsonSerializedObject.availableQuantity;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.itemId = this.itemId.toString();\n toRet.itemCode = this.itemCode;\n toRet.itemName = this.itemName;\n toRet.listPrice = this.listPrice;\n toRet.discountId = this.discountId == null ? null : this.discountId.toString();\n toRet.availableQuantity = this.availableQuantity == null ? null : this.availableQuantity;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"itemId\", rule: (v: any) => !v.isEmpty() || \"FindItemsAllowedOnOrderResult.ItemId cannot be empty\"},\n {field: \"discountId\", rule: (v: any) => v == null || !v.isEmpty() || \"FindItemsAllowedOnOrderResult.DiscountId cannot be empty\"},\n ];\n}\n\n\nexport class OrderExpectedStockLevelDelta extends ModelObject {\n\n public stockItemId: Guid = Guid.createEmpty();\n public sourceType: EnumStockMovementReferenceSource = EnumStockMovementReferenceSource.none;\n public sourceId: Guid = Guid.createEmpty();\n public stockChangeDate: LocalDate = LocalDate.ofEpochDay(0);\n public stockLevelIncrease: number = 0;\n public unitOfMeasureId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.sourceType = EnumStockMovementReferenceSource.getByValue(jsonSerializedObject.sourceType, this.sourceType);\n this.sourceId = Guid.fromString(jsonSerializedObject.sourceId);\n this.stockChangeDate = LocalDate.parse(jsonSerializedObject.stockChangeDate);\n this.stockLevelIncrease = jsonSerializedObject.stockLevelIncrease;\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.sourceType = this.sourceType.value;\n toRet.sourceId = this.sourceId.toString();\n toRet.stockChangeDate = this.stockChangeDate.toString();\n toRet.stockLevelIncrease = this.stockLevelIncrease;\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"OrderExpectedStockLevelDelta.StockItemId cannot be empty\"},\n {field: \"sourceId\", rule: (v: any) => !v.isEmpty() || \"OrderExpectedStockLevelDelta.SourceId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"OrderExpectedStockLevelDelta.UnitOfMeasureId cannot be empty\"},\n ];\n}\n\n\nexport class DutySuspendedOrdersResultSet extends ModelObject {\n\n public alcoholType: EnumAlcoholType = EnumAlcoholType.none;\n public dutySuspendedSentLitres: number = 0;\n public dutySuspendedSentLitresOfAlcohol: number = 0;\n public orderType: EnumStandardOrder = EnumStandardOrder.fullPriceDutyPaid;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.alcoholType = EnumAlcoholType.getByValue(jsonSerializedObject.alcoholType, this.alcoholType);\n this.dutySuspendedSentLitres = jsonSerializedObject.dutySuspendedSentLitres;\n this.dutySuspendedSentLitresOfAlcohol = jsonSerializedObject.dutySuspendedSentLitresOfAlcohol;\n this.orderType = EnumStandardOrder.getByValue(jsonSerializedObject.orderType, this.orderType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.alcoholType = this.alcoholType.value;\n toRet.dutySuspendedSentLitres = this.dutySuspendedSentLitres;\n toRet.dutySuspendedSentLitresOfAlcohol = this.dutySuspendedSentLitresOfAlcohol;\n toRet.orderType = this.orderType.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class PartialOrder extends ModelObject {\n\n public header: OrderHeader = new OrderHeader();\n public lines: OrderLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.header = new OrderHeader(jsonSerializedObject.header);\n this.lines = jsonSerializedObject.lines.map((v: any) => new OrderLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.header = this.header.toJsonSerializedObject();\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OrderLine[]).reduce((acc: Array, curr: OrderLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class OrderIdBatch extends ModelObject {\n\n public orderIds: Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.orderIds = jsonSerializedObject.orderIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.orderIds = this.orderIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class ImportOrderLine extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Net (no VAT) Price charged for the line. Not directly editable, calculated from other line properties (List Price, Discount)\n */\n public lineNetPrice: number = 0;\n /**\n * Total VAT for the line. Not directly editable, calculated from other line properties (List Price, Discount)\n */\n public lineVat: number = 0;\n /**\n * Product Name. Stored so invoice can be recreated. Can be edited (useful for eg Miscellaneous / Guest products). Defaults to name of product when line is added to order.\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public productName: string = \"\";\n /**\n * Quantity Ordered\n * Not Negative\n */\n public quantity: number = 0;\n /**\n * Stock Item Id. Given when line is added to order. Not editable.\n */\n public stockItemId: Guid = Guid.createEmpty();\n /**\n * Stock Location Id from which this line is despatched.\n */\n public stockLocationId: Guid = Guid.createEmpty();\n /**\n * Unit Net Price. Evaluated from other pricing information. Not editable.\n */\n public unitNetPrice: number = 0;\n /**\n * Vat Percentage at time of order.\n * Not Negative\n */\n public vatPercentage: number = 0;\n /**\n * Vat Code Applicable to the line.\n */\n public vatCodeId: Guid = Guid.createEmpty();\n private _isDesignedForPump: boolean | null = null;\n public get isDesignedForPump(): boolean | null { return this._isDesignedForPump }\n public set isDesignedForPump(value: boolean | null) {\n this._isDesignedForPump = value === undefined ? null : value;\n }\n public currencyPerUnitNetDiscountApplied: number = 0;\n private _bogofId: Guid | null = null;\n /**\n * The Bogof offer, if any, for which this is the free product.\n */\n public get bogofId(): Guid | null { return this._bogofId }\n public set bogofId(value: Guid | null) {\n this._bogofId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.lineNetPrice = jsonSerializedObject.lineNetPrice;\n this.lineVat = jsonSerializedObject.lineVat;\n this.productName = jsonSerializedObject.productName;\n this.quantity = jsonSerializedObject.quantity;\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.unitNetPrice = jsonSerializedObject.unitNetPrice;\n this.vatPercentage = jsonSerializedObject.vatPercentage;\n this.vatCodeId = Guid.fromString(jsonSerializedObject.vatCodeId);\n this.isDesignedForPump = jsonSerializedObject.isDesignedForPump == null ? null : jsonSerializedObject.isDesignedForPump;\n this.currencyPerUnitNetDiscountApplied = jsonSerializedObject.currencyPerUnitNetDiscountApplied;\n this.bogofId = jsonSerializedObject.bogofId == null ? null : Guid.fromString(jsonSerializedObject.bogofId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.lineNetPrice = this.lineNetPrice;\n toRet.lineVat = this.lineVat;\n toRet.productName = this.productName;\n toRet.quantity = this.quantity;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.unitNetPrice = this.unitNetPrice;\n toRet.vatPercentage = this.vatPercentage;\n toRet.vatCodeId = this.vatCodeId.toString();\n toRet.isDesignedForPump = this.isDesignedForPump == null ? null : this.isDesignedForPump;\n toRet.currencyPerUnitNetDiscountApplied = this.currencyPerUnitNetDiscountApplied;\n toRet.bogofId = this.bogofId == null ? null : this.bogofId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"ImportOrderLine.Id cannot be empty\"},\n {field: \"productName\", rule: (v: any) => v == null || v.length !== 0 || \"ProductName cannot be empty\"},\n {field: \"productName\", rule: (v: any) => v == null || v.length <= 1000 || \"ProductName has too many characters (1000)\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"ImportOrderLine.StockItemId cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \"ImportOrderLine.StockLocationId cannot be empty\"},\n {field: \"vatCodeId\", rule: (v: any) => !v.isEmpty() || \"ImportOrderLine.VatCodeId cannot be empty\"},\n {field: \"bogofId\", rule: (v: any) => v == null || !v.isEmpty() || \"ImportOrderLine.BogofId cannot be empty\"},\n ];\n}\n\n\nexport class SuggestedInvoiceLine extends ModelObject {\n\n public stockItemId: Guid = Guid.createEmpty();\n public productName: string = \"\";\n public stockLocationId: Guid = Guid.createEmpty();\n public qtyDelivered: number = 0;\n public listPrice: number = 0;\n private _discount: number | null = null;\n public get discount(): number | null { return this._discount }\n public set discount(value: number | null) {\n this._discount = value === undefined ? null : value;\n }\n public unitPrice: number = 0;\n public lineTotal: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.productName = jsonSerializedObject.productName;\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.qtyDelivered = jsonSerializedObject.qtyDelivered;\n this.listPrice = jsonSerializedObject.listPrice;\n this.discount = jsonSerializedObject.discount == null ? null : jsonSerializedObject.discount;\n this.unitPrice = jsonSerializedObject.unitPrice;\n this.lineTotal = jsonSerializedObject.lineTotal;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.productName = this.productName;\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.qtyDelivered = this.qtyDelivered;\n toRet.listPrice = this.listPrice;\n toRet.discount = this.discount == null ? null : this.discount;\n toRet.unitPrice = this.unitPrice;\n toRet.lineTotal = this.lineTotal;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"SuggestedInvoiceLine.StockItemId cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \"SuggestedInvoiceLine.StockLocationId cannot be empty\"},\n ];\n}\n\n\nexport class DuplicateOrderSummary extends ModelObject {\n\n /**\n * The order requested for duplication\n */\n public sourceOrderId: Guid = Guid.createEmpty();\n private _targetOrderId: Guid | null = null;\n /**\n * The duplicate order created, if any\n */\n public get targetOrderId(): Guid | null { return this._targetOrderId }\n public set targetOrderId(value: Guid | null) {\n this._targetOrderId = value === undefined ? null : value;\n }\n /**\n * Errors preventing full duplication of the order. Note that errors may be associated with only some lines, in which case duplication of the order will still be possible but will omit the lines showing errors.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public errors: string[] = [];\n /**\n * Indicates if duplication (which may be full or partial) is possible. If errors indicates any errors then duplication will only be partial and will omit the lines with errors.\n */\n public isPossible: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.sourceOrderId = Guid.fromString(jsonSerializedObject.sourceOrderId);\n this.targetOrderId = jsonSerializedObject.targetOrderId == null ? null : Guid.fromString(jsonSerializedObject.targetOrderId);\n this.errors = jsonSerializedObject.errors.map((v: any) => v);\n this.isPossible = jsonSerializedObject.isPossible;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.sourceOrderId = this.sourceOrderId.toString();\n toRet.targetOrderId = this.targetOrderId == null ? null : this.targetOrderId.toString();\n toRet.errors = this.errors.map(v => v);\n toRet.isPossible = this.isPossible;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"sourceOrderId\", rule: (v: any) => !v.isEmpty() || \"DuplicateOrderSummary.SourceOrderId cannot be empty\"},\n {field: \"targetOrderId\", rule: (v: any) => v == null || !v.isEmpty() || \"DuplicateOrderSummary.TargetOrderId cannot be empty\"},\n ];\n}\n\n\nexport class OutletLastOrderTimestamp extends ModelObject {\n\n public outletId: Guid = Guid.createEmpty();\n private _latestOrderCreatedAt: Instant | null = null;\n public get latestOrderCreatedAt(): Instant | null { return this._latestOrderCreatedAt }\n public set latestOrderCreatedAt(value: Instant | null) {\n this._latestOrderCreatedAt = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n this.latestOrderCreatedAt = jsonSerializedObject.latestOrderCreatedAt == null ? null : Instant.parse(jsonSerializedObject.latestOrderCreatedAt);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outletId = this.outletId.toString();\n toRet.latestOrderCreatedAt = this.latestOrderCreatedAt == null ? null : this.latestOrderCreatedAt.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \"OutletLastOrderTimestamp.OutletId cannot be empty\"},\n ];\n}\n\n\nexport class TopSellingItem extends ModelObject {\n\n public itemId: Guid = Guid.createEmpty();\n public quantitySold: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.itemId = Guid.fromString(jsonSerializedObject.itemId);\n this.quantitySold = jsonSerializedObject.quantitySold;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.itemId = this.itemId.toString();\n toRet.quantitySold = this.quantitySold;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"itemId\", rule: (v: any) => !v.isEmpty() || \"TopSellingItem.ItemId cannot be empty\"},\n ];\n}\n\n\nexport class GetOrderSummariesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: OrderFilter = new OrderFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new OrderFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetOrderSummariesResponse extends ModelObject {\n\n public results: OrderSummariesResult = new OrderSummariesResult();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new OrderSummariesResult(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetOrderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderId = this.orderId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n ];\n}\n\n\nexport class GetOrderResponse extends ModelObject {\n\n public order: Order = new Order();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.order = new Order(jsonSerializedObject.order);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.order = this.order.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"order\", rule: (v: any) => !!v || \"order is required\"},\n {field: \"order\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetOrdersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderIds: readonly Guid[] = [];\n public checkStockForLines: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderIds = jsonSerializedObject.orderIds.map((v: any) => Guid.fromString(v));\n this.checkStockForLines = jsonSerializedObject.checkStockForLines;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderIds = this.orderIds.map(v => v.toString());\n toRet.checkStockForLines = this.checkStockForLines;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetOrdersResponse extends ModelObject {\n\n public orders: Order[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.orders = jsonSerializedObject.orders.map((v: any) => new Order(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.orders = this.orders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"orders\", rule: (v: any) => !!v || \"orders is required\"},\n {field: \"orders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Order[]).reduce((acc: Array, curr: Order) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetOrderHeadersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderIds = jsonSerializedObject.orderIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderIds = this.orderIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetOrderHeadersResponse extends ModelObject {\n\n public orderHeaders: OrderHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.orderHeaders = jsonSerializedObject.orderHeaders.map((v: any) => new OrderHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.orderHeaders = this.orderHeaders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"orderHeaders\", rule: (v: any) => !!v || \"orderHeaders is required\"},\n {field: \"orderHeaders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OrderHeader[]).reduce((acc: Array, curr: OrderHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetOrdersByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: OrderFilter = new OrderFilter();\n public checkStockForLines: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new OrderFilter(jsonSerializedObject.filter);\n this.checkStockForLines = jsonSerializedObject.checkStockForLines;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n toRet.checkStockForLines = this.checkStockForLines;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetOrdersByFilterResponse extends ModelObject {\n\n public results: FilteredOrdersResult = new FilteredOrdersResult();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredOrdersResult(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class CreateOrderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n /**\n * Outlet which the order is for. Shown on docs. Used to determine which contact in accounts the order is sent to (if not invoiced to group). Outlet is required at order create and then Not editable.\n */\n public outletId: Guid = Guid.createEmpty();\n /**\n * Customer Reference. Displays on documents, sent to accounts packages.\n * Not Nullable\n * Max Length : 1000\n */\n public customerReference: string = \"\";\n /**\n * Date the order will be / was Delivered. Sent to accounts as the Invoice Date for the order.\n */\n public deliveryDate: LocalDate = LocalDate.ofEpochDay(0);\n /**\n * Date the order was/will be despatched for delivery. This is also the date at which any duty liability for the order occurs.\n */\n public despatchDate: LocalDate = LocalDate.ofEpochDay(0);\n private _dutyReturnDateOverride: LocalDate | null = null;\n /**\n * Special Effective Duty Date for this order. Normally will be null, but can be set if the order is put on BrewMan after the natural duty return has been submitted.\n */\n public get dutyReturnDateOverride(): LocalDate | null { return this._dutyReturnDateOverride }\n public set dutyReturnDateOverride(value: LocalDate | null) {\n this._dutyReturnDateOverride = value === undefined ? null : value;\n }\n /**\n * Order Type. Determines the duty implication of the order. Affects weight allocated to lines (export/normal). Can be changed, but all Order Lines should be removed if StandardOrderType is changed. : 0 = FullPriceDutyPaid, 1 = PriceExcludingDutyDutySuspended, 2 = FullPriceDutyPaidElsewhere, 3 = ExportDutySuspended, 4 = ConsumeOnPremisesNoDuty\n */\n public standardOrderType: EnumStandardOrder = EnumStandardOrder.fullPriceDutyPaid;\n /**\n * Price List used for the order. Affects price calculations and discounts. Controls which products are allowed.\n */\n public priceListId: Guid = Guid.createEmpty();\n /**\n * Order Source. Assigned at order creation. Not editable. : 0 = None, 1 = BrewMan, 2 = WooCommerce, 3 = Shopify, 4 = Sellar, 5 = Zettle, 6 = Other, 7 = EposNow, 8 = Beerflex, 9 = Square, 10 = Squarespace, 11 = Ecwid, 12 = EeBria, 13 = Commerce7, 14 = TradePortal, 15 = Amazon\n */\n public orderSource: EnumOrderSource = EnumOrderSource.none;\n /**\n * Reference of Order in External system. (OrderSource identifies which system the order was imported from eg WooCommerce / Shopify). Not editable.\n * Not Nullable\n * Max Length : 1000\n */\n public externalReference: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n this.customerReference = jsonSerializedObject.customerReference;\n this.deliveryDate = LocalDate.parse(jsonSerializedObject.deliveryDate);\n this.despatchDate = LocalDate.parse(jsonSerializedObject.despatchDate);\n this.dutyReturnDateOverride = jsonSerializedObject.dutyReturnDateOverride == null ? null : LocalDate.parse(jsonSerializedObject.dutyReturnDateOverride);\n this.standardOrderType = EnumStandardOrder.getByValue(jsonSerializedObject.standardOrderType, this.standardOrderType);\n this.priceListId = Guid.fromString(jsonSerializedObject.priceListId);\n this.orderSource = EnumOrderSource.getByValue(jsonSerializedObject.orderSource, this.orderSource);\n this.externalReference = jsonSerializedObject.externalReference;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletId = this.outletId.toString();\n toRet.customerReference = this.customerReference;\n toRet.deliveryDate = this.deliveryDate.toString();\n toRet.despatchDate = this.despatchDate.toString();\n toRet.dutyReturnDateOverride = this.dutyReturnDateOverride == null ? null : this.dutyReturnDateOverride.toString();\n toRet.standardOrderType = this.standardOrderType.value;\n toRet.priceListId = this.priceListId.toString();\n toRet.orderSource = this.orderSource.value;\n toRet.externalReference = this.externalReference;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \".OutletId cannot be empty\"},\n {field: \"customerReference\", rule: (v: any) => v == null || v.length <= 1000 || \"CustomerReference has too many characters (1000)\"},\n {field: \"priceListId\", rule: (v: any) => !v.isEmpty() || \".PriceListId cannot be empty\"},\n {field: \"externalReference\", rule: (v: any) => v == null || v.length <= 1000 || \"ExternalReference has too many characters (1000)\"},\n ];\n}\n\n\nexport class CreateOrderResponse extends ModelObject {\n\n public order: Order = new Order();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.order = new Order(jsonSerializedObject.order);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.order = this.order.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"order\", rule: (v: any) => !!v || \"order is required\"},\n {field: \"order\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class AddLineToOrderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderId: Guid = Guid.createEmpty();\n public orderLineId: Guid = Guid.createEmpty();\n public stockLocationId: Guid = Guid.createEmpty();\n public stockItemId: Guid = Guid.createEmpty();\n public quantity: number = 0;\n public unitOfMeasureId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n this.orderLineId = Guid.fromString(jsonSerializedObject.orderLineId);\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.quantity = jsonSerializedObject.quantity;\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderId = this.orderId.toString();\n toRet.orderLineId = this.orderLineId.toString();\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.stockItemId = this.stockItemId.toString();\n toRet.quantity = this.quantity;\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n {field: \"orderLineId\", rule: (v: any) => !v.isEmpty() || \".OrderLineId cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \".StockLocationId cannot be empty\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \".StockItemId cannot be empty\"},\n {field: \"quantity\", rule: (v: any) => v == null || v > 0 || \"Quantity is not greater than minimum allowed value: 0\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \".UnitOfMeasureId cannot be empty\"},\n ];\n}\n\n\nexport class AddLineToOrderResponse extends ModelObject {\n\n public order: Order = new Order();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.order = new Order(jsonSerializedObject.order);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.order = this.order.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"order\", rule: (v: any) => !!v || \"order is required\"},\n {field: \"order\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class UpdateOrderLineRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderId: Guid = Guid.createEmpty();\n public orderLineId: Guid = Guid.createEmpty();\n public line: OrderLine = new OrderLine();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n this.orderLineId = Guid.fromString(jsonSerializedObject.orderLineId);\n this.line = new OrderLine(jsonSerializedObject.line);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderId = this.orderId.toString();\n toRet.orderLineId = this.orderLineId.toString();\n toRet.line = this.line.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n {field: \"orderLineId\", rule: (v: any) => !v.isEmpty() || \".OrderLineId cannot be empty\"},\n {field: \"line\", rule: (v: any) => !!v || \"line is required\"},\n {field: \"line\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class UpdateOrderLineResponse extends ModelObject {\n\n public order: Order = new Order();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.order = new Order(jsonSerializedObject.order);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.order = this.order.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"order\", rule: (v: any) => !!v || \"order is required\"},\n {field: \"order\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class DeleteLinesFromOrderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderHeaderId: Guid = Guid.createEmpty();\n public lineIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderHeaderId = Guid.fromString(jsonSerializedObject.orderHeaderId);\n this.lineIds = jsonSerializedObject.lineIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderHeaderId = this.orderHeaderId.toString();\n toRet.lineIds = this.lineIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderHeaderId\", rule: (v: any) => !v.isEmpty() || \".OrderHeaderId cannot be empty\"},\n ];\n}\n\n\nexport class DeleteLinesFromOrderResponse extends ModelObject {\n\n public order: Order = new Order();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.order = new Order(jsonSerializedObject.order);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.order = this.order.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"order\", rule: (v: any) => !!v || \"order is required\"},\n {field: \"order\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class BuildOrderStandardDeliveryServiceLineRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderHeader: OrderHeader = new OrderHeader();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderHeader = new OrderHeader(jsonSerializedObject.orderHeader);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderHeader = this.orderHeader.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderHeader\", rule: (v: any) => !!v || \"orderHeader is required\"},\n {field: \"orderHeader\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class BuildOrderStandardDeliveryServiceLineResponse extends ModelObject {\n\n private _deliveryServiceLine: OrderLine | null = null;\n public get deliveryServiceLine(): OrderLine | null { return this._deliveryServiceLine }\n public set deliveryServiceLine(value: OrderLine | null) {\n this._deliveryServiceLine = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.deliveryServiceLine = jsonSerializedObject.deliveryServiceLine == null ? null : new OrderLine(jsonSerializedObject.deliveryServiceLine);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.deliveryServiceLine = this.deliveryServiceLine == null ? null : this.deliveryServiceLine?.toJsonSerializedObject() ?? null;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"deliveryServiceLine\", rule: (v: any) => (v === null) || v.validate()},\n ];\n}\n\n\nexport class UpdateOrderDetailsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderHeaderId: Guid = Guid.createEmpty();\n public header: OrderHeader = new OrderHeader();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderHeaderId = Guid.fromString(jsonSerializedObject.orderHeaderId);\n this.header = new OrderHeader(jsonSerializedObject.header);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderHeaderId = this.orderHeaderId.toString();\n toRet.header = this.header.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderHeaderId\", rule: (v: any) => !v.isEmpty() || \".OrderHeaderId cannot be empty\"},\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class UpdateOrderDetailsResponse extends ModelObject {\n\n public order: Order = new Order();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.order = new Order(jsonSerializedObject.order);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.order = this.order.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"order\", rule: (v: any) => !!v || \"order is required\"},\n {field: \"order\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class AssignInvoiceNumbersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderHeaderIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderHeaderIds = jsonSerializedObject.orderHeaderIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderHeaderIds = this.orderHeaderIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class AssignInvoiceNumbersResponse extends ModelObject {\n\n public orderHeaders: OrderHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.orderHeaders = jsonSerializedObject.orderHeaders.map((v: any) => new OrderHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.orderHeaders = this.orderHeaders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"orderHeaders\", rule: (v: any) => !!v || \"orderHeaders is required\"},\n {field: \"orderHeaders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OrderHeader[]).reduce((acc: Array, curr: OrderHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class AdvancedProductSearch2Request extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public despatchDate: LocalDate = LocalDate.ofEpochDay(0);\n public priceListId: Guid = Guid.createEmpty();\n public stockLocationId: Guid = Guid.createEmpty();\n public vatCodeId: Guid = Guid.createEmpty();\n public outletId: Guid = Guid.createEmpty();\n private _groupId: Guid | null = null;\n public get groupId(): Guid | null { return this._groupId }\n public set groupId(value: Guid | null) {\n this._groupId = value === undefined ? null : value;\n }\n public standardOrderType: EnumStandardOrder = EnumStandardOrder.fullPriceDutyPaid;\n private _productBrandId: Guid | null = null;\n public get productBrandId(): Guid | null { return this._productBrandId }\n public set productBrandId(value: Guid | null) {\n this._productBrandId = value === undefined ? null : value;\n }\n private _packageTypeId: Guid | null = null;\n public get packageTypeId(): Guid | null { return this._packageTypeId }\n public set packageTypeId(value: Guid | null) {\n this._packageTypeId = value === undefined ? null : value;\n }\n private _supplierId: Guid | null = null;\n public get supplierId(): Guid | null { return this._supplierId }\n public set supplierId(value: Guid | null) {\n this._supplierId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.despatchDate = LocalDate.parse(jsonSerializedObject.despatchDate);\n this.priceListId = Guid.fromString(jsonSerializedObject.priceListId);\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.vatCodeId = Guid.fromString(jsonSerializedObject.vatCodeId);\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n this.groupId = jsonSerializedObject.groupId == null ? null : Guid.fromString(jsonSerializedObject.groupId);\n this.standardOrderType = EnumStandardOrder.getByValue(jsonSerializedObject.standardOrderType, this.standardOrderType);\n this.productBrandId = jsonSerializedObject.productBrandId == null ? null : Guid.fromString(jsonSerializedObject.productBrandId);\n this.packageTypeId = jsonSerializedObject.packageTypeId == null ? null : Guid.fromString(jsonSerializedObject.packageTypeId);\n this.supplierId = jsonSerializedObject.supplierId == null ? null : Guid.fromString(jsonSerializedObject.supplierId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.despatchDate = this.despatchDate.toString();\n toRet.priceListId = this.priceListId.toString();\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.vatCodeId = this.vatCodeId.toString();\n toRet.outletId = this.outletId.toString();\n toRet.groupId = this.groupId == null ? null : this.groupId.toString();\n toRet.standardOrderType = this.standardOrderType.value;\n toRet.productBrandId = this.productBrandId == null ? null : this.productBrandId.toString();\n toRet.packageTypeId = this.packageTypeId == null ? null : this.packageTypeId.toString();\n toRet.supplierId = this.supplierId == null ? null : this.supplierId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"priceListId\", rule: (v: any) => !v.isEmpty() || \".PriceListId cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \".StockLocationId cannot be empty\"},\n {field: \"vatCodeId\", rule: (v: any) => !v.isEmpty() || \".VatCodeId cannot be empty\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \".OutletId cannot be empty\"},\n {field: \"groupId\", rule: (v: any) => v == null || !v.isEmpty() || \".GroupId cannot be empty\"},\n {field: \"productBrandId\", rule: (v: any) => v == null || !v.isEmpty() || \".ProductBrandId cannot be empty\"},\n {field: \"packageTypeId\", rule: (v: any) => v == null || !v.isEmpty() || \".PackageTypeId cannot be empty\"},\n {field: \"supplierId\", rule: (v: any) => v == null || !v.isEmpty() || \".SupplierId cannot be empty\"},\n ];\n}\n\n\nexport class AdvancedProductSearch2Response extends ModelObject {\n\n public results: AdvancedProductSearchResult[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new AdvancedProductSearchResult(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AdvancedProductSearchResult[]).reduce((acc: Array, curr: AdvancedProductSearchResult) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class AdvancedProductSearchRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderId: Guid = Guid.createEmpty();\n public stockLocationId: Guid = Guid.createEmpty();\n private _productBrandId: Guid | null = null;\n public get productBrandId(): Guid | null { return this._productBrandId }\n public set productBrandId(value: Guid | null) {\n this._productBrandId = value === undefined ? null : value;\n }\n private _packageTypeId: Guid | null = null;\n public get packageTypeId(): Guid | null { return this._packageTypeId }\n public set packageTypeId(value: Guid | null) {\n this._packageTypeId = value === undefined ? null : value;\n }\n private _supplierId: Guid | null = null;\n public get supplierId(): Guid | null { return this._supplierId }\n public set supplierId(value: Guid | null) {\n this._supplierId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.productBrandId = jsonSerializedObject.productBrandId == null ? null : Guid.fromString(jsonSerializedObject.productBrandId);\n this.packageTypeId = jsonSerializedObject.packageTypeId == null ? null : Guid.fromString(jsonSerializedObject.packageTypeId);\n this.supplierId = jsonSerializedObject.supplierId == null ? null : Guid.fromString(jsonSerializedObject.supplierId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderId = this.orderId.toString();\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.productBrandId = this.productBrandId == null ? null : this.productBrandId.toString();\n toRet.packageTypeId = this.packageTypeId == null ? null : this.packageTypeId.toString();\n toRet.supplierId = this.supplierId == null ? null : this.supplierId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \".StockLocationId cannot be empty\"},\n {field: \"productBrandId\", rule: (v: any) => v == null || !v.isEmpty() || \".ProductBrandId cannot be empty\"},\n {field: \"packageTypeId\", rule: (v: any) => v == null || !v.isEmpty() || \".PackageTypeId cannot be empty\"},\n {field: \"supplierId\", rule: (v: any) => v == null || !v.isEmpty() || \".SupplierId cannot be empty\"},\n ];\n}\n\n\nexport class AdvancedProductSearchResponse extends ModelObject {\n\n public results: AdvancedProductSearchResult[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new AdvancedProductSearchResult(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AdvancedProductSearchResult[]).reduce((acc: Array, curr: AdvancedProductSearchResult) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class FindItemsAllowedOnOrderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderId: Guid = Guid.createEmpty();\n public stockLocationId: Guid = Guid.createEmpty();\n private _productBrandId: Guid | null = null;\n public get productBrandId(): Guid | null { return this._productBrandId }\n public set productBrandId(value: Guid | null) {\n this._productBrandId = value === undefined ? null : value;\n }\n private _packageTypeId: Guid | null = null;\n public get packageTypeId(): Guid | null { return this._packageTypeId }\n public set packageTypeId(value: Guid | null) {\n this._packageTypeId = value === undefined ? null : value;\n }\n private _supplierId: Guid | null = null;\n public get supplierId(): Guid | null { return this._supplierId }\n public set supplierId(value: Guid | null) {\n this._supplierId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.productBrandId = jsonSerializedObject.productBrandId == null ? null : Guid.fromString(jsonSerializedObject.productBrandId);\n this.packageTypeId = jsonSerializedObject.packageTypeId == null ? null : Guid.fromString(jsonSerializedObject.packageTypeId);\n this.supplierId = jsonSerializedObject.supplierId == null ? null : Guid.fromString(jsonSerializedObject.supplierId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderId = this.orderId.toString();\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.productBrandId = this.productBrandId == null ? null : this.productBrandId.toString();\n toRet.packageTypeId = this.packageTypeId == null ? null : this.packageTypeId.toString();\n toRet.supplierId = this.supplierId == null ? null : this.supplierId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \".StockLocationId cannot be empty\"},\n {field: \"productBrandId\", rule: (v: any) => v == null || !v.isEmpty() || \".ProductBrandId cannot be empty\"},\n {field: \"packageTypeId\", rule: (v: any) => v == null || !v.isEmpty() || \".PackageTypeId cannot be empty\"},\n {field: \"supplierId\", rule: (v: any) => v == null || !v.isEmpty() || \".SupplierId cannot be empty\"},\n ];\n}\n\n\nexport class FindItemsAllowedOnOrderResponse extends ModelObject {\n\n public results: FindItemsAllowedOnOrderResult[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new FindItemsAllowedOnOrderResult(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as FindItemsAllowedOnOrderResult[]).reduce((acc: Array, curr: FindItemsAllowedOnOrderResult) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class CancelOrderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderId: Guid = Guid.createEmpty();\n /**\n * Reason Order Cancelled. Expected to be provided at time of cancelling an order.\n * Not Nullable\n * Not Empty\n * Max Length : 100000\n */\n public cancellationReason: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n this.cancellationReason = jsonSerializedObject.cancellationReason;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderId = this.orderId.toString();\n toRet.cancellationReason = this.cancellationReason;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n {field: \"cancellationReason\", rule: (v: any) => v == null || v.length !== 0 || \"CancellationReason cannot be empty\"},\n {field: \"cancellationReason\", rule: (v: any) => v == null || v.length <= 100000 || \"CancellationReason has too many characters (100000)\"},\n ];\n}\n\n\nexport class CancelOrderResponse extends ModelObject {\n\n public order: Order = new Order();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.order = new Order(jsonSerializedObject.order);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.order = this.order.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"order\", rule: (v: any) => !!v || \"order is required\"},\n {field: \"order\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class CompleteOrderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderId = this.orderId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n ];\n}\n\n\nexport class CompleteOrderResponse extends ModelObject {\n\n public order: Order = new Order();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.order = new Order(jsonSerializedObject.order);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.order = this.order.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"order\", rule: (v: any) => !!v || \"order is required\"},\n {field: \"order\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class CompleteOrdersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderIds = jsonSerializedObject.orderIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderIds = this.orderIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class UncompleteOrderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderId = this.orderId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n ];\n}\n\n\nexport class UncompleteOrderResponse extends ModelObject {\n\n public order: Order = new Order();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.order = new Order(jsonSerializedObject.order);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.order = this.order.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"order\", rule: (v: any) => !!v || \"order is required\"},\n {field: \"order\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class UncompleteOrdersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderIds = jsonSerializedObject.orderIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderIds = this.orderIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class ArchiveOrdersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderIds = jsonSerializedObject.orderIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderIds = this.orderIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetOrderExpectedStockLevelDeltasRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockLocationId: Guid = Guid.createEmpty();\n public stockItemIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.stockItemIds = jsonSerializedObject.stockItemIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.stockItemIds = this.stockItemIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \".StockLocationId cannot be empty\"},\n ];\n}\n\n\nexport class GetOrderExpectedStockLevelDeltasResponse extends ModelObject {\n\n public results: OrderExpectedStockLevelDelta[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new OrderExpectedStockLevelDelta(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OrderExpectedStockLevelDelta[]).reduce((acc: Array, curr: OrderExpectedStockLevelDelta) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class EvaluateDutySuspendedOrdersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public fromDutyDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public toDutyDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public limitToGivenAlcoholTypes: boolean = false;\n public limitedAlcoholTypes: readonly EnumAlcoholType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.fromDutyDateInclusive = LocalDate.parse(jsonSerializedObject.fromDutyDateInclusive);\n this.toDutyDateInclusive = LocalDate.parse(jsonSerializedObject.toDutyDateInclusive);\n this.limitToGivenAlcoholTypes = jsonSerializedObject.limitToGivenAlcoholTypes;\n this.limitedAlcoholTypes = jsonSerializedObject.limitedAlcoholTypes.map((v: any) => EnumAlcoholType.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.fromDutyDateInclusive = this.fromDutyDateInclusive.toString();\n toRet.toDutyDateInclusive = this.toDutyDateInclusive.toString();\n toRet.limitToGivenAlcoholTypes = this.limitToGivenAlcoholTypes;\n toRet.limitedAlcoholTypes = this.limitedAlcoholTypes.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class EvaluateDutySuspendedOrdersResponse extends ModelObject {\n\n public results: DutySuspendedOrdersResultSet[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new DutySuspendedOrdersResultSet(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as DutySuspendedOrdersResultSet[]).reduce((acc: Array, curr: DutySuspendedOrdersResultSet) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetPossibleOrderDutyLinesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public fromDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public toDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public limitedAlcoholTypes: readonly EnumAlcoholType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.fromDateInclusive = LocalDate.parse(jsonSerializedObject.fromDateInclusive);\n this.toDateInclusive = LocalDate.parse(jsonSerializedObject.toDateInclusive);\n this.limitedAlcoholTypes = jsonSerializedObject.limitedAlcoholTypes.map((v: any) => EnumAlcoholType.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.fromDateInclusive = this.fromDateInclusive.toString();\n toRet.toDateInclusive = this.toDateInclusive.toString();\n toRet.limitedAlcoholTypes = this.limitedAlcoholTypes.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetPossibleOrderDutyLinesResponse extends ModelObject {\n\n public results: PartialOrder[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new PartialOrder(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PartialOrder[]).reduce((acc: Array, curr: PartialOrder) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class AllocateInvoiceNumbersForRetailOrderBatchesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderBatches: readonly OrderIdBatch[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderBatches = jsonSerializedObject.orderBatches.map((v: any) => new OrderIdBatch(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderBatches = this.orderBatches.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderBatches\", rule: (v: any) => !!v || \"orderBatches is required\"},\n {field: \"orderBatches\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OrderIdBatch[]).reduce((acc: Array, curr: OrderIdBatch) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class AllocateInvoiceNumbersForRetailOrderBatchesResponse extends ModelObject {\n\n public invoiceNumbers: string[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.invoiceNumbers = jsonSerializedObject.invoiceNumbers.map((v: any) => v);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.invoiceNumbers = this.invoiceNumbers.map(v => v);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class ImportOrderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderHeader: OrderHeader = new OrderHeader();\n /**\n * Outlet which the order is for. Shown on docs. Used to determine which contact in accounts the order is sent to (if not invoiced to group). Outlet is required at order create and then Not editable.\n */\n public outletId: Guid = Guid.createEmpty();\n /**\n * Reference of Order in External system. (OrderSource identifies which system the order was imported from eg WooCommerce / Shopify). Not editable.\n * Not Nullable\n * Max Length : 1000\n */\n public externalReference: string = \"\";\n /**\n * Order Source. Assigned at order creation. Not editable. : 0 = None, 1 = BrewMan, 2 = WooCommerce, 3 = Shopify, 4 = Sellar, 5 = Zettle, 6 = Other, 7 = EposNow, 8 = Beerflex, 9 = Square, 10 = Squarespace, 11 = Ecwid, 12 = EeBria, 13 = Commerce7, 14 = TradePortal, 15 = Amazon\n */\n public orderSource: EnumOrderSource = EnumOrderSource.none;\n private _deliveryLatitude: number | null = null;\n /**\n * Latitude of delviery address (if known). Used for distribution planning, routing, mapping. Copies from Outlet by default. Not directly editable by user, but updated automatically when order delivery address changed.\n */\n public get deliveryLatitude(): number | null { return this._deliveryLatitude }\n public set deliveryLatitude(value: number | null) {\n this._deliveryLatitude = value === undefined ? null : value;\n }\n private _deliveryLongitude: number | null = null;\n /**\n * Longitude of delviery address (if known). Used for distribution planning, routing, mapping. Copies from Outlet by default. Not directly editable by user, but updated automatically when order delivery address changed.\n */\n public get deliveryLongitude(): number | null { return this._deliveryLongitude }\n public set deliveryLongitude(value: number | null) {\n this._deliveryLongitude = value === undefined ? null : value;\n }\n private _forcedGroupId: Guid | null = null;\n public get forcedGroupId(): Guid | null { return this._forcedGroupId }\n public set forcedGroupId(value: Guid | null) {\n this._forcedGroupId = value === undefined ? null : value;\n }\n public lines: readonly ImportOrderLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderHeader = new OrderHeader(jsonSerializedObject.orderHeader);\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n this.externalReference = jsonSerializedObject.externalReference;\n this.orderSource = EnumOrderSource.getByValue(jsonSerializedObject.orderSource, this.orderSource);\n this.deliveryLatitude = jsonSerializedObject.deliveryLatitude == null ? null : jsonSerializedObject.deliveryLatitude;\n this.deliveryLongitude = jsonSerializedObject.deliveryLongitude == null ? null : jsonSerializedObject.deliveryLongitude;\n this.forcedGroupId = jsonSerializedObject.forcedGroupId == null ? null : Guid.fromString(jsonSerializedObject.forcedGroupId);\n this.lines = jsonSerializedObject.lines.map((v: any) => new ImportOrderLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderHeader = this.orderHeader.toJsonSerializedObject();\n toRet.outletId = this.outletId.toString();\n toRet.externalReference = this.externalReference;\n toRet.orderSource = this.orderSource.value;\n toRet.deliveryLatitude = this.deliveryLatitude == null ? null : this.deliveryLatitude;\n toRet.deliveryLongitude = this.deliveryLongitude == null ? null : this.deliveryLongitude;\n toRet.forcedGroupId = this.forcedGroupId == null ? null : this.forcedGroupId.toString();\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderHeader\", rule: (v: any) => !!v || \"orderHeader is required\"},\n {field: \"orderHeader\", rule: (v: any) => v.validate()},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \".OutletId cannot be empty\"},\n {field: \"externalReference\", rule: (v: any) => v == null || v.length <= 1000 || \"ExternalReference has too many characters (1000)\"},\n {field: \"forcedGroupId\", rule: (v: any) => v == null || !v.isEmpty() || \".ForcedGroupId cannot be empty\"},\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ImportOrderLine[]).reduce((acc: Array, curr: ImportOrderLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class ImportOrderResponse extends ModelObject {\n\n public order: Order = new Order();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.order = new Order(jsonSerializedObject.order);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.order = this.order.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"order\", rule: (v: any) => !!v || \"order is required\"},\n {field: \"order\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class UpdateOrderLinesToMatchDeliveredRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderId = this.orderId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n ];\n}\n\n\nexport class GetSuggestedInvoiceRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderId = this.orderId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n ];\n}\n\n\nexport class GetSuggestedInvoiceResponse extends ModelObject {\n\n public invoice: SuggestedInvoiceLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.invoice = jsonSerializedObject.invoice.map((v: any) => new SuggestedInvoiceLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.invoice = this.invoice.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"invoice\", rule: (v: any) => !!v || \"invoice is required\"},\n {field: \"invoice\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as SuggestedInvoiceLine[]).reduce((acc: Array, curr: SuggestedInvoiceLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class RemoveOrdersOnRetailSummaryRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderIds = jsonSerializedObject.orderIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderIds = this.orderIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class MarkOrdersAsDraftRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderIds = jsonSerializedObject.orderIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderIds = this.orderIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class ConfirmDraftOrderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderId = this.orderId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n ];\n}\n\n\nexport class MarkOrdersForPostingRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderIds = jsonSerializedObject.orderIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderIds = this.orderIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class UnmarkOrdersForPostingRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditIds = jsonSerializedObject.creditIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditIds = this.creditIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class RecordOrderPostingResultRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderId: Guid = Guid.createEmpty();\n /**\n * Error text, if any. Empty implies posting was successful.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public postingError: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n this.postingError = jsonSerializedObject.postingError;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderId = this.orderId.toString();\n toRet.postingError = this.postingError;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n ];\n}\n\n\nexport class RecordRetailOrderSummaryPostingResultRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public retailSummaryInvoiceNumber: string = \"\";\n /**\n * Error text, if any. Empty implies posting was successful.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public postingError: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.retailSummaryInvoiceNumber = jsonSerializedObject.retailSummaryInvoiceNumber;\n this.postingError = jsonSerializedObject.postingError;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.retailSummaryInvoiceNumber = this.retailSummaryInvoiceNumber;\n toRet.postingError = this.postingError;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetDuplicateOrderSummaryRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n /**\n * Order to consider for duplication.\n */\n public orderId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderId = this.orderId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n ];\n}\n\n\nexport class GetDuplicateOrderSummaryResponse extends ModelObject {\n\n public duplicateOrderSummary: DuplicateOrderSummary = new DuplicateOrderSummary();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.duplicateOrderSummary = new DuplicateOrderSummary(jsonSerializedObject.duplicateOrderSummary);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.duplicateOrderSummary = this.duplicateOrderSummary.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"duplicateOrderSummary\", rule: (v: any) => !!v || \"duplicateOrderSummary is required\"},\n {field: \"duplicateOrderSummary\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class DuplicateOrderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n /**\n * Order to be duplicated.\n */\n public orderId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderId = this.orderId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n ];\n}\n\n\nexport class DuplicateOrderResponse extends ModelObject {\n\n public duplicateOrderSummary: DuplicateOrderSummary = new DuplicateOrderSummary();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.duplicateOrderSummary = new DuplicateOrderSummary(jsonSerializedObject.duplicateOrderSummary);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.duplicateOrderSummary = this.duplicateOrderSummary.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"duplicateOrderSummary\", rule: (v: any) => !!v || \"duplicateOrderSummary is required\"},\n {field: \"duplicateOrderSummary\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class UpdateOrderApproximateDutyCostsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderIds = jsonSerializedObject.orderIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderIds = this.orderIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class UpdateOrderApproximateDutyCostsResponse extends ModelObject {\n\n public affectedOrderIds: Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.affectedOrderIds = jsonSerializedObject.affectedOrderIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.affectedOrderIds = this.affectedOrderIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class UpdateOrderLineSequenceRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderId: Guid = Guid.createEmpty();\n public orderLineIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n this.orderLineIds = jsonSerializedObject.orderLineIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderId = this.orderId.toString();\n toRet.orderLineIds = this.orderLineIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n ];\n}\n\n\nexport class GetLastOrderTimestampsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletIds = jsonSerializedObject.outletIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletIds = this.outletIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetLastOrderTimestampsResponse extends ModelObject {\n\n public lastOrderTimestamps: OutletLastOrderTimestamp[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.lastOrderTimestamps = jsonSerializedObject.lastOrderTimestamps.map((v: any) => new OutletLastOrderTimestamp(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.lastOrderTimestamps = this.lastOrderTimestamps.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"lastOrderTimestamps\", rule: (v: any) => !!v || \"lastOrderTimestamps is required\"},\n {field: \"lastOrderTimestamps\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OutletLastOrderTimestamp[]).reduce((acc: Array, curr: OutletLastOrderTimestamp) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class UpdateAccountsLinkReferenceNameRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderId: Guid = Guid.createEmpty();\n public accountsLinkReferenceName: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n this.accountsLinkReferenceName = jsonSerializedObject.accountsLinkReferenceName;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderId = this.orderId.toString();\n toRet.accountsLinkReferenceName = this.accountsLinkReferenceName;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n ];\n}\n\n\nexport class SaveOrderHeaderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public header: OrderHeader = new OrderHeader();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.header = new OrderHeader(jsonSerializedObject.header);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.header = this.header.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class BuildOrderHeaderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletId = this.outletId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \".OutletId cannot be empty\"},\n ];\n}\n\n\nexport class BuildOrderHeaderResponse extends ModelObject {\n\n public header: OrderHeader = new OrderHeader();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.header = new OrderHeader(jsonSerializedObject.header);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.header = this.header.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveOrderLineRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderId: Guid = Guid.createEmpty();\n public line: OrderLine = new OrderLine();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n this.line = new OrderLine(jsonSerializedObject.line);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderId = this.orderId.toString();\n toRet.line = this.line.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n {field: \"line\", rule: (v: any) => !!v || \"line is required\"},\n {field: \"line\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class BuildOrderLineRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderId: Guid = Guid.createEmpty();\n public itemId: Guid = Guid.createEmpty();\n public quantity: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n this.itemId = Guid.fromString(jsonSerializedObject.itemId);\n this.quantity = jsonSerializedObject.quantity;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderId = this.orderId.toString();\n toRet.itemId = this.itemId.toString();\n toRet.quantity = this.quantity;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n {field: \"itemId\", rule: (v: any) => !v.isEmpty() || \".ItemId cannot be empty\"},\n ];\n}\n\n\nexport class BuildOrderLineResponse extends ModelObject {\n\n public line: OrderLine = new OrderLine();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.line = new OrderLine(jsonSerializedObject.line);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.line = this.line.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"line\", rule: (v: any) => !!v || \"line is required\"},\n {field: \"line\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class FindTopSellingProductsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public maxResults: number = 0;\n public fromDate: LocalDate = LocalDate.ofEpochDay(0);\n public toDate: LocalDate = LocalDate.ofEpochDay(0);\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.maxResults = jsonSerializedObject.maxResults;\n this.fromDate = LocalDate.parse(jsonSerializedObject.fromDate);\n this.toDate = LocalDate.parse(jsonSerializedObject.toDate);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.maxResults = this.maxResults;\n toRet.fromDate = this.fromDate.toString();\n toRet.toDate = this.toDate.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"maxResults\", rule: (v: any) => v == null || v >= -2147483648 || \"MaxResults is not greater than minimum allowed value: -2147483648\"},\n {field: \"maxResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaxResults is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class FindTopSellingProductsResponse extends ModelObject {\n\n public results: TopSellingItem[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new TopSellingItem(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as TopSellingItem[]).reduce((acc: Array, curr: TopSellingItem) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class UpdateTradePortalTransactionFeeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderId: Guid = Guid.createEmpty();\n public transactionFee: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n this.transactionFee = jsonSerializedObject.transactionFee;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderId = this.orderId.toString();\n toRet.transactionFee = this.transactionFee;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n ];\n}\n\n\nexport class UpdateOrderDetailsToCurrentRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public orderId: Guid = Guid.createEmpty();\n public applyListPrices: boolean = false;\n public applyGlCodes: boolean = false;\n public applyVatCodes: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n this.applyListPrices = jsonSerializedObject.applyListPrices;\n this.applyGlCodes = jsonSerializedObject.applyGlCodes;\n this.applyVatCodes = jsonSerializedObject.applyVatCodes;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.orderId = this.orderId.toString();\n toRet.applyListPrices = this.applyListPrices;\n toRet.applyGlCodes = this.applyGlCodes;\n toRet.applyVatCodes = this.applyVatCodes;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n ];\n}\n\n\nexport class OrderService extends ServiceBase {\n\n public async getOrderSummaries(tenantId: Guid, filter: OrderFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetOrderSummariesRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetOrderSummariesResponse(response).results;\n return this.makeJsonRequest(\"order/v1/getOrderSummaries\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getOrder(tenantId: Guid, orderId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetOrderRequest();\n req.tenantId = tenantId;\n req.orderId = orderId;\n const extractor = (response:any) => new GetOrderResponse(response).order;\n return this.makeJsonRequest(\"order/v1/getOrder\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getOrders(tenantId: Guid, orderIds: readonly Guid[], checkStockForLines: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetOrdersRequest();\n req.tenantId = tenantId;\n req.orderIds = orderIds;\n req.checkStockForLines = checkStockForLines;\n const extractor = (response:any) => new GetOrdersResponse(response).orders;\n return this.makeJsonRequest(\"order/v1/getOrders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getOrderHeaders(tenantId: Guid, orderIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetOrderHeadersRequest();\n req.tenantId = tenantId;\n req.orderIds = orderIds;\n const extractor = (response:any) => new GetOrderHeadersResponse(response).orderHeaders;\n return this.makeJsonRequest(\"order/v1/getOrderHeaders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getOrdersByFilter(tenantId: Guid, filter: OrderFilter, checkStockForLines: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetOrdersByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n req.checkStockForLines = checkStockForLines;\n const extractor = (response:any) => new GetOrdersByFilterResponse(response).results;\n return this.makeJsonRequest(\"order/v1/getOrdersByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async createOrder(tenantId: Guid, outletId: Guid, customerReference: string, deliveryDate: LocalDate, despatchDate: LocalDate, dutyReturnDateOverride: LocalDate | null, standardOrderType: EnumStandardOrder, priceListId: Guid, orderSource: EnumOrderSource, externalReference: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CreateOrderRequest();\n req.tenantId = tenantId;\n req.outletId = outletId;\n req.customerReference = customerReference;\n req.deliveryDate = deliveryDate;\n req.despatchDate = despatchDate;\n req.dutyReturnDateOverride = dutyReturnDateOverride;\n req.standardOrderType = standardOrderType;\n req.priceListId = priceListId;\n req.orderSource = orderSource;\n req.externalReference = externalReference;\n const extractor = (response:any) => new CreateOrderResponse(response).order;\n return this.makeJsonRequest(\"order/v1/createOrder\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async addLineToOrder(tenantId: Guid, orderId: Guid, orderLineId: Guid, stockLocationId: Guid, stockItemId: Guid, quantity: number, unitOfMeasureId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new AddLineToOrderRequest();\n req.tenantId = tenantId;\n req.orderId = orderId;\n req.orderLineId = orderLineId;\n req.stockLocationId = stockLocationId;\n req.stockItemId = stockItemId;\n req.quantity = quantity;\n req.unitOfMeasureId = unitOfMeasureId;\n const extractor = (response:any) => new AddLineToOrderResponse(response).order;\n return this.makeJsonRequest(\"order/v1/addLineToOrder\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updateOrderLine(tenantId: Guid, orderId: Guid, orderLineId: Guid, line: OrderLine, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdateOrderLineRequest();\n req.tenantId = tenantId;\n req.orderId = orderId;\n req.orderLineId = orderLineId;\n req.line = line;\n const extractor = (response:any) => new UpdateOrderLineResponse(response).order;\n return this.makeJsonRequest(\"order/v1/updateOrderLine\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async deleteLinesFromOrder(tenantId: Guid, orderHeaderId: Guid, lineIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new DeleteLinesFromOrderRequest();\n req.tenantId = tenantId;\n req.orderHeaderId = orderHeaderId;\n req.lineIds = lineIds;\n const extractor = (response:any) => new DeleteLinesFromOrderResponse(response).order;\n return this.makeJsonRequest(\"order/v1/deleteLinesFromOrder\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async buildOrderStandardDeliveryServiceLine(tenantId: Guid, orderHeader: OrderHeader, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new BuildOrderStandardDeliveryServiceLineRequest();\n req.tenantId = tenantId;\n req.orderHeader = orderHeader;\n const extractor = (response:any) => new BuildOrderStandardDeliveryServiceLineResponse(response).deliveryServiceLine;\n return this.makeJsonRequest(\"order/v1/buildOrderStandardDeliveryServiceLine\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updateOrderDetails(tenantId: Guid, orderHeaderId: Guid, header: OrderHeader, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdateOrderDetailsRequest();\n req.tenantId = tenantId;\n req.orderHeaderId = orderHeaderId;\n req.header = header;\n const extractor = (response:any) => new UpdateOrderDetailsResponse(response).order;\n return this.makeJsonRequest(\"order/v1/updateOrderDetails\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async assignInvoiceNumbers(tenantId: Guid, orderHeaderIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new AssignInvoiceNumbersRequest();\n req.tenantId = tenantId;\n req.orderHeaderIds = orderHeaderIds;\n const extractor = (response:any) => new AssignInvoiceNumbersResponse(response).orderHeaders;\n return this.makeJsonRequest(\"order/v1/assignInvoiceNumbers\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async advancedProductSearch2(tenantId: Guid, despatchDate: LocalDate, priceListId: Guid, stockLocationId: Guid, vatCodeId: Guid, outletId: Guid, groupId: Guid | null, standardOrderType: EnumStandardOrder, productBrandId: Guid | null, packageTypeId: Guid | null, supplierId: Guid | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new AdvancedProductSearch2Request();\n req.tenantId = tenantId;\n req.despatchDate = despatchDate;\n req.priceListId = priceListId;\n req.stockLocationId = stockLocationId;\n req.vatCodeId = vatCodeId;\n req.outletId = outletId;\n req.groupId = groupId;\n req.standardOrderType = standardOrderType;\n req.productBrandId = productBrandId;\n req.packageTypeId = packageTypeId;\n req.supplierId = supplierId;\n const extractor = (response:any) => new AdvancedProductSearch2Response(response).results;\n return this.makeJsonRequest(\"order/v1/advancedProductSearch2\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async advancedProductSearch(tenantId: Guid, orderId: Guid, stockLocationId: Guid, productBrandId: Guid | null, packageTypeId: Guid | null, supplierId: Guid | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new AdvancedProductSearchRequest();\n req.tenantId = tenantId;\n req.orderId = orderId;\n req.stockLocationId = stockLocationId;\n req.productBrandId = productBrandId;\n req.packageTypeId = packageTypeId;\n req.supplierId = supplierId;\n const extractor = (response:any) => new AdvancedProductSearchResponse(response).results;\n return this.makeJsonRequest(\"order/v1/advancedProductSearch\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async findItemsAllowedOnOrder(tenantId: Guid, orderId: Guid, stockLocationId: Guid, productBrandId: Guid | null, packageTypeId: Guid | null, supplierId: Guid | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new FindItemsAllowedOnOrderRequest();\n req.tenantId = tenantId;\n req.orderId = orderId;\n req.stockLocationId = stockLocationId;\n req.productBrandId = productBrandId;\n req.packageTypeId = packageTypeId;\n req.supplierId = supplierId;\n const extractor = (response:any) => new FindItemsAllowedOnOrderResponse(response).results;\n return this.makeJsonRequest(\"order/v1/findItemsAllowedOnOrder\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async cancelOrder(tenantId: Guid, orderId: Guid, cancellationReason: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CancelOrderRequest();\n req.tenantId = tenantId;\n req.orderId = orderId;\n req.cancellationReason = cancellationReason;\n const extractor = (response:any) => new CancelOrderResponse(response).order;\n return this.makeJsonRequest(\"order/v1/cancelOrder\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async completeOrder(tenantId: Guid, orderId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CompleteOrderRequest();\n req.tenantId = tenantId;\n req.orderId = orderId;\n const extractor = (response:any) => new CompleteOrderResponse(response).order;\n return this.makeJsonRequest(\"order/v1/completeOrder\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async completeOrders(tenantId: Guid, orderIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CompleteOrdersRequest();\n req.tenantId = tenantId;\n req.orderIds = orderIds;\n const extractor = null;\n return this.makeJsonRequest(\"order/v1/completeOrders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async uncompleteOrder(tenantId: Guid, orderId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UncompleteOrderRequest();\n req.tenantId = tenantId;\n req.orderId = orderId;\n const extractor = (response:any) => new UncompleteOrderResponse(response).order;\n return this.makeJsonRequest(\"order/v1/uncompleteOrder\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async uncompleteOrders(tenantId: Guid, orderIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UncompleteOrdersRequest();\n req.tenantId = tenantId;\n req.orderIds = orderIds;\n const extractor = null;\n return this.makeJsonRequest(\"order/v1/uncompleteOrders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async archiveOrders(tenantId: Guid, orderIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new ArchiveOrdersRequest();\n req.tenantId = tenantId;\n req.orderIds = orderIds;\n const extractor = null;\n return this.makeJsonRequest(\"order/v1/archiveOrders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getOrderExpectedStockLevelDeltas(tenantId: Guid, stockLocationId: Guid, stockItemIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetOrderExpectedStockLevelDeltasRequest();\n req.tenantId = tenantId;\n req.stockLocationId = stockLocationId;\n req.stockItemIds = stockItemIds;\n const extractor = (response:any) => new GetOrderExpectedStockLevelDeltasResponse(response).results;\n return this.makeJsonRequest(\"order/v1/getOrderExpectedStockLevelDeltas\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async evaluateDutySuspendedOrders(tenantId: Guid, fromDutyDateInclusive: LocalDate, toDutyDateInclusive: LocalDate, limitToGivenAlcoholTypes: boolean, limitedAlcoholTypes: readonly EnumAlcoholType[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new EvaluateDutySuspendedOrdersRequest();\n req.tenantId = tenantId;\n req.fromDutyDateInclusive = fromDutyDateInclusive;\n req.toDutyDateInclusive = toDutyDateInclusive;\n req.limitToGivenAlcoholTypes = limitToGivenAlcoholTypes;\n req.limitedAlcoholTypes = limitedAlcoholTypes;\n const extractor = (response:any) => new EvaluateDutySuspendedOrdersResponse(response).results;\n return this.makeJsonRequest(\"order/v1/evaluateDutySuspendedOrders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updateOrderLinesToMatchDelivered(tenantId: Guid, orderId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdateOrderLinesToMatchDeliveredRequest();\n req.tenantId = tenantId;\n req.orderId = orderId;\n const extractor = null;\n return this.makeJsonRequest(\"order/v1/updateOrderLinesToMatchDelivered\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getSuggestedInvoice(tenantId: Guid, orderId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetSuggestedInvoiceRequest();\n req.tenantId = tenantId;\n req.orderId = orderId;\n const extractor = (response:any) => new GetSuggestedInvoiceResponse(response).invoice;\n return this.makeJsonRequest(\"order/v1/getSuggestedInvoice\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async removeOrdersOnRetailSummary(tenantId: Guid, orderIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new RemoveOrdersOnRetailSummaryRequest();\n req.tenantId = tenantId;\n req.orderIds = orderIds;\n const extractor = null;\n return this.makeJsonRequest(\"order/v1/removeOrdersOnRetailSummary\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async markOrdersAsDraft(tenantId: Guid, orderIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new MarkOrdersAsDraftRequest();\n req.tenantId = tenantId;\n req.orderIds = orderIds;\n const extractor = null;\n return this.makeJsonRequest(\"order/v1/markOrdersAsDraft\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async confirmDraftOrder(tenantId: Guid, orderId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new ConfirmDraftOrderRequest();\n req.tenantId = tenantId;\n req.orderId = orderId;\n const extractor = null;\n return this.makeJsonRequest(\"order/v1/confirmDraftOrder\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async markOrdersForPosting(tenantId: Guid, orderIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new MarkOrdersForPostingRequest();\n req.tenantId = tenantId;\n req.orderIds = orderIds;\n const extractor = null;\n return this.makeJsonRequest(\"order/v1/markOrdersForPosting\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async unmarkOrdersForPosting(tenantId: Guid, creditIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UnmarkOrdersForPostingRequest();\n req.tenantId = tenantId;\n req.creditIds = creditIds;\n const extractor = null;\n return this.makeJsonRequest(\"order/v1/unmarkOrdersForPosting\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async recordOrderPostingResult(tenantId: Guid, orderId: Guid, postingError: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new RecordOrderPostingResultRequest();\n req.tenantId = tenantId;\n req.orderId = orderId;\n req.postingError = postingError;\n const extractor = null;\n return this.makeJsonRequest(\"order/v1/recordOrderPostingResult\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async recordRetailOrderSummaryPostingResult(tenantId: Guid, retailSummaryInvoiceNumber: string, postingError: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new RecordRetailOrderSummaryPostingResultRequest();\n req.tenantId = tenantId;\n req.retailSummaryInvoiceNumber = retailSummaryInvoiceNumber;\n req.postingError = postingError;\n const extractor = null;\n return this.makeJsonRequest(\"order/v1/recordRetailOrderSummaryPostingResult\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getDuplicateOrderSummary(tenantId: Guid, orderId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetDuplicateOrderSummaryRequest();\n req.tenantId = tenantId;\n req.orderId = orderId;\n const extractor = (response:any) => new GetDuplicateOrderSummaryResponse(response).duplicateOrderSummary;\n return this.makeJsonRequest(\"order/v1/getDuplicateOrderSummary\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async duplicateOrder(tenantId: Guid, orderId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new DuplicateOrderRequest();\n req.tenantId = tenantId;\n req.orderId = orderId;\n const extractor = (response:any) => new DuplicateOrderResponse(response).duplicateOrderSummary;\n return this.makeJsonRequest(\"order/v1/duplicateOrder\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updateOrderLineSequence(tenantId: Guid, orderId: Guid, orderLineIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdateOrderLineSequenceRequest();\n req.tenantId = tenantId;\n req.orderId = orderId;\n req.orderLineIds = orderLineIds;\n const extractor = null;\n return this.makeJsonRequest(\"order/v1/updateOrderLineSequence\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getLastOrderTimestamps(tenantId: Guid, outletIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetLastOrderTimestampsRequest();\n req.tenantId = tenantId;\n req.outletIds = outletIds;\n const extractor = (response:any) => new GetLastOrderTimestampsResponse(response).lastOrderTimestamps;\n return this.makeJsonRequest(\"order/v1/getLastOrderTimestamps\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveOrderHeader(tenantId: Guid, header: OrderHeader, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveOrderHeaderRequest();\n req.tenantId = tenantId;\n req.header = header;\n const extractor = null;\n return this.makeJsonRequest(\"order/v1/saveOrderHeader\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async buildOrderHeader(tenantId: Guid, outletId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new BuildOrderHeaderRequest();\n req.tenantId = tenantId;\n req.outletId = outletId;\n const extractor = (response:any) => new BuildOrderHeaderResponse(response).header;\n return this.makeJsonRequest(\"order/v1/buildOrderHeader\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveOrderLine(tenantId: Guid, orderId: Guid, line: OrderLine, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveOrderLineRequest();\n req.tenantId = tenantId;\n req.orderId = orderId;\n req.line = line;\n const extractor = null;\n return this.makeJsonRequest(\"order/v1/saveOrderLine\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async buildOrderLine(tenantId: Guid, orderId: Guid, itemId: Guid, quantity: number, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new BuildOrderLineRequest();\n req.tenantId = tenantId;\n req.orderId = orderId;\n req.itemId = itemId;\n req.quantity = quantity;\n const extractor = (response:any) => new BuildOrderLineResponse(response).line;\n return this.makeJsonRequest(\"order/v1/buildOrderLine\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async findTopSellingProducts(tenantId: Guid, maxResults: number, fromDate: LocalDate, toDate: LocalDate, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new FindTopSellingProductsRequest();\n req.tenantId = tenantId;\n req.maxResults = maxResults;\n req.fromDate = fromDate;\n req.toDate = toDate;\n const extractor = (response:any) => new FindTopSellingProductsResponse(response).results;\n return this.makeJsonRequest(\"order/v1/findTopSellingProducts\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updateTradePortalTransactionFee(tenantId: Guid, orderId: Guid, transactionFee: number, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdateTradePortalTransactionFeeRequest();\n req.tenantId = tenantId;\n req.orderId = orderId;\n req.transactionFee = transactionFee;\n const extractor = null;\n return this.makeJsonRequest(\"order/v1/updateTradePortalTransactionFee\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updateOrderDetailsToCurrent(tenantId: Guid, orderId: Guid, applyListPrices: boolean, applyGlCodes: boolean, applyVatCodes: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdateOrderDetailsToCurrentRequest();\n req.tenantId = tenantId;\n req.orderId = orderId;\n req.applyListPrices = applyListPrices;\n req.applyGlCodes = applyGlCodes;\n req.applyVatCodes = applyVatCodes;\n const extractor = null;\n return this.makeJsonRequest(\"order/v1/updateOrderDetailsToCurrent\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const orderService = new OrderService();","import { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport EnumUserPermissionAccess from \"@/components/pages/administration/user_roles/EnumUserPermissionAccess\";\nimport userStore from \"@/store/modules/userStore\";\nimport type Key from \"@/app/types/common/key\";\nimport { keys } from \"@/plugins/i18n\";\n\ntype UserPermissionsViewEditOrFullAccess = {\n view: EnumUserPermission;\n edit: EnumUserPermission;\n};\n\ntype ViewEditUserPermissionGroupsOptions = {\n groupName: Key;\n groupDescription: Key;\n permissions: UserPermissionsViewEditOrFullAccess;\n};\n\ntype UserPermissionGroupsOptions = {\n groupName: Key;\n groupDescription: Key;\n permissions: EnumUserPermission[];\n};\n\ninterface IUserPermissionGroup {\n // TODO - this should probably just be string\n groupName: Key;\n // TODO - this should probably just be string\n groupDescription: Key;\n allPermissions: EnumUserPermission[];\n}\n\nexport class ViewEditUserPermissionGroup implements IUserPermissionGroup {\n private _viewPermission: EnumUserPermission;\n private _editPermission: EnumUserPermission;\n private _groupName: Key;\n private _groupDescription: Key;\n\n constructor(options: ViewEditUserPermissionGroupsOptions) {\n this._groupName = options.groupName;\n this._groupDescription = options.groupDescription;\n this._viewPermission = options.permissions.view;\n this._editPermission = options.permissions.edit;\n }\n\n get groupName() {\n return this._groupName;\n }\n\n get groupDescription() {\n return this._groupDescription;\n }\n\n get viewPermission() {\n return this._viewPermission;\n }\n\n get editPermission() {\n return this._editPermission;\n }\n\n get allPermissions() {\n return [this._viewPermission, this._editPermission];\n }\n\n evaluateAccess(permissions: EnumUserPermission[]): EnumUserPermissionAccess {\n const permissionsSet = new Set(\n permissions.map((permission) => permission.key)\n );\n\n if (permissionsSet.has(this._editPermission.key)) {\n return EnumUserPermissionAccess.fullAccess;\n }\n\n if (permissionsSet.has(this._viewPermission.key)) {\n return EnumUserPermissionAccess.readOnly;\n }\n\n return EnumUserPermissionAccess.noAccess;\n }\n}\n\nexport class UserPermissionGroup implements IUserPermissionGroup {\n private _groupName: Key;\n private _groupDescription: Key;\n private _allPermissions: EnumUserPermission[];\n\n constructor(options: UserPermissionGroupsOptions) {\n this._groupName = options.groupName;\n this._groupDescription = options.groupDescription;\n this._allPermissions = options.permissions;\n }\n\n get groupName() {\n return this._groupName;\n }\n\n get groupDescription() {\n return this._groupDescription;\n }\n\n get allPermissions() {\n return this._allPermissions;\n }\n}\n\nexport const groupIsViewEditUserPermissionGroup = (\n group: ViewEditUserPermissionGroup | UserPermissionGroup\n): group is ViewEditUserPermissionGroup =>\n (group as any).viewPermission !== undefined;\n\nexport const allMenuSecurityEnums = [\n EnumUserPermission.menuCalendarView,\n EnumUserPermission.menuTasksView,\n EnumUserPermission.menuSalesView,\n EnumUserPermission.menuContactsView,\n EnumUserPermission.menuStockView,\n EnumUserPermission.menuDistributionView,\n EnumUserPermission.menuProductionView,\n EnumUserPermission.menuUllagesView,\n EnumUserPermission.menuPricingView,\n EnumUserPermission.menuContainerTrackingView,\n EnumUserPermission.menuDutyView,\n EnumUserPermission.menuReportingView,\n EnumUserPermission.menuIntegrationsView,\n EnumUserPermission.menuAdministrationView,\n EnumUserPermission.menuDistributionAppView,\n EnumUserPermission.menuMultiTenantView,\n];\n\nconst orders = new ViewEditUserPermissionGroup({\n groupName: keys.user_roles_orders,\n groupDescription: keys.user_roles_orders_description,\n permissions: {\n view: EnumUserPermission.ordersView,\n edit: EnumUserPermission.ordersEdit,\n },\n});\nconst creditNotes = new ViewEditUserPermissionGroup({\n groupName: keys.user_roles_credit_notes,\n groupDescription: keys.user_roles_credit_notes_description,\n permissions: {\n view: EnumUserPermission.creditNotesView,\n edit: EnumUserPermission.creditNotesEdit,\n },\n});\nconst outletsAndGroups = new ViewEditUserPermissionGroup({\n groupName: keys.user_roles_outlets_and_groups,\n groupDescription: keys.user_roles_outlets_and_groups_description,\n permissions: {\n view: EnumUserPermission.outletsAndGroupsView,\n edit: EnumUserPermission.outletsAndGroupsEdit,\n },\n});\nconst distributionManagement = new ViewEditUserPermissionGroup({\n groupName: keys.user_roles_distribution_management,\n groupDescription: keys.user_roles_distribution_management_description,\n permissions: {\n view: EnumUserPermission.distributionManagementView,\n edit: EnumUserPermission.distributionManagementView, // @TODO: Update when edit permissions are set\n },\n});\nconst distributionProcessing = new ViewEditUserPermissionGroup({\n groupName: keys.user_roles_distribution_processing,\n groupDescription: keys.user_roles_distribution_processing_description,\n permissions: {\n view: EnumUserPermission.distributionProcessingView,\n edit: EnumUserPermission.distributionProcessingView, // @TODO: Update when edit permissions are set\n },\n});\nconst distributionApp = new ViewEditUserPermissionGroup({\n groupName: keys.user_roles_distribution_app,\n groupDescription: keys.user_roles_distribution_app_description,\n permissions: {\n view: EnumUserPermission.distributionApp,\n edit: EnumUserPermission.distributionApp,\n },\n});\nconst priceLists = new ViewEditUserPermissionGroup({\n groupName: keys.user_roles_price_lists,\n groupDescription: keys.user_roles_price_lists_description,\n permissions: {\n view: EnumUserPermission.priceListsView,\n edit: EnumUserPermission.priceListsEdit,\n },\n});\nconst reporting = new ViewEditUserPermissionGroup({\n groupName: keys.user_roles_reporting,\n groupDescription: keys.user_roles_reporting_description,\n permissions: {\n view: EnumUserPermission.reporting,\n edit: EnumUserPermission.reporting,\n },\n});\nconst administration = new ViewEditUserPermissionGroup({\n groupName: keys.user_roles_administration,\n groupDescription: keys.user_roles_administration_description,\n permissions: {\n view: EnumUserPermission.administration,\n edit: EnumUserPermission.administration,\n },\n});\nconst assemblies = new ViewEditUserPermissionGroup({\n groupName: keys.user_roles_assemblies,\n groupDescription: keys.user_roles_assemblies_description,\n permissions: {\n view: EnumUserPermission.batchesView,\n edit: EnumUserPermission.batchesEdit,\n },\n});\nconst recipes = new ViewEditUserPermissionGroup({\n groupName: keys.user_roles_recipes,\n groupDescription: keys.user_roles_recipes_description,\n permissions: {\n view: EnumUserPermission.recipesView,\n edit: EnumUserPermission.recipesEdit,\n },\n});\nconst vessels = new ViewEditUserPermissionGroup({\n groupName: keys.user_roles_vessels,\n groupDescription: keys.user_roles_vessels_description,\n permissions: {\n view: EnumUserPermission.vesselsView,\n edit: EnumUserPermission.vesselsEdit,\n },\n});\nconst menuSecurity = new UserPermissionGroup({\n groupName: keys.user_roles_menu_security,\n groupDescription: keys.user_roles_menu_security_description,\n permissions: allMenuSecurityEnums,\n});\nconst multiTenant = new ViewEditUserPermissionGroup({\n groupName: keys.user_roles_multi_tenant,\n groupDescription: keys.user_roles_multi_tenant_description,\n permissions: {\n view: EnumUserPermission.multiTenant,\n edit: EnumUserPermission.multiTenant,\n },\n});\n\nexport const allPermissionGroups: (\n | ViewEditUserPermissionGroup\n | UserPermissionGroup\n)[] = [\n orders,\n creditNotes,\n outletsAndGroups,\n distributionManagement,\n distributionProcessing,\n distributionApp,\n vessels,\n assemblies,\n recipes,\n priceLists,\n reporting,\n administration,\n menuSecurity,\n multiTenant,\n];\n\nexport function checkUserPermissions(\n existingPermissions: Readonly,\n requiredPermissions: Readonly\n): boolean {\n if (\n userStore.state.user?.readOnly.isSupportUser ||\n userStore.state.user?.readOnly.isSystemUser\n ) {\n return true;\n }\n\n // True admins are immune to checks\n if (\n userStore.hasAdministrativePrivileges.value &&\n !requiredPermissions.includes(EnumUserPermission.multiTenant) &&\n !requiredPermissions.includes(EnumUserPermission.menuMultiTenantView)\n ) {\n return true;\n }\n\n // Compare against key values, as object instances will likely not be the same\n return requiredPermissions.every((requiredPermission) =>\n existingPermissions.find(\n (existingPermission) => existingPermission.key === requiredPermission.key\n )\n );\n}\n\nexport function hasPermissionsUsingUserStore(\n requiredPermissions: EnumUserPermission[]\n): boolean {\n return checkUserPermissions(\n userStore.state.userPermissions,\n requiredPermissions\n );\n}\n","import { MenuItem } from \"@/app/ui/navigation/types\";\nimport type Guid from \"@/app/types/common/guid\";\nimport type { Location } from \"vue-router\";\nimport { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\n\nexport const contactsMenu = {\n root: \"navigation_contacts_group\",\n // Specify correct value for isRetail if known. However it will redirect as appropriate.\n viewOutlet: (\n outletId: Guid,\n isRetail: boolean = false,\n taskId: Guid | null = null\n ): Location => {\n if (taskId) {\n return {\n name: isRetail\n ? contactsMenu.retailOutlets.crm_task\n : contactsMenu.outlets.crm_task,\n params: { id: outletId.toString(), taskId: taskId.toString() },\n };\n }\n return {\n name: isRetail\n ? contactsMenu.retailOutlets.crm\n : contactsMenu.outlets.crm,\n params: { id: outletId.toString() },\n };\n },\n duplicateOutlet: (outletId: Guid): Location => ({\n name: contactsMenu.outlets.create,\n query: { duplicate_from_outlet_id: outletId.toString() },\n }),\n outlets: {\n create: \"create_outlet\",\n createLocation: (opts?: {\n leadId?: Guid;\n sellarCustomerId?: number;\n sellarSettingsId?: Guid;\n }): Location => ({\n name: contactsMenu.outlets.create,\n query: {\n create_from_lead: opts?.leadId?.toString(),\n create_from_sellar_customer: opts?.sellarCustomerId?.toString(),\n create_from_sellar_settings: opts?.sellarSettingsId?.toString(),\n },\n }),\n createOutletFromLeadsMap: (opts: {\n businessName: string;\n telephoneNumber: string;\n addressLine1: string;\n addressLine2: string;\n addressLine3: string;\n addressLine4: string;\n addressLine5: string;\n addressLine6: string;\n addressPostcode: string;\n webAddress: string;\n }): Location => ({\n name: contactsMenu.outlets.create,\n query: opts,\n }),\n\n list: \"outlet_list\",\n view: \"outlet\",\n salesHistory: \"outlet_sales_history\",\n crm_task: \"outlet_crm_task\",\n crm: \"outlet_crm\",\n contacts: \"outlet_contacts\",\n containerHistory: \"outlet_containerHistory\",\n documents: \"outlet_documents\",\n deposits: \"outlet_deposits\",\n pricelists: {\n root: \"outlet_price_lists\",\n pricingCategories: \"outlet_pricing_categories\",\n products: \"outlet_pricing_products\",\n oneForFree: \"outlet_pricing_one_for_free\",\n },\n finance: \"outlet_finance\",\n settings: \"outlet_settings\",\n containerHistoryLocation: (id: Guid): Location => ({\n name: contactsMenu.outlets.containerHistory,\n params: { id: id.toString() },\n }),\n },\n retailOutlets: {\n view: \"retail_outlet\",\n salesHistory: \"retail_outlet_sales_history\",\n crm: \"retail_outlet_crm\",\n crm_task: \"retail_outlet_crm_task\",\n documents: \"retail_outlet_documents\",\n deposits: \"retail_outlet_deposits\",\n settings: \"retail_outlet_settings\",\n },\n outletGroups: {\n list: \"group_list\",\n create: \"create_outlet_group\",\n view: \"group_settings\",\n contacts: \"group_contacts\",\n documents: \"group_documents\",\n outlets: \"group_outlets\",\n pricing: \"group_pricing\",\n finance: \"group_finance\",\n settings: \"group_settings\",\n },\n viewOutletGroup: (id: Guid): Location => ({\n name: contactsMenu.outletGroups.view,\n params: { id: id.toString() },\n }),\n suppliers: {\n list: \"supplier_list\",\n view: \"supplier_view\",\n edit: \"supplier_edit\",\n create: \"supplier_create\",\n documents: \"supplier_documents\",\n },\n viewSupplier: (id: Guid): Location => ({\n name: contactsMenu.suppliers.edit,\n params: { id: id.toString() },\n }),\n communications: {\n list: \"communications_list\",\n listLocation: (): Location => ({\n name: contactsMenu.communications.list,\n }),\n },\n};\n\nexport const buildContactsMenuItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n name: contactsMenu.root,\n icon: \"contacts\",\n visible: () =>\n hasPermissionsUsingUserStore([EnumUserPermission.menuContactsView]),\n subMenus: [\n MenuItem.fromOpts({\n name: contactsMenu.outlets.list,\n icon: \"list\",\n url: \"/outlets/list\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/ListOutlets.vue\"\n ),\n requiredUserPermissions: [EnumUserPermission.outletsAndGroupsView],\n }),\n MenuItem.fromOpts({\n name: contactsMenu.outlets.create,\n icon: \"create\",\n url: \"/outlets/create\",\n breadcrumbParentName: contactsMenu.outlets.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/CreateOutletWizard.vue\"\n ),\n visible: false,\n requiredUserPermissions: [EnumUserPermission.outletsAndGroupsView],\n }),\n MenuItem.fromOpts({\n name: contactsMenu.retailOutlets.view,\n icon: \"edit\",\n url: \"/retailoutlet/:id/\",\n breadcrumbParentName: contactsMenu.outlets.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/ViewRetailOutlet.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n id: route.params.id,\n }),\n childRoutes: [\n {\n name: contactsMenu.retailOutlets.salesHistory,\n path: \"saleshistory\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/OutletSalesHistoryTab.vue\"\n ),\n meta: {\n requiredUserPermissions: [EnumUserPermission.ordersView],\n },\n },\n {\n name: contactsMenu.retailOutlets.crm_task,\n path: \"crm/task/:taskId\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/crm/CrmTab.vue\"\n ),\n props: (route) => ({\n taskId: route.params.taskId,\n }),\n },\n {\n name: contactsMenu.retailOutlets.crm,\n path: \"crm\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/crm/CrmTab.vue\"\n ),\n },\n {\n name: contactsMenu.retailOutlets.documents,\n path: \"documents\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/DocumentStoreTab.vue\"\n ),\n },\n {\n name: contactsMenu.retailOutlets.deposits,\n path: \"deposits\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/OutletDepositsTab.vue\"\n ),\n },\n {\n name: contactsMenu.retailOutlets.settings,\n path: \"settings\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/viewretailoutlet/RetailOutletSettingsTab.vue\"\n ),\n },\n ],\n requiredUserPermissions: [EnumUserPermission.outletsAndGroupsView],\n }),\n MenuItem.fromOpts({\n name: contactsMenu.outlets.view,\n icon: \"edit\",\n url: \"/outlet/:id/\",\n breadcrumbParentName: contactsMenu.outlets.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/ViewOutlet.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n id: route.params.id,\n }),\n childRoutes: [\n {\n name: contactsMenu.outlets.salesHistory,\n path: \"saleshistory\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/OutletSalesHistoryTab.vue\"\n ),\n meta: {\n requiredUserPermissions: [EnumUserPermission.ordersView],\n },\n },\n {\n name: contactsMenu.outlets.crm_task,\n path: \"crm/task/:taskId\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/crm/CrmTab.vue\"\n ),\n props: (route) => ({\n taskId: route.params.taskId,\n }),\n },\n {\n name: contactsMenu.outlets.crm,\n path: \"crm\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/crm/CrmTab.vue\"\n ),\n },\n {\n name: contactsMenu.outlets.contacts,\n path: \"contacts\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/contacts/ContactsTab.vue\"\n ),\n },\n {\n name: contactsMenu.outlets.containerHistory,\n path: \"container-history\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/OutletContainerHistoryTab.vue\"\n ),\n },\n {\n name: contactsMenu.outlets.documents,\n path: \"documents\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/DocumentStoreTab.vue\"\n ),\n },\n {\n name: contactsMenu.outlets.deposits,\n path: \"deposits\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/OutletDepositsTab.vue\"\n ),\n },\n {\n name: contactsMenu.outlets.pricelists.root,\n path: \"pricelists\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/viewoutlet/pricing/PriceListTab.vue\"\n ),\n children: [\n {\n alias: \"\",\n name: contactsMenu.outlets.pricelists.pricingCategories,\n path: \"pricingcategories\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/viewoutlet/PriceListTabPriceCategory.vue\"\n ),\n },\n {\n name: contactsMenu.outlets.pricelists.products,\n path: \"products\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/viewoutlet/PriceListTabProduct.vue\"\n ),\n },\n {\n name: contactsMenu.outlets.pricelists.oneForFree,\n path: \"oneforfree\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/viewoutlet/PriceListTabOneForFree.vue\"\n ),\n },\n ],\n },\n {\n name: contactsMenu.outlets.finance,\n path: \"finances\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/viewoutlet/finance/FinanceTab.vue\"\n ),\n },\n {\n name: contactsMenu.outlets.settings,\n path: \"settings\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/viewoutlet/settings/SettingsTab.vue\"\n ),\n },\n ],\n requiredUserPermissions: [EnumUserPermission.outletsAndGroupsView],\n }),\n MenuItem.fromOpts({\n name: contactsMenu.outletGroups.list,\n icon: \"list\",\n url: \"/groups/list\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/ListGroups.vue\"\n ),\n requiredUserPermissions: [EnumUserPermission.outletsAndGroupsView],\n }),\n MenuItem.fromOpts({\n name: contactsMenu.outletGroups.create,\n icon: \"create\",\n url: \"/groups/create\",\n breadcrumbParentName: contactsMenu.outletGroups.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/CreateOutletGroupWizard.vue\"\n ),\n visible: false,\n requiredUserPermissions: [EnumUserPermission.outletsAndGroupsView],\n }),\n MenuItem.fromOpts({\n name: \"\",\n icon: \"edit\",\n url: \"/groups/:id\",\n componentProps: (route) => ({\n idString: route.params.id,\n }),\n breadcrumbParentName: contactsMenu.outletGroups.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/ViewGroup.vue\"\n ),\n visible: false,\n childRoutes: [\n {\n name: contactsMenu.outletGroups.contacts,\n path: \"contacts\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/contacts/ContactsTab.vue\"\n ),\n },\n {\n name: contactsMenu.outletGroups.documents,\n path: \"documents\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/DocumentStoreTab.vue\"\n ),\n },\n {\n name: contactsMenu.outletGroups.outlets,\n path: \"outlets\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/viewgroup/GroupOutletsTab.vue\"\n ),\n },\n {\n name: contactsMenu.outletGroups.pricing,\n path: \"/groups/:id/pricing\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/viewgroup/GroupPricingTab.vue\"\n ),\n },\n {\n name: contactsMenu.outletGroups.finance,\n path: \"/groups/:id/finance\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/viewgroup/GroupFinanceTab.vue\"\n ),\n },\n {\n name: contactsMenu.outletGroups.settings,\n path: \"/groups/:id/settings\",\n component: () =>\n import(\n /* webpackChunkName: \"outlet\" */ \"@/components/pages/outlet/viewgroup/GroupSettingsTab.vue\"\n ),\n },\n ],\n requiredUserPermissions: [EnumUserPermission.outletsAndGroupsView],\n }),\n MenuItem.fromOpts({\n name: contactsMenu.suppliers.list,\n url: \"/stock/suppliers/list\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/suppliers/ListSuppliers.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: contactsMenu.suppliers.view,\n url: \"/stock/suppliers/:id\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/suppliers/ViewSupplier.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n id: route.params.id,\n editing: false,\n }),\n childRoutes: [\n {\n name: contactsMenu.suppliers.edit,\n path: \"edit\",\n component: () =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/suppliers/EditSupplier.vue\"\n ),\n },\n {\n name: contactsMenu.suppliers.documents,\n path: \"documents\",\n component: () =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/suppliers/SupplierDocumentStoreTab.vue\"\n ),\n },\n ],\n }),\n MenuItem.fromOpts({\n name: contactsMenu.suppliers.create,\n url: \"/stock/suppliers/create\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/suppliers/CreateSupplier.vue\"\n ),\n visible: false,\n }),\n\n MenuItem.fromOpts({\n name: contactsMenu.communications.list,\n url: \"/communications/list\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"orders\" */ \"@/components/pages/outlet/communications/ListCommunications\"\n ),\n }),\n ],\n }),\n];\n","/**\n * Configures the menu layout.\n */\nimport type { RouteConfig } from \"vue-router\";\nimport type {\n Location,\n Route,\n RoutePropsFunction,\n} from \"vue-router/types/router\";\nimport type { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport Guid from \"@/app/types/common/guid\";\nimport type {\n IRouteItem,\n IRouteWithLocation,\n RouteMetadata,\n} from \"@/app/ui/navigation/types\";\n\nexport type BuildRouteOpts = {\n url: string;\n view: () => Promise;\n componentProps?: boolean | Record | RoutePropsFunction;\n preSession?: boolean;\n requiredUserPermissions?: EnumUserPermission[];\n childRoutes?: RouteConfig[];\n};\n\nexport type SubRouteOpts = {\n path: string;\n component: () => Promise;\n};\n\nexport type ISubRouteWithLocation = RouteConfig & {\n location: (...params: TParams) => Location;\n};\n\nexport class RouteBuilder {\n private _nameBase: string;\n private _routes: IRouteItem[] = [];\n private _nextId = 1;\n\n constructor(nameBase: string) {\n this._nameBase = nameBase;\n }\n\n public getRoutes(): readonly IRouteItem[] {\n return this._routes.slice();\n }\n\n private buildAndAddRoute any>(\n opts: BuildRouteOpts,\n makeLocationParams: (...p: Parameters) => any\n ) {\n const meta: RouteMetadata = {};\n if (opts.preSession !== undefined) {\n meta.preSession = opts.preSession;\n }\n\n const route = {\n name: this._nameBase + \"_\" + this._nextId++,\n url: opts.url,\n view: opts.view,\n componentProps: opts.componentProps,\n routeMetadata: meta,\n requiredUserPermissions: opts.requiredUserPermissions,\n childRoutes: opts.childRoutes ?? [],\n location: (...ps: Parameters): Location => ({\n name: route.name,\n params: makeLocationParams(...ps),\n }),\n };\n\n this._routes.push(route);\n return route;\n }\n\n route(opts: BuildRouteOpts): IRouteWithLocation<[]> {\n return this.buildAndAddRoute(opts, () => ({}));\n }\n\n routeWithParams any>(\n opts: BuildRouteOpts,\n locationParams: TParamsFunc\n ): IRouteWithLocation> {\n return this.buildAndAddRoute(opts, locationParams);\n }\n\n routeWithSingleIdParam(opts: BuildRouteOpts): IRouteWithLocation<[id: Guid]> {\n return this.routeWithParams(\n Object.assign(\n {\n componentProps: (route: Route) => ({\n id: Guid.parseOrThrow(route.params.id),\n }),\n },\n opts\n ),\n (id: Guid) => ({\n id: id.toString(),\n })\n );\n }\n\n routeToHoldSubRoutes(opts: BuildRouteOpts): IRouteItem {\n return this.route(opts);\n }\n\n subRoute any>(\n opts: SubRouteOpts,\n locationParams: TParamsFunc\n ): ISubRouteWithLocation> {\n const route = {\n name: this._nameBase + \"_sub_\" + this._nextId++,\n path: opts.path,\n component: opts.component,\n location: (...ps: Parameters): Location => ({\n name: route.name,\n params: locationParams(ps),\n }),\n };\n\n return route;\n }\n\n subRouteWithSingleIdParam(\n opts: SubRouteOpts\n ): ISubRouteWithLocation<[id: Guid]> {\n return this.subRoute(\n Object.assign(\n {\n componentProps: (route: Route) => ({\n id: Guid.parseOrThrow(route.params.id),\n }),\n },\n opts\n ),\n (id: Guid) => ({\n id: id.toString(),\n })\n );\n }\n}\n","import { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport Guid from \"@/app/types/common/guid\";\nimport { RouteBuilder } from \"@/app/ui/navigation/routeBuilder\";\nimport { MenuItem } from \"@/app/ui/navigation/types\";\nimport { keys } from \"@/plugins/i18n\";\n\nconst builder = new RouteBuilder(\"Pricing_\");\n\nexport const priceListSubRoutes = {\n pricesTab: builder.subRouteWithSingleIdParam({\n path: \"/pricing/view-price-list/:id/prices\",\n component: () =>\n import(\n /* webpackChunkName: \"pricing\" */ \"@/components/pages/prices/viewpricelist/PriceListPricesTab.vue\"\n ),\n }),\n discountsTab: builder.subRouteWithSingleIdParam({\n path: \"/pricing/view-price-list/:id/discounts\",\n component: () =>\n import(\n /* webpackChunkName: \"pricing\" */ \"@/components/pages/prices/viewpricelist/PriceListDiscountsTab.vue\"\n ),\n }),\n settingsTab: builder.subRouteWithSingleIdParam({\n path: \"/pricing/view-price-list/:id/settings\",\n component: () =>\n import(\n /* webpackChunkName: \"pricing\" */ \"@/components/pages/prices/viewpricelist/PriceListSettingsTab.vue\"\n ),\n }),\n};\n\nexport const pricingRoutes = {\n listPriceLists: builder.route({\n url: \"/pricing/list-price-lists\",\n view: () =>\n import(\n /* webpackChunkName: \"pricing\" */ \"@/components/pages/prices/ListPriceLists.vue\"\n ),\n requiredUserPermissions: [EnumUserPermission.priceListsView],\n }),\n viewPriceList: builder.routeToHoldSubRoutes({\n url: \"/pricing/view-price-list/:id\",\n view: () =>\n import(\n /* webpackChunkName: \"pricing\" */ \"@/components/pages/prices/ViewPriceList.vue\"\n ),\n childRoutes: [\n priceListSubRoutes.pricesTab,\n priceListSubRoutes.discountsTab,\n priceListSubRoutes.settingsTab,\n ],\n requiredUserPermissions: [EnumUserPermission.priceListsView],\n }),\n priceFinder: builder.routeWithParams(\n {\n url: \"/pricing/price-finder\",\n componentProps: (route) => ({\n initialOutletId:\n Guid.tryParse(route.params.initialOutletId?.toString()) ?? undefined,\n }),\n view: () =>\n import(\n /* webpackChunkName: \"pricing\" */ \"@/components/pages/prices/PriceFinder.vue\"\n ),\n },\n (initialOutletId?: Guid) => ({ initialOutletId })\n ),\n outletsWithOneFree: builder.route({\n url: \"/pricing/outlets-with-one-for-free\",\n view: () =>\n import(\n /* webpackChunkName: \"pricing\" */ \"@/components/pages/prices/OutletsWithOneForFree.vue\"\n ),\n }),\n outletsWithSpecialPricing: builder.route({\n url: \"/pricing/outletswithspecialpricing\",\n view: () =>\n import(\n /* webpackChunkName: \"pricing\" */ \"@/components/pages/prices/OutletsWithSpecialPricing.vue\"\n ),\n }),\n};\n\nexport const buildPricingMenuItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n translationKey: keys.navigation_pricing_group.value,\n icon: \"monetization_on\",\n requiredUserPermissions: [EnumUserPermission.menuPricingView],\n subMenus: [\n MenuItem.forRoute(keys.price_lists_list, pricingRoutes.listPriceLists, {\n requiredUserPermissions: [EnumUserPermission.priceListsView],\n }),\n MenuItem.forRoute(keys.price_price_finder, pricingRoutes.priceFinder),\n MenuItem.forRoute(\n keys.bogof_outlets_with_one_for_free,\n pricingRoutes.outletsWithOneFree\n ),\n MenuItem.forRoute(\n keys.bogof_outlets_with_special_pricing,\n pricingRoutes.outletsWithSpecialPricing\n ),\n ],\n }),\n];\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumAccountsPackageType } from \"./enums/enumAccountsPackageType.generated\";\n\n// Model Objects\n\nexport class AccountLinkSettings extends BaseModelObject {\n\n /**\n * Determines whether purchase orders should be posted on connected accounts links.\n */\n public postPurchaseOrders: boolean = false;\n /**\n * If true, orders and credits are posted to the accounts package in an approved state. Applicable only to some directly-linked packages (eg Xero).\n */\n public postInvoicesAsApproved: boolean = false;\n /**\n * If true, when an order is completed it will automatically be set to posting.\n */\n public postOrdersOnCompletion: boolean = false;\n private _defaultPurchaseGlCodeId: Guid | null = null;\n /**\n * Default purchase gl code id. If provided then products with no purchase gl code will be posted with the provided gl code id.On Sage Online, the priority for purchase gl code is 1. BM item 2. Sage Online item (if exist) 3. DefaultPurchaseGlCodeId (this field) 4. 1000 (hard-coded gl code)\n */\n public get defaultPurchaseGlCodeId(): Guid | null { return this._defaultPurchaseGlCodeId }\n public set defaultPurchaseGlCodeId(value: Guid | null) {\n this._defaultPurchaseGlCodeId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.postPurchaseOrders = jsonSerializedObject.postPurchaseOrders;\n this.postInvoicesAsApproved = jsonSerializedObject.postInvoicesAsApproved;\n this.postOrdersOnCompletion = jsonSerializedObject.postOrdersOnCompletion;\n this.defaultPurchaseGlCodeId = jsonSerializedObject.defaultPurchaseGlCodeId == null ? null : Guid.fromString(jsonSerializedObject.defaultPurchaseGlCodeId);\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.postPurchaseOrders = this.postPurchaseOrders;\n toRet.postInvoicesAsApproved = this.postInvoicesAsApproved;\n toRet.postOrdersOnCompletion = this.postOrdersOnCompletion;\n toRet.defaultPurchaseGlCodeId = this.defaultPurchaseGlCodeId == null ? null : this.defaultPurchaseGlCodeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"defaultPurchaseGlCodeId\", rule: (v: any) => v == null || !v.isEmpty() || \"AccountLinkSettings.DefaultPurchaseGlCodeId cannot be empty\"},\n ];\n}\n\n\nexport class AccountsLinkDetails extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n /**\n * The type of the current accounts provider : 0 = None, 1 = Xero, 2 = QuickBooksLive, 3 = QuickBooksSandbox, 4 = SageOne, 5 = Sage50, 6 = Sage200, 7 = BrewmanApi, 8 = CustomCsv, 9 = GreenTree, 10 = Sage200Web, 11 = Lexoffice, 12 = Fortnox, 13 = SageOneZa\n */\n public accountsPackageType: EnumAccountsPackageType = EnumAccountsPackageType.none;\n /**\n * Identifies if the link is ready for communicating. (Ie established and thought still connected.\n */\n public ready: boolean = false;\n public settings: AccountLinkSettings = new AccountLinkSettings();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.accountsPackageType = EnumAccountsPackageType.getByValue(jsonSerializedObject.accountsPackageType, this.accountsPackageType);\n this.ready = jsonSerializedObject.ready;\n this.settings = new AccountLinkSettings(jsonSerializedObject.settings);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.accountsPackageType = this.accountsPackageType.value;\n toRet.ready = this.ready;\n toRet.settings = this.settings.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \"AccountsLinkDetails.TenantId cannot be empty\"},\n {field: \"settings\", rule: (v: any) => !!v || \"settings is required\"},\n {field: \"settings\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class CompleteSignUpWithXeroResult extends ModelObject {\n\n public firstName: string = \"\";\n public lastName: string = \"\";\n public fullName: string = \"\";\n public emailAddress: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.firstName = jsonSerializedObject.firstName;\n this.lastName = jsonSerializedObject.lastName;\n this.fullName = jsonSerializedObject.fullName;\n this.emailAddress = jsonSerializedObject.emailAddress;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.firstName = this.firstName;\n toRet.lastName = this.lastName;\n toRet.fullName = this.fullName;\n toRet.emailAddress = this.emailAddress;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class SageOneZaCompany extends ModelObject {\n\n public id: string = \"\";\n public name: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = jsonSerializedObject.id;\n this.name = jsonSerializedObject.name;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id;\n toRet.name = this.name;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class AccountsGlCode extends ModelObject {\n\n public code: string = \"\";\n public name: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.code = jsonSerializedObject.code;\n this.name = jsonSerializedObject.name;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.code = this.code;\n toRet.name = this.name;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class AccountsTaxCode extends ModelObject {\n\n public code: string = \"\";\n public name: string = \"\";\n public percentage: number = 0;\n public appliesToSales: boolean = false;\n public appliesToPurchases: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.code = jsonSerializedObject.code;\n this.name = jsonSerializedObject.name;\n this.percentage = jsonSerializedObject.percentage;\n this.appliesToSales = jsonSerializedObject.appliesToSales;\n this.appliesToPurchases = jsonSerializedObject.appliesToPurchases;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.code = this.code;\n toRet.name = this.name;\n toRet.percentage = this.percentage;\n toRet.appliesToSales = this.appliesToSales;\n toRet.appliesToPurchases = this.appliesToPurchases;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GetAccountsLinkDetailsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAccountsLinkDetailsResponse extends ModelObject {\n\n public accountsLinkDetails: AccountsLinkDetails = new AccountsLinkDetails();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.accountsLinkDetails = new AccountsLinkDetails(jsonSerializedObject.accountsLinkDetails);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.accountsLinkDetails = this.accountsLinkDetails.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"accountsLinkDetails\", rule: (v: any) => !!v || \"accountsLinkDetails is required\"},\n {field: \"accountsLinkDetails\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetAccountsLinkLogonUrlRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public accountsPackageType: EnumAccountsPackageType = EnumAccountsPackageType.none;\n public callbackUri: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.accountsPackageType = EnumAccountsPackageType.getByValue(jsonSerializedObject.accountsPackageType, this.accountsPackageType);\n this.callbackUri = jsonSerializedObject.callbackUri;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.accountsPackageType = this.accountsPackageType.value;\n toRet.callbackUri = this.callbackUri;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"callbackUri\", rule: (v: any) => v == null || v.length !== 0 || \"CallbackUri cannot be empty\"},\n ];\n}\n\n\nexport class GetAccountsLinkLogonUrlResponse extends ModelObject {\n\n public accountsLinkLogonUrl: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.accountsLinkLogonUrl = jsonSerializedObject.accountsLinkLogonUrl;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.accountsLinkLogonUrl = this.accountsLinkLogonUrl;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class DisconnectAccountsLinkRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class SetExternalAccountsLinkRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public accountsPackageType: EnumAccountsPackageType = EnumAccountsPackageType.none;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.accountsPackageType = EnumAccountsPackageType.getByValue(jsonSerializedObject.accountsPackageType, this.accountsPackageType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.accountsPackageType = this.accountsPackageType.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class PerformXeroAccountsLinkRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public temporaryCode: string = \"\";\n public state: string = \"\";\n public callbackUri: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.temporaryCode = jsonSerializedObject.temporaryCode;\n this.state = jsonSerializedObject.state;\n this.callbackUri = jsonSerializedObject.callbackUri;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.temporaryCode = this.temporaryCode;\n toRet.state = this.state;\n toRet.callbackUri = this.callbackUri;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"temporaryCode\", rule: (v: any) => v == null || v.length !== 0 || \"TemporaryCode cannot be empty\"},\n {field: \"state\", rule: (v: any) => v == null || v.length !== 0 || \"State cannot be empty\"},\n {field: \"callbackUri\", rule: (v: any) => v == null || v.length !== 0 || \"CallbackUri cannot be empty\"},\n ];\n}\n\n\nexport class GenerateSignUpWithXeroRedirectUriRequest extends ModelObject {\n\n public callbackUri: string = \"\";\n public nonce: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.callbackUri = jsonSerializedObject.callbackUri;\n this.nonce = jsonSerializedObject.nonce;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.callbackUri = this.callbackUri;\n toRet.nonce = this.nonce;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GenerateSignUpWithXeroRedirectUriResponse extends ModelObject {\n\n public redirectUri: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.redirectUri = jsonSerializedObject.redirectUri;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.redirectUri = this.redirectUri;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class CompleteSignUpWithXeroRequest extends ModelObject {\n\n public code: string = \"\";\n public callbackUri: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.code = jsonSerializedObject.code;\n this.callbackUri = jsonSerializedObject.callbackUri;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.code = this.code;\n toRet.callbackUri = this.callbackUri;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class CompleteSignUpWithXeroResponse extends ModelObject {\n\n public result: CompleteSignUpWithXeroResult = new CompleteSignUpWithXeroResult();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.result = new CompleteSignUpWithXeroResult(jsonSerializedObject.result);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.result = this.result.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"result\", rule: (v: any) => !!v || \"result is required\"},\n {field: \"result\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class PerformFortnoxAccountsLinkRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public authorizationCode: string = \"\";\n public state: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.authorizationCode = jsonSerializedObject.authorizationCode;\n this.state = jsonSerializedObject.state;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.authorizationCode = this.authorizationCode;\n toRet.state = this.state;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"authorizationCode\", rule: (v: any) => v == null || v.length !== 0 || \"AuthorizationCode cannot be empty\"},\n {field: \"state\", rule: (v: any) => v == null || v.length !== 0 || \"State cannot be empty\"},\n ];\n}\n\n\nexport class CompleteQuickBooksAccountsLinkRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n /**\n * The callback Uri used in the link establishment.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public callbackUri: string = \"\";\n /**\n * The code provided by QuickBooks in the redirect back to BrewMan after authorization.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public authorizationCode: string = \"\";\n /**\n * The state returned by QuickBooks in the redirect back to BrewMan. Should match the Nonce used in the OAuth flow.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public state: string = \"\";\n /**\n * The realm id returned by QuickBooks, which identifies the QuickBooks company which has been linked.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public realmId: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.callbackUri = jsonSerializedObject.callbackUri;\n this.authorizationCode = jsonSerializedObject.authorizationCode;\n this.state = jsonSerializedObject.state;\n this.realmId = jsonSerializedObject.realmId;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.callbackUri = this.callbackUri;\n toRet.authorizationCode = this.authorizationCode;\n toRet.state = this.state;\n toRet.realmId = this.realmId;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class CompleteSageOneAccountsLinkRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n /**\n * The callback Uri used in the link establishment.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public callbackUri: string = \"\";\n /**\n * The code provided by SageOne in the redirect back to BrewMan after authorization.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public authorizationCode: string = \"\";\n /**\n * The state returned by SageOne in the redirect back to BrewMan. Should match the Nonce used in the OAuth flow.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public state: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.callbackUri = jsonSerializedObject.callbackUri;\n this.authorizationCode = jsonSerializedObject.authorizationCode;\n this.state = jsonSerializedObject.state;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.callbackUri = this.callbackUri;\n toRet.authorizationCode = this.authorizationCode;\n toRet.state = this.state;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class PerformLexofficeAccountsLinkRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n /**\n * The client's API key used for linking to Lexoffice\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public apiKey: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.apiKey = jsonSerializedObject.apiKey;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.apiKey = this.apiKey;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class SaveSettingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public settings: AccountLinkSettings = new AccountLinkSettings();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.settings = new AccountLinkSettings(jsonSerializedObject.settings);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.settings = this.settings.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"settings\", rule: (v: any) => !!v || \"settings is required\"},\n {field: \"settings\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetSageOneZaCompaniesRequest extends ModelObject {\n\n public sageUsername: string = \"\";\n public sagePassword: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.sageUsername = jsonSerializedObject.sageUsername;\n this.sagePassword = jsonSerializedObject.sagePassword;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.sageUsername = this.sageUsername;\n toRet.sagePassword = this.sagePassword;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GetSageOneZaCompaniesResponse extends ModelObject {\n\n public companies: SageOneZaCompany[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.companies = jsonSerializedObject.companies.map((v: any) => new SageOneZaCompany(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.companies = this.companies.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"companies\", rule: (v: any) => !!v || \"companies is required\"},\n {field: \"companies\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as SageOneZaCompany[]).reduce((acc: Array, curr: SageOneZaCompany) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class CompleteSageOneZaLinkRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public sageUsername: string = \"\";\n public sagePassword: string = \"\";\n public sageCompanyId: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.sageUsername = jsonSerializedObject.sageUsername;\n this.sagePassword = jsonSerializedObject.sagePassword;\n this.sageCompanyId = jsonSerializedObject.sageCompanyId;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.sageUsername = this.sageUsername;\n toRet.sagePassword = this.sagePassword;\n toRet.sageCompanyId = this.sageCompanyId;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAvailableAccountsGlCodesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAvailableAccountsGlCodesResponse extends ModelObject {\n\n private _accountsGlCodes: AccountsGlCode[] | null = null;\n public get accountsGlCodes(): AccountsGlCode[] | null { return this._accountsGlCodes }\n public set accountsGlCodes(value: AccountsGlCode[] | null) {\n this._accountsGlCodes = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.accountsGlCodes = jsonSerializedObject.accountsGlCodes == null ? null : jsonSerializedObject.accountsGlCodes.map((v: any) => new AccountsGlCode(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.accountsGlCodes = this.accountsGlCodes == null ? null : this.accountsGlCodes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"accountsGlCodes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AccountsGlCode[]).reduce((acc: Array, curr: AccountsGlCode) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAvailableAccountsTaxCodesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAvailableAccountsTaxCodesResponse extends ModelObject {\n\n private _accountsTaxCodes: AccountsTaxCode[] | null = null;\n public get accountsTaxCodes(): AccountsTaxCode[] | null { return this._accountsTaxCodes }\n public set accountsTaxCodes(value: AccountsTaxCode[] | null) {\n this._accountsTaxCodes = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.accountsTaxCodes = jsonSerializedObject.accountsTaxCodes == null ? null : jsonSerializedObject.accountsTaxCodes.map((v: any) => new AccountsTaxCode(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.accountsTaxCodes = this.accountsTaxCodes == null ? null : this.accountsTaxCodes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"accountsTaxCodes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AccountsTaxCode[]).reduce((acc: Array, curr: AccountsTaxCode) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class AccountsLinkService extends ServiceBase {\n\n public async getAccountsLinkDetails(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAccountsLinkDetailsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAccountsLinkDetailsResponse(response).accountsLinkDetails;\n return this.makeJsonRequest(\"accountsLink/v1/getAccountsLinkDetails\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAccountsLinkLogonUrl(tenantId: Guid, accountsPackageType: EnumAccountsPackageType, callbackUri: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAccountsLinkLogonUrlRequest();\n req.tenantId = tenantId;\n req.accountsPackageType = accountsPackageType;\n req.callbackUri = callbackUri;\n const extractor = (response:any) => new GetAccountsLinkLogonUrlResponse(response).accountsLinkLogonUrl;\n return this.makeJsonRequest(\"accountsLink/v1/getAccountsLinkLogonUrl\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async disconnectAccountsLink(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new DisconnectAccountsLinkRequest();\n req.tenantId = tenantId;\n const extractor = null;\n return this.makeJsonRequest(\"accountsLink/v1/disconnectAccountsLink\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setExternalAccountsLink(tenantId: Guid, accountsPackageType: EnumAccountsPackageType, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetExternalAccountsLinkRequest();\n req.tenantId = tenantId;\n req.accountsPackageType = accountsPackageType;\n const extractor = null;\n return this.makeJsonRequest(\"accountsLink/v1/setExternalAccountsLink\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async performXeroAccountsLink(tenantId: Guid, temporaryCode: string, state: string, callbackUri: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new PerformXeroAccountsLinkRequest();\n req.tenantId = tenantId;\n req.temporaryCode = temporaryCode;\n req.state = state;\n req.callbackUri = callbackUri;\n const extractor = null;\n return this.makeJsonRequest(\"accountsLink/v1/performXeroAccountsLink\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async performFortnoxAccountsLink(tenantId: Guid, authorizationCode: string, state: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new PerformFortnoxAccountsLinkRequest();\n req.tenantId = tenantId;\n req.authorizationCode = authorizationCode;\n req.state = state;\n const extractor = null;\n return this.makeJsonRequest(\"accountsLink/v1/performFortnoxAccountsLink\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async completeQuickBooksAccountsLink(tenantId: Guid, callbackUri: string, authorizationCode: string, state: string, realmId: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CompleteQuickBooksAccountsLinkRequest();\n req.tenantId = tenantId;\n req.callbackUri = callbackUri;\n req.authorizationCode = authorizationCode;\n req.state = state;\n req.realmId = realmId;\n const extractor = null;\n return this.makeJsonRequest(\"accountsLink/v1/completeQuickBooksAccountsLink\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async completeSageOneAccountsLink(tenantId: Guid, callbackUri: string, authorizationCode: string, state: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CompleteSageOneAccountsLinkRequest();\n req.tenantId = tenantId;\n req.callbackUri = callbackUri;\n req.authorizationCode = authorizationCode;\n req.state = state;\n const extractor = null;\n return this.makeJsonRequest(\"accountsLink/v1/completeSageOneAccountsLink\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async performLexofficeAccountsLink(tenantId: Guid, apiKey: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new PerformLexofficeAccountsLinkRequest();\n req.tenantId = tenantId;\n req.apiKey = apiKey;\n const extractor = null;\n return this.makeJsonRequest(\"accountsLink/v1/performLexofficeAccountsLink\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveSettings(tenantId: Guid, settings: AccountLinkSettings, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveSettingsRequest();\n req.tenantId = tenantId;\n req.settings = settings;\n const extractor = null;\n return this.makeJsonRequest(\"accountsLink/v1/saveSettings\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getSageOneZaCompanies(sageUsername: string, sagePassword: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetSageOneZaCompaniesRequest();\n req.sageUsername = sageUsername;\n req.sagePassword = sagePassword;\n const extractor = (response:any) => new GetSageOneZaCompaniesResponse(response).companies;\n return this.makeJsonRequest(\"accountsLink/v1/getSageOneZaCompanies\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async completeSageOneZaLink(tenantId: Guid, sageUsername: string, sagePassword: string, sageCompanyId: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CompleteSageOneZaLinkRequest();\n req.tenantId = tenantId;\n req.sageUsername = sageUsername;\n req.sagePassword = sagePassword;\n req.sageCompanyId = sageCompanyId;\n const extractor = null;\n return this.makeJsonRequest(\"accountsLink/v1/completeSageOneZaLink\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAvailableAccountsGlCodes(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAvailableAccountsGlCodesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAvailableAccountsGlCodesResponse(response).accountsGlCodes;\n return this.makeJsonRequest(\"accountsLink/v1/getAvailableAccountsGlCodes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAvailableAccountsTaxCodes(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAvailableAccountsTaxCodesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAvailableAccountsTaxCodesResponse(response).accountsTaxCodes;\n return this.makeJsonRequest(\"accountsLink/v1/getAvailableAccountsTaxCodes\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const accountsLinkService = new AccountsLinkService();","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class TenantDepositSettings extends ModelObject {\n\n public version: number = 0;\n /**\n * Whether the tenant partakes in bottle deposit scheme.\n */\n public isBottleDepositEnabled: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.isBottleDepositEnabled = jsonSerializedObject.isBottleDepositEnabled;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.isBottleDepositEnabled = this.isBottleDepositEnabled;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n ];\n}\n\n\nexport class OutletDepositSettings extends ModelObject {\n\n public version: number = 0;\n /**\n * Outlet with the setting.\n */\n public outletId: Guid = Guid.createEmpty();\n /**\n * Whether the outlet partakes in bottle deposit scheme.\n */\n public isBottleDepositEnabled: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n this.isBottleDepositEnabled = jsonSerializedObject.isBottleDepositEnabled;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.outletId = this.outletId.toString();\n toRet.isBottleDepositEnabled = this.isBottleDepositEnabled;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \"OutletDepositSettings.OutletId cannot be empty\"},\n ];\n}\n\n\nexport class GetTenantSettingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetTenantSettingsResponse extends ModelObject {\n\n public tenantDepositSettings: TenantDepositSettings = new TenantDepositSettings();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantDepositSettings = new TenantDepositSettings(jsonSerializedObject.tenantDepositSettings);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantDepositSettings = this.tenantDepositSettings.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantDepositSettings\", rule: (v: any) => !!v || \"tenantDepositSettings is required\"},\n {field: \"tenantDepositSettings\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveTenantSettingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public tenantDepositSettings: TenantDepositSettings = new TenantDepositSettings();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.tenantDepositSettings = new TenantDepositSettings(jsonSerializedObject.tenantDepositSettings);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.tenantDepositSettings = this.tenantDepositSettings.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"tenantDepositSettings\", rule: (v: any) => !!v || \"tenantDepositSettings is required\"},\n {field: \"tenantDepositSettings\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetOutletSettingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletId = this.outletId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \".OutletId cannot be empty\"},\n ];\n}\n\n\nexport class GetOutletSettingsResponse extends ModelObject {\n\n public outletDepositSettings: OutletDepositSettings = new OutletDepositSettings();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outletDepositSettings = new OutletDepositSettings(jsonSerializedObject.outletDepositSettings);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outletDepositSettings = this.outletDepositSettings.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outletDepositSettings\", rule: (v: any) => !!v || \"outletDepositSettings is required\"},\n {field: \"outletDepositSettings\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetManyOutletSettingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletIds = jsonSerializedObject.outletIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletIds = this.outletIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetManyOutletSettingsResponse extends ModelObject {\n\n public outletDepositSettings: OutletDepositSettings[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outletDepositSettings = jsonSerializedObject.outletDepositSettings.map((v: any) => new OutletDepositSettings(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outletDepositSettings = this.outletDepositSettings.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outletDepositSettings\", rule: (v: any) => !!v || \"outletDepositSettings is required\"},\n {field: \"outletDepositSettings\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OutletDepositSettings[]).reduce((acc: Array, curr: OutletDepositSettings) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveOutletSettingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletDepositSettings: OutletDepositSettings = new OutletDepositSettings();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletDepositSettings = new OutletDepositSettings(jsonSerializedObject.outletDepositSettings);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletDepositSettings = this.outletDepositSettings.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletDepositSettings\", rule: (v: any) => !!v || \"outletDepositSettings is required\"},\n {field: \"outletDepositSettings\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class BottleDepositSettingsService extends ServiceBase {\n\n public async getTenantSettings(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetTenantSettingsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetTenantSettingsResponse(response).tenantDepositSettings;\n return this.makeJsonRequest(\"bottleDepositSettings/v1/getTenantSettings\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveTenantSettings(tenantId: Guid, tenantDepositSettings: TenantDepositSettings, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveTenantSettingsRequest();\n req.tenantId = tenantId;\n req.tenantDepositSettings = tenantDepositSettings;\n const extractor = null;\n return this.makeJsonRequest(\"bottleDepositSettings/v1/saveTenantSettings\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getOutletSettings(tenantId: Guid, outletId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetOutletSettingsRequest();\n req.tenantId = tenantId;\n req.outletId = outletId;\n const extractor = (response:any) => new GetOutletSettingsResponse(response).outletDepositSettings;\n return this.makeJsonRequest(\"bottleDepositSettings/v1/getOutletSettings\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getManyOutletSettings(tenantId: Guid, outletIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetManyOutletSettingsRequest();\n req.tenantId = tenantId;\n req.outletIds = outletIds;\n const extractor = (response:any) => new GetManyOutletSettingsResponse(response).outletDepositSettings;\n return this.makeJsonRequest(\"bottleDepositSettings/v1/getManyOutletSettings\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveOutletSettings(tenantId: Guid, outletDepositSettings: OutletDepositSettings, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveOutletSettingsRequest();\n req.tenantId = tenantId;\n req.outletDepositSettings = outletDepositSettings;\n const extractor = null;\n return this.makeJsonRequest(\"bottleDepositSettings/v1/saveOutletSettings\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const bottleDepositSettingsService = new BottleDepositSettingsService();","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class CompanySettingsReadOnly extends ModelObject {\n\n public version: number = 0;\n private _latitude: number | null = null;\n /**\n * Latitude (if known)\n */\n public get latitude(): number | null { return this._latitude }\n public set latitude(value: number | null) {\n this._latitude = value === undefined ? null : value;\n }\n private _longitude: number | null = null;\n /**\n * Longitude (if known)\n */\n public get longitude(): number | null { return this._longitude }\n public set longitude(value: number | null) {\n this._longitude = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.latitude = jsonSerializedObject.latitude == null ? null : jsonSerializedObject.latitude;\n this.longitude = jsonSerializedObject.longitude == null ? null : jsonSerializedObject.longitude;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.latitude = this.latitude == null ? null : this.latitude;\n toRet.longitude = this.longitude == null ? null : this.longitude;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n ];\n}\n\n\nexport class CompanySettings extends BaseModelObject {\n\n /**\n * Account Number\n * Not Nullable\n * Max Length : 1000\n */\n public accountNumber: string = \"\";\n /**\n * Address Line 1\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine1: string = \"\";\n /**\n * Address Line 2\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine2: string = \"\";\n /**\n * Address Line 3\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine3: string = \"\";\n /**\n * Address Line 4\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine4: string = \"\";\n /**\n * Address Line 5\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine5: string = \"\";\n /**\n * Address Line 6\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine6: string = \"\";\n /**\n * Alternative Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public alternativeName: string = \"\";\n /**\n * AWRS Number\n * Not Nullable\n * Max Length : 1000\n */\n public awrsNumber: string = \"\";\n /**\n * Bank Name\n * Not Nullable\n * Max Length : 1000\n */\n public bankName: string = \"\";\n /**\n * Company Registration Number\n * Not Nullable\n * Max Length : 1000\n */\n public companyRegistrationNumber: string = \"\";\n /**\n * Email Address\n * Not Nullable\n * Max Length : 1000\n */\n public emailAddress: string = \"\";\n /**\n * EORI Number\n * Not Nullable\n * Max Length : 1000\n */\n public eoriNumber: string = \"\";\n /**\n * EORI Number (NI)\n * Not Nullable\n * Max Length : 1000\n */\n public eoriNumberNi: string = \"\";\n private _logoImageId: Guid | null = null;\n /**\n * Main Company Logo\n */\n public get logoImageId(): Guid | null { return this._logoImageId }\n public set logoImageId(value: Guid | null) {\n this._logoImageId = value === undefined ? null : value;\n }\n /**\n * Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n /**\n * Postcode\n * Not Nullable\n * Max Length : 1000\n */\n public postcode: string = \"\";\n /**\n * Sort Code\n * Not Nullable\n * Max Length : 1000\n */\n public sortCode: string = \"\";\n /**\n * Telephone Number\n * Not Nullable\n * Max Length : 1000\n */\n public telephoneNumber: string = \"\";\n /**\n * Use Alternative Name on Invoices\n */\n public useAlternativeNameOnInvoices: boolean = false;\n /**\n * VAT Registration No\n * Not Nullable\n * Max Length : 1000\n */\n public vatRegistrationNumber: string = \"\";\n /**\n * Web\n * Not Nullable\n * Max Length : 1000\n */\n public website: string = \"\";\n public readOnly: CompanySettingsReadOnly = new CompanySettingsReadOnly();\n /**\n * International Bank Account Number\n * Not Nullable\n * Max Length : 1000\n */\n public iban: string = \"\";\n /**\n * Bank Identification Code\n * Not Nullable\n * Max Length : 1000\n */\n public bic: string = \"\";\n private _creditLimitThreshold: number | null = null;\n /**\n * The level at which the user should be notified that the credit balance is near the credit limit.\n * Not Negative\n */\n public get creditLimitThreshold(): number | null { return this._creditLimitThreshold }\n public set creditLimitThreshold(value: number | null) {\n this._creditLimitThreshold = value === undefined ? null : value;\n }\n public australianBusinessNumber: string = \"\";\n public employerIdentificationNumber: string = \"\";\n public ttbBrewersNotice: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.accountNumber = jsonSerializedObject.accountNumber;\n this.addressLine1 = jsonSerializedObject.addressLine1;\n this.addressLine2 = jsonSerializedObject.addressLine2;\n this.addressLine3 = jsonSerializedObject.addressLine3;\n this.addressLine4 = jsonSerializedObject.addressLine4;\n this.addressLine5 = jsonSerializedObject.addressLine5;\n this.addressLine6 = jsonSerializedObject.addressLine6;\n this.alternativeName = jsonSerializedObject.alternativeName;\n this.awrsNumber = jsonSerializedObject.awrsNumber;\n this.bankName = jsonSerializedObject.bankName;\n this.companyRegistrationNumber = jsonSerializedObject.companyRegistrationNumber;\n this.emailAddress = jsonSerializedObject.emailAddress;\n this.eoriNumber = jsonSerializedObject.eoriNumber;\n this.eoriNumberNi = jsonSerializedObject.eoriNumberNi;\n this.logoImageId = jsonSerializedObject.logoImageId == null ? null : Guid.fromString(jsonSerializedObject.logoImageId);\n this.name = jsonSerializedObject.name;\n this.postcode = jsonSerializedObject.postcode;\n this.sortCode = jsonSerializedObject.sortCode;\n this.telephoneNumber = jsonSerializedObject.telephoneNumber;\n this.useAlternativeNameOnInvoices = jsonSerializedObject.useAlternativeNameOnInvoices;\n this.vatRegistrationNumber = jsonSerializedObject.vatRegistrationNumber;\n this.website = jsonSerializedObject.website;\n this.readOnly = new CompanySettingsReadOnly(jsonSerializedObject.readOnly);\n this.iban = jsonSerializedObject.iban;\n this.bic = jsonSerializedObject.bic;\n this.creditLimitThreshold = jsonSerializedObject.creditLimitThreshold == null ? null : jsonSerializedObject.creditLimitThreshold;\n this.australianBusinessNumber = jsonSerializedObject.australianBusinessNumber;\n this.employerIdentificationNumber = jsonSerializedObject.employerIdentificationNumber;\n this.ttbBrewersNotice = jsonSerializedObject.ttbBrewersNotice;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.accountNumber = this.accountNumber;\n toRet.addressLine1 = this.addressLine1;\n toRet.addressLine2 = this.addressLine2;\n toRet.addressLine3 = this.addressLine3;\n toRet.addressLine4 = this.addressLine4;\n toRet.addressLine5 = this.addressLine5;\n toRet.addressLine6 = this.addressLine6;\n toRet.alternativeName = this.alternativeName;\n toRet.awrsNumber = this.awrsNumber;\n toRet.bankName = this.bankName;\n toRet.companyRegistrationNumber = this.companyRegistrationNumber;\n toRet.emailAddress = this.emailAddress;\n toRet.eoriNumber = this.eoriNumber;\n toRet.eoriNumberNi = this.eoriNumberNi;\n toRet.logoImageId = this.logoImageId == null ? null : this.logoImageId.toString();\n toRet.name = this.name;\n toRet.postcode = this.postcode;\n toRet.sortCode = this.sortCode;\n toRet.telephoneNumber = this.telephoneNumber;\n toRet.useAlternativeNameOnInvoices = this.useAlternativeNameOnInvoices;\n toRet.vatRegistrationNumber = this.vatRegistrationNumber;\n toRet.website = this.website;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.iban = this.iban;\n toRet.bic = this.bic;\n toRet.creditLimitThreshold = this.creditLimitThreshold == null ? null : this.creditLimitThreshold;\n toRet.australianBusinessNumber = this.australianBusinessNumber;\n toRet.employerIdentificationNumber = this.employerIdentificationNumber;\n toRet.ttbBrewersNotice = this.ttbBrewersNotice;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"accountNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"AccountNumber has too many characters (1000)\"},\n {field: \"addressLine1\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine1 has too many characters (1000)\"},\n {field: \"addressLine2\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine2 has too many characters (1000)\"},\n {field: \"addressLine3\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine3 has too many characters (1000)\"},\n {field: \"addressLine4\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine4 has too many characters (1000)\"},\n {field: \"addressLine5\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine5 has too many characters (1000)\"},\n {field: \"addressLine6\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine6 has too many characters (1000)\"},\n {field: \"alternativeName\", rule: (v: any) => v == null || v.length !== 0 || \"AlternativeName cannot be empty\"},\n {field: \"alternativeName\", rule: (v: any) => v == null || v.length <= 1000 || \"AlternativeName has too many characters (1000)\"},\n {field: \"awrsNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"AwrsNumber has too many characters (1000)\"},\n {field: \"bankName\", rule: (v: any) => v == null || v.length <= 1000 || \"BankName has too many characters (1000)\"},\n {field: \"companyRegistrationNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"CompanyRegistrationNumber has too many characters (1000)\"},\n {field: \"emailAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"EmailAddress has too many characters (1000)\"},\n {field: \"eoriNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"EoriNumber has too many characters (1000)\"},\n {field: \"eoriNumberNi\", rule: (v: any) => v == null || v.length <= 1000 || \"EoriNumberNi has too many characters (1000)\"},\n {field: \"logoImageId\", rule: (v: any) => v == null || !v.isEmpty() || \"CompanySettings.LogoImageId cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"postcode\", rule: (v: any) => v == null || v.length <= 1000 || \"Postcode has too many characters (1000)\"},\n {field: \"sortCode\", rule: (v: any) => v == null || v.length <= 1000 || \"SortCode has too many characters (1000)\"},\n {field: \"telephoneNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"TelephoneNumber has too many characters (1000)\"},\n {field: \"vatRegistrationNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"VatRegistrationNumber has too many characters (1000)\"},\n {field: \"website\", rule: (v: any) => v == null || v.length <= 1000 || \"Website has too many characters (1000)\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"iban\", rule: (v: any) => v == null || v.length <= 1000 || \"Iban has too many characters (1000)\"},\n {field: \"bic\", rule: (v: any) => v == null || v.length <= 1000 || \"Bic has too many characters (1000)\"},\n {field: \"australianBusinessNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"AustralianBusinessNumber has too many characters (1000)\"},\n {field: \"employerIdentificationNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"EmployerIdentificationNumber has too many characters (1000)\"},\n {field: \"ttbBrewersNotice\", rule: (v: any) => v == null || v.length <= 1000 || \"TtbBrewersNotice has too many characters (1000)\"},\n ];\n}\n\n\nexport class GetCompanySettingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetCompanySettingsResponse extends ModelObject {\n\n public companySettings: CompanySettings = new CompanySettings();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.companySettings = new CompanySettings(jsonSerializedObject.companySettings);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.companySettings = this.companySettings.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"companySettings\", rule: (v: any) => !!v || \"companySettings is required\"},\n {field: \"companySettings\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class UpdateCompanySettingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public companySettings: CompanySettings = new CompanySettings();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.companySettings = new CompanySettings(jsonSerializedObject.companySettings);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.companySettings = this.companySettings.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"companySettings\", rule: (v: any) => !!v || \"companySettings is required\"},\n {field: \"companySettings\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class CompanySettingsService extends ServiceBase {\n\n public async getCompanySettings(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetCompanySettingsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetCompanySettingsResponse(response).companySettings;\n return this.makeJsonRequest(\"companySettings/v1/getCompanySettings\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updateCompanySettings(tenantId: Guid, companySettings: CompanySettings, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdateCompanySettingsRequest();\n req.tenantId = tenantId;\n req.companySettings = companySettings;\n const extractor = null;\n return this.makeJsonRequest(\"companySettings/v1/updateCompanySettings\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const companySettingsService = new CompanySettingsService();","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class DeliveryNotificationSettings extends ModelObject {\n\n public version: number = 0;\n /**\n * Whether despatch notifications should be sent by SMS for this tenant.\n */\n public sendDespatchNotificationSms: boolean = false;\n /**\n * Name to show Sms's coming from.\n * Not Nullable\n * Max Length : 32\n */\n public smsSenderIdentification: string = \"\";\n /**\n * Whether despatch notifications should be sent by Email for this tenant.\n */\n public sendDespatchNotificationEmails: boolean = false;\n /**\n * Reply To address to use when sending emails.\n * Not Nullable\n * Max Length : 1000\n */\n public emailReplyToAddress: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.sendDespatchNotificationSms = jsonSerializedObject.sendDespatchNotificationSms;\n this.smsSenderIdentification = jsonSerializedObject.smsSenderIdentification;\n this.sendDespatchNotificationEmails = jsonSerializedObject.sendDespatchNotificationEmails;\n this.emailReplyToAddress = jsonSerializedObject.emailReplyToAddress;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.sendDespatchNotificationSms = this.sendDespatchNotificationSms;\n toRet.smsSenderIdentification = this.smsSenderIdentification;\n toRet.sendDespatchNotificationEmails = this.sendDespatchNotificationEmails;\n toRet.emailReplyToAddress = this.emailReplyToAddress;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"smsSenderIdentification\", rule: (v: any) => v == null || v.length <= 32 || \"SmsSenderIdentification has too many characters (32)\"},\n {field: \"emailReplyToAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"EmailReplyToAddress has too many characters (1000)\"},\n ];\n}\n\n\nexport class GetDeliveryNotificationSettingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetDeliveryNotificationSettingsResponse extends ModelObject {\n\n public deliveryNotificationSettings: DeliveryNotificationSettings = new DeliveryNotificationSettings();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.deliveryNotificationSettings = new DeliveryNotificationSettings(jsonSerializedObject.deliveryNotificationSettings);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.deliveryNotificationSettings = this.deliveryNotificationSettings.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"deliveryNotificationSettings\", rule: (v: any) => !!v || \"deliveryNotificationSettings is required\"},\n {field: \"deliveryNotificationSettings\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveDeliveryNotificationSettingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public deliveryNotificationSettings: DeliveryNotificationSettings = new DeliveryNotificationSettings();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.deliveryNotificationSettings = new DeliveryNotificationSettings(jsonSerializedObject.deliveryNotificationSettings);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.deliveryNotificationSettings = this.deliveryNotificationSettings.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"deliveryNotificationSettings\", rule: (v: any) => !!v || \"deliveryNotificationSettings is required\"},\n {field: \"deliveryNotificationSettings\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GenerateDespatchNotificationTextRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public textTemplate: string = \"\";\n public journeyId: Guid = Guid.createEmpty();\n public orderId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.textTemplate = jsonSerializedObject.textTemplate;\n this.journeyId = Guid.fromString(jsonSerializedObject.journeyId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.textTemplate = this.textTemplate;\n toRet.journeyId = this.journeyId.toString();\n toRet.orderId = this.orderId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"journeyId\", rule: (v: any) => !v.isEmpty() || \".JourneyId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n ];\n}\n\n\nexport class GenerateDespatchNotificationTextResponse extends ModelObject {\n\n public result: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.result = jsonSerializedObject.result;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.result = this.result;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class SendDespatchNotificationsForJourneyRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public journeyId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.journeyId = Guid.fromString(jsonSerializedObject.journeyId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.journeyId = this.journeyId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"journeyId\", rule: (v: any) => !v.isEmpty() || \".JourneyId cannot be empty\"},\n ];\n}\n\n\nexport class DeliveryNotificationService extends ServiceBase {\n\n public async getDeliveryNotificationSettings(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetDeliveryNotificationSettingsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetDeliveryNotificationSettingsResponse(response).deliveryNotificationSettings;\n return this.makeJsonRequest(\"deliveryNotification/v1/getDeliveryNotificationSettings\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveDeliveryNotificationSettings(tenantId: Guid, deliveryNotificationSettings: DeliveryNotificationSettings, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveDeliveryNotificationSettingsRequest();\n req.tenantId = tenantId;\n req.deliveryNotificationSettings = deliveryNotificationSettings;\n const extractor = null;\n return this.makeJsonRequest(\"deliveryNotification/v1/saveDeliveryNotificationSettings\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async generateDespatchNotificationText(tenantId: Guid, textTemplate: string, journeyId: Guid, orderId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GenerateDespatchNotificationTextRequest();\n req.tenantId = tenantId;\n req.textTemplate = textTemplate;\n req.journeyId = journeyId;\n req.orderId = orderId;\n const extractor = (response:any) => new GenerateDespatchNotificationTextResponse(response).result;\n return this.makeJsonRequest(\"deliveryNotification/v1/generateDespatchNotificationText\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const deliveryNotificationService = new DeliveryNotificationService();","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumKegstarContainerType } from \"./enums/enumKegstarContainerType.generated\";\n\n// Model Objects\n\nexport class KegstarSettings extends ModelObject {\n\n public version: number = 0;\n /**\n * Whether the Kegstar link is enabled.\n */\n public isEnabled: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.isEnabled = jsonSerializedObject.isEnabled;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.isEnabled = this.isEnabled;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n ];\n}\n\n\nexport class KegstarReportLine extends ModelObject {\n\n /**\n * Company name\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public brewer: string = \"\";\n /**\n * Sales order\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public transactionType: string = \"\";\n /**\n * Outlet code\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public customerId: string = \"\";\n /**\n * Outlet business name\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public customerName: string = \"\";\n /**\n * Outlet main address 1\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public customerAddress1: string = \"\";\n /**\n * Outlet main address 2\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public customerAddress2: string = \"\";\n /**\n * Outlet main address 3\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public customerAddress3: string = \"\";\n /**\n * Outlet main address 4\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public customerCity: string = \"\";\n /**\n * Outlet main address 5\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public customerState: string = \"\";\n /**\n * Outlet main address 6\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public customerCountry: string = \"\";\n /**\n * Outlet main address postcode\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public customerPostcode: string = \"\";\n /**\n * Order despatch date\n */\n public shipDate: LocalDate = LocalDate.ofEpochDay(0);\n public item: EnumKegstarContainerType = EnumKegstarContainerType.none;\n /**\n * Quantity of the package type on the order\n */\n public quantity: number = 0;\n /**\n * Order number\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public customerReferenceNumber: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.brewer = jsonSerializedObject.brewer;\n this.transactionType = jsonSerializedObject.transactionType;\n this.customerId = jsonSerializedObject.customerId;\n this.customerName = jsonSerializedObject.customerName;\n this.customerAddress1 = jsonSerializedObject.customerAddress1;\n this.customerAddress2 = jsonSerializedObject.customerAddress2;\n this.customerAddress3 = jsonSerializedObject.customerAddress3;\n this.customerCity = jsonSerializedObject.customerCity;\n this.customerState = jsonSerializedObject.customerState;\n this.customerCountry = jsonSerializedObject.customerCountry;\n this.customerPostcode = jsonSerializedObject.customerPostcode;\n this.shipDate = LocalDate.parse(jsonSerializedObject.shipDate);\n this.item = EnumKegstarContainerType.getByValue(jsonSerializedObject.item, this.item);\n this.quantity = jsonSerializedObject.quantity;\n this.customerReferenceNumber = jsonSerializedObject.customerReferenceNumber;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.brewer = this.brewer;\n toRet.transactionType = this.transactionType;\n toRet.customerId = this.customerId;\n toRet.customerName = this.customerName;\n toRet.customerAddress1 = this.customerAddress1;\n toRet.customerAddress2 = this.customerAddress2;\n toRet.customerAddress3 = this.customerAddress3;\n toRet.customerCity = this.customerCity;\n toRet.customerState = this.customerState;\n toRet.customerCountry = this.customerCountry;\n toRet.customerPostcode = this.customerPostcode;\n toRet.shipDate = this.shipDate.toString();\n toRet.item = this.item.value;\n toRet.quantity = this.quantity;\n toRet.customerReferenceNumber = this.customerReferenceNumber;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GetKegstarSettingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetKegstarSettingsResponse extends ModelObject {\n\n public kegstarSettings: KegstarSettings = new KegstarSettings();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.kegstarSettings = new KegstarSettings(jsonSerializedObject.kegstarSettings);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.kegstarSettings = this.kegstarSettings.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"kegstarSettings\", rule: (v: any) => !!v || \"kegstarSettings is required\"},\n {field: \"kegstarSettings\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveKegstarSettingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public kegstarSettings: KegstarSettings = new KegstarSettings();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.kegstarSettings = new KegstarSettings(jsonSerializedObject.kegstarSettings);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.kegstarSettings = this.kegstarSettings.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"kegstarSettings\", rule: (v: any) => !!v || \"kegstarSettings is required\"},\n {field: \"kegstarSettings\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GenerateKegstarContainerReportRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public despatchStartDate: LocalDate = LocalDate.ofEpochDay(0);\n public despatchEndDate: LocalDate = LocalDate.ofEpochDay(0);\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.despatchStartDate = LocalDate.parse(jsonSerializedObject.despatchStartDate);\n this.despatchEndDate = LocalDate.parse(jsonSerializedObject.despatchEndDate);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.despatchStartDate = this.despatchStartDate.toString();\n toRet.despatchEndDate = this.despatchEndDate.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GenerateKegstarContainerReportResponse extends ModelObject {\n\n public kegstarReportLine: KegstarReportLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.kegstarReportLine = jsonSerializedObject.kegstarReportLine.map((v: any) => new KegstarReportLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.kegstarReportLine = this.kegstarReportLine.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"kegstarReportLine\", rule: (v: any) => !!v || \"kegstarReportLine is required\"},\n {field: \"kegstarReportLine\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as KegstarReportLine[]).reduce((acc: Array, curr: KegstarReportLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class KegstarLinkService extends ServiceBase {\n\n public async getKegstarSettings(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetKegstarSettingsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetKegstarSettingsResponse(response).kegstarSettings;\n return this.makeJsonRequest(\"kegstarLink/v1/getKegstarSettings\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveKegstarSettings(tenantId: Guid, kegstarSettings: KegstarSettings, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveKegstarSettingsRequest();\n req.tenantId = tenantId;\n req.kegstarSettings = kegstarSettings;\n const extractor = null;\n return this.makeJsonRequest(\"kegstarLink/v1/saveKegstarSettings\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async generateKegstarContainerReport(tenantId: Guid, despatchStartDate: LocalDate, despatchEndDate: LocalDate, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GenerateKegstarContainerReportRequest();\n req.tenantId = tenantId;\n req.despatchStartDate = despatchStartDate;\n req.despatchEndDate = despatchEndDate;\n const extractor = (response:any) => new GenerateKegstarContainerReportResponse(response).kegstarReportLine;\n return this.makeJsonRequest(\"kegstarLink/v1/generateKegstarContainerReport\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const kegstarLinkService = new KegstarLinkService();","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumPurchaseOrderDeliveryDisbursement } from \"./enums/enumPurchaseOrderDeliveryDisbursement.generated\";\n\n// Model Objects\n\nexport class TenantSettings extends ModelObject {\n\n public version: number = 0;\n public tenantId: Guid = Guid.createEmpty();\n /**\n * Controls the Mega Batches status; when true, Production is disabled.\n */\n public isMegaBatchesEnabled: boolean = false;\n /**\n * Specifies the duration in months for which a product batch can be displayed in the system.\n * Minimum : 1\n */\n public productBatchDuration: number = 0;\n /**\n * If enabled, allows hop alpha for materials.\n */\n public usesHopAlpha: boolean = false;\n public poDefaultDeliveryDisbursement: EnumPurchaseOrderDeliveryDisbursement = EnumPurchaseOrderDeliveryDisbursement.none;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.isMegaBatchesEnabled = jsonSerializedObject.isMegaBatchesEnabled;\n this.productBatchDuration = jsonSerializedObject.productBatchDuration;\n this.usesHopAlpha = jsonSerializedObject.usesHopAlpha;\n this.poDefaultDeliveryDisbursement = EnumPurchaseOrderDeliveryDisbursement.getByValue(jsonSerializedObject.poDefaultDeliveryDisbursement, this.poDefaultDeliveryDisbursement);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.tenantId = this.tenantId.toString();\n toRet.isMegaBatchesEnabled = this.isMegaBatchesEnabled;\n toRet.productBatchDuration = this.productBatchDuration;\n toRet.usesHopAlpha = this.usesHopAlpha;\n toRet.poDefaultDeliveryDisbursement = this.poDefaultDeliveryDisbursement.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \"TenantSettings.TenantId cannot be empty\"},\n {field: \"productBatchDuration\", rule: (v: any) => v == null || v >= 1 || \"ProductBatchDuration is not greater than minimum allowed value: 1\"},\n {field: \"productBatchDuration\", rule: (v: any) => v == null || v <= 2147483647 || \"ProductBatchDuration is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class GetTenantSettingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetTenantSettingsResponse extends ModelObject {\n\n public tenantSettings: TenantSettings = new TenantSettings();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantSettings = new TenantSettings(jsonSerializedObject.tenantSettings);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantSettings = this.tenantSettings.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantSettings\", rule: (v: any) => !!v || \"tenantSettings is required\"},\n {field: \"tenantSettings\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetIsMegaBatchesEnabledRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n /**\n * True to enable, false to disable.\n */\n public enable: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.enable = jsonSerializedObject.enable;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.enable = this.enable;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class SetProductBatchDurationRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public monthsToDisplay: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.monthsToDisplay = jsonSerializedObject.monthsToDisplay;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.monthsToDisplay = this.monthsToDisplay;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"monthsToDisplay\", rule: (v: any) => v == null || v >= -2147483648 || \"MonthsToDisplay is not greater than minimum allowed value: -2147483648\"},\n {field: \"monthsToDisplay\", rule: (v: any) => v == null || v <= 2147483647 || \"MonthsToDisplay is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class SavePurchaseOrderSettingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public poDefaultDeliveryDisbursement: EnumPurchaseOrderDeliveryDisbursement = EnumPurchaseOrderDeliveryDisbursement.none;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.poDefaultDeliveryDisbursement = EnumPurchaseOrderDeliveryDisbursement.getByValue(jsonSerializedObject.poDefaultDeliveryDisbursement, this.poDefaultDeliveryDisbursement);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.poDefaultDeliveryDisbursement = this.poDefaultDeliveryDisbursement.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class SaveProductionSettingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n /**\n * If enabled, allows hop alpha for materials.\n */\n public usesHopAlpha: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.usesHopAlpha = jsonSerializedObject.usesHopAlpha;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.usesHopAlpha = this.usesHopAlpha;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class TenantSettingsService extends ServiceBase {\n\n public async getTenantSettings(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetTenantSettingsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetTenantSettingsResponse(response).tenantSettings;\n return this.makeJsonRequest(\"tenantSettings/v1/getTenantSettings\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setIsMegaBatchesEnabled(tenantId: Guid, enable: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetIsMegaBatchesEnabledRequest();\n req.tenantId = tenantId;\n req.enable = enable;\n const extractor = null;\n return this.makeJsonRequest(\"tenantSettings/v1/setIsMegaBatchesEnabled\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setProductBatchDuration(tenantId: Guid, monthsToDisplay: number, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetProductBatchDurationRequest();\n req.tenantId = tenantId;\n req.monthsToDisplay = monthsToDisplay;\n const extractor = null;\n return this.makeJsonRequest(\"tenantSettings/v1/setProductBatchDuration\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async savePurchaseOrderSettings(tenantId: Guid, poDefaultDeliveryDisbursement: EnumPurchaseOrderDeliveryDisbursement, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SavePurchaseOrderSettingsRequest();\n req.tenantId = tenantId;\n req.poDefaultDeliveryDisbursement = poDefaultDeliveryDisbursement;\n const extractor = null;\n return this.makeJsonRequest(\"tenantSettings/v1/savePurchaseOrderSettings\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveProductionSettings(tenantId: Guid, usesHopAlpha: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveProductionSettingsRequest();\n req.tenantId = tenantId;\n req.usesHopAlpha = usesHopAlpha;\n const extractor = null;\n return this.makeJsonRequest(\"tenantSettings/v1/saveProductionSettings\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const tenantSettingsService = new TenantSettingsService();","import api from \"@/app/api\";\nimport {\n AccountsLinkDetails,\n accountsLinkService,\n} from \"@/app/services/generated/accountslinkService\";\nimport {\n TenantDepositSettings,\n bottleDepositSettingsService,\n} from \"@/app/services/generated/bottledepositsettingsService\";\nimport {\n CompanySettings,\n companySettingsService,\n} from \"@/app/services/generated/companysettingsService\";\nimport {\n DeliveryNotificationSettings,\n deliveryNotificationService,\n} from \"@/app/services/generated/deliverynotificationService\";\nimport {\n KegstarSettings,\n kegstarLinkService,\n} from \"@/app/services/generated/kegstarlinkService\";\nimport type {\n DateAndTimeConfiguration,\n CurrencyConfiguration,\n LanguageAndCultureConfiguration,\n NumberConfiguration,\n} from \"@/app/services/generated/tenantService\";\nimport { tenantService } from \"@/app/services/generated/tenantService\";\nimport { reactive, shallowReadonly, watch } from \"vue\";\nimport userStore from \"@/store/modules/userStore\";\nimport {\n TenantSettings,\n tenantSettingsService,\n} from \"@/app/services/generated/tenantsettingsService\";\nimport type { EnumPurchaseOrderDeliveryDisbursement } from \"@/app/services/generated/enums/enumPurchaseOrderDeliveryDisbursement.generated\";\n\ninterface TenantStoreState {\n companySettings: Readonly;\n bottleDepositSettings: Readonly;\n deliveryNotificationSettings: Readonly;\n kegstarSettings: Readonly;\n accountsLinkDetails: Readonly;\n tenantSettings: Readonly;\n}\n\nconst state = reactive({\n companySettings: new CompanySettings(),\n bottleDepositSettings: new TenantDepositSettings(),\n deliveryNotificationSettings: new DeliveryNotificationSettings(),\n kegstarSettings: new KegstarSettings(),\n accountsLinkDetails: new AccountsLinkDetails(),\n tenantSettings: new TenantSettings(),\n});\n\nasync function refreshStore() {\n [\n state.companySettings,\n state.bottleDepositSettings,\n state.deliveryNotificationSettings,\n state.kegstarSettings,\n state.accountsLinkDetails,\n state.tenantSettings,\n ] = await Promise.all([\n companySettingsService.getCompanySettings(api.tenantId),\n bottleDepositSettingsService.getTenantSettings(api.tenantId),\n deliveryNotificationService.getDeliveryNotificationSettings(api.tenantId),\n kegstarLinkService.getKegstarSettings(api.tenantId),\n accountsLinkService.getAccountsLinkDetails(api.tenantId),\n tenantSettingsService.getTenantSettings(api.tenantId),\n ]);\n}\n\n// We should only need to refresh our store completely when the tenant as a whole has changed, otherwise our individual\n// save calls should catch and individually replace.\nwatch(\n () => userStore.state.tenant,\n async (newTenant) => {\n if (newTenant) {\n await refreshStore();\n }\n },\n { immediate: true }\n);\n\nconst saveDateAndTimeConfiguration = async (\n dateAndTimeConfiguration: DateAndTimeConfiguration\n) => {\n await tenantService.updateDateAndTimeConfiguration(\n api.tenantId,\n dateAndTimeConfiguration\n );\n\n // Stored as part of the tenant, which is in the userStore\n await userStore.refreshStore();\n};\n\nconst saveCurrencyConfiguration = async (\n currencyConfiguration: CurrencyConfiguration\n) => {\n await tenantService.updateCurrencyConfiguration(\n api.tenantId,\n currencyConfiguration\n );\n\n // Stored as part of the tenant, which is in the userStore\n await userStore.refreshStore();\n};\n\nconst saveNumberConfiguration = async (\n numberConfiguration: NumberConfiguration\n) => {\n await tenantService.updateNumberConfiguration(\n api.tenantId,\n numberConfiguration\n );\n\n // Stored as part of the tenant, which is in the userStore\n await userStore.refreshStore();\n};\n\nconst saveLanguageAndCultureConfiguration = async (\n languageAndCultureConfiguration: LanguageAndCultureConfiguration\n) => {\n await tenantService.updateLanguageAndCultureConfiguration(\n api.tenantId,\n languageAndCultureConfiguration\n );\n\n // Stored as part of the tenant, which is in the userStore\n await userStore.refreshStore();\n};\n\nconst saveCompanySettings = async (companySettings: CompanySettings) => {\n await companySettingsService.updateCompanySettings(\n api.tenantId,\n companySettings\n );\n\n state.companySettings = await companySettingsService.getCompanySettings(\n api.tenantId\n );\n};\n\nconst saveTenantBottleDepositSettings = async (\n bottleDepositSettings: TenantDepositSettings\n) => {\n await bottleDepositSettingsService.saveTenantSettings(\n api.tenantId,\n bottleDepositSettings\n );\n\n state.bottleDepositSettings =\n await bottleDepositSettingsService.getTenantSettings(api.tenantId);\n};\n\nconst saveDeliveryNotificationSettings = async (\n deliveryNotificationSettings: DeliveryNotificationSettings\n) => {\n await deliveryNotificationService.saveDeliveryNotificationSettings(\n api.tenantId,\n deliveryNotificationSettings\n );\n\n state.deliveryNotificationSettings =\n await deliveryNotificationService.getDeliveryNotificationSettings(\n api.tenantId\n );\n};\n\nconst saveKegstarSettings = async (kegstarSettings: KegstarSettings) => {\n await kegstarLinkService.saveKegstarSettings(api.tenantId, kegstarSettings);\n\n state.kegstarSettings = await kegstarLinkService.getKegstarSettings(\n api.tenantId\n );\n};\n\nconst setIsMegaBatchesEnabled = async (isMegaBatchesEnabled: boolean) => {\n await tenantSettingsService.setIsMegaBatchesEnabled(\n api.tenantId,\n isMegaBatchesEnabled\n );\n\n state.tenantSettings = await tenantSettingsService.getTenantSettings(\n api.tenantId\n );\n};\n\nconst saveProductBatchDuration = async (productBatchDuration: number) => {\n await tenantSettingsService.setProductBatchDuration(\n api.tenantId,\n productBatchDuration\n );\n\n state.tenantSettings = await tenantSettingsService.getTenantSettings(\n api.tenantId\n );\n};\n\nconst savePurchaseOrderSettings = async (\n poDefaultDeliveryDisbursement: EnumPurchaseOrderDeliveryDisbursement\n) => {\n await tenantSettingsService.savePurchaseOrderSettings(\n api.tenantId,\n poDefaultDeliveryDisbursement\n );\n\n state.tenantSettings = await tenantSettingsService.getTenantSettings(\n api.tenantId\n );\n};\n\nconst saveProductionSettings = async (usesHopAlpha: boolean) => {\n await tenantSettingsService.saveProductionSettings(\n api.tenantId,\n usesHopAlpha\n );\n\n state.tenantSettings = await tenantSettingsService.getTenantSettings(\n api.tenantId\n );\n};\n\nexport default {\n // Using readonly breaks enums as it wraps with proxies.\n state: shallowReadonly(state),\n\n saveDateAndTimeConfiguration,\n saveCurrencyConfiguration,\n saveNumberConfiguration,\n saveCompanySettings,\n saveTenantBottleDepositSettings,\n saveDeliveryNotificationSettings,\n saveKegstarSettings,\n saveLanguageAndCultureConfiguration,\n setIsMegaBatchesEnabled,\n saveProductBatchDuration,\n savePurchaseOrderSettings,\n saveProductionSettings,\n};\n","import { EnumFeatureFlag } from \"@/app/services/generated/enums/enumFeatureFlag.generated\";\nimport type { User } from \"@/app/services/generated/userService\";\nimport userStore from \"@/store/modules/userStore\";\nimport type { DeepReadonly } from \"vue\";\n\nconst supportOnlyFlags = [EnumFeatureFlag.showSupportFunctions];\n\nexport function hasFeatureUsingUserStore(\n featureFlag: EnumFeatureFlag\n): boolean {\n return userStore.state.tenant && userStore.state.user\n ? hasFeature(\n featureFlag,\n userStore.state.tenant?.featureFlags ?? [],\n userStore.state.user\n )\n : false;\n}\nexport function hasFeature(\n featureFlag: EnumFeatureFlag,\n tenantFeatureFlags: readonly EnumFeatureFlag[],\n user: DeepReadonly\n): boolean {\n // Add features from tenant (features we want to enable for customers on a case by case basis)\n let availableFeatures: EnumFeatureFlag[] = [...tenantFeatureFlags];\n\n // Add features granted by email domain (useful for testing of new features by developers).\n if (user.email.includes(\"@premiersystems.com\")) {\n const premierDomainFlags = EnumFeatureFlag.getValues().filter(\n (flag) => !supportOnlyFlags.includes(flag)\n );\n\n availableFeatures.push(...premierDomainFlags);\n }\n\n // Add features granted by support function. A feature flag test for support functions.\n if (user.readOnly.isSupportUser) {\n availableFeatures.push(...supportOnlyFlags);\n }\n\n return availableFeatures.some((ff) => ff.key === featureFlag.key);\n}\n","import { EnumAssemblyType } from \"@/app/services/generated/enums/enumAssemblyType.generated\";\nimport { EnumAssemblyStatus } from \"@/app/services/generated/enums/enumAssemblyStatus.generated\";\nimport Guid from \"@/app/types/common/guid\";\nimport { MenuItem } from \"@/app/ui/navigation/types\";\nimport type { Location } from \"vue-router\";\nimport type { Recipe } from \"@/app/services/generated/recipeService\";\nimport { BrewManError } from \"@/app/errors\";\nimport { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\nimport tenantStore from \"@/store/modules/tenantStore\";\nimport { EnumFeatureFlag } from \"@/app/services/generated/enums/enumFeatureFlag.generated\";\nimport { hasFeatureUsingUserStore } from \"@/app/featureFlags\";\n\nexport const productionMenu = {\n root: \"navigation_production_group\",\n vesselSummary: \"production_vessel_summary\",\n planned: \"production_planned\",\n viewPlannedAssemblies: (): Location => ({ name: productionMenu.planned }),\n inProgress: \"production_in_progress\",\n viewInProgressAssemblies: (): Location => ({\n name: productionMenu.inProgress,\n }),\n complete: \"production_complete\",\n vessel: {\n record: \"production_vessel_record\",\n movementsTab: \"production_vessel_record_movements\",\n viewMovementsTab: (id: Guid): Location => ({\n name: productionMenu.vessel.movementsTab,\n params: { id: id.toString() },\n }),\n maintenanceTab: \"production_vessel_record_maintenance\",\n viewMaintenanceTab: (id: Guid): Location => ({\n name: productionMenu.vessel.maintenanceTab,\n params: { id: id.toString() },\n }),\n },\n vesselMaintenanceRecord: {\n create: \"production_vessel_maintenance_record_create\",\n createLocation: (\n vesselId: string,\n requiredMaintenanceRecipeId?: string\n ): Location => ({\n name: productionMenu.vesselMaintenanceRecord.create,\n params: {\n vesselId,\n },\n query: {\n requiredMaintenanceRecipeId,\n },\n }),\n edit: \"production_vessel_maintenance_record_edit\",\n },\n assembly: {\n create: \"production_packaging_assembly_create\",\n view: \"production_packaging_assembly_edit\",\n viewAssembly: (assemblyId: Guid): Location => ({\n name: productionMenu.assembly.view,\n params: { id: assemblyId.toString() },\n }),\n },\n batch: {\n create: \"production_recipe_assembly_create\",\n view: \"production_recipe_assembly_edit\",\n viewBatch: (batchId: Guid): Location => ({\n name: productionMenu.batch.view,\n params: { id: batchId.toString() },\n }),\n },\n recipe: {\n list: \"production_recipe_list\",\n view: \"production_recipe_view\",\n viewRecipe: (recipeId: Guid): Location => ({\n name: productionMenu.recipe.view,\n params: { id: recipeId.toString() },\n }),\n edit: \"production_recipe_edit\",\n create: \"production_recipe_create\",\n },\n packaging: {\n list: \"production_packaging_list\",\n view: \"production_packaging_view\",\n viewPackaging: (packagingId: Guid): Location => ({\n name: productionMenu.packaging.view,\n params: { id: packagingId.toString() },\n }),\n edit: \"production_packaging_edit\",\n create: \"production_packaging_create\",\n },\n pickingList: \"production_picking_list\",\n agingCasks: {\n caskVessels: {\n list: \"cask_vessels\",\n listLocation: (): Location => ({\n name: productionMenu.agingCasks.caskVessels.list,\n }),\n edit: \"cask_vessels_edit\",\n editLocation: (id: Guid, isEditing: boolean): Location => ({\n name: productionMenu.agingCasks.caskVessels.edit,\n params: {\n id: id.toString(),\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n createLocation: (): Location => ({\n name: productionMenu.agingCasks.caskVessels.edit,\n }),\n },\n },\n vesselScheduling: \"vessel_scheduling\",\n vesselSchedulingLocation: (): Location => ({\n name: productionMenu.vesselScheduling,\n }),\n batchGenealogy: \"production_batch_genealogy\",\n};\n\nexport function getLocationForRecipeOrPackaging(recipeOrPackaging: Recipe) {\n switch (recipeOrPackaging.header.assemblyType) {\n case EnumAssemblyType.materialProduction:\n return productionMenu.recipe.viewRecipe(recipeOrPackaging.header.id);\n\n case EnumAssemblyType.productPackaging:\n return productionMenu.packaging.viewPackaging(\n recipeOrPackaging.header.id\n );\n\n default:\n throw new BrewManError(\n `Unable to find location for recipe or packaging ${recipeOrPackaging.header.id.toString()}`\n );\n }\n}\n\nexport const buildProductionMenuItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n name: productionMenu.root,\n icon: \"local_drink\",\n visible: () =>\n hasFeatureUsingUserStore(EnumFeatureFlag.onlyDev) ||\n (hasPermissionsUsingUserStore([EnumUserPermission.menuProductionView]) &&\n !tenantStore.state.tenantSettings.isMegaBatchesEnabled),\n subMenus: [\n MenuItem.fromOpts({\n name: productionMenu.vesselSummary,\n url: \"/production/vessels\",\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/vessels/VesselSummary.vue\"\n ),\n requiredUserPermissions: [EnumUserPermission.vesselsView],\n }),\n MenuItem.fromOpts({\n name: productionMenu.vesselScheduling,\n url: \"/production/vessel-scheduling\",\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/scheduling/VesselScheduling.vue\"\n ),\n requiredUserPermissions: [EnumUserPermission.batchesEdit],\n }),\n MenuItem.fromOpts({\n name: productionMenu.vessel.record,\n url: \"/production/vessels/:id\",\n visible: false,\n componentProps: (route) => {\n return {\n vesselId: Guid.parseOrEmpty(route.params.id),\n };\n },\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/vessels/VesselRecord.vue\"\n ),\n childRoutes: [\n {\n name: productionMenu.vessel.movementsTab,\n path: \"/production/vessels/:id/movements\",\n component: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/vessels/subcomponents/VesselMovementsTab.vue\"\n ),\n },\n {\n name: productionMenu.vessel.maintenanceTab,\n path: \"/production/vessels/:id/maintenance\",\n component: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/vessels/subcomponents/VesselMaintenanceTab.vue\"\n ),\n },\n ],\n requiredUserPermissions: [EnumUserPermission.vesselsView],\n }),\n MenuItem.fromOpts({\n name: productionMenu.vesselMaintenanceRecord.create,\n url: \"/production/vessels/:vesselId/maintenance/create\",\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/vessels/maintenance/EditVesselMaintenanceRecord.vue\"\n ),\n componentProps: (route) => {\n return {\n vesselId: Guid.tryParse(route.params.vesselId) ?? undefined,\n };\n },\n visible: false,\n requiredUserPermissions: [EnumUserPermission.vesselsView],\n }),\n MenuItem.fromOpts({\n name: productionMenu.vesselMaintenanceRecord.edit,\n url: \"/production/vessels/:vesselId/maintenance/:recordId\",\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/vessels/maintenance/EditVesselMaintenanceRecord.vue\"\n ),\n componentProps: (route) => {\n return {\n vesselId: route.params.vesselId\n ? Guid.parse(route.params.vesselId)\n : undefined,\n recordId: route.params.recordId\n ? Guid.parse(route.params.recordId)\n : undefined,\n };\n },\n visible: false,\n requiredUserPermissions: [EnumUserPermission.vesselsView],\n }),\n MenuItem.fromOpts({\n name: productionMenu.planned,\n url: \"/production/assemblies/planned\",\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/assemblies/ListAssemblies.vue\"\n ),\n componentProps: {\n assemblyStatus: EnumAssemblyStatus.open,\n },\n requiredUserPermissions: [EnumUserPermission.batchesView],\n }),\n MenuItem.fromOpts({\n name: productionMenu.inProgress,\n url: \"/production/assemblies/inprogress\",\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/assemblies/ListAssemblies.vue\"\n ),\n componentProps: {\n assemblyStatus: EnumAssemblyStatus.inProgress,\n },\n requiredUserPermissions: [EnumUserPermission.batchesView],\n }),\n MenuItem.fromOpts({\n name: productionMenu.complete,\n url: \"/production/assemblies/complete\",\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/assemblies/ListAssemblies.vue\"\n ),\n componentProps: {\n assemblyStatus: EnumAssemblyStatus.complete,\n },\n requiredUserPermissions: [EnumUserPermission.batchesView],\n }),\n MenuItem.fromOpts({\n name: productionMenu.batch.create,\n url: \"/production/batches/create\",\n breadcrumbParentName: productionMenu.planned,\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/assemblies/EditAssembly.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n assemblyType: EnumAssemblyType.materialProduction,\n defaultRecipeId:\n Guid.tryParse(route.params.defaultRecipeId) ?? undefined,\n id: undefined,\n }),\n requiredUserPermissions: [EnumUserPermission.batchesView],\n }),\n MenuItem.fromOpts({\n name: productionMenu.batch.view,\n url: \"/production/batches/:id\",\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/assemblies/EditAssembly.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n assemblyType: EnumAssemblyType.materialProduction,\n assemblyIdString: Guid.canParse(route.params.id)\n ? route.params.id // Still pass it as a string due to refresh bug\n : undefined,\n }),\n requiredUserPermissions: [EnumUserPermission.batchesView],\n }),\n MenuItem.fromOpts({\n name: productionMenu.assembly.create,\n url: \"/production/assemblies/create\",\n breadcrumbParentName: productionMenu.planned,\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/assemblies/EditAssembly.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n assemblyType: EnumAssemblyType.productPackaging,\n defaultRecipeId:\n Guid.tryParse(route.params.defaultRecipeId) ?? undefined,\n id: undefined,\n }),\n requiredUserPermissions: [EnumUserPermission.batchesView],\n }),\n MenuItem.fromOpts({\n name: productionMenu.assembly.view,\n url: \"/production/assemblies/:id\",\n breadcrumbParentName: productionMenu.planned,\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/assemblies/EditAssembly.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n assemblyType: EnumAssemblyType.productPackaging,\n assemblyIdString: Guid.canParse(route.params.id)\n ? route.params.id // Still pass it as a string due to refresh bug\n : undefined,\n }),\n requiredUserPermissions: [EnumUserPermission.batchesView],\n }),\n MenuItem.fromOpts({\n name: productionMenu.recipe.list,\n url: \"/production/recipe/list\",\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/recipes/ListRecipes.vue\"\n ),\n componentProps: { assemblyType: EnumAssemblyType.materialProduction },\n requiredUserPermissions: [EnumUserPermission.recipesView],\n }),\n MenuItem.fromOpts({\n name: productionMenu.recipe.create,\n url: \"/production/recipe/create\",\n breadcrumbParentName: productionMenu.recipe.list,\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/recipes/EditRecipe.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n assemblyType: EnumAssemblyType.materialProduction,\n defaultEditing: true,\n id: undefined,\n }),\n requiredUserPermissions: [EnumUserPermission.recipesView],\n }),\n MenuItem.fromOpts({\n name: productionMenu.recipe.view,\n url: \"/production/recipe/:id\",\n breadcrumbParentName: productionMenu.recipe.list,\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/recipes/EditRecipe.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n assemblyType: EnumAssemblyType.materialProduction,\n defaultEditing: false,\n id: Guid.tryParse(route.params.id) ?? undefined,\n }),\n requiredUserPermissions: [EnumUserPermission.recipesView],\n }),\n MenuItem.fromOpts({\n name: productionMenu.recipe.edit,\n url: \"/production/recipe/:id/edit\",\n breadcrumbParentName: productionMenu.recipe.list,\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/recipes/EditRecipe.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n assemblyType: EnumAssemblyType.materialProduction,\n defaultEditing: true,\n id: Guid.tryParse(route.params.id) ?? undefined,\n }),\n requiredUserPermissions: [EnumUserPermission.recipesView],\n }),\n MenuItem.fromOpts({\n name: productionMenu.packaging.list,\n url: \"/production/packaging/list\",\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/recipes/ListRecipes.vue\"\n ),\n componentProps: { assemblyType: EnumAssemblyType.productPackaging },\n requiredUserPermissions: [EnumUserPermission.recipesView],\n }),\n MenuItem.fromOpts({\n name: productionMenu.packaging.create,\n url: \"/production/packaging/create\",\n breadcrumbParentName: productionMenu.packaging.list,\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/recipes/EditRecipe.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n assemblyType: EnumAssemblyType.productPackaging,\n defaultEditing: true,\n id: undefined,\n }),\n requiredUserPermissions: [EnumUserPermission.recipesView],\n }),\n MenuItem.fromOpts({\n name: productionMenu.packaging.view,\n url: \"/production/packaging/:id\",\n breadcrumbParentName: productionMenu.packaging.list,\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/recipes/EditRecipe.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n assemblyType: EnumAssemblyType.productPackaging,\n defaultEditing: false,\n id: Guid.tryParse(route.params.id) ?? undefined,\n }),\n requiredUserPermissions: [EnumUserPermission.recipesView],\n }),\n MenuItem.fromOpts({\n name: productionMenu.packaging.edit,\n url: \"/production/packaging/:id/edit\",\n breadcrumbParentName: productionMenu.packaging.list,\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/recipes/EditRecipe.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n assemblyType: EnumAssemblyType.productPackaging,\n defaultEditing: true,\n id: Guid.tryParse(route.params.id) ?? undefined,\n }),\n requiredUserPermissions: [EnumUserPermission.recipesView],\n }),\n MenuItem.fromOpts({\n name: productionMenu.pickingList,\n url: \"/production/pickingList\",\n view: () =>\n import(\n /* webpackChunkName: \"production\" */ \"@/components/pages/production/pickingList/ProductionPickingList.vue\"\n ),\n componentProps: (route) => ({\n assemblyId: Guid.canParse(route.params.id)\n ? route.params.id\n : undefined,\n }),\n requiredUserPermissions: [EnumUserPermission.batchesView],\n }),\n MenuItem.fromOpts({\n name: productionMenu.agingCasks.caskVessels.list,\n url: \"/production/cask-vessels\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/production/caskVessels/ListCaskVessels.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: productionMenu.agingCasks.caskVessels.edit,\n url: \"/production/cask-vessel/:id?/:mode?\",\n breadcrumbParentName: productionMenu.agingCasks.caskVessels.list,\n view: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/production/caskVessels/EditCaskVessel.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: productionMenu.batchGenealogy,\n url: \"/production/batch-genealogy\",\n view: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/production/genealogy/BatchGenealogy.vue\"\n ),\n }),\n ],\n }),\n];\n","import { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport Guid from \"@/app/types/common/guid\";\nimport { MenuItem } from \"@/app/ui/navigation/types\";\nimport type { Location } from \"vue-router\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\nimport type { EnumSalesVisitAssociatedEntityType } from \"@/app/services/generated/enums/enumSalesVisitAssociatedEntityType.generated\";\nimport { LocalDate } from \"@js-joda/core\";\n\nconst menuNames = {\n orders: {\n list: \"orders_list\",\n view: \"view_order\",\n edit: \"edit_order\",\n create: \"create_order\",\n old_create: \"old-create-order\",\n old_view: \"old-view-order\",\n old_edit: \"old-edit-order\",\n },\n};\n\nexport const salesMenu = {\n root: \"navigation_sales_group\",\n listOrders: () => ({\n name: menuNames.orders.list,\n }),\n viewOrder: (\n id: Guid,\n opts?: { salesVisitLogId?: Guid | null }\n ): Location => ({\n name: menuNames.orders.view,\n params: {\n id: id.toString(),\n salesVisitLogId: opts?.salesVisitLogId?.toString() ?? \"\",\n },\n }),\n createOrder: (\n outletIdParam?: Guid,\n salesVisitLogId?: Guid | null\n ): Location => ({\n name: menuNames.orders.create,\n params: {\n salesVisitLogId: salesVisitLogId?.toString() ?? \"\",\n outletId: outletIdParam?.toString() ?? \"\",\n },\n }),\n editOrder: (\n id: Guid,\n opts?: { salesVisitLogId?: Guid | null }\n ): Location => ({\n name: menuNames.orders.edit,\n params: {\n id: id.toString(),\n salesVisitLogId: opts?.salesVisitLogId?.toString() ?? \"\",\n },\n }),\n oldCredits: {\n create: \"add_lines_to_credit\",\n view: \"view_credit\",\n details: \"credit_details\",\n },\n creditNotes: {\n list: \"credit_notes_list\",\n setup: \"credit_notes_set_up\",\n edit: \"edit_credit_note\",\n create: \"create_credit_note\",\n view: \"view_credit_note\",\n },\n createCreditNote: (opts?: {\n outletId?: Guid | null;\n ullageId?: Guid | null;\n despatchDate?: LocalDate | null;\n }): Location => ({\n name: salesMenu.creditNotes.create,\n params: {\n outletId: opts?.outletId?.toString() ?? \"\",\n ullageId: opts?.ullageId?.toString() ?? \"\",\n despatchDate: opts?.despatchDate?.toString() ?? \"\",\n },\n }),\n viewCreditNote: (id: Guid): Location => ({\n name: salesMenu.creditNotes.view,\n params: { id: id.toString() },\n }),\n editCreditNote: (id: Guid): Location => ({\n name: salesMenu.creditNotes.edit,\n params: { id: id.toString() },\n }),\n oldViewCredit: (id: Guid): Location => ({\n name: salesMenu.oldCredits.view,\n params: { id: id.toString() },\n }),\n listCreditNotes: (): Location => ({ name: salesMenu.creditNotes.list }),\n leads: {\n root: \"leads_leads\",\n pipeline: \"leads_pipeline\",\n list: \"leads_list\",\n edit: \"leads_edit\",\n create: \"leads_create\",\n finder: \"leads_finder\",\n viewLeads: (): Location => ({\n name: salesMenu.leads.list,\n }),\n createLead: () => ({\n name: salesMenu.leads.create,\n }),\n createLeadFromLeadsMap: (opts: {\n businessName: string;\n telephoneNumber: string;\n addressLine1: string;\n addressLine2: string;\n addressLine3: string;\n addressLine4: string;\n addressLine5: string;\n addressLine6: string;\n addressPostcode: string;\n webAddress: string;\n }): Location => ({\n name: salesMenu.leads.create,\n query: opts,\n }),\n viewLead: (leadId: Guid): Location => ({\n name: salesMenu.leads.edit,\n params: {\n id: leadId.toString(),\n },\n }),\n },\n salesVisits: {\n root: \"navigation_sales_visits_group\",\n planned: {\n list: \"planned_sales_visit_list\",\n listLocation: (): Location => ({\n name: salesMenu.salesVisits.planned.list,\n }),\n edit: \"planned_sales_visit_edit\",\n editLocation: (id: Guid, isEditing: boolean): Location => ({\n name: salesMenu.salesVisits.planned.edit,\n params: {\n id: id.toString(),\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n createLocation: (): Location => ({\n name: salesMenu.salesVisits.planned.edit,\n }),\n },\n logs: {\n list: \"sales_visit_log_list\",\n listLocation: (): Location => ({\n name: salesMenu.salesVisits.logs.list,\n }),\n edit: \"sales_visit_log_edit\",\n editLocation: (id: Guid, isEditing: boolean): Location => ({\n name: salesMenu.salesVisits.logs.edit,\n params: {\n id: id.toString(),\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n createLocation: (opts?: {\n entityType: EnumSalesVisitAssociatedEntityType;\n entityId: Guid;\n }): Location => ({\n name: salesMenu.salesVisits.logs.edit,\n query: {\n entityType: opts?.entityType.key.toString(),\n entityId: opts?.entityId?.toString(),\n },\n }),\n },\n visitPlan: \"sales_visit_plan\",\n },\n};\n\nexport const buildSalesMenuItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n name: salesMenu.root,\n icon: \"shopping_basket\",\n visible: () =>\n hasPermissionsUsingUserStore([EnumUserPermission.menuSalesView]),\n subMenus: [\n MenuItem.fromOpts({\n name: menuNames.orders.list,\n icon: \"list\",\n url: \"/orders/list\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"orders\" */ \"@/components/pages/orders/ListOrders.vue\"\n ),\n requiredUserPermissions: [EnumUserPermission.ordersView],\n }),\n MenuItem.fromOpts({\n name: menuNames.orders.create,\n icon: \"create\",\n url: \"/orders/create-order\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"orders\" */ \"@/pages/sales/orders/CreateOrderPage.vue\"\n ),\n componentProps: (route) => ({\n outletId: Guid.tryParse(route.params.outletId),\n salesVisitLogId: Guid.tryParse(route.params.salesVisitLogId),\n }),\n requiredUserPermissions: [EnumUserPermission.ordersEdit],\n visible: false,\n }),\n MenuItem.fromOpts({\n name: menuNames.orders.view,\n url: \"/orders/view-order/:id\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"orders\" */ \"@/pages/sales/orders/ViewOrderPage.vue\"\n ),\n componentProps: (route) => ({\n id: Guid.tryParse(route.params.id),\n salesVisitLogId: Guid.tryParse(route.params.salesVisitLogId),\n }),\n visible: false,\n requiredUserPermissions: [EnumUserPermission.ordersView],\n }),\n MenuItem.fromOpts({\n name: menuNames.orders.edit,\n url: \"/orders/edit-order/:id\",\n breadcrumbParentName: menuNames.orders.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"orders\" */ \"@/pages/sales/orders/EditOrderPage.vue\"\n ),\n visible: false,\n requiredUserPermissions: [EnumUserPermission.ordersEdit],\n componentProps: (route) => ({\n id: Guid.tryParse(route.params.id),\n salesVisitLogId: Guid.tryParse(route.params.salesVisitLogId),\n }),\n }),\n MenuItem.fromOpts({\n name: salesMenu.oldCredits.create,\n url: \"/credit/:id/addLine\",\n breadcrumbParentName: salesMenu.creditNotes.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"credit\" */ \"@/components/pages/orders/creditnotes/AddLine.vue\"\n ),\n visible: false,\n requiredUserPermissions: [EnumUserPermission.creditNotesView],\n }),\n MenuItem.fromOpts({\n name: salesMenu.oldCredits.view,\n url: \"/credit/:id/view\",\n breadcrumbParentName: salesMenu.creditNotes.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"credit\" */ \"@/components/pages/orders/creditnotes/ViewCredit.vue\"\n ),\n visible: false,\n requiredUserPermissions: [EnumUserPermission.creditNotesView],\n }),\n MenuItem.fromOpts({\n name: salesMenu.creditNotes.list,\n icon: \"list\",\n url: \"/creditnotes/list\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"orders\" */ \"@/components/pages/orders/creditnotes/ListCreditNotes.vue\"\n ),\n requiredUserPermissions: [EnumUserPermission.creditNotesView],\n }),\n MenuItem.fromOpts({\n name: salesMenu.creditNotes.setup,\n url: \"/creditnotes/setup\",\n breadcrumbParentName: salesMenu.creditNotes.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"orders\" */ \"@/components/pages/orders/creditnotes/SetupCreditNote.vue\"\n ),\n visible: false,\n requiredUserPermissions: [EnumUserPermission.creditNotesView],\n }),\n MenuItem.fromOpts({\n name: salesMenu.oldCredits.details,\n url: \"/credit/:id/details\",\n breadcrumbParentName: salesMenu.creditNotes.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"orders\" */ \"@/components/pages/orders/creditnotes/CreditDetails.vue\"\n ),\n visible: false,\n requiredUserPermissions: [EnumUserPermission.creditNotesView],\n }),\n MenuItem.fromOpts({\n name: salesMenu.creditNotes.create,\n url: \"/creditnotes/create-credit-note\",\n breadcrumbParentName: salesMenu.creditNotes.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"orders\" */ \"@/pages/sales/creditnotes/CreateCreditNotePage.vue\"\n ),\n componentProps: (route) => ({\n outletId: Guid.tryParse(route.params.outletId),\n ullageId: Guid.tryParse(route.params.ullageId),\n despatchDate: route.params.despatchDate\n ? LocalDate.parse(route.params.despatchDate)\n : null,\n }),\n visible: false,\n requiredUserPermissions: [EnumUserPermission.creditNotesEdit],\n }),\n MenuItem.fromOpts({\n name: salesMenu.creditNotes.edit,\n url: \"/creditnotes/edit-credit-note/:id\",\n breadcrumbParentName: salesMenu.creditNotes.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"orders\" */ \"@/pages/sales/creditnotes/EditCreditNotePage.vue\"\n ),\n componentProps: (route) => ({\n id: Guid.tryParse(route.params.id),\n }),\n visible: false,\n requiredUserPermissions: [EnumUserPermission.creditNotesEdit],\n }),\n MenuItem.fromOpts({\n name: salesMenu.creditNotes.view,\n url: \"/creditnotes/view-credit-note/:id\",\n breadcrumbParentName: salesMenu.creditNotes.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"orders\" */ \"@/pages/sales/creditnotes/ViewCreditNotePage.vue\"\n ),\n componentProps: (route) => ({\n id: Guid.tryParse(route.params.id),\n }),\n visible: false,\n requiredUserPermissions: [EnumUserPermission.creditNotesView],\n }),\n MenuItem.forBranch({\n name: salesMenu.leads.root,\n subMenus: [\n MenuItem.fromOpts({\n name: salesMenu.leads.list,\n url: \"/leads/list\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"orders\" */ \"@/components/pages/orders/leads/ListLeads.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: salesMenu.leads.pipeline,\n url: \"/leads/pipeline\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"orders\" */ \"@/components/pages/orders/leads/LeadsPipeline.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: salesMenu.leads.finder,\n url: \"/leads/map\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"orders\" */ \"@/components/pages/orders/leads/LeadsFinder.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: salesMenu.leads.create,\n url: \"/leads/create\",\n breadcrumbParentName: salesMenu.leads.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"orders\" */ \"@/components/pages/orders/leads/EditLead.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: salesMenu.leads.edit,\n url: \"/leads/view/:id\",\n breadcrumbParentName: salesMenu.leads.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"orders\" */ \"@/components/pages/orders/leads/EditLead.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n id: route.params.id,\n }),\n }),\n ],\n }),\n\n MenuItem.forBranch({\n name: salesMenu.salesVisits.root,\n subMenus: [\n MenuItem.fromOpts({\n name: salesMenu.salesVisits.planned.list,\n url: \"/sales/sales-visits/planned-visits\",\n breadcrumbParentName: salesMenu.salesVisits.root,\n view: () =>\n import(\n /* webpackChunkName: \"sales-visit\" */ \"@/components/pages/orders/salesvisits/ListPlannedSalesVisits.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: salesMenu.salesVisits.planned.edit,\n url: \"/sales/sales-visits/planned-visit/:id?/:mode?\",\n breadcrumbParentName: salesMenu.salesVisits.planned.list,\n view: () =>\n import(\n /* webpackChunkName: \"sales-visit\" */ \"@/components/pages/orders/salesvisits/EditPlannedSalesVisit.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: salesMenu.salesVisits.logs.list,\n url: \"/sales/sales-visits/logs\",\n breadcrumbParentName: salesMenu.salesVisits.root,\n view: () =>\n import(\n /* webpackChunkName: \"sales-visit\" */ \"@/components/pages/orders/salesvisits/ListSalesVisitLogs.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: salesMenu.salesVisits.logs.edit,\n url: \"/sales/sales-visits/log/:id?/:mode?\",\n breadcrumbParentName: salesMenu.salesVisits.logs.list,\n view: () =>\n import(\n /* webpackChunkName: \"sales-visit\" */ \"@/components/pages/orders/salesvisits/EditSalesVisitLog.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: salesMenu.salesVisits.visitPlan,\n url: \"/sales/sales-visits/plan\",\n breadcrumbParentName: salesMenu.salesVisits.root,\n view: () =>\n import(\n /* webpackChunkName: \"sales-visit\" */ \"@/components/pages/orders/salesvisits/SalesVisitPlan.vue\"\n ),\n }),\n ],\n }),\n ],\n }),\n];\n","import type BaseEnumType from \"@/app/services/baseEnumType\";\nimport Key from \"@/app/types/common/key\";\nimport { translate, translateWithParams } from \"@/plugins/i18n\";\n\nclass NounMessages {\n private _translationKey: string;\n constructor(translationKey: string) {\n this._translationKey = translationKey;\n }\n\n Singular() {\n return translate(Key.fromString(this._translationKey));\n }\n\n Plural() {\n return translate(Key.fromString(this._translationKey + \"_plural\"));\n }\n\n SingleOrPlural(count: number) {\n return count === 1 ? this.Singular() : this.Plural();\n }\n\n CopySingle() {\n return translateWithParams(\"noun_copy_noun\", { noun: this.Singular() });\n }\n\n ViewSingle() {\n return translateWithParams(\"noun_view_noun\", { noun: this.Singular() });\n }\n\n DeleteSingle() {\n return translateWithParams(\"noun_delete_noun\", { noun: this.Singular() });\n }\n\n CreateSingle() {\n return translateWithParams(\"noun_create_noun\", { noun: this.Singular() });\n }\n\n HideSingle() {\n return translateWithParams(\"noun_hide_noun\", { noun: this.Singular() });\n }\n\n UnhideSingle() {\n return translateWithParams(\"noun_unhide_noun\", { noun: this.Singular() });\n }\n\n EditSingle() {\n return translateWithParams(\"noun_edit_noun\", { noun: this.Singular() });\n }\n\n OpenSingle() {\n return translateWithParams(\"noun_open_noun\", { noun: this.Singular() });\n }\n\n AddSingle() {\n return translateWithParams(\"noun_add_noun\", { noun: this.Singular() });\n }\n}\n\nexport class EnumNoun implements BaseEnumType {\n private static allValues: EnumNoun[] = []; // make sure this is top-most\n\n public static batch = new EnumNoun(1, \"Batch\", \"enum_noun_batch\");\n public static recipe = new EnumNoun(2, \"Recipe\", \"enum_noun_recipe\");\n public static process = new EnumNoun(3, \"Process\", \"enum_noun_process\");\n public static outletSubType = new EnumNoun(\n 4,\n \"OutletSubType\",\n \"enum_noun_outlet_sub_type\"\n );\n public static order = new EnumNoun(5, \"Order\", \"enum_noun_order\");\n public static outlet = new EnumNoun(6, \"Outlet\", \"enum_noun_outlet\");\n public static group = new EnumNoun(7, \"Group\", \"enum_noun_group\");\n public static dutyReturn = new EnumNoun(\n 8,\n \"DutyReturn\",\n \"enum_noun_duty_return\"\n );\n public static credit = new EnumNoun(9, \"Credit\", \"enum_noun_credit\");\n public static pricingCategory = new EnumNoun(\n 10,\n \"PricingCategory\",\n \"enum_noun_pricing_category\"\n );\n public static product = new EnumNoun(11, \"Product\", \"enum_noun_product\");\n public static discount = new EnumNoun(12, \"Discount\", \"enum_noun_discount\");\n public static pallet = new EnumNoun(13, \"Pallet\", \"enum_noun_pallet\");\n public static item = new EnumNoun(14, \"Item\", \"enum_noun_item\");\n public static ullage = new EnumNoun(15, \"Ullage\", \"enum_noun_ullage\");\n\n public static stockTransfer = new EnumNoun(\n 16,\n \"StockTransfer\",\n \"enum_noun_stock_transfer\"\n );\n\n public static stockBatch = new EnumNoun(\n 17,\n \"StockBatch\",\n \"enum_noun_stock_batch\"\n );\n\n public static contact = new EnumNoun(18, \"Contact\", \"enum_noun_contact\");\n\n public key: number;\n public value: string;\n public translationKey: string;\n\n private constructor(key: number, value: string, translationKey: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumNoun.allValues.push(this);\n }\n\n public static getValues(): EnumNoun[] {\n return EnumNoun.allValues;\n }\n\n public static getByKey(key: number): EnumNoun {\n const found = EnumNoun.allValues.find((e) => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumNoun - Key not found: ${key}`);\n }\n\n return found;\n }\n\n get messages(): NounMessages {\n return new NounMessages(this.translationKey);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { MenuItem } from \"@/app/ui/navigation/types\";\nimport type { Location } from \"vue-router\";\nimport type { Dictionary } from \"vue-router/types/router\";\nimport { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\nimport { EnumNoun } from \"@/app/types/common/enumNoun\";\n\nexport type CreateProductType = \"product\" | \"auto-assembled\";\n\nexport const stockMenu = {\n root: \"navigation_stock_group\",\n materials: {\n list: \"material_list\",\n inStock: \"materials_in_stock\",\n create: \"create_material\",\n createLocation: (): Location => ({ name: stockMenu.materials.create }),\n duplicateMaterial: (materialId: Guid): Location => ({\n name: stockMenu.materials.create,\n query: {\n duplicate_from_material_id: materialId.toString(),\n },\n }),\n },\n products: {\n list: \"product_list\",\n inStock: \"products_in_stock\",\n create: \"create_product\",\n createLocation: (\n stockItemType: CreateProductType = \"product\"\n ): Location => ({\n name: stockMenu.products.create,\n params: { stockItemType },\n }),\n duplicateProduct: (productId: Guid): Location => ({\n name: stockMenu.products.create,\n query: {\n duplicate_from_product_id: productId.toString(),\n },\n }),\n },\n autoAssembled: {\n stock: \"auto_assembled_in_stock\",\n },\n productBrands: {\n list: \"product_brands\",\n listLocation: (): Location => ({\n name: stockMenu.productBrands.list,\n }),\n edit: \"stock_product_brands_edit\",\n editLocation: (id: Guid, isEditing: boolean): Location => ({\n name: stockMenu.productBrands.edit,\n params: {\n id: id.toString(),\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n createLocation: (): Location => ({\n name: stockMenu.productBrands.edit,\n }),\n },\n purchaseOrdering: {\n list: \"purchase_order_list\",\n listPurchaseOrders: (): Location => ({\n name: stockMenu.purchaseOrdering.list,\n }),\n create: \"purchase_order_create\",\n edit: \"purchase_order_edit\",\n viewPurchaseOrder: (id: Guid): Location => ({\n name: stockMenu.purchaseOrdering.edit,\n params: { id: id.toString() },\n }),\n },\n\n stockMovements: {\n root: \"navigation_stock_movements_group\",\n stockTransfer: {\n list: \"stock_transfer_list\",\n create: \"stock_transfer_create\",\n edit: \"stock_transfer_edit\",\n listTransfers: (): Location => ({\n name: stockMenu.stockMovements.stockTransfer.list,\n }),\n createStockTransfer: (\n fromStockLocationId?: Guid,\n stockItemId?: Guid,\n batch?: string\n ): Location => {\n let params: Dictionary = {};\n\n if (fromStockLocationId) {\n params.fromStockLocationId = fromStockLocationId.toString();\n }\n\n if (stockItemId) {\n params.stockItemId = stockItemId.toString();\n }\n\n if (batch) {\n params.batch = batch;\n }\n\n return {\n name: stockMenu.stockMovements.stockTransfer.edit,\n params,\n };\n },\n editStockTransfer: (id: Guid, isEditing: boolean): Location => ({\n name: stockMenu.stockMovements.stockTransfer.edit,\n params: { id: id.toString(), mode: isEditing ? \"edit\" : \"view\" },\n }),\n },\n stockAdjustment: {\n list: \"stock_adjustment_list\",\n listLocation: (): Location => ({\n name: stockMenu.stockMovements.stockAdjustment.list,\n }),\n view: \"stock_adjustment_view\",\n create: \"stock_adjustment_create\",\n createLocation: (\n stockLocationId?: Guid,\n stockItemId?: Guid\n ): Location => {\n let params: Dictionary = {};\n if (stockLocationId) {\n params.location = stockLocationId?.toString();\n }\n if (stockItemId) {\n params.stockItemId = stockItemId?.toString();\n }\n return {\n name: stockMenu.stockMovements.stockAdjustment.create,\n params,\n };\n },\n viewStockAdjustment: (id: Guid): Location => ({\n name: stockMenu.stockMovements.stockAdjustment.view,\n params: { id: id.toString() },\n }),\n },\n },\n stock: {\n view: \"stock_details\",\n viewLocation: (stockItemId: Guid): Location => ({\n name: \"stock_details\",\n params: {\n id: stockItemId.toString(),\n },\n }),\n pricing: \"stock_pricing\",\n labelling: \"stock_labelling\",\n documents: \"stcok_item_documents\",\n openOrders: \"stock_open_orders\",\n tradePortal: \"stock_trade_portal\",\n },\n stockTake: {\n list: \"stock_takes\",\n create: \"stock_take_create\",\n view: \"stock_take_view\",\n viewLocation: (stockItemId: Guid): Location => ({\n name: \"stock_take_view\",\n params: {\n id: stockItemId.toString(),\n },\n }),\n },\n stockReplenishment: \"stock_replenishment\",\n viewStockReplenishment: (): Location => ({\n name: stockMenu.stockReplenishment,\n }),\n stockAudit: \"stock_audit\",\n viewStockAudit: (opts?: {\n stockItemId?: Guid;\n stockLocationId?: Guid;\n }): Location => ({\n name: stockMenu.stockAudit,\n query: {\n stockItemId: opts?.stockItemId?.toString(),\n stockLocationId: opts?.stockLocationId?.toString(),\n },\n }),\n stockRequirement: \"stock_requirement\",\n stockFutureTransactions: \"stock_future_transactions\",\n viewFutureStockTransaction: (\n stockItemId: Guid,\n stockLocationId: Guid\n ): Location => ({\n name: stockMenu.stockFutureTransactions,\n query: {\n item: stockItemId.toString(),\n location: stockLocationId.toString(),\n },\n }),\n historicStock: \"historic_stock\",\n stockBatches: \"stock_batches\",\n stockBatchesList: (): Location => ({ name: stockMenu.stockBatches }),\n};\n\nexport const buildStockMenuItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n name: stockMenu.root,\n icon: \"local_bar\",\n visible: () =>\n hasPermissionsUsingUserStore([EnumUserPermission.menuStockView]),\n subMenus: [\n // Materials\n MenuItem.fromOpts({\n name: stockMenu.materials.list,\n url: \"/stock/materials/list\",\n view: () =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/items/ListMaterials\"\n ),\n }),\n MenuItem.fromOpts({\n name: stockMenu.materials.inStock,\n icon: \"create\",\n url: \"/stock/materials_in_stock\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/stockenquiry/MaterialsInStock.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: stockMenu.materials.create,\n url: \"/stock/materials/create\",\n breadcrumbParentName: stockMenu.materials.list,\n view: () =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/create/CreateMaterialWizard.vue\"\n ),\n visible: false,\n }),\n // Products\n MenuItem.fromOpts({\n name: stockMenu.products.list,\n url: \"/stock/products/list\",\n view: () =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/items/ListProducts\"\n ),\n }),\n MenuItem.fromOpts({\n name: stockMenu.products.inStock,\n icon: \"create\",\n url: \"/stock/products_in_stock\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/stockenquiry/ProductsInStock.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: stockMenu.autoAssembled.stock,\n icon: \"create\",\n url: \"/stock/auto_assembled_stock\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/stockenquiry/AutoAssembledStock.vue\"\n ),\n }),\n\n MenuItem.fromOpts({\n name: stockMenu.productBrands.list,\n url: \"/stock/productbrands\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/brands/ListProductBrands\"\n ),\n }),\n MenuItem.fromOpts({\n name: stockMenu.productBrands.edit,\n url: \"/stock/productbrands/:id?/:mode?\",\n breadcrumbParentName: stockMenu.productBrands.list,\n view: () =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/brands/EditProductBrands.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: stockMenu.purchaseOrdering.list,\n url: \"/purchaseorders\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"sales\" */ \"@/components/pages/purchasing/ListPurchaseOrders.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: stockMenu.purchaseOrdering.create,\n url: \"/purchaseorders/create\",\n breadcrumbParentName: stockMenu.purchaseOrdering.list,\n view: () =>\n import(\n /* webpackChunkName: \"sales\" */ \"@/components/pages/purchasing/EditPurchaseOrder.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: stockMenu.purchaseOrdering.edit,\n url: \"/purchaseorders/:id\",\n breadcrumbParentName: stockMenu.purchaseOrdering.list,\n view: () =>\n import(\n /* webpackChunkName: \"sales\" */ \"@/components/pages/purchasing/EditPurchaseOrder.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n purchaseOrderIdString: route.params.id,\n }),\n }),\n MenuItem.fromOpts({\n name: stockMenu.stockReplenishment,\n url: \"/stockreplenishment\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/stockreplenishment/StockReplenishmentPage.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: stockMenu.stockRequirement,\n url: \"/stockrequirement\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"reporting\" */ \"@/components/pages/stock/stockrequirement/StockRequirement.vue\"\n ),\n }),\n MenuItem.forBranch({\n name: stockMenu.stockMovements.root,\n subMenus: [\n MenuItem.fromOpts({\n name: stockMenu.stockMovements.stockTransfer.list,\n url: \"/stock/stocktransfers/list\",\n breadcrumbParentName: stockMenu.stockMovements.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/pages/stock/stocktransfers/StockTransfersListPage.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: stockMenu.products.create,\n url: \"/stock/products/create\",\n breadcrumbParentName: stockMenu.products.list,\n view: () =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/create/CreateProductWizard.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n stockItemType: route.params.stockItemType,\n }),\n }),\n MenuItem.fromOpts({\n name: stockMenu.stockMovements.stockTransfer.edit,\n url: \"/stock/stocktransfer/:id?/:mode?\",\n breadcrumbParentName: stockMenu.stockMovements.stockTransfer.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/transfer/EditTransfer.vue\"\n ),\n visible: false,\n componentProps: (route) => {\n return {\n fromStockLocationId: route.params.fromStockLocationId,\n stockItemId: route.params.stockItemId,\n batch: route.params.batch,\n };\n },\n }),\n MenuItem.fromOpts({\n name: stockMenu.stockMovements.stockAdjustment.list,\n url: \"/stock/adjustments/list\",\n breadcrumbParentName: stockMenu.stockMovements.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/stockadjustment/ListStockAdjustments.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: stockMenu.stockMovements.stockAdjustment.create,\n icon: \"\",\n url: \"/stock/adjustments/create\",\n breadcrumbParentName: stockMenu.stockMovements.stockAdjustment.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/stockadjustment/EditStockAdjustment.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: stockMenu.stockMovements.stockAdjustment.view,\n icon: \"\",\n url: \"/stock/adjustments/:id\",\n breadcrumbParentName: stockMenu.stockMovements.stockAdjustment.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/stockadjustment/EditStockAdjustment.vue\"\n ),\n visible: false,\n }),\n ],\n }),\n\n MenuItem.fromOpts({\n name: \"\",\n url: \"/stock/:id\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/items/ViewStock.vue\"\n ),\n visible: false,\n childRoutes: [\n {\n name: stockMenu.stock.view,\n path: \"\",\n component: () =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/viewstock/StockDetailsTab.vue\"\n ),\n },\n {\n name: stockMenu.stock.pricing,\n path: \"pricing\",\n component: () =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/viewstock/StockPricingTab.vue\"\n ),\n },\n {\n name: stockMenu.stock.labelling,\n path: \"labelling\",\n component: () =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/viewstock/StockLabellingTab.vue\"\n ),\n },\n {\n name: stockMenu.stock.documents,\n path: \"documents\",\n component: () =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/viewstock/StockDocumentStoreTab.vue\"\n ),\n },\n {\n name: stockMenu.stock.openOrders,\n path: \"openorders\",\n component: () =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/viewstock/StockOpenOrdersTab.vue\"\n ),\n },\n {\n name: stockMenu.stock.tradePortal,\n path: \"trade-portal\",\n component: () =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/pages/trade_portal/item_settings/TradePortalItemTab.vue\"\n ),\n },\n ],\n }),\n\n MenuItem.fromOpts({\n name: stockMenu.stockTake.list,\n url: \"/stocktake\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/stocktake/ListStockTake.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: stockMenu.stockTake.create,\n url: \"/stocktake/create/:id?\",\n breadcrumbParentName: stockMenu.stockTake.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/stocktake/CreateStockTake.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n stockTakeId: Guid.tryParse(route.params.id) ?? undefined,\n }),\n }),\n MenuItem.fromOpts({\n name: stockMenu.stockTake.view,\n url: \"/stocktake/:id\",\n breadcrumbParentName: stockMenu.stockTake.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/stocktake/ViewStockTake.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n stockTakeId: Guid.tryParse(route.params.id) ?? undefined,\n }),\n }),\n MenuItem.fromOpts({\n name: stockMenu.stockAudit,\n url: \"/reporting/stockaudit\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"reporting\" */ \"@/components/pages/reporting/StockAuditReport.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: stockMenu.stockFutureTransactions,\n url: \"/futuretransactions\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/items/ListFutureTransactions\"\n ),\n }),\n MenuItem.fromOpts({\n name: stockMenu.historicStock,\n url: \"/historic-stock\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/components/pages/stock/historicstock/HistoricStockLevelPage.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: stockMenu.stockBatches,\n label: EnumNoun.stockBatch.messages.Plural(),\n url: \"/stockbatches/stockbatchlist\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"stock\" */ \"@/pages/stock/stockbatches/StockBatchListPage.vue\"\n ),\n }),\n ],\n }),\n];\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumAlcoholType } from \"./enums/enumAlcoholType.generated\";\nimport { EnumStandardOrder } from \"./enums/enumStandardOrder.generated\";\nimport { EnumStockAdjustDutyImplication } from \"./enums/enumStockAdjustDutyImplication.generated\";\n\n// Model Objects\n\nexport class AlcoholDutyFieldRequirement extends ModelObject {\n\n public show: boolean = false;\n public required: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.show = jsonSerializedObject.show;\n this.required = jsonSerializedObject.required;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.show = this.show;\n toRet.required = this.required;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class BooleanFieldRequirement extends ModelObject {\n\n public show: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.show = jsonSerializedObject.show;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.show = this.show;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class AlcoholDutyHeaderRequirements extends ModelObject {\n\n public standardOrderType: AlcoholDutyFieldRequirement = new AlcoholDutyFieldRequirement();\n public germanBeerDutyMovementType: AlcoholDutyFieldRequirement = new AlcoholDutyFieldRequirement();\n public allowedOrderTypes: EnumStandardOrder[] = [];\n public liquorLicenceNumber: AlcoholDutyFieldRequirement = new AlcoholDutyFieldRequirement();\n public eireDutyMovementType: AlcoholDutyFieldRequirement = new AlcoholDutyFieldRequirement();\n public allowDraughtRelief: BooleanFieldRequirement = new BooleanFieldRequirement();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.standardOrderType = new AlcoholDutyFieldRequirement(jsonSerializedObject.standardOrderType);\n this.germanBeerDutyMovementType = new AlcoholDutyFieldRequirement(jsonSerializedObject.germanBeerDutyMovementType);\n this.allowedOrderTypes = jsonSerializedObject.allowedOrderTypes.map((v: any) => EnumStandardOrder.getByValue(v));\n this.liquorLicenceNumber = new AlcoholDutyFieldRequirement(jsonSerializedObject.liquorLicenceNumber);\n this.eireDutyMovementType = new AlcoholDutyFieldRequirement(jsonSerializedObject.eireDutyMovementType);\n this.allowDraughtRelief = new BooleanFieldRequirement(jsonSerializedObject.allowDraughtRelief);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.standardOrderType = this.standardOrderType.toJsonSerializedObject();\n toRet.germanBeerDutyMovementType = this.germanBeerDutyMovementType.toJsonSerializedObject();\n toRet.allowedOrderTypes = this.allowedOrderTypes.map(v => v.value);\n toRet.liquorLicenceNumber = this.liquorLicenceNumber.toJsonSerializedObject();\n toRet.eireDutyMovementType = this.eireDutyMovementType.toJsonSerializedObject();\n toRet.allowDraughtRelief = this.allowDraughtRelief.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"standardOrderType\", rule: (v: any) => !!v || \"standardOrderType is required\"},\n {field: \"standardOrderType\", rule: (v: any) => v.validate()},\n {field: \"germanBeerDutyMovementType\", rule: (v: any) => !!v || \"germanBeerDutyMovementType is required\"},\n {field: \"germanBeerDutyMovementType\", rule: (v: any) => v.validate()},\n {field: \"liquorLicenceNumber\", rule: (v: any) => !!v || \"liquorLicenceNumber is required\"},\n {field: \"liquorLicenceNumber\", rule: (v: any) => v.validate()},\n {field: \"eireDutyMovementType\", rule: (v: any) => !!v || \"eireDutyMovementType is required\"},\n {field: \"eireDutyMovementType\", rule: (v: any) => v.validate()},\n {field: \"allowDraughtRelief\", rule: (v: any) => !!v || \"allowDraughtRelief is required\"},\n {field: \"allowDraughtRelief\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class AlcoholDutyLineRequirements extends ModelObject {\n\n public abv: AlcoholDutyFieldRequirement = new AlcoholDutyFieldRequirement();\n public manufacturer: AlcoholDutyFieldRequirement = new AlcoholDutyFieldRequirement();\n public unitDutiableLitres: AlcoholDutyFieldRequirement = new AlcoholDutyFieldRequirement();\n public plato: AlcoholDutyFieldRequirement = new AlcoholDutyFieldRequirement();\n public germanBeerDutyProductType: AlcoholDutyFieldRequirement = new AlcoholDutyFieldRequirement();\n public alcoholType: EnumAlcoholType = EnumAlcoholType.none;\n public isBrewedForPersonalUse: BooleanFieldRequirement = new BooleanFieldRequirement();\n public isDesignedForPump: BooleanFieldRequirement = new BooleanFieldRequirement();\n public finalUnitLitres: AlcoholDutyFieldRequirement = new AlcoholDutyFieldRequirement();\n public spiritDutyExemptionReason: AlcoholDutyFieldRequirement = new AlcoholDutyFieldRequirement();\n public packageType: AlcoholDutyFieldRequirement = new AlcoholDutyFieldRequirement();\n public dateOfProductionDutyRate: AlcoholDutyFieldRequirement = new AlcoholDutyFieldRequirement();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.abv = new AlcoholDutyFieldRequirement(jsonSerializedObject.abv);\n this.manufacturer = new AlcoholDutyFieldRequirement(jsonSerializedObject.manufacturer);\n this.unitDutiableLitres = new AlcoholDutyFieldRequirement(jsonSerializedObject.unitDutiableLitres);\n this.plato = new AlcoholDutyFieldRequirement(jsonSerializedObject.plato);\n this.germanBeerDutyProductType = new AlcoholDutyFieldRequirement(jsonSerializedObject.germanBeerDutyProductType);\n this.alcoholType = EnumAlcoholType.getByValue(jsonSerializedObject.alcoholType, this.alcoholType);\n this.isBrewedForPersonalUse = new BooleanFieldRequirement(jsonSerializedObject.isBrewedForPersonalUse);\n this.isDesignedForPump = new BooleanFieldRequirement(jsonSerializedObject.isDesignedForPump);\n this.finalUnitLitres = new AlcoholDutyFieldRequirement(jsonSerializedObject.finalUnitLitres);\n this.spiritDutyExemptionReason = new AlcoholDutyFieldRequirement(jsonSerializedObject.spiritDutyExemptionReason);\n this.packageType = new AlcoholDutyFieldRequirement(jsonSerializedObject.packageType);\n this.dateOfProductionDutyRate = new AlcoholDutyFieldRequirement(jsonSerializedObject.dateOfProductionDutyRate);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.abv = this.abv.toJsonSerializedObject();\n toRet.manufacturer = this.manufacturer.toJsonSerializedObject();\n toRet.unitDutiableLitres = this.unitDutiableLitres.toJsonSerializedObject();\n toRet.plato = this.plato.toJsonSerializedObject();\n toRet.germanBeerDutyProductType = this.germanBeerDutyProductType.toJsonSerializedObject();\n toRet.alcoholType = this.alcoholType.value;\n toRet.isBrewedForPersonalUse = this.isBrewedForPersonalUse.toJsonSerializedObject();\n toRet.isDesignedForPump = this.isDesignedForPump.toJsonSerializedObject();\n toRet.finalUnitLitres = this.finalUnitLitres.toJsonSerializedObject();\n toRet.spiritDutyExemptionReason = this.spiritDutyExemptionReason.toJsonSerializedObject();\n toRet.packageType = this.packageType.toJsonSerializedObject();\n toRet.dateOfProductionDutyRate = this.dateOfProductionDutyRate.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"abv\", rule: (v: any) => !!v || \"abv is required\"},\n {field: \"abv\", rule: (v: any) => v.validate()},\n {field: \"manufacturer\", rule: (v: any) => !!v || \"manufacturer is required\"},\n {field: \"manufacturer\", rule: (v: any) => v.validate()},\n {field: \"unitDutiableLitres\", rule: (v: any) => !!v || \"unitDutiableLitres is required\"},\n {field: \"unitDutiableLitres\", rule: (v: any) => v.validate()},\n {field: \"plato\", rule: (v: any) => !!v || \"plato is required\"},\n {field: \"plato\", rule: (v: any) => v.validate()},\n {field: \"germanBeerDutyProductType\", rule: (v: any) => !!v || \"germanBeerDutyProductType is required\"},\n {field: \"germanBeerDutyProductType\", rule: (v: any) => v.validate()},\n {field: \"isBrewedForPersonalUse\", rule: (v: any) => !!v || \"isBrewedForPersonalUse is required\"},\n {field: \"isBrewedForPersonalUse\", rule: (v: any) => v.validate()},\n {field: \"isDesignedForPump\", rule: (v: any) => !!v || \"isDesignedForPump is required\"},\n {field: \"isDesignedForPump\", rule: (v: any) => v.validate()},\n {field: \"finalUnitLitres\", rule: (v: any) => !!v || \"finalUnitLitres is required\"},\n {field: \"finalUnitLitres\", rule: (v: any) => v.validate()},\n {field: \"spiritDutyExemptionReason\", rule: (v: any) => !!v || \"spiritDutyExemptionReason is required\"},\n {field: \"spiritDutyExemptionReason\", rule: (v: any) => v.validate()},\n {field: \"packageType\", rule: (v: any) => !!v || \"packageType is required\"},\n {field: \"packageType\", rule: (v: any) => v.validate()},\n {field: \"dateOfProductionDutyRate\", rule: (v: any) => !!v || \"dateOfProductionDutyRate is required\"},\n {field: \"dateOfProductionDutyRate\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class StockLocationDutyRequirements extends ModelObject {\n\n public warehouseTaxCode: AlcoholDutyFieldRequirement = new AlcoholDutyFieldRequirement();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.warehouseTaxCode = new AlcoholDutyFieldRequirement(jsonSerializedObject.warehouseTaxCode);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.warehouseTaxCode = this.warehouseTaxCode.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"warehouseTaxCode\", rule: (v: any) => !!v || \"warehouseTaxCode is required\"},\n {field: \"warehouseTaxCode\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class StockLocationsDutyRequirements extends ModelObject {\n\n public bondedRequirements: StockLocationDutyRequirements = new StockLocationDutyRequirements();\n public nonBondedRequirements: StockLocationDutyRequirements = new StockLocationDutyRequirements();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.bondedRequirements = new StockLocationDutyRequirements(jsonSerializedObject.bondedRequirements);\n this.nonBondedRequirements = new StockLocationDutyRequirements(jsonSerializedObject.nonBondedRequirements);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.bondedRequirements = this.bondedRequirements.toJsonSerializedObject();\n toRet.nonBondedRequirements = this.nonBondedRequirements.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"bondedRequirements\", rule: (v: any) => !!v || \"bondedRequirements is required\"},\n {field: \"bondedRequirements\", rule: (v: any) => v.validate()},\n {field: \"nonBondedRequirements\", rule: (v: any) => !!v || \"nonBondedRequirements is required\"},\n {field: \"nonBondedRequirements\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class StockAdjustmentDutyRequirements extends ModelObject {\n\n public allowedDutyImplications: EnumStockAdjustDutyImplication[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.allowedDutyImplications = jsonSerializedObject.allowedDutyImplications.map((v: any) => EnumStockAdjustDutyImplication.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.allowedDutyImplications = this.allowedDutyImplications.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class PackageTypeDutyRequirements extends ModelObject {\n\n public categoryType: AlcoholDutyFieldRequirement = new AlcoholDutyFieldRequirement();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.categoryType = new AlcoholDutyFieldRequirement(jsonSerializedObject.categoryType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.categoryType = this.categoryType.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"categoryType\", rule: (v: any) => !!v || \"categoryType is required\"},\n {field: \"categoryType\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetAllowedAlcoholTypesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllowedAlcoholTypesResponse extends ModelObject {\n\n public allowedAlcoholTypes: EnumAlcoholType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.allowedAlcoholTypes = jsonSerializedObject.allowedAlcoholTypes.map((v: any) => EnumAlcoholType.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.allowedAlcoholTypes = this.allowedAlcoholTypes.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GetAlcoholDutyHeaderRequirementsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAlcoholDutyHeaderRequirementsResponse extends ModelObject {\n\n public requirements: AlcoholDutyHeaderRequirements = new AlcoholDutyHeaderRequirements();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.requirements = new AlcoholDutyHeaderRequirements(jsonSerializedObject.requirements);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.requirements = this.requirements.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"requirements\", rule: (v: any) => !!v || \"requirements is required\"},\n {field: \"requirements\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetAlcoholDutyLineRequirementsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public alcoholType: EnumAlcoholType = EnumAlcoholType.none;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.alcoholType = EnumAlcoholType.getByValue(jsonSerializedObject.alcoholType, this.alcoholType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.alcoholType = this.alcoholType.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAlcoholDutyLineRequirementsResponse extends ModelObject {\n\n public requirements: AlcoholDutyLineRequirements = new AlcoholDutyLineRequirements();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.requirements = new AlcoholDutyLineRequirements(jsonSerializedObject.requirements);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.requirements = this.requirements.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"requirements\", rule: (v: any) => !!v || \"requirements is required\"},\n {field: \"requirements\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetStockLocationDutyRequirementsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetStockLocationDutyRequirementsResponse extends ModelObject {\n\n public requirements: StockLocationsDutyRequirements = new StockLocationsDutyRequirements();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.requirements = new StockLocationsDutyRequirements(jsonSerializedObject.requirements);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.requirements = this.requirements.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"requirements\", rule: (v: any) => !!v || \"requirements is required\"},\n {field: \"requirements\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetAlcoholDutyLineRequirementsForTypesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public alcoholTypes: readonly EnumAlcoholType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.alcoholTypes = jsonSerializedObject.alcoholTypes.map((v: any) => EnumAlcoholType.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.alcoholTypes = this.alcoholTypes.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAlcoholDutyLineRequirementsForTypesResponse extends ModelObject {\n\n public requirements: AlcoholDutyLineRequirements[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.requirements = jsonSerializedObject.requirements.map((v: any) => new AlcoholDutyLineRequirements(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.requirements = this.requirements.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"requirements\", rule: (v: any) => !!v || \"requirements is required\"},\n {field: \"requirements\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AlcoholDutyLineRequirements[]).reduce((acc: Array, curr: AlcoholDutyLineRequirements) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class IsTransferOfAlcoholFromNonBondedToBondedAllowedRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class IsTransferOfAlcoholFromNonBondedToBondedAllowedResponse extends ModelObject {\n\n public isAllowed: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.isAllowed = jsonSerializedObject.isAllowed;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.isAllowed = this.isAllowed;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class ArePurchaseOrdersReportedForDutyRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class ArePurchaseOrdersReportedForDutyResponse extends ModelObject {\n\n public purchaseOrdersAreReportedForDuty: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.purchaseOrdersAreReportedForDuty = jsonSerializedObject.purchaseOrdersAreReportedForDuty;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.purchaseOrdersAreReportedForDuty = this.purchaseOrdersAreReportedForDuty;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class AreDutySuspendedSalesVatExemptRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public alcoholType: EnumAlcoholType = EnumAlcoholType.none;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.alcoholType = EnumAlcoholType.getByValue(jsonSerializedObject.alcoholType, this.alcoholType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.alcoholType = this.alcoholType.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class AreDutySuspendedSalesVatExemptResponse extends ModelObject {\n\n public dutySuspendedSalesAreVatExempt: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.dutySuspendedSalesAreVatExempt = jsonSerializedObject.dutySuspendedSalesAreVatExempt;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.dutySuspendedSalesAreVatExempt = this.dutySuspendedSalesAreVatExempt;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GetStockAdjustmentDutyRequirementsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetStockAdjustmentDutyRequirementsResponse extends ModelObject {\n\n public requirements: StockAdjustmentDutyRequirements = new StockAdjustmentDutyRequirements();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.requirements = new StockAdjustmentDutyRequirements(jsonSerializedObject.requirements);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.requirements = this.requirements.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"requirements\", rule: (v: any) => !!v || \"requirements is required\"},\n {field: \"requirements\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetPackageTypeDutyRequirementsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetPackageTypeDutyRequirementsResponse extends ModelObject {\n\n public requirements: PackageTypeDutyRequirements = new PackageTypeDutyRequirements();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.requirements = new PackageTypeDutyRequirements(jsonSerializedObject.requirements);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.requirements = this.requirements.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"requirements\", rule: (v: any) => !!v || \"requirements is required\"},\n {field: \"requirements\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class DutyRulesService extends ServiceBase {\n\n public async getAllowedAlcoholTypes(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllowedAlcoholTypesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllowedAlcoholTypesResponse(response).allowedAlcoholTypes;\n return this.makeJsonRequest(\"dutyRules/v1/getAllowedAlcoholTypes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAlcoholDutyHeaderRequirements(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAlcoholDutyHeaderRequirementsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAlcoholDutyHeaderRequirementsResponse(response).requirements;\n return this.makeJsonRequest(\"dutyRules/v1/getAlcoholDutyHeaderRequirements\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAlcoholDutyLineRequirements(tenantId: Guid, alcoholType: EnumAlcoholType, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAlcoholDutyLineRequirementsRequest();\n req.tenantId = tenantId;\n req.alcoholType = alcoholType;\n const extractor = (response:any) => new GetAlcoholDutyLineRequirementsResponse(response).requirements;\n return this.makeJsonRequest(\"dutyRules/v1/getAlcoholDutyLineRequirements\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getStockLocationDutyRequirements(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetStockLocationDutyRequirementsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetStockLocationDutyRequirementsResponse(response).requirements;\n return this.makeJsonRequest(\"dutyRules/v1/getStockLocationDutyRequirements\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAlcoholDutyLineRequirementsForTypes(tenantId: Guid, alcoholTypes: readonly EnumAlcoholType[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAlcoholDutyLineRequirementsForTypesRequest();\n req.tenantId = tenantId;\n req.alcoholTypes = alcoholTypes;\n const extractor = (response:any) => new GetAlcoholDutyLineRequirementsForTypesResponse(response).requirements;\n return this.makeJsonRequest(\"dutyRules/v1/getAlcoholDutyLineRequirementsForTypes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async isTransferOfAlcoholFromNonBondedToBondedAllowed(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new IsTransferOfAlcoholFromNonBondedToBondedAllowedRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new IsTransferOfAlcoholFromNonBondedToBondedAllowedResponse(response).isAllowed;\n return this.makeJsonRequest(\"dutyRules/v1/isTransferOfAlcoholFromNonBondedToBondedAllowed\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async arePurchaseOrdersReportedForDuty(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new ArePurchaseOrdersReportedForDutyRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new ArePurchaseOrdersReportedForDutyResponse(response).purchaseOrdersAreReportedForDuty;\n return this.makeJsonRequest(\"dutyRules/v1/arePurchaseOrdersReportedForDuty\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async areDutySuspendedSalesVatExempt(tenantId: Guid, alcoholType: EnumAlcoholType, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new AreDutySuspendedSalesVatExemptRequest();\n req.tenantId = tenantId;\n req.alcoholType = alcoholType;\n const extractor = (response:any) => new AreDutySuspendedSalesVatExemptResponse(response).dutySuspendedSalesAreVatExempt;\n return this.makeJsonRequest(\"dutyRules/v1/areDutySuspendedSalesVatExempt\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getStockAdjustmentDutyRequirements(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetStockAdjustmentDutyRequirementsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetStockAdjustmentDutyRequirementsResponse(response).requirements;\n return this.makeJsonRequest(\"dutyRules/v1/getStockAdjustmentDutyRequirements\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getPackageTypeDutyRequirements(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPackageTypeDutyRequirementsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetPackageTypeDutyRequirementsResponse(response).requirements;\n return this.makeJsonRequest(\"dutyRules/v1/getPackageTypeDutyRequirements\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const dutyRulesService = new DutyRulesService();","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumAlcoholType } from \"./enums/enumAlcoholType.generated\";\nimport { EnumDutySource } from \"./enums/enumDutySource.generated\";\nimport { EnumEireMovementType } from \"./enums/enumEireMovementType.generated\";\nimport { EnumGermanBeerDutyMovementType } from \"./enums/enumGermanBeerDutyMovementType.generated\";\nimport { EnumGermanBeerDutyProductType } from \"./enums/enumGermanBeerDutyProductType.generated\";\nimport { EnumLocationBondedStatus } from \"./enums/enumLocationBondedStatus.generated\";\nimport { EnumSpiritDutyExemptionReason } from \"./enums/enumSpiritDutyExemptionReason.generated\";\nimport { EnumStandardOrder } from \"./enums/enumStandardOrder.generated\";\nimport { EnumStockAdjustDutyImplication } from \"./enums/enumStockAdjustDutyImplication.generated\";\n\n// Model Objects\n\nexport class DutySuspendedResultSet extends ModelObject {\n\n public alcoholType: EnumAlcoholType = EnumAlcoholType.none;\n public dutySuspendedReceivedLitres: number = 0;\n public dutySuspendedReceivedLitresOfAlcohol: number = 0;\n public dutySuspendedSentInCountryLitres: number = 0;\n public dutySuspendedSentInCountryLitresOfAlcohol: number = 0;\n public dutySuspendedSentExportLitres: number = 0;\n public dutySuspendedSentExportLitresOfAlcohol: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.alcoholType = EnumAlcoholType.getByValue(jsonSerializedObject.alcoholType, this.alcoholType);\n this.dutySuspendedReceivedLitres = jsonSerializedObject.dutySuspendedReceivedLitres;\n this.dutySuspendedReceivedLitresOfAlcohol = jsonSerializedObject.dutySuspendedReceivedLitresOfAlcohol;\n this.dutySuspendedSentInCountryLitres = jsonSerializedObject.dutySuspendedSentInCountryLitres;\n this.dutySuspendedSentInCountryLitresOfAlcohol = jsonSerializedObject.dutySuspendedSentInCountryLitresOfAlcohol;\n this.dutySuspendedSentExportLitres = jsonSerializedObject.dutySuspendedSentExportLitres;\n this.dutySuspendedSentExportLitresOfAlcohol = jsonSerializedObject.dutySuspendedSentExportLitresOfAlcohol;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.alcoholType = this.alcoholType.value;\n toRet.dutySuspendedReceivedLitres = this.dutySuspendedReceivedLitres;\n toRet.dutySuspendedReceivedLitresOfAlcohol = this.dutySuspendedReceivedLitresOfAlcohol;\n toRet.dutySuspendedSentInCountryLitres = this.dutySuspendedSentInCountryLitres;\n toRet.dutySuspendedSentInCountryLitresOfAlcohol = this.dutySuspendedSentInCountryLitresOfAlcohol;\n toRet.dutySuspendedSentExportLitres = this.dutySuspendedSentExportLitres;\n toRet.dutySuspendedSentExportLitresOfAlcohol = this.dutySuspendedSentExportLitresOfAlcohol;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class DutySuspendedReceiptItem extends ModelObject {\n\n public receiptDate: LocalDate = LocalDate.ofEpochDay(0);\n public stockLocationId: Guid = Guid.createEmpty();\n public stockItemId: Guid = Guid.createEmpty();\n public quantityReceived: number = 0;\n public unitOfMeasureId: Guid = Guid.createEmpty();\n public alcoholType: EnumAlcoholType = EnumAlcoholType.none;\n public litresReceived: number = 0;\n public abv: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.receiptDate = LocalDate.parse(jsonSerializedObject.receiptDate);\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.quantityReceived = jsonSerializedObject.quantityReceived;\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n this.alcoholType = EnumAlcoholType.getByValue(jsonSerializedObject.alcoholType, this.alcoholType);\n this.litresReceived = jsonSerializedObject.litresReceived;\n this.abv = jsonSerializedObject.abv;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.receiptDate = this.receiptDate.toString();\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.stockItemId = this.stockItemId.toString();\n toRet.quantityReceived = this.quantityReceived;\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n toRet.alcoholType = this.alcoholType.value;\n toRet.litresReceived = this.litresReceived;\n toRet.abv = this.abv;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \"DutySuspendedReceiptItem.StockLocationId cannot be empty\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"DutySuspendedReceiptItem.StockItemId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"DutySuspendedReceiptItem.UnitOfMeasureId cannot be empty\"},\n ];\n}\n\n\nexport class DutyAuditLine extends ModelObject {\n\n public alcoholType: EnumAlcoholType = EnumAlcoholType.none;\n /**\n * The date to be used for identifying the duty rate. Typically the Despatach Date\n */\n public dateOfDutyRate: LocalDate = LocalDate.ofEpochDay(0);\n /**\n * The date for which this item should appear on a duty return. Typically the Despatach Date, but may be different Eg for credits or corrective actions.\n */\n public dateOfDutyImplication: LocalDate = LocalDate.ofEpochDay(0);\n /**\n * The type of entity this audit line arises from, Eg Order/Credit\n */\n public sourceType: EnumDutySource = EnumDutySource.none;\n private _sourceOutletId: Guid | null = null;\n /**\n * The outlet id associated with the entity this audit line arises from.\n */\n public get sourceOutletId(): Guid | null { return this._sourceOutletId }\n public set sourceOutletId(value: Guid | null) {\n this._sourceOutletId = value === undefined ? null : value;\n }\n /**\n * Textual reference for the entity this audit line arises from, Eg OrderNumber\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public sourceReference: string = \"\";\n /**\n * The Stock Item this audit line relates to.\n */\n public stockItemId: Guid = Guid.createEmpty();\n private _manufacturerId: Guid | null = null;\n /**\n * The Manufacturer of the alcoholic liquid.\n */\n public get manufacturerId(): Guid | null { return this._manufacturerId }\n public set manufacturerId(value: Guid | null) {\n this._manufacturerId = value === undefined ? null : value;\n }\n /**\n * The Abv of the item at the time of the duty implication.\n */\n public abv: number = 0;\n /**\n * The number of dutiable litres leaving bond. +ve means we Sent liquid (Eg Orders), -ve means we Received liquid (eg Credits)\n */\n public dutiableLitresLeavingBond: number = 0;\n /**\n * German beer duty movement type.\n */\n public germanBeerDutyMovementType: EnumGermanBeerDutyMovementType = EnumGermanBeerDutyMovementType.none;\n private _plato: number | null = null;\n /**\n * Beer original Plato value, if applicable and known.\n */\n public get plato(): number | null { return this._plato }\n public set plato(value: number | null) {\n this._plato = value === undefined ? null : value;\n }\n /**\n * German beer duty product type.\n */\n public germanBeerDutyProductType: EnumGermanBeerDutyProductType = EnumGermanBeerDutyProductType.none;\n private _germanBeerMixedProductPercentageA: number | null = null;\n /**\n * German beer duty percentage of beer in a mixed product, if applicable.\n */\n public get germanBeerMixedProductPercentageA(): number | null { return this._germanBeerMixedProductPercentageA }\n public set germanBeerMixedProductPercentageA(value: number | null) {\n this._germanBeerMixedProductPercentageA = value === undefined ? null : value;\n }\n /**\n * The Stock Location this audit line relates to.\n */\n public stockLocationId: Guid = Guid.createEmpty();\n /**\n * True true if this item is brewed by members of the public for their personal use by borrowing the Brewery's equipment.\n */\n public isBrewedForPersonalUse: boolean = false;\n /**\n * True if this item is designed to be connected to a pump or pressurised gas system, such as those used in pubs.\n */\n public isDesignedForPump: boolean = false;\n private _finalUnitLitres: number | null = null;\n /**\n * Litres held by the final consumable packaged unit, if relevant.\n */\n public get finalUnitLitres(): number | null { return this._finalUnitLitres }\n public set finalUnitLitres(value: number | null) {\n this._finalUnitLitres = value === undefined ? null : value;\n }\n /**\n * Reason Spirit is exempt from duty.\n */\n public spiritDutyExemptionReason: EnumSpiritDutyExemptionReason = EnumSpiritDutyExemptionReason.none;\n /**\n * Id for the entity this audit line arises from, Eg OrderId\n */\n public sourceId: Guid = Guid.createEmpty();\n /**\n * Invoice number associated with the entity this audit line arises from. Only applicable to audit lines with source type as Order.Returns empty string for other audit lines.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public sourceInvoiceNumber: string = \"\";\n private _dateOfProductionDutyRate: LocalDate | null = null;\n /**\n * For UK, some items have duty calculated at the rateapplicable at date of production instead of date of leaving duty suspense.\n */\n public get dateOfProductionDutyRate(): LocalDate | null { return this._dateOfProductionDutyRate }\n public set dateOfProductionDutyRate(value: LocalDate | null) {\n this._dateOfProductionDutyRate = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.alcoholType = EnumAlcoholType.getByValue(jsonSerializedObject.alcoholType, this.alcoholType);\n this.dateOfDutyRate = LocalDate.parse(jsonSerializedObject.dateOfDutyRate);\n this.dateOfDutyImplication = LocalDate.parse(jsonSerializedObject.dateOfDutyImplication);\n this.sourceType = EnumDutySource.getByValue(jsonSerializedObject.sourceType, this.sourceType);\n this.sourceOutletId = jsonSerializedObject.sourceOutletId == null ? null : Guid.fromString(jsonSerializedObject.sourceOutletId);\n this.sourceReference = jsonSerializedObject.sourceReference;\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.manufacturerId = jsonSerializedObject.manufacturerId == null ? null : Guid.fromString(jsonSerializedObject.manufacturerId);\n this.abv = jsonSerializedObject.abv;\n this.dutiableLitresLeavingBond = jsonSerializedObject.dutiableLitresLeavingBond;\n this.germanBeerDutyMovementType = EnumGermanBeerDutyMovementType.getByValue(jsonSerializedObject.germanBeerDutyMovementType, this.germanBeerDutyMovementType);\n this.plato = jsonSerializedObject.plato == null ? null : jsonSerializedObject.plato;\n this.germanBeerDutyProductType = EnumGermanBeerDutyProductType.getByValue(jsonSerializedObject.germanBeerDutyProductType, this.germanBeerDutyProductType);\n this.germanBeerMixedProductPercentageA = jsonSerializedObject.germanBeerMixedProductPercentageA == null ? null : jsonSerializedObject.germanBeerMixedProductPercentageA;\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.isBrewedForPersonalUse = jsonSerializedObject.isBrewedForPersonalUse;\n this.isDesignedForPump = jsonSerializedObject.isDesignedForPump;\n this.finalUnitLitres = jsonSerializedObject.finalUnitLitres == null ? null : jsonSerializedObject.finalUnitLitres;\n this.spiritDutyExemptionReason = EnumSpiritDutyExemptionReason.getByValue(jsonSerializedObject.spiritDutyExemptionReason, this.spiritDutyExemptionReason);\n this.sourceId = Guid.fromString(jsonSerializedObject.sourceId);\n this.sourceInvoiceNumber = jsonSerializedObject.sourceInvoiceNumber;\n this.dateOfProductionDutyRate = jsonSerializedObject.dateOfProductionDutyRate == null ? null : LocalDate.parse(jsonSerializedObject.dateOfProductionDutyRate);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.alcoholType = this.alcoholType.value;\n toRet.dateOfDutyRate = this.dateOfDutyRate.toString();\n toRet.dateOfDutyImplication = this.dateOfDutyImplication.toString();\n toRet.sourceType = this.sourceType.value;\n toRet.sourceOutletId = this.sourceOutletId == null ? null : this.sourceOutletId.toString();\n toRet.sourceReference = this.sourceReference;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.manufacturerId = this.manufacturerId == null ? null : this.manufacturerId.toString();\n toRet.abv = this.abv;\n toRet.dutiableLitresLeavingBond = this.dutiableLitresLeavingBond;\n toRet.germanBeerDutyMovementType = this.germanBeerDutyMovementType.value;\n toRet.plato = this.plato == null ? null : this.plato;\n toRet.germanBeerDutyProductType = this.germanBeerDutyProductType.value;\n toRet.germanBeerMixedProductPercentageA = this.germanBeerMixedProductPercentageA == null ? null : this.germanBeerMixedProductPercentageA;\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.isBrewedForPersonalUse = this.isBrewedForPersonalUse;\n toRet.isDesignedForPump = this.isDesignedForPump;\n toRet.finalUnitLitres = this.finalUnitLitres == null ? null : this.finalUnitLitres;\n toRet.spiritDutyExemptionReason = this.spiritDutyExemptionReason.value;\n toRet.sourceId = this.sourceId.toString();\n toRet.sourceInvoiceNumber = this.sourceInvoiceNumber;\n toRet.dateOfProductionDutyRate = this.dateOfProductionDutyRate == null ? null : this.dateOfProductionDutyRate.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"sourceOutletId\", rule: (v: any) => v == null || !v.isEmpty() || \"DutyAuditLine.SourceOutletId cannot be empty\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"DutyAuditLine.StockItemId cannot be empty\"},\n {field: \"manufacturerId\", rule: (v: any) => v == null || !v.isEmpty() || \"DutyAuditLine.ManufacturerId cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \"DutyAuditLine.StockLocationId cannot be empty\"},\n {field: \"sourceId\", rule: (v: any) => !v.isEmpty() || \"DutyAuditLine.SourceId cannot be empty\"},\n ];\n}\n\n\nexport class EvaluateDutyRequestItem extends ModelObject {\n\n /**\n * An Id which will be copied to result for this item, to allow correlation of results to query lines\n */\n public correlationId: Guid = Guid.createEmpty();\n /**\n * Date of leaving duty suspense.\n */\n public dutyDate: LocalDate = LocalDate.ofEpochDay(0);\n public dutySource: EnumDutySource = EnumDutySource.none;\n private _stockLocationId: Guid | null = null;\n /**\n * Stock Location the item leaves. May be null in case of Spoilt Beer Credit.\n */\n public get stockLocationId(): Guid | null { return this._stockLocationId }\n public set stockLocationId(value: Guid | null) {\n this._stockLocationId = value === undefined ? null : value;\n }\n public alcoholType: EnumAlcoholType = EnumAlcoholType.none;\n public abv: number = 0;\n public isSpoilt: boolean = false;\n private _manufacturerId: Guid | null = null;\n public get manufacturerId(): Guid | null { return this._manufacturerId }\n public set manufacturerId(value: Guid | null) {\n this._manufacturerId = value === undefined ? null : value;\n }\n public quantityLeavingLocation: number = 0;\n public unitDutiableLitres: number = 0;\n public standardOrderType: EnumStandardOrder = EnumStandardOrder.fullPriceDutyPaid;\n public germanBeerDutyMovementType: EnumGermanBeerDutyMovementType = EnumGermanBeerDutyMovementType.none;\n public germanBeerDutyProductType: EnumGermanBeerDutyProductType = EnumGermanBeerDutyProductType.none;\n private _germanBeerMixedProductPercentageA: number | null = null;\n public get germanBeerMixedProductPercentageA(): number | null { return this._germanBeerMixedProductPercentageA }\n public set germanBeerMixedProductPercentageA(value: number | null) {\n this._germanBeerMixedProductPercentageA = value === undefined ? null : value;\n }\n private _plato: number | null = null;\n public get plato(): number | null { return this._plato }\n public set plato(value: number | null) {\n this._plato = value === undefined ? null : value;\n }\n public isBrewedForPersonalUse: boolean = false;\n public isDesignedForPump: boolean = false;\n private _finalUnitLitres: number | null = null;\n public get finalUnitLitres(): number | null { return this._finalUnitLitres }\n public set finalUnitLitres(value: number | null) {\n this._finalUnitLitres = value === undefined ? null : value;\n }\n public spiritDutyExemptionReason: EnumSpiritDutyExemptionReason = EnumSpiritDutyExemptionReason.none;\n public eireDutyMovementType: EnumEireMovementType = EnumEireMovementType.unknown;\n private _dateOfProductionDutyRate: LocalDate | null = null;\n /**\n * For UK, some items have duty calculated at the rateapplicable at date of production instead of date of leaving duty suspense.\n */\n public get dateOfProductionDutyRate(): LocalDate | null { return this._dateOfProductionDutyRate }\n public set dateOfProductionDutyRate(value: LocalDate | null) {\n this._dateOfProductionDutyRate = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.correlationId = Guid.fromString(jsonSerializedObject.correlationId);\n this.dutyDate = LocalDate.parse(jsonSerializedObject.dutyDate);\n this.dutySource = EnumDutySource.getByValue(jsonSerializedObject.dutySource, this.dutySource);\n this.stockLocationId = jsonSerializedObject.stockLocationId == null ? null : Guid.fromString(jsonSerializedObject.stockLocationId);\n this.alcoholType = EnumAlcoholType.getByValue(jsonSerializedObject.alcoholType, this.alcoholType);\n this.abv = jsonSerializedObject.abv;\n this.isSpoilt = jsonSerializedObject.isSpoilt;\n this.manufacturerId = jsonSerializedObject.manufacturerId == null ? null : Guid.fromString(jsonSerializedObject.manufacturerId);\n this.quantityLeavingLocation = jsonSerializedObject.quantityLeavingLocation;\n this.unitDutiableLitres = jsonSerializedObject.unitDutiableLitres;\n this.standardOrderType = EnumStandardOrder.getByValue(jsonSerializedObject.standardOrderType, this.standardOrderType);\n this.germanBeerDutyMovementType = EnumGermanBeerDutyMovementType.getByValue(jsonSerializedObject.germanBeerDutyMovementType, this.germanBeerDutyMovementType);\n this.germanBeerDutyProductType = EnumGermanBeerDutyProductType.getByValue(jsonSerializedObject.germanBeerDutyProductType, this.germanBeerDutyProductType);\n this.germanBeerMixedProductPercentageA = jsonSerializedObject.germanBeerMixedProductPercentageA == null ? null : jsonSerializedObject.germanBeerMixedProductPercentageA;\n this.plato = jsonSerializedObject.plato == null ? null : jsonSerializedObject.plato;\n this.isBrewedForPersonalUse = jsonSerializedObject.isBrewedForPersonalUse;\n this.isDesignedForPump = jsonSerializedObject.isDesignedForPump;\n this.finalUnitLitres = jsonSerializedObject.finalUnitLitres == null ? null : jsonSerializedObject.finalUnitLitres;\n this.spiritDutyExemptionReason = EnumSpiritDutyExemptionReason.getByValue(jsonSerializedObject.spiritDutyExemptionReason, this.spiritDutyExemptionReason);\n this.eireDutyMovementType = EnumEireMovementType.getByValue(jsonSerializedObject.eireDutyMovementType, this.eireDutyMovementType);\n this.dateOfProductionDutyRate = jsonSerializedObject.dateOfProductionDutyRate == null ? null : LocalDate.parse(jsonSerializedObject.dateOfProductionDutyRate);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.correlationId = this.correlationId.toString();\n toRet.dutyDate = this.dutyDate.toString();\n toRet.dutySource = this.dutySource.value;\n toRet.stockLocationId = this.stockLocationId == null ? null : this.stockLocationId.toString();\n toRet.alcoholType = this.alcoholType.value;\n toRet.abv = this.abv;\n toRet.isSpoilt = this.isSpoilt;\n toRet.manufacturerId = this.manufacturerId == null ? null : this.manufacturerId.toString();\n toRet.quantityLeavingLocation = this.quantityLeavingLocation;\n toRet.unitDutiableLitres = this.unitDutiableLitres;\n toRet.standardOrderType = this.standardOrderType.value;\n toRet.germanBeerDutyMovementType = this.germanBeerDutyMovementType.value;\n toRet.germanBeerDutyProductType = this.germanBeerDutyProductType.value;\n toRet.germanBeerMixedProductPercentageA = this.germanBeerMixedProductPercentageA == null ? null : this.germanBeerMixedProductPercentageA;\n toRet.plato = this.plato == null ? null : this.plato;\n toRet.isBrewedForPersonalUse = this.isBrewedForPersonalUse;\n toRet.isDesignedForPump = this.isDesignedForPump;\n toRet.finalUnitLitres = this.finalUnitLitres == null ? null : this.finalUnitLitres;\n toRet.spiritDutyExemptionReason = this.spiritDutyExemptionReason.value;\n toRet.eireDutyMovementType = this.eireDutyMovementType.value;\n toRet.dateOfProductionDutyRate = this.dateOfProductionDutyRate == null ? null : this.dateOfProductionDutyRate.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"correlationId\", rule: (v: any) => !v.isEmpty() || \"EvaluateDutyRequestItem.CorrelationId cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => v == null || !v.isEmpty() || \"EvaluateDutyRequestItem.StockLocationId cannot be empty\"},\n {field: \"manufacturerId\", rule: (v: any) => v == null || !v.isEmpty() || \"EvaluateDutyRequestItem.ManufacturerId cannot be empty\"},\n ];\n}\n\n\nexport class EvaluateDutyResponseItem extends ModelObject {\n\n /**\n * Returns the same value as provided in the request item\n */\n public correlationId: Guid = Guid.createEmpty();\n /**\n * Duty cost due to relevant item. -ve means the tenant's duty liability is decreased, eg for a credit where quantityLeavingLocation is -ve.\n */\n public dutyCostUnrounded: number = 0;\n /**\n * True if duty will be incurred directly due to the line (Eg sale from a bonded location). False indicates that the duty cost will be incurred in a manner not directly related to this line (Eg sale from a non-bonded location where the duty would have been incurred when the stock was transferred to the location.)\n */\n public isDutyDirectlyIncurred: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.correlationId = Guid.fromString(jsonSerializedObject.correlationId);\n this.dutyCostUnrounded = jsonSerializedObject.dutyCostUnrounded;\n this.isDutyDirectlyIncurred = jsonSerializedObject.isDutyDirectlyIncurred;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.correlationId = this.correlationId.toString();\n toRet.dutyCostUnrounded = this.dutyCostUnrounded;\n toRet.isDutyDirectlyIncurred = this.isDutyDirectlyIncurred;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"correlationId\", rule: (v: any) => !v.isEmpty() || \"EvaluateDutyResponseItem.CorrelationId cannot be empty\"},\n ];\n}\n\n\nexport class FullStockAuditLine extends ModelObject {\n\n /**\n * The Stock Location this audit line relates to.\n */\n public stockLocationId: Guid = Guid.createEmpty();\n public isBonded: boolean = false;\n public isExternal: boolean = false;\n /**\n * The type of entity this audit line arises from, Eg Order/Credit\n */\n public sourceType: EnumDutySource = EnumDutySource.none;\n /**\n * Textual reference for the entity this audit line arises from, Eg OrderNumber\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public sourceReference: string = \"\";\n /**\n * The Id of the source item. Will be a reference suitable to SourceType.\n */\n public sourceId: Guid = Guid.createEmpty();\n /**\n * Identifies if the stock moved across a bonded boundary.\n */\n public didCrossBondedBoundary: boolean = false;\n /**\n * The date of the stock movement, in particular for identifying which duty return period this relates to.\n */\n public date: LocalDate = LocalDate.ofEpochDay(0);\n /**\n * The date to be used for identifying the duty rate. Often same as Date but occasionally not (Eg credits).\n */\n public dateOfDutyRate: LocalDate = LocalDate.ofEpochDay(0);\n private _sourceOutletId: Guid | null = null;\n /**\n * The outlet id associated with the entity this audit line arises from.\n */\n public get sourceOutletId(): Guid | null { return this._sourceOutletId }\n public set sourceOutletId(value: Guid | null) {\n this._sourceOutletId = value === undefined ? null : value;\n }\n /**\n * The duty implication as best inferred from all the information about the movement. For example, orders and credits will infer from StandardOrderType, transfers will infer from the bonded and non-bonded nature of source and dest.\n */\n public inferredDutyImplication: EnumStockAdjustDutyImplication = EnumStockAdjustDutyImplication.noDuty;\n /**\n * Identifies if the stock is not yet committed into stock figures. This could be the case for orders/credits which are complete but not yet historic.\n */\n public isPendingStockFigureUpdate: boolean = false;\n public alcoholType: EnumAlcoholType = EnumAlcoholType.none;\n /**\n * The Stock Item this audit line relates to.\n */\n public stockItemId: Guid = Guid.createEmpty();\n private _manufacturerId: Guid | null = null;\n /**\n * The Manufacturer of the alcoholic liquid.\n */\n public get manufacturerId(): Guid | null { return this._manufacturerId }\n public set manufacturerId(value: Guid | null) {\n this._manufacturerId = value === undefined ? null : value;\n }\n /**\n * The Abv of the item at the time of the duty implication.\n */\n public abv: number = 0;\n /**\n * German beer duty movement type.\n */\n public germanBeerDutyMovementType: EnumGermanBeerDutyMovementType = EnumGermanBeerDutyMovementType.none;\n private _plato: number | null = null;\n /**\n * Beer original Plato value, if applicable and known.\n */\n public get plato(): number | null { return this._plato }\n public set plato(value: number | null) {\n this._plato = value === undefined ? null : value;\n }\n /**\n * German beer duty product type.\n */\n public germanBeerDutyProductType: EnumGermanBeerDutyProductType = EnumGermanBeerDutyProductType.none;\n private _germanBeerMixedProductPercentageA: number | null = null;\n /**\n * German beer duty percentage of beer in a mixed product, if applicable.\n */\n public get germanBeerMixedProductPercentageA(): number | null { return this._germanBeerMixedProductPercentageA }\n public set germanBeerMixedProductPercentageA(value: number | null) {\n this._germanBeerMixedProductPercentageA = value === undefined ? null : value;\n }\n /**\n * True true if this item is brewed by members of the public for their personal use by borrowing the Brewery's equipment.\n */\n public isBrewedForPersonalUse: boolean = false;\n /**\n * True if this item is designed to be connected to a pump or pressurised gas system, such as those used in pubs.\n */\n public isDesignedForPump: boolean = false;\n private _finalUnitLitres: number | null = null;\n /**\n * Litres held by the final consumable packaged unit, if relevant.\n */\n public get finalUnitLitres(): number | null { return this._finalUnitLitres }\n public set finalUnitLitres(value: number | null) {\n this._finalUnitLitres = value === undefined ? null : value;\n }\n /**\n * Reason Spirit is exempt from duty.\n */\n public spiritDutyExemptionReason: EnumSpiritDutyExemptionReason = EnumSpiritDutyExemptionReason.none;\n /**\n * Quantity of relevant units leaving the given location. Will be -ve if units arrived.\n */\n public quantityLeaving: number = 0;\n public unitOfMeasureId: Guid = Guid.createEmpty();\n private _packageTypeId: Guid | null = null;\n public get packageTypeId(): Guid | null { return this._packageTypeId }\n public set packageTypeId(value: Guid | null) {\n this._packageTypeId = value === undefined ? null : value;\n }\n private _unitDutiableLitres: number | null = null;\n /**\n * Dutiable litres per unit of measure, if defined.\n */\n public get unitDutiableLitres(): number | null { return this._unitDutiableLitres }\n public set unitDutiableLitres(value: number | null) {\n this._unitDutiableLitres = value === undefined ? null : value;\n }\n private _unitLitres: number | null = null;\n /**\n * Litres per unit, if known. May come from the source entity itself (Eg OrderLine), the Unit of Measure or the Package Type.\n */\n public get unitLitres(): number | null { return this._unitLitres }\n public set unitLitres(value: number | null) {\n this._unitLitres = value === undefined ? null : value;\n }\n /**\n * Eire alcohol movement type.\n */\n public eireMovementType: EnumEireMovementType = EnumEireMovementType.unknown;\n /**\n * Invoice number associated with the entity this audit line arises from. Only applicable to audit lines with source type as Order.Returns empty string for other audit lines.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public sourceInvoiceNumber: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.isBonded = jsonSerializedObject.isBonded;\n this.isExternal = jsonSerializedObject.isExternal;\n this.sourceType = EnumDutySource.getByValue(jsonSerializedObject.sourceType, this.sourceType);\n this.sourceReference = jsonSerializedObject.sourceReference;\n this.sourceId = Guid.fromString(jsonSerializedObject.sourceId);\n this.didCrossBondedBoundary = jsonSerializedObject.didCrossBondedBoundary;\n this.date = LocalDate.parse(jsonSerializedObject.date);\n this.dateOfDutyRate = LocalDate.parse(jsonSerializedObject.dateOfDutyRate);\n this.sourceOutletId = jsonSerializedObject.sourceOutletId == null ? null : Guid.fromString(jsonSerializedObject.sourceOutletId);\n this.inferredDutyImplication = EnumStockAdjustDutyImplication.getByValue(jsonSerializedObject.inferredDutyImplication, this.inferredDutyImplication);\n this.isPendingStockFigureUpdate = jsonSerializedObject.isPendingStockFigureUpdate;\n this.alcoholType = EnumAlcoholType.getByValue(jsonSerializedObject.alcoholType, this.alcoholType);\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.manufacturerId = jsonSerializedObject.manufacturerId == null ? null : Guid.fromString(jsonSerializedObject.manufacturerId);\n this.abv = jsonSerializedObject.abv;\n this.germanBeerDutyMovementType = EnumGermanBeerDutyMovementType.getByValue(jsonSerializedObject.germanBeerDutyMovementType, this.germanBeerDutyMovementType);\n this.plato = jsonSerializedObject.plato == null ? null : jsonSerializedObject.plato;\n this.germanBeerDutyProductType = EnumGermanBeerDutyProductType.getByValue(jsonSerializedObject.germanBeerDutyProductType, this.germanBeerDutyProductType);\n this.germanBeerMixedProductPercentageA = jsonSerializedObject.germanBeerMixedProductPercentageA == null ? null : jsonSerializedObject.germanBeerMixedProductPercentageA;\n this.isBrewedForPersonalUse = jsonSerializedObject.isBrewedForPersonalUse;\n this.isDesignedForPump = jsonSerializedObject.isDesignedForPump;\n this.finalUnitLitres = jsonSerializedObject.finalUnitLitres == null ? null : jsonSerializedObject.finalUnitLitres;\n this.spiritDutyExemptionReason = EnumSpiritDutyExemptionReason.getByValue(jsonSerializedObject.spiritDutyExemptionReason, this.spiritDutyExemptionReason);\n this.quantityLeaving = jsonSerializedObject.quantityLeaving;\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n this.packageTypeId = jsonSerializedObject.packageTypeId == null ? null : Guid.fromString(jsonSerializedObject.packageTypeId);\n this.unitDutiableLitres = jsonSerializedObject.unitDutiableLitres == null ? null : jsonSerializedObject.unitDutiableLitres;\n this.unitLitres = jsonSerializedObject.unitLitres == null ? null : jsonSerializedObject.unitLitres;\n this.eireMovementType = EnumEireMovementType.getByValue(jsonSerializedObject.eireMovementType, this.eireMovementType);\n this.sourceInvoiceNumber = jsonSerializedObject.sourceInvoiceNumber;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.isBonded = this.isBonded;\n toRet.isExternal = this.isExternal;\n toRet.sourceType = this.sourceType.value;\n toRet.sourceReference = this.sourceReference;\n toRet.sourceId = this.sourceId.toString();\n toRet.didCrossBondedBoundary = this.didCrossBondedBoundary;\n toRet.date = this.date.toString();\n toRet.dateOfDutyRate = this.dateOfDutyRate.toString();\n toRet.sourceOutletId = this.sourceOutletId == null ? null : this.sourceOutletId.toString();\n toRet.inferredDutyImplication = this.inferredDutyImplication.value;\n toRet.isPendingStockFigureUpdate = this.isPendingStockFigureUpdate;\n toRet.alcoholType = this.alcoholType.value;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.manufacturerId = this.manufacturerId == null ? null : this.manufacturerId.toString();\n toRet.abv = this.abv;\n toRet.germanBeerDutyMovementType = this.germanBeerDutyMovementType.value;\n toRet.plato = this.plato == null ? null : this.plato;\n toRet.germanBeerDutyProductType = this.germanBeerDutyProductType.value;\n toRet.germanBeerMixedProductPercentageA = this.germanBeerMixedProductPercentageA == null ? null : this.germanBeerMixedProductPercentageA;\n toRet.isBrewedForPersonalUse = this.isBrewedForPersonalUse;\n toRet.isDesignedForPump = this.isDesignedForPump;\n toRet.finalUnitLitres = this.finalUnitLitres == null ? null : this.finalUnitLitres;\n toRet.spiritDutyExemptionReason = this.spiritDutyExemptionReason.value;\n toRet.quantityLeaving = this.quantityLeaving;\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n toRet.packageTypeId = this.packageTypeId == null ? null : this.packageTypeId.toString();\n toRet.unitDutiableLitres = this.unitDutiableLitres == null ? null : this.unitDutiableLitres;\n toRet.unitLitres = this.unitLitres == null ? null : this.unitLitres;\n toRet.eireMovementType = this.eireMovementType.value;\n toRet.sourceInvoiceNumber = this.sourceInvoiceNumber;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \"FullStockAuditLine.StockLocationId cannot be empty\"},\n {field: \"sourceId\", rule: (v: any) => !v.isEmpty() || \"FullStockAuditLine.SourceId cannot be empty\"},\n {field: \"sourceOutletId\", rule: (v: any) => v == null || !v.isEmpty() || \"FullStockAuditLine.SourceOutletId cannot be empty\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"FullStockAuditLine.StockItemId cannot be empty\"},\n {field: \"manufacturerId\", rule: (v: any) => v == null || !v.isEmpty() || \"FullStockAuditLine.ManufacturerId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"FullStockAuditLine.UnitOfMeasureId cannot be empty\"},\n {field: \"packageTypeId\", rule: (v: any) => v == null || !v.isEmpty() || \"FullStockAuditLine.PackageTypeId cannot be empty\"},\n ];\n}\n\n\nexport class DutySuspendedOrderAuditLine extends ModelObject {\n\n public orderNumber: string = \"\";\n public creditNumber: string = \"\";\n public despatchDate: LocalDate = LocalDate.ofEpochDay(0);\n public outletId: Guid = Guid.createEmpty();\n public alcoholType: EnumAlcoholType = EnumAlcoholType.none;\n public stockItemId: Guid = Guid.createEmpty();\n public productName: string = \"\";\n public quantity: number = 0;\n public totalNetPrice: number = 0;\n public totalHectolitres: number = 0;\n public abv: number = 0;\n public totalLitresOfAlcohol: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.orderNumber = jsonSerializedObject.orderNumber;\n this.creditNumber = jsonSerializedObject.creditNumber;\n this.despatchDate = LocalDate.parse(jsonSerializedObject.despatchDate);\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n this.alcoholType = EnumAlcoholType.getByValue(jsonSerializedObject.alcoholType, this.alcoholType);\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.productName = jsonSerializedObject.productName;\n this.quantity = jsonSerializedObject.quantity;\n this.totalNetPrice = jsonSerializedObject.totalNetPrice;\n this.totalHectolitres = jsonSerializedObject.totalHectolitres;\n this.abv = jsonSerializedObject.abv;\n this.totalLitresOfAlcohol = jsonSerializedObject.totalLitresOfAlcohol;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.orderNumber = this.orderNumber;\n toRet.creditNumber = this.creditNumber;\n toRet.despatchDate = this.despatchDate.toString();\n toRet.outletId = this.outletId.toString();\n toRet.alcoholType = this.alcoholType.value;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.productName = this.productName;\n toRet.quantity = this.quantity;\n toRet.totalNetPrice = this.totalNetPrice;\n toRet.totalHectolitres = this.totalHectolitres;\n toRet.abv = this.abv;\n toRet.totalLitresOfAlcohol = this.totalLitresOfAlcohol;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \"DutySuspendedOrderAuditLine.OutletId cannot be empty\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"DutySuspendedOrderAuditLine.StockItemId cannot be empty\"},\n ];\n}\n\n\nexport class ProductionDutyRateDateRange extends ModelObject {\n\n private _fromDate: LocalDate | null = null;\n /**\n * Earliest date in range, null means start of time.\n */\n public get fromDate(): LocalDate | null { return this._fromDate }\n public set fromDate(value: LocalDate | null) {\n this._fromDate = value === undefined ? null : value;\n }\n private _toDate: LocalDate | null = null;\n /**\n * Latest date in range, null means end date is in future but not yet known.\n */\n public get toDate(): LocalDate | null { return this._toDate }\n public set toDate(value: LocalDate | null) {\n this._toDate = value === undefined ? null : value;\n }\n /**\n * Preferred single date to use to represent this range.\n */\n public preferredValue: LocalDate = LocalDate.ofEpochDay(0);\n /**\n * Friendly name to represent this range.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public name: string = \"\";\n /**\n * Identifies if range should be hidden by default. Typically we only want to show the current range and the immediately previous range only.\n */\n public isHidden: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.fromDate = jsonSerializedObject.fromDate == null ? null : LocalDate.parse(jsonSerializedObject.fromDate);\n this.toDate = jsonSerializedObject.toDate == null ? null : LocalDate.parse(jsonSerializedObject.toDate);\n this.preferredValue = LocalDate.parse(jsonSerializedObject.preferredValue);\n this.name = jsonSerializedObject.name;\n this.isHidden = jsonSerializedObject.isHidden;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.fromDate = this.fromDate == null ? null : this.fromDate.toString();\n toRet.toDate = this.toDate == null ? null : this.toDate.toString();\n toRet.preferredValue = this.preferredValue.toString();\n toRet.name = this.name;\n toRet.isHidden = this.isHidden;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class EvaluateDutySuspendedMovementsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public fromDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public toDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public limitToGivenAlcoholTypes: boolean = false;\n public limitedAlcoholTypes: readonly EnumAlcoholType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.fromDateInclusive = LocalDate.parse(jsonSerializedObject.fromDateInclusive);\n this.toDateInclusive = LocalDate.parse(jsonSerializedObject.toDateInclusive);\n this.limitToGivenAlcoholTypes = jsonSerializedObject.limitToGivenAlcoholTypes;\n this.limitedAlcoholTypes = jsonSerializedObject.limitedAlcoholTypes.map((v: any) => EnumAlcoholType.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.fromDateInclusive = this.fromDateInclusive.toString();\n toRet.toDateInclusive = this.toDateInclusive.toString();\n toRet.limitToGivenAlcoholTypes = this.limitToGivenAlcoholTypes;\n toRet.limitedAlcoholTypes = this.limitedAlcoholTypes.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class EvaluateDutySuspendedMovementsResponse extends ModelObject {\n\n public results: DutySuspendedResultSet[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new DutySuspendedResultSet(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as DutySuspendedResultSet[]).reduce((acc: Array, curr: DutySuspendedResultSet) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetDutySuspendedReceiptsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public fromDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public toDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public limitToGivenAlcoholTypes: boolean = false;\n public limitedAlcoholTypes: readonly EnumAlcoholType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.fromDateInclusive = LocalDate.parse(jsonSerializedObject.fromDateInclusive);\n this.toDateInclusive = LocalDate.parse(jsonSerializedObject.toDateInclusive);\n this.limitToGivenAlcoholTypes = jsonSerializedObject.limitToGivenAlcoholTypes;\n this.limitedAlcoholTypes = jsonSerializedObject.limitedAlcoholTypes.map((v: any) => EnumAlcoholType.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.fromDateInclusive = this.fromDateInclusive.toString();\n toRet.toDateInclusive = this.toDateInclusive.toString();\n toRet.limitToGivenAlcoholTypes = this.limitToGivenAlcoholTypes;\n toRet.limitedAlcoholTypes = this.limitedAlcoholTypes.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetDutySuspendedReceiptsResponse extends ModelObject {\n\n public results: DutySuspendedReceiptItem[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new DutySuspendedReceiptItem(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as DutySuspendedReceiptItem[]).reduce((acc: Array, curr: DutySuspendedReceiptItem) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetDutyAuditInformationRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public fromDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public toDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public limitedAlcoholTypes: readonly EnumAlcoholType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.fromDateInclusive = LocalDate.parse(jsonSerializedObject.fromDateInclusive);\n this.toDateInclusive = LocalDate.parse(jsonSerializedObject.toDateInclusive);\n this.limitedAlcoholTypes = jsonSerializedObject.limitedAlcoholTypes.map((v: any) => EnumAlcoholType.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.fromDateInclusive = this.fromDateInclusive.toString();\n toRet.toDateInclusive = this.toDateInclusive.toString();\n toRet.limitedAlcoholTypes = this.limitedAlcoholTypes.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetDutyAuditInformationResponse extends ModelObject {\n\n public results: DutyAuditLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new DutyAuditLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as DutyAuditLine[]).reduce((acc: Array, curr: DutyAuditLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class EvaluateDutyForItemsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public items: readonly EvaluateDutyRequestItem[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.items = jsonSerializedObject.items.map((v: any) => new EvaluateDutyRequestItem(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.items = this.items.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"items\", rule: (v: any) => !!v || \"items is required\"},\n {field: \"items\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as EvaluateDutyRequestItem[]).reduce((acc: Array, curr: EvaluateDutyRequestItem) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class EvaluateDutyForItemsResponse extends ModelObject {\n\n public results: EvaluateDutyResponseItem[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new EvaluateDutyResponseItem(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as EvaluateDutyResponseItem[]).reduce((acc: Array, curr: EvaluateDutyResponseItem) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetFullStockAuditRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public fromDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public toDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public alcoholTypes: readonly EnumAlcoholType[] = [];\n private _bondedStatuses: readonly EnumLocationBondedStatus[] | null = null;\n public get bondedStatuses(): readonly EnumLocationBondedStatus[] | null { return this._bondedStatuses }\n public set bondedStatuses(value: readonly EnumLocationBondedStatus[] | null) {\n this._bondedStatuses = value === undefined ? null : value;\n }\n private _sources: readonly EnumDutySource[] | null = null;\n public get sources(): readonly EnumDutySource[] | null { return this._sources }\n public set sources(value: readonly EnumDutySource[] | null) {\n this._sources = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.fromDateInclusive = LocalDate.parse(jsonSerializedObject.fromDateInclusive);\n this.toDateInclusive = LocalDate.parse(jsonSerializedObject.toDateInclusive);\n this.alcoholTypes = jsonSerializedObject.alcoholTypes.map((v: any) => EnumAlcoholType.getByValue(v));\n this.bondedStatuses = jsonSerializedObject.bondedStatuses == null ? null : jsonSerializedObject.bondedStatuses.map((v: any) => EnumLocationBondedStatus.getByValue(v));\n this.sources = jsonSerializedObject.sources == null ? null : jsonSerializedObject.sources.map((v: any) => EnumDutySource.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.fromDateInclusive = this.fromDateInclusive.toString();\n toRet.toDateInclusive = this.toDateInclusive.toString();\n toRet.alcoholTypes = this.alcoholTypes.map(v => v.value);\n toRet.bondedStatuses = this.bondedStatuses == null ? null : this.bondedStatuses.map(v => v.value);\n toRet.sources = this.sources == null ? null : this.sources.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetFullStockAuditResponse extends ModelObject {\n\n public results: FullStockAuditLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new FullStockAuditLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as FullStockAuditLine[]).reduce((acc: Array, curr: FullStockAuditLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class EvaluateDutySuspendedOrdersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public fromDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public toDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.fromDateInclusive = LocalDate.parse(jsonSerializedObject.fromDateInclusive);\n this.toDateInclusive = LocalDate.parse(jsonSerializedObject.toDateInclusive);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.fromDateInclusive = this.fromDateInclusive.toString();\n toRet.toDateInclusive = this.toDateInclusive.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class EvaluateDutySuspendedOrdersResponse extends ModelObject {\n\n public results: DutySuspendedOrderAuditLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new DutySuspendedOrderAuditLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as DutySuspendedOrderAuditLine[]).reduce((acc: Array, curr: DutySuspendedOrderAuditLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllProductionDutyDateRangesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllProductionDutyDateRangesResponse extends ModelObject {\n\n public ranges: ProductionDutyRateDateRange[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.ranges = jsonSerializedObject.ranges.map((v: any) => new ProductionDutyRateDateRange(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.ranges = this.ranges.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"ranges\", rule: (v: any) => !!v || \"ranges is required\"},\n {field: \"ranges\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProductionDutyRateDateRange[]).reduce((acc: Array, curr: ProductionDutyRateDateRange) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetItemIdsNeedingKnowledgeOfOldStockSalesForDateRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public dateToConsider: LocalDate = LocalDate.ofEpochDay(0);\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.dateToConsider = LocalDate.parse(jsonSerializedObject.dateToConsider);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.dateToConsider = this.dateToConsider.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetItemIdsNeedingKnowledgeOfOldStockSalesForDateResponse extends ModelObject {\n\n public itemIds: Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.itemIds = jsonSerializedObject.itemIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.itemIds = this.itemIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class DutyService extends ServiceBase {\n\n public async evaluateDutySuspendedMovements(tenantId: Guid, fromDateInclusive: LocalDate, toDateInclusive: LocalDate, limitToGivenAlcoholTypes: boolean, limitedAlcoholTypes: readonly EnumAlcoholType[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new EvaluateDutySuspendedMovementsRequest();\n req.tenantId = tenantId;\n req.fromDateInclusive = fromDateInclusive;\n req.toDateInclusive = toDateInclusive;\n req.limitToGivenAlcoholTypes = limitToGivenAlcoholTypes;\n req.limitedAlcoholTypes = limitedAlcoholTypes;\n const extractor = (response:any) => new EvaluateDutySuspendedMovementsResponse(response).results;\n return this.makeJsonRequest(\"duty/v1/evaluateDutySuspendedMovements\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getDutySuspendedReceipts(tenantId: Guid, fromDateInclusive: LocalDate, toDateInclusive: LocalDate, limitToGivenAlcoholTypes: boolean, limitedAlcoholTypes: readonly EnumAlcoholType[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetDutySuspendedReceiptsRequest();\n req.tenantId = tenantId;\n req.fromDateInclusive = fromDateInclusive;\n req.toDateInclusive = toDateInclusive;\n req.limitToGivenAlcoholTypes = limitToGivenAlcoholTypes;\n req.limitedAlcoholTypes = limitedAlcoholTypes;\n const extractor = (response:any) => new GetDutySuspendedReceiptsResponse(response).results;\n return this.makeJsonRequest(\"duty/v1/getDutySuspendedReceipts\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getDutyAuditInformation(tenantId: Guid, fromDateInclusive: LocalDate, toDateInclusive: LocalDate, limitedAlcoholTypes: readonly EnumAlcoholType[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetDutyAuditInformationRequest();\n req.tenantId = tenantId;\n req.fromDateInclusive = fromDateInclusive;\n req.toDateInclusive = toDateInclusive;\n req.limitedAlcoholTypes = limitedAlcoholTypes;\n const extractor = (response:any) => new GetDutyAuditInformationResponse(response).results;\n return this.makeJsonRequest(\"duty/v1/getDutyAuditInformation\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async evaluateDutyForItems(tenantId: Guid, items: readonly EvaluateDutyRequestItem[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new EvaluateDutyForItemsRequest();\n req.tenantId = tenantId;\n req.items = items;\n const extractor = (response:any) => new EvaluateDutyForItemsResponse(response).results;\n return this.makeJsonRequest(\"duty/v1/evaluateDutyForItems\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getFullStockAudit(tenantId: Guid, fromDateInclusive: LocalDate, toDateInclusive: LocalDate, alcoholTypes: readonly EnumAlcoholType[], bondedStatuses: readonly EnumLocationBondedStatus[] | null, sources: readonly EnumDutySource[] | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetFullStockAuditRequest();\n req.tenantId = tenantId;\n req.fromDateInclusive = fromDateInclusive;\n req.toDateInclusive = toDateInclusive;\n req.alcoholTypes = alcoholTypes;\n req.bondedStatuses = bondedStatuses;\n req.sources = sources;\n const extractor = (response:any) => new GetFullStockAuditResponse(response).results;\n return this.makeJsonRequest(\"duty/v1/getFullStockAudit\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async evaluateDutySuspendedOrders(tenantId: Guid, fromDateInclusive: LocalDate, toDateInclusive: LocalDate, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new EvaluateDutySuspendedOrdersRequest();\n req.tenantId = tenantId;\n req.fromDateInclusive = fromDateInclusive;\n req.toDateInclusive = toDateInclusive;\n const extractor = (response:any) => new EvaluateDutySuspendedOrdersResponse(response).results;\n return this.makeJsonRequest(\"duty/v1/evaluateDutySuspendedOrders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllProductionDutyDateRanges(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllProductionDutyDateRangesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllProductionDutyDateRangesResponse(response).ranges;\n return this.makeJsonRequest(\"duty/v1/getAllProductionDutyDateRanges\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const dutyService = new DutyService();","import api from \"@/app/api\";\nimport type { ProductionDutyRateDateRange } from \"@/app/services/generated/dutyService\";\nimport { dutyService } from \"@/app/services/generated/dutyService\";\nimport type {\n AlcoholDutyLineRequirements,\n PackageTypeDutyRequirements,\n StockLocationsDutyRequirements,\n} from \"@/app/services/generated/dutyrulesService\";\nimport {\n AlcoholDutyHeaderRequirements,\n dutyRulesService,\n} from \"@/app/services/generated/dutyrulesService\";\nimport type { EnumAlcoholType } from \"@/app/services/generated/enums/enumAlcoholType.generated\";\nimport type { EnumStockAdjustDutyImplication } from \"@/app/services/generated/enums/enumStockAdjustDutyImplication.generated\";\nimport userStore from \"@/store/modules/userStore\";\nimport { reactive, readonly, watch } from \"vue\";\n\ninterface DutyConfigurationStoreState {\n headerRequirements: AlcoholDutyHeaderRequirements;\n allowedAlcoholTypes: EnumAlcoholType[];\n stockAdjustmentDutyImplications: EnumStockAdjustDutyImplication[];\n alcoholTypeToRequirementsMap: Map<\n EnumAlcoholType,\n AlcoholDutyLineRequirements\n >;\n stockLocationDutyRequirements: StockLocationsDutyRequirements | null;\n packageTypeDutyRequirements: PackageTypeDutyRequirements | null;\n allProductionDutyDateRanges: readonly ProductionDutyRateDateRange[];\n}\n\nconst state = reactive({\n headerRequirements: new AlcoholDutyHeaderRequirements(),\n allowedAlcoholTypes: [],\n stockAdjustmentDutyImplications: [],\n alcoholTypeToRequirementsMap: new Map(),\n stockLocationDutyRequirements: null,\n packageTypeDutyRequirements: null,\n allProductionDutyDateRanges: [],\n});\n\nconst refreshStore = async () => {\n [\n state.headerRequirements,\n state.allowedAlcoholTypes,\n state.stockLocationDutyRequirements,\n state.stockAdjustmentDutyImplications,\n state.packageTypeDutyRequirements,\n state.allProductionDutyDateRanges,\n ] = await Promise.all([\n dutyRulesService.getAlcoholDutyHeaderRequirements(api.tenantId),\n dutyRulesService.getAllowedAlcoholTypes(api.tenantId),\n dutyRulesService.getStockLocationDutyRequirements(api.tenantId),\n (await dutyRulesService.getStockAdjustmentDutyRequirements(api.tenantId))\n .allowedDutyImplications,\n dutyRulesService.getPackageTypeDutyRequirements(api.tenantId),\n dutyService.getAllProductionDutyDateRanges(api.tenantId),\n ]);\n\n const dutyLineRequirements =\n await dutyRulesService.getAlcoholDutyLineRequirementsForTypes(\n api.tenantId,\n state.allowedAlcoholTypes\n );\n\n dutyLineRequirements.forEach((requirement) => {\n state.alcoholTypeToRequirementsMap.set(\n requirement.alcoholType,\n requirement\n );\n });\n};\n\nwatch(\n () => userStore.state.tenant,\n async () => {\n if (userStore.state.tenant) {\n await refreshStore();\n }\n },\n { immediate: true }\n);\n\nexport default {\n state: readonly(state),\n refreshStore,\n};\n","import errorLoggerService from \"@/app/errors/errorLoggerService\";\nimport {\n AlcoholDutyFieldRequirement,\n BooleanFieldRequirement,\n} from \"@/app/services/generated/dutyrulesService\";\nimport { EnumAlcoholType } from \"@/app/services/generated/enums/enumAlcoholType.generated\";\nimport { EnumDutyScheme } from \"@/app/services/generated/enums/enumDutyScheme.generated\";\nimport { EnumGermanBeerDutyMovementType } from \"@/app/services/generated/enums/enumGermanBeerDutyMovementType.generated\";\nimport { EnumGermanBeerDutyProductType } from \"@/app/services/generated/enums/enumGermanBeerDutyProductType.generated\";\nimport type { EnumStandardOrder } from \"@/app/services/generated/enums/enumStandardOrder.generated\";\nimport type { EnumStockAdjustDutyImplication } from \"@/app/services/generated/enums/enumStockAdjustDutyImplication.generated\";\nimport type { StockLocation } from \"@/app/services/generated/stocklocationService\";\nimport { useI18n } from \"@/plugins/i18n\";\nimport type { ValidationRule } from \"@/plugins/validation\";\nimport { useRuleSets } from \"@/plugins/validation\";\nimport dutyConfigurationStore from \"@/store/modules/dutyConfigurationStore\";\nimport userStore from \"@/store/modules/userStore\";\nimport type { ComputedRef, Ref } from \"vue\";\nimport { computed, ref } from \"vue\";\n\ninterface DutyRules {\n abv: AlcoholDutyFieldRequirement;\n manufacturer: AlcoholDutyFieldRequirement;\n unitDutiableLitres: AlcoholDutyFieldRequirement;\n plato: AlcoholDutyFieldRequirement;\n germanBeerDutyProductType: AlcoholDutyFieldRequirement;\n packageType: AlcoholDutyFieldRequirement;\n}\n\ninterface DutyRuleSets {\n abv: ValidationRule[];\n manufacturer: ValidationRule[];\n unitDutiableLitres: ValidationRule[];\n plato: ValidationRule[];\n germanBeerDutyProductType: ValidationRule[];\n packageType: ValidationRule[];\n}\n\ninterface DutyRulesForLines {\n dutyRules: ComputedRef;\n dutyRuleSets: ComputedRef;\n shouldShowDutyRow: ComputedRef;\n}\n\nconst { ruleSet } = useRuleSets();\nconst { $m, $t } = useI18n();\n\nconst defaultRequirement = new AlcoholDutyFieldRequirement();\ndefaultRequirement.required = false;\ndefaultRequirement.show = false;\n\nconst booleanRequirementDontShow = new BooleanFieldRequirement();\nbooleanRequirementDontShow.show = false;\n\nexport const useDutyRulesForLines = (\n alcoholType: Ref\n) => {\n const dutyRules = computed(() => {\n const requirements =\n dutyConfigurationStore.state.alcoholTypeToRequirementsMap.get(\n alcoholType.value ?? EnumAlcoholType.none\n );\n\n return {\n abv: requirements?.abv ?? defaultRequirement,\n\n manufacturer: requirements?.manufacturer ?? defaultRequirement,\n\n unitDutiableLitres:\n requirements?.unitDutiableLitres ?? defaultRequirement,\n\n plato: requirements?.plato ?? defaultRequirement,\n\n germanBeerDutyProductType:\n requirements?.germanBeerDutyProductType ?? defaultRequirement,\n\n finalUnitLitres: requirements?.finalUnitLitres ?? defaultRequirement,\n\n isBrewedForPersonalUse:\n requirements?.isBrewedForPersonalUse ?? defaultRequirement,\n\n isDesignedForPump: requirements?.isDesignedForPump ?? defaultRequirement,\n\n spiritDutyExemptionReason:\n requirements?.spiritDutyExemptionReason ?? defaultRequirement,\n\n packageType: requirements?.packageType ?? defaultRequirement,\n\n dateOfProductionDutyRate:\n requirements?.dateOfProductionDutyRate ?? defaultRequirement,\n };\n });\n\n const dutyRuleSets = computed(() => ({\n abv: dutyRules.value.abv.required ? [ruleSet.required()] : [],\n\n manufacturer: dutyRules.value.manufacturer.required\n ? [ruleSet.required()]\n : [],\n\n unitDutiableLitres: dutyRules.value.unitDutiableLitres.required\n ? [ruleSet.required(), ruleSet.notNegativeNumber(), ruleSet.notZero()]\n : [ruleSet.notNegativeNumber()],\n\n plato: dutyRules.value.plato.required ? [ruleSet.required()] : [],\n\n germanBeerDutyProductType: dutyRules.value.germanBeerDutyProductType\n .required\n ? [ruleSet.required()]\n : [],\n\n finalUnitLitres: dutyRules.value.finalUnitLitres.required\n ? [ruleSet.required(), ruleSet.notNegativeNumber(), ruleSet.notZero()]\n : [ruleSet.notNegativeNumber(), ruleSet.notZero()],\n\n spiritDutyExemptionReason: dutyRules.value.spiritDutyExemptionReason\n .required\n ? [ruleSet.required()]\n : [],\n\n packageType: dutyRules.value.packageType.required\n ? [ruleSet.required()]\n : [],\n }));\n\n const shouldShowDutyRow = computed(() =>\n Array.from(Object.values(dutyRules.value)).some((rule) => rule.show)\n );\n\n return {\n dutyRules,\n dutyRuleSets,\n shouldShowDutyRow,\n };\n};\n\nexport const useDutyRulesForHeaders = () => {\n const dutyRules = computed(() => ({\n standardOrderType:\n dutyConfigurationStore.state.headerRequirements?.standardOrderType ??\n defaultRequirement,\n\n germanBeerDutyMovementType:\n dutyConfigurationStore.state.headerRequirements\n ?.germanBeerDutyMovementType ?? defaultRequirement,\n\n bondedStockLocation: {\n taxWarehouseCode:\n dutyConfigurationStore.state.stockLocationDutyRequirements\n ?.bondedRequirements.warehouseTaxCode ?? defaultRequirement,\n },\n\n nonBondedStockLocation: {\n taxWarehouseCode:\n dutyConfigurationStore.state.stockLocationDutyRequirements\n ?.nonBondedRequirements.warehouseTaxCode ?? defaultRequirement,\n },\n\n allowedAlcoholTypes: dutyConfigurationStore.state.allowedAlcoholTypes,\n\n stockAdjustmentDutyImplications:\n dutyConfigurationStore.state.stockAdjustmentDutyImplications,\n\n liquorLicenceNumber:\n dutyConfigurationStore.state.headerRequirements?.liquorLicenceNumber ??\n defaultRequirement,\n\n packageTypeCategory:\n dutyConfigurationStore.state.packageTypeDutyRequirements?.categoryType ??\n defaultRequirement,\n\n eireDutyMovementType:\n dutyConfigurationStore.state.headerRequirements?.eireDutyMovementType ??\n defaultRequirement,\n\n allowDraughtRelief:\n dutyConfigurationStore.state.headerRequirements?.allowDraughtRelief ??\n booleanRequirementDontShow,\n }));\n\n const dutyRuleSets = computed(() => ({\n standardOrderType: dutyRules.value.standardOrderType.required\n ? [ruleSet.required()]\n : [],\n\n germanBeerDutyMovementType: dutyRules.value.germanBeerDutyMovementType\n .required\n ? [ruleSet.required()]\n : [],\n\n bondedStockLocation: {\n taxWarehouseCode: dutyRules.value.bondedStockLocation.taxWarehouseCode\n .required\n ? [ruleSet.required()]\n : [],\n },\n\n nonBondedStockLocation: {\n taxWarehouseCode: dutyRules.value.nonBondedStockLocation.taxWarehouseCode\n .required\n ? [ruleSet.required()]\n : [],\n },\n packageTypeCategory: dutyRules.value.packageTypeCategory.required\n ? [ruleSet.required()]\n : [],\n\n eireDutyMovementType: dutyRules.value.eireDutyMovementType.required\n ? [ruleSet.required()]\n : [],\n }));\n\n // These don't revive as exact copies of the enum, so we need to evaluate against the value, not equality\n const dutyEnumFilters = computed(() => ({\n standardOrderType: (enumType: EnumStandardOrder) =>\n dutyConfigurationStore.state.headerRequirements?.allowedOrderTypes.some(\n (allowedType) => enumType.value === allowedType.value\n ),\n alcoholType: (enumType: EnumAlcoholType) =>\n dutyRules.value.allowedAlcoholTypes.some(\n (allowedType) => allowedType.value === enumType.value\n ),\n stockAdjustDutyImplication: (enumType: EnumStockAdjustDutyImplication) =>\n dutyRules.value.stockAdjustmentDutyImplications.some(\n (allowedType) => enumType.value === allowedType.value\n ),\n }));\n\n const visibleFieldsForCurrentDutyScheme = computed(() => {\n const allowedAlcoholTypes = dutyRules.value.allowedAlcoholTypes;\n return {\n isPlatoVisible: allowedAlcoholTypes.some(\n (type) => useDutyRulesForLines(ref(type)).dutyRules.value.plato.show\n ),\n isGermanBeerDutyProductTypeVisible: allowedAlcoholTypes.some(\n (type) =>\n useDutyRulesForLines(ref(type)).dutyRules.value\n .germanBeerDutyProductType.show\n ),\n isFinalUnitLitresVisible: allowedAlcoholTypes.some(\n (type) =>\n useDutyRulesForLines(ref(type)).dutyRules.value.finalUnitLitres.show\n ),\n isDesignedForPumpVisible: allowedAlcoholTypes.some(\n (type) =>\n useDutyRulesForLines(ref(type)).dutyRules.value.isDesignedForPump.show\n ),\n isBrewedForPersonalUseVisible: allowedAlcoholTypes.some(\n (type) =>\n useDutyRulesForLines(ref(type)).dutyRules.value.isBrewedForPersonalUse\n .show\n ),\n isSpiritDutyExemptionReasonVisible: allowedAlcoholTypes.some(\n (type) =>\n useDutyRulesForLines(ref(type)).dutyRules.value\n .spiritDutyExemptionReason.show\n ),\n\n isPackageTypeCategoryVisible: dutyRules.value.packageTypeCategory.show,\n\n isAllowDraughtReliefVisible: dutyRules.value.allowDraughtRelief.show,\n };\n });\n\n return {\n dutyRules,\n dutyRuleSets,\n dutyEnumFilters,\n visibleFieldsForCurrentDutyScheme,\n };\n};\n\n/**\n * Displays german beer duty product type letter. Includes\n * german beer mixed product percentage separated by a pipe\n * if product type === M\n *\n * @example \"M | 4%\"\n * \"F\"\n */\nexport const displayDutyCategoryWithMixPercentage = (\n germanBeerDutyProductType: EnumGermanBeerDutyProductType,\n germanBeerMixedProductPercentageA: number | null\n): string => {\n const categoryLetter = germanBeerDutyProductType.translation;\n\n return germanBeerDutyProductType ===\n EnumGermanBeerDutyProductType.mixedProduct_M\n ? `${categoryLetter} | ${germanBeerMixedProductPercentageA}%`\n : categoryLetter;\n};\n\n/**\n * Validation ruleset for the german duty movement type field\n * on stock transfers. This follows same validation logic as the\n * `SaveStockTransferAsync` method in StockTransferService\n */\nexport const germanDutyMovementTypeEnumRuleSetForStockTransfers = (\n fromStockLocation: ComputedRef | undefined>,\n toStockLocation: ComputedRef | undefined>\n): ComputedRef =>\n computed(() => {\n // these rulesets only apply if german beer duty movement is shown\n if (\n !useDutyRulesForHeaders().dutyRules.value.germanBeerDutyMovementType.show\n ) {\n return () => true;\n }\n\n if (!fromStockLocation.value || !toStockLocation.value) {\n return () => false;\n }\n\n // From external should ALWAYS be a NONE movement\n if (fromStockLocation.value.isExternal) {\n return ruleSet.containedInArray(\n [EnumGermanBeerDutyMovementType.none].map((arr) => arr.key),\n $m.german_duty_transfer_from_external\n );\n }\n\n // Bonded to bonded\n if (fromStockLocation.value.isBonded && toStockLocation.value.isBonded) {\n return ruleSet.containedInArray(\n [\n EnumGermanBeerDutyMovementType.dutySuspendedRemovalStayingInGermany,\n EnumGermanBeerDutyMovementType.dutyExemptRemovalGoingToEU,\n ].map((arr) => arr.key),\n $m.german_duty_transfer_taxed_taxed\n );\n }\n\n // Bonded to non-bonded\n if (fromStockLocation.value.isBonded && !toStockLocation.value.isBonded) {\n return ruleSet.containedInArray(\n [EnumGermanBeerDutyMovementType.dutiableRemoval].map((arr) => arr.key),\n $m.german_duty_transfer_taxed_non_taxed\n );\n }\n\n // Non-bonded to bonded\n if (!fromStockLocation.value.isBonded && toStockLocation.value.isBonded) {\n return ruleSet.containedInArray(\n [EnumGermanBeerDutyMovementType.none].map((arr) => arr.key),\n $m.german_duty_transfer_non_taxed_taxed\n );\n }\n\n // Non-bonded to non-bonded\n if (!fromStockLocation.value.isBonded && !toStockLocation.value.isBonded) {\n return ruleSet.containedInArray(\n [EnumGermanBeerDutyMovementType.none].map((arr) => arr.key),\n $m.german_duty_transfer_non_taxed_non_taxed\n );\n }\n\n return () => false;\n });\n\nexport class DutyConfiguration {\n constructor(public alcoholType?: EnumAlcoholType | undefined) {}\n\n get dutyConfigForLines() {\n const dr = useDutyRulesForLines(computed(() => this.alcoholType));\n return {\n dutyRules: dr.dutyRules.value,\n dutyRuleSets: dr.dutyRuleSets.value,\n shouldShowDutyRow: dr.shouldShowDutyRow.value,\n };\n }\n\n get dutyConfigForHeaders() {\n const dr = useDutyRulesForHeaders();\n return {\n dutyRules: dr.dutyRules.value,\n dutyRuleSets: dr.dutyRuleSets.value,\n visibleFieldsForCurrentDutyScheme:\n dr.visibleFieldsForCurrentDutyScheme.value,\n dutyEnumFilters: dr.dutyEnumFilters.value,\n };\n }\n}\n\nexport const dutySchemeType = computed(() => {\n // @TODO: [BREW-5797] Temporary FE implementation - Remove for BE provided value when available\n const countryCode =\n userStore.state.tenant?.locationConfiguration.locationCountryCode;\n switch (countryCode) {\n case \"AU\":\n return EnumDutyScheme.australia;\n case \"GB\":\n case \"UK\":\n return EnumDutyScheme.uk;\n case \"DE\":\n return EnumDutyScheme.germany;\n case \"ZA\":\n return EnumDutyScheme.southAfrica;\n case \"SE\":\n return EnumDutyScheme.sweden;\n case \"US\":\n return EnumDutyScheme.us;\n case \"IE\":\n return EnumDutyScheme.eire;\n case \"NZ\":\n return EnumDutyScheme.nz;\n default:\n errorLoggerService.logError(\n `Unknown duty scheme type from country code: \"${countryCode}\"`\n );\n return EnumDutyScheme.none;\n }\n});\n","import Guid from \"@/app/types/common/guid\";\nimport { MenuItem } from \"@/app/ui/navigation/types\";\nimport { dutySchemeType } from \"@/components/pages/duty/composables/dutyConfiguration\";\nimport { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\nimport { keys } from \"@/plugins/i18n\";\nimport { RouteBuilder } from \"@/app/ui/navigation/routeBuilder\";\n\nconst builder = new RouteBuilder(\"Ullages_\");\n\nexport const ullageRoutes = {\n list: builder.route({\n url: \"/ullages/list-ullages\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"ullages\" */ \"@/pages/ullages/ListUllagesPage.vue\"\n ),\n }),\n report: builder.route({\n url: \"/ullages/ullage-report\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"ullages\" */ \"@/components/pages/ullages/UllageReport.vue\"\n ),\n }),\n createOld: builder.routeWithParams(\n {\n url: \"/ullages/create-ullage-old\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"ullages\" */ \"@/components/pages/ullages/CreateUllage.vue\"\n ),\n componentProps: (route) => ({\n outletId: Guid.tryParse(route.params.outletId),\n }),\n },\n (opts?: { outletId?: Guid | null }) => ({\n outletId: opts?.outletId?.toString() ?? \"\",\n })\n ),\n editOld: builder.routeWithParams(\n {\n url: \"/ullages/edit-ullage-old/:id\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"ullages\" */ \"@/components/pages/ullages/EditUllage.vue\"\n ),\n componentProps: (route) => ({\n ullageId: Guid.tryParse(route.params.id),\n }),\n },\n (ullageId: Guid) => ({\n id: ullageId.toString(),\n })\n ),\n create: builder.routeWithParams(\n {\n url: \"/ullages/create-ullage\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"ullages\" */ \"@/pages/ullages/UllagePage.vue\"\n ),\n componentProps: (route) => ({\n id: Guid.create(),\n createOutletId: Guid.tryParse(route.params.outletId),\n createForContainerId: Guid.tryParse(route.params.createForContainerId),\n mode: \"create\",\n }),\n },\n (opts?: {\n outletId?: Guid | null;\n createForContainerId?: Guid | null;\n }) => ({\n outletId: opts?.outletId?.toString(),\n createForContainerId: opts?.createForContainerId?.toString(),\n })\n ),\n edit: builder.routeWithParams(\n {\n url: \"/ullages/edit-ullage/:id\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"ullages\" */ \"@/pages/ullages/UllagePage.vue\"\n ),\n componentProps: (route) => ({\n id: Guid.tryParse(route.params.id),\n mode: \"edit\",\n }),\n },\n (ullageId: Guid) => ({\n id: ullageId.toString(),\n })\n ),\n view: builder.routeWithParams(\n {\n url: \"/ullages/view-ullage/:id\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"ullages\" */ \"@/pages/ullages/UllagePage.vue\"\n ),\n componentProps: (route) => ({\n id: Guid.tryParse(route.params.id),\n mode: \"view\",\n }),\n },\n (ullageId: Guid) => ({\n id: ullageId.toString(),\n })\n ),\n};\n\nexport const buildUllagesMenuItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n translationKey: keys.ullages.value,\n icon: \"delete\",\n visible: () =>\n dutySchemeType.value.isUk() &&\n hasPermissionsUsingUserStore([EnumUserPermission.menuUllagesView]),\n subMenus: [\n MenuItem.forRoute(keys.ullages_list, ullageRoutes.list),\n MenuItem.forRoute(keys.ullages_report, ullageRoutes.report),\n ],\n }),\n];\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumDeliveryNotificationSetting } from \"./enums/enumDeliveryNotificationSetting.generated\";\nimport { EnumDistributionType } from \"./enums/enumDistributionType.generated\";\nimport { EnumEireMovementType } from \"./enums/enumEireMovementType.generated\";\nimport { EnumEmailDocumentGrouping } from \"./enums/enumEmailDocumentGrouping.generated\";\nimport { EnumExportIncotermCode } from \"./enums/enumExportIncotermCode.generated\";\nimport { EnumGermanBeerDutyMovementType } from \"./enums/enumGermanBeerDutyMovementType.generated\";\nimport { EnumStandardOrder } from \"./enums/enumStandardOrder.generated\";\n\n// Model Objects\n\nexport class OutletSummary extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Internal name shown only to the users of the BrewMan system\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public displayName: string = \"\";\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressLine1: string = \"\";\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressLine2: string = \"\";\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressLine3: string = \"\";\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressLine4: string = \"\";\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressLine5: string = \"\";\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressLine6: string = \"\";\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressPostcode: string = \"\";\n /**\n * Outlet Code\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public code: string = \"\";\n /**\n * Identifies if this is a Retail Outlet.\n */\n public isRetail: boolean = false;\n public isHidden: boolean = false;\n /**\n * Email Invoices\n */\n public emailInvoices: boolean = false;\n private _groupId: Guid | null = null;\n /**\n * Outlet Group\n */\n public get groupId(): Guid | null { return this._groupId }\n public set groupId(value: Guid | null) {\n this._groupId = value === undefined ? null : value;\n }\n private _salesCodeId: Guid | null = null;\n /**\n * Sales Code Id\n */\n public get salesCodeId(): Guid | null { return this._salesCodeId }\n public set salesCodeId(value: Guid | null) {\n this._salesCodeId = value === undefined ? null : value;\n }\n private _salesAreaId: Guid | null = null;\n /**\n * Sales Area Id\n */\n public get salesAreaId(): Guid | null { return this._salesAreaId }\n public set salesAreaId(value: Guid | null) {\n this._salesAreaId = value === undefined ? null : value;\n }\n /**\n * Outlet Rating\n */\n public outletRatingId: Guid = Guid.createEmpty();\n private _outletTypeId: Guid | null = null;\n /**\n * Outlet Type\n */\n public get outletTypeId(): Guid | null { return this._outletTypeId }\n public set outletTypeId(value: Guid | null) {\n this._outletTypeId = value === undefined ? null : value;\n }\n /**\n * Outlet Standard Order Type 0=Full Price - Duty Paid 1=Price Excluding Duty - Duty Suspended 2=Full Price - Duty Paid Elsewhere 3=Export - Duty Suspended\n */\n public standardOrderType: EnumStandardOrder = EnumStandardOrder.fullPriceDutyPaid;\n private _deliveryAreaId: Guid | null = null;\n /**\n * Delivery Area\n */\n public get deliveryAreaId(): Guid | null { return this._deliveryAreaId }\n public set deliveryAreaId(value: Guid | null) {\n this._deliveryAreaId = value === undefined ? null : value;\n }\n /**\n * Price List\n */\n public priceListId: Guid = Guid.createEmpty();\n private _creditTermsId: Guid | null = null;\n /**\n * Credit Terms\n */\n public get creditTermsId(): Guid | null { return this._creditTermsId }\n public set creditTermsId(value: Guid | null) {\n this._creditTermsId = value === undefined ? null : value;\n }\n /**\n * Telephone number\n * Not Nullable\n * Max Length : 1000\n */\n public telephoneNumber: string = \"\";\n /**\n * Distribution Type : 0 = None, 1 = Delivery, 2 = Courier, 3 = Collection\n */\n public distributionType: EnumDistributionType = EnumDistributionType.none;\n public germanBeerDutyMovementType: EnumGermanBeerDutyMovementType = EnumGermanBeerDutyMovementType.none;\n /**\n * Default Stock Location\n */\n public stockLocationId: Guid = Guid.createEmpty();\n private _mainLongitude: number | null = null;\n /**\n * Longitude\n */\n public get mainLongitude(): number | null { return this._mainLongitude }\n public set mainLongitude(value: number | null) {\n this._mainLongitude = value === undefined ? null : value;\n }\n private _mainLatitude: number | null = null;\n /**\n * Latitude\n */\n public get mainLatitude(): number | null { return this._mainLatitude }\n public set mainLatitude(value: number | null) {\n this._mainLatitude = value === undefined ? null : value;\n }\n public eireDutyMovementType: EnumEireMovementType = EnumEireMovementType.unknown;\n /**\n * Product Requirements, eg minimum batch expiry lifetime. Not applicable if Outlet is in a group with UseGroupProductRequirementsForAllOutlets true\n * Not Nullable\n * Max Length : 1000\n */\n public productRequirements: string = \"\";\n public webAddress: string = \"\";\n /**\n * Email Address\n * Not Nullable\n * Max Length : 1000\n */\n public emailAddress: string = \"\";\n /**\n * Sales Notes\n * Not Nullable\n * Max Length : 100000\n */\n public salesNotes: string = \"\";\n private _lastOrderDeliveredDate: LocalDate | null = null;\n /**\n * The most recent delivery date of a completed order associated with this outlet. Captured by system not user editable.\n */\n public get lastOrderDeliveredDate(): LocalDate | null { return this._lastOrderDeliveredDate }\n public set lastOrderDeliveredDate(value: LocalDate | null) {\n this._lastOrderDeliveredDate = value === undefined ? null : value;\n }\n private _placedOnHoldAt: Instant | null = null;\n /**\n * The time when Outlet was set as On Hold\n */\n public get placedOnHoldAt(): Instant | null { return this._placedOnHoldAt }\n public set placedOnHoldAt(value: Instant | null) {\n this._placedOnHoldAt = value === undefined ? null : value;\n }\n /**\n * Identifies if this is Outlet allows order lines to be added qualifying for draught duty rates. For UK, if not allowed then new order lines will always add as DesignedForPump=false. \n */\n public allowDraughtRelief: boolean = false;\n /**\n * The default phone number to use for delivery issues and updates.\n * Not Nullable\n * Max Length : 1000\n */\n public defaultDeliveryTelephoneNumber: string = \"\";\n /**\n * Text to appear on Delivery Notes\n * Not Nullable\n * Max Length : 100000\n */\n public deliveryNoteText: string = \"\";\n /**\n * Notes to appear on the Dray Run\n * Not Nullable\n * Max Length : 100000\n */\n public drayRunNotes: string = \"\";\n private _outletSubTypeId: Guid | null = null;\n /**\n * Outlet Sub Type\n */\n public get outletSubTypeId(): Guid | null { return this._outletSubTypeId }\n public set outletSubTypeId(value: Guid | null) {\n this._outletSubTypeId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.displayName = jsonSerializedObject.displayName;\n this.mainAddressLine1 = jsonSerializedObject.mainAddressLine1;\n this.mainAddressLine2 = jsonSerializedObject.mainAddressLine2;\n this.mainAddressLine3 = jsonSerializedObject.mainAddressLine3;\n this.mainAddressLine4 = jsonSerializedObject.mainAddressLine4;\n this.mainAddressLine5 = jsonSerializedObject.mainAddressLine5;\n this.mainAddressLine6 = jsonSerializedObject.mainAddressLine6;\n this.mainAddressPostcode = jsonSerializedObject.mainAddressPostcode;\n this.code = jsonSerializedObject.code;\n this.isRetail = jsonSerializedObject.isRetail;\n this.isHidden = jsonSerializedObject.isHidden;\n this.emailInvoices = jsonSerializedObject.emailInvoices;\n this.groupId = jsonSerializedObject.groupId == null ? null : Guid.fromString(jsonSerializedObject.groupId);\n this.salesCodeId = jsonSerializedObject.salesCodeId == null ? null : Guid.fromString(jsonSerializedObject.salesCodeId);\n this.salesAreaId = jsonSerializedObject.salesAreaId == null ? null : Guid.fromString(jsonSerializedObject.salesAreaId);\n this.outletRatingId = Guid.fromString(jsonSerializedObject.outletRatingId);\n this.outletTypeId = jsonSerializedObject.outletTypeId == null ? null : Guid.fromString(jsonSerializedObject.outletTypeId);\n this.standardOrderType = EnumStandardOrder.getByValue(jsonSerializedObject.standardOrderType, this.standardOrderType);\n this.deliveryAreaId = jsonSerializedObject.deliveryAreaId == null ? null : Guid.fromString(jsonSerializedObject.deliveryAreaId);\n this.priceListId = Guid.fromString(jsonSerializedObject.priceListId);\n this.creditTermsId = jsonSerializedObject.creditTermsId == null ? null : Guid.fromString(jsonSerializedObject.creditTermsId);\n this.telephoneNumber = jsonSerializedObject.telephoneNumber;\n this.distributionType = EnumDistributionType.getByValue(jsonSerializedObject.distributionType, this.distributionType);\n this.germanBeerDutyMovementType = EnumGermanBeerDutyMovementType.getByValue(jsonSerializedObject.germanBeerDutyMovementType, this.germanBeerDutyMovementType);\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.mainLongitude = jsonSerializedObject.mainLongitude == null ? null : jsonSerializedObject.mainLongitude;\n this.mainLatitude = jsonSerializedObject.mainLatitude == null ? null : jsonSerializedObject.mainLatitude;\n this.eireDutyMovementType = EnumEireMovementType.getByValue(jsonSerializedObject.eireDutyMovementType, this.eireDutyMovementType);\n this.productRequirements = jsonSerializedObject.productRequirements;\n this.webAddress = jsonSerializedObject.webAddress;\n this.emailAddress = jsonSerializedObject.emailAddress;\n this.salesNotes = jsonSerializedObject.salesNotes;\n this.lastOrderDeliveredDate = jsonSerializedObject.lastOrderDeliveredDate == null ? null : LocalDate.parse(jsonSerializedObject.lastOrderDeliveredDate);\n this.placedOnHoldAt = jsonSerializedObject.placedOnHoldAt == null ? null : Instant.parse(jsonSerializedObject.placedOnHoldAt);\n this.allowDraughtRelief = jsonSerializedObject.allowDraughtRelief;\n this.defaultDeliveryTelephoneNumber = jsonSerializedObject.defaultDeliveryTelephoneNumber;\n this.deliveryNoteText = jsonSerializedObject.deliveryNoteText;\n this.drayRunNotes = jsonSerializedObject.drayRunNotes;\n this.outletSubTypeId = jsonSerializedObject.outletSubTypeId == null ? null : Guid.fromString(jsonSerializedObject.outletSubTypeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.displayName = this.displayName;\n toRet.mainAddressLine1 = this.mainAddressLine1;\n toRet.mainAddressLine2 = this.mainAddressLine2;\n toRet.mainAddressLine3 = this.mainAddressLine3;\n toRet.mainAddressLine4 = this.mainAddressLine4;\n toRet.mainAddressLine5 = this.mainAddressLine5;\n toRet.mainAddressLine6 = this.mainAddressLine6;\n toRet.mainAddressPostcode = this.mainAddressPostcode;\n toRet.code = this.code;\n toRet.isRetail = this.isRetail;\n toRet.isHidden = this.isHidden;\n toRet.emailInvoices = this.emailInvoices;\n toRet.groupId = this.groupId == null ? null : this.groupId.toString();\n toRet.salesCodeId = this.salesCodeId == null ? null : this.salesCodeId.toString();\n toRet.salesAreaId = this.salesAreaId == null ? null : this.salesAreaId.toString();\n toRet.outletRatingId = this.outletRatingId.toString();\n toRet.outletTypeId = this.outletTypeId == null ? null : this.outletTypeId.toString();\n toRet.standardOrderType = this.standardOrderType.value;\n toRet.deliveryAreaId = this.deliveryAreaId == null ? null : this.deliveryAreaId.toString();\n toRet.priceListId = this.priceListId.toString();\n toRet.creditTermsId = this.creditTermsId == null ? null : this.creditTermsId.toString();\n toRet.telephoneNumber = this.telephoneNumber;\n toRet.distributionType = this.distributionType.value;\n toRet.germanBeerDutyMovementType = this.germanBeerDutyMovementType.value;\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.mainLongitude = this.mainLongitude == null ? null : this.mainLongitude;\n toRet.mainLatitude = this.mainLatitude == null ? null : this.mainLatitude;\n toRet.eireDutyMovementType = this.eireDutyMovementType.value;\n toRet.productRequirements = this.productRequirements;\n toRet.webAddress = this.webAddress;\n toRet.emailAddress = this.emailAddress;\n toRet.salesNotes = this.salesNotes;\n toRet.lastOrderDeliveredDate = this.lastOrderDeliveredDate == null ? null : this.lastOrderDeliveredDate.toString();\n toRet.placedOnHoldAt = this.placedOnHoldAt == null ? null : this.placedOnHoldAt.toString();\n toRet.allowDraughtRelief = this.allowDraughtRelief;\n toRet.defaultDeliveryTelephoneNumber = this.defaultDeliveryTelephoneNumber;\n toRet.deliveryNoteText = this.deliveryNoteText;\n toRet.drayRunNotes = this.drayRunNotes;\n toRet.outletSubTypeId = this.outletSubTypeId == null ? null : this.outletSubTypeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"OutletSummary.Id cannot be empty\"},\n {field: \"displayName\", rule: (v: any) => v == null || v.length !== 0 || \"DisplayName cannot be empty\"},\n {field: \"displayName\", rule: (v: any) => v == null || v.length <= 1000 || \"DisplayName has too many characters (1000)\"},\n {field: \"mainAddressLine1\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressLine1 has too many characters (1000)\"},\n {field: \"mainAddressLine2\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressLine2 has too many characters (1000)\"},\n {field: \"mainAddressLine3\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressLine3 has too many characters (1000)\"},\n {field: \"mainAddressLine4\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressLine4 has too many characters (1000)\"},\n {field: \"mainAddressLine5\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressLine5 has too many characters (1000)\"},\n {field: \"mainAddressLine6\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressLine6 has too many characters (1000)\"},\n {field: \"mainAddressPostcode\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressPostcode has too many characters (1000)\"},\n {field: \"code\", rule: (v: any) => v == null || v.length !== 0 || \"Code cannot be empty\"},\n {field: \"code\", rule: (v: any) => v == null || v.length <= 1000 || \"Code has too many characters (1000)\"},\n {field: \"groupId\", rule: (v: any) => v == null || !v.isEmpty() || \"OutletSummary.GroupId cannot be empty\"},\n {field: \"salesCodeId\", rule: (v: any) => v == null || !v.isEmpty() || \"OutletSummary.SalesCodeId cannot be empty\"},\n {field: \"salesAreaId\", rule: (v: any) => v == null || !v.isEmpty() || \"OutletSummary.SalesAreaId cannot be empty\"},\n {field: \"outletRatingId\", rule: (v: any) => !v.isEmpty() || \"OutletSummary.OutletRatingId cannot be empty\"},\n {field: \"outletTypeId\", rule: (v: any) => v == null || !v.isEmpty() || \"OutletSummary.OutletTypeId cannot be empty\"},\n {field: \"deliveryAreaId\", rule: (v: any) => v == null || !v.isEmpty() || \"OutletSummary.DeliveryAreaId cannot be empty\"},\n {field: \"priceListId\", rule: (v: any) => !v.isEmpty() || \"OutletSummary.PriceListId cannot be empty\"},\n {field: \"creditTermsId\", rule: (v: any) => v == null || !v.isEmpty() || \"OutletSummary.CreditTermsId cannot be empty\"},\n {field: \"telephoneNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"TelephoneNumber has too many characters (1000)\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \"OutletSummary.StockLocationId cannot be empty\"},\n {field: \"productRequirements\", rule: (v: any) => v == null || v.length <= 1000 || \"ProductRequirements has too many characters (1000)\"},\n {field: \"webAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"WebAddress has too many characters (1000)\"},\n {field: \"emailAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"EmailAddress has too many characters (1000)\"},\n {field: \"salesNotes\", rule: (v: any) => v == null || v.length <= 100000 || \"SalesNotes has too many characters (100000)\"},\n {field: \"defaultDeliveryTelephoneNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultDeliveryTelephoneNumber has too many characters (1000)\"},\n {field: \"deliveryNoteText\", rule: (v: any) => v == null || v.length <= 100000 || \"DeliveryNoteText has too many characters (100000)\"},\n {field: \"drayRunNotes\", rule: (v: any) => v == null || v.length <= 100000 || \"DrayRunNotes has too many characters (100000)\"},\n {field: \"outletSubTypeId\", rule: (v: any) => v == null || !v.isEmpty() || \"OutletSummary.OutletSubTypeId cannot be empty\"},\n ];\n}\n\n\nexport class Contact extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Outlet Id\n */\n public outletId: Guid = Guid.createEmpty();\n /**\n * Forename\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public forename: string = \"\";\n /**\n * Surname\n * Not Nullable\n * Max Length : 1000\n */\n public surname: string = \"\";\n /**\n * Salutation\n * Not Nullable\n * Max Length : 1000\n */\n public salutation: string = \"\";\n /**\n * JobTitle\n * Not Nullable\n * Max Length : 1000\n */\n public jobTitle: string = \"\";\n /**\n * Telephone number\n * Not Nullable\n * Max Length : 1000\n */\n public phoneNumber: string = \"\";\n /**\n * Phone Extension\n * Not Nullable\n * Max Length : 1000\n */\n public phoneExtension: string = \"\";\n /**\n * Mobile Phone Number\n * Not Nullable\n * Max Length : 1000\n */\n public mobileNumber: string = \"\";\n /**\n * Email Address\n * Not Nullable\n * Max Length : 1000\n */\n public emailAddress: string = \"\";\n /**\n * Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n /**\n * Address Line 1\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine1: string = \"\";\n /**\n * Address Line 2\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine2: string = \"\";\n /**\n * Address Line 3\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine3: string = \"\";\n /**\n * Address Line 4\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine4: string = \"\";\n /**\n * Address Line 5\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine5: string = \"\";\n /**\n * Address Line 6\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine6: string = \"\";\n /**\n * Postcode\n * Not Nullable\n * Max Length : 1000\n */\n public postcode: string = \"\";\n /**\n * Receives invoices\n */\n public areasInvoice: boolean = false;\n /**\n * Deals with orders\n */\n public areasOrders: boolean = false;\n /**\n * Receives delivery notes\n */\n public areasDeliveries: boolean = false;\n /**\n * Received marketing communication\n */\n public areasMarketing: boolean = false;\n /**\n * Deals with account queries\n */\n public areasAccounts: boolean = false;\n /**\n * Primary contact of the outlet. Should only have one primary contact per outlet.\n */\n public isPrimaryContact: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n this.forename = jsonSerializedObject.forename;\n this.surname = jsonSerializedObject.surname;\n this.salutation = jsonSerializedObject.salutation;\n this.jobTitle = jsonSerializedObject.jobTitle;\n this.phoneNumber = jsonSerializedObject.phoneNumber;\n this.phoneExtension = jsonSerializedObject.phoneExtension;\n this.mobileNumber = jsonSerializedObject.mobileNumber;\n this.emailAddress = jsonSerializedObject.emailAddress;\n this.notes = jsonSerializedObject.notes;\n this.addressLine1 = jsonSerializedObject.addressLine1;\n this.addressLine2 = jsonSerializedObject.addressLine2;\n this.addressLine3 = jsonSerializedObject.addressLine3;\n this.addressLine4 = jsonSerializedObject.addressLine4;\n this.addressLine5 = jsonSerializedObject.addressLine5;\n this.addressLine6 = jsonSerializedObject.addressLine6;\n this.postcode = jsonSerializedObject.postcode;\n this.areasInvoice = jsonSerializedObject.areasInvoice;\n this.areasOrders = jsonSerializedObject.areasOrders;\n this.areasDeliveries = jsonSerializedObject.areasDeliveries;\n this.areasMarketing = jsonSerializedObject.areasMarketing;\n this.areasAccounts = jsonSerializedObject.areasAccounts;\n this.isPrimaryContact = jsonSerializedObject.isPrimaryContact;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.outletId = this.outletId.toString();\n toRet.forename = this.forename;\n toRet.surname = this.surname;\n toRet.salutation = this.salutation;\n toRet.jobTitle = this.jobTitle;\n toRet.phoneNumber = this.phoneNumber;\n toRet.phoneExtension = this.phoneExtension;\n toRet.mobileNumber = this.mobileNumber;\n toRet.emailAddress = this.emailAddress;\n toRet.notes = this.notes;\n toRet.addressLine1 = this.addressLine1;\n toRet.addressLine2 = this.addressLine2;\n toRet.addressLine3 = this.addressLine3;\n toRet.addressLine4 = this.addressLine4;\n toRet.addressLine5 = this.addressLine5;\n toRet.addressLine6 = this.addressLine6;\n toRet.postcode = this.postcode;\n toRet.areasInvoice = this.areasInvoice;\n toRet.areasOrders = this.areasOrders;\n toRet.areasDeliveries = this.areasDeliveries;\n toRet.areasMarketing = this.areasMarketing;\n toRet.areasAccounts = this.areasAccounts;\n toRet.isPrimaryContact = this.isPrimaryContact;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"Contact.Id cannot be empty\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \"Contact.OutletId cannot be empty\"},\n {field: \"forename\", rule: (v: any) => v == null || v.length !== 0 || \"Forename cannot be empty\"},\n {field: \"forename\", rule: (v: any) => v == null || v.length <= 1000 || \"Forename has too many characters (1000)\"},\n {field: \"surname\", rule: (v: any) => v == null || v.length <= 1000 || \"Surname has too many characters (1000)\"},\n {field: \"salutation\", rule: (v: any) => v == null || v.length <= 1000 || \"Salutation has too many characters (1000)\"},\n {field: \"jobTitle\", rule: (v: any) => v == null || v.length <= 1000 || \"JobTitle has too many characters (1000)\"},\n {field: \"phoneNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"PhoneNumber has too many characters (1000)\"},\n {field: \"phoneExtension\", rule: (v: any) => v == null || v.length <= 1000 || \"PhoneExtension has too many characters (1000)\"},\n {field: \"mobileNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"MobileNumber has too many characters (1000)\"},\n {field: \"emailAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"EmailAddress has too many characters (1000)\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"addressLine1\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine1 has too many characters (1000)\"},\n {field: \"addressLine2\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine2 has too many characters (1000)\"},\n {field: \"addressLine3\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine3 has too many characters (1000)\"},\n {field: \"addressLine4\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine4 has too many characters (1000)\"},\n {field: \"addressLine5\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine5 has too many characters (1000)\"},\n {field: \"addressLine6\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine6 has too many characters (1000)\"},\n {field: \"postcode\", rule: (v: any) => v == null || v.length <= 1000 || \"Postcode has too many characters (1000)\"},\n ];\n}\n\n\nexport class OutletReadOnly extends ModelObject {\n\n /**\n * Identifies if this is a Retail Outlet.\n */\n public isRetail: boolean = false;\n private _defaultDeliveryLatitude: number | null = null;\n /**\n * Default Latitude of delviery address (if known)\n */\n public get defaultDeliveryLatitude(): number | null { return this._defaultDeliveryLatitude }\n public set defaultDeliveryLatitude(value: number | null) {\n this._defaultDeliveryLatitude = value === undefined ? null : value;\n }\n private _defaultDeliveryLongitude: number | null = null;\n /**\n * Default Longitude of delviery address (if known)\n */\n public get defaultDeliveryLongitude(): number | null { return this._defaultDeliveryLongitude }\n public set defaultDeliveryLongitude(value: number | null) {\n this._defaultDeliveryLongitude = value === undefined ? null : value;\n }\n private _mainLongitude: number | null = null;\n /**\n * Longitude\n */\n public get mainLongitude(): number | null { return this._mainLongitude }\n public set mainLongitude(value: number | null) {\n this._mainLongitude = value === undefined ? null : value;\n }\n private _mainLatitude: number | null = null;\n /**\n * Latitude\n */\n public get mainLatitude(): number | null { return this._mainLatitude }\n public set mainLatitude(value: number | null) {\n this._mainLatitude = value === undefined ? null : value;\n }\n /**\n * Outlet Code\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public code: string = \"\";\n private _placedOnHoldAt: Instant | null = null;\n /**\n * The time when Outlet was set as On Hold\n */\n public get placedOnHoldAt(): Instant | null { return this._placedOnHoldAt }\n public set placedOnHoldAt(value: Instant | null) {\n this._placedOnHoldAt = value === undefined ? null : value;\n }\n private _placedOnHoldByUserId: Guid | null = null;\n /**\n * User who set this Outlet as On Hold\n */\n public get placedOnHoldByUserId(): Guid | null { return this._placedOnHoldByUserId }\n public set placedOnHoldByUserId(value: Guid | null) {\n this._placedOnHoldByUserId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.isRetail = jsonSerializedObject.isRetail;\n this.defaultDeliveryLatitude = jsonSerializedObject.defaultDeliveryLatitude == null ? null : jsonSerializedObject.defaultDeliveryLatitude;\n this.defaultDeliveryLongitude = jsonSerializedObject.defaultDeliveryLongitude == null ? null : jsonSerializedObject.defaultDeliveryLongitude;\n this.mainLongitude = jsonSerializedObject.mainLongitude == null ? null : jsonSerializedObject.mainLongitude;\n this.mainLatitude = jsonSerializedObject.mainLatitude == null ? null : jsonSerializedObject.mainLatitude;\n this.code = jsonSerializedObject.code;\n this.placedOnHoldAt = jsonSerializedObject.placedOnHoldAt == null ? null : Instant.parse(jsonSerializedObject.placedOnHoldAt);\n this.placedOnHoldByUserId = jsonSerializedObject.placedOnHoldByUserId == null ? null : Guid.fromString(jsonSerializedObject.placedOnHoldByUserId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.isRetail = this.isRetail;\n toRet.defaultDeliveryLatitude = this.defaultDeliveryLatitude == null ? null : this.defaultDeliveryLatitude;\n toRet.defaultDeliveryLongitude = this.defaultDeliveryLongitude == null ? null : this.defaultDeliveryLongitude;\n toRet.mainLongitude = this.mainLongitude == null ? null : this.mainLongitude;\n toRet.mainLatitude = this.mainLatitude == null ? null : this.mainLatitude;\n toRet.code = this.code;\n toRet.placedOnHoldAt = this.placedOnHoldAt == null ? null : this.placedOnHoldAt.toString();\n toRet.placedOnHoldByUserId = this.placedOnHoldByUserId == null ? null : this.placedOnHoldByUserId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"code\", rule: (v: any) => v == null || v.length !== 0 || \"Code cannot be empty\"},\n {field: \"code\", rule: (v: any) => v == null || v.length <= 1000 || \"Code has too many characters (1000)\"},\n {field: \"placedOnHoldByUserId\", rule: (v: any) => v == null || !v.isEmpty() || \"OutletReadOnly.PlacedOnHoldByUserId cannot be empty\"},\n ];\n}\n\n\nexport class Outlet extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n public isHidden: boolean = false;\n /**\n * Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public businessName: string = \"\";\n /**\n * Internal name shown only to the users of the BrewMan system\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public displayName: string = \"\";\n /**\n * Telephone number\n * Not Nullable\n * Max Length : 1000\n */\n public telephoneNumber: string = \"\";\n /**\n * Email Address\n * Not Nullable\n * Max Length : 1000\n */\n public emailAddress: string = \"\";\n private _groupId: Guid | null = null;\n /**\n * Outlet Group\n */\n public get groupId(): Guid | null { return this._groupId }\n public set groupId(value: Guid | null) {\n this._groupId = value === undefined ? null : value;\n }\n private _salesAreaId: Guid | null = null;\n /**\n * Sales Area Id\n */\n public get salesAreaId(): Guid | null { return this._salesAreaId }\n public set salesAreaId(value: Guid | null) {\n this._salesAreaId = value === undefined ? null : value;\n }\n private _salesCodeId: Guid | null = null;\n /**\n * Sales Code Id\n */\n public get salesCodeId(): Guid | null { return this._salesCodeId }\n public set salesCodeId(value: Guid | null) {\n this._salesCodeId = value === undefined ? null : value;\n }\n /**\n * Outlet Rating\n */\n public outletRatingId: Guid = Guid.createEmpty();\n private _outletTypeId: Guid | null = null;\n /**\n * Outlet Type\n */\n public get outletTypeId(): Guid | null { return this._outletTypeId }\n public set outletTypeId(value: Guid | null) {\n this._outletTypeId = value === undefined ? null : value;\n }\n /**\n * Default Stock Location\n */\n public stockLocationId: Guid = Guid.createEmpty();\n private _outletSubTypeId: Guid | null = null;\n /**\n * Outlet Sub Type\n */\n public get outletSubTypeId(): Guid | null { return this._outletSubTypeId }\n public set outletSubTypeId(value: Guid | null) {\n this._outletSubTypeId = value === undefined ? null : value;\n }\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressLine1: string = \"\";\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressLine2: string = \"\";\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressLine3: string = \"\";\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressLine4: string = \"\";\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressLine5: string = \"\";\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressLine6: string = \"\";\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressPostcode: string = \"\";\n /**\n * Price List\n */\n public priceListId: Guid = Guid.createEmpty();\n /**\n * VAT Registration No.\n * Not Nullable\n * Max Length : 1000\n */\n public vatNumber: string = \"\";\n /**\n * Credit Terms Set\n */\n public creditTermsSet: boolean = false;\n private _creditTermsId: Guid | null = null;\n /**\n * Credit Terms\n */\n public get creditTermsId(): Guid | null { return this._creditTermsId }\n public set creditTermsId(value: Guid | null) {\n this._creditTermsId = value === undefined ? null : value;\n }\n private _creditLimit: number | null = null;\n /**\n * Credit Limit\n * Not Negative\n */\n public get creditLimit(): number | null { return this._creditLimit }\n public set creditLimit(value: number | null) {\n this._creditLimit = value === undefined ? null : value;\n }\n private _reviewDate: LocalDate | null = null;\n /**\n * Credit Review Date\n */\n public get reviewDate(): LocalDate | null { return this._reviewDate }\n public set reviewDate(value: LocalDate | null) {\n this._reviewDate = value === undefined ? null : value;\n }\n /**\n * Bank Name\n * Not Nullable\n * Max Length : 1000\n */\n public bankName: string = \"\";\n /**\n * Bank Sort Code\n * Not Nullable\n * Max Length : 1000\n */\n public bankSortCode: string = \"\";\n /**\n * Bank Account No\n * Not Nullable\n * Max Length : 1000\n */\n public bankAccountNumber: string = \"\";\n /**\n * Credit Term Notes\n * Not Nullable\n * Max Length : 100000\n */\n public creditTermNotes: string = \"\";\n /**\n * Email Invoices\n */\n public emailInvoices: boolean = false;\n private _defaultInvoiceTemplateId: Guid | null = null;\n /**\n * Default Invoice Template Id\n */\n public get defaultInvoiceTemplateId(): Guid | null { return this._defaultInvoiceTemplateId }\n public set defaultInvoiceTemplateId(value: Guid | null) {\n this._defaultInvoiceTemplateId = value === undefined ? null : value;\n }\n /**\n * Default invoice recipient\n * Not Nullable\n * Max Length : 1000\n */\n public defaultInvoiceRecipient: string = \"\";\n /**\n * The default email address invoices will be sent to if not updated by the order.\n * Not Nullable\n * Max Length : 1000\n */\n public defaultInvoiceEmailAddress: string = \"\";\n /**\n * HasDefaultInvoiceAddress\n */\n public hasDefaultInvoiceAddress: boolean = false;\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public defaultInvoiceAddressBusiness: string = \"\";\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public defaultInvoiceAddressLine1: string = \"\";\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public defaultInvoiceAddressLine2: string = \"\";\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public defaultInvoiceAddressLine3: string = \"\";\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public defaultInvoiceAddressLine4: string = \"\";\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public defaultInvoiceAddressLine5: string = \"\";\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public defaultInvoiceAddressLine6: string = \"\";\n /**\n * Default Invoice Address\n * Not Nullable\n * Max Length : 1000\n */\n public defaultInvoiceAddressPostcode: string = \"\";\n /**\n * Country Code (for Accounts)\n * Not Nullable\n * Max Length : 1000\n */\n public countryCode: string = \"\";\n /**\n * Accounts Department No (1-999)\n */\n public accountsDepartmentNumber: number = 0;\n private _defaultDespatchNoteTemplateId: Guid | null = null;\n /**\n * Default Despatch Note Template Id\n */\n public get defaultDespatchNoteTemplateId(): Guid | null { return this._defaultDespatchNoteTemplateId }\n public set defaultDespatchNoteTemplateId(value: Guid | null) {\n this._defaultDespatchNoteTemplateId = value === undefined ? null : value;\n }\n private _courierId: Guid | null = null;\n /**\n * Courier\n */\n public get courierId(): Guid | null { return this._courierId }\n public set courierId(value: Guid | null) {\n this._courierId = value === undefined ? null : value;\n }\n private _deliveryAreaId: Guid | null = null;\n /**\n * Delivery Area\n */\n public get deliveryAreaId(): Guid | null { return this._deliveryAreaId }\n public set deliveryAreaId(value: Guid | null) {\n this._deliveryAreaId = value === undefined ? null : value;\n }\n private _deliveryTimeEnd: LocalTime | null = null;\n /**\n * End of delivery window\n */\n public get deliveryTimeEnd(): LocalTime | null { return this._deliveryTimeEnd }\n public set deliveryTimeEnd(value: LocalTime | null) {\n this._deliveryTimeEnd = value === undefined ? null : value;\n }\n private _deliveryTimeStart: LocalTime | null = null;\n /**\n * Start of delivery window\n */\n public get deliveryTimeStart(): LocalTime | null { return this._deliveryTimeStart }\n public set deliveryTimeStart(value: LocalTime | null) {\n this._deliveryTimeStart = value === undefined ? null : value;\n }\n /**\n * Distribution Type : 0 = None, 1 = Delivery, 2 = Courier, 3 = Collection\n */\n public distributionType: EnumDistributionType = EnumDistributionType.none;\n /**\n * Stop Minutes\n */\n public stopMinutes: number = 0;\n /**\n * Text to appear on Delivery Notes\n * Not Nullable\n * Max Length : 100000\n */\n public deliveryNoteText: string = \"\";\n /**\n * Notes to appear on the Dray Run\n * Not Nullable\n * Max Length : 100000\n */\n public drayRunNotes: string = \"\";\n /**\n * EORI Number\n * Not Nullable\n * Max Length : 1000\n */\n public eoriNumber: string = \"\";\n /**\n * Exporting Incoterm Code : 0 = None, 1 = EXW, 2 = FCA, 3 = FAS, 4 = FOB, 5 = CFR, 6 = CIF, 7 = CIP, 8 = DPU, 9 = DDP, 10 = CPT, 11 = DAP\n */\n public exportingIncotermCode: EnumExportIncotermCode = EnumExportIncotermCode.none;\n /**\n * Exporting Incoterm Place\n * Not Nullable\n * Max Length : 1000\n */\n public exportingIncotermPlace: string = \"\";\n /**\n * The default email address to use for delivery issues and updates.\n * Not Nullable\n * Max Length : 1000\n */\n public defaultDeliveryEmailAddress: string = \"\";\n /**\n * The default phone number to use for delivery issues and updates.\n * Not Nullable\n * Max Length : 1000\n */\n public defaultDeliveryTelephoneNumber: string = \"\";\n /**\n * The recipient of the delivery\n * Not Nullable\n * Max Length : 1000\n */\n public defaultDeliveryRecipient: string = \"\";\n /**\n * HasDefaultDeliveryAddress\n */\n public hasDefaultDeliveryAddress: boolean = false;\n /**\n * Default Delivery Address\n * Not Nullable\n * Max Length : 1000\n */\n public defaultDeliveryAddressBusiness: string = \"\";\n /**\n * Default Delivery Address\n * Not Nullable\n * Max Length : 1000\n */\n public defaultDeliveryAddressLine1: string = \"\";\n /**\n * Default Delivery Address\n * Not Nullable\n * Max Length : 1000\n */\n public defaultDeliveryAddressLine2: string = \"\";\n /**\n * Default Delivery Address\n * Not Nullable\n * Max Length : 1000\n */\n public defaultDeliveryAddressLine3: string = \"\";\n /**\n * Default Delivery Address\n * Not Nullable\n * Max Length : 1000\n */\n public defaultDeliveryAddressLine4: string = \"\";\n /**\n * Default Delivery Address\n * Not Nullable\n * Max Length : 1000\n */\n public defaultDeliveryAddressLine5: string = \"\";\n /**\n * Default Delivery Address\n * Not Nullable\n * Max Length : 1000\n */\n public defaultDeliveryAddressLine6: string = \"\";\n /**\n * Default Delivery Address\n * Not Nullable\n * Max Length : 1000\n */\n public defaultDeliveryAddressPostcode: string = \"\";\n private _lastOrderDeliveredDate: LocalDate | null = null;\n /**\n * The most recent delivery date of a completed order associated with this outlet. Captured by system not user editable.\n */\n public get lastOrderDeliveredDate(): LocalDate | null { return this._lastOrderDeliveredDate }\n public set lastOrderDeliveredDate(value: LocalDate | null) {\n this._lastOrderDeliveredDate = value === undefined ? null : value;\n }\n /**\n * Outlet Standard Order Type 0=Full Price - Duty Paid 1=Price Excluding Duty - Duty Suspended 2=Full Price - Duty Paid Elsewhere 3=Export - Duty Suspended\n */\n public standardOrderType: EnumStandardOrder = EnumStandardOrder.fullPriceDutyPaid;\n /**\n * VAT Code\n */\n public vatCodeId: Guid = Guid.createEmpty();\n /**\n * Application Form Returned\n */\n public applicationFormReturned: boolean = false;\n /**\n * Trading Terms\n * Not Nullable\n * Max Length : 100000\n */\n public tradingTerms: string = \"\";\n /**\n * Company Number of the outlet\n * Not Nullable\n * Max Length : 1000\n */\n public companyRegNumber: string = \"\";\n /**\n * Sales Notes\n * Not Nullable\n * Max Length : 100000\n */\n public salesNotes: string = \"\";\n public readOnly: OutletReadOnly = new OutletReadOnly();\n /**\n * International Bank Account Number\n * Not Nullable\n * Max Length : 1000\n */\n public iban: string = \"\";\n /**\n * Bank Identification Code\n * Not Nullable\n * Max Length : 1000\n */\n public bic: string = \"\";\n /**\n * The code used by Greene King to identify this outlet in exported data exchange files.\n * Not Nullable\n * Max Length : 1000\n */\n public gkSupplierCode: string = \"\";\n /**\n * The number of despatch notes to print\n * Not Negative\n */\n public despatchNoteCopiesToPrint: number = 0;\n /**\n * The number of invoice copies to print. (Not used if invoice goes to group).\n * Not Negative\n */\n public invoiceCopiesToPrint: number = 0;\n private _deliveryServiceId: Guid | null = null;\n /**\n * Delivery Service, if any, to apply by default to orders for this outlet. Has priority over group / courier / delivery area settings.\n */\n public get deliveryServiceId(): Guid | null { return this._deliveryServiceId }\n public set deliveryServiceId(value: Guid | null) {\n this._deliveryServiceId = value === undefined ? null : value;\n }\n public invoiceNotes: string = \"\";\n public germanBeerDutyMovementType: EnumGermanBeerDutyMovementType = EnumGermanBeerDutyMovementType.none;\n /**\n * Identifies how multiple documents are grouped into pdfs and emails when many documents are emailed at the same time.\n */\n public emailDocumentGrouping: EnumEmailDocumentGrouping = EnumEmailDocumentGrouping.unknown;\n /**\n * Sales Warning\n * Not Nullable\n * Max Length : 100000\n */\n public salesWarning: string = \"\";\n /**\n * Liquor Licence Number, only show for Australia and US region.\n * Not Nullable\n * Max Length : 1000\n */\n public liquorLicenceNumber: string = \"\";\n /**\n * Whether to send despatch notifications by SMS for this outlet.\n */\n public smsDespatchNotifications: EnumDeliveryNotificationSetting = EnumDeliveryNotificationSetting.unknown;\n private _smsDespatchNotificationTemplateId: Guid | null = null;\n /**\n * Template Id for sending despatch notification SMS.\n */\n public get smsDespatchNotificationTemplateId(): Guid | null { return this._smsDespatchNotificationTemplateId }\n public set smsDespatchNotificationTemplateId(value: Guid | null) {\n this._smsDespatchNotificationTemplateId = value === undefined ? null : value;\n }\n /**\n * Phone number to send Despatch SMS to, if SmsDespatchNotifications is ToSpecifiedAddress\n * Not Nullable\n * Max Length : 1000\n */\n public despatchConfirmationSmsTelephoneNumber: string = \"\";\n /**\n * Whether to send despatch notifications by Email for this outlet.\n */\n public emailDespatchNotifications: EnumDeliveryNotificationSetting = EnumDeliveryNotificationSetting.unknown;\n private _emailDespatchNotificationTemplateId: Guid | null = null;\n /**\n * Template Id for sending despatch notification Emails.\n */\n public get emailDespatchNotificationTemplateId(): Guid | null { return this._emailDespatchNotificationTemplateId }\n public set emailDespatchNotificationTemplateId(value: Guid | null) {\n this._emailDespatchNotificationTemplateId = value === undefined ? null : value;\n }\n /**\n * Email address to send Despatch Email to, if EmailDespatchNotifications is ToSpecifiedAddress\n * Not Nullable\n * Max Length : 1000\n */\n public despatchConfirmationEmailAddress: string = \"\";\n /**\n * Tax number for posting to accounts. Only shown for countries which require a Tax Number of invoice recipients such as Germany (Steuernummer).\n * Not Nullable\n * Max Length : 1000\n */\n public invoiceRecipientTaxNumber: string = \"\";\n public eireDutyMovementType: EnumEireMovementType = EnumEireMovementType.unknown;\n /**\n * Product Requirements, eg minimum batch expiry lifetime. Not applicable if Outlet is in a group with UseGroupProductRequirementsForAllOutlets true\n * Not Nullable\n * Max Length : 1000\n */\n public productRequirements: string = \"\";\n public webAddress: string = \"\";\n public facebookWebAddress: string = \"\";\n public instagramWebAddress: string = \"\";\n public twitterWebAddress: string = \"\";\n public linkedInWebAddress: string = \"\";\n public tikTokWebAddress: string = \"\";\n public threadsWebAddress: string = \"\";\n public onHoldReason: string = \"\";\n /**\n * True if PlacedOnHoldAt is not null\n */\n public onHold: boolean = false;\n /**\n * Identifies if this is Outlet allows order lines to be added qualifying for draught duty rates. For UK, if not allowed then new order lines will always add as DesignedForPump=false. \n */\n public allowDraughtRelief: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.isHidden = jsonSerializedObject.isHidden;\n this.businessName = jsonSerializedObject.businessName;\n this.displayName = jsonSerializedObject.displayName;\n this.telephoneNumber = jsonSerializedObject.telephoneNumber;\n this.emailAddress = jsonSerializedObject.emailAddress;\n this.groupId = jsonSerializedObject.groupId == null ? null : Guid.fromString(jsonSerializedObject.groupId);\n this.salesAreaId = jsonSerializedObject.salesAreaId == null ? null : Guid.fromString(jsonSerializedObject.salesAreaId);\n this.salesCodeId = jsonSerializedObject.salesCodeId == null ? null : Guid.fromString(jsonSerializedObject.salesCodeId);\n this.outletRatingId = Guid.fromString(jsonSerializedObject.outletRatingId);\n this.outletTypeId = jsonSerializedObject.outletTypeId == null ? null : Guid.fromString(jsonSerializedObject.outletTypeId);\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.outletSubTypeId = jsonSerializedObject.outletSubTypeId == null ? null : Guid.fromString(jsonSerializedObject.outletSubTypeId);\n this.mainAddressLine1 = jsonSerializedObject.mainAddressLine1;\n this.mainAddressLine2 = jsonSerializedObject.mainAddressLine2;\n this.mainAddressLine3 = jsonSerializedObject.mainAddressLine3;\n this.mainAddressLine4 = jsonSerializedObject.mainAddressLine4;\n this.mainAddressLine5 = jsonSerializedObject.mainAddressLine5;\n this.mainAddressLine6 = jsonSerializedObject.mainAddressLine6;\n this.mainAddressPostcode = jsonSerializedObject.mainAddressPostcode;\n this.priceListId = Guid.fromString(jsonSerializedObject.priceListId);\n this.vatNumber = jsonSerializedObject.vatNumber;\n this.creditTermsSet = jsonSerializedObject.creditTermsSet;\n this.creditTermsId = jsonSerializedObject.creditTermsId == null ? null : Guid.fromString(jsonSerializedObject.creditTermsId);\n this.creditLimit = jsonSerializedObject.creditLimit == null ? null : jsonSerializedObject.creditLimit;\n this.reviewDate = jsonSerializedObject.reviewDate == null ? null : LocalDate.parse(jsonSerializedObject.reviewDate);\n this.bankName = jsonSerializedObject.bankName;\n this.bankSortCode = jsonSerializedObject.bankSortCode;\n this.bankAccountNumber = jsonSerializedObject.bankAccountNumber;\n this.creditTermNotes = jsonSerializedObject.creditTermNotes;\n this.emailInvoices = jsonSerializedObject.emailInvoices;\n this.defaultInvoiceTemplateId = jsonSerializedObject.defaultInvoiceTemplateId == null ? null : Guid.fromString(jsonSerializedObject.defaultInvoiceTemplateId);\n this.defaultInvoiceRecipient = jsonSerializedObject.defaultInvoiceRecipient;\n this.defaultInvoiceEmailAddress = jsonSerializedObject.defaultInvoiceEmailAddress;\n this.hasDefaultInvoiceAddress = jsonSerializedObject.hasDefaultInvoiceAddress;\n this.defaultInvoiceAddressBusiness = jsonSerializedObject.defaultInvoiceAddressBusiness;\n this.defaultInvoiceAddressLine1 = jsonSerializedObject.defaultInvoiceAddressLine1;\n this.defaultInvoiceAddressLine2 = jsonSerializedObject.defaultInvoiceAddressLine2;\n this.defaultInvoiceAddressLine3 = jsonSerializedObject.defaultInvoiceAddressLine3;\n this.defaultInvoiceAddressLine4 = jsonSerializedObject.defaultInvoiceAddressLine4;\n this.defaultInvoiceAddressLine5 = jsonSerializedObject.defaultInvoiceAddressLine5;\n this.defaultInvoiceAddressLine6 = jsonSerializedObject.defaultInvoiceAddressLine6;\n this.defaultInvoiceAddressPostcode = jsonSerializedObject.defaultInvoiceAddressPostcode;\n this.countryCode = jsonSerializedObject.countryCode;\n this.accountsDepartmentNumber = jsonSerializedObject.accountsDepartmentNumber;\n this.defaultDespatchNoteTemplateId = jsonSerializedObject.defaultDespatchNoteTemplateId == null ? null : Guid.fromString(jsonSerializedObject.defaultDespatchNoteTemplateId);\n this.courierId = jsonSerializedObject.courierId == null ? null : Guid.fromString(jsonSerializedObject.courierId);\n this.deliveryAreaId = jsonSerializedObject.deliveryAreaId == null ? null : Guid.fromString(jsonSerializedObject.deliveryAreaId);\n this.deliveryTimeEnd = jsonSerializedObject.deliveryTimeEnd == null ? null : LocalTime.parse(jsonSerializedObject.deliveryTimeEnd);\n this.deliveryTimeStart = jsonSerializedObject.deliveryTimeStart == null ? null : LocalTime.parse(jsonSerializedObject.deliveryTimeStart);\n this.distributionType = EnumDistributionType.getByValue(jsonSerializedObject.distributionType, this.distributionType);\n this.stopMinutes = jsonSerializedObject.stopMinutes;\n this.deliveryNoteText = jsonSerializedObject.deliveryNoteText;\n this.drayRunNotes = jsonSerializedObject.drayRunNotes;\n this.eoriNumber = jsonSerializedObject.eoriNumber;\n this.exportingIncotermCode = EnumExportIncotermCode.getByValue(jsonSerializedObject.exportingIncotermCode, this.exportingIncotermCode);\n this.exportingIncotermPlace = jsonSerializedObject.exportingIncotermPlace;\n this.defaultDeliveryEmailAddress = jsonSerializedObject.defaultDeliveryEmailAddress;\n this.defaultDeliveryTelephoneNumber = jsonSerializedObject.defaultDeliveryTelephoneNumber;\n this.defaultDeliveryRecipient = jsonSerializedObject.defaultDeliveryRecipient;\n this.hasDefaultDeliveryAddress = jsonSerializedObject.hasDefaultDeliveryAddress;\n this.defaultDeliveryAddressBusiness = jsonSerializedObject.defaultDeliveryAddressBusiness;\n this.defaultDeliveryAddressLine1 = jsonSerializedObject.defaultDeliveryAddressLine1;\n this.defaultDeliveryAddressLine2 = jsonSerializedObject.defaultDeliveryAddressLine2;\n this.defaultDeliveryAddressLine3 = jsonSerializedObject.defaultDeliveryAddressLine3;\n this.defaultDeliveryAddressLine4 = jsonSerializedObject.defaultDeliveryAddressLine4;\n this.defaultDeliveryAddressLine5 = jsonSerializedObject.defaultDeliveryAddressLine5;\n this.defaultDeliveryAddressLine6 = jsonSerializedObject.defaultDeliveryAddressLine6;\n this.defaultDeliveryAddressPostcode = jsonSerializedObject.defaultDeliveryAddressPostcode;\n this.lastOrderDeliveredDate = jsonSerializedObject.lastOrderDeliveredDate == null ? null : LocalDate.parse(jsonSerializedObject.lastOrderDeliveredDate);\n this.standardOrderType = EnumStandardOrder.getByValue(jsonSerializedObject.standardOrderType, this.standardOrderType);\n this.vatCodeId = Guid.fromString(jsonSerializedObject.vatCodeId);\n this.applicationFormReturned = jsonSerializedObject.applicationFormReturned;\n this.tradingTerms = jsonSerializedObject.tradingTerms;\n this.companyRegNumber = jsonSerializedObject.companyRegNumber;\n this.salesNotes = jsonSerializedObject.salesNotes;\n this.readOnly = new OutletReadOnly(jsonSerializedObject.readOnly);\n this.iban = jsonSerializedObject.iban;\n this.bic = jsonSerializedObject.bic;\n this.gkSupplierCode = jsonSerializedObject.gkSupplierCode;\n this.despatchNoteCopiesToPrint = jsonSerializedObject.despatchNoteCopiesToPrint;\n this.invoiceCopiesToPrint = jsonSerializedObject.invoiceCopiesToPrint;\n this.deliveryServiceId = jsonSerializedObject.deliveryServiceId == null ? null : Guid.fromString(jsonSerializedObject.deliveryServiceId);\n this.invoiceNotes = jsonSerializedObject.invoiceNotes;\n this.germanBeerDutyMovementType = EnumGermanBeerDutyMovementType.getByValue(jsonSerializedObject.germanBeerDutyMovementType, this.germanBeerDutyMovementType);\n this.emailDocumentGrouping = EnumEmailDocumentGrouping.getByValue(jsonSerializedObject.emailDocumentGrouping, this.emailDocumentGrouping);\n this.salesWarning = jsonSerializedObject.salesWarning;\n this.liquorLicenceNumber = jsonSerializedObject.liquorLicenceNumber;\n this.smsDespatchNotifications = EnumDeliveryNotificationSetting.getByValue(jsonSerializedObject.smsDespatchNotifications, this.smsDespatchNotifications);\n this.smsDespatchNotificationTemplateId = jsonSerializedObject.smsDespatchNotificationTemplateId == null ? null : Guid.fromString(jsonSerializedObject.smsDespatchNotificationTemplateId);\n this.despatchConfirmationSmsTelephoneNumber = jsonSerializedObject.despatchConfirmationSmsTelephoneNumber;\n this.emailDespatchNotifications = EnumDeliveryNotificationSetting.getByValue(jsonSerializedObject.emailDespatchNotifications, this.emailDespatchNotifications);\n this.emailDespatchNotificationTemplateId = jsonSerializedObject.emailDespatchNotificationTemplateId == null ? null : Guid.fromString(jsonSerializedObject.emailDespatchNotificationTemplateId);\n this.despatchConfirmationEmailAddress = jsonSerializedObject.despatchConfirmationEmailAddress;\n this.invoiceRecipientTaxNumber = jsonSerializedObject.invoiceRecipientTaxNumber;\n this.eireDutyMovementType = EnumEireMovementType.getByValue(jsonSerializedObject.eireDutyMovementType, this.eireDutyMovementType);\n this.productRequirements = jsonSerializedObject.productRequirements;\n this.webAddress = jsonSerializedObject.webAddress;\n this.facebookWebAddress = jsonSerializedObject.facebookWebAddress;\n this.instagramWebAddress = jsonSerializedObject.instagramWebAddress;\n this.twitterWebAddress = jsonSerializedObject.twitterWebAddress;\n this.linkedInWebAddress = jsonSerializedObject.linkedInWebAddress;\n this.tikTokWebAddress = jsonSerializedObject.tikTokWebAddress;\n this.threadsWebAddress = jsonSerializedObject.threadsWebAddress;\n this.onHoldReason = jsonSerializedObject.onHoldReason;\n this.onHold = jsonSerializedObject.onHold;\n this.allowDraughtRelief = jsonSerializedObject.allowDraughtRelief;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.isHidden = this.isHidden;\n toRet.businessName = this.businessName;\n toRet.displayName = this.displayName;\n toRet.telephoneNumber = this.telephoneNumber;\n toRet.emailAddress = this.emailAddress;\n toRet.groupId = this.groupId == null ? null : this.groupId.toString();\n toRet.salesAreaId = this.salesAreaId == null ? null : this.salesAreaId.toString();\n toRet.salesCodeId = this.salesCodeId == null ? null : this.salesCodeId.toString();\n toRet.outletRatingId = this.outletRatingId.toString();\n toRet.outletTypeId = this.outletTypeId == null ? null : this.outletTypeId.toString();\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.outletSubTypeId = this.outletSubTypeId == null ? null : this.outletSubTypeId.toString();\n toRet.mainAddressLine1 = this.mainAddressLine1;\n toRet.mainAddressLine2 = this.mainAddressLine2;\n toRet.mainAddressLine3 = this.mainAddressLine3;\n toRet.mainAddressLine4 = this.mainAddressLine4;\n toRet.mainAddressLine5 = this.mainAddressLine5;\n toRet.mainAddressLine6 = this.mainAddressLine6;\n toRet.mainAddressPostcode = this.mainAddressPostcode;\n toRet.priceListId = this.priceListId.toString();\n toRet.vatNumber = this.vatNumber;\n toRet.creditTermsSet = this.creditTermsSet;\n toRet.creditTermsId = this.creditTermsId == null ? null : this.creditTermsId.toString();\n toRet.creditLimit = this.creditLimit == null ? null : this.creditLimit;\n toRet.reviewDate = this.reviewDate == null ? null : this.reviewDate.toString();\n toRet.bankName = this.bankName;\n toRet.bankSortCode = this.bankSortCode;\n toRet.bankAccountNumber = this.bankAccountNumber;\n toRet.creditTermNotes = this.creditTermNotes;\n toRet.emailInvoices = this.emailInvoices;\n toRet.defaultInvoiceTemplateId = this.defaultInvoiceTemplateId == null ? null : this.defaultInvoiceTemplateId.toString();\n toRet.defaultInvoiceRecipient = this.defaultInvoiceRecipient;\n toRet.defaultInvoiceEmailAddress = this.defaultInvoiceEmailAddress;\n toRet.hasDefaultInvoiceAddress = this.hasDefaultInvoiceAddress;\n toRet.defaultInvoiceAddressBusiness = this.defaultInvoiceAddressBusiness;\n toRet.defaultInvoiceAddressLine1 = this.defaultInvoiceAddressLine1;\n toRet.defaultInvoiceAddressLine2 = this.defaultInvoiceAddressLine2;\n toRet.defaultInvoiceAddressLine3 = this.defaultInvoiceAddressLine3;\n toRet.defaultInvoiceAddressLine4 = this.defaultInvoiceAddressLine4;\n toRet.defaultInvoiceAddressLine5 = this.defaultInvoiceAddressLine5;\n toRet.defaultInvoiceAddressLine6 = this.defaultInvoiceAddressLine6;\n toRet.defaultInvoiceAddressPostcode = this.defaultInvoiceAddressPostcode;\n toRet.countryCode = this.countryCode;\n toRet.accountsDepartmentNumber = this.accountsDepartmentNumber;\n toRet.defaultDespatchNoteTemplateId = this.defaultDespatchNoteTemplateId == null ? null : this.defaultDespatchNoteTemplateId.toString();\n toRet.courierId = this.courierId == null ? null : this.courierId.toString();\n toRet.deliveryAreaId = this.deliveryAreaId == null ? null : this.deliveryAreaId.toString();\n toRet.deliveryTimeEnd = this.deliveryTimeEnd == null ? null : this.deliveryTimeEnd.toString();\n toRet.deliveryTimeStart = this.deliveryTimeStart == null ? null : this.deliveryTimeStart.toString();\n toRet.distributionType = this.distributionType.value;\n toRet.stopMinutes = this.stopMinutes;\n toRet.deliveryNoteText = this.deliveryNoteText;\n toRet.drayRunNotes = this.drayRunNotes;\n toRet.eoriNumber = this.eoriNumber;\n toRet.exportingIncotermCode = this.exportingIncotermCode.value;\n toRet.exportingIncotermPlace = this.exportingIncotermPlace;\n toRet.defaultDeliveryEmailAddress = this.defaultDeliveryEmailAddress;\n toRet.defaultDeliveryTelephoneNumber = this.defaultDeliveryTelephoneNumber;\n toRet.defaultDeliveryRecipient = this.defaultDeliveryRecipient;\n toRet.hasDefaultDeliveryAddress = this.hasDefaultDeliveryAddress;\n toRet.defaultDeliveryAddressBusiness = this.defaultDeliveryAddressBusiness;\n toRet.defaultDeliveryAddressLine1 = this.defaultDeliveryAddressLine1;\n toRet.defaultDeliveryAddressLine2 = this.defaultDeliveryAddressLine2;\n toRet.defaultDeliveryAddressLine3 = this.defaultDeliveryAddressLine3;\n toRet.defaultDeliveryAddressLine4 = this.defaultDeliveryAddressLine4;\n toRet.defaultDeliveryAddressLine5 = this.defaultDeliveryAddressLine5;\n toRet.defaultDeliveryAddressLine6 = this.defaultDeliveryAddressLine6;\n toRet.defaultDeliveryAddressPostcode = this.defaultDeliveryAddressPostcode;\n toRet.lastOrderDeliveredDate = this.lastOrderDeliveredDate == null ? null : this.lastOrderDeliveredDate.toString();\n toRet.standardOrderType = this.standardOrderType.value;\n toRet.vatCodeId = this.vatCodeId.toString();\n toRet.applicationFormReturned = this.applicationFormReturned;\n toRet.tradingTerms = this.tradingTerms;\n toRet.companyRegNumber = this.companyRegNumber;\n toRet.salesNotes = this.salesNotes;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.iban = this.iban;\n toRet.bic = this.bic;\n toRet.gkSupplierCode = this.gkSupplierCode;\n toRet.despatchNoteCopiesToPrint = this.despatchNoteCopiesToPrint;\n toRet.invoiceCopiesToPrint = this.invoiceCopiesToPrint;\n toRet.deliveryServiceId = this.deliveryServiceId == null ? null : this.deliveryServiceId.toString();\n toRet.invoiceNotes = this.invoiceNotes;\n toRet.germanBeerDutyMovementType = this.germanBeerDutyMovementType.value;\n toRet.emailDocumentGrouping = this.emailDocumentGrouping.value;\n toRet.salesWarning = this.salesWarning;\n toRet.liquorLicenceNumber = this.liquorLicenceNumber;\n toRet.smsDespatchNotifications = this.smsDespatchNotifications.value;\n toRet.smsDespatchNotificationTemplateId = this.smsDespatchNotificationTemplateId == null ? null : this.smsDespatchNotificationTemplateId.toString();\n toRet.despatchConfirmationSmsTelephoneNumber = this.despatchConfirmationSmsTelephoneNumber;\n toRet.emailDespatchNotifications = this.emailDespatchNotifications.value;\n toRet.emailDespatchNotificationTemplateId = this.emailDespatchNotificationTemplateId == null ? null : this.emailDespatchNotificationTemplateId.toString();\n toRet.despatchConfirmationEmailAddress = this.despatchConfirmationEmailAddress;\n toRet.invoiceRecipientTaxNumber = this.invoiceRecipientTaxNumber;\n toRet.eireDutyMovementType = this.eireDutyMovementType.value;\n toRet.productRequirements = this.productRequirements;\n toRet.webAddress = this.webAddress;\n toRet.facebookWebAddress = this.facebookWebAddress;\n toRet.instagramWebAddress = this.instagramWebAddress;\n toRet.twitterWebAddress = this.twitterWebAddress;\n toRet.linkedInWebAddress = this.linkedInWebAddress;\n toRet.tikTokWebAddress = this.tikTokWebAddress;\n toRet.threadsWebAddress = this.threadsWebAddress;\n toRet.onHoldReason = this.onHoldReason;\n toRet.onHold = this.onHold;\n toRet.allowDraughtRelief = this.allowDraughtRelief;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"Outlet.Id cannot be empty\"},\n {field: \"businessName\", rule: (v: any) => v == null || v.length !== 0 || \"BusinessName cannot be empty\"},\n {field: \"businessName\", rule: (v: any) => v == null || v.length <= 1000 || \"BusinessName has too many characters (1000)\"},\n {field: \"displayName\", rule: (v: any) => v == null || v.length !== 0 || \"DisplayName cannot be empty\"},\n {field: \"displayName\", rule: (v: any) => v == null || v.length <= 1000 || \"DisplayName has too many characters (1000)\"},\n {field: \"telephoneNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"TelephoneNumber has too many characters (1000)\"},\n {field: \"emailAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"EmailAddress has too many characters (1000)\"},\n {field: \"groupId\", rule: (v: any) => v == null || !v.isEmpty() || \"Outlet.GroupId cannot be empty\"},\n {field: \"salesAreaId\", rule: (v: any) => v == null || !v.isEmpty() || \"Outlet.SalesAreaId cannot be empty\"},\n {field: \"salesCodeId\", rule: (v: any) => v == null || !v.isEmpty() || \"Outlet.SalesCodeId cannot be empty\"},\n {field: \"outletRatingId\", rule: (v: any) => !v.isEmpty() || \"Outlet.OutletRatingId cannot be empty\"},\n {field: \"outletTypeId\", rule: (v: any) => v == null || !v.isEmpty() || \"Outlet.OutletTypeId cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \"Outlet.StockLocationId cannot be empty\"},\n {field: \"outletSubTypeId\", rule: (v: any) => v == null || !v.isEmpty() || \"Outlet.OutletSubTypeId cannot be empty\"},\n {field: \"mainAddressLine1\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressLine1 has too many characters (1000)\"},\n {field: \"mainAddressLine2\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressLine2 has too many characters (1000)\"},\n {field: \"mainAddressLine3\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressLine3 has too many characters (1000)\"},\n {field: \"mainAddressLine4\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressLine4 has too many characters (1000)\"},\n {field: \"mainAddressLine5\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressLine5 has too many characters (1000)\"},\n {field: \"mainAddressLine6\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressLine6 has too many characters (1000)\"},\n {field: \"mainAddressPostcode\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressPostcode has too many characters (1000)\"},\n {field: \"priceListId\", rule: (v: any) => !v.isEmpty() || \"Outlet.PriceListId cannot be empty\"},\n {field: \"vatNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"VatNumber has too many characters (1000)\"},\n {field: \"creditTermsId\", rule: (v: any) => v == null || !v.isEmpty() || \"Outlet.CreditTermsId cannot be empty\"},\n {field: \"bankName\", rule: (v: any) => v == null || v.length <= 1000 || \"BankName has too many characters (1000)\"},\n {field: \"bankSortCode\", rule: (v: any) => v == null || v.length <= 1000 || \"BankSortCode has too many characters (1000)\"},\n {field: \"bankAccountNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"BankAccountNumber has too many characters (1000)\"},\n {field: \"creditTermNotes\", rule: (v: any) => v == null || v.length <= 100000 || \"CreditTermNotes has too many characters (100000)\"},\n {field: \"defaultInvoiceTemplateId\", rule: (v: any) => v == null || !v.isEmpty() || \"Outlet.DefaultInvoiceTemplateId cannot be empty\"},\n {field: \"defaultInvoiceRecipient\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultInvoiceRecipient has too many characters (1000)\"},\n {field: \"defaultInvoiceEmailAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultInvoiceEmailAddress has too many characters (1000)\"},\n {field: \"defaultInvoiceAddressBusiness\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultInvoiceAddressBusiness has too many characters (1000)\"},\n {field: \"defaultInvoiceAddressLine1\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultInvoiceAddressLine1 has too many characters (1000)\"},\n {field: \"defaultInvoiceAddressLine2\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultInvoiceAddressLine2 has too many characters (1000)\"},\n {field: \"defaultInvoiceAddressLine3\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultInvoiceAddressLine3 has too many characters (1000)\"},\n {field: \"defaultInvoiceAddressLine4\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultInvoiceAddressLine4 has too many characters (1000)\"},\n {field: \"defaultInvoiceAddressLine5\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultInvoiceAddressLine5 has too many characters (1000)\"},\n {field: \"defaultInvoiceAddressLine6\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultInvoiceAddressLine6 has too many characters (1000)\"},\n {field: \"defaultInvoiceAddressPostcode\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultInvoiceAddressPostcode has too many characters (1000)\"},\n {field: \"countryCode\", rule: (v: any) => v == null || v.length <= 1000 || \"CountryCode has too many characters (1000)\"},\n {field: \"accountsDepartmentNumber\", rule: (v: any) => v == null || v >= -2147483648 || \"AccountsDepartmentNumber is not greater than minimum allowed value: -2147483648\"},\n {field: \"accountsDepartmentNumber\", rule: (v: any) => v == null || v <= 2147483647 || \"AccountsDepartmentNumber is above maximum allowed value: 2147483647\"},\n {field: \"defaultDespatchNoteTemplateId\", rule: (v: any) => v == null || !v.isEmpty() || \"Outlet.DefaultDespatchNoteTemplateId cannot be empty\"},\n {field: \"courierId\", rule: (v: any) => v == null || !v.isEmpty() || \"Outlet.CourierId cannot be empty\"},\n {field: \"deliveryAreaId\", rule: (v: any) => v == null || !v.isEmpty() || \"Outlet.DeliveryAreaId cannot be empty\"},\n {field: \"stopMinutes\", rule: (v: any) => v == null || v >= -2147483648 || \"StopMinutes is not greater than minimum allowed value: -2147483648\"},\n {field: \"stopMinutes\", rule: (v: any) => v == null || v <= 2147483647 || \"StopMinutes is above maximum allowed value: 2147483647\"},\n {field: \"deliveryNoteText\", rule: (v: any) => v == null || v.length <= 100000 || \"DeliveryNoteText has too many characters (100000)\"},\n {field: \"drayRunNotes\", rule: (v: any) => v == null || v.length <= 100000 || \"DrayRunNotes has too many characters (100000)\"},\n {field: \"eoriNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"EoriNumber has too many characters (1000)\"},\n {field: \"exportingIncotermPlace\", rule: (v: any) => v == null || v.length <= 1000 || \"ExportingIncotermPlace has too many characters (1000)\"},\n {field: \"defaultDeliveryEmailAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultDeliveryEmailAddress has too many characters (1000)\"},\n {field: \"defaultDeliveryTelephoneNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultDeliveryTelephoneNumber has too many characters (1000)\"},\n {field: \"defaultDeliveryRecipient\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultDeliveryRecipient has too many characters (1000)\"},\n {field: \"defaultDeliveryAddressBusiness\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultDeliveryAddressBusiness has too many characters (1000)\"},\n {field: \"defaultDeliveryAddressLine1\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultDeliveryAddressLine1 has too many characters (1000)\"},\n {field: \"defaultDeliveryAddressLine2\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultDeliveryAddressLine2 has too many characters (1000)\"},\n {field: \"defaultDeliveryAddressLine3\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultDeliveryAddressLine3 has too many characters (1000)\"},\n {field: \"defaultDeliveryAddressLine4\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultDeliveryAddressLine4 has too many characters (1000)\"},\n {field: \"defaultDeliveryAddressLine5\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultDeliveryAddressLine5 has too many characters (1000)\"},\n {field: \"defaultDeliveryAddressLine6\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultDeliveryAddressLine6 has too many characters (1000)\"},\n {field: \"defaultDeliveryAddressPostcode\", rule: (v: any) => v == null || v.length <= 1000 || \"DefaultDeliveryAddressPostcode has too many characters (1000)\"},\n {field: \"vatCodeId\", rule: (v: any) => !v.isEmpty() || \"Outlet.VatCodeId cannot be empty\"},\n {field: \"tradingTerms\", rule: (v: any) => v == null || v.length <= 100000 || \"TradingTerms has too many characters (100000)\"},\n {field: \"companyRegNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"CompanyRegNumber has too many characters (1000)\"},\n {field: \"salesNotes\", rule: (v: any) => v == null || v.length <= 100000 || \"SalesNotes has too many characters (100000)\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"iban\", rule: (v: any) => v == null || v.length <= 1000 || \"Iban has too many characters (1000)\"},\n {field: \"bic\", rule: (v: any) => v == null || v.length <= 1000 || \"Bic has too many characters (1000)\"},\n {field: \"gkSupplierCode\", rule: (v: any) => v == null || v.length <= 1000 || \"GkSupplierCode has too many characters (1000)\"},\n {field: \"despatchNoteCopiesToPrint\", rule: (v: any) => v == null || v >= 0 || \"DespatchNoteCopiesToPrint is not greater than minimum allowed value: 0\"},\n {field: \"despatchNoteCopiesToPrint\", rule: (v: any) => v == null || v <= 2147483647 || \"DespatchNoteCopiesToPrint is above maximum allowed value: 2147483647\"},\n {field: \"invoiceCopiesToPrint\", rule: (v: any) => v == null || v >= 0 || \"InvoiceCopiesToPrint is not greater than minimum allowed value: 0\"},\n {field: \"invoiceCopiesToPrint\", rule: (v: any) => v == null || v <= 2147483647 || \"InvoiceCopiesToPrint is above maximum allowed value: 2147483647\"},\n {field: \"deliveryServiceId\", rule: (v: any) => v == null || !v.isEmpty() || \"Outlet.DeliveryServiceId cannot be empty\"},\n {field: \"invoiceNotes\", rule: (v: any) => v == null || v.length <= 100000 || \"InvoiceNotes has too many characters (100000)\"},\n {field: \"salesWarning\", rule: (v: any) => v == null || v.length <= 100000 || \"SalesWarning has too many characters (100000)\"},\n {field: \"liquorLicenceNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"LiquorLicenceNumber has too many characters (1000)\"},\n {field: \"smsDespatchNotificationTemplateId\", rule: (v: any) => v == null || !v.isEmpty() || \"Outlet.SmsDespatchNotificationTemplateId cannot be empty\"},\n {field: \"despatchConfirmationSmsTelephoneNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"DespatchConfirmationSmsTelephoneNumber has too many characters (1000)\"},\n {field: \"emailDespatchNotificationTemplateId\", rule: (v: any) => v == null || !v.isEmpty() || \"Outlet.EmailDespatchNotificationTemplateId cannot be empty\"},\n {field: \"despatchConfirmationEmailAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"DespatchConfirmationEmailAddress has too many characters (1000)\"},\n {field: \"invoiceRecipientTaxNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"InvoiceRecipientTaxNumber has too many characters (1000)\"},\n {field: \"productRequirements\", rule: (v: any) => v == null || v.length <= 1000 || \"ProductRequirements has too many characters (1000)\"},\n {field: \"webAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"WebAddress has too many characters (1000)\"},\n {field: \"facebookWebAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"FacebookWebAddress has too many characters (1000)\"},\n {field: \"instagramWebAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"InstagramWebAddress has too many characters (1000)\"},\n {field: \"twitterWebAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"TwitterWebAddress has too many characters (1000)\"},\n {field: \"linkedInWebAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"LinkedInWebAddress has too many characters (1000)\"},\n {field: \"tikTokWebAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"TikTokWebAddress has too many characters (1000)\"},\n {field: \"threadsWebAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"ThreadsWebAddress has too many characters (1000)\"},\n {field: \"onHoldReason\", rule: (v: any) => v == null || v.length <= 1000 || \"OnHoldReason has too many characters (1000)\"},\n ];\n}\n\n\nexport class LatestCreditBalance extends ModelObject {\n\n private _creditBalance: number | null = null;\n /**\n * Credit balance from the accounts package. Captured by system not user editable.\n * Not Negative\n */\n public get creditBalance(): number | null { return this._creditBalance }\n public set creditBalance(value: number | null) {\n this._creditBalance = value === undefined ? null : value;\n }\n private _creditBalanceExpiresAt: Instant | null = null;\n /**\n * The time when the credit balance will expire and need updating from the accounts package. Captured by system not user editable.\n */\n public get creditBalanceExpiresAt(): Instant | null { return this._creditBalanceExpiresAt }\n public set creditBalanceExpiresAt(value: Instant | null) {\n this._creditBalanceExpiresAt = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.creditBalance = jsonSerializedObject.creditBalance == null ? null : jsonSerializedObject.creditBalance;\n this.creditBalanceExpiresAt = jsonSerializedObject.creditBalanceExpiresAt == null ? null : Instant.parse(jsonSerializedObject.creditBalanceExpiresAt);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.creditBalance = this.creditBalance == null ? null : this.creditBalance;\n toRet.creditBalanceExpiresAt = this.creditBalanceExpiresAt == null ? null : this.creditBalanceExpiresAt.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class OutletFilter extends ModelObject {\n\n private _priceListIds: Guid[] | null = null;\n public get priceListIds(): Guid[] | null { return this._priceListIds }\n public set priceListIds(value: Guid[] | null) {\n this._priceListIds = value === undefined ? null : value;\n }\n private _stockLocationIds: Guid[] | null = null;\n public get stockLocationIds(): Guid[] | null { return this._stockLocationIds }\n public set stockLocationIds(value: Guid[] | null) {\n this._stockLocationIds = value === undefined ? null : value;\n }\n private _vatCodeIds: Guid[] | null = null;\n public get vatCodeIds(): Guid[] | null { return this._vatCodeIds }\n public set vatCodeIds(value: Guid[] | null) {\n this._vatCodeIds = value === undefined ? null : value;\n }\n private _outletGroupIds: Guid[] | null = null;\n public get outletGroupIds(): Guid[] | null { return this._outletGroupIds }\n public set outletGroupIds(value: Guid[] | null) {\n this._outletGroupIds = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.priceListIds = jsonSerializedObject.priceListIds == null ? null : jsonSerializedObject.priceListIds.map((v: any) => Guid.fromString(v));\n this.stockLocationIds = jsonSerializedObject.stockLocationIds == null ? null : jsonSerializedObject.stockLocationIds.map((v: any) => Guid.fromString(v));\n this.vatCodeIds = jsonSerializedObject.vatCodeIds == null ? null : jsonSerializedObject.vatCodeIds.map((v: any) => Guid.fromString(v));\n this.outletGroupIds = jsonSerializedObject.outletGroupIds == null ? null : jsonSerializedObject.outletGroupIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.priceListIds = this.priceListIds == null ? null : this.priceListIds.map(v => v.toString());\n toRet.stockLocationIds = this.stockLocationIds == null ? null : this.stockLocationIds.map(v => v.toString());\n toRet.vatCodeIds = this.vatCodeIds == null ? null : this.vatCodeIds.map(v => v.toString());\n toRet.outletGroupIds = this.outletGroupIds == null ? null : this.outletGroupIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class OutletCreditBalance extends ModelObject {\n\n public outletId: Guid = Guid.createEmpty();\n private _creditBalance: number | null = null;\n public get creditBalance(): number | null { return this._creditBalance }\n public set creditBalance(value: number | null) {\n this._creditBalance = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n this.creditBalance = jsonSerializedObject.creditBalance == null ? null : jsonSerializedObject.creditBalance;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outletId = this.outletId.toString();\n toRet.creditBalance = this.creditBalance == null ? null : this.creditBalance;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \"OutletCreditBalance.OutletId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllOutletSummariesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllOutletSummariesResponse extends ModelObject {\n\n public outletSummaries: OutletSummary[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outletSummaries = jsonSerializedObject.outletSummaries.map((v: any) => new OutletSummary(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outletSummaries = this.outletSummaries.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outletSummaries\", rule: (v: any) => !!v || \"outletSummaries is required\"},\n {field: \"outletSummaries\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OutletSummary[]).reduce((acc: Array, curr: OutletSummary) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetOutletSummariesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletIds = jsonSerializedObject.outletIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletIds = this.outletIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetOutletSummariesResponse extends ModelObject {\n\n public outletSummaries: OutletSummary[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outletSummaries = jsonSerializedObject.outletSummaries.map((v: any) => new OutletSummary(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outletSummaries = this.outletSummaries.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outletSummaries\", rule: (v: any) => !!v || \"outletSummaries is required\"},\n {field: \"outletSummaries\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OutletSummary[]).reduce((acc: Array, curr: OutletSummary) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllOutletsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllOutletsResponse extends ModelObject {\n\n public outlets: Outlet[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outlets = jsonSerializedObject.outlets.map((v: any) => new Outlet(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outlets = this.outlets.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outlets\", rule: (v: any) => !!v || \"outlets is required\"},\n {field: \"outlets\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Outlet[]).reduce((acc: Array, curr: Outlet) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetOutletsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletId: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletId = jsonSerializedObject.outletId.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletId = this.outletId.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetOutletsResponse extends ModelObject {\n\n public outlets: Outlet[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outlets = jsonSerializedObject.outlets.map((v: any) => new Outlet(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outlets = this.outlets.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outlets\", rule: (v: any) => !!v || \"outlets is required\"},\n {field: \"outlets\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Outlet[]).reduce((acc: Array, curr: Outlet) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetOutletRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletId = this.outletId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \".OutletId cannot be empty\"},\n ];\n}\n\n\nexport class GetOutletResponse extends ModelObject {\n\n public outlet: Outlet = new Outlet();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outlet = new Outlet(jsonSerializedObject.outlet);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outlet = this.outlet.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outlet\", rule: (v: any) => !!v || \"outlet is required\"},\n {field: \"outlet\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class CreateOutletRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outlet: Outlet = new Outlet();\n public outletIsRetail: boolean = false;\n public contacts: readonly Contact[] = [];\n public outletCode: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outlet = new Outlet(jsonSerializedObject.outlet);\n this.outletIsRetail = jsonSerializedObject.outletIsRetail;\n this.contacts = jsonSerializedObject.contacts.map((v: any) => new Contact(v));\n this.outletCode = jsonSerializedObject.outletCode;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outlet = this.outlet.toJsonSerializedObject();\n toRet.outletIsRetail = this.outletIsRetail;\n toRet.contacts = this.contacts.map(v => v.toJsonSerializedObject());\n toRet.outletCode = this.outletCode;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outlet\", rule: (v: any) => !!v || \"outlet is required\"},\n {field: \"outlet\", rule: (v: any) => v.validate()},\n {field: \"contacts\", rule: (v: any) => !!v || \"contacts is required\"},\n {field: \"contacts\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Contact[]).reduce((acc: Array, curr: Contact) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class UpdateOutletRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletId: Guid = Guid.createEmpty();\n public outlet: Outlet = new Outlet();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n this.outlet = new Outlet(jsonSerializedObject.outlet);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletId = this.outletId.toString();\n toRet.outlet = this.outlet.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \".OutletId cannot be empty\"},\n {field: \"outlet\", rule: (v: any) => !!v || \"outlet is required\"},\n {field: \"outlet\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetOutletIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletId = this.outletId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \".OutletId cannot be empty\"},\n ];\n}\n\n\nexport class GenerateOutletCodeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletName: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletName = jsonSerializedObject.outletName;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletName = this.outletName;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletName\", rule: (v: any) => v == null || v.length !== 0 || \"OutletName cannot be empty\"},\n ];\n}\n\n\nexport class GenerateOutletCodeResponse extends ModelObject {\n\n /**\n * Outlet Code\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public code: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.code = jsonSerializedObject.code;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.code = this.code;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"code\", rule: (v: any) => v == null || v.length !== 0 || \"Code cannot be empty\"},\n {field: \"code\", rule: (v: any) => v == null || v.length <= 1000 || \"Code has too many characters (1000)\"},\n ];\n}\n\n\nexport class CheckOutletCodeAvailableRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public code: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.code = jsonSerializedObject.code;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.code = this.code;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"code\", rule: (v: any) => v == null || v.length !== 0 || \"Code cannot be empty\"},\n ];\n}\n\n\nexport class CheckOutletCodeAvailableResponse extends ModelObject {\n\n public available: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.available = jsonSerializedObject.available;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.available = this.available;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GetOutletsByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: OutletFilter = new OutletFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new OutletFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetOutletsByFilterResponse extends ModelObject {\n\n public outlets: Outlet[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outlets = jsonSerializedObject.outlets.map((v: any) => new Outlet(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outlets = this.outlets.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outlets\", rule: (v: any) => !!v || \"outlets is required\"},\n {field: \"outlets\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Outlet[]).reduce((acc: Array, curr: Outlet) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetLatestCreditBalanceRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletId = this.outletId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \".OutletId cannot be empty\"},\n ];\n}\n\n\nexport class GetLatestCreditBalanceResponse extends ModelObject {\n\n public latestCreditBalance: LatestCreditBalance = new LatestCreditBalance();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.latestCreditBalance = new LatestCreditBalance(jsonSerializedObject.latestCreditBalance);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.latestCreditBalance = this.latestCreditBalance.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"latestCreditBalance\", rule: (v: any) => !!v || \"latestCreditBalance is required\"},\n {field: \"latestCreditBalance\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class UpdateCreditBalancesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletCreditBalances: readonly OutletCreditBalance[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletCreditBalances = jsonSerializedObject.outletCreditBalances.map((v: any) => new OutletCreditBalance(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletCreditBalances = this.outletCreditBalances.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletCreditBalances\", rule: (v: any) => !!v || \"outletCreditBalances is required\"},\n {field: \"outletCreditBalances\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OutletCreditBalance[]).reduce((acc: Array, curr: OutletCreditBalance) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetContactsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletId = this.outletId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \".OutletId cannot be empty\"},\n ];\n}\n\n\nexport class GetContactsResponse extends ModelObject {\n\n public contacts: Contact[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.contacts = jsonSerializedObject.contacts.map((v: any) => new Contact(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.contacts = this.contacts.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"contacts\", rule: (v: any) => !!v || \"contacts is required\"},\n {field: \"contacts\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Contact[]).reduce((acc: Array, curr: Contact) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetMultipleOutletContactsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletIds = jsonSerializedObject.outletIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletIds = this.outletIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetMultipleOutletContactsResponse extends ModelObject {\n\n public contacts: Contact[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.contacts = jsonSerializedObject.contacts.map((v: any) => new Contact(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.contacts = this.contacts.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"contacts\", rule: (v: any) => !!v || \"contacts is required\"},\n {field: \"contacts\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Contact[]).reduce((acc: Array, curr: Contact) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveContactsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public contacts: readonly Contact[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.contacts = jsonSerializedObject.contacts.map((v: any) => new Contact(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.contacts = this.contacts.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"contacts\", rule: (v: any) => !!v || \"contacts is required\"},\n {field: \"contacts\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Contact[]).reduce((acc: Array, curr: Contact) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class DeleteContactsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public contactIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.contactIds = jsonSerializedObject.contactIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.contactIds = this.contactIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllContactsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllContactsResponse extends ModelObject {\n\n public contacts: Contact[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.contacts = jsonSerializedObject.contacts.map((v: any) => new Contact(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.contacts = this.contacts.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"contacts\", rule: (v: any) => !!v || \"contacts is required\"},\n {field: \"contacts\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Contact[]).reduce((acc: Array, curr: Contact) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetPrimaryContactRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletId = this.outletId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \".OutletId cannot be empty\"},\n ];\n}\n\n\nexport class GetPrimaryContactResponse extends ModelObject {\n\n private _contact: Contact | null = null;\n public get contact(): Contact | null { return this._contact }\n public set contact(value: Contact | null) {\n this._contact = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.contact = jsonSerializedObject.contact == null ? null : new Contact(jsonSerializedObject.contact);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.contact = this.contact == null ? null : this.contact?.toJsonSerializedObject() ?? null;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"contact\", rule: (v: any) => (v === null) || v.validate()},\n ];\n}\n\n\nexport class GetPrimaryContactsForOutletsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletIds = jsonSerializedObject.outletIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletIds = this.outletIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetPrimaryContactsForOutletsResponse extends ModelObject {\n\n public contacts: Contact[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.contacts = jsonSerializedObject.contacts.map((v: any) => new Contact(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.contacts = this.contacts.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"contacts\", rule: (v: any) => !!v || \"contacts is required\"},\n {field: \"contacts\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Contact[]).reduce((acc: Array, curr: Contact) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetContactInternalRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public contactId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.contactId = Guid.fromString(jsonSerializedObject.contactId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.contactId = this.contactId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"contactId\", rule: (v: any) => !v.isEmpty() || \".ContactId cannot be empty\"},\n ];\n}\n\n\nexport class GetContactInternalResponse extends ModelObject {\n\n public contact: Contact = new Contact();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.contact = new Contact(jsonSerializedObject.contact);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.contact = this.contact.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"contact\", rule: (v: any) => !!v || \"contact is required\"},\n {field: \"contact\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class UpdateContactsToHaveOnePrimaryContactRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n private _outletIds: readonly Guid[] | null = null;\n /**\n * Specifies which outlet to be updated. If null, updates will be for the whole tenant.\n */\n public get outletIds(): readonly Guid[] | null { return this._outletIds }\n public set outletIds(value: readonly Guid[] | null) {\n this._outletIds = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletIds = jsonSerializedObject.outletIds == null ? null : jsonSerializedObject.outletIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletIds = this.outletIds == null ? null : this.outletIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class UpdateOutletLatLngsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletId = Guid.fromString(jsonSerializedObject.outletId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletId = this.outletId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletId\", rule: (v: any) => !v.isEmpty() || \".OutletId cannot be empty\"},\n ];\n}\n\n\nexport class OutletService extends ServiceBase {\n\n public async getAllOutletSummaries(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllOutletSummariesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllOutletSummariesResponse(response).outletSummaries;\n return this.makeJsonRequest(\"outlet/v1/getAllOutletSummaries\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getOutletSummaries(tenantId: Guid, outletIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetOutletSummariesRequest();\n req.tenantId = tenantId;\n req.outletIds = outletIds;\n const extractor = (response:any) => new GetOutletSummariesResponse(response).outletSummaries;\n return this.makeJsonRequest(\"outlet/v1/getOutletSummaries\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllOutlets(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllOutletsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllOutletsResponse(response).outlets;\n return this.makeJsonRequest(\"outlet/v1/getAllOutlets\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getOutlets(tenantId: Guid, outletId: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetOutletsRequest();\n req.tenantId = tenantId;\n req.outletId = outletId;\n const extractor = (response:any) => new GetOutletsResponse(response).outlets;\n return this.makeJsonRequest(\"outlet/v1/getOutlets\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getOutlet(tenantId: Guid, outletId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetOutletRequest();\n req.tenantId = tenantId;\n req.outletId = outletId;\n const extractor = (response:any) => new GetOutletResponse(response).outlet;\n return this.makeJsonRequest(\"outlet/v1/getOutlet\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async createOutlet(tenantId: Guid, outlet: Outlet, outletIsRetail: boolean, contacts: readonly Contact[], outletCode: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CreateOutletRequest();\n req.tenantId = tenantId;\n req.outlet = outlet;\n req.outletIsRetail = outletIsRetail;\n req.contacts = contacts;\n req.outletCode = outletCode;\n const extractor = null;\n return this.makeJsonRequest(\"outlet/v1/createOutlet\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updateOutlet(tenantId: Guid, outletId: Guid, outlet: Outlet, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdateOutletRequest();\n req.tenantId = tenantId;\n req.outletId = outletId;\n req.outlet = outlet;\n const extractor = null;\n return this.makeJsonRequest(\"outlet/v1/updateOutlet\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setOutletIsHidden(tenantId: Guid, outletId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetOutletIsHiddenRequest();\n req.tenantId = tenantId;\n req.outletId = outletId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"outlet/v1/setOutletIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async generateOutletCode(tenantId: Guid, outletName: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GenerateOutletCodeRequest();\n req.tenantId = tenantId;\n req.outletName = outletName;\n const extractor = (response:any) => new GenerateOutletCodeResponse(response).code;\n return this.makeJsonRequest(\"outlet/v1/generateOutletCode\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getOutletsByFilter(tenantId: Guid, filter: OutletFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetOutletsByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetOutletsByFilterResponse(response).outlets;\n return this.makeJsonRequest(\"outlet/v1/getOutletsByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getLatestCreditBalance(tenantId: Guid, outletId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetLatestCreditBalanceRequest();\n req.tenantId = tenantId;\n req.outletId = outletId;\n const extractor = (response:any) => new GetLatestCreditBalanceResponse(response).latestCreditBalance;\n return this.makeJsonRequest(\"outlet/v1/getLatestCreditBalance\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updateCreditBalances(tenantId: Guid, outletCreditBalances: readonly OutletCreditBalance[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdateCreditBalancesRequest();\n req.tenantId = tenantId;\n req.outletCreditBalances = outletCreditBalances;\n const extractor = null;\n return this.makeJsonRequest(\"outlet/v1/updateCreditBalances\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getContacts(tenantId: Guid, outletId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetContactsRequest();\n req.tenantId = tenantId;\n req.outletId = outletId;\n const extractor = (response:any) => new GetContactsResponse(response).contacts;\n return this.makeJsonRequest(\"outlet/v1/getContacts\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getMultipleOutletContacts(tenantId: Guid, outletIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetMultipleOutletContactsRequest();\n req.tenantId = tenantId;\n req.outletIds = outletIds;\n const extractor = (response:any) => new GetMultipleOutletContactsResponse(response).contacts;\n return this.makeJsonRequest(\"outlet/v1/getMultipleOutletContacts\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveContacts(tenantId: Guid, contacts: readonly Contact[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveContactsRequest();\n req.tenantId = tenantId;\n req.contacts = contacts;\n const extractor = null;\n return this.makeJsonRequest(\"outlet/v1/saveContacts\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async deleteContacts(tenantId: Guid, contactIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new DeleteContactsRequest();\n req.tenantId = tenantId;\n req.contactIds = contactIds;\n const extractor = null;\n return this.makeJsonRequest(\"outlet/v1/deleteContacts\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllContacts(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllContactsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllContactsResponse(response).contacts;\n return this.makeJsonRequest(\"outlet/v1/getAllContacts\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getPrimaryContact(tenantId: Guid, outletId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPrimaryContactRequest();\n req.tenantId = tenantId;\n req.outletId = outletId;\n const extractor = (response:any) => new GetPrimaryContactResponse(response).contact;\n return this.makeJsonRequest(\"outlet/v1/getPrimaryContact\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getPrimaryContactsForOutlets(tenantId: Guid, outletIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPrimaryContactsForOutletsRequest();\n req.tenantId = tenantId;\n req.outletIds = outletIds;\n const extractor = (response:any) => new GetPrimaryContactsForOutletsResponse(response).contacts;\n return this.makeJsonRequest(\"outlet/v1/getPrimaryContactsForOutlets\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const outletService = new OutletService();","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class ItemAtLocation extends BaseModelObject {\n\n /**\n * Stock Item Id\n */\n public stockItemId: Guid = Guid.createEmpty();\n /**\n * Stock Location Id\n */\n public stockLocationId: Guid = Guid.createEmpty();\n private _reorderLevel: number | null = null;\n /**\n * The level at which users should re-order stock.\n * Not Negative\n */\n public get reorderLevel(): number | null { return this._reorderLevel }\n public set reorderLevel(value: number | null) {\n this._reorderLevel = value === undefined ? null : value;\n }\n private _reorderQuantity: number | null = null;\n /**\n * The default amount that the user should order.\n * Not Negative\n */\n public get reorderQuantity(): number | null { return this._reorderQuantity }\n public set reorderQuantity(value: number | null) {\n this._reorderQuantity = value === undefined ? null : value;\n }\n private _stockLevelAlert: number | null = null;\n /**\n * The level at which the user should be notified that more stock is required.\n * Not Negative\n */\n public get stockLevelAlert(): number | null { return this._stockLevelAlert }\n public set stockLevelAlert(value: number | null) {\n this._stockLevelAlert = value === undefined ? null : value;\n }\n /**\n * Whether this item should be offered for sale from this location (applicable to sales-type items).\n */\n public allowSales: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.reorderLevel = jsonSerializedObject.reorderLevel == null ? null : jsonSerializedObject.reorderLevel;\n this.reorderQuantity = jsonSerializedObject.reorderQuantity == null ? null : jsonSerializedObject.reorderQuantity;\n this.stockLevelAlert = jsonSerializedObject.stockLevelAlert == null ? null : jsonSerializedObject.stockLevelAlert;\n this.allowSales = jsonSerializedObject.allowSales;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.reorderLevel = this.reorderLevel == null ? null : this.reorderLevel;\n toRet.reorderQuantity = this.reorderQuantity == null ? null : this.reorderQuantity;\n toRet.stockLevelAlert = this.stockLevelAlert == null ? null : this.stockLevelAlert;\n toRet.allowSales = this.allowSales;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"ItemAtLocation.StockItemId cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \"ItemAtLocation.StockLocationId cannot be empty\"},\n ];\n}\n\n\nexport class SaveItemAtLocationRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public itemAtLocation: ItemAtLocation = new ItemAtLocation();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.itemAtLocation = new ItemAtLocation(jsonSerializedObject.itemAtLocation);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.itemAtLocation = this.itemAtLocation.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"itemAtLocation\", rule: (v: any) => !!v || \"itemAtLocation is required\"},\n {field: \"itemAtLocation\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetItemAtLocationsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n private _limitItemIds: readonly Guid[] | null = null;\n public get limitItemIds(): readonly Guid[] | null { return this._limitItemIds }\n public set limitItemIds(value: readonly Guid[] | null) {\n this._limitItemIds = value === undefined ? null : value;\n }\n private _limitStockLocationIds: readonly Guid[] | null = null;\n public get limitStockLocationIds(): readonly Guid[] | null { return this._limitStockLocationIds }\n public set limitStockLocationIds(value: readonly Guid[] | null) {\n this._limitStockLocationIds = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.limitItemIds = jsonSerializedObject.limitItemIds == null ? null : jsonSerializedObject.limitItemIds.map((v: any) => Guid.fromString(v));\n this.limitStockLocationIds = jsonSerializedObject.limitStockLocationIds == null ? null : jsonSerializedObject.limitStockLocationIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.limitItemIds = this.limitItemIds == null ? null : this.limitItemIds.map(v => v.toString());\n toRet.limitStockLocationIds = this.limitStockLocationIds == null ? null : this.limitStockLocationIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetItemAtLocationsResponse extends ModelObject {\n\n public itemAtLocations: ItemAtLocation[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.itemAtLocations = jsonSerializedObject.itemAtLocations.map((v: any) => new ItemAtLocation(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.itemAtLocations = this.itemAtLocations.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"itemAtLocations\", rule: (v: any) => !!v || \"itemAtLocations is required\"},\n {field: \"itemAtLocations\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ItemAtLocation[]).reduce((acc: Array, curr: ItemAtLocation) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class ItemAtLocationService extends ServiceBase {\n\n public async saveItemAtLocation(tenantId: Guid, itemAtLocation: ItemAtLocation, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveItemAtLocationRequest();\n req.tenantId = tenantId;\n req.itemAtLocation = itemAtLocation;\n const extractor = null;\n return this.makeJsonRequest(\"itemAtLocation/v1/saveItemAtLocation\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getItemAtLocations(tenantId: Guid, limitItemIds: readonly Guid[] | null, limitStockLocationIds: readonly Guid[] | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetItemAtLocationsRequest();\n req.tenantId = tenantId;\n req.limitItemIds = limitItemIds;\n req.limitStockLocationIds = limitStockLocationIds;\n const extractor = (response:any) => new GetItemAtLocationsResponse(response).itemAtLocations;\n return this.makeJsonRequest(\"itemAtLocation/v1/getItemAtLocations\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const itemAtLocationService = new ItemAtLocationService();","import api from \"@/app/api\";\nimport type {\n AdvancedProductSearchResult,\n OrderHeader,\n OrderLine,\n} from \"@/app/services/generated/orderService\";\nimport { OrderService } from \"@/app/services/generated/orderService\";\nimport type {\n Outlet,\n OutletSummary,\n} from \"@/app/services/generated/outletService\";\nimport { outletService } from \"@/app/services/generated/outletService\";\nimport { tenantService } from \"@/app/services/extensions/tenantServiceExtended\";\nimport type Guid from \"@/app/types/common/guid\";\nimport { GuidSet, type GuidMap } from \"@/app/types/common/guidcollections\";\nimport { translateWithParams, useI18n } from \"@/plugins/i18n\";\nimport type { PackageType } from \"@/app/services/generated/packagetypeService\";\nimport type { Group } from \"@/app/services/generated/groupService\";\nimport { itemAtLocationService } from \"../generated/itematlocationService\";\n\nconst { $m, $t } = useI18n();\nexport default class OrderServiceExtended extends OrderService {\n /**\n * Generate a file name for an invoice given an order ID\n */\n public async generateInvoiceFilename(orderId: Guid): Promise {\n let filename = \"\";\n let orderHeaderWithInvoiceNumber: OrderHeader | null = null;\n\n const order = (\n await orderService.getOrders(api.tenantId, [orderId], false)\n )[0];\n\n if (\n order.header.readOnly.invoiceNumber === \"\" &&\n !order.header.readOnly.isRetailOrder\n ) {\n orderHeaderWithInvoiceNumber = (\n await orderService.assignInvoiceNumbers(api.tenantId, [\n order.header.readOnly.id,\n ])\n )[0];\n }\n\n // if retail order, set filename to outlet code + date\n if (order.header.readOnly.isRetailOrder) {\n const outlet = await outletService.getOutlet(\n api.tenantId,\n order.header.readOnly.outletId\n );\n filename = translateWithParams(\"orders_file_template_pdf\", {\n number: outlet.readOnly.code + tenantService.today.toString(),\n }).toString();\n } else {\n filename = translateWithParams(\"orders_file_template_pdf\", {\n number: orderHeaderWithInvoiceNumber\n ? orderHeaderWithInvoiceNumber.readOnly.invoiceNumber\n : order.header.readOnly.invoiceNumber,\n }).toString();\n }\n\n return filename;\n }\n\n sortOrderLinesByPackageType(\n packageTypeMap: GuidMap | null>\n ) {\n return (lineA: OrderLine, lineB: OrderLine) => {\n // Sort by package Type name\n const packageTypeA = packageTypeMap.get(lineA.readOnly.stockItemId);\n const packageTypeB = packageTypeMap.get(lineB.readOnly.stockItemId);\n\n const packageCompare = (packageTypeA?.id.toString() ?? \"\").localeCompare(\n packageTypeB?.id.toString() ?? \"\"\n );\n\n if (packageCompare === 0) {\n // Within package Type Sort Name Alphabetically\n return lineA.productName.localeCompare(lineB.productName);\n }\n return packageCompare;\n };\n }\n\n shouldEmailInvoices(\n outlet: Readonly | null,\n group: Readonly | null\n ) {\n return group && !group.sendInvoiceToOutlet\n ? group.emailInvoices\n : !!outlet?.emailInvoices;\n }\n\n async filterProductSearchResultsByAllowSales(\n toFilter: readonly AdvancedProductSearchResult[],\n stockLocationId: Guid,\n includeHidden: boolean\n ) {\n const disallowedItemIds = (\n await itemAtLocationService.getItemAtLocations(\n api.tenantId,\n toFilter.map((result) => result.stockItemId),\n [stockLocationId]\n )\n )\n .filter((x) => !x.allowSales)\n .map((x) => x.stockItemId);\n\n const disallowedItemsHash = new GuidSet(disallowedItemIds);\n\n return toFilter.filter(\n (result) =>\n (includeHidden || !result.isHidden) &&\n !disallowedItemsHash.has(result.stockItemId)\n );\n }\n\n // Mimic what advanced product search does, but splice in \"allowSales\" behaviours at locations\n // we could make take the same arguments as advancedProductSearch Paramters\n // but we want this to 100% break if the api changes\n async advancedProductSearchWithRestrictedSales(\n tenantId: Guid,\n orderId: Guid,\n stockLocationId: Guid,\n productBrandId: Guid | null,\n packageTypeId: Guid | null,\n supplierId: Guid | null,\n includeHidden: boolean\n ): Promise {\n const searchResults = await this.advancedProductSearch(\n tenantId,\n orderId,\n stockLocationId,\n productBrandId,\n packageTypeId,\n supplierId\n );\n\n return await this.filterProductSearchResultsByAllowSales(\n searchResults,\n stockLocationId,\n includeHidden\n );\n }\n\n async advancedProductSearchByOrderHeader(\n tenantId: Guid,\n header: OrderHeader,\n stockLocationId: Guid,\n productBrandId: Guid | null,\n packageTypeId: Guid | null,\n supplierId: Guid | null\n ): Promise {\n return await this.advancedProductSearch2(\n tenantId,\n header.despatchDate,\n header.priceListId,\n stockLocationId,\n header.vatCodeId,\n header.readOnly.outletId,\n header.readOnly.groupId,\n header.standardOrderType,\n productBrandId,\n packageTypeId,\n supplierId\n );\n }\n}\n\nexport const orderService = new OrderServiceExtended();\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumLeadStatus } from \"./enums/enumLeadStatus.generated\";\nimport { EnumYesNoEither } from \"./enums/enumYesNoEither.generated\";\n\n// Model Objects\n\nexport class LeadReadOnly extends ModelObject {\n\n public status: EnumLeadStatus = EnumLeadStatus.active;\n private _wonAt: Instant | null = null;\n /**\n * Timestamp at which the lead was marked as won.\n */\n public get wonAt(): Instant | null { return this._wonAt }\n public set wonAt(value: Instant | null) {\n this._wonAt = value === undefined ? null : value;\n }\n private _lostAt: Instant | null = null;\n /**\n * Timestamp at which the lead was marked as lost.\n */\n public get lostAt(): Instant | null { return this._lostAt }\n public set lostAt(value: Instant | null) {\n this._lostAt = value === undefined ? null : value;\n }\n /**\n * Timestamp at which the lead was last updated.\n */\n public lastUpdatedAt: Instant = Instant.ofEpochMilli(0);\n private _latitude: number | null = null;\n /**\n * Latitude\n */\n public get latitude(): number | null { return this._latitude }\n public set latitude(value: number | null) {\n this._latitude = value === undefined ? null : value;\n }\n private _longitude: number | null = null;\n /**\n * Longitude\n */\n public get longitude(): number | null { return this._longitude }\n public set longitude(value: number | null) {\n this._longitude = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.status = EnumLeadStatus.getByValue(jsonSerializedObject.status, this.status);\n this.wonAt = jsonSerializedObject.wonAt == null ? null : Instant.parse(jsonSerializedObject.wonAt);\n this.lostAt = jsonSerializedObject.lostAt == null ? null : Instant.parse(jsonSerializedObject.lostAt);\n this.lastUpdatedAt = Instant.parse(jsonSerializedObject.lastUpdatedAt);\n this.latitude = jsonSerializedObject.latitude == null ? null : jsonSerializedObject.latitude;\n this.longitude = jsonSerializedObject.longitude == null ? null : jsonSerializedObject.longitude;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.status = this.status.value;\n toRet.wonAt = this.wonAt == null ? null : this.wonAt.toString();\n toRet.lostAt = this.lostAt == null ? null : this.lostAt.toString();\n toRet.lastUpdatedAt = this.lastUpdatedAt.toString();\n toRet.latitude = this.latitude == null ? null : this.latitude;\n toRet.longitude = this.longitude == null ? null : this.longitude;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class Lead extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Lead business name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public businessName: string = \"\";\n /**\n * Telephone number\n * Not Nullable\n * Max Length : 1000\n */\n public telephoneNumber: string = \"\";\n /**\n * Lead contact name\n * Not Nullable\n * Max Length : 1000\n */\n public contactName: string = \"\";\n /**\n * Email Address\n * Not Nullable\n * Max Length : 1000\n */\n public emailAddress: string = \"\";\n /**\n * Notes about the lead\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n private _salesCodeId: Guid | null = null;\n /**\n * Sales Code Id\n */\n public get salesCodeId(): Guid | null { return this._salesCodeId }\n public set salesCodeId(value: Guid | null) {\n this._salesCodeId = value === undefined ? null : value;\n }\n private _salesAreaId: Guid | null = null;\n /**\n * Sales Area Id\n */\n public get salesAreaId(): Guid | null { return this._salesAreaId }\n public set salesAreaId(value: Guid | null) {\n this._salesAreaId = value === undefined ? null : value;\n }\n private _assignedToUserId: Guid | null = null;\n /**\n * User, if any, currently assigned to this lead.\n */\n public get assignedToUserId(): Guid | null { return this._assignedToUserId }\n public set assignedToUserId(value: Guid | null) {\n this._assignedToUserId = value === undefined ? null : value;\n }\n /**\n * The monetary value of the lead. For display and reporting purposes.\n */\n public value: number = 0;\n /**\n * The probability of winning this lead (creating a customer from it). For display and reporting purposes.\n * Not Negative\n */\n public winProbabilityPercentage: number = 0;\n private _leadSourceId: Guid | null = null;\n /**\n * The source that generated this lead.\n */\n public get leadSourceId(): Guid | null { return this._leadSourceId }\n public set leadSourceId(value: Guid | null) {\n this._leadSourceId = value === undefined ? null : value;\n }\n private _startDate: LocalDate | null = null;\n /**\n * The date which the lead became pursued. For reporting purposes only.\n */\n public get startDate(): LocalDate | null { return this._startDate }\n public set startDate(value: LocalDate | null) {\n this._startDate = value === undefined ? null : value;\n }\n private _estimatedClosingDate: LocalDate | null = null;\n /**\n * The date which is is expected for the lead to be closed (won or lost). For reporting purposes only.\n */\n public get estimatedClosingDate(): LocalDate | null { return this._estimatedClosingDate }\n public set estimatedClosingDate(value: LocalDate | null) {\n this._estimatedClosingDate = value === undefined ? null : value;\n }\n private _wonOutletId: Guid | null = null;\n /**\n * The outlet that was won as a result of this lead.\n */\n public get wonOutletId(): Guid | null { return this._wonOutletId }\n public set wonOutletId(value: Guid | null) {\n this._wonOutletId = value === undefined ? null : value;\n }\n private _leadLossReasonId: Guid | null = null;\n /**\n * The reason this lead was lost (not converted to an outlet).\n */\n public get leadLossReasonId(): Guid | null { return this._leadLossReasonId }\n public set leadLossReasonId(value: Guid | null) {\n this._leadLossReasonId = value === undefined ? null : value;\n }\n /**\n * More descriptive notes to why the lead was lost.\n * Not Nullable\n * Max Length : 100000\n */\n public lossReasonNotes: string = \"\";\n /**\n * The current pipeline stage for this lead.\n */\n public pipelineStageId: Guid = Guid.createEmpty();\n /**\n * Whether the current lead is on hold.\n */\n public isOnHold: boolean = false;\n public isHidden: boolean = false;\n public readOnly: LeadReadOnly = new LeadReadOnly();\n /**\n * Contact Address\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine1: string = \"\";\n /**\n * Contact Address\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine2: string = \"\";\n /**\n * Contact Address\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine3: string = \"\";\n /**\n * Contact Address\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine4: string = \"\";\n /**\n * Contact Address\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine5: string = \"\";\n /**\n * Contact Address\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine6: string = \"\";\n /**\n * Contact Address\n * Not Nullable\n * Max Length : 1000\n */\n public addressPostcode: string = \"\";\n public webAddress: string = \"\";\n private _outletTypeId: Guid | null = null;\n public get outletTypeId(): Guid | null { return this._outletTypeId }\n public set outletTypeId(value: Guid | null) {\n this._outletTypeId = value === undefined ? null : value;\n }\n /**\n * Liquor Licence Number, only show for Australia and US region.\n * Not Nullable\n * Max Length : 1000\n */\n public liquorLicenceNumber: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.businessName = jsonSerializedObject.businessName;\n this.telephoneNumber = jsonSerializedObject.telephoneNumber;\n this.contactName = jsonSerializedObject.contactName;\n this.emailAddress = jsonSerializedObject.emailAddress;\n this.notes = jsonSerializedObject.notes;\n this.salesCodeId = jsonSerializedObject.salesCodeId == null ? null : Guid.fromString(jsonSerializedObject.salesCodeId);\n this.salesAreaId = jsonSerializedObject.salesAreaId == null ? null : Guid.fromString(jsonSerializedObject.salesAreaId);\n this.assignedToUserId = jsonSerializedObject.assignedToUserId == null ? null : Guid.fromString(jsonSerializedObject.assignedToUserId);\n this.value = jsonSerializedObject.value;\n this.winProbabilityPercentage = jsonSerializedObject.winProbabilityPercentage;\n this.leadSourceId = jsonSerializedObject.leadSourceId == null ? null : Guid.fromString(jsonSerializedObject.leadSourceId);\n this.startDate = jsonSerializedObject.startDate == null ? null : LocalDate.parse(jsonSerializedObject.startDate);\n this.estimatedClosingDate = jsonSerializedObject.estimatedClosingDate == null ? null : LocalDate.parse(jsonSerializedObject.estimatedClosingDate);\n this.wonOutletId = jsonSerializedObject.wonOutletId == null ? null : Guid.fromString(jsonSerializedObject.wonOutletId);\n this.leadLossReasonId = jsonSerializedObject.leadLossReasonId == null ? null : Guid.fromString(jsonSerializedObject.leadLossReasonId);\n this.lossReasonNotes = jsonSerializedObject.lossReasonNotes;\n this.pipelineStageId = Guid.fromString(jsonSerializedObject.pipelineStageId);\n this.isOnHold = jsonSerializedObject.isOnHold;\n this.isHidden = jsonSerializedObject.isHidden;\n this.readOnly = new LeadReadOnly(jsonSerializedObject.readOnly);\n this.addressLine1 = jsonSerializedObject.addressLine1;\n this.addressLine2 = jsonSerializedObject.addressLine2;\n this.addressLine3 = jsonSerializedObject.addressLine3;\n this.addressLine4 = jsonSerializedObject.addressLine4;\n this.addressLine5 = jsonSerializedObject.addressLine5;\n this.addressLine6 = jsonSerializedObject.addressLine6;\n this.addressPostcode = jsonSerializedObject.addressPostcode;\n this.webAddress = jsonSerializedObject.webAddress;\n this.outletTypeId = jsonSerializedObject.outletTypeId == null ? null : Guid.fromString(jsonSerializedObject.outletTypeId);\n this.liquorLicenceNumber = jsonSerializedObject.liquorLicenceNumber;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.businessName = this.businessName;\n toRet.telephoneNumber = this.telephoneNumber;\n toRet.contactName = this.contactName;\n toRet.emailAddress = this.emailAddress;\n toRet.notes = this.notes;\n toRet.salesCodeId = this.salesCodeId == null ? null : this.salesCodeId.toString();\n toRet.salesAreaId = this.salesAreaId == null ? null : this.salesAreaId.toString();\n toRet.assignedToUserId = this.assignedToUserId == null ? null : this.assignedToUserId.toString();\n toRet.value = this.value;\n toRet.winProbabilityPercentage = this.winProbabilityPercentage;\n toRet.leadSourceId = this.leadSourceId == null ? null : this.leadSourceId.toString();\n toRet.startDate = this.startDate == null ? null : this.startDate.toString();\n toRet.estimatedClosingDate = this.estimatedClosingDate == null ? null : this.estimatedClosingDate.toString();\n toRet.wonOutletId = this.wonOutletId == null ? null : this.wonOutletId.toString();\n toRet.leadLossReasonId = this.leadLossReasonId == null ? null : this.leadLossReasonId.toString();\n toRet.lossReasonNotes = this.lossReasonNotes;\n toRet.pipelineStageId = this.pipelineStageId.toString();\n toRet.isOnHold = this.isOnHold;\n toRet.isHidden = this.isHidden;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.addressLine1 = this.addressLine1;\n toRet.addressLine2 = this.addressLine2;\n toRet.addressLine3 = this.addressLine3;\n toRet.addressLine4 = this.addressLine4;\n toRet.addressLine5 = this.addressLine5;\n toRet.addressLine6 = this.addressLine6;\n toRet.addressPostcode = this.addressPostcode;\n toRet.webAddress = this.webAddress;\n toRet.outletTypeId = this.outletTypeId == null ? null : this.outletTypeId.toString();\n toRet.liquorLicenceNumber = this.liquorLicenceNumber;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"Lead.Id cannot be empty\"},\n {field: \"businessName\", rule: (v: any) => v == null || v.length !== 0 || \"BusinessName cannot be empty\"},\n {field: \"businessName\", rule: (v: any) => v == null || v.length <= 1000 || \"BusinessName has too many characters (1000)\"},\n {field: \"telephoneNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"TelephoneNumber has too many characters (1000)\"},\n {field: \"contactName\", rule: (v: any) => v == null || v.length <= 1000 || \"ContactName has too many characters (1000)\"},\n {field: \"emailAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"EmailAddress has too many characters (1000)\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"salesCodeId\", rule: (v: any) => v == null || !v.isEmpty() || \"Lead.SalesCodeId cannot be empty\"},\n {field: \"salesAreaId\", rule: (v: any) => v == null || !v.isEmpty() || \"Lead.SalesAreaId cannot be empty\"},\n {field: \"assignedToUserId\", rule: (v: any) => v == null || !v.isEmpty() || \"Lead.AssignedToUserId cannot be empty\"},\n {field: \"leadSourceId\", rule: (v: any) => v == null || !v.isEmpty() || \"Lead.LeadSourceId cannot be empty\"},\n {field: \"wonOutletId\", rule: (v: any) => v == null || !v.isEmpty() || \"Lead.WonOutletId cannot be empty\"},\n {field: \"leadLossReasonId\", rule: (v: any) => v == null || !v.isEmpty() || \"Lead.LeadLossReasonId cannot be empty\"},\n {field: \"lossReasonNotes\", rule: (v: any) => v == null || v.length <= 100000 || \"LossReasonNotes has too many characters (100000)\"},\n {field: \"pipelineStageId\", rule: (v: any) => !v.isEmpty() || \"Lead.PipelineStageId cannot be empty\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"addressLine1\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine1 has too many characters (1000)\"},\n {field: \"addressLine2\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine2 has too many characters (1000)\"},\n {field: \"addressLine3\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine3 has too many characters (1000)\"},\n {field: \"addressLine4\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine4 has too many characters (1000)\"},\n {field: \"addressLine5\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine5 has too many characters (1000)\"},\n {field: \"addressLine6\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine6 has too many characters (1000)\"},\n {field: \"addressPostcode\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressPostcode has too many characters (1000)\"},\n {field: \"webAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"WebAddress has too many characters (1000)\"},\n {field: \"outletTypeId\", rule: (v: any) => v == null || !v.isEmpty() || \"Lead.OutletTypeId cannot be empty\"},\n {field: \"liquorLicenceNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"LiquorLicenceNumber has too many characters (1000)\"},\n ];\n}\n\n\nexport class LeadFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _statuses: EnumLeadStatus[] | null = null;\n public get statuses(): EnumLeadStatus[] | null { return this._statuses }\n public set statuses(value: EnumLeadStatus[] | null) {\n this._statuses = value === undefined ? null : value;\n }\n private _assignedUserIds: Guid[] | null = null;\n public get assignedUserIds(): Guid[] | null { return this._assignedUserIds }\n public set assignedUserIds(value: Guid[] | null) {\n this._assignedUserIds = value === undefined ? null : value;\n }\n private _leadPipelineStageIds: Guid[] | null = null;\n public get leadPipelineStageIds(): Guid[] | null { return this._leadPipelineStageIds }\n public set leadPipelineStageIds(value: Guid[] | null) {\n this._leadPipelineStageIds = value === undefined ? null : value;\n }\n private _wonOutletIds: Guid[] | null = null;\n public get wonOutletIds(): Guid[] | null { return this._wonOutletIds }\n public set wonOutletIds(value: Guid[] | null) {\n this._wonOutletIds = value === undefined ? null : value;\n }\n public assignedOrNot: EnumYesNoEither = EnumYesNoEither.either;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.statuses = jsonSerializedObject.statuses == null ? null : jsonSerializedObject.statuses.map((v: any) => EnumLeadStatus.getByValue(v));\n this.assignedUserIds = jsonSerializedObject.assignedUserIds == null ? null : jsonSerializedObject.assignedUserIds.map((v: any) => Guid.fromString(v));\n this.leadPipelineStageIds = jsonSerializedObject.leadPipelineStageIds == null ? null : jsonSerializedObject.leadPipelineStageIds.map((v: any) => Guid.fromString(v));\n this.wonOutletIds = jsonSerializedObject.wonOutletIds == null ? null : jsonSerializedObject.wonOutletIds.map((v: any) => Guid.fromString(v));\n this.assignedOrNot = EnumYesNoEither.getByValue(jsonSerializedObject.assignedOrNot, this.assignedOrNot);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.statuses = this.statuses == null ? null : this.statuses.map(v => v.value);\n toRet.assignedUserIds = this.assignedUserIds == null ? null : this.assignedUserIds.map(v => v.toString());\n toRet.leadPipelineStageIds = this.leadPipelineStageIds == null ? null : this.leadPipelineStageIds.map(v => v.toString());\n toRet.wonOutletIds = this.wonOutletIds == null ? null : this.wonOutletIds.map(v => v.toString());\n toRet.assignedOrNot = this.assignedOrNot.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class FilteredLeadResults extends ModelObject {\n\n public matchingCount: number = 0;\n public leads: Lead[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.leads = jsonSerializedObject.leads.map((v: any) => new Lead(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.leads = this.leads.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"leads\", rule: (v: any) => !!v || \"leads is required\"},\n {field: \"leads\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Lead[]).reduce((acc: Array, curr: Lead) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllLeadsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllLeadsResponse extends ModelObject {\n\n public leads: Lead[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.leads = jsonSerializedObject.leads.map((v: any) => new Lead(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.leads = this.leads.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"leads\", rule: (v: any) => !!v || \"leads is required\"},\n {field: \"leads\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Lead[]).reduce((acc: Array, curr: Lead) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetLeadRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public leadId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.leadId = Guid.fromString(jsonSerializedObject.leadId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.leadId = this.leadId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"leadId\", rule: (v: any) => !v.isEmpty() || \".LeadId cannot be empty\"},\n ];\n}\n\n\nexport class GetLeadResponse extends ModelObject {\n\n public lead: Lead = new Lead();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.lead = new Lead(jsonSerializedObject.lead);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.lead = this.lead.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"lead\", rule: (v: any) => !!v || \"lead is required\"},\n {field: \"lead\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetLeadsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public leadIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.leadIds = jsonSerializedObject.leadIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.leadIds = this.leadIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetLeadsResponse extends ModelObject {\n\n public leads: Lead[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.leads = jsonSerializedObject.leads.map((v: any) => new Lead(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.leads = this.leads.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"leads\", rule: (v: any) => !!v || \"leads is required\"},\n {field: \"leads\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Lead[]).reduce((acc: Array, curr: Lead) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetLeadsByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: LeadFilter = new LeadFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new LeadFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetLeadsByFilterResponse extends ModelObject {\n\n public results: FilteredLeadResults = new FilteredLeadResults();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredLeadResults(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveLeadRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public lead: Lead = new Lead();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.lead = new Lead(jsonSerializedObject.lead);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.lead = this.lead.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"lead\", rule: (v: any) => !!v || \"lead is required\"},\n {field: \"lead\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveLeadsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public leads: readonly Lead[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.leads = jsonSerializedObject.leads.map((v: any) => new Lead(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.leads = this.leads.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"leads\", rule: (v: any) => !!v || \"leads is required\"},\n {field: \"leads\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Lead[]).reduce((acc: Array, curr: Lead) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SetLeadIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public leadId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.leadId = Guid.fromString(jsonSerializedObject.leadId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.leadId = this.leadId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"leadId\", rule: (v: any) => !v.isEmpty() || \".LeadId cannot be empty\"},\n ];\n}\n\n\nexport class UpdateLeadLatLngsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public leadId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.leadId = Guid.fromString(jsonSerializedObject.leadId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.leadId = this.leadId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"leadId\", rule: (v: any) => !v.isEmpty() || \".LeadId cannot be empty\"},\n ];\n}\n\n\nexport class LeadService extends ServiceBase {\n\n public async getAllLeads(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllLeadsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllLeadsResponse(response).leads;\n return this.makeJsonRequest(\"lead/v1/getAllLeads\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getLead(tenantId: Guid, leadId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetLeadRequest();\n req.tenantId = tenantId;\n req.leadId = leadId;\n const extractor = (response:any) => new GetLeadResponse(response).lead;\n return this.makeJsonRequest(\"lead/v1/getLead\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getLeads(tenantId: Guid, leadIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetLeadsRequest();\n req.tenantId = tenantId;\n req.leadIds = leadIds;\n const extractor = (response:any) => new GetLeadsResponse(response).leads;\n return this.makeJsonRequest(\"lead/v1/getLeads\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getLeadsByFilter(tenantId: Guid, filter: LeadFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetLeadsByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetLeadsByFilterResponse(response).results;\n return this.makeJsonRequest(\"lead/v1/getLeadsByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveLead(tenantId: Guid, lead: Lead, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveLeadRequest();\n req.tenantId = tenantId;\n req.lead = lead;\n const extractor = null;\n return this.makeJsonRequest(\"lead/v1/saveLead\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveLeads(tenantId: Guid, leads: readonly Lead[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveLeadsRequest();\n req.tenantId = tenantId;\n req.leads = leads;\n const extractor = null;\n return this.makeJsonRequest(\"lead/v1/saveLeads\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setLeadIsHidden(tenantId: Guid, leadId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetLeadIsHiddenRequest();\n req.tenantId = tenantId;\n req.leadId = leadId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"lead/v1/setLeadIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const leadService = new LeadService();","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumCacheEntityType } from \"./enums/enumCacheEntityType.generated\";\n\n// Model Objects\n\nexport class TypesModifiedSinceResults extends ModelObject {\n\n /**\n * The last sequence number issued in the system. Usually stored by the receiver and then used in the next call to GetTypesModifiedSince to get types modified after the first call.\n */\n public latestSequenceNumber: number = 0;\n /**\n * All types which may have been modified since AfterSequence. This is deliberately generous in that it may include types where an update was attempted but actually resulted in no modification (Eg setting is_default on a Vat Code which was already the default), or types which have been modified and then modified back to the initial value.\n */\n public modifiedEntityTypes: EnumCacheEntityType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.latestSequenceNumber = jsonSerializedObject.latestSequenceNumber;\n this.modifiedEntityTypes = jsonSerializedObject.modifiedEntityTypes.map((v: any) => EnumCacheEntityType.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.latestSequenceNumber = this.latestSequenceNumber;\n toRet.modifiedEntityTypes = this.modifiedEntityTypes.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"latestSequenceNumber\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"LatestSequenceNumber is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"latestSequenceNumber\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"LatestSequenceNumber is above maximum allowed value: 9223372036854775807\"},\n ];\n}\n\n\nexport class RegisterTypeModifiedRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public cacheEntityType: EnumCacheEntityType = EnumCacheEntityType.none;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.cacheEntityType = EnumCacheEntityType.getByValue(jsonSerializedObject.cacheEntityType, this.cacheEntityType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.cacheEntityType = this.cacheEntityType.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class RegisterTypesModifiedRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public cacheEntityTypes: readonly EnumCacheEntityType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.cacheEntityTypes = jsonSerializedObject.cacheEntityTypes.map((v: any) => EnumCacheEntityType.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.cacheEntityTypes = this.cacheEntityTypes.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetTypesModifiedSinceRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n /**\n * Sequence to get modifications from. Typically set to 0 on first call, then to the returned latest sequence from previous call on each subsequent call.\n */\n public afterSequence: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.afterSequence = jsonSerializedObject.afterSequence;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.afterSequence = this.afterSequence;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"afterSequence\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"AfterSequence is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"afterSequence\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"AfterSequence is above maximum allowed value: 9223372036854775807\"},\n ];\n}\n\n\nexport class GetTypesModifiedSinceResponse extends ModelObject {\n\n public results: TypesModifiedSinceResults = new TypesModifiedSinceResults();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new TypesModifiedSinceResults(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class ModifiedTypeService extends ServiceBase {\n\n public async getTypesModifiedSince(tenantId: Guid, afterSequence: number, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetTypesModifiedSinceRequest();\n req.tenantId = tenantId;\n req.afterSequence = afterSequence;\n const extractor = (response:any) => new GetTypesModifiedSinceResponse(response).results;\n return this.makeJsonRequest(\"modifiedType/v1/getTypesModifiedSince\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const modifiedTypeService = new ModifiedTypeService();","import type { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport { modifiedTypeService } from \"@/app/services/generated/modifiedtypev1Service\";\nimport type Guid from \"@/app/types/common/guid\";\nimport type { GuidMap } from \"@/app/types/common/guidcollections\";\nimport type { ShallowRef } from \"vue\";\nimport { disallowConcurrency, distinctGuids, toGuidMap } from \"@/app/apiutils\";\nimport type { Maybe } from \"@/components/utils/typeHelpers\";\nimport { BrewManError } from \"@/app/errors\";\nimport messages, { translateWithParams } from \"@/plugins/i18n\";\nimport { makeRef } from \"@/components/composables/reactivityTypes\";\n\n/**\n * The API cache.\n *\n * Provides cache objects that allow for synchronous access to api objects. You request the entity caches by providing a\n * blueprint of the final cache you would like to create using the entity cache types. The returned cache will use the\n * same object properties you specify but replace the entity cache type with the actual instance type of the cache.\n *\n * The returned cache will also contain an `update` method that can be used to refresh the requested entity cache types.\n * This update method will not update entity caches that are not part of the current cache object. However the cache entity\n * instances are shared amongst all cache objects, so updates will be applied to all uses of the entity cache in any cache\n * object.\n *\n * Note. The caches are not reactive.\n */\n\n// Global state of the cache.\nlet currentCacheSequence = 0;\nlet entityCacheTypesMarkedForUpdate = new Set();\nlet cacheTenantId: Guid | null = null;\n\n/**\n * Base class for the cache *store* - this is a central store of cacheable entities that the entity caches will take a copy\n * from when needed.\n *\n * Has an update method that will refetch entities from source when cacheservice says is required.\n */\nexport class EntityCacheStore {\n private _cacheEntities: readonly T[] = [];\n private cacheVersion = 0;\n\n public constructor(\n private cacheType: EnumCacheEntityType,\n private getAllMethod: (tenantId: Guid) => Promise\n ) {}\n\n public get cacheEntities() {\n return this._cacheEntities;\n }\n\n async update(): Promise {\n if (entityCacheTypesMarkedForUpdate.has(this.cacheType)) {\n entityCacheTypesMarkedForUpdate.delete(this.cacheType);\n this._cacheEntities = (await this.getAllMethod(api.tenantId)).map((obj) =>\n Object.freeze(obj)\n );\n this.cacheVersion++;\n }\n\n return this.cacheVersion;\n }\n}\n\nexport interface EntityCache {\n update(): Promise;\n}\n\n/**\n * Base class for centralCacheStore readers that have guid keys.\n *\n * Note. Caches are initialised as empty to reduce likelihood of forgetting a call to update before use.\n */\nexport abstract class EntityWithGuidKeyCache\n implements EntityCache\n{\n private centralCacheStore: EntityCacheStore;\n\n private lookupMapLazy?: ShallowRef>;\n private cacheVersion = -1;\n private readonly keyExtractorFn: (entity: T) => Guid;\n\n private refEntities = makeRef([]);\n\n private get lookupMap() {\n return (\n this.lookupMapLazy ||\n (this.lookupMapLazy = makeRef(\n toGuidMap(this.refEntities.value, (x) => this.keyExtractorFn(x))\n ))\n ).value;\n }\n\n public get allReactive(): ShallowRef {\n return this.refEntities;\n }\n\n protected constructor(\n centralCacheStore: EntityCacheStore,\n keyExtractorFn: (entity: T) => Guid\n ) {\n this.centralCacheStore = centralCacheStore;\n this.keyExtractorFn = keyExtractorFn;\n }\n\n /**\n * Update the centralCacheStore store (if required) and then update our local copy.\n */\n async update() {\n const cacheVersion = await this.centralCacheStore.update();\n if (cacheVersion !== this.cacheVersion) {\n // Take a copy of the cache store entity array as the cache store may update independently of us.\n this.refEntities.value = [...this.centralCacheStore.cacheEntities];\n if (this.lookupMapLazy) {\n this.lookupMapLazy.value = toGuidMap(this.refEntities.value, (x) =>\n this.keyExtractorFn(x)\n );\n }\n\n this.cacheVersion = cacheVersion;\n }\n }\n\n /**\n * Get the contents of the centralCacheStore.\n */\n get all(): readonly T[] {\n return this.refEntities.value;\n }\n\n /**\n * Get the entity by its key.\n * Throws if key is not null / undefined and the entity does not exist.\n */\n forId(id: Guid): T;\n forId(id: Maybe): T | null;\n forId(id: Maybe): T | null {\n if (!id) {\n return null;\n }\n const result = this.lookupMap.get(id);\n if (!result) {\n throw new BrewManError(\n translateWithParams(\"unable_to_find_id_in_cache\", {\n id: id.toString(),\n }).toString()\n );\n }\n return result;\n }\n\n /**\n * Get an entity by its key.\n */\n getById(id: Maybe, required: true): T;\n getById(id: Maybe, required: false): T | null;\n getById(id: Maybe): T | null;\n getById(id: Maybe, required: boolean = false): T | null {\n if (id === null || id === undefined) {\n if (required) {\n throw new BrewManError(messages.get_by_id_searched_for_null);\n }\n return null;\n }\n\n const foundValue = this.lookupMap.get(id) ?? null;\n\n if (required && !foundValue) {\n throw new BrewManError(\n translateWithParams(\"unable_to_find_id_in_cache\", {\n id: id.toString(),\n }).toString()\n );\n }\n\n return foundValue;\n }\n\n has(id: Maybe): boolean {\n if (id === null || id === undefined) {\n return false;\n }\n\n return this.lookupMap.has(id);\n }\n\n /**\n * Get an array of entities filtered by an array of Guids. Ignores\n * null/undefined and duplicated Guids.\n */\n getByDistinctIds(ids: Maybe[]): readonly T[] {\n const distinctIds = distinctGuids(ids);\n return this.all.filter((arr) =>\n distinctIds.some((id) => id.equals(this.keyExtractorFn(arr)))\n );\n }\n}\n\n// It would be good to figure out how to restrict this to EntityCache's only.\nexport type EntityCacheConstructor = new (...args: any[]) => T;\n\n// Ensure multiple cache sets are not performing updates at the same time.\nconst updateEntityCaches = disallowConcurrency(\n async (entityCaches: EntityCache[]): Promise => {\n if (!cacheTenantId?.equals(api.tenantId)) {\n // If the tenant has changed, we need to update all caches.\n cacheTenantId = api.tenantId;\n markAllCachesForUpdate();\n }\n // Query service for modified types\n const modifiedSinceResults =\n await modifiedTypeService.getTypesModifiedSince(\n api.tenantId,\n currentCacheSequence\n );\n\n // Store the types of caches that need updating\n for (const serverCacheType of modifiedSinceResults.modifiedEntityTypes) {\n entityCacheTypesMarkedForUpdate.add(serverCacheType);\n }\n\n // Store latest sequence number, then we only invalidate what's changed next time to check for changes.\n currentCacheSequence = modifiedSinceResults.latestSequenceNumber;\n\n // Perform async update of all requested caches (these updates will likely callback here to see if they need updating)\n await Promise.all(entityCaches.map((entityCache) => entityCache.update()));\n }\n);\n\nexport type UpdateCacheSetFunc = () => Promise;\n\ntype BlueprintToCacheSet = {\n [P in keyof T]: T[P] extends EntityCacheConstructor ? U : never;\n};\n\nexport type CacheSet = BlueprintToCacheSet & {\n update: UpdateCacheSetFunc;\n};\n\n/**\n * Builds a working cache set from a blueprint. Types will be replaced with instances.\n *\n * @param cacheSetBlueprint A blueprint of the cache set to build.\n */\nfunction buildCacheSet>(\n cacheSetBlueprint: T\n): CacheSet {\n let cacheSet: any = {};\n let entityCaches: EntityCache[] = [];\n\n for (const key of Object.keys(cacheSetBlueprint)) {\n const entityCache = new cacheSetBlueprint[key]() as EntityCache;\n entityCaches.push(entityCache);\n cacheSet[key] = entityCache;\n }\n\n cacheSet.update = () => updateEntityCaches(entityCaches);\n\n return cacheSet;\n}\n\nfunction markAllCachesForUpdate() {\n currentCacheSequence = 0;\n}\n\nexport default {\n buildCacheSet,\n markAllCachesForUpdate,\n};\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumDocumentFileType } from \"./enums/enumDocumentFileType.generated\";\nimport { EnumPalletStatus } from \"./enums/enumPalletStatus.generated\";\nimport { EnumYesNoEither } from \"./enums/enumYesNoEither.generated\";\n\n// Model Objects\n\nexport class PalletHeaderReadOnly extends ModelObject {\n\n /**\n * The barcode generated for this pallet. Generated from sequence not user editable.\n * Not Nullable\n * Max Length : 1000\n */\n public barcode: string = \"\";\n private _deliveredToOrderId: Guid | null = null;\n /**\n * The order for which this pallet was delivered, if any. If this pallet was registered as delivered to multiple orders then last processed registration wins.\n */\n public get deliveredToOrderId(): Guid | null { return this._deliveredToOrderId }\n public set deliveredToOrderId(value: Guid | null) {\n this._deliveredToOrderId = value === undefined ? null : value;\n }\n /**\n * Timestamp at which the pallet was created on the system. Captured by system not user editable.\n */\n public createdAt: Instant = Instant.ofEpochMilli(0);\n /**\n * User who created the pallet. Captured by system not user editable.\n */\n public createdByUserId: Guid = Guid.createEmpty();\n private _disassembledAt: Instant | null = null;\n /**\n * Timestamp at which the pallet was disassembled on the system. Captured by system not user editable.\n */\n public get disassembledAt(): Instant | null { return this._disassembledAt }\n public set disassembledAt(value: Instant | null) {\n this._disassembledAt = value === undefined ? null : value;\n }\n private _disassembledByUserId: Guid | null = null;\n /**\n * User who disassembled the pallet. Captured by system not user editable.\n */\n public get disassembledByUserId(): Guid | null { return this._disassembledByUserId }\n public set disassembledByUserId(value: Guid | null) {\n this._disassembledByUserId = value === undefined ? null : value;\n }\n private _deliveredAt: Instant | null = null;\n /**\n * Timestamp at which the pallet was marked as delivered on the system. Captured by system not user editable. Will be the system timestamp at which the pallet delivered instruction was processed, and in particular is NOT the time captured by the distrubtion app.\n */\n public get deliveredAt(): Instant | null { return this._deliveredAt }\n public set deliveredAt(value: Instant | null) {\n this._deliveredAt = value === undefined ? null : value;\n }\n private _deliveredByUserId: Guid | null = null;\n /**\n * User who delivered the pallet. Captured by system not user editable.\n */\n public get deliveredByUserId(): Guid | null { return this._deliveredByUserId }\n public set deliveredByUserId(value: Guid | null) {\n this._deliveredByUserId = value === undefined ? null : value;\n }\n /**\n * Pallet number. Allocated from pallet numbering sequence.\n * Not Nullable\n * Max Length : 1000\n */\n public number: string = \"\";\n public status: EnumPalletStatus = EnumPalletStatus.none;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.barcode = jsonSerializedObject.barcode;\n this.deliveredToOrderId = jsonSerializedObject.deliveredToOrderId == null ? null : Guid.fromString(jsonSerializedObject.deliveredToOrderId);\n this.createdAt = Instant.parse(jsonSerializedObject.createdAt);\n this.createdByUserId = Guid.fromString(jsonSerializedObject.createdByUserId);\n this.disassembledAt = jsonSerializedObject.disassembledAt == null ? null : Instant.parse(jsonSerializedObject.disassembledAt);\n this.disassembledByUserId = jsonSerializedObject.disassembledByUserId == null ? null : Guid.fromString(jsonSerializedObject.disassembledByUserId);\n this.deliveredAt = jsonSerializedObject.deliveredAt == null ? null : Instant.parse(jsonSerializedObject.deliveredAt);\n this.deliveredByUserId = jsonSerializedObject.deliveredByUserId == null ? null : Guid.fromString(jsonSerializedObject.deliveredByUserId);\n this.number = jsonSerializedObject.number;\n this.status = EnumPalletStatus.getByValue(jsonSerializedObject.status, this.status);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.barcode = this.barcode;\n toRet.deliveredToOrderId = this.deliveredToOrderId == null ? null : this.deliveredToOrderId.toString();\n toRet.createdAt = this.createdAt.toString();\n toRet.createdByUserId = this.createdByUserId.toString();\n toRet.disassembledAt = this.disassembledAt == null ? null : this.disassembledAt.toString();\n toRet.disassembledByUserId = this.disassembledByUserId == null ? null : this.disassembledByUserId.toString();\n toRet.deliveredAt = this.deliveredAt == null ? null : this.deliveredAt.toString();\n toRet.deliveredByUserId = this.deliveredByUserId == null ? null : this.deliveredByUserId.toString();\n toRet.number = this.number;\n toRet.status = this.status.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"barcode\", rule: (v: any) => v == null || v.length <= 1000 || \"Barcode has too many characters (1000)\"},\n {field: \"deliveredToOrderId\", rule: (v: any) => v == null || !v.isEmpty() || \"PalletHeaderReadOnly.DeliveredToOrderId cannot be empty\"},\n {field: \"createdByUserId\", rule: (v: any) => !v.isEmpty() || \"PalletHeaderReadOnly.CreatedByUserId cannot be empty\"},\n {field: \"disassembledByUserId\", rule: (v: any) => v == null || !v.isEmpty() || \"PalletHeaderReadOnly.DisassembledByUserId cannot be empty\"},\n {field: \"deliveredByUserId\", rule: (v: any) => v == null || !v.isEmpty() || \"PalletHeaderReadOnly.DeliveredByUserId cannot be empty\"},\n {field: \"number\", rule: (v: any) => v == null || v.length <= 1000 || \"Number has too many characters (1000)\"},\n ];\n}\n\n\nexport class PalletHeader extends BaseModelObject {\n\n public id: Guid = Guid.createEmpty();\n public version: number = 0;\n /**\n * PalletTypeId.\n */\n public palletTypeId: Guid = Guid.createEmpty();\n /**\n * Weight of this pallet when empty. (Initially copied from pallet type but can be changed).\n * Not Negative\n */\n public emptyWeightKg: number = 0;\n private _intendedForOrderId: Guid | null = null;\n /**\n * The order (if any) which this pallet is ear-marked for.\n */\n public get intendedForOrderId(): Guid | null { return this._intendedForOrderId }\n public set intendedForOrderId(value: Guid | null) {\n this._intendedForOrderId = value === undefined ? null : value;\n }\n /**\n * Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n public readOnly: PalletHeaderReadOnly = new PalletHeaderReadOnly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.version = jsonSerializedObject.version;\n this.palletTypeId = Guid.fromString(jsonSerializedObject.palletTypeId);\n this.emptyWeightKg = jsonSerializedObject.emptyWeightKg;\n this.intendedForOrderId = jsonSerializedObject.intendedForOrderId == null ? null : Guid.fromString(jsonSerializedObject.intendedForOrderId);\n this.notes = jsonSerializedObject.notes;\n this.readOnly = new PalletHeaderReadOnly(jsonSerializedObject.readOnly);\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.version = this.version;\n toRet.palletTypeId = this.palletTypeId.toString();\n toRet.emptyWeightKg = this.emptyWeightKg;\n toRet.intendedForOrderId = this.intendedForOrderId == null ? null : this.intendedForOrderId.toString();\n toRet.notes = this.notes;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"PalletHeader.Id cannot be empty\"},\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"palletTypeId\", rule: (v: any) => !v.isEmpty() || \"PalletHeader.PalletTypeId cannot be empty\"},\n {field: \"intendedForOrderId\", rule: (v: any) => v == null || !v.isEmpty() || \"PalletHeader.IntendedForOrderId cannot be empty\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class PalletLine extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * The item which is on the pallet in this line.\n */\n public itemId: Guid = Guid.createEmpty();\n /**\n * URN of the item which is on the pallet in this line.\n * Not Nullable\n * Max Length : 1000\n */\n public urn: string = \"\";\n /**\n * The quantity of this item line. If a container id is given then this should be 1.\n * Greater Than : 0\n */\n public quantity: number = 0;\n /**\n * Unit of Measure Id. This should match the unit of measure of the stock item.\n */\n public unitOfMeasureId: Guid = Guid.createEmpty();\n private _containerId: Guid | null = null;\n /**\n * The Container which is on the pallet in this line. If specified then Quantity should be 1.\n */\n public get containerId(): Guid | null { return this._containerId }\n public set containerId(value: Guid | null) {\n this._containerId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.itemId = Guid.fromString(jsonSerializedObject.itemId);\n this.urn = jsonSerializedObject.urn;\n this.quantity = jsonSerializedObject.quantity;\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n this.containerId = jsonSerializedObject.containerId == null ? null : Guid.fromString(jsonSerializedObject.containerId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.itemId = this.itemId.toString();\n toRet.urn = this.urn;\n toRet.quantity = this.quantity;\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n toRet.containerId = this.containerId == null ? null : this.containerId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"PalletLine.Id cannot be empty\"},\n {field: \"itemId\", rule: (v: any) => !v.isEmpty() || \"PalletLine.ItemId cannot be empty\"},\n {field: \"urn\", rule: (v: any) => v == null || v.length <= 1000 || \"Urn has too many characters (1000)\"},\n {field: \"quantity\", rule: (v: any) => v == null || v > 0 || \"Quantity is not greater than minimum allowed value: 0\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"PalletLine.UnitOfMeasureId cannot be empty\"},\n {field: \"containerId\", rule: (v: any) => v == null || !v.isEmpty() || \"PalletLine.ContainerId cannot be empty\"},\n ];\n}\n\n\nexport class PalletCalculated extends ModelObject {\n\n /**\n * Sum of line total weight and pallet's empty weight\n */\n public totalWeightKg: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.totalWeightKg = jsonSerializedObject.totalWeightKg;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.totalWeightKg = this.totalWeightKg;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class Pallet extends BaseModelObject {\n\n public header: PalletHeader = new PalletHeader();\n public lines: PalletLine[] = [];\n public calculated: PalletCalculated = new PalletCalculated();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.header = new PalletHeader(jsonSerializedObject.header);\n this.lines = jsonSerializedObject.lines.map((v: any) => new PalletLine(v));\n this.calculated = new PalletCalculated(jsonSerializedObject.calculated);\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.header = this.header.toJsonSerializedObject();\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n toRet.calculated = this.calculated.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PalletLine[]).reduce((acc: Array, curr: PalletLine) => acc.concat(curr.validate()), new Array());\n }},\n {field: \"calculated\", rule: (v: any) => !!v || \"calculated is required\"},\n {field: \"calculated\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class PalletFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _statuses: EnumPalletStatus[] | null = null;\n public get statuses(): EnumPalletStatus[] | null { return this._statuses }\n public set statuses(value: EnumPalletStatus[] | null) {\n this._statuses = value === undefined ? null : value;\n }\n public intendedForOrderOrNot: EnumYesNoEither = EnumYesNoEither.either;\n private _intendedForOrderIds: Guid[] | null = null;\n public get intendedForOrderIds(): Guid[] | null { return this._intendedForOrderIds }\n public set intendedForOrderIds(value: Guid[] | null) {\n this._intendedForOrderIds = value === undefined ? null : value;\n }\n private _deliveredToOrderIds: Guid[] | null = null;\n public get deliveredToOrderIds(): Guid[] | null { return this._deliveredToOrderIds }\n public set deliveredToOrderIds(value: Guid[] | null) {\n this._deliveredToOrderIds = value === undefined ? null : value;\n }\n private _palletIds: Guid[] | null = null;\n public get palletIds(): Guid[] | null { return this._palletIds }\n public set palletIds(value: Guid[] | null) {\n this._palletIds = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.statuses = jsonSerializedObject.statuses == null ? null : jsonSerializedObject.statuses.map((v: any) => EnumPalletStatus.getByValue(v));\n this.intendedForOrderOrNot = EnumYesNoEither.getByValue(jsonSerializedObject.intendedForOrderOrNot, this.intendedForOrderOrNot);\n this.intendedForOrderIds = jsonSerializedObject.intendedForOrderIds == null ? null : jsonSerializedObject.intendedForOrderIds.map((v: any) => Guid.fromString(v));\n this.deliveredToOrderIds = jsonSerializedObject.deliveredToOrderIds == null ? null : jsonSerializedObject.deliveredToOrderIds.map((v: any) => Guid.fromString(v));\n this.palletIds = jsonSerializedObject.palletIds == null ? null : jsonSerializedObject.palletIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.statuses = this.statuses == null ? null : this.statuses.map(v => v.value);\n toRet.intendedForOrderOrNot = this.intendedForOrderOrNot.value;\n toRet.intendedForOrderIds = this.intendedForOrderIds == null ? null : this.intendedForOrderIds.map(v => v.toString());\n toRet.deliveredToOrderIds = this.deliveredToOrderIds == null ? null : this.deliveredToOrderIds.map(v => v.toString());\n toRet.palletIds = this.palletIds == null ? null : this.palletIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class FilteredPalletsResult extends ModelObject {\n\n public matchingCount: number = 0;\n public pallets: Pallet[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.pallets = jsonSerializedObject.pallets.map((v: any) => new Pallet(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.pallets = this.pallets.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"pallets\", rule: (v: any) => !!v || \"pallets is required\"},\n {field: \"pallets\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Pallet[]).reduce((acc: Array, curr: Pallet) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetPalletRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public palletId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.palletId = Guid.fromString(jsonSerializedObject.palletId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.palletId = this.palletId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"palletId\", rule: (v: any) => !v.isEmpty() || \".PalletId cannot be empty\"},\n ];\n}\n\n\nexport class GetPalletResponse extends ModelObject {\n\n public pallet: Pallet = new Pallet();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.pallet = new Pallet(jsonSerializedObject.pallet);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.pallet = this.pallet.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"pallet\", rule: (v: any) => !!v || \"pallet is required\"},\n {field: \"pallet\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetPalletsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public palletIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.palletIds = jsonSerializedObject.palletIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.palletIds = this.palletIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetPalletsResponse extends ModelObject {\n\n public pallets: Pallet[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.pallets = jsonSerializedObject.pallets.map((v: any) => new Pallet(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.pallets = this.pallets.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"pallets\", rule: (v: any) => !!v || \"pallets is required\"},\n {field: \"pallets\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Pallet[]).reduce((acc: Array, curr: Pallet) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetPalletsByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: PalletFilter = new PalletFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new PalletFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetPalletsByFilterResponse extends ModelObject {\n\n public results: FilteredPalletsResult = new FilteredPalletsResult();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredPalletsResult(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SavePalletRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public pallet: Pallet = new Pallet();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.pallet = new Pallet(jsonSerializedObject.pallet);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.pallet = this.pallet.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"pallet\", rule: (v: any) => !!v || \"pallet is required\"},\n {field: \"pallet\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SavePalletsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public pallets: readonly Pallet[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.pallets = jsonSerializedObject.pallets.map((v: any) => new Pallet(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.pallets = this.pallets.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"pallets\", rule: (v: any) => !!v || \"pallets is required\"},\n {field: \"pallets\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Pallet[]).reduce((acc: Array, curr: Pallet) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class MarkPalletDeliveredRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public palletId: Guid = Guid.createEmpty();\n public orderId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.palletId = Guid.fromString(jsonSerializedObject.palletId);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.palletId = this.palletId.toString();\n toRet.orderId = this.orderId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"palletId\", rule: (v: any) => !v.isEmpty() || \".PalletId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n ];\n}\n\n\nexport class MarkPalletDisassembledRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public palletId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.palletId = Guid.fromString(jsonSerializedObject.palletId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.palletId = this.palletId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"palletId\", rule: (v: any) => !v.isEmpty() || \".PalletId cannot be empty\"},\n ];\n}\n\n\nexport class GeneratePalletLabelRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public palletId: Guid = Guid.createEmpty();\n public documentFormat: EnumDocumentFileType = EnumDocumentFileType.pdf;\n private _documentTemplateId: Guid | null = null;\n public get documentTemplateId(): Guid | null { return this._documentTemplateId }\n public set documentTemplateId(value: Guid | null) {\n this._documentTemplateId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.palletId = Guid.fromString(jsonSerializedObject.palletId);\n this.documentFormat = EnumDocumentFileType.getByValue(jsonSerializedObject.documentFormat, this.documentFormat);\n this.documentTemplateId = jsonSerializedObject.documentTemplateId == null ? null : Guid.fromString(jsonSerializedObject.documentTemplateId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.palletId = this.palletId.toString();\n toRet.documentFormat = this.documentFormat.value;\n toRet.documentTemplateId = this.documentTemplateId == null ? null : this.documentTemplateId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"palletId\", rule: (v: any) => !v.isEmpty() || \".PalletId cannot be empty\"},\n {field: \"documentTemplateId\", rule: (v: any) => v == null || !v.isEmpty() || \".DocumentTemplateId cannot be empty\"},\n ];\n}\n\n\nexport class GeneratePalletLabelResponse extends ModelObject {\n\n public documentBytes: Uint8Array = new Uint8Array();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.documentBytes = converters.base64ToUint8Array(jsonSerializedObject.documentBytes);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.documentBytes = converters.uint8ArrayToBase64(this.documentBytes);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GeneratePalletLabelsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public palletIds: readonly Guid[] = [];\n public documentFormat: EnumDocumentFileType = EnumDocumentFileType.pdf;\n private _documentTemplateId: Guid | null = null;\n public get documentTemplateId(): Guid | null { return this._documentTemplateId }\n public set documentTemplateId(value: Guid | null) {\n this._documentTemplateId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.palletIds = jsonSerializedObject.palletIds.map((v: any) => Guid.fromString(v));\n this.documentFormat = EnumDocumentFileType.getByValue(jsonSerializedObject.documentFormat, this.documentFormat);\n this.documentTemplateId = jsonSerializedObject.documentTemplateId == null ? null : Guid.fromString(jsonSerializedObject.documentTemplateId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.palletIds = this.palletIds.map(v => v.toString());\n toRet.documentFormat = this.documentFormat.value;\n toRet.documentTemplateId = this.documentTemplateId == null ? null : this.documentTemplateId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"documentTemplateId\", rule: (v: any) => v == null || !v.isEmpty() || \".DocumentTemplateId cannot be empty\"},\n ];\n}\n\n\nexport class GeneratePalletLabelsResponse extends ModelObject {\n\n public documentBytes: Uint8Array = new Uint8Array();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.documentBytes = converters.base64ToUint8Array(jsonSerializedObject.documentBytes);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.documentBytes = converters.uint8ArrayToBase64(this.documentBytes);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GeneratePalletManifestRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public palletId: Guid = Guid.createEmpty();\n public documentFormat: EnumDocumentFileType = EnumDocumentFileType.pdf;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.palletId = Guid.fromString(jsonSerializedObject.palletId);\n this.documentFormat = EnumDocumentFileType.getByValue(jsonSerializedObject.documentFormat, this.documentFormat);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.palletId = this.palletId.toString();\n toRet.documentFormat = this.documentFormat.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"palletId\", rule: (v: any) => !v.isEmpty() || \".PalletId cannot be empty\"},\n ];\n}\n\n\nexport class GeneratePalletManifestResponse extends ModelObject {\n\n public documentBytes: Uint8Array = new Uint8Array();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.documentBytes = converters.base64ToUint8Array(jsonSerializedObject.documentBytes);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.documentBytes = converters.uint8ArrayToBase64(this.documentBytes);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class MarkPalletsDeliveredByPalletBarcodesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public palletBarcodes: readonly string[] = [];\n public orderId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.palletBarcodes = jsonSerializedObject.palletBarcodes.map((v: any) => v);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.palletBarcodes = this.palletBarcodes.map(v => v);\n toRet.orderId = this.orderId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n ];\n}\n\n\nexport class UnmarkPalletsDeliveredRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public palletBarcodes: readonly string[] = [];\n public orderId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.palletBarcodes = jsonSerializedObject.palletBarcodes.map((v: any) => v);\n this.orderId = Guid.fromString(jsonSerializedObject.orderId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.palletBarcodes = this.palletBarcodes.map(v => v);\n toRet.orderId = this.orderId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"orderId\", rule: (v: any) => !v.isEmpty() || \".OrderId cannot be empty\"},\n ];\n}\n\n\nexport class PalletService extends ServiceBase {\n\n public async getPallet(tenantId: Guid, palletId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPalletRequest();\n req.tenantId = tenantId;\n req.palletId = palletId;\n const extractor = (response:any) => new GetPalletResponse(response).pallet;\n return this.makeJsonRequest(\"pallet/v1/getPallet\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getPallets(tenantId: Guid, palletIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPalletsRequest();\n req.tenantId = tenantId;\n req.palletIds = palletIds;\n const extractor = (response:any) => new GetPalletsResponse(response).pallets;\n return this.makeJsonRequest(\"pallet/v1/getPallets\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getPalletsByFilter(tenantId: Guid, filter: PalletFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPalletsByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetPalletsByFilterResponse(response).results;\n return this.makeJsonRequest(\"pallet/v1/getPalletsByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async savePallet(tenantId: Guid, pallet: Pallet, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SavePalletRequest();\n req.tenantId = tenantId;\n req.pallet = pallet;\n const extractor = null;\n return this.makeJsonRequest(\"pallet/v1/savePallet\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async savePallets(tenantId: Guid, pallets: readonly Pallet[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SavePalletsRequest();\n req.tenantId = tenantId;\n req.pallets = pallets;\n const extractor = null;\n return this.makeJsonRequest(\"pallet/v1/savePallets\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async markPalletDelivered(tenantId: Guid, palletId: Guid, orderId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new MarkPalletDeliveredRequest();\n req.tenantId = tenantId;\n req.palletId = palletId;\n req.orderId = orderId;\n const extractor = null;\n return this.makeJsonRequest(\"pallet/v1/markPalletDelivered\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async markPalletDisassembled(tenantId: Guid, palletId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new MarkPalletDisassembledRequest();\n req.tenantId = tenantId;\n req.palletId = palletId;\n const extractor = null;\n return this.makeJsonRequest(\"pallet/v1/markPalletDisassembled\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async generatePalletLabel(tenantId: Guid, palletId: Guid, documentFormat: EnumDocumentFileType, documentTemplateId: Guid | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GeneratePalletLabelRequest();\n req.tenantId = tenantId;\n req.palletId = palletId;\n req.documentFormat = documentFormat;\n req.documentTemplateId = documentTemplateId;\n const extractor = (response:any) => new GeneratePalletLabelResponse(response).documentBytes;\n return this.makeJsonRequest(\"pallet/v1/generatePalletLabel\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async generatePalletLabels(tenantId: Guid, palletIds: readonly Guid[], documentFormat: EnumDocumentFileType, documentTemplateId: Guid | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GeneratePalletLabelsRequest();\n req.tenantId = tenantId;\n req.palletIds = palletIds;\n req.documentFormat = documentFormat;\n req.documentTemplateId = documentTemplateId;\n const extractor = (response:any) => new GeneratePalletLabelsResponse(response).documentBytes;\n return this.makeJsonRequest(\"pallet/v1/generatePalletLabels\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async generatePalletManifest(tenantId: Guid, palletId: Guid, documentFormat: EnumDocumentFileType, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GeneratePalletManifestRequest();\n req.tenantId = tenantId;\n req.palletId = palletId;\n req.documentFormat = documentFormat;\n const extractor = (response:any) => new GeneratePalletManifestResponse(response).documentBytes;\n return this.makeJsonRequest(\"pallet/v1/generatePalletManifest\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async markPalletsDeliveredByPalletBarcodes(tenantId: Guid, palletBarcodes: readonly string[], orderId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new MarkPalletsDeliveredByPalletBarcodesRequest();\n req.tenantId = tenantId;\n req.palletBarcodes = palletBarcodes;\n req.orderId = orderId;\n const extractor = null;\n return this.makeJsonRequest(\"pallet/v1/markPalletsDeliveredByPalletBarcodes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async unmarkPalletsDelivered(tenantId: Guid, palletBarcodes: readonly string[], orderId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UnmarkPalletsDeliveredRequest();\n req.tenantId = tenantId;\n req.palletBarcodes = palletBarcodes;\n req.orderId = orderId;\n const extractor = null;\n return this.makeJsonRequest(\"pallet/v1/unmarkPalletsDelivered\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const palletService = new PalletService();","import { isNotNullOrUndefined } from \"@/app/apiutils\";\nimport Guid from \"@/app/types/common/guid\";\n\nexport const getOneOrManyQueryValuesAsArray = (\n queryValue: string | (string | null)[]\n): string[] => {\n return (queryValue instanceof Array ? queryValue : [queryValue]).filter(\n isNotNullOrUndefined\n );\n};\n\n// Enums use static function declarations which TS can't add to interfaces, so accept any for now\nexport const parseEnumArrayQuery = (\n queryValue: string | (string | null)[],\n enumType: any\n): any[] => {\n return getOneOrManyQueryValuesAsArray(queryValue)\n .map((enumKey) =>\n !Number.isNaN(enumKey) ? enumType.getByKey(Number(enumKey)) : null\n )\n .filter(isNotNullOrUndefined);\n};\n\nexport const parseGuidArrayQuery = (\n queryValue: string | (string | null)[]\n): Guid[] => {\n return getOneOrManyQueryValuesAsArray(queryValue)\n .map((guidString) => Guid.tryParse(guidString))\n .filter(isNotNullOrUndefined);\n};\n","import { EnumDistributionType } from \"@/app/services/generated/enums/enumDistributionType.generated\";\nimport { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport Guid from \"@/app/types/common/guid\";\nimport {\n getOneOrManyQueryValuesAsArray,\n parseEnumArrayQuery,\n parseGuidArrayQuery,\n} from \"@/app/ui/navigation/queryHelpers\";\nimport { MenuItem } from \"@/app/ui/navigation/types\";\nimport { EnumDistributionItemType } from \"@/components/pages/distribution/types\";\nimport type { Location } from \"vue-router\";\n\nexport const distributionMenu = {\n root: \"navigation_distribution_group\",\n multiPlanning: {\n root: \"multi_planning\",\n vehiclePlan: \"vehicle_plan\",\n allStopsRoute: () => ({\n name: distributionMenu.multiPlanning.root,\n }),\n vehiclePlanRoute: (vehicleId: Guid) => ({\n name: distributionMenu.multiPlanning.vehiclePlan,\n params: {\n vehicleId: vehicleId.toString(),\n },\n }),\n },\n distributionLists: {\n view: \"distribution_lists\",\n\n pickingByVehicle: \"distribution_picking_list_by_vehicle\",\n pickingListByVehicleRoute: (\n despatchDateString: string | null,\n vehicleIds?: Guid[],\n distributionTypes?: EnumDistributionType[]\n ): Location => ({\n name: distributionMenu.distributionLists.pickingByVehicle,\n query: {\n vehicleIds: vehicleIds?.map((id) => id.toString()),\n distributionTypes: distributionTypes?.map((type) =>\n type.key.toString()\n ),\n },\n params: { date: despatchDateString ?? \"\" },\n }),\n\n picking: \"distribution_picking_list\",\n pickingListRoute: (despatchDateString: string | null) => ({\n name: distributionMenu.distributionLists.picking,\n params: { date: despatchDateString ?? \"\" },\n }),\n\n loading: \"distribution_loading_list\",\n loadingListRoute: (despatchDateString: string | null) => ({\n name: distributionMenu.distributionLists.loading,\n params: { date: despatchDateString ?? \"\" },\n }),\n\n packing: \"distribution_pick_up_list\",\n packingListRoute: (despatchDateString: string | null) => ({\n name: distributionMenu.distributionLists.packing,\n params: { date: despatchDateString ?? \"\" },\n }),\n },\n courierCollection: \"courier_collection\",\n viewCourierCollection: (): Location => ({\n name: distributionMenu.courierCollection,\n }),\n processing: \"distribution_processing\",\n viewProcessing: (): Location => ({\n name: distributionMenu.processing,\n }),\n journeyLog: \"distribution_journey_log\",\n journeyDetailsLog: {\n view: \"distribution_journey_details_log\",\n viewLocation: (journeyId: Guid): Location => ({\n name: distributionMenu.journeyDetailsLog.view,\n params: {\n journeyId: journeyId.toString(),\n },\n }),\n },\n visitLog: \"distribution_visit_log\",\n activeJourneys: \"distribution_active_journeys\",\n pallets: {\n list: \"pallet_list\",\n listLocation: (): Location => ({\n name: distributionMenu.pallets.list,\n }),\n view: \"view_pallet\",\n viewLocation: (id: Guid): Location => ({\n name: distributionMenu.pallets.view,\n params: {\n id: id.toString(),\n },\n }),\n edit: \"pallet_edit\",\n editLocation: (id: Guid): Location => ({\n name: distributionMenu.pallets.edit,\n params: {\n id: id.toString(),\n },\n }),\n create: \"pallet_create\",\n createLocation: (orderId?: Guid): Location => ({\n name: distributionMenu.pallets.create,\n params: {\n orderId: orderId?.toString() ?? \"\",\n },\n }),\n },\n settings: {\n root: \"navigation_distribution_settings_group\",\n fleetManagement: {\n list: \"fleet_management\",\n listLocation: (): Location => ({\n name: distributionMenu.settings.fleetManagement.list,\n }),\n edit: \"fleet_management_edit\",\n editLocation: (id: Guid, isEditing: boolean): Location => ({\n name: distributionMenu.settings.fleetManagement.edit,\n params: {\n id: id.toString(),\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n createLocation: (): Location => ({\n name: distributionMenu.settings.fleetManagement.edit,\n }),\n },\n schedule: \"distribution_schedule\",\n create: \"vehicle_create\",\n edit: \"vehicle_edit\",\n view: \"vehicle_view\",\n deliveryServices: {\n list: \"distribution_delivery_services\",\n listLocation: (): Location => ({\n name: distributionMenu.settings.deliveryServices.list,\n }),\n edit: \"distribution_delivery_services_edit\",\n editLocation: (id: Guid, isEditing: boolean): Location => ({\n name: distributionMenu.settings.deliveryServices.edit,\n params: {\n id: id.toString(),\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n createLocation: (): Location => ({\n name: distributionMenu.settings.deliveryServices.edit,\n }),\n },\n },\n orderRecord: \"distribution_order_record\",\n viewOrderRecord: (id: Guid): Location => ({\n name: distributionMenu.orderRecord,\n params: {\n id: id.toString(),\n distributionItemType: EnumDistributionItemType.order.value,\n },\n }),\n visitRecord: \"distribution_visit_record\",\n viewVisitRecord: (id: Guid): Location => ({\n name: distributionMenu.visitRecord,\n params: {\n id: id.toString(),\n distributionItemType: EnumDistributionItemType.visit.value,\n },\n }),\n};\n\nexport const buildDistributionMenuItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n name: distributionMenu.root,\n icon: \"local_shipping\",\n requiredUserPermissions: [EnumUserPermission.menuDistributionView],\n subMenus: [\n MenuItem.fromOpts({\n name: distributionMenu.multiPlanning.root,\n url: \"/distribution/multi-journey-planning/\",\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/multijourney/DistributionPlanning.vue\"\n ),\n childRoutes: [\n {\n name: distributionMenu.multiPlanning.root,\n path: \"\",\n component: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/multijourney/components/AllStops.vue\"\n ),\n },\n {\n name: distributionMenu.multiPlanning.vehiclePlan,\n path: \"vehicleplan/:vehicleId\",\n component: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/multijourney/components/VehiclePlan.vue\"\n ),\n props: (route) => ({\n vehicleId: Guid.tryParse(route.params.vehicleId) || undefined,\n }),\n },\n ],\n requiredUserPermissions: [\n EnumUserPermission.distributionManagementView,\n ],\n }),\n MenuItem.fromOpts({\n name: distributionMenu.distributionLists.view,\n url: \"/distribution/lists\",\n breadcrumbParentName: distributionMenu.multiPlanning.root,\n visible: false,\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/DistributionPickingLists.vue\"\n ),\n componentProps: (route) => ({\n date: route.params.date,\n }),\n childRoutes: [\n {\n name: distributionMenu.distributionLists.pickingByVehicle,\n path: \"picking/vehicle/:date?\",\n component: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/subcomponents/PickingListByVehicleTab.vue\"\n ),\n props: (route) => ({\n vehicleIds: route.query.vehicleIds\n ? parseGuidArrayQuery(route.query.vehicleIds)\n : [],\n distributionTypes: route.query.distributionTypes\n ? parseEnumArrayQuery(\n route.query.distributionTypes,\n EnumDistributionType\n )\n : [],\n }),\n },\n {\n name: distributionMenu.distributionLists.picking,\n path: \"picking/:date?\",\n component: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/subcomponents/PickingListByStockLocationTab.vue\"\n ),\n props: (route) => ({\n vehicleIds: route.query.vehicleIds\n ? parseGuidArrayQuery(route.query.vehicleIds)\n : [],\n distributionTypes: route.query.distributionTypes\n ? parseEnumArrayQuery(\n route.query.distributionTypes,\n EnumDistributionType\n )\n : [],\n }),\n },\n {\n name: distributionMenu.distributionLists.loading,\n path: \"loading/:date?\",\n component: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/subcomponents/LoadingListTab.vue\"\n ),\n props: (route) => ({\n vehicleIds: route.query.vehicleIds\n ? parseGuidArrayQuery(route.query.vehicleIds)\n : [],\n }),\n },\n {\n name: distributionMenu.distributionLists.packing,\n path: \"packing/:date?\",\n component: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/subcomponents/PackingListTab.vue\"\n ),\n props: (route) => ({\n filterTypes: route.query.filterTypes\n ? getOneOrManyQueryValuesAsArray(route.query.filterTypes)\n : [],\n }),\n },\n ],\n requiredUserPermissions: [\n EnumUserPermission.distributionManagementView,\n ],\n }),\n MenuItem.fromOpts({\n name: distributionMenu.courierCollection,\n url: \"/distribution/courier_collection\",\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/ListCourierCollection.vue\"\n ),\n requiredUserPermissions: [\n EnumUserPermission.distributionManagementView,\n ],\n }),\n MenuItem.fromOpts({\n name: distributionMenu.processing,\n url: \"/distribution/processing\",\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/DistributionProcessing.vue\"\n ),\n requiredUserPermissions: [\n EnumUserPermission.distributionProcessingView,\n ],\n }),\n MenuItem.fromOpts({\n name: distributionMenu.journeyLog,\n url: \"/distribution/journeylog\",\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/JourneyLog.vue\"\n ),\n requiredUserPermissions: [\n EnumUserPermission.distributionManagementView,\n ],\n }),\n MenuItem.fromOpts({\n name: distributionMenu.journeyDetailsLog.view,\n url: \"/distribution/journeydetailslog/:journeyId\",\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/JourneyDetailsLog.vue\"\n ),\n requiredUserPermissions: [\n EnumUserPermission.distributionManagementView,\n ],\n componentProps: (route) => ({\n journeyId: Guid.tryParse(route.params.journeyId) ?? undefined,\n }),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: distributionMenu.visitLog,\n url: \"/distribution/visitLog\",\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/VisitLog.vue\"\n ),\n requiredUserPermissions: [\n EnumUserPermission.distributionManagementView,\n ],\n }),\n MenuItem.fromOpts({\n name: distributionMenu.activeJourneys,\n url: \"/distribution/activejourneys\",\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/ActiveJourneys.vue\"\n ),\n requiredUserPermissions: [\n EnumUserPermission.distributionManagementView,\n ],\n }),\n MenuItem.fromOpts({\n name: distributionMenu.pallets.list,\n url: \"/distribution/pallets\",\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/pallets/ListPallets.vue\"\n ),\n requiredUserPermissions: [\n EnumUserPermission.distributionManagementView,\n ],\n }),\n MenuItem.fromOpts({\n name: distributionMenu.pallets.edit,\n url: \"/distribution/pallets/edit-pallet/:id\",\n breadcrumbParentName: distributionMenu.pallets.list,\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/pages/distribution/pallets/EditPalletPage.vue\"\n ),\n visible: false,\n componentProps: (route) => {\n return {\n id: route.params.id,\n };\n },\n requiredUserPermissions: [\n EnumUserPermission.distributionManagementView,\n ],\n }),\n MenuItem.fromOpts({\n name: distributionMenu.pallets.view,\n url: \"/distribution/pallets/view-pallet/:id\",\n breadcrumbParentName: distributionMenu.pallets.list,\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/pages/distribution/pallets/ViewPalletPage.vue\"\n ),\n visible: false,\n componentProps: (route) => {\n return {\n id: route.params.id,\n };\n },\n requiredUserPermissions: [\n EnumUserPermission.distributionManagementView,\n ],\n }),\n MenuItem.fromOpts({\n name: distributionMenu.pallets.create,\n url: \"/distribution/pallets/create\",\n breadcrumbParentName: distributionMenu.pallets.list,\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/pages/distribution/pallets/CreatePalletPage.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n orderId: Guid.tryParse(route.params.orderId),\n }),\n requiredUserPermissions: [\n EnumUserPermission.distributionManagementView,\n ],\n }),\n MenuItem.forBranch({\n name: distributionMenu.settings.root,\n subMenus: [\n MenuItem.fromOpts({\n name: distributionMenu.settings.fleetManagement.list,\n url: \"/distribution/fleetmanagement\",\n breadcrumbParentName: distributionMenu.settings.root,\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/ListVehicles.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: distributionMenu.settings.fleetManagement.edit,\n url: \"/distribution/fleetmanagement/:id?/:mode?\",\n breadcrumbParentName:\n distributionMenu.settings.fleetManagement.list,\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/EditVehicle.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: distributionMenu.settings.schedule,\n url: \"/distribution/schedule\",\n breadcrumbParentName: distributionMenu.settings.root,\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/DistributionSchedule.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: distributionMenu.settings.deliveryServices.list,\n url: \"/distribution/deliveryservices\",\n breadcrumbParentName: distributionMenu.settings.root,\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/ListDeliveryServices.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: distributionMenu.settings.deliveryServices.edit,\n url: \"/distribution/deliveryservice/:id?/:mode?\",\n breadcrumbParentName:\n distributionMenu.settings.deliveryServices.list,\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/EditDeliveryService.vue\"\n ),\n visible: false,\n }),\n ],\n requiredUserPermissions: [\n EnumUserPermission.distributionManagementView,\n ],\n }),\n\n MenuItem.fromOpts({\n name: distributionMenu.orderRecord,\n url: \"/distribution/orderrecord/:id\",\n breadcrumbParentName: distributionMenu.processing,\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/DistributionRecord.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n distributionItemType: EnumDistributionItemType.order,\n id: Guid.tryParse(route.params.id) ?? undefined,\n }),\n requiredUserPermissions: [\n EnumUserPermission.distributionProcessingView,\n ],\n }),\n MenuItem.fromOpts({\n name: distributionMenu.visitRecord,\n url: \"/distribution/visitrecord/:id\",\n breadcrumbParentName: distributionMenu.processing,\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/distribution/DistributionRecord.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n distributionItemType: EnumDistributionItemType.visit,\n id: Guid.tryParse(route.params.id) ?? undefined,\n }),\n requiredUserPermissions: [\n EnumUserPermission.distributionProcessingView,\n ],\n }),\n ],\n }),\n];\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumAlcoholType } from \"./enums/enumAlcoholType.generated\";\nimport { EnumDocumentFileType } from \"./enums/enumDocumentFileType.generated\";\nimport { EnumGermanBeerDutyMovementType } from \"./enums/enumGermanBeerDutyMovementType.generated\";\nimport { EnumGermanBeerDutyProductType } from \"./enums/enumGermanBeerDutyProductType.generated\";\nimport { EnumSpiritDutyExemptionReason } from \"./enums/enumSpiritDutyExemptionReason.generated\";\nimport { EnumStockTransferStatus } from \"./enums/enumStockTransferStatus.generated\";\n\n// Model Objects\n\nexport class TransferHeaderReadOnly extends ModelObject {\n\n /**\n * Transfer Number\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public number: string = \"\";\n public status: EnumStockTransferStatus = EnumStockTransferStatus.none;\n /**\n * User Id of the creating user.\n */\n public createdByUserId: Guid = Guid.createEmpty();\n /**\n * Timestamp at which the stock transfer was created. Captured by system not user editable.\n */\n public createdAt: Instant = Instant.ofEpochMilli(0);\n private _cancelledByUserId: Guid | null = null;\n /**\n * User who cancelled the order. Captured by system not user editable. (Null if not cancelled).\n */\n public get cancelledByUserId(): Guid | null { return this._cancelledByUserId }\n public set cancelledByUserId(value: Guid | null) {\n this._cancelledByUserId = value === undefined ? null : value;\n }\n private _cancelledAt: Instant | null = null;\n /**\n * Timestamp at which the stock transfer was last cancelled. Captured by system not user editable. (Null if not completed).\n */\n public get cancelledAt(): Instant | null { return this._cancelledAt }\n public set cancelledAt(value: Instant | null) {\n this._cancelledAt = value === undefined ? null : value;\n }\n private _completedByUserId: Guid | null = null;\n /**\n * User who completed the order. Captured by system not user editable. (Null if not completed).\n */\n public get completedByUserId(): Guid | null { return this._completedByUserId }\n public set completedByUserId(value: Guid | null) {\n this._completedByUserId = value === undefined ? null : value;\n }\n private _completedAt: Instant | null = null;\n /**\n * Timestamp at which the stock transfer was last completed. Captured by system not user editable. (Null if not completed).\n */\n public get completedAt(): Instant | null { return this._completedAt }\n public set completedAt(value: Instant | null) {\n this._completedAt = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.number = jsonSerializedObject.number;\n this.status = EnumStockTransferStatus.getByValue(jsonSerializedObject.status, this.status);\n this.createdByUserId = Guid.fromString(jsonSerializedObject.createdByUserId);\n this.createdAt = Instant.parse(jsonSerializedObject.createdAt);\n this.cancelledByUserId = jsonSerializedObject.cancelledByUserId == null ? null : Guid.fromString(jsonSerializedObject.cancelledByUserId);\n this.cancelledAt = jsonSerializedObject.cancelledAt == null ? null : Instant.parse(jsonSerializedObject.cancelledAt);\n this.completedByUserId = jsonSerializedObject.completedByUserId == null ? null : Guid.fromString(jsonSerializedObject.completedByUserId);\n this.completedAt = jsonSerializedObject.completedAt == null ? null : Instant.parse(jsonSerializedObject.completedAt);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.number = this.number;\n toRet.status = this.status.value;\n toRet.createdByUserId = this.createdByUserId.toString();\n toRet.createdAt = this.createdAt.toString();\n toRet.cancelledByUserId = this.cancelledByUserId == null ? null : this.cancelledByUserId.toString();\n toRet.cancelledAt = this.cancelledAt == null ? null : this.cancelledAt.toString();\n toRet.completedByUserId = this.completedByUserId == null ? null : this.completedByUserId.toString();\n toRet.completedAt = this.completedAt == null ? null : this.completedAt.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"createdByUserId\", rule: (v: any) => !v.isEmpty() || \"TransferHeaderReadOnly.CreatedByUserId cannot be empty\"},\n {field: \"cancelledByUserId\", rule: (v: any) => v == null || !v.isEmpty() || \"TransferHeaderReadOnly.CancelledByUserId cannot be empty\"},\n {field: \"completedByUserId\", rule: (v: any) => v == null || !v.isEmpty() || \"TransferHeaderReadOnly.CompletedByUserId cannot be empty\"},\n ];\n}\n\n\nexport class StockTransferHeader extends ModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Delivery Date\n */\n public deliveryDate: LocalDate = LocalDate.ofEpochDay(0);\n /**\n * Despatch Date\n */\n public despatchDate: LocalDate = LocalDate.ofEpochDay(0);\n /**\n * From Stock Location\n */\n public fromStockLocationId: Guid = Guid.createEmpty();\n /**\n * Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n /**\n * To Stock Location\n */\n public toStockLocationId: Guid = Guid.createEmpty();\n public readOnly: TransferHeaderReadOnly = new TransferHeaderReadOnly();\n /**\n * German Duty Implication for Beer leaving the FROM location. Only limited valid options for Bonded/NonBonded combinations of From/To. Bonded->Bonded = NonTaxableToGermany or NonTaxableToEU. Bonded->NonBonded = Taxable.NonBonded->Bonded = None.NonBonded->NonBonded = None.\n */\n public germanBeerDutyMovementTypeAtFrom: EnumGermanBeerDutyMovementType = EnumGermanBeerDutyMovementType.none;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.deliveryDate = LocalDate.parse(jsonSerializedObject.deliveryDate);\n this.despatchDate = LocalDate.parse(jsonSerializedObject.despatchDate);\n this.fromStockLocationId = Guid.fromString(jsonSerializedObject.fromStockLocationId);\n this.notes = jsonSerializedObject.notes;\n this.toStockLocationId = Guid.fromString(jsonSerializedObject.toStockLocationId);\n this.readOnly = new TransferHeaderReadOnly(jsonSerializedObject.readOnly);\n this.germanBeerDutyMovementTypeAtFrom = EnumGermanBeerDutyMovementType.getByValue(jsonSerializedObject.germanBeerDutyMovementTypeAtFrom, this.germanBeerDutyMovementTypeAtFrom);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.deliveryDate = this.deliveryDate.toString();\n toRet.despatchDate = this.despatchDate.toString();\n toRet.fromStockLocationId = this.fromStockLocationId.toString();\n toRet.notes = this.notes;\n toRet.toStockLocationId = this.toStockLocationId.toString();\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.germanBeerDutyMovementTypeAtFrom = this.germanBeerDutyMovementTypeAtFrom.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"StockTransferHeader.Id cannot be empty\"},\n {field: \"fromStockLocationId\", rule: (v: any) => !v.isEmpty() || \"StockTransferHeader.FromStockLocationId cannot be empty\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"toStockLocationId\", rule: (v: any) => !v.isEmpty() || \"StockTransferHeader.ToStockLocationId cannot be empty\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class StockTransferLineDetailReadOnly extends ModelObject {\n\n /**\n * Stock Item ABV\n * Not Negative\n */\n public stockItemAbv: number = 0;\n /**\n * Alcohol Type\n */\n public alcoholType: EnumAlcoholType = EnumAlcoholType.none;\n /**\n * Stock Dutiable Litres\n * Not Negative\n */\n public unitDutiableLitres: number = 0;\n private _manufacturerId: Guid | null = null;\n /**\n * Manufacturer of the product - Required for lines with Alcohol.\n */\n public get manufacturerId(): Guid | null { return this._manufacturerId }\n public set manufacturerId(value: Guid | null) {\n this._manufacturerId = value === undefined ? null : value;\n }\n /**\n * Stock Transfer Id\n */\n public stockTransferId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockItemAbv = jsonSerializedObject.stockItemAbv;\n this.alcoholType = EnumAlcoholType.getByValue(jsonSerializedObject.alcoholType, this.alcoholType);\n this.unitDutiableLitres = jsonSerializedObject.unitDutiableLitres;\n this.manufacturerId = jsonSerializedObject.manufacturerId == null ? null : Guid.fromString(jsonSerializedObject.manufacturerId);\n this.stockTransferId = Guid.fromString(jsonSerializedObject.stockTransferId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockItemAbv = this.stockItemAbv;\n toRet.alcoholType = this.alcoholType.value;\n toRet.unitDutiableLitres = this.unitDutiableLitres;\n toRet.manufacturerId = this.manufacturerId == null ? null : this.manufacturerId.toString();\n toRet.stockTransferId = this.stockTransferId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"manufacturerId\", rule: (v: any) => v == null || !v.isEmpty() || \"StockTransferLineDetailReadOnly.ManufacturerId cannot be empty\"},\n {field: \"stockTransferId\", rule: (v: any) => !v.isEmpty() || \"StockTransferLineDetailReadOnly.StockTransferId cannot be empty\"},\n ];\n}\n\n\nexport class StockTransferLineDetail extends ModelObject {\n\n private _dateOfBatch: LocalDate | null = null;\n public get dateOfBatch(): LocalDate | null { return this._dateOfBatch }\n public set dateOfBatch(value: LocalDate | null) {\n this._dateOfBatch = value === undefined ? null : value;\n }\n public stockItemId: Guid = Guid.createEmpty();\n public urn: string = \"\";\n /**\n * Quantity\n */\n public quantity: number = 0;\n /**\n * Unit of Measure\n */\n public unitOfMeasureId: Guid = Guid.createEmpty();\n public readOnly: StockTransferLineDetailReadOnly = new StockTransferLineDetailReadOnly();\n private _plato: number | null = null;\n /**\n * Plato Value\n */\n public get plato(): number | null { return this._plato }\n public set plato(value: number | null) {\n this._plato = value === undefined ? null : value;\n }\n public germanBeerDutyProductType: EnumGermanBeerDutyProductType = EnumGermanBeerDutyProductType.none;\n private _germanBeerMixedProductPercentageA: number | null = null;\n public get germanBeerMixedProductPercentageA(): number | null { return this._germanBeerMixedProductPercentageA }\n public set germanBeerMixedProductPercentageA(value: number | null) {\n this._germanBeerMixedProductPercentageA = value === undefined ? null : value;\n }\n /**\n * Set true if this item is brewed by members of the public for their personal use by borrowing the Brewery's equipment. This is a service offered by breweries in some countries, such as Australia, and can affect duty.\n */\n public isBrewedForPersonalUse: boolean = false;\n /**\n * Set true if this item is designed to be connected to a pump or pressurised gas system, such as those used in pubs. Some duty systems have different duty rates for beer packaged in these manners for selling to pubs.\n */\n public isDesignedForPump: boolean = false;\n private _finalUnitLitres: number | null = null;\n /**\n * Litres held by the final consumable packaged unit, if relevant. For example, a case of 12 x 500ml bottles would have a final unit litres of 0.5. Some duty systems have different rates depending upon this value.\n * Greater Than : 0\n */\n public get finalUnitLitres(): number | null { return this._finalUnitLitres }\n public set finalUnitLitres(value: number | null) {\n this._finalUnitLitres = value === undefined ? null : value;\n }\n public spiritDutyExemptionReason: EnumSpiritDutyExemptionReason = EnumSpiritDutyExemptionReason.none;\n private _dateOfProductionDutyRate: LocalDate | null = null;\n /**\n * An optional date identifying the duty rate in force at the time the item was produced. Used for UK alcohol duty, where products qualifying for SPR are charged at the rate in force at date of production, not date of crossing duty boundary. To make management easier we only track the date to granularity of rate changes, So eg a value of 2023-08-01 would represent the period from 2023-08-01 to 2024-01-31 because rates did not change in this period.\n */\n public get dateOfProductionDutyRate(): LocalDate | null { return this._dateOfProductionDutyRate }\n public set dateOfProductionDutyRate(value: LocalDate | null) {\n this._dateOfProductionDutyRate = value === undefined ? null : value;\n }\n public id: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.dateOfBatch = jsonSerializedObject.dateOfBatch == null ? null : LocalDate.parse(jsonSerializedObject.dateOfBatch);\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.urn = jsonSerializedObject.urn;\n this.quantity = jsonSerializedObject.quantity;\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n this.readOnly = new StockTransferLineDetailReadOnly(jsonSerializedObject.readOnly);\n this.plato = jsonSerializedObject.plato == null ? null : jsonSerializedObject.plato;\n this.germanBeerDutyProductType = EnumGermanBeerDutyProductType.getByValue(jsonSerializedObject.germanBeerDutyProductType, this.germanBeerDutyProductType);\n this.germanBeerMixedProductPercentageA = jsonSerializedObject.germanBeerMixedProductPercentageA == null ? null : jsonSerializedObject.germanBeerMixedProductPercentageA;\n this.isBrewedForPersonalUse = jsonSerializedObject.isBrewedForPersonalUse;\n this.isDesignedForPump = jsonSerializedObject.isDesignedForPump;\n this.finalUnitLitres = jsonSerializedObject.finalUnitLitres == null ? null : jsonSerializedObject.finalUnitLitres;\n this.spiritDutyExemptionReason = EnumSpiritDutyExemptionReason.getByValue(jsonSerializedObject.spiritDutyExemptionReason, this.spiritDutyExemptionReason);\n this.dateOfProductionDutyRate = jsonSerializedObject.dateOfProductionDutyRate == null ? null : LocalDate.parse(jsonSerializedObject.dateOfProductionDutyRate);\n this.id = Guid.fromString(jsonSerializedObject.id);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.dateOfBatch = this.dateOfBatch == null ? null : this.dateOfBatch.toString();\n toRet.stockItemId = this.stockItemId.toString();\n toRet.urn = this.urn;\n toRet.quantity = this.quantity;\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.plato = this.plato == null ? null : this.plato;\n toRet.germanBeerDutyProductType = this.germanBeerDutyProductType.value;\n toRet.germanBeerMixedProductPercentageA = this.germanBeerMixedProductPercentageA == null ? null : this.germanBeerMixedProductPercentageA;\n toRet.isBrewedForPersonalUse = this.isBrewedForPersonalUse;\n toRet.isDesignedForPump = this.isDesignedForPump;\n toRet.finalUnitLitres = this.finalUnitLitres == null ? null : this.finalUnitLitres;\n toRet.spiritDutyExemptionReason = this.spiritDutyExemptionReason.value;\n toRet.dateOfProductionDutyRate = this.dateOfProductionDutyRate == null ? null : this.dateOfProductionDutyRate.toString();\n toRet.id = this.id.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"StockTransferLineDetail.StockItemId cannot be empty\"},\n {field: \"urn\", rule: (v: any) => v == null || v.length <= 1000 || \"Urn has too many characters (1000)\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"StockTransferLineDetail.UnitOfMeasureId cannot be empty\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"finalUnitLitres\", rule: (v: any) => v == null || v > 0 || \"FinalUnitLitres is not greater than minimum allowed value: 0\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"StockTransferLineDetail.Id cannot be empty\"},\n ];\n}\n\n\nexport class StockTransfer extends BaseModelObject {\n\n public header: StockTransferHeader = new StockTransferHeader();\n public lineDetails: StockTransferLineDetail[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.header = new StockTransferHeader(jsonSerializedObject.header);\n this.lineDetails = jsonSerializedObject.lineDetails.map((v: any) => new StockTransferLineDetail(v));\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.header = this.header.toJsonSerializedObject();\n toRet.lineDetails = this.lineDetails.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n {field: \"lineDetails\", rule: (v: any) => !!v || \"lineDetails is required\"},\n {field: \"lineDetails\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockTransferLineDetail[]).reduce((acc: Array, curr: StockTransferLineDetail) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class StockTransferFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _fromDespatchDateInclusive: LocalDate | null = null;\n /**\n * Minimum (inclusive) despatch date\n */\n public get fromDespatchDateInclusive(): LocalDate | null { return this._fromDespatchDateInclusive }\n public set fromDespatchDateInclusive(value: LocalDate | null) {\n this._fromDespatchDateInclusive = value === undefined ? null : value;\n }\n private _toDespatchDateInclusive: LocalDate | null = null;\n /**\n * Maximum (inclusive) despatch date\n */\n public get toDespatchDateInclusive(): LocalDate | null { return this._toDespatchDateInclusive }\n public set toDespatchDateInclusive(value: LocalDate | null) {\n this._toDespatchDateInclusive = value === undefined ? null : value;\n }\n private _limitStatuses: EnumStockTransferStatus[] | null = null;\n public get limitStatuses(): EnumStockTransferStatus[] | null { return this._limitStatuses }\n public set limitStatuses(value: EnumStockTransferStatus[] | null) {\n this._limitStatuses = value === undefined ? null : value;\n }\n private _stockTransferIds: Guid[] | null = null;\n public get stockTransferIds(): Guid[] | null { return this._stockTransferIds }\n public set stockTransferIds(value: Guid[] | null) {\n this._stockTransferIds = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.fromDespatchDateInclusive = jsonSerializedObject.fromDespatchDateInclusive == null ? null : LocalDate.parse(jsonSerializedObject.fromDespatchDateInclusive);\n this.toDespatchDateInclusive = jsonSerializedObject.toDespatchDateInclusive == null ? null : LocalDate.parse(jsonSerializedObject.toDespatchDateInclusive);\n this.limitStatuses = jsonSerializedObject.limitStatuses == null ? null : jsonSerializedObject.limitStatuses.map((v: any) => EnumStockTransferStatus.getByValue(v));\n this.stockTransferIds = jsonSerializedObject.stockTransferIds == null ? null : jsonSerializedObject.stockTransferIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.fromDespatchDateInclusive = this.fromDespatchDateInclusive == null ? null : this.fromDespatchDateInclusive.toString();\n toRet.toDespatchDateInclusive = this.toDespatchDateInclusive == null ? null : this.toDespatchDateInclusive.toString();\n toRet.limitStatuses = this.limitStatuses == null ? null : this.limitStatuses.map(v => v.value);\n toRet.stockTransferIds = this.stockTransferIds == null ? null : this.stockTransferIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class FilteredStockTransferHeaderResults extends ModelObject {\n\n public matchingCount: number = 0;\n public stockTransferHeaders: StockTransferHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.stockTransferHeaders = jsonSerializedObject.stockTransferHeaders.map((v: any) => new StockTransferHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.stockTransferHeaders = this.stockTransferHeaders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"stockTransferHeaders\", rule: (v: any) => !!v || \"stockTransferHeaders is required\"},\n {field: \"stockTransferHeaders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockTransferHeader[]).reduce((acc: Array, curr: StockTransferHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllStockTransferHeadersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllStockTransferHeadersResponse extends ModelObject {\n\n public stockTransferHeaders: StockTransferHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockTransferHeaders = jsonSerializedObject.stockTransferHeaders.map((v: any) => new StockTransferHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockTransferHeaders = this.stockTransferHeaders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockTransferHeaders\", rule: (v: any) => !!v || \"stockTransferHeaders is required\"},\n {field: \"stockTransferHeaders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockTransferHeader[]).reduce((acc: Array, curr: StockTransferHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetFilteredStockTransferHeadersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: StockTransferFilter = new StockTransferFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new StockTransferFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetFilteredStockTransferHeadersResponse extends ModelObject {\n\n public results: FilteredStockTransferHeaderResults = new FilteredStockTransferHeaderResults();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredStockTransferHeaderResults(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetStockTransferHeaderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockTransferId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockTransferId = Guid.fromString(jsonSerializedObject.stockTransferId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockTransferId = this.stockTransferId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockTransferId\", rule: (v: any) => !v.isEmpty() || \".StockTransferId cannot be empty\"},\n ];\n}\n\n\nexport class GetStockTransferHeaderResponse extends ModelObject {\n\n public stockTransferHeader: StockTransferHeader = new StockTransferHeader();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockTransferHeader = new StockTransferHeader(jsonSerializedObject.stockTransferHeader);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockTransferHeader = this.stockTransferHeader.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockTransferHeader\", rule: (v: any) => !!v || \"stockTransferHeader is required\"},\n {field: \"stockTransferHeader\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetStockTransferHeadersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockTransferIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockTransferIds = jsonSerializedObject.stockTransferIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockTransferIds = this.stockTransferIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetStockTransferHeadersResponse extends ModelObject {\n\n public stockTransferHeaders: StockTransferHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockTransferHeaders = jsonSerializedObject.stockTransferHeaders.map((v: any) => new StockTransferHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockTransferHeaders = this.stockTransferHeaders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockTransferHeaders\", rule: (v: any) => !!v || \"stockTransferHeaders is required\"},\n {field: \"stockTransferHeaders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockTransferHeader[]).reduce((acc: Array, curr: StockTransferHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetStockTransferRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockTransferId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockTransferId = Guid.fromString(jsonSerializedObject.stockTransferId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockTransferId = this.stockTransferId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockTransferId\", rule: (v: any) => !v.isEmpty() || \".StockTransferId cannot be empty\"},\n ];\n}\n\n\nexport class GetStockTransferResponse extends ModelObject {\n\n public stockTransfer: StockTransfer = new StockTransfer();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockTransfer = new StockTransfer(jsonSerializedObject.stockTransfer);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockTransfer = this.stockTransfer.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockTransfer\", rule: (v: any) => !!v || \"stockTransfer is required\"},\n {field: \"stockTransfer\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetFilteredStockTransfersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: StockTransferFilter = new StockTransferFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new StockTransferFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetFilteredStockTransfersResponse extends ModelObject {\n\n public stockTransfers: StockTransfer[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockTransfers = jsonSerializedObject.stockTransfers.map((v: any) => new StockTransfer(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockTransfers = this.stockTransfers.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockTransfers\", rule: (v: any) => !!v || \"stockTransfers is required\"},\n {field: \"stockTransfers\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockTransfer[]).reduce((acc: Array, curr: StockTransfer) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveStockTransferRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockTransfer: StockTransfer = new StockTransfer();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockTransfer = new StockTransfer(jsonSerializedObject.stockTransfer);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockTransfer = this.stockTransfer.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockTransfer\", rule: (v: any) => !!v || \"stockTransfer is required\"},\n {field: \"stockTransfer\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class CompleteStockTransferRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockTransferId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockTransferId = Guid.fromString(jsonSerializedObject.stockTransferId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockTransferId = this.stockTransferId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockTransferId\", rule: (v: any) => !v.isEmpty() || \".StockTransferId cannot be empty\"},\n ];\n}\n\n\nexport class CancelStockTransferRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockTransferId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockTransferId = Guid.fromString(jsonSerializedObject.stockTransferId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockTransferId = this.stockTransferId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockTransferId\", rule: (v: any) => !v.isEmpty() || \".StockTransferId cannot be empty\"},\n ];\n}\n\n\nexport class GenerateStockTransferNoteRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockTransferId: Guid = Guid.createEmpty();\n public documentFormat: EnumDocumentFileType = EnumDocumentFileType.pdf;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockTransferId = Guid.fromString(jsonSerializedObject.stockTransferId);\n this.documentFormat = EnumDocumentFileType.getByValue(jsonSerializedObject.documentFormat, this.documentFormat);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockTransferId = this.stockTransferId.toString();\n toRet.documentFormat = this.documentFormat.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockTransferId\", rule: (v: any) => !v.isEmpty() || \".StockTransferId cannot be empty\"},\n ];\n}\n\n\nexport class GenerateStockTransferNoteResponse extends ModelObject {\n\n public documentBytes: Uint8Array = new Uint8Array();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.documentBytes = converters.base64ToUint8Array(jsonSerializedObject.documentBytes);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.documentBytes = converters.uint8ArrayToBase64(this.documentBytes);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class CancelCompletedStockTransferRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockTransferId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockTransferId = Guid.fromString(jsonSerializedObject.stockTransferId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockTransferId = this.stockTransferId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockTransferId\", rule: (v: any) => !v.isEmpty() || \".StockTransferId cannot be empty\"},\n ];\n}\n\n\nexport class StockTransferService extends ServiceBase {\n\n public async getAllStockTransferHeaders(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllStockTransferHeadersRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllStockTransferHeadersResponse(response).stockTransferHeaders;\n return this.makeJsonRequest(\"stockTransfer/v1/getAllStockTransferHeaders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getFilteredStockTransferHeaders(tenantId: Guid, filter: StockTransferFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetFilteredStockTransferHeadersRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetFilteredStockTransferHeadersResponse(response).results;\n return this.makeJsonRequest(\"stockTransfer/v1/getFilteredStockTransferHeaders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getStockTransferHeader(tenantId: Guid, stockTransferId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetStockTransferHeaderRequest();\n req.tenantId = tenantId;\n req.stockTransferId = stockTransferId;\n const extractor = (response:any) => new GetStockTransferHeaderResponse(response).stockTransferHeader;\n return this.makeJsonRequest(\"stockTransfer/v1/getStockTransferHeader\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getStockTransferHeaders(tenantId: Guid, stockTransferIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetStockTransferHeadersRequest();\n req.tenantId = tenantId;\n req.stockTransferIds = stockTransferIds;\n const extractor = (response:any) => new GetStockTransferHeadersResponse(response).stockTransferHeaders;\n return this.makeJsonRequest(\"stockTransfer/v1/getStockTransferHeaders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getStockTransfer(tenantId: Guid, stockTransferId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetStockTransferRequest();\n req.tenantId = tenantId;\n req.stockTransferId = stockTransferId;\n const extractor = (response:any) => new GetStockTransferResponse(response).stockTransfer;\n return this.makeJsonRequest(\"stockTransfer/v1/getStockTransfer\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getFilteredStockTransfers(tenantId: Guid, filter: StockTransferFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetFilteredStockTransfersRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetFilteredStockTransfersResponse(response).stockTransfers;\n return this.makeJsonRequest(\"stockTransfer/v1/getFilteredStockTransfers\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveStockTransfer(tenantId: Guid, stockTransfer: StockTransfer, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveStockTransferRequest();\n req.tenantId = tenantId;\n req.stockTransfer = stockTransfer;\n const extractor = null;\n return this.makeJsonRequest(\"stockTransfer/v1/saveStockTransfer\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async completeStockTransfer(tenantId: Guid, stockTransferId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CompleteStockTransferRequest();\n req.tenantId = tenantId;\n req.stockTransferId = stockTransferId;\n const extractor = null;\n return this.makeJsonRequest(\"stockTransfer/v1/completeStockTransfer\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async cancelStockTransfer(tenantId: Guid, stockTransferId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CancelStockTransferRequest();\n req.tenantId = tenantId;\n req.stockTransferId = stockTransferId;\n const extractor = null;\n return this.makeJsonRequest(\"stockTransfer/v1/cancelStockTransfer\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async generateStockTransferNote(tenantId: Guid, stockTransferId: Guid, documentFormat: EnumDocumentFileType, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GenerateStockTransferNoteRequest();\n req.tenantId = tenantId;\n req.stockTransferId = stockTransferId;\n req.documentFormat = documentFormat;\n const extractor = (response:any) => new GenerateStockTransferNoteResponse(response).documentBytes;\n return this.makeJsonRequest(\"stockTransfer/v1/generateStockTransferNote\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async cancelCompletedStockTransfer(tenantId: Guid, stockTransferId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CancelCompletedStockTransferRequest();\n req.tenantId = tenantId;\n req.stockTransferId = stockTransferId;\n const extractor = null;\n return this.makeJsonRequest(\"stockTransfer/v1/cancelCompletedStockTransfer\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const stockTransferService = new StockTransferService();","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumAlcoholType } from \"./enums/enumAlcoholType.generated\";\nimport { EnumDocumentFileType } from \"./enums/enumDocumentFileType.generated\";\nimport { EnumEireMovementType } from \"./enums/enumEireMovementType.generated\";\nimport { EnumGermanBeerDutyMovementType } from \"./enums/enumGermanBeerDutyMovementType.generated\";\nimport { EnumGermanBeerDutyProductType } from \"./enums/enumGermanBeerDutyProductType.generated\";\nimport { EnumSpiritDutyExemptionReason } from \"./enums/enumSpiritDutyExemptionReason.generated\";\nimport { EnumStockAdjustDutyImplication } from \"./enums/enumStockAdjustDutyImplication.generated\";\n\n// Model Objects\n\nexport class StockAdjustmentHeaderReadonly extends ModelObject {\n\n /**\n * Created By Id\n */\n public createdByUserId: Guid = Guid.createEmpty();\n /**\n * Adjustment Number - Auto allocated from numbering scheme.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public adjustmentNumber: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.createdByUserId = Guid.fromString(jsonSerializedObject.createdByUserId);\n this.adjustmentNumber = jsonSerializedObject.adjustmentNumber;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.createdByUserId = this.createdByUserId.toString();\n toRet.adjustmentNumber = this.adjustmentNumber;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"createdByUserId\", rule: (v: any) => !v.isEmpty() || \"StockAdjustmentHeaderReadonly.CreatedByUserId cannot be empty\"},\n ];\n}\n\n\nexport class StockAdjustmentHeader extends ModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Stock Location\n */\n public stockLocationId: Guid = Guid.createEmpty();\n /**\n * Adjustment Date\n */\n public adjustmentDate: LocalDate = LocalDate.ofEpochDay(0);\n /**\n * Adjustment Reason\n * Not Nullable\n */\n public reason: string = \"\";\n /**\n * DutyImplication\n */\n public dutyImplication: EnumStockAdjustDutyImplication = EnumStockAdjustDutyImplication.noDuty;\n /**\n * Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n public readOnly: StockAdjustmentHeaderReadonly = new StockAdjustmentHeaderReadonly();\n public germanBeerDutyMovementType: EnumGermanBeerDutyMovementType = EnumGermanBeerDutyMovementType.none;\n public eireDutyMovementType: EnumEireMovementType = EnumEireMovementType.unknown;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.adjustmentDate = LocalDate.parse(jsonSerializedObject.adjustmentDate);\n this.reason = jsonSerializedObject.reason;\n this.dutyImplication = EnumStockAdjustDutyImplication.getByValue(jsonSerializedObject.dutyImplication, this.dutyImplication);\n this.notes = jsonSerializedObject.notes;\n this.readOnly = new StockAdjustmentHeaderReadonly(jsonSerializedObject.readOnly);\n this.germanBeerDutyMovementType = EnumGermanBeerDutyMovementType.getByValue(jsonSerializedObject.germanBeerDutyMovementType, this.germanBeerDutyMovementType);\n this.eireDutyMovementType = EnumEireMovementType.getByValue(jsonSerializedObject.eireDutyMovementType, this.eireDutyMovementType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.adjustmentDate = this.adjustmentDate.toString();\n toRet.reason = this.reason;\n toRet.dutyImplication = this.dutyImplication.value;\n toRet.notes = this.notes;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.germanBeerDutyMovementType = this.germanBeerDutyMovementType.value;\n toRet.eireDutyMovementType = this.eireDutyMovementType.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"StockAdjustmentHeader.Id cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \"StockAdjustmentHeader.StockLocationId cannot be empty\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class StockAdjustmentLineReadonly extends ModelObject {\n\n /**\n * AlcoholType\n */\n public alcoholType: EnumAlcoholType = EnumAlcoholType.none;\n /**\n * ItemAbv\n */\n public abv: number = 0;\n /**\n * ItemDutiableLitres\n */\n public unitDutiableLitres: number = 0;\n /**\n * ItemUnitLitres\n */\n public unitLitres: number = 0;\n private _manufacturerId: Guid | null = null;\n /**\n * Manufacturer Id\n */\n public get manufacturerId(): Guid | null { return this._manufacturerId }\n public set manufacturerId(value: Guid | null) {\n this._manufacturerId = value === undefined ? null : value;\n }\n /**\n * Stock Adjustment Id\n */\n public stockAdjustmentId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.alcoholType = EnumAlcoholType.getByValue(jsonSerializedObject.alcoholType, this.alcoholType);\n this.abv = jsonSerializedObject.abv;\n this.unitDutiableLitres = jsonSerializedObject.unitDutiableLitres;\n this.unitLitres = jsonSerializedObject.unitLitres;\n this.manufacturerId = jsonSerializedObject.manufacturerId == null ? null : Guid.fromString(jsonSerializedObject.manufacturerId);\n this.stockAdjustmentId = Guid.fromString(jsonSerializedObject.stockAdjustmentId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.alcoholType = this.alcoholType.value;\n toRet.abv = this.abv;\n toRet.unitDutiableLitres = this.unitDutiableLitres;\n toRet.unitLitres = this.unitLitres;\n toRet.manufacturerId = this.manufacturerId == null ? null : this.manufacturerId.toString();\n toRet.stockAdjustmentId = this.stockAdjustmentId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"manufacturerId\", rule: (v: any) => v == null || !v.isEmpty() || \"StockAdjustmentLineReadonly.ManufacturerId cannot be empty\"},\n {field: \"stockAdjustmentId\", rule: (v: any) => !v.isEmpty() || \"StockAdjustmentLineReadonly.StockAdjustmentId cannot be empty\"},\n ];\n}\n\n\nexport class StockAdjustmentLine extends ModelObject {\n\n /**\n * Quantity\n */\n public quantity: number = 0;\n /**\n * Unit of Measure\n */\n public unitOfMeasureId: Guid = Guid.createEmpty();\n private _dateOfBatch: LocalDate | null = null;\n public get dateOfBatch(): LocalDate | null { return this._dateOfBatch }\n public set dateOfBatch(value: LocalDate | null) {\n this._dateOfBatch = value === undefined ? null : value;\n }\n public stockItemId: Guid = Guid.createEmpty();\n public urn: string = \"\";\n private _hopAlpha: number | null = null;\n public get hopAlpha(): number | null { return this._hopAlpha }\n public set hopAlpha(value: number | null) {\n this._hopAlpha = value === undefined ? null : value;\n }\n public readOnly: StockAdjustmentLineReadonly = new StockAdjustmentLineReadonly();\n private _plato: number | null = null;\n /**\n * Plato Value\n */\n public get plato(): number | null { return this._plato }\n public set plato(value: number | null) {\n this._plato = value === undefined ? null : value;\n }\n public germanBeerDutyProductType: EnumGermanBeerDutyProductType = EnumGermanBeerDutyProductType.none;\n private _germanBeerMixedProductPercentageA: number | null = null;\n public get germanBeerMixedProductPercentageA(): number | null { return this._germanBeerMixedProductPercentageA }\n public set germanBeerMixedProductPercentageA(value: number | null) {\n this._germanBeerMixedProductPercentageA = value === undefined ? null : value;\n }\n /**\n * Set true if this item is brewed by members of the public for their personal use by borrowing the Brewery's equipment. This is a service offered by breweries in some countries, such as Australia, and can affect duty.\n */\n public isBrewedForPersonalUse: boolean = false;\n /**\n * Set true if this item is designed to be connected to a pump or pressurised gas system, such as those used in pubs. Some duty systems have different duty rates for beer packaged in these manners for selling to pubs.\n */\n public isDesignedForPump: boolean = false;\n private _finalUnitLitres: number | null = null;\n /**\n * Litres held by the final consumable packaged unit, if relevant. For example, a case of 12 x 500ml bottles would have a final unit litres of 0.5. Some duty systems have different rates depending upon this value.\n * Greater Than : 0\n */\n public get finalUnitLitres(): number | null { return this._finalUnitLitres }\n public set finalUnitLitres(value: number | null) {\n this._finalUnitLitres = value === undefined ? null : value;\n }\n public spiritDutyExemptionReason: EnumSpiritDutyExemptionReason = EnumSpiritDutyExemptionReason.none;\n public id: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.quantity = jsonSerializedObject.quantity;\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n this.dateOfBatch = jsonSerializedObject.dateOfBatch == null ? null : LocalDate.parse(jsonSerializedObject.dateOfBatch);\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.urn = jsonSerializedObject.urn;\n this.hopAlpha = jsonSerializedObject.hopAlpha == null ? null : jsonSerializedObject.hopAlpha;\n this.readOnly = new StockAdjustmentLineReadonly(jsonSerializedObject.readOnly);\n this.plato = jsonSerializedObject.plato == null ? null : jsonSerializedObject.plato;\n this.germanBeerDutyProductType = EnumGermanBeerDutyProductType.getByValue(jsonSerializedObject.germanBeerDutyProductType, this.germanBeerDutyProductType);\n this.germanBeerMixedProductPercentageA = jsonSerializedObject.germanBeerMixedProductPercentageA == null ? null : jsonSerializedObject.germanBeerMixedProductPercentageA;\n this.isBrewedForPersonalUse = jsonSerializedObject.isBrewedForPersonalUse;\n this.isDesignedForPump = jsonSerializedObject.isDesignedForPump;\n this.finalUnitLitres = jsonSerializedObject.finalUnitLitres == null ? null : jsonSerializedObject.finalUnitLitres;\n this.spiritDutyExemptionReason = EnumSpiritDutyExemptionReason.getByValue(jsonSerializedObject.spiritDutyExemptionReason, this.spiritDutyExemptionReason);\n this.id = Guid.fromString(jsonSerializedObject.id);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.quantity = this.quantity;\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n toRet.dateOfBatch = this.dateOfBatch == null ? null : this.dateOfBatch.toString();\n toRet.stockItemId = this.stockItemId.toString();\n toRet.urn = this.urn;\n toRet.hopAlpha = this.hopAlpha == null ? null : this.hopAlpha;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.plato = this.plato == null ? null : this.plato;\n toRet.germanBeerDutyProductType = this.germanBeerDutyProductType.value;\n toRet.germanBeerMixedProductPercentageA = this.germanBeerMixedProductPercentageA == null ? null : this.germanBeerMixedProductPercentageA;\n toRet.isBrewedForPersonalUse = this.isBrewedForPersonalUse;\n toRet.isDesignedForPump = this.isDesignedForPump;\n toRet.finalUnitLitres = this.finalUnitLitres == null ? null : this.finalUnitLitres;\n toRet.spiritDutyExemptionReason = this.spiritDutyExemptionReason.value;\n toRet.id = this.id.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"StockAdjustmentLine.UnitOfMeasureId cannot be empty\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"StockAdjustmentLine.StockItemId cannot be empty\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"finalUnitLitres\", rule: (v: any) => v == null || v > 0 || \"FinalUnitLitres is not greater than minimum allowed value: 0\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"StockAdjustmentLine.Id cannot be empty\"},\n ];\n}\n\n\nexport class StockAdjustment extends BaseModelObject {\n\n public header: StockAdjustmentHeader = new StockAdjustmentHeader();\n public lines: StockAdjustmentLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.header = new StockAdjustmentHeader(jsonSerializedObject.header);\n this.lines = jsonSerializedObject.lines.map((v: any) => new StockAdjustmentLine(v));\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.header = this.header.toJsonSerializedObject();\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockAdjustmentLine[]).reduce((acc: Array, curr: StockAdjustmentLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class StockAdjustmentFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _fromAdjustmentDateInclusive: LocalDate | null = null;\n /**\n * Minimum (inclusive) adjustment date\n */\n public get fromAdjustmentDateInclusive(): LocalDate | null { return this._fromAdjustmentDateInclusive }\n public set fromAdjustmentDateInclusive(value: LocalDate | null) {\n this._fromAdjustmentDateInclusive = value === undefined ? null : value;\n }\n private _toAdjustmentDateInclusive: LocalDate | null = null;\n /**\n * Maximum (inclusive) adjustment date\n */\n public get toAdjustmentDateInclusive(): LocalDate | null { return this._toAdjustmentDateInclusive }\n public set toAdjustmentDateInclusive(value: LocalDate | null) {\n this._toAdjustmentDateInclusive = value === undefined ? null : value;\n }\n private _limitStockAdjustmentIds: Guid[] | null = null;\n public get limitStockAdjustmentIds(): Guid[] | null { return this._limitStockAdjustmentIds }\n public set limitStockAdjustmentIds(value: Guid[] | null) {\n this._limitStockAdjustmentIds = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.fromAdjustmentDateInclusive = jsonSerializedObject.fromAdjustmentDateInclusive == null ? null : LocalDate.parse(jsonSerializedObject.fromAdjustmentDateInclusive);\n this.toAdjustmentDateInclusive = jsonSerializedObject.toAdjustmentDateInclusive == null ? null : LocalDate.parse(jsonSerializedObject.toAdjustmentDateInclusive);\n this.limitStockAdjustmentIds = jsonSerializedObject.limitStockAdjustmentIds == null ? null : jsonSerializedObject.limitStockAdjustmentIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.fromAdjustmentDateInclusive = this.fromAdjustmentDateInclusive == null ? null : this.fromAdjustmentDateInclusive.toString();\n toRet.toAdjustmentDateInclusive = this.toAdjustmentDateInclusive == null ? null : this.toAdjustmentDateInclusive.toString();\n toRet.limitStockAdjustmentIds = this.limitStockAdjustmentIds == null ? null : this.limitStockAdjustmentIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class FilteredStockAdjustmentResults extends ModelObject {\n\n public matchingCount: number = 0;\n public stockAdjustments: StockAdjustmentHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.stockAdjustments = jsonSerializedObject.stockAdjustments.map((v: any) => new StockAdjustmentHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.stockAdjustments = this.stockAdjustments.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"stockAdjustments\", rule: (v: any) => !!v || \"stockAdjustments is required\"},\n {field: \"stockAdjustments\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockAdjustmentHeader[]).reduce((acc: Array, curr: StockAdjustmentHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class DutySuspendedAdjustmentReceiptsResultSet extends ModelObject {\n\n public alcoholType: EnumAlcoholType = EnumAlcoholType.none;\n public dutySuspendedReceivedLitres: number = 0;\n public dutySuspendedReceivedLitresOfAlcohol: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.alcoholType = EnumAlcoholType.getByValue(jsonSerializedObject.alcoholType, this.alcoholType);\n this.dutySuspendedReceivedLitres = jsonSerializedObject.dutySuspendedReceivedLitres;\n this.dutySuspendedReceivedLitresOfAlcohol = jsonSerializedObject.dutySuspendedReceivedLitresOfAlcohol;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.alcoholType = this.alcoholType.value;\n toRet.dutySuspendedReceivedLitres = this.dutySuspendedReceivedLitres;\n toRet.dutySuspendedReceivedLitresOfAlcohol = this.dutySuspendedReceivedLitresOfAlcohol;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class PartialStockAdjustment extends ModelObject {\n\n public header: StockAdjustmentHeader = new StockAdjustmentHeader();\n public lines: StockAdjustmentLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.header = new StockAdjustmentHeader(jsonSerializedObject.header);\n this.lines = jsonSerializedObject.lines.map((v: any) => new StockAdjustmentLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.header = this.header.toJsonSerializedObject();\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockAdjustmentLine[]).reduce((acc: Array, curr: StockAdjustmentLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllStockAdjustmentHeadersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllStockAdjustmentHeadersResponse extends ModelObject {\n\n public stockAdjustments: StockAdjustmentHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockAdjustments = jsonSerializedObject.stockAdjustments.map((v: any) => new StockAdjustmentHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockAdjustments = this.stockAdjustments.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockAdjustments\", rule: (v: any) => !!v || \"stockAdjustments is required\"},\n {field: \"stockAdjustments\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockAdjustmentHeader[]).reduce((acc: Array, curr: StockAdjustmentHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetFilteredStockAdjustmentHeadersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: StockAdjustmentFilter = new StockAdjustmentFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new StockAdjustmentFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetFilteredStockAdjustmentHeadersResponse extends ModelObject {\n\n public results: FilteredStockAdjustmentResults = new FilteredStockAdjustmentResults();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredStockAdjustmentResults(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetStockAdjustmentsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockAdjustmentIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockAdjustmentIds = jsonSerializedObject.stockAdjustmentIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockAdjustmentIds = this.stockAdjustmentIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetStockAdjustmentsResponse extends ModelObject {\n\n public stockAdjustments: StockAdjustment[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockAdjustments = jsonSerializedObject.stockAdjustments.map((v: any) => new StockAdjustment(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockAdjustments = this.stockAdjustments.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockAdjustments\", rule: (v: any) => !!v || \"stockAdjustments is required\"},\n {field: \"stockAdjustments\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockAdjustment[]).reduce((acc: Array, curr: StockAdjustment) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class CreateStockAdjustmentRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockAdjustment: StockAdjustment = new StockAdjustment();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockAdjustment = new StockAdjustment(jsonSerializedObject.stockAdjustment);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockAdjustment = this.stockAdjustment.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockAdjustment\", rule: (v: any) => !!v || \"stockAdjustment is required\"},\n {field: \"stockAdjustment\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetDutySuspendedReceiptStockAdjustmentsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public fromDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public toDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public limitToGivenAlcoholTypes: boolean = false;\n public limitedAlcoholTypes: readonly EnumAlcoholType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.fromDateInclusive = LocalDate.parse(jsonSerializedObject.fromDateInclusive);\n this.toDateInclusive = LocalDate.parse(jsonSerializedObject.toDateInclusive);\n this.limitToGivenAlcoholTypes = jsonSerializedObject.limitToGivenAlcoholTypes;\n this.limitedAlcoholTypes = jsonSerializedObject.limitedAlcoholTypes.map((v: any) => EnumAlcoholType.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.fromDateInclusive = this.fromDateInclusive.toString();\n toRet.toDateInclusive = this.toDateInclusive.toString();\n toRet.limitToGivenAlcoholTypes = this.limitToGivenAlcoholTypes;\n toRet.limitedAlcoholTypes = this.limitedAlcoholTypes.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetDutySuspendedReceiptStockAdjustmentsResponse extends ModelObject {\n\n public results: StockAdjustment[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new StockAdjustment(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockAdjustment[]).reduce((acc: Array, curr: StockAdjustment) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class EvaluateDutySuspendedAdjustmentReceiptsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public fromDutyDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public toDutyDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public limitToGivenAlcoholTypes: boolean = false;\n public limitedAlcoholTypes: readonly EnumAlcoholType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.fromDutyDateInclusive = LocalDate.parse(jsonSerializedObject.fromDutyDateInclusive);\n this.toDutyDateInclusive = LocalDate.parse(jsonSerializedObject.toDutyDateInclusive);\n this.limitToGivenAlcoholTypes = jsonSerializedObject.limitToGivenAlcoholTypes;\n this.limitedAlcoholTypes = jsonSerializedObject.limitedAlcoholTypes.map((v: any) => EnumAlcoholType.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.fromDutyDateInclusive = this.fromDutyDateInclusive.toString();\n toRet.toDutyDateInclusive = this.toDutyDateInclusive.toString();\n toRet.limitToGivenAlcoholTypes = this.limitToGivenAlcoholTypes;\n toRet.limitedAlcoholTypes = this.limitedAlcoholTypes.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class EvaluateDutySuspendedAdjustmentReceiptsResponse extends ModelObject {\n\n public results: DutySuspendedAdjustmentReceiptsResultSet[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new DutySuspendedAdjustmentReceiptsResultSet(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as DutySuspendedAdjustmentReceiptsResultSet[]).reduce((acc: Array, curr: DutySuspendedAdjustmentReceiptsResultSet) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetPossibleDutiableStockAdjustmentLinesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public fromDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public toDateInclusive: LocalDate = LocalDate.ofEpochDay(0);\n public limitedAlcoholTypes: readonly EnumAlcoholType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.fromDateInclusive = LocalDate.parse(jsonSerializedObject.fromDateInclusive);\n this.toDateInclusive = LocalDate.parse(jsonSerializedObject.toDateInclusive);\n this.limitedAlcoholTypes = jsonSerializedObject.limitedAlcoholTypes.map((v: any) => EnumAlcoholType.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.fromDateInclusive = this.fromDateInclusive.toString();\n toRet.toDateInclusive = this.toDateInclusive.toString();\n toRet.limitedAlcoholTypes = this.limitedAlcoholTypes.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetPossibleDutiableStockAdjustmentLinesResponse extends ModelObject {\n\n public results: PartialStockAdjustment[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new PartialStockAdjustment(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PartialStockAdjustment[]).reduce((acc: Array, curr: PartialStockAdjustment) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class MoveAllStockInBatchesToEmptyUrnRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockBatchIds: readonly Guid[] = [];\n public stockAdjustmentReason: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockBatchIds = jsonSerializedObject.stockBatchIds.map((v: any) => Guid.fromString(v));\n this.stockAdjustmentReason = jsonSerializedObject.stockAdjustmentReason;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockBatchIds = this.stockBatchIds.map(v => v.toString());\n toRet.stockAdjustmentReason = this.stockAdjustmentReason;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GenerateStockAdjustmentSheetRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public documentFormat: EnumDocumentFileType = EnumDocumentFileType.pdf;\n public stockAdjustmentId: Guid = Guid.createEmpty();\n private _documentTemplateId: Guid | null = null;\n public get documentTemplateId(): Guid | null { return this._documentTemplateId }\n public set documentTemplateId(value: Guid | null) {\n this._documentTemplateId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.documentFormat = EnumDocumentFileType.getByValue(jsonSerializedObject.documentFormat, this.documentFormat);\n this.stockAdjustmentId = Guid.fromString(jsonSerializedObject.stockAdjustmentId);\n this.documentTemplateId = jsonSerializedObject.documentTemplateId == null ? null : Guid.fromString(jsonSerializedObject.documentTemplateId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.documentFormat = this.documentFormat.value;\n toRet.stockAdjustmentId = this.stockAdjustmentId.toString();\n toRet.documentTemplateId = this.documentTemplateId == null ? null : this.documentTemplateId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockAdjustmentId\", rule: (v: any) => !v.isEmpty() || \".StockAdjustmentId cannot be empty\"},\n {field: \"documentTemplateId\", rule: (v: any) => v == null || !v.isEmpty() || \".DocumentTemplateId cannot be empty\"},\n ];\n}\n\n\nexport class GenerateStockAdjustmentSheetResponse extends ModelObject {\n\n public documentBytes: Uint8Array = new Uint8Array();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.documentBytes = converters.base64ToUint8Array(jsonSerializedObject.documentBytes);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.documentBytes = converters.uint8ArrayToBase64(this.documentBytes);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class StockAdjustmentService extends ServiceBase {\n\n public async getAllStockAdjustmentHeaders(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllStockAdjustmentHeadersRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllStockAdjustmentHeadersResponse(response).stockAdjustments;\n return this.makeJsonRequest(\"stockAdjustment/v1/getAllStockAdjustmentHeaders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getFilteredStockAdjustmentHeaders(tenantId: Guid, filter: StockAdjustmentFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetFilteredStockAdjustmentHeadersRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetFilteredStockAdjustmentHeadersResponse(response).results;\n return this.makeJsonRequest(\"stockAdjustment/v1/getFilteredStockAdjustmentHeaders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getStockAdjustments(tenantId: Guid, stockAdjustmentIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetStockAdjustmentsRequest();\n req.tenantId = tenantId;\n req.stockAdjustmentIds = stockAdjustmentIds;\n const extractor = (response:any) => new GetStockAdjustmentsResponse(response).stockAdjustments;\n return this.makeJsonRequest(\"stockAdjustment/v1/getStockAdjustments\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async createStockAdjustment(tenantId: Guid, stockAdjustment: StockAdjustment, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CreateStockAdjustmentRequest();\n req.tenantId = tenantId;\n req.stockAdjustment = stockAdjustment;\n const extractor = null;\n return this.makeJsonRequest(\"stockAdjustment/v1/createStockAdjustment\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getDutySuspendedReceiptStockAdjustments(tenantId: Guid, fromDateInclusive: LocalDate, toDateInclusive: LocalDate, limitToGivenAlcoholTypes: boolean, limitedAlcoholTypes: readonly EnumAlcoholType[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetDutySuspendedReceiptStockAdjustmentsRequest();\n req.tenantId = tenantId;\n req.fromDateInclusive = fromDateInclusive;\n req.toDateInclusive = toDateInclusive;\n req.limitToGivenAlcoholTypes = limitToGivenAlcoholTypes;\n req.limitedAlcoholTypes = limitedAlcoholTypes;\n const extractor = (response:any) => new GetDutySuspendedReceiptStockAdjustmentsResponse(response).results;\n return this.makeJsonRequest(\"stockAdjustment/v1/getDutySuspendedReceiptStockAdjustments\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async evaluateDutySuspendedAdjustmentReceipts(tenantId: Guid, fromDutyDateInclusive: LocalDate, toDutyDateInclusive: LocalDate, limitToGivenAlcoholTypes: boolean, limitedAlcoholTypes: readonly EnumAlcoholType[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new EvaluateDutySuspendedAdjustmentReceiptsRequest();\n req.tenantId = tenantId;\n req.fromDutyDateInclusive = fromDutyDateInclusive;\n req.toDutyDateInclusive = toDutyDateInclusive;\n req.limitToGivenAlcoholTypes = limitToGivenAlcoholTypes;\n req.limitedAlcoholTypes = limitedAlcoholTypes;\n const extractor = (response:any) => new EvaluateDutySuspendedAdjustmentReceiptsResponse(response).results;\n return this.makeJsonRequest(\"stockAdjustment/v1/evaluateDutySuspendedAdjustmentReceipts\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getPossibleDutiableStockAdjustmentLines(tenantId: Guid, fromDateInclusive: LocalDate, toDateInclusive: LocalDate, limitedAlcoholTypes: readonly EnumAlcoholType[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPossibleDutiableStockAdjustmentLinesRequest();\n req.tenantId = tenantId;\n req.fromDateInclusive = fromDateInclusive;\n req.toDateInclusive = toDateInclusive;\n req.limitedAlcoholTypes = limitedAlcoholTypes;\n const extractor = (response:any) => new GetPossibleDutiableStockAdjustmentLinesResponse(response).results;\n return this.makeJsonRequest(\"stockAdjustment/v1/getPossibleDutiableStockAdjustmentLines\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async generateStockAdjustmentSheet(tenantId: Guid, documentFormat: EnumDocumentFileType, stockAdjustmentId: Guid, documentTemplateId: Guid | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GenerateStockAdjustmentSheetRequest();\n req.tenantId = tenantId;\n req.documentFormat = documentFormat;\n req.stockAdjustmentId = stockAdjustmentId;\n req.documentTemplateId = documentTemplateId;\n const extractor = (response:any) => new GenerateStockAdjustmentSheetResponse(response).documentBytes;\n return this.makeJsonRequest(\"stockAdjustment/v1/generateStockAdjustmentSheet\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const stockAdjustmentService = new StockAdjustmentService();","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumAlcoholType } from \"./enums/enumAlcoholType.generated\";\nimport { EnumAssemblyStatus } from \"./enums/enumAssemblyStatus.generated\";\nimport { EnumAssemblyType } from \"./enums/enumAssemblyType.generated\";\nimport { EnumDocumentFileType } from \"./enums/enumDocumentFileType.generated\";\nimport { EnumProcessIngredientSource } from \"./enums/enumProcessIngredientSource.generated\";\nimport { EnumProcessOutputTarget } from \"./enums/enumProcessOutputTarget.generated\";\nimport { EnumYesNoEither } from \"./enums/enumYesNoEither.generated\";\n\n// Model Objects\n\nexport class BatchOutput extends ModelObject {\n\n public quantity: number = 0;\n public stockItemId: Guid = Guid.createEmpty();\n public unitOfMeasureId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.quantity = jsonSerializedObject.quantity;\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.quantity = this.quantity;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"BatchOutput.StockItemId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"BatchOutput.UnitOfMeasureId cannot be empty\"},\n ];\n}\n\n\nexport class BatchHeaderReadOnly extends ModelObject {\n\n private _startedAt: Instant | null = null;\n /**\n * Timestamp at which the batch was started.\n */\n public get startedAt(): Instant | null { return this._startedAt }\n public set startedAt(value: Instant | null) {\n this._startedAt = value === undefined ? null : value;\n }\n private _startedBy: Guid | null = null;\n /**\n * User who has started the batch.\n */\n public get startedBy(): Guid | null { return this._startedBy }\n public set startedBy(value: Guid | null) {\n this._startedBy = value === undefined ? null : value;\n }\n private _completedAt: Instant | null = null;\n /**\n * Timestamp at which the batch was completed.\n */\n public get completedAt(): Instant | null { return this._completedAt }\n public set completedAt(value: Instant | null) {\n this._completedAt = value === undefined ? null : value;\n }\n private _cancelledAt: Instant | null = null;\n /**\n * Timestamp at which the assembly was cancelled.\n */\n public get cancelledAt(): Instant | null { return this._cancelledAt }\n public set cancelledAt(value: Instant | null) {\n this._cancelledAt = value === undefined ? null : value;\n }\n /**\n * True if this batch has been previously completed, and then un-completed.\n */\n public hasBeenPreviouslyCompleted: boolean = false;\n /**\n * Total Litres of all ingredients already used in batch. (Will be 0 if not yet started)\n */\n public totalIngredientUsedLitres: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.startedAt = jsonSerializedObject.startedAt == null ? null : Instant.parse(jsonSerializedObject.startedAt);\n this.startedBy = jsonSerializedObject.startedBy == null ? null : Guid.fromString(jsonSerializedObject.startedBy);\n this.completedAt = jsonSerializedObject.completedAt == null ? null : Instant.parse(jsonSerializedObject.completedAt);\n this.cancelledAt = jsonSerializedObject.cancelledAt == null ? null : Instant.parse(jsonSerializedObject.cancelledAt);\n this.hasBeenPreviouslyCompleted = jsonSerializedObject.hasBeenPreviouslyCompleted;\n this.totalIngredientUsedLitres = jsonSerializedObject.totalIngredientUsedLitres;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.startedAt = this.startedAt == null ? null : this.startedAt.toString();\n toRet.startedBy = this.startedBy == null ? null : this.startedBy.toString();\n toRet.completedAt = this.completedAt == null ? null : this.completedAt.toString();\n toRet.cancelledAt = this.cancelledAt == null ? null : this.cancelledAt.toString();\n toRet.hasBeenPreviouslyCompleted = this.hasBeenPreviouslyCompleted;\n toRet.totalIngredientUsedLitres = this.totalIngredientUsedLitres;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"startedBy\", rule: (v: any) => v == null || !v.isEmpty() || \"BatchHeaderReadOnly.StartedBy cannot be empty\"},\n ];\n}\n\n\nexport class BatchHeaderCalculated extends ModelObject {\n\n public status: EnumAssemblyStatus = EnumAssemblyStatus.open;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.status = EnumAssemblyStatus.getByValue(jsonSerializedObject.status, this.status);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.status = this.status.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class BatchHeader extends ModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n public isHidden: boolean = false;\n private _materialProducedStockItemId: Guid | null = null;\n /**\n * Stock Item Id produced by the batch\n */\n public get materialProducedStockItemId(): Guid | null { return this._materialProducedStockItemId }\n public set materialProducedStockItemId(value: Guid | null) {\n this._materialProducedStockItemId = value === undefined ? null : value;\n }\n /**\n * Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n /**\n * Stock Location Id\n */\n public stockLocationId: Guid = Guid.createEmpty();\n /**\n * Urn. Will be either allocated at begin batch, or will be provided by user, or left blank.\n * Not Nullable\n * Max Length : 1000\n */\n public urn: string = \"\";\n /**\n * When True, Urn will be system allocated at begin batch, When false, Urn must be provided by user if needed.\n */\n public autoAllocateUrnAtStart: boolean = false;\n /**\n * Vessel Fill Colour\n * Not Nullable\n */\n public vesselFillColour: string = \"\";\n /**\n * Batch Start Date. Either planned (if batch not started) or actual (if started). Editable by the user.\n */\n public startDate: LocalDate = LocalDate.ofEpochDay(0);\n private _batchTemplateId: Guid | null = null;\n /**\n * Batch template from which this batch was initially created (if any). For reference only.\n */\n public get batchTemplateId(): Guid | null { return this._batchTemplateId }\n public set batchTemplateId(value: Guid | null) {\n this._batchTemplateId = value === undefined ? null : value;\n }\n public readOnly: BatchHeaderReadOnly = new BatchHeaderReadOnly();\n public calculated: BatchHeaderCalculated = new BatchHeaderCalculated();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.isHidden = jsonSerializedObject.isHidden;\n this.materialProducedStockItemId = jsonSerializedObject.materialProducedStockItemId == null ? null : Guid.fromString(jsonSerializedObject.materialProducedStockItemId);\n this.notes = jsonSerializedObject.notes;\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.urn = jsonSerializedObject.urn;\n this.autoAllocateUrnAtStart = jsonSerializedObject.autoAllocateUrnAtStart;\n this.vesselFillColour = jsonSerializedObject.vesselFillColour;\n this.startDate = LocalDate.parse(jsonSerializedObject.startDate);\n this.batchTemplateId = jsonSerializedObject.batchTemplateId == null ? null : Guid.fromString(jsonSerializedObject.batchTemplateId);\n this.readOnly = new BatchHeaderReadOnly(jsonSerializedObject.readOnly);\n this.calculated = new BatchHeaderCalculated(jsonSerializedObject.calculated);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.isHidden = this.isHidden;\n toRet.materialProducedStockItemId = this.materialProducedStockItemId == null ? null : this.materialProducedStockItemId.toString();\n toRet.notes = this.notes;\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.urn = this.urn;\n toRet.autoAllocateUrnAtStart = this.autoAllocateUrnAtStart;\n toRet.vesselFillColour = this.vesselFillColour;\n toRet.startDate = this.startDate.toString();\n toRet.batchTemplateId = this.batchTemplateId == null ? null : this.batchTemplateId.toString();\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.calculated = this.calculated.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"BatchHeader.Id cannot be empty\"},\n {field: \"materialProducedStockItemId\", rule: (v: any) => v == null || !v.isEmpty() || \"BatchHeader.MaterialProducedStockItemId cannot be empty\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \"BatchHeader.StockLocationId cannot be empty\"},\n {field: \"urn\", rule: (v: any) => v == null || v.length <= 1000 || \"Urn has too many characters (1000)\"},\n {field: \"batchTemplateId\", rule: (v: any) => v == null || !v.isEmpty() || \"BatchHeader.BatchTemplateId cannot be empty\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"calculated\", rule: (v: any) => !!v || \"calculated is required\"},\n {field: \"calculated\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class ProcessHeaderReadOnly extends ModelObject {\n\n private _startedAt: Instant | null = null;\n /**\n * Timestamp at which the process was started.\n */\n public get startedAt(): Instant | null { return this._startedAt }\n public set startedAt(value: Instant | null) {\n this._startedAt = value === undefined ? null : value;\n }\n private _completedAt: Instant | null = null;\n /**\n * Timestamp at which the process was completed.\n */\n public get completedAt(): Instant | null { return this._completedAt }\n public set completedAt(value: Instant | null) {\n this._completedAt = value === undefined ? null : value;\n }\n private _costExpectedAtStart: number | null = null;\n /**\n * The cost which was expected as captured when the process was started.\n */\n public get costExpectedAtStart(): number | null { return this._costExpectedAtStart }\n public set costExpectedAtStart(value: number | null) {\n this._costExpectedAtStart = value === undefined ? null : value;\n }\n /**\n * Cannot be unset once set.\n */\n public hasPrintedLabels: boolean = false;\n /**\n * Timestamp at which the process header was last updated.\n */\n public lastUpdatedAt: Instant = Instant.ofEpochMilli(0);\n private _startedBy: Guid | null = null;\n /**\n * User who has started the process.\n */\n public get startedBy(): Guid | null { return this._startedBy }\n public set startedBy(value: Guid | null) {\n this._startedBy = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.startedAt = jsonSerializedObject.startedAt == null ? null : Instant.parse(jsonSerializedObject.startedAt);\n this.completedAt = jsonSerializedObject.completedAt == null ? null : Instant.parse(jsonSerializedObject.completedAt);\n this.costExpectedAtStart = jsonSerializedObject.costExpectedAtStart == null ? null : jsonSerializedObject.costExpectedAtStart;\n this.hasPrintedLabels = jsonSerializedObject.hasPrintedLabels;\n this.lastUpdatedAt = Instant.parse(jsonSerializedObject.lastUpdatedAt);\n this.startedBy = jsonSerializedObject.startedBy == null ? null : Guid.fromString(jsonSerializedObject.startedBy);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.startedAt = this.startedAt == null ? null : this.startedAt.toString();\n toRet.completedAt = this.completedAt == null ? null : this.completedAt.toString();\n toRet.costExpectedAtStart = this.costExpectedAtStart == null ? null : this.costExpectedAtStart;\n toRet.hasPrintedLabels = this.hasPrintedLabels;\n toRet.lastUpdatedAt = this.lastUpdatedAt.toString();\n toRet.startedBy = this.startedBy == null ? null : this.startedBy.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"startedBy\", rule: (v: any) => v == null || !v.isEmpty() || \"ProcessHeaderReadOnly.StartedBy cannot be empty\"},\n ];\n}\n\n\nexport class ProcessHeaderCalculated extends ModelObject {\n\n private _outputExpectedAtStart: BatchOutput | null = null;\n public get outputExpectedAtStart(): BatchOutput | null { return this._outputExpectedAtStart }\n public set outputExpectedAtStart(value: BatchOutput | null) {\n this._outputExpectedAtStart = value === undefined ? null : value;\n }\n private _outputProduced: BatchOutput | null = null;\n public get outputProduced(): BatchOutput | null { return this._outputProduced }\n public set outputProduced(value: BatchOutput | null) {\n this._outputProduced = value === undefined ? null : value;\n }\n public status: EnumAssemblyStatus = EnumAssemblyStatus.open;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outputExpectedAtStart = jsonSerializedObject.outputExpectedAtStart == null ? null : new BatchOutput(jsonSerializedObject.outputExpectedAtStart);\n this.outputProduced = jsonSerializedObject.outputProduced == null ? null : new BatchOutput(jsonSerializedObject.outputProduced);\n this.status = EnumAssemblyStatus.getByValue(jsonSerializedObject.status, this.status);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outputExpectedAtStart = this.outputExpectedAtStart == null ? null : this.outputExpectedAtStart?.toJsonSerializedObject() ?? null;\n toRet.outputProduced = this.outputProduced == null ? null : this.outputProduced?.toJsonSerializedObject() ?? null;\n toRet.status = this.status.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outputExpectedAtStart\", rule: (v: any) => (v === null) || v.validate()},\n {field: \"outputProduced\", rule: (v: any) => (v === null) || v.validate()},\n ];\n}\n\n\nexport class ProcessHeader extends ModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n private _batchId: Guid | null = null;\n /**\n * Id of the Batch where this Process Header belongs to. Null for ad hoc maintenance process.\n */\n public get batchId(): Guid | null { return this._batchId }\n public set batchId(value: Guid | null) {\n this._batchId = value === undefined ? null : value;\n }\n private _recipeId: Guid | null = null;\n /**\n * Recipe from which this process was initially created (if any). Does not drive any functionality, just for future reference really.\n */\n public get recipeId(): Guid | null { return this._recipeId }\n public set recipeId(value: Guid | null) {\n this._recipeId = value === undefined ? null : value;\n }\n /**\n * Assembly type of this process. : 0 = MaterialProduction, 1 = ProductPackaging, 2 = Maintenance\n */\n public processType: EnumAssemblyType = EnumAssemblyType.materialProduction;\n private _bestBefore: LocalDate | null = null;\n /**\n * Best Before Date\n */\n public get bestBefore(): LocalDate | null { return this._bestBefore }\n public set bestBefore(value: LocalDate | null) {\n this._bestBefore = value === undefined ? null : value;\n }\n /**\n * Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n /**\n * Name.\n * Not Nullable\n * Max Length : 1000\n */\n public name: string = \"\";\n private _startDate: LocalDate | null = null;\n /**\n * Date at which the process was actually started - user editable (not captured by system). Not applicable to unstarted assemblies.\n */\n public get startDate(): LocalDate | null { return this._startDate }\n public set startDate(value: LocalDate | null) {\n this._startDate = value === undefined ? null : value;\n }\n /**\n * Duration this process is expected to take. Used for planning. Can be updated while process is in progress.\n */\n public expectedDurationDays: number = 0;\n private _doNotStartBeforeDate: LocalDate | null = null;\n /**\n * Date which the process should be delayed until if all prerequisites are already complete. Particularly useful for planning packagings once produce is ready if the produce is to be held in a holding vessel and packaged in multiple steps.\n */\n public get doNotStartBeforeDate(): LocalDate | null { return this._doNotStartBeforeDate }\n public set doNotStartBeforeDate(value: LocalDate | null) {\n this._doNotStartBeforeDate = value === undefined ? null : value;\n }\n /**\n * Cannot be unset once set.\n */\n public hasPrintedLabels: boolean = false;\n /**\n * SubBatch\n * Not Nullable\n * Max Length : 1000\n */\n public subBatch: string = \"\";\n private _stockLocationId: Guid | null = null;\n /**\n * Required for ad hoc maintenance processes. Otherwise, use the Batch Stock Location Id.\n */\n public get stockLocationId(): Guid | null { return this._stockLocationId }\n public set stockLocationId(value: Guid | null) {\n this._stockLocationId = value === undefined ? null : value;\n }\n private _outputStillExpected: BatchOutput | null = null;\n public get outputStillExpected(): BatchOutput | null { return this._outputStillExpected }\n public set outputStillExpected(value: BatchOutput | null) {\n this._outputStillExpected = value === undefined ? null : value;\n }\n public readOnly: ProcessHeaderReadOnly = new ProcessHeaderReadOnly();\n public calculated: ProcessHeaderCalculated = new ProcessHeaderCalculated();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.batchId = jsonSerializedObject.batchId == null ? null : Guid.fromString(jsonSerializedObject.batchId);\n this.recipeId = jsonSerializedObject.recipeId == null ? null : Guid.fromString(jsonSerializedObject.recipeId);\n this.processType = EnumAssemblyType.getByValue(jsonSerializedObject.processType, this.processType);\n this.bestBefore = jsonSerializedObject.bestBefore == null ? null : LocalDate.parse(jsonSerializedObject.bestBefore);\n this.notes = jsonSerializedObject.notes;\n this.name = jsonSerializedObject.name;\n this.startDate = jsonSerializedObject.startDate == null ? null : LocalDate.parse(jsonSerializedObject.startDate);\n this.expectedDurationDays = jsonSerializedObject.expectedDurationDays;\n this.doNotStartBeforeDate = jsonSerializedObject.doNotStartBeforeDate == null ? null : LocalDate.parse(jsonSerializedObject.doNotStartBeforeDate);\n this.hasPrintedLabels = jsonSerializedObject.hasPrintedLabels;\n this.subBatch = jsonSerializedObject.subBatch;\n this.stockLocationId = jsonSerializedObject.stockLocationId == null ? null : Guid.fromString(jsonSerializedObject.stockLocationId);\n this.outputStillExpected = jsonSerializedObject.outputStillExpected == null ? null : new BatchOutput(jsonSerializedObject.outputStillExpected);\n this.readOnly = new ProcessHeaderReadOnly(jsonSerializedObject.readOnly);\n this.calculated = new ProcessHeaderCalculated(jsonSerializedObject.calculated);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.batchId = this.batchId == null ? null : this.batchId.toString();\n toRet.recipeId = this.recipeId == null ? null : this.recipeId.toString();\n toRet.processType = this.processType.value;\n toRet.bestBefore = this.bestBefore == null ? null : this.bestBefore.toString();\n toRet.notes = this.notes;\n toRet.name = this.name;\n toRet.startDate = this.startDate == null ? null : this.startDate.toString();\n toRet.expectedDurationDays = this.expectedDurationDays;\n toRet.doNotStartBeforeDate = this.doNotStartBeforeDate == null ? null : this.doNotStartBeforeDate.toString();\n toRet.hasPrintedLabels = this.hasPrintedLabels;\n toRet.subBatch = this.subBatch;\n toRet.stockLocationId = this.stockLocationId == null ? null : this.stockLocationId.toString();\n toRet.outputStillExpected = this.outputStillExpected == null ? null : this.outputStillExpected?.toJsonSerializedObject() ?? null;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.calculated = this.calculated.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"ProcessHeader.Id cannot be empty\"},\n {field: \"batchId\", rule: (v: any) => v == null || !v.isEmpty() || \"ProcessHeader.BatchId cannot be empty\"},\n {field: \"recipeId\", rule: (v: any) => v == null || !v.isEmpty() || \"ProcessHeader.RecipeId cannot be empty\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"expectedDurationDays\", rule: (v: any) => v == null || v >= -2147483648 || \"ExpectedDurationDays is not greater than minimum allowed value: -2147483648\"},\n {field: \"expectedDurationDays\", rule: (v: any) => v == null || v <= 2147483647 || \"ExpectedDurationDays is above maximum allowed value: 2147483647\"},\n {field: \"subBatch\", rule: (v: any) => v == null || v.length <= 1000 || \"SubBatch has too many characters (1000)\"},\n {field: \"stockLocationId\", rule: (v: any) => v == null || !v.isEmpty() || \"ProcessHeader.StockLocationId cannot be empty\"},\n {field: \"outputStillExpected\", rule: (v: any) => (v === null) || v.validate()},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"calculated\", rule: (v: any) => !!v || \"calculated is required\"},\n {field: \"calculated\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class ProcessInstructionReadOnly extends ModelObject {\n\n private _completedAt: Instant | null = null;\n /**\n * Timestamp at which the instruction was completed on the system. Captured by system not user editable.\n */\n public get completedAt(): Instant | null { return this._completedAt }\n public set completedAt(value: Instant | null) {\n this._completedAt = value === undefined ? null : value;\n }\n private _completedByUserId: Guid | null = null;\n /**\n * User Id of the user who completed the instruction. Captured by system not user editable.\n */\n public get completedByUserId(): Guid | null { return this._completedByUserId }\n public set completedByUserId(value: Guid | null) {\n this._completedByUserId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.completedAt = jsonSerializedObject.completedAt == null ? null : Instant.parse(jsonSerializedObject.completedAt);\n this.completedByUserId = jsonSerializedObject.completedByUserId == null ? null : Guid.fromString(jsonSerializedObject.completedByUserId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.completedAt = this.completedAt == null ? null : this.completedAt.toString();\n toRet.completedByUserId = this.completedByUserId == null ? null : this.completedByUserId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"completedByUserId\", rule: (v: any) => v == null || !v.isEmpty() || \"ProcessInstructionReadOnly.CompletedByUserId cannot be empty\"},\n ];\n}\n\n\nexport class ProcessInstruction extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Id of the Process Header where this Instruction belongs to. \n */\n public processId: Guid = Guid.createEmpty();\n /**\n * Sequence\n */\n public sequence: number = 0;\n /**\n * Instruction\n * Not Nullable\n * Max Length : 1000\n */\n public instruction: string = \"\";\n /**\n * Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n /**\n * Complete\n */\n public complete: boolean = false;\n /**\n * Recorded Result\n * Not Nullable\n * Max Length : 100000\n */\n public recordedResult: string = \"\";\n public readOnly: ProcessInstructionReadOnly = new ProcessInstructionReadOnly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n this.sequence = jsonSerializedObject.sequence;\n this.instruction = jsonSerializedObject.instruction;\n this.notes = jsonSerializedObject.notes;\n this.complete = jsonSerializedObject.complete;\n this.recordedResult = jsonSerializedObject.recordedResult;\n this.readOnly = new ProcessInstructionReadOnly(jsonSerializedObject.readOnly);\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.processId = this.processId.toString();\n toRet.sequence = this.sequence;\n toRet.instruction = this.instruction;\n toRet.notes = this.notes;\n toRet.complete = this.complete;\n toRet.recordedResult = this.recordedResult;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"ProcessInstruction.Id cannot be empty\"},\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \"ProcessInstruction.ProcessId cannot be empty\"},\n {field: \"sequence\", rule: (v: any) => v == null || v >= -2147483648 || \"Sequence is not greater than minimum allowed value: -2147483648\"},\n {field: \"sequence\", rule: (v: any) => v == null || v <= 2147483647 || \"Sequence is above maximum allowed value: 2147483647\"},\n {field: \"instruction\", rule: (v: any) => v == null || v.length <= 1000 || \"Instruction has too many characters (1000)\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"recordedResult\", rule: (v: any) => v == null || v.length <= 100000 || \"RecordedResult has too many characters (100000)\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class ProcessVesselRequirement extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n public version: number = 0;\n /**\n * Id of the Process Header to which this Requirement belongs. \n */\n public processId: Guid = Guid.createEmpty();\n /**\n * Required Vessel Capability.\n */\n public vesselCapabilityId: Guid = Guid.createEmpty();\n /**\n * Required minimum capacity of Vessel in Litres\n * Not Negative\n */\n public capacityLitres: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.version = jsonSerializedObject.version;\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n this.vesselCapabilityId = Guid.fromString(jsonSerializedObject.vesselCapabilityId);\n this.capacityLitres = jsonSerializedObject.capacityLitres;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.version = this.version;\n toRet.processId = this.processId.toString();\n toRet.vesselCapabilityId = this.vesselCapabilityId.toString();\n toRet.capacityLitres = this.capacityLitres;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"ProcessVesselRequirement.Id cannot be empty\"},\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \"ProcessVesselRequirement.ProcessId cannot be empty\"},\n {field: \"vesselCapabilityId\", rule: (v: any) => !v.isEmpty() || \"ProcessVesselRequirement.VesselCapabilityId cannot be empty\"},\n ];\n}\n\n\nexport class ProcessProducedItemReadOnly extends ModelObject {\n\n /**\n * Timestamp at which the item produced line was created on the system. Captured by system not user editable.\n */\n public createdAt: Instant = Instant.ofEpochMilli(0);\n /**\n * Target Type this output went to. : 0 = Stock, 1 = ProcessSameBatch, 2 = ProcessOtherBatch\n */\n public targetType: EnumProcessOutputTarget = EnumProcessOutputTarget.stock;\n private _targetProcessId: Guid | null = null;\n /**\n * Id of Target Process if this output went to another process. Required if TargetType is ProcessSameBatch or ProcessOtherBatch.\n */\n public get targetProcessId(): Guid | null { return this._targetProcessId }\n public set targetProcessId(value: Guid | null) {\n this._targetProcessId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.createdAt = Instant.parse(jsonSerializedObject.createdAt);\n this.targetType = EnumProcessOutputTarget.getByValue(jsonSerializedObject.targetType, this.targetType);\n this.targetProcessId = jsonSerializedObject.targetProcessId == null ? null : Guid.fromString(jsonSerializedObject.targetProcessId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.createdAt = this.createdAt.toString();\n toRet.targetType = this.targetType.value;\n toRet.targetProcessId = this.targetProcessId == null ? null : this.targetProcessId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"targetProcessId\", rule: (v: any) => v == null || !v.isEmpty() || \"ProcessProducedItemReadOnly.TargetProcessId cannot be empty\"},\n ];\n}\n\n\nexport class ProcessProducedItem extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Process Id\n */\n public processId: Guid = Guid.createEmpty();\n /**\n * Stock item Id. All lines in one assembly must be for the same stock item.\n */\n public stockItemId: Guid = Guid.createEmpty();\n /**\n * Quantity Produced. A -ve value can act as a correction to a previous entry.\n */\n public quantityProduced: number = 0;\n /**\n * Unit of Measure\n */\n public unitOfMeasureId: Guid = Guid.createEmpty();\n /**\n * Whether this output was a by-product of the process rather than the main output item.\n */\n public isByProduct: boolean = false;\n /**\n * Unit cost price of the produced item.\n */\n public unitCostPrice: number = 0;\n public readOnly: ProcessProducedItemReadOnly = new ProcessProducedItemReadOnly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.quantityProduced = jsonSerializedObject.quantityProduced;\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n this.isByProduct = jsonSerializedObject.isByProduct;\n this.unitCostPrice = jsonSerializedObject.unitCostPrice;\n this.readOnly = new ProcessProducedItemReadOnly(jsonSerializedObject.readOnly);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.processId = this.processId.toString();\n toRet.stockItemId = this.stockItemId.toString();\n toRet.quantityProduced = this.quantityProduced;\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n toRet.isByProduct = this.isByProduct;\n toRet.unitCostPrice = this.unitCostPrice;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"ProcessProducedItem.Id cannot be empty\"},\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \"ProcessProducedItem.ProcessId cannot be empty\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"ProcessProducedItem.StockItemId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"ProcessProducedItem.UnitOfMeasureId cannot be empty\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class ProcessIngredientLineReadOnly extends ModelObject {\n\n private _quantityExpectedAtStart: number | null = null;\n /**\n * Quantity expected to be used as captured at the time the process was started (null if not started).\n */\n public get quantityExpectedAtStart(): number | null { return this._quantityExpectedAtStart }\n public set quantityExpectedAtStart(value: number | null) {\n this._quantityExpectedAtStart = value === undefined ? null : value;\n }\n private _totalCostExpectedAtStart: number | null = null;\n /**\n * Total cost of ingredient expected as captured at the time the process was started. (Quantity * StockItem Cost Price at time of start). (null if not started).\n */\n public get totalCostExpectedAtStart(): number | null { return this._totalCostExpectedAtStart }\n public set totalCostExpectedAtStart(value: number | null) {\n this._totalCostExpectedAtStart = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.quantityExpectedAtStart = jsonSerializedObject.quantityExpectedAtStart == null ? null : jsonSerializedObject.quantityExpectedAtStart;\n this.totalCostExpectedAtStart = jsonSerializedObject.totalCostExpectedAtStart == null ? null : jsonSerializedObject.totalCostExpectedAtStart;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.quantityExpectedAtStart = this.quantityExpectedAtStart == null ? null : this.quantityExpectedAtStart;\n toRet.totalCostExpectedAtStart = this.totalCostExpectedAtStart == null ? null : this.totalCostExpectedAtStart;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class ProcessIngredientLine extends BaseModelObject {\n\n public id: Guid = Guid.createEmpty();\n public version: number = 0;\n /**\n * Parent Process Id, can not be changed after creation of the ingredient line.\n */\n public processId: Guid = Guid.createEmpty();\n /**\n * Sequence (for ordering Lines).\n */\n public sequence: number = 0;\n /**\n * Quantity Still expected to be used.\n */\n public quantityStillExpected: number = 0;\n /**\n * Ingredient stock item, can not be changed if any ingredient used lines exist.\n */\n public stockItemId: Guid = Guid.createEmpty();\n /**\n * Unit of Measure\n */\n public unitOfMeasureId: Guid = Guid.createEmpty();\n /**\n * Whether this ingredient is fixed to its current quantity regardless of adjustments to process output.If set to true, the ingredient required quantity will not be multiplied when adjusting planned process output quantities.\n */\n public fixedQuantity: boolean = false;\n /**\n * Notes.\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n /**\n * Enables hop alpha scaling for this ingredient if the item and stock batch have hop alpha values.\n */\n public allowsHopAlpha: boolean = false;\n public readOnly: ProcessIngredientLineReadOnly = new ProcessIngredientLineReadOnly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.version = jsonSerializedObject.version;\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n this.sequence = jsonSerializedObject.sequence;\n this.quantityStillExpected = jsonSerializedObject.quantityStillExpected;\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n this.fixedQuantity = jsonSerializedObject.fixedQuantity;\n this.notes = jsonSerializedObject.notes;\n this.allowsHopAlpha = jsonSerializedObject.allowsHopAlpha;\n this.readOnly = new ProcessIngredientLineReadOnly(jsonSerializedObject.readOnly);\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.version = this.version;\n toRet.processId = this.processId.toString();\n toRet.sequence = this.sequence;\n toRet.quantityStillExpected = this.quantityStillExpected;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n toRet.fixedQuantity = this.fixedQuantity;\n toRet.notes = this.notes;\n toRet.allowsHopAlpha = this.allowsHopAlpha;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"ProcessIngredientLine.Id cannot be empty\"},\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \"ProcessIngredientLine.ProcessId cannot be empty\"},\n {field: \"sequence\", rule: (v: any) => v == null || v >= -2147483648 || \"Sequence is not greater than minimum allowed value: -2147483648\"},\n {field: \"sequence\", rule: (v: any) => v == null || v <= 2147483647 || \"Sequence is above maximum allowed value: 2147483647\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"ProcessIngredientLine.StockItemId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"ProcessIngredientLine.UnitOfMeasureId cannot be empty\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class ProcessIngredientUsedLineReadOnly extends ModelObject {\n\n /**\n * Timestamp at which the ingredient used line was created on the system. Captured by system not user editable.\n */\n public createdAt: Instant = Instant.ofEpochMilli(0);\n private _sourceProcessId: Guid | null = null;\n /**\n * Id of Source Process if this ingredient came from another process. Required if SourceType is ProcessSameBatch or ProcessOtherBatch.\n */\n public get sourceProcessId(): Guid | null { return this._sourceProcessId }\n public set sourceProcessId(value: Guid | null) {\n this._sourceProcessId = value === undefined ? null : value;\n }\n /**\n * Source Type this ingredient came from. : 0 = Stock, 1 = ProcessSameBatch, 2 = ProcessOtherBatch\n */\n public sourceType: EnumProcessIngredientSource = EnumProcessIngredientSource.stock;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.createdAt = Instant.parse(jsonSerializedObject.createdAt);\n this.sourceProcessId = jsonSerializedObject.sourceProcessId == null ? null : Guid.fromString(jsonSerializedObject.sourceProcessId);\n this.sourceType = EnumProcessIngredientSource.getByValue(jsonSerializedObject.sourceType, this.sourceType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.createdAt = this.createdAt.toString();\n toRet.sourceProcessId = this.sourceProcessId == null ? null : this.sourceProcessId.toString();\n toRet.sourceType = this.sourceType.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"sourceProcessId\", rule: (v: any) => v == null || !v.isEmpty() || \"ProcessIngredientUsedLineReadOnly.SourceProcessId cannot be empty\"},\n ];\n}\n\n\nexport class ProcessIngredientUsedLine extends BaseModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Parent Ingredient Line Id, can not be changed after creation of ingredient used line.\n */\n public processIngredientLineId: Guid = Guid.createEmpty();\n /**\n * Cannot be changed after creation of ingredient used line.\n */\n public quantityUsed: number = 0;\n /**\n * Total cost of ingredients used in this line.\n */\n public totalCost: number = 0;\n /**\n * True if the cost is now known, False if it may be updated automatically, due to completion of the source batch.\n */\n public isCostFinalised: boolean = false;\n /**\n * Must match the ingredient line item unit of measure.\n */\n public unitOfMeasureId: Guid = Guid.createEmpty();\n /**\n * Cannot be changed after creation of ingredient used line.\n * Not Nullable\n * Max Length : 1000\n */\n public urn: string = \"\";\n public readOnly: ProcessIngredientUsedLineReadOnly = new ProcessIngredientUsedLineReadOnly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.processIngredientLineId = Guid.fromString(jsonSerializedObject.processIngredientLineId);\n this.quantityUsed = jsonSerializedObject.quantityUsed;\n this.totalCost = jsonSerializedObject.totalCost;\n this.isCostFinalised = jsonSerializedObject.isCostFinalised;\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n this.urn = jsonSerializedObject.urn;\n this.readOnly = new ProcessIngredientUsedLineReadOnly(jsonSerializedObject.readOnly);\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.processIngredientLineId = this.processIngredientLineId.toString();\n toRet.quantityUsed = this.quantityUsed;\n toRet.totalCost = this.totalCost;\n toRet.isCostFinalised = this.isCostFinalised;\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n toRet.urn = this.urn;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"ProcessIngredientUsedLine.Id cannot be empty\"},\n {field: \"processIngredientLineId\", rule: (v: any) => !v.isEmpty() || \"ProcessIngredientUsedLine.ProcessIngredientLineId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"ProcessIngredientUsedLine.UnitOfMeasureId cannot be empty\"},\n {field: \"urn\", rule: (v: any) => v == null || v.length <= 1000 || \"Urn has too many characters (1000)\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class ProcessIngredient extends ModelObject {\n\n public line: ProcessIngredientLine = new ProcessIngredientLine();\n public usedLines: ProcessIngredientUsedLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.line = new ProcessIngredientLine(jsonSerializedObject.line);\n this.usedLines = jsonSerializedObject.usedLines.map((v: any) => new ProcessIngredientUsedLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.line = this.line.toJsonSerializedObject();\n toRet.usedLines = this.usedLines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"line\", rule: (v: any) => !!v || \"line is required\"},\n {field: \"line\", rule: (v: any) => v.validate()},\n {field: \"usedLines\", rule: (v: any) => !!v || \"usedLines is required\"},\n {field: \"usedLines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessIngredientUsedLine[]).reduce((acc: Array, curr: ProcessIngredientUsedLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class Process extends ModelObject {\n\n public header: ProcessHeader = new ProcessHeader();\n public instructions: ProcessInstruction[] = [];\n public prerequisites: Guid[] = [];\n public vesselRequirements: ProcessVesselRequirement[] = [];\n public producedItems: ProcessProducedItem[] = [];\n public ingredients: ProcessIngredient[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.header = new ProcessHeader(jsonSerializedObject.header);\n this.instructions = jsonSerializedObject.instructions.map((v: any) => new ProcessInstruction(v));\n this.prerequisites = jsonSerializedObject.prerequisites.map((v: any) => Guid.fromString(v));\n this.vesselRequirements = jsonSerializedObject.vesselRequirements.map((v: any) => new ProcessVesselRequirement(v));\n this.producedItems = jsonSerializedObject.producedItems.map((v: any) => new ProcessProducedItem(v));\n this.ingredients = jsonSerializedObject.ingredients.map((v: any) => new ProcessIngredient(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.header = this.header.toJsonSerializedObject();\n toRet.instructions = this.instructions.map(v => v.toJsonSerializedObject());\n toRet.prerequisites = this.prerequisites.map(v => v.toString());\n toRet.vesselRequirements = this.vesselRequirements.map(v => v.toJsonSerializedObject());\n toRet.producedItems = this.producedItems.map(v => v.toJsonSerializedObject());\n toRet.ingredients = this.ingredients.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n {field: \"instructions\", rule: (v: any) => !!v || \"instructions is required\"},\n {field: \"instructions\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessInstruction[]).reduce((acc: Array, curr: ProcessInstruction) => acc.concat(curr.validate()), new Array());\n }},\n {field: \"vesselRequirements\", rule: (v: any) => !!v || \"vesselRequirements is required\"},\n {field: \"vesselRequirements\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessVesselRequirement[]).reduce((acc: Array, curr: ProcessVesselRequirement) => acc.concat(curr.validate()), new Array());\n }},\n {field: \"producedItems\", rule: (v: any) => !!v || \"producedItems is required\"},\n {field: \"producedItems\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessProducedItem[]).reduce((acc: Array, curr: ProcessProducedItem) => acc.concat(curr.validate()), new Array());\n }},\n {field: \"ingredients\", rule: (v: any) => !!v || \"ingredients is required\"},\n {field: \"ingredients\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessIngredient[]).reduce((acc: Array, curr: ProcessIngredient) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class Batch extends ModelObject {\n\n public header: BatchHeader = new BatchHeader();\n public processes: Process[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.header = new BatchHeader(jsonSerializedObject.header);\n this.processes = jsonSerializedObject.processes.map((v: any) => new Process(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.header = this.header.toJsonSerializedObject();\n toRet.processes = this.processes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n {field: \"processes\", rule: (v: any) => !!v || \"processes is required\"},\n {field: \"processes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Process[]).reduce((acc: Array, curr: Process) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class IngredientRecommendedBatch extends ModelObject {\n\n public ingredientLineId: Guid = Guid.createEmpty();\n public processId: Guid = Guid.createEmpty();\n public stockLocationId: Guid = Guid.createEmpty();\n public stockItemId: Guid = Guid.createEmpty();\n private _availableQuantity: number | null = null;\n public get availableQuantity(): number | null { return this._availableQuantity }\n public set availableQuantity(value: number | null) {\n this._availableQuantity = value === undefined ? null : value;\n }\n private _recommendedBatch: Guid | null = null;\n public get recommendedBatch(): Guid | null { return this._recommendedBatch }\n public set recommendedBatch(value: Guid | null) {\n this._recommendedBatch = value === undefined ? null : value;\n }\n public recommendedBatchUrn: string = \"\";\n private _recommendedBatchHopAlpha: number | null = null;\n public get recommendedBatchHopAlpha(): number | null { return this._recommendedBatchHopAlpha }\n public set recommendedBatchHopAlpha(value: number | null) {\n this._recommendedBatchHopAlpha = value === undefined ? null : value;\n }\n public recommendedQuantity: number = 0;\n public requiredQuantity: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.ingredientLineId = Guid.fromString(jsonSerializedObject.ingredientLineId);\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.availableQuantity = jsonSerializedObject.availableQuantity == null ? null : jsonSerializedObject.availableQuantity;\n this.recommendedBatch = jsonSerializedObject.recommendedBatch == null ? null : Guid.fromString(jsonSerializedObject.recommendedBatch);\n this.recommendedBatchUrn = jsonSerializedObject.recommendedBatchUrn;\n this.recommendedBatchHopAlpha = jsonSerializedObject.recommendedBatchHopAlpha == null ? null : jsonSerializedObject.recommendedBatchHopAlpha;\n this.recommendedQuantity = jsonSerializedObject.recommendedQuantity;\n this.requiredQuantity = jsonSerializedObject.requiredQuantity;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.ingredientLineId = this.ingredientLineId.toString();\n toRet.processId = this.processId.toString();\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.stockItemId = this.stockItemId.toString();\n toRet.availableQuantity = this.availableQuantity == null ? null : this.availableQuantity;\n toRet.recommendedBatch = this.recommendedBatch == null ? null : this.recommendedBatch.toString();\n toRet.recommendedBatchUrn = this.recommendedBatchUrn;\n toRet.recommendedBatchHopAlpha = this.recommendedBatchHopAlpha == null ? null : this.recommendedBatchHopAlpha;\n toRet.recommendedQuantity = this.recommendedQuantity;\n toRet.requiredQuantity = this.requiredQuantity;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"ingredientLineId\", rule: (v: any) => !v.isEmpty() || \"IngredientRecommendedBatch.IngredientLineId cannot be empty\"},\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \"IngredientRecommendedBatch.ProcessId cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \"IngredientRecommendedBatch.StockLocationId cannot be empty\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"IngredientRecommendedBatch.StockItemId cannot be empty\"},\n {field: \"recommendedBatch\", rule: (v: any) => v == null || !v.isEmpty() || \"IngredientRecommendedBatch.RecommendedBatch cannot be empty\"},\n ];\n}\n\n\nexport class SectionsControl extends ModelObject {\n\n public showDetailsRecordedSection: boolean = false;\n public showIngredientSection: boolean = false;\n public showProcessSection: boolean = false;\n public showQualityControlSection: boolean = false;\n public showVolumeVesselSection: boolean = false;\n public showOutputSection: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.showDetailsRecordedSection = jsonSerializedObject.showDetailsRecordedSection;\n this.showIngredientSection = jsonSerializedObject.showIngredientSection;\n this.showProcessSection = jsonSerializedObject.showProcessSection;\n this.showQualityControlSection = jsonSerializedObject.showQualityControlSection;\n this.showVolumeVesselSection = jsonSerializedObject.showVolumeVesselSection;\n this.showOutputSection = jsonSerializedObject.showOutputSection;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.showDetailsRecordedSection = this.showDetailsRecordedSection;\n toRet.showIngredientSection = this.showIngredientSection;\n toRet.showProcessSection = this.showProcessSection;\n toRet.showQualityControlSection = this.showQualityControlSection;\n toRet.showVolumeVesselSection = this.showVolumeVesselSection;\n toRet.showOutputSection = this.showOutputSection;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class ProcessCostSummary extends ModelObject {\n\n public processId: Guid = Guid.createEmpty();\n private _producedStockItemId: Guid | null = null;\n public get producedStockItemId(): Guid | null { return this._producedStockItemId }\n public set producedStockItemId(value: Guid | null) {\n this._producedStockItemId = value === undefined ? null : value;\n }\n public totalIngredientsCost: number = 0;\n /**\n * Total quantity of outputs to process of the same batch.\n */\n public outputQuantityStayingInBatch: number = 0;\n public outputQuantityToOtherBatch: number = 0;\n public outputQuantityToStock: number = 0;\n public batchWastageCostApportionedToProcess: number = 0;\n public calculatedPricePerUnitForOutputStayingInBatch: number = 0;\n public calculatedPricePerUnitForOutputLeavingBatch: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n this.producedStockItemId = jsonSerializedObject.producedStockItemId == null ? null : Guid.fromString(jsonSerializedObject.producedStockItemId);\n this.totalIngredientsCost = jsonSerializedObject.totalIngredientsCost;\n this.outputQuantityStayingInBatch = jsonSerializedObject.outputQuantityStayingInBatch;\n this.outputQuantityToOtherBatch = jsonSerializedObject.outputQuantityToOtherBatch;\n this.outputQuantityToStock = jsonSerializedObject.outputQuantityToStock;\n this.batchWastageCostApportionedToProcess = jsonSerializedObject.batchWastageCostApportionedToProcess;\n this.calculatedPricePerUnitForOutputStayingInBatch = jsonSerializedObject.calculatedPricePerUnitForOutputStayingInBatch;\n this.calculatedPricePerUnitForOutputLeavingBatch = jsonSerializedObject.calculatedPricePerUnitForOutputLeavingBatch;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.processId = this.processId.toString();\n toRet.producedStockItemId = this.producedStockItemId == null ? null : this.producedStockItemId.toString();\n toRet.totalIngredientsCost = this.totalIngredientsCost;\n toRet.outputQuantityStayingInBatch = this.outputQuantityStayingInBatch;\n toRet.outputQuantityToOtherBatch = this.outputQuantityToOtherBatch;\n toRet.outputQuantityToStock = this.outputQuantityToStock;\n toRet.batchWastageCostApportionedToProcess = this.batchWastageCostApportionedToProcess;\n toRet.calculatedPricePerUnitForOutputStayingInBatch = this.calculatedPricePerUnitForOutputStayingInBatch;\n toRet.calculatedPricePerUnitForOutputLeavingBatch = this.calculatedPricePerUnitForOutputLeavingBatch;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \"ProcessCostSummary.ProcessId cannot be empty\"},\n {field: \"producedStockItemId\", rule: (v: any) => v == null || !v.isEmpty() || \"ProcessCostSummary.ProducedStockItemId cannot be empty\"},\n ];\n}\n\n\nexport class BatchFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _statuses: EnumAssemblyStatus[] | null = null;\n /**\n * If provided only matching statuses are returned\n */\n public get statuses(): EnumAssemblyStatus[] | null { return this._statuses }\n public set statuses(value: EnumAssemblyStatus[] | null) {\n this._statuses = value === undefined ? null : value;\n }\n private _stockLocations: Guid[] | null = null;\n public get stockLocations(): Guid[] | null { return this._stockLocations }\n public set stockLocations(value: Guid[] | null) {\n this._stockLocations = value === undefined ? null : value;\n }\n /**\n * Yes = Hidden Only, No = Not Hidden Only, Either = Either\n */\n public hiddenOrNot: EnumYesNoEither = EnumYesNoEither.either;\n private _batchIds: Guid[] | null = null;\n public get batchIds(): Guid[] | null { return this._batchIds }\n public set batchIds(value: Guid[] | null) {\n this._batchIds = value === undefined ? null : value;\n }\n private _fromStartDateInclusive: LocalDate | null = null;\n /**\n * Minimum Start Date\n */\n public get fromStartDateInclusive(): LocalDate | null { return this._fromStartDateInclusive }\n public set fromStartDateInclusive(value: LocalDate | null) {\n this._fromStartDateInclusive = value === undefined ? null : value;\n }\n private _toStartDateInclusive: LocalDate | null = null;\n /**\n * Maximum Start Date\n */\n public get toStartDateInclusive(): LocalDate | null { return this._toStartDateInclusive }\n public set toStartDateInclusive(value: LocalDate | null) {\n this._toStartDateInclusive = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.statuses = jsonSerializedObject.statuses == null ? null : jsonSerializedObject.statuses.map((v: any) => EnumAssemblyStatus.getByValue(v));\n this.stockLocations = jsonSerializedObject.stockLocations == null ? null : jsonSerializedObject.stockLocations.map((v: any) => Guid.fromString(v));\n this.hiddenOrNot = EnumYesNoEither.getByValue(jsonSerializedObject.hiddenOrNot, this.hiddenOrNot);\n this.batchIds = jsonSerializedObject.batchIds == null ? null : jsonSerializedObject.batchIds.map((v: any) => Guid.fromString(v));\n this.fromStartDateInclusive = jsonSerializedObject.fromStartDateInclusive == null ? null : LocalDate.parse(jsonSerializedObject.fromStartDateInclusive);\n this.toStartDateInclusive = jsonSerializedObject.toStartDateInclusive == null ? null : LocalDate.parse(jsonSerializedObject.toStartDateInclusive);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.statuses = this.statuses == null ? null : this.statuses.map(v => v.value);\n toRet.stockLocations = this.stockLocations == null ? null : this.stockLocations.map(v => v.toString());\n toRet.hiddenOrNot = this.hiddenOrNot.value;\n toRet.batchIds = this.batchIds == null ? null : this.batchIds.map(v => v.toString());\n toRet.fromStartDateInclusive = this.fromStartDateInclusive == null ? null : this.fromStartDateInclusive.toString();\n toRet.toStartDateInclusive = this.toStartDateInclusive == null ? null : this.toStartDateInclusive.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class FilteredBatches extends ModelObject {\n\n public matchingCount: number = 0;\n public batches: Batch[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.batches = jsonSerializedObject.batches.map((v: any) => new Batch(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.batches = this.batches.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"batches\", rule: (v: any) => !!v || \"batches is required\"},\n {field: \"batches\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Batch[]).reduce((acc: Array, curr: Batch) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class BatchLiquidEvaluation extends ModelObject {\n\n public batchId: Guid = Guid.createEmpty();\n public stockLocationId: Guid = Guid.createEmpty();\n public heldAtStartOfPeriodLitres: number = 0;\n public heldAtEndOfPeriodLitres: number = 0;\n public producedLitres: number = 0;\n public reprocessedLitres: number = 0;\n public discardedLitres: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.batchId = Guid.fromString(jsonSerializedObject.batchId);\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.heldAtStartOfPeriodLitres = jsonSerializedObject.heldAtStartOfPeriodLitres;\n this.heldAtEndOfPeriodLitres = jsonSerializedObject.heldAtEndOfPeriodLitres;\n this.producedLitres = jsonSerializedObject.producedLitres;\n this.reprocessedLitres = jsonSerializedObject.reprocessedLitres;\n this.discardedLitres = jsonSerializedObject.discardedLitres;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.batchId = this.batchId.toString();\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.heldAtStartOfPeriodLitres = this.heldAtStartOfPeriodLitres;\n toRet.heldAtEndOfPeriodLitres = this.heldAtEndOfPeriodLitres;\n toRet.producedLitres = this.producedLitres;\n toRet.reprocessedLitres = this.reprocessedLitres;\n toRet.discardedLitres = this.discardedLitres;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"batchId\", rule: (v: any) => !v.isEmpty() || \"BatchLiquidEvaluation.BatchId cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \"BatchLiquidEvaluation.StockLocationId cannot be empty\"},\n ];\n}\n\n\nexport class FilteredBatchHeaders extends ModelObject {\n\n public matchingCount: number = 0;\n public batchHeaders: BatchHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.batchHeaders = jsonSerializedObject.batchHeaders.map((v: any) => new BatchHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.batchHeaders = this.batchHeaders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"batchHeaders\", rule: (v: any) => !!v || \"batchHeaders is required\"},\n {field: \"batchHeaders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as BatchHeader[]).reduce((acc: Array, curr: BatchHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class ProcessFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _fromStartDateInclusive: LocalDate | null = null;\n /**\n * Minimum Start Date\n */\n public get fromStartDateInclusive(): LocalDate | null { return this._fromStartDateInclusive }\n public set fromStartDateInclusive(value: LocalDate | null) {\n this._fromStartDateInclusive = value === undefined ? null : value;\n }\n private _toStartDateInclusive: LocalDate | null = null;\n /**\n * Maximum Start Date\n */\n public get toStartDateInclusive(): LocalDate | null { return this._toStartDateInclusive }\n public set toStartDateInclusive(value: LocalDate | null) {\n this._toStartDateInclusive = value === undefined ? null : value;\n }\n private _batchIds: Guid[] | null = null;\n public get batchIds(): Guid[] | null { return this._batchIds }\n public set batchIds(value: Guid[] | null) {\n this._batchIds = value === undefined ? null : value;\n }\n private _statuses: EnumAssemblyStatus[] | null = null;\n public get statuses(): EnumAssemblyStatus[] | null { return this._statuses }\n public set statuses(value: EnumAssemblyStatus[] | null) {\n this._statuses = value === undefined ? null : value;\n }\n private _processTypes: EnumAssemblyType[] | null = null;\n public get processTypes(): EnumAssemblyType[] | null { return this._processTypes }\n public set processTypes(value: EnumAssemblyType[] | null) {\n this._processTypes = value === undefined ? null : value;\n }\n public includeAdHocMaintenanceProcess: EnumYesNoEither = EnumYesNoEither.either;\n private _hasOutput: boolean | null = null;\n /**\n * Returns processes with an output\n */\n public get hasOutput(): boolean | null { return this._hasOutput }\n public set hasOutput(value: boolean | null) {\n this._hasOutput = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.fromStartDateInclusive = jsonSerializedObject.fromStartDateInclusive == null ? null : LocalDate.parse(jsonSerializedObject.fromStartDateInclusive);\n this.toStartDateInclusive = jsonSerializedObject.toStartDateInclusive == null ? null : LocalDate.parse(jsonSerializedObject.toStartDateInclusive);\n this.batchIds = jsonSerializedObject.batchIds == null ? null : jsonSerializedObject.batchIds.map((v: any) => Guid.fromString(v));\n this.statuses = jsonSerializedObject.statuses == null ? null : jsonSerializedObject.statuses.map((v: any) => EnumAssemblyStatus.getByValue(v));\n this.processTypes = jsonSerializedObject.processTypes == null ? null : jsonSerializedObject.processTypes.map((v: any) => EnumAssemblyType.getByValue(v));\n this.includeAdHocMaintenanceProcess = EnumYesNoEither.getByValue(jsonSerializedObject.includeAdHocMaintenanceProcess, this.includeAdHocMaintenanceProcess);\n this.hasOutput = jsonSerializedObject.hasOutput == null ? null : jsonSerializedObject.hasOutput;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.fromStartDateInclusive = this.fromStartDateInclusive == null ? null : this.fromStartDateInclusive.toString();\n toRet.toStartDateInclusive = this.toStartDateInclusive == null ? null : this.toStartDateInclusive.toString();\n toRet.batchIds = this.batchIds == null ? null : this.batchIds.map(v => v.toString());\n toRet.statuses = this.statuses == null ? null : this.statuses.map(v => v.value);\n toRet.processTypes = this.processTypes == null ? null : this.processTypes.map(v => v.value);\n toRet.includeAdHocMaintenanceProcess = this.includeAdHocMaintenanceProcess.value;\n toRet.hasOutput = this.hasOutput == null ? null : this.hasOutput;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class FilteredProcesses extends ModelObject {\n\n public matchingCount: number = 0;\n public processes: Process[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.processes = jsonSerializedObject.processes.map((v: any) => new Process(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.processes = this.processes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"processes\", rule: (v: any) => !!v || \"processes is required\"},\n {field: \"processes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Process[]).reduce((acc: Array, curr: Process) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class ProcessStockExpectationLine extends ModelObject {\n\n public processId: Guid = Guid.createEmpty();\n public status: EnumAssemblyStatus = EnumAssemblyStatus.open;\n public expectedCompletionDate: LocalDate = LocalDate.ofEpochDay(0);\n public stockLocationId: Guid = Guid.createEmpty();\n /**\n * Expected stock change. +ve means stock will increase.\n */\n public signedQuantity: number = 0;\n /**\n * Identifies if this is an expected ingredient (opposed to expected output). Explicit as sign of SignedQuantity may not correlate.\n */\n public isIngredient: boolean = false;\n public stockItemId: Guid = Guid.createEmpty();\n public unitOfMeasureId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n this.status = EnumAssemblyStatus.getByValue(jsonSerializedObject.status, this.status);\n this.expectedCompletionDate = LocalDate.parse(jsonSerializedObject.expectedCompletionDate);\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.signedQuantity = jsonSerializedObject.signedQuantity;\n this.isIngredient = jsonSerializedObject.isIngredient;\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.processId = this.processId.toString();\n toRet.status = this.status.value;\n toRet.expectedCompletionDate = this.expectedCompletionDate.toString();\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.signedQuantity = this.signedQuantity;\n toRet.isIngredient = this.isIngredient;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \"ProcessStockExpectationLine.ProcessId cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \"ProcessStockExpectationLine.StockLocationId cannot be empty\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"ProcessStockExpectationLine.StockItemId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"ProcessStockExpectationLine.UnitOfMeasureId cannot be empty\"},\n ];\n}\n\n\nexport class ProcessStockFilter extends ModelObject {\n\n public includeIngredientsUsedFromStock: boolean = false;\n public includeOutputsToStock: boolean = false;\n private _fromInstant: Instant | null = null;\n /**\n * Timestamp of when the ingredient is used or when process outputs to stock.\n */\n public get fromInstant(): Instant | null { return this._fromInstant }\n public set fromInstant(value: Instant | null) {\n this._fromInstant = value === undefined ? null : value;\n }\n private _beforeInstant: Instant | null = null;\n /**\n * Timestamp of when the ingredient is used or when process outputs to stock.\n */\n public get beforeInstant(): Instant | null { return this._beforeInstant }\n public set beforeInstant(value: Instant | null) {\n this._beforeInstant = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.includeIngredientsUsedFromStock = jsonSerializedObject.includeIngredientsUsedFromStock;\n this.includeOutputsToStock = jsonSerializedObject.includeOutputsToStock;\n this.fromInstant = jsonSerializedObject.fromInstant == null ? null : Instant.parse(jsonSerializedObject.fromInstant);\n this.beforeInstant = jsonSerializedObject.beforeInstant == null ? null : Instant.parse(jsonSerializedObject.beforeInstant);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.includeIngredientsUsedFromStock = this.includeIngredientsUsedFromStock;\n toRet.includeOutputsToStock = this.includeOutputsToStock;\n toRet.fromInstant = this.fromInstant == null ? null : this.fromInstant.toString();\n toRet.beforeInstant = this.beforeInstant == null ? null : this.beforeInstant.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class ProcessBlockingQcTest extends ModelObject {\n\n public processId: Guid = Guid.createEmpty();\n public qcTestId: Guid = Guid.createEmpty();\n public name: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n this.qcTestId = Guid.fromString(jsonSerializedObject.qcTestId);\n this.name = jsonSerializedObject.name;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.processId = this.processId.toString();\n toRet.qcTestId = this.qcTestId.toString();\n toRet.name = this.name;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \"ProcessBlockingQcTest.ProcessId cannot be empty\"},\n {field: \"qcTestId\", rule: (v: any) => !v.isEmpty() || \"ProcessBlockingQcTest.QcTestId cannot be empty\"},\n ];\n}\n\n\nexport class FilteredProcessHeaders extends ModelObject {\n\n public matchingCount: number = 0;\n public processHeaders: ProcessHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.processHeaders = jsonSerializedObject.processHeaders.map((v: any) => new ProcessHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.processHeaders = this.processHeaders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"processHeaders\", rule: (v: any) => !!v || \"processHeaders is required\"},\n {field: \"processHeaders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessHeader[]).reduce((acc: Array, curr: ProcessHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class ProcessPrerequisite extends ModelObject {\n\n /**\n * Id of the Process Header where this Prerequisite belongs to.\n */\n public processId: Guid = Guid.createEmpty();\n /**\n * Id of the Process Header that must be completed as a prerequisite before the current ProcessId.\n */\n public prerequisiteProcessId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n this.prerequisiteProcessId = Guid.fromString(jsonSerializedObject.prerequisiteProcessId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.processId = this.processId.toString();\n toRet.prerequisiteProcessId = this.prerequisiteProcessId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \"ProcessPrerequisite.ProcessId cannot be empty\"},\n {field: \"prerequisiteProcessId\", rule: (v: any) => !v.isEmpty() || \"ProcessPrerequisite.PrerequisiteProcessId cannot be empty\"},\n ];\n}\n\n\nexport class GetBatchRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public batchId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.batchId = Guid.fromString(jsonSerializedObject.batchId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.batchId = this.batchId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"batchId\", rule: (v: any) => !v.isEmpty() || \".BatchId cannot be empty\"},\n ];\n}\n\n\nexport class GetBatchResponse extends ModelObject {\n\n public batch: Batch = new Batch();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.batch = new Batch(jsonSerializedObject.batch);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.batch = this.batch.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"batch\", rule: (v: any) => !!v || \"batch is required\"},\n {field: \"batch\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetBatchesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public batchIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.batchIds = jsonSerializedObject.batchIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.batchIds = this.batchIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetBatchesResponse extends ModelObject {\n\n public batches: Batch[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.batches = jsonSerializedObject.batches.map((v: any) => new Batch(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.batches = this.batches.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"batches\", rule: (v: any) => !!v || \"batches is required\"},\n {field: \"batches\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Batch[]).reduce((acc: Array, curr: Batch) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetFilteredBatchesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: BatchFilter = new BatchFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new BatchFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetFilteredBatchesResponse extends ModelObject {\n\n public results: FilteredBatches = new FilteredBatches();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredBatches(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GenerateBatchControlSheetRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public documentFormat: EnumDocumentFileType = EnumDocumentFileType.pdf;\n private _documentTemplateId: Guid | null = null;\n public get documentTemplateId(): Guid | null { return this._documentTemplateId }\n public set documentTemplateId(value: Guid | null) {\n this._documentTemplateId = value === undefined ? null : value;\n }\n public batchId: Guid = Guid.createEmpty();\n public sectionsControl: SectionsControl = new SectionsControl();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.documentFormat = EnumDocumentFileType.getByValue(jsonSerializedObject.documentFormat, this.documentFormat);\n this.documentTemplateId = jsonSerializedObject.documentTemplateId == null ? null : Guid.fromString(jsonSerializedObject.documentTemplateId);\n this.batchId = Guid.fromString(jsonSerializedObject.batchId);\n this.sectionsControl = new SectionsControl(jsonSerializedObject.sectionsControl);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.documentFormat = this.documentFormat.value;\n toRet.documentTemplateId = this.documentTemplateId == null ? null : this.documentTemplateId.toString();\n toRet.batchId = this.batchId.toString();\n toRet.sectionsControl = this.sectionsControl.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"documentTemplateId\", rule: (v: any) => v == null || !v.isEmpty() || \".DocumentTemplateId cannot be empty\"},\n {field: \"batchId\", rule: (v: any) => !v.isEmpty() || \".BatchId cannot be empty\"},\n {field: \"sectionsControl\", rule: (v: any) => !!v || \"sectionsControl is required\"},\n {field: \"sectionsControl\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GenerateBatchControlSheetResponse extends ModelObject {\n\n public documentBytes: Uint8Array = new Uint8Array();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.documentBytes = converters.base64ToUint8Array(jsonSerializedObject.documentBytes);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.documentBytes = converters.uint8ArrayToBase64(this.documentBytes);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class MigrateAssembliesToMegaBatchesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetBatchCostSummaryRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public batchId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.batchId = Guid.fromString(jsonSerializedObject.batchId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.batchId = this.batchId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"batchId\", rule: (v: any) => !v.isEmpty() || \".BatchId cannot be empty\"},\n ];\n}\n\n\nexport class GetBatchCostSummaryResponse extends ModelObject {\n\n public batchCostSummary: ProcessCostSummary[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.batchCostSummary = jsonSerializedObject.batchCostSummary.map((v: any) => new ProcessCostSummary(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.batchCostSummary = this.batchCostSummary.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"batchCostSummary\", rule: (v: any) => !!v || \"batchCostSummary is required\"},\n {field: \"batchCostSummary\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessCostSummary[]).reduce((acc: Array, curr: ProcessCostSummary) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class EvaluateLiquidProductionRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public fromDate: LocalDate = LocalDate.ofEpochDay(0);\n public toDate: LocalDate = LocalDate.ofEpochDay(0);\n public alcoholTypes: readonly EnumAlcoholType[] = [];\n private _stockLocations: readonly Guid[] | null = null;\n public get stockLocations(): readonly Guid[] | null { return this._stockLocations }\n public set stockLocations(value: readonly Guid[] | null) {\n this._stockLocations = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.fromDate = LocalDate.parse(jsonSerializedObject.fromDate);\n this.toDate = LocalDate.parse(jsonSerializedObject.toDate);\n this.alcoholTypes = jsonSerializedObject.alcoholTypes.map((v: any) => EnumAlcoholType.getByValue(v));\n this.stockLocations = jsonSerializedObject.stockLocations == null ? null : jsonSerializedObject.stockLocations.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.fromDate = this.fromDate.toString();\n toRet.toDate = this.toDate.toString();\n toRet.alcoholTypes = this.alcoholTypes.map(v => v.value);\n toRet.stockLocations = this.stockLocations == null ? null : this.stockLocations.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class EvaluateLiquidProductionResponse extends ModelObject {\n\n public results: BatchLiquidEvaluation[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new BatchLiquidEvaluation(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as BatchLiquidEvaluation[]).reduce((acc: Array, curr: BatchLiquidEvaluation) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetBatchHeaderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public batchId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.batchId = Guid.fromString(jsonSerializedObject.batchId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.batchId = this.batchId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"batchId\", rule: (v: any) => !v.isEmpty() || \".BatchId cannot be empty\"},\n ];\n}\n\n\nexport class GetBatchHeaderResponse extends ModelObject {\n\n public batchHeader: BatchHeader = new BatchHeader();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.batchHeader = new BatchHeader(jsonSerializedObject.batchHeader);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.batchHeader = this.batchHeader.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"batchHeader\", rule: (v: any) => !!v || \"batchHeader is required\"},\n {field: \"batchHeader\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetBatchHeadersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public batchIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.batchIds = jsonSerializedObject.batchIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.batchIds = this.batchIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetBatchHeadersResponse extends ModelObject {\n\n public batchHeaders: BatchHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.batchHeaders = jsonSerializedObject.batchHeaders.map((v: any) => new BatchHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.batchHeaders = this.batchHeaders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"batchHeaders\", rule: (v: any) => !!v || \"batchHeaders is required\"},\n {field: \"batchHeaders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as BatchHeader[]).reduce((acc: Array, curr: BatchHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetFilteredBatchHeadersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: BatchFilter = new BatchFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new BatchFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetFilteredBatchHeadersResponse extends ModelObject {\n\n public results: FilteredBatchHeaders = new FilteredBatchHeaders();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredBatchHeaders(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetBatchIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public batchId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.batchId = Guid.fromString(jsonSerializedObject.batchId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.batchId = this.batchId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"batchId\", rule: (v: any) => !v.isEmpty() || \".BatchId cannot be empty\"},\n ];\n}\n\n\nexport class SaveBatchHeaderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public header: BatchHeader = new BatchHeader();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.header = new BatchHeader(jsonSerializedObject.header);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.header = this.header.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class CancelBatchRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public batchId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.batchId = Guid.fromString(jsonSerializedObject.batchId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.batchId = this.batchId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"batchId\", rule: (v: any) => !v.isEmpty() || \".BatchId cannot be empty\"},\n ];\n}\n\n\nexport class CompleteBatchRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public batchId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.batchId = Guid.fromString(jsonSerializedObject.batchId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.batchId = this.batchId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"batchId\", rule: (v: any) => !v.isEmpty() || \".BatchId cannot be empty\"},\n ];\n}\n\n\nexport class UncompleteBatchRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public batchId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.batchId = Guid.fromString(jsonSerializedObject.batchId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.batchId = this.batchId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"batchId\", rule: (v: any) => !v.isEmpty() || \".BatchId cannot be empty\"},\n ];\n}\n\n\nexport class StartBatchRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public batchId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.batchId = Guid.fromString(jsonSerializedObject.batchId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.batchId = this.batchId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"batchId\", rule: (v: any) => !v.isEmpty() || \".BatchId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllBatchHeadersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllBatchHeadersResponse extends ModelObject {\n\n public batchHeaders: BatchHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.batchHeaders = jsonSerializedObject.batchHeaders.map((v: any) => new BatchHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.batchHeaders = this.batchHeaders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"batchHeaders\", rule: (v: any) => !!v || \"batchHeaders is required\"},\n {field: \"batchHeaders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as BatchHeader[]).reduce((acc: Array, curr: BatchHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetProcessRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processId = this.processId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \".ProcessId cannot be empty\"},\n ];\n}\n\n\nexport class GetProcessResponse extends ModelObject {\n\n public process: Process = new Process();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.process = new Process(jsonSerializedObject.process);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.process = this.process.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"process\", rule: (v: any) => !!v || \"process is required\"},\n {field: \"process\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetProcessesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processIds = jsonSerializedObject.processIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processIds = this.processIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetProcessesResponse extends ModelObject {\n\n public processes: Process[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.processes = jsonSerializedObject.processes.map((v: any) => new Process(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.processes = this.processes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"processes\", rule: (v: any) => !!v || \"processes is required\"},\n {field: \"processes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Process[]).reduce((acc: Array, curr: Process) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetFilteredProcessesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: ProcessFilter = new ProcessFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new ProcessFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetFilteredProcessesResponse extends ModelObject {\n\n public results: FilteredProcesses = new FilteredProcesses();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredProcesses(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GenerateProcessControlSheetRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public documentFormat: EnumDocumentFileType = EnumDocumentFileType.pdf;\n private _documentTemplateId: Guid | null = null;\n public get documentTemplateId(): Guid | null { return this._documentTemplateId }\n public set documentTemplateId(value: Guid | null) {\n this._documentTemplateId = value === undefined ? null : value;\n }\n public processId: Guid = Guid.createEmpty();\n public sectionsControl: SectionsControl = new SectionsControl();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.documentFormat = EnumDocumentFileType.getByValue(jsonSerializedObject.documentFormat, this.documentFormat);\n this.documentTemplateId = jsonSerializedObject.documentTemplateId == null ? null : Guid.fromString(jsonSerializedObject.documentTemplateId);\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n this.sectionsControl = new SectionsControl(jsonSerializedObject.sectionsControl);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.documentFormat = this.documentFormat.value;\n toRet.documentTemplateId = this.documentTemplateId == null ? null : this.documentTemplateId.toString();\n toRet.processId = this.processId.toString();\n toRet.sectionsControl = this.sectionsControl.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"documentTemplateId\", rule: (v: any) => v == null || !v.isEmpty() || \".DocumentTemplateId cannot be empty\"},\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \".ProcessId cannot be empty\"},\n {field: \"sectionsControl\", rule: (v: any) => !!v || \"sectionsControl is required\"},\n {field: \"sectionsControl\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GenerateProcessControlSheetResponse extends ModelObject {\n\n public documentBytes: Uint8Array = new Uint8Array();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.documentBytes = converters.base64ToUint8Array(jsonSerializedObject.documentBytes);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.documentBytes = converters.uint8ArrayToBase64(this.documentBytes);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GetProcessStockExpectationsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n private _limitStockLocationIds: readonly Guid[] | null = null;\n public get limitStockLocationIds(): readonly Guid[] | null { return this._limitStockLocationIds }\n public set limitStockLocationIds(value: readonly Guid[] | null) {\n this._limitStockLocationIds = value === undefined ? null : value;\n }\n private _limitStockItemIds: readonly Guid[] | null = null;\n public get limitStockItemIds(): readonly Guid[] | null { return this._limitStockItemIds }\n public set limitStockItemIds(value: readonly Guid[] | null) {\n this._limitStockItemIds = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.limitStockLocationIds = jsonSerializedObject.limitStockLocationIds == null ? null : jsonSerializedObject.limitStockLocationIds.map((v: any) => Guid.fromString(v));\n this.limitStockItemIds = jsonSerializedObject.limitStockItemIds == null ? null : jsonSerializedObject.limitStockItemIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.limitStockLocationIds = this.limitStockLocationIds == null ? null : this.limitStockLocationIds.map(v => v.toString());\n toRet.limitStockItemIds = this.limitStockItemIds == null ? null : this.limitStockItemIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetProcessStockExpectationsResponse extends ModelObject {\n\n public results: ProcessStockExpectationLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new ProcessStockExpectationLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessStockExpectationLine[]).reduce((acc: Array, curr: ProcessStockExpectationLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetFilteredProcessesByStockFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: ProcessStockFilter = new ProcessStockFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new ProcessStockFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetFilteredProcessesByStockFilterResponse extends ModelObject {\n\n public processes: Process[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.processes = jsonSerializedObject.processes.map((v: any) => new Process(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.processes = this.processes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"processes\", rule: (v: any) => !!v || \"processes is required\"},\n {field: \"processes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Process[]).reduce((acc: Array, curr: Process) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllBlockingQcTestsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllBlockingQcTestsResponse extends ModelObject {\n\n public processBlockingQcTests: ProcessBlockingQcTest[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.processBlockingQcTests = jsonSerializedObject.processBlockingQcTests.map((v: any) => new ProcessBlockingQcTest(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.processBlockingQcTests = this.processBlockingQcTests.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"processBlockingQcTests\", rule: (v: any) => !!v || \"processBlockingQcTests is required\"},\n {field: \"processBlockingQcTests\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessBlockingQcTest[]).reduce((acc: Array, curr: ProcessBlockingQcTest) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetBlockingQcTestsForProcessesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processIds = jsonSerializedObject.processIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processIds = this.processIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetBlockingQcTestsForProcessesResponse extends ModelObject {\n\n public processBlockingQcTests: ProcessBlockingQcTest[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.processBlockingQcTests = jsonSerializedObject.processBlockingQcTests.map((v: any) => new ProcessBlockingQcTest(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.processBlockingQcTests = this.processBlockingQcTests.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"processBlockingQcTests\", rule: (v: any) => !!v || \"processBlockingQcTests is required\"},\n {field: \"processBlockingQcTests\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessBlockingQcTest[]).reduce((acc: Array, curr: ProcessBlockingQcTest) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetProcessHeaderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processId = this.processId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \".ProcessId cannot be empty\"},\n ];\n}\n\n\nexport class GetProcessHeaderResponse extends ModelObject {\n\n public processHeader: ProcessHeader = new ProcessHeader();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.processHeader = new ProcessHeader(jsonSerializedObject.processHeader);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.processHeader = this.processHeader.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"processHeader\", rule: (v: any) => !!v || \"processHeader is required\"},\n {field: \"processHeader\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetProcessHeadersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processIds = jsonSerializedObject.processIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processIds = this.processIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetProcessHeadersResponse extends ModelObject {\n\n public processHeaders: ProcessHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.processHeaders = jsonSerializedObject.processHeaders.map((v: any) => new ProcessHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.processHeaders = this.processHeaders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"processHeaders\", rule: (v: any) => !!v || \"processHeaders is required\"},\n {field: \"processHeaders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessHeader[]).reduce((acc: Array, curr: ProcessHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetFilteredProcessHeadersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: ProcessFilter = new ProcessFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new ProcessFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetFilteredProcessHeadersResponse extends ModelObject {\n\n public results: FilteredProcessHeaders = new FilteredProcessHeaders();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredProcessHeaders(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveProcessHeaderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public header: ProcessHeader = new ProcessHeader();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.header = new ProcessHeader(jsonSerializedObject.header);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.header = this.header.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class StartProcessRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processId = this.processId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \".ProcessId cannot be empty\"},\n ];\n}\n\n\nexport class CompleteProcessRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processId = this.processId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \".ProcessId cannot be empty\"},\n ];\n}\n\n\nexport class UncompleteProcessRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processId = this.processId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \".ProcessId cannot be empty\"},\n ];\n}\n\n\nexport class HardDeleteProcessRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processId = this.processId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \".ProcessId cannot be empty\"},\n ];\n}\n\n\nexport class SavePrintUpdatesForProcessRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processId: Guid = Guid.createEmpty();\n public hasPrintedLabels: boolean = false;\n private _bestBeforeDate: LocalDate | null = null;\n public get bestBeforeDate(): LocalDate | null { return this._bestBeforeDate }\n public set bestBeforeDate(value: LocalDate | null) {\n this._bestBeforeDate = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n this.hasPrintedLabels = jsonSerializedObject.hasPrintedLabels;\n this.bestBeforeDate = jsonSerializedObject.bestBeforeDate == null ? null : LocalDate.parse(jsonSerializedObject.bestBeforeDate);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processId = this.processId.toString();\n toRet.hasPrintedLabels = this.hasPrintedLabels;\n toRet.bestBeforeDate = this.bestBeforeDate == null ? null : this.bestBeforeDate.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \".ProcessId cannot be empty\"},\n ];\n}\n\n\nexport class StartProcessesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processIds = jsonSerializedObject.processIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processIds = this.processIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class SaveProcessInstructionRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processInstruction: ProcessInstruction = new ProcessInstruction();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processInstruction = new ProcessInstruction(jsonSerializedObject.processInstruction);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processInstruction = this.processInstruction.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"processInstruction\", rule: (v: any) => !!v || \"processInstruction is required\"},\n {field: \"processInstruction\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveProcessInstructionsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processInstructions: readonly ProcessInstruction[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processInstructions = jsonSerializedObject.processInstructions.map((v: any) => new ProcessInstruction(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processInstructions = this.processInstructions.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"processInstructions\", rule: (v: any) => !!v || \"processInstructions is required\"},\n {field: \"processInstructions\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessInstruction[]).reduce((acc: Array, curr: ProcessInstruction) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class HardDeleteProcessInstructionRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processInstructionId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processInstructionId = Guid.fromString(jsonSerializedObject.processInstructionId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processInstructionId = this.processInstructionId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"processInstructionId\", rule: (v: any) => !v.isEmpty() || \".ProcessInstructionId cannot be empty\"},\n ];\n}\n\n\nexport class GetProcessInstructionsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processInstructionIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processInstructionIds = jsonSerializedObject.processInstructionIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processInstructionIds = this.processInstructionIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetProcessInstructionsResponse extends ModelObject {\n\n public processInstructions: ProcessInstruction[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.processInstructions = jsonSerializedObject.processInstructions.map((v: any) => new ProcessInstruction(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.processInstructions = this.processInstructions.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"processInstructions\", rule: (v: any) => !!v || \"processInstructions is required\"},\n {field: \"processInstructions\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessInstruction[]).reduce((acc: Array, curr: ProcessInstruction) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllProcessInstructionsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllProcessInstructionsResponse extends ModelObject {\n\n public processInstructions: ProcessInstruction[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.processInstructions = jsonSerializedObject.processInstructions.map((v: any) => new ProcessInstruction(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.processInstructions = this.processInstructions.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"processInstructions\", rule: (v: any) => !!v || \"processInstructions is required\"},\n {field: \"processInstructions\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessInstruction[]).reduce((acc: Array, curr: ProcessInstruction) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveProcessIngredientLineRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public line: ProcessIngredientLine = new ProcessIngredientLine();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.line = new ProcessIngredientLine(jsonSerializedObject.line);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.line = this.line.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"line\", rule: (v: any) => !!v || \"line is required\"},\n {field: \"line\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveProcessIngredientLinesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public lines: readonly ProcessIngredientLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.lines = jsonSerializedObject.lines.map((v: any) => new ProcessIngredientLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessIngredientLine[]).reduce((acc: Array, curr: ProcessIngredientLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class HardDeleteProcessIngredientLinesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public lineIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.lineIds = jsonSerializedObject.lineIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.lineIds = this.lineIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class UseIngredientsFromStockRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public usedIngredients: readonly ProcessIngredientUsedLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.usedIngredients = jsonSerializedObject.usedIngredients.map((v: any) => new ProcessIngredientUsedLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.usedIngredients = this.usedIngredients.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"usedIngredients\", rule: (v: any) => !!v || \"usedIngredients is required\"},\n {field: \"usedIngredients\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessIngredientUsedLine[]).reduce((acc: Array, curr: ProcessIngredientUsedLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveProcessUsedIngredientLinesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public lines: readonly ProcessIngredientUsedLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.lines = jsonSerializedObject.lines.map((v: any) => new ProcessIngredientUsedLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessIngredientUsedLine[]).reduce((acc: Array, curr: ProcessIngredientUsedLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetRecommendedBatchesForProcessRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processId = this.processId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \".ProcessId cannot be empty\"},\n ];\n}\n\n\nexport class GetRecommendedBatchesForProcessResponse extends ModelObject {\n\n public recommendedBatches: IngredientRecommendedBatch[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.recommendedBatches = jsonSerializedObject.recommendedBatches.map((v: any) => new IngredientRecommendedBatch(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.recommendedBatches = this.recommendedBatches.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"recommendedBatches\", rule: (v: any) => !!v || \"recommendedBatches is required\"},\n {field: \"recommendedBatches\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as IngredientRecommendedBatch[]).reduce((acc: Array, curr: IngredientRecommendedBatch) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetRecommendedBatchesForPickingListRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetRecommendedBatchesForPickingListResponse extends ModelObject {\n\n public recommendedBatches: IngredientRecommendedBatch[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.recommendedBatches = jsonSerializedObject.recommendedBatches.map((v: any) => new IngredientRecommendedBatch(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.recommendedBatches = this.recommendedBatches.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"recommendedBatches\", rule: (v: any) => !!v || \"recommendedBatches is required\"},\n {field: \"recommendedBatches\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as IngredientRecommendedBatch[]).reduce((acc: Array, curr: IngredientRecommendedBatch) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetProcessIngredientsByProcessIdsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processIds = jsonSerializedObject.processIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processIds = this.processIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetProcessIngredientsByProcessIdsResponse extends ModelObject {\n\n public processIngredients: ProcessIngredient[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.processIngredients = jsonSerializedObject.processIngredients.map((v: any) => new ProcessIngredient(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.processIngredients = this.processIngredients.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"processIngredients\", rule: (v: any) => !!v || \"processIngredients is required\"},\n {field: \"processIngredients\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessIngredient[]).reduce((acc: Array, curr: ProcessIngredient) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class ProduceItemsToStockRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processId: Guid = Guid.createEmpty();\n public producedItems: readonly ProcessProducedItem[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n this.producedItems = jsonSerializedObject.producedItems.map((v: any) => new ProcessProducedItem(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processId = this.processId.toString();\n toRet.producedItems = this.producedItems.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \".ProcessId cannot be empty\"},\n {field: \"producedItems\", rule: (v: any) => !!v || \"producedItems is required\"},\n {field: \"producedItems\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessProducedItem[]).reduce((acc: Array, curr: ProcessProducedItem) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class ProduceItemToProcessRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public sourceProcessId: Guid = Guid.createEmpty();\n public targetProcessId: Guid = Guid.createEmpty();\n public targetType: EnumProcessOutputTarget = EnumProcessOutputTarget.stock;\n public producedItem: ProcessProducedItem = new ProcessProducedItem();\n public targetIngredientLineId: Guid = Guid.createEmpty();\n public urn: string = \"\";\n public sourceRemainingExpectedQuantity: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.sourceProcessId = Guid.fromString(jsonSerializedObject.sourceProcessId);\n this.targetProcessId = Guid.fromString(jsonSerializedObject.targetProcessId);\n this.targetType = EnumProcessOutputTarget.getByValue(jsonSerializedObject.targetType, this.targetType);\n this.producedItem = new ProcessProducedItem(jsonSerializedObject.producedItem);\n this.targetIngredientLineId = Guid.fromString(jsonSerializedObject.targetIngredientLineId);\n this.urn = jsonSerializedObject.urn;\n this.sourceRemainingExpectedQuantity = jsonSerializedObject.sourceRemainingExpectedQuantity;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.sourceProcessId = this.sourceProcessId.toString();\n toRet.targetProcessId = this.targetProcessId.toString();\n toRet.targetType = this.targetType.value;\n toRet.producedItem = this.producedItem.toJsonSerializedObject();\n toRet.targetIngredientLineId = this.targetIngredientLineId.toString();\n toRet.urn = this.urn;\n toRet.sourceRemainingExpectedQuantity = this.sourceRemainingExpectedQuantity;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"sourceProcessId\", rule: (v: any) => !v.isEmpty() || \".SourceProcessId cannot be empty\"},\n {field: \"targetProcessId\", rule: (v: any) => !v.isEmpty() || \".TargetProcessId cannot be empty\"},\n {field: \"producedItem\", rule: (v: any) => !!v || \"producedItem is required\"},\n {field: \"producedItem\", rule: (v: any) => v.validate()},\n {field: \"targetIngredientLineId\", rule: (v: any) => !v.isEmpty() || \".TargetIngredientLineId cannot be empty\"},\n ];\n}\n\n\nexport class GetProcessPrerequisitesByProcessIdsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processIds = jsonSerializedObject.processIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processIds = this.processIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetProcessPrerequisitesByProcessIdsResponse extends ModelObject {\n\n public prerequisites: ProcessPrerequisite[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.prerequisites = jsonSerializedObject.prerequisites.map((v: any) => new ProcessPrerequisite(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.prerequisites = this.prerequisites.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"prerequisites\", rule: (v: any) => !!v || \"prerequisites is required\"},\n {field: \"prerequisites\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProcessPrerequisite[]).reduce((acc: Array, curr: ProcessPrerequisite) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class UpdatePrerequisiteForProcessRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processHeaderId: Guid = Guid.createEmpty();\n public prerequisiteProcessIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processHeaderId = Guid.fromString(jsonSerializedObject.processHeaderId);\n this.prerequisiteProcessIds = jsonSerializedObject.prerequisiteProcessIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processHeaderId = this.processHeaderId.toString();\n toRet.prerequisiteProcessIds = this.prerequisiteProcessIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"processHeaderId\", rule: (v: any) => !v.isEmpty() || \".ProcessHeaderId cannot be empty\"},\n ];\n}\n\n\nexport class SaveProcessVesselRequirementRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public requirement: ProcessVesselRequirement = new ProcessVesselRequirement();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.requirement = new ProcessVesselRequirement(jsonSerializedObject.requirement);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.requirement = this.requirement.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"requirement\", rule: (v: any) => !!v || \"requirement is required\"},\n {field: \"requirement\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class HardDeleteProcessVesselRequirementRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public requirementId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.requirementId = Guid.fromString(jsonSerializedObject.requirementId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.requirementId = this.requirementId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"requirementId\", rule: (v: any) => !v.isEmpty() || \".RequirementId cannot be empty\"},\n ];\n}\n\n\nexport class BatchService extends ServiceBase {\n\n public async getBatch(tenantId: Guid, batchId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetBatchRequest();\n req.tenantId = tenantId;\n req.batchId = batchId;\n const extractor = (response:any) => new GetBatchResponse(response).batch;\n return this.makeJsonRequest(\"batch/v1/getBatch\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getBatches(tenantId: Guid, batchIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetBatchesRequest();\n req.tenantId = tenantId;\n req.batchIds = batchIds;\n const extractor = (response:any) => new GetBatchesResponse(response).batches;\n return this.makeJsonRequest(\"batch/v1/getBatches\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getFilteredBatches(tenantId: Guid, filter: BatchFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetFilteredBatchesRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetFilteredBatchesResponse(response).results;\n return this.makeJsonRequest(\"batch/v1/getFilteredBatches\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async generateBatchControlSheet(tenantId: Guid, documentFormat: EnumDocumentFileType, documentTemplateId: Guid | null, batchId: Guid, sectionsControl: SectionsControl, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GenerateBatchControlSheetRequest();\n req.tenantId = tenantId;\n req.documentFormat = documentFormat;\n req.documentTemplateId = documentTemplateId;\n req.batchId = batchId;\n req.sectionsControl = sectionsControl;\n const extractor = (response:any) => new GenerateBatchControlSheetResponse(response).documentBytes;\n return this.makeJsonRequest(\"batch/v1/generateBatchControlSheet\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async migrateAssembliesToMegaBatches(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new MigrateAssembliesToMegaBatchesRequest();\n req.tenantId = tenantId;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/migrateAssembliesToMegaBatches\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getBatchCostSummary(tenantId: Guid, batchId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetBatchCostSummaryRequest();\n req.tenantId = tenantId;\n req.batchId = batchId;\n const extractor = (response:any) => new GetBatchCostSummaryResponse(response).batchCostSummary;\n return this.makeJsonRequest(\"batch/v1/getBatchCostSummary\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async evaluateLiquidProduction(tenantId: Guid, fromDate: LocalDate, toDate: LocalDate, alcoholTypes: readonly EnumAlcoholType[], stockLocations: readonly Guid[] | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new EvaluateLiquidProductionRequest();\n req.tenantId = tenantId;\n req.fromDate = fromDate;\n req.toDate = toDate;\n req.alcoholTypes = alcoholTypes;\n req.stockLocations = stockLocations;\n const extractor = (response:any) => new EvaluateLiquidProductionResponse(response).results;\n return this.makeJsonRequest(\"batch/v1/evaluateLiquidProduction\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getBatchHeader(tenantId: Guid, batchId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetBatchHeaderRequest();\n req.tenantId = tenantId;\n req.batchId = batchId;\n const extractor = (response:any) => new GetBatchHeaderResponse(response).batchHeader;\n return this.makeJsonRequest(\"batch/v1/getBatchHeader\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getBatchHeaders(tenantId: Guid, batchIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetBatchHeadersRequest();\n req.tenantId = tenantId;\n req.batchIds = batchIds;\n const extractor = (response:any) => new GetBatchHeadersResponse(response).batchHeaders;\n return this.makeJsonRequest(\"batch/v1/getBatchHeaders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getFilteredBatchHeaders(tenantId: Guid, filter: BatchFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetFilteredBatchHeadersRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetFilteredBatchHeadersResponse(response).results;\n return this.makeJsonRequest(\"batch/v1/getFilteredBatchHeaders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setBatchIsHidden(tenantId: Guid, batchId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetBatchIsHiddenRequest();\n req.tenantId = tenantId;\n req.batchId = batchId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/setBatchIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveBatchHeader(tenantId: Guid, header: BatchHeader, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveBatchHeaderRequest();\n req.tenantId = tenantId;\n req.header = header;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/saveBatchHeader\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async cancelBatch(tenantId: Guid, batchId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CancelBatchRequest();\n req.tenantId = tenantId;\n req.batchId = batchId;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/cancelBatch\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async completeBatch(tenantId: Guid, batchId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CompleteBatchRequest();\n req.tenantId = tenantId;\n req.batchId = batchId;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/completeBatch\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async uncompleteBatch(tenantId: Guid, batchId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UncompleteBatchRequest();\n req.tenantId = tenantId;\n req.batchId = batchId;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/uncompleteBatch\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async startBatch(tenantId: Guid, batchId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new StartBatchRequest();\n req.tenantId = tenantId;\n req.batchId = batchId;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/startBatch\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllBatchHeaders(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllBatchHeadersRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllBatchHeadersResponse(response).batchHeaders;\n return this.makeJsonRequest(\"batch/v1/getAllBatchHeaders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getProcess(tenantId: Guid, processId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetProcessRequest();\n req.tenantId = tenantId;\n req.processId = processId;\n const extractor = (response:any) => new GetProcessResponse(response).process;\n return this.makeJsonRequest(\"batch/v1/getProcess\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getProcesses(tenantId: Guid, processIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetProcessesRequest();\n req.tenantId = tenantId;\n req.processIds = processIds;\n const extractor = (response:any) => new GetProcessesResponse(response).processes;\n return this.makeJsonRequest(\"batch/v1/getProcesses\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getFilteredProcesses(tenantId: Guid, filter: ProcessFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetFilteredProcessesRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetFilteredProcessesResponse(response).results;\n return this.makeJsonRequest(\"batch/v1/getFilteredProcesses\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async generateProcessControlSheet(tenantId: Guid, documentFormat: EnumDocumentFileType, documentTemplateId: Guid | null, processId: Guid, sectionsControl: SectionsControl, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GenerateProcessControlSheetRequest();\n req.tenantId = tenantId;\n req.documentFormat = documentFormat;\n req.documentTemplateId = documentTemplateId;\n req.processId = processId;\n req.sectionsControl = sectionsControl;\n const extractor = (response:any) => new GenerateProcessControlSheetResponse(response).documentBytes;\n return this.makeJsonRequest(\"batch/v1/generateProcessControlSheet\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getProcessStockExpectations(tenantId: Guid, limitStockLocationIds: readonly Guid[] | null, limitStockItemIds: readonly Guid[] | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetProcessStockExpectationsRequest();\n req.tenantId = tenantId;\n req.limitStockLocationIds = limitStockLocationIds;\n req.limitStockItemIds = limitStockItemIds;\n const extractor = (response:any) => new GetProcessStockExpectationsResponse(response).results;\n return this.makeJsonRequest(\"batch/v1/getProcessStockExpectations\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllBlockingQcTests(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllBlockingQcTestsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllBlockingQcTestsResponse(response).processBlockingQcTests;\n return this.makeJsonRequest(\"batch/v1/getAllBlockingQcTests\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getBlockingQcTestsForProcesses(tenantId: Guid, processIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetBlockingQcTestsForProcessesRequest();\n req.tenantId = tenantId;\n req.processIds = processIds;\n const extractor = (response:any) => new GetBlockingQcTestsForProcessesResponse(response).processBlockingQcTests;\n return this.makeJsonRequest(\"batch/v1/getBlockingQcTestsForProcesses\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getProcessHeader(tenantId: Guid, processId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetProcessHeaderRequest();\n req.tenantId = tenantId;\n req.processId = processId;\n const extractor = (response:any) => new GetProcessHeaderResponse(response).processHeader;\n return this.makeJsonRequest(\"batch/v1/getProcessHeader\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getProcessHeaders(tenantId: Guid, processIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetProcessHeadersRequest();\n req.tenantId = tenantId;\n req.processIds = processIds;\n const extractor = (response:any) => new GetProcessHeadersResponse(response).processHeaders;\n return this.makeJsonRequest(\"batch/v1/getProcessHeaders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getFilteredProcessHeaders(tenantId: Guid, filter: ProcessFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetFilteredProcessHeadersRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetFilteredProcessHeadersResponse(response).results;\n return this.makeJsonRequest(\"batch/v1/getFilteredProcessHeaders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveProcessHeader(tenantId: Guid, header: ProcessHeader, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveProcessHeaderRequest();\n req.tenantId = tenantId;\n req.header = header;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/saveProcessHeader\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async startProcess(tenantId: Guid, processId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new StartProcessRequest();\n req.tenantId = tenantId;\n req.processId = processId;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/startProcess\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async completeProcess(tenantId: Guid, processId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CompleteProcessRequest();\n req.tenantId = tenantId;\n req.processId = processId;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/completeProcess\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async uncompleteProcess(tenantId: Guid, processId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UncompleteProcessRequest();\n req.tenantId = tenantId;\n req.processId = processId;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/uncompleteProcess\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async hardDeleteProcess(tenantId: Guid, processId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new HardDeleteProcessRequest();\n req.tenantId = tenantId;\n req.processId = processId;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/hardDeleteProcess\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async savePrintUpdatesForProcess(tenantId: Guid, processId: Guid, hasPrintedLabels: boolean, bestBeforeDate: LocalDate | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SavePrintUpdatesForProcessRequest();\n req.tenantId = tenantId;\n req.processId = processId;\n req.hasPrintedLabels = hasPrintedLabels;\n req.bestBeforeDate = bestBeforeDate;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/savePrintUpdatesForProcess\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async startProcesses(tenantId: Guid, processIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new StartProcessesRequest();\n req.tenantId = tenantId;\n req.processIds = processIds;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/startProcesses\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveProcessInstruction(tenantId: Guid, processInstruction: ProcessInstruction, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveProcessInstructionRequest();\n req.tenantId = tenantId;\n req.processInstruction = processInstruction;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/saveProcessInstruction\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveProcessInstructions(tenantId: Guid, processInstructions: readonly ProcessInstruction[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveProcessInstructionsRequest();\n req.tenantId = tenantId;\n req.processInstructions = processInstructions;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/saveProcessInstructions\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async hardDeleteProcessInstruction(tenantId: Guid, processInstructionId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new HardDeleteProcessInstructionRequest();\n req.tenantId = tenantId;\n req.processInstructionId = processInstructionId;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/hardDeleteProcessInstruction\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getProcessInstructions(tenantId: Guid, processInstructionIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetProcessInstructionsRequest();\n req.tenantId = tenantId;\n req.processInstructionIds = processInstructionIds;\n const extractor = (response:any) => new GetProcessInstructionsResponse(response).processInstructions;\n return this.makeJsonRequest(\"batch/v1/getProcessInstructions\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllProcessInstructions(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllProcessInstructionsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllProcessInstructionsResponse(response).processInstructions;\n return this.makeJsonRequest(\"batch/v1/getAllProcessInstructions\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveProcessIngredientLine(tenantId: Guid, line: ProcessIngredientLine, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveProcessIngredientLineRequest();\n req.tenantId = tenantId;\n req.line = line;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/saveProcessIngredientLine\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveProcessIngredientLines(tenantId: Guid, lines: readonly ProcessIngredientLine[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveProcessIngredientLinesRequest();\n req.tenantId = tenantId;\n req.lines = lines;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/saveProcessIngredientLines\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async hardDeleteProcessIngredientLines(tenantId: Guid, lineIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new HardDeleteProcessIngredientLinesRequest();\n req.tenantId = tenantId;\n req.lineIds = lineIds;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/hardDeleteProcessIngredientLines\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async useIngredientsFromStock(tenantId: Guid, usedIngredients: readonly ProcessIngredientUsedLine[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UseIngredientsFromStockRequest();\n req.tenantId = tenantId;\n req.usedIngredients = usedIngredients;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/useIngredientsFromStock\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveProcessUsedIngredientLines(tenantId: Guid, lines: readonly ProcessIngredientUsedLine[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveProcessUsedIngredientLinesRequest();\n req.tenantId = tenantId;\n req.lines = lines;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/saveProcessUsedIngredientLines\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getRecommendedBatchesForProcess(tenantId: Guid, processId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetRecommendedBatchesForProcessRequest();\n req.tenantId = tenantId;\n req.processId = processId;\n const extractor = (response:any) => new GetRecommendedBatchesForProcessResponse(response).recommendedBatches;\n return this.makeJsonRequest(\"batch/v1/getRecommendedBatchesForProcess\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getRecommendedBatchesForPickingList(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetRecommendedBatchesForPickingListRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetRecommendedBatchesForPickingListResponse(response).recommendedBatches;\n return this.makeJsonRequest(\"batch/v1/getRecommendedBatchesForPickingList\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getProcessIngredientsByProcessIds(tenantId: Guid, processIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetProcessIngredientsByProcessIdsRequest();\n req.tenantId = tenantId;\n req.processIds = processIds;\n const extractor = (response:any) => new GetProcessIngredientsByProcessIdsResponse(response).processIngredients;\n return this.makeJsonRequest(\"batch/v1/getProcessIngredientsByProcessIds\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async produceItemsToStock(tenantId: Guid, processId: Guid, producedItems: readonly ProcessProducedItem[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new ProduceItemsToStockRequest();\n req.tenantId = tenantId;\n req.processId = processId;\n req.producedItems = producedItems;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/produceItemsToStock\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async produceItemToProcess(tenantId: Guid, sourceProcessId: Guid, targetProcessId: Guid, targetType: EnumProcessOutputTarget, producedItem: ProcessProducedItem, targetIngredientLineId: Guid, urn: string, sourceRemainingExpectedQuantity: number, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new ProduceItemToProcessRequest();\n req.tenantId = tenantId;\n req.sourceProcessId = sourceProcessId;\n req.targetProcessId = targetProcessId;\n req.targetType = targetType;\n req.producedItem = producedItem;\n req.targetIngredientLineId = targetIngredientLineId;\n req.urn = urn;\n req.sourceRemainingExpectedQuantity = sourceRemainingExpectedQuantity;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/produceItemToProcess\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getProcessPrerequisitesByProcessIds(tenantId: Guid, processIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetProcessPrerequisitesByProcessIdsRequest();\n req.tenantId = tenantId;\n req.processIds = processIds;\n const extractor = (response:any) => new GetProcessPrerequisitesByProcessIdsResponse(response).prerequisites;\n return this.makeJsonRequest(\"batch/v1/getProcessPrerequisitesByProcessIds\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updatePrerequisiteForProcess(tenantId: Guid, processHeaderId: Guid, prerequisiteProcessIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdatePrerequisiteForProcessRequest();\n req.tenantId = tenantId;\n req.processHeaderId = processHeaderId;\n req.prerequisiteProcessIds = prerequisiteProcessIds;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/updatePrerequisiteForProcess\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveProcessVesselRequirement(tenantId: Guid, requirement: ProcessVesselRequirement, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveProcessVesselRequirementRequest();\n req.tenantId = tenantId;\n req.requirement = requirement;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/saveProcessVesselRequirement\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async hardDeleteProcessVesselRequirement(tenantId: Guid, requirementId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new HardDeleteProcessVesselRequirementRequest();\n req.tenantId = tenantId;\n req.requirementId = requirementId;\n const extractor = null;\n return this.makeJsonRequest(\"batch/v1/hardDeleteProcessVesselRequirement\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const batchService = new BatchService();","import { MenuItem } from \"@/app/ui/navigation/types\";\nimport type Guid from \"@/app/types/common/guid\";\nimport type { Location } from \"vue-router\";\nimport tenantStore from \"@/store/modules/tenantStore\";\nimport { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { EnumFeatureFlag } from \"@/app/services/generated/enums/enumFeatureFlag.generated\";\nimport { hasFeatureUsingUserStore } from \"@/app/featureFlags\";\nimport { EnumAssemblyType } from \"@/app/services/generated/enums/enumAssemblyType.generated\";\n\nexport const batchMenu = {\n root: \"navigation_batch_group\",\n list: {\n view: \"batch_list\",\n plannedBatchesTab: \"planned_batches\",\n viewPlannedBatchesTab: (): Location => ({\n name: batchMenu.list.plannedBatchesTab,\n }),\n inProgressBatchesTab: \"in_progress_batches\",\n viewInProgressBatchesTab: (): Location => ({\n name: batchMenu.list.inProgressBatchesTab,\n }),\n completedBatchesTab: \"completed_batches\",\n viewCompletedBatchesTab: (): Location => ({\n name: batchMenu.list.completedBatchesTab,\n }),\n },\n batch: {\n view: \"batch_view\",\n viewBatch: (id: Guid): Location => ({\n name: batchMenu.batch.view,\n params: { id: id.toString() },\n }),\n createBatch: (): Location => ({\n name: batchMenu.batch.view,\n }),\n process: \"batch_process_view\",\n viewProcess: (id: Guid): Location => ({\n name: batchMenu.batch.process,\n params: { id: id.toString() },\n }),\n batchPerformance: \"batch_performance\",\n viewBatchPerformance: (id: Guid): Location => ({\n name: batchMenu.batch.batchPerformance,\n params: { id: id.toString() },\n }),\n processOverview: \"process_overview\",\n viewProcessOverview: (id: Guid): Location => ({\n name: batchMenu.batch.processOverview,\n params: { id: id.toString() },\n }),\n },\n listProcesses: \"list_processes\",\n recipe: {\n list: \"recipe_list\",\n view: \"recipe_view\",\n listRecipes: (): Location => ({\n name: batchMenu.recipe.list,\n }),\n viewRecipe: (id: Guid): Location => ({\n name: batchMenu.recipe.view,\n params: { id: id.toString() },\n }),\n batch_template_list: \"batch_template_list\",\n view_batch_template: \"view_batch_template\",\n listBatchTemplates: (): Location => ({\n name: batchMenu.recipe.batch_template_list,\n }),\n viewBatchTemplate: (id: Guid): Location => ({\n name: batchMenu.recipe.view_batch_template,\n params: { id: id.toString() },\n }),\n listIngredientsUsage: \"list_ingredients_usage\",\n },\n vesselScheduling: \"batch_vessel_scheduling\",\n viewVesselScheduling: (): Location => ({ name: batchMenu.vesselScheduling }),\n vesselSummary: \"batch_vessel_summary\",\n pickingList: \"batch_picking_list\",\n viewPickingList: (opts?: { processId?: Guid }): Location => ({\n name: batchMenu.pickingList,\n query: {\n processId: opts?.processId?.toString(),\n },\n }),\n agingCasks: {\n caskVessels: {\n list: \"batch_cask_vessels\",\n listLocation: (): Location => ({\n name: batchMenu.agingCasks.caskVessels.list,\n }),\n edit: \"batch_cask_vessels_edit\",\n editLocation: (id: Guid, isEditing: boolean): Location => ({\n name: batchMenu.agingCasks.caskVessels.edit,\n params: {\n id: id.toString(),\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n createLocation: (): Location => ({\n name: batchMenu.agingCasks.caskVessels.edit,\n }),\n },\n },\n batchGenealogy: \"batch_genealogy\",\n maintenance: {\n root: \"maintenance\",\n list_maintenance_recipe: \"list_maintenance_recipe\",\n view_maintenance_recipe: \"view_maintenance_recipe\",\n listMaintenanceRecipes: (): Location => ({\n name: batchMenu.maintenance.list_maintenance_recipe,\n }),\n viewMaintenanceRecipe: (id: Guid): Location => ({\n name: batchMenu.maintenance.view_maintenance_recipe,\n params: { id: id.toString() },\n }),\n vessel_records: \"vessel_records\",\n maintenance_schedule: \"maintenance_schedule\",\n },\n};\n\nexport const buildBatchMenuItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n name: batchMenu.root,\n icon: \"local_drink\",\n visible: () =>\n hasFeatureUsingUserStore(EnumFeatureFlag.onlyDev) ||\n tenantStore.state.tenantSettings.isMegaBatchesEnabled,\n subMenus: [\n MenuItem.fromOpts({\n name: batchMenu.vesselScheduling,\n url: \"/batch/vessel-scheduling\",\n view: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/batches/scheduling/VesselScheduling.vue\"\n ),\n requiredUserPermissions: [EnumUserPermission.vesselsView],\n }),\n MenuItem.fromOpts({\n name: batchMenu.vesselSummary,\n url: \"/batch/vessels\",\n view: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/batches/vesselSummary/VesselSummary.vue\"\n ),\n requiredUserPermissions: [EnumUserPermission.vesselsView],\n }),\n MenuItem.fromOpts({\n name: batchMenu.list.view,\n url: \"/batch/list\",\n view: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/batches/ListBatches.vue\"\n ),\n redirect: \"/batch/list/in-progress-batches\",\n requiredUserPermissions: [EnumUserPermission.batchesView],\n childRoutes: [\n {\n name: batchMenu.list.plannedBatchesTab,\n path: \"/batch/list/planned-batches\",\n component: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/batches/PlannedBatchesTab.vue\"\n ),\n },\n {\n name: batchMenu.list.inProgressBatchesTab,\n path: \"/batch/list/in-progress-batches\",\n component: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/batches/InProgressBatchesTab.vue\"\n ),\n },\n {\n name: batchMenu.list.completedBatchesTab,\n path: \"/batch/list/complete-batches\",\n component: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/batches/CompletedBatchesTab.vue\"\n ),\n },\n ],\n }),\n MenuItem.fromOpts({\n name: batchMenu.batch.view,\n url: \"/batch/view-batch/:id\",\n breadcrumbParentName: batchMenu.list.inProgressBatchesTab,\n view: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/batches/overview/ViewBatch.vue\"\n ),\n componentProps: (route) => ({\n id: route.params.id,\n }),\n visible: false,\n redirect: \"/batch/batch-performance/:id\",\n requiredUserPermissions: [EnumUserPermission.batchesView],\n childRoutes: [\n {\n name: batchMenu.batch.batchPerformance,\n path: \"/batch/batch-performance/:id\",\n component: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/batches/overview/BatchPerformance.vue\"\n ),\n props: (route) => ({\n id: route.params.id,\n }),\n },\n {\n name: batchMenu.batch.processOverview,\n path: \"/batch/process-overview/:id\",\n component: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/batches/overview/ProcessOverview.vue\"\n ),\n props: (route) => ({\n id: route.params.id,\n }),\n },\n ],\n }),\n MenuItem.fromOpts({\n name: batchMenu.batch.process,\n url: \"/batch/process/:id\",\n breadcrumbParentName: batchMenu.list.inProgressBatchesTab,\n view: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/batches/ViewProcess.vue\"\n ),\n componentProps: (route) => ({\n id: route.params.id,\n }),\n visible: false,\n requiredUserPermissions: [EnumUserPermission.batchesView],\n }),\n MenuItem.fromOpts({\n name: batchMenu.listProcesses,\n url: \"/batch/list-processes\",\n view: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/pages/production/ListProcessesPage.vue\"\n ),\n requiredUserPermissions: [EnumUserPermission.batchesView],\n }),\n MenuItem.fromOpts({\n name: batchMenu.recipe.batch_template_list,\n url: \"/batch/recipe/batch-template-list\",\n view: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/batches/batchTemplates/pages/BatchTemplateList.vue\"\n ),\n requiredUserPermissions: [EnumUserPermission.batchesView],\n }),\n MenuItem.fromOpts({\n name: batchMenu.recipe.view_batch_template,\n url: \"/batch/recipe/view-batch-template/:id\",\n breadcrumbParentName: batchMenu.recipe.batch_template_list,\n view: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/batches/batchTemplates/pages/ViewBatchTemplate.vue\"\n ),\n componentProps: (route) => ({\n id: route.params.id,\n }),\n visible: false,\n requiredUserPermissions: [EnumUserPermission.batchesView],\n }),\n MenuItem.fromOpts({\n name: batchMenu.recipe.list,\n url: \"/batch/recipe/list\",\n view: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/batches/recipes/ListRecipes.vue\"\n ),\n routeMetadata: {\n key: batchMenu.recipe.list,\n },\n componentProps: () => ({\n processTypes: [\n EnumAssemblyType.materialProduction,\n EnumAssemblyType.productPackaging,\n ],\n }),\n requiredUserPermissions: [EnumUserPermission.recipesView],\n }),\n MenuItem.fromOpts({\n name: batchMenu.recipe.view,\n url: \"/batch/recipe/view-recipe/:id\",\n breadcrumbParentName: batchMenu.recipe.list,\n view: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/batches/recipes/ViewRecipe.vue\"\n ),\n componentProps: (route) => ({\n id: route.params.id,\n }),\n visible: false,\n requiredUserPermissions: [EnumUserPermission.recipesView],\n }),\n MenuItem.fromOpts({\n name: batchMenu.recipe.listIngredientsUsage,\n url: \"/batch/recipe/list-ingredients-usage\",\n view: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/batches/recipes/ListRecipeIngredientsUsagePage.vue\"\n ),\n componentProps: () => ({\n processTypes: [\n EnumAssemblyType.materialProduction,\n EnumAssemblyType.productPackaging,\n ],\n }),\n requiredUserPermissions: [EnumUserPermission.recipesView],\n }),\n MenuItem.fromOpts({\n name: batchMenu.pickingList,\n url: \"/batch/batch-picking-list\",\n view: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/batches/pickingList/BatchPickingListPage.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: batchMenu.agingCasks.caskVessels.list,\n url: \"/batch/cask-vessels/view\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/production/caskVessels/ListCaskVessels.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: batchMenu.agingCasks.caskVessels.edit,\n url: \"/batch/cask-vessel/:id?/:mode?\",\n breadcrumbParentName: batchMenu.agingCasks.caskVessels.list,\n view: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/production/caskVessels/EditCaskVessel.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: batchMenu.batchGenealogy,\n url: \"/batch/batch-genealogy/view\",\n view: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/production/genealogy/BatchGenealogy.vue\"\n ),\n }),\n MenuItem.forBranch({\n name: batchMenu.maintenance.root,\n subMenus: [\n MenuItem.fromOpts({\n name: batchMenu.maintenance.list_maintenance_recipe,\n url: \"/batch/maintenance/list-maintenance-recipe\",\n view: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/batches/recipes/ListRecipes.vue\"\n ),\n routeMetadata: {\n key: batchMenu.maintenance.list_maintenance_recipe,\n },\n componentProps: () => ({\n processTypes: [EnumAssemblyType.maintenance],\n }),\n requiredUserPermissions: [EnumUserPermission.recipesView],\n }),\n MenuItem.fromOpts({\n name: batchMenu.maintenance.view_maintenance_recipe,\n url: \"/batch/maintenance/view-maintenance-recipe/:id\",\n breadcrumbParentName: batchMenu.maintenance.list_maintenance_recipe,\n view: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/batches/recipes/ViewRecipe.vue\"\n ),\n componentProps: (route) => ({\n id: route.params.id,\n }),\n visible: false,\n requiredUserPermissions: [EnumUserPermission.recipesView],\n }),\n MenuItem.fromOpts({\n name: batchMenu.maintenance.vessel_records,\n url: \"/production/vessels/records\",\n view: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/production/vessels/VesselRecord.vue\"\n ),\n requiredUserPermissions: [EnumUserPermission.vesselsView],\n }),\n MenuItem.fromOpts({\n name: batchMenu.maintenance.maintenance_schedule,\n url: \"/batch/maintenance/maintenance-schedule\",\n view: () =>\n import(\n /* webpackChunkName: \"batch\" */ \"@/components/pages/batches/maintenance/ListMaintenanceSchedulePage.vue\"\n ),\n requiredUserPermissions: [EnumUserPermission.vesselsView],\n }),\n ],\n }),\n ],\n }),\n];\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumEmailDocumentGrouping } from \"./enums/enumEmailDocumentGrouping.generated\";\n\n// Model Objects\n\nexport class GroupReadOnly extends ModelObject {\n\n /**\n * Outlet Group Code\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public code: string = \"\";\n private _mainLatitude: number | null = null;\n /**\n * Latitude\n */\n public get mainLatitude(): number | null { return this._mainLatitude }\n public set mainLatitude(value: number | null) {\n this._mainLatitude = value === undefined ? null : value;\n }\n private _mainLongitude: number | null = null;\n /**\n * Longitude\n */\n public get mainLongitude(): number | null { return this._mainLongitude }\n public set mainLongitude(value: number | null) {\n this._mainLongitude = value === undefined ? null : value;\n }\n private _placedOnHoldAt: Instant | null = null;\n /**\n * The time when Group was set as On Hold\n */\n public get placedOnHoldAt(): Instant | null { return this._placedOnHoldAt }\n public set placedOnHoldAt(value: Instant | null) {\n this._placedOnHoldAt = value === undefined ? null : value;\n }\n private _placedOnHoldByUserId: Guid | null = null;\n /**\n * User who set this Group as On Hold\n */\n public get placedOnHoldByUserId(): Guid | null { return this._placedOnHoldByUserId }\n public set placedOnHoldByUserId(value: Guid | null) {\n this._placedOnHoldByUserId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.code = jsonSerializedObject.code;\n this.mainLatitude = jsonSerializedObject.mainLatitude == null ? null : jsonSerializedObject.mainLatitude;\n this.mainLongitude = jsonSerializedObject.mainLongitude == null ? null : jsonSerializedObject.mainLongitude;\n this.placedOnHoldAt = jsonSerializedObject.placedOnHoldAt == null ? null : Instant.parse(jsonSerializedObject.placedOnHoldAt);\n this.placedOnHoldByUserId = jsonSerializedObject.placedOnHoldByUserId == null ? null : Guid.fromString(jsonSerializedObject.placedOnHoldByUserId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.code = this.code;\n toRet.mainLatitude = this.mainLatitude == null ? null : this.mainLatitude;\n toRet.mainLongitude = this.mainLongitude == null ? null : this.mainLongitude;\n toRet.placedOnHoldAt = this.placedOnHoldAt == null ? null : this.placedOnHoldAt.toString();\n toRet.placedOnHoldByUserId = this.placedOnHoldByUserId == null ? null : this.placedOnHoldByUserId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"code\", rule: (v: any) => v == null || v.length !== 0 || \"Code cannot be empty\"},\n {field: \"code\", rule: (v: any) => v == null || v.length <= 1000 || \"Code has too many characters (1000)\"},\n {field: \"placedOnHoldByUserId\", rule: (v: any) => v == null || !v.isEmpty() || \"GroupReadOnly.PlacedOnHoldByUserId cannot be empty\"},\n ];\n}\n\n\nexport class Group extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n public isHidden: boolean = false;\n /**\n * Group Name\n * Not Nullable\n * Max Length : 1000\n */\n public name: string = \"\";\n /**\n * Telephone number\n * Not Nullable\n * Max Length : 1000\n */\n public telephoneNumber: string = \"\";\n /**\n * Email Address\n * Not Nullable\n * Max Length : 1000\n */\n public emailAddress: string = \"\";\n /**\n * Main Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressLine1: string = \"\";\n /**\n * Main Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressLine2: string = \"\";\n /**\n * Main Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressLine3: string = \"\";\n /**\n * Main Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressLine4: string = \"\";\n /**\n * Main Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressLine5: string = \"\";\n /**\n * Main Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressLine6: string = \"\";\n /**\n * Main Address\n * Not Nullable\n * Max Length : 1000\n */\n public mainAddressPostcode: string = \"\";\n /**\n * VAT Registration No.\n * Not Nullable\n * Max Length : 1000\n */\n public vatNumber: string = \"\";\n /**\n * Bank Name\n * Not Nullable\n * Max Length : 1000\n */\n public bankName: string = \"\";\n /**\n * Bank Account No\n * Not Nullable\n * Max Length : 1000\n */\n public bankAccountNumber: string = \"\";\n /**\n * Bank Sort Code\n * Not Nullable\n * Max Length : 1000\n */\n public bankSortCode: string = \"\";\n /**\n * Send Invoices to the outlet rather than the group\n */\n public sendInvoiceToOutlet: boolean = false;\n /**\n * Email Invoices\n */\n public emailInvoices: boolean = false;\n /**\n * Email Address that receives invoices\n * Not Nullable\n * Max Length : 1000\n */\n public invoiceEmailAddress: string = \"\";\n private _defaultInvoiceTemplateId: Guid | null = null;\n /**\n * Default Invoice Template Id\n */\n public get defaultInvoiceTemplateId(): Guid | null { return this._defaultInvoiceTemplateId }\n public set defaultInvoiceTemplateId(value: Guid | null) {\n this._defaultInvoiceTemplateId = value === undefined ? null : value;\n }\n private _invoiceDataExchangeTemplateId: Guid | null = null;\n /**\n * On optional invoice data exchange template that can be used to send a list of invoices to the group\n */\n public get invoiceDataExchangeTemplateId(): Guid | null { return this._invoiceDataExchangeTemplateId }\n public set invoiceDataExchangeTemplateId(value: Guid | null) {\n this._invoiceDataExchangeTemplateId = value === undefined ? null : value;\n }\n public readOnly: GroupReadOnly = new GroupReadOnly();\n /**\n * The number of invoice copies to print. (Not used if SendInvoiceToOutlet is true).\n * Not Negative\n */\n public invoiceCopiesToPrint: number = 0;\n private _deliveryServiceId: Guid | null = null;\n /**\n * Delivery Service, if any, to apply by default to orders for outlets in this group. May be overriden by outlet setting, but will have priority over courier / delivery area settings.\n */\n public get deliveryServiceId(): Guid | null { return this._deliveryServiceId }\n public set deliveryServiceId(value: Guid | null) {\n this._deliveryServiceId = value === undefined ? null : value;\n }\n /**\n * Accounts Department No (1-999)\n */\n public accountsDepartmentNumber: number = 0;\n /**\n * Identifies how multiple documents are grouped into pdfs and emails when many documents are emailed at the same time.\n */\n public emailDocumentGrouping: EnumEmailDocumentGrouping = EnumEmailDocumentGrouping.unknown;\n /**\n * If true, then this Group's sales code applies to all outlets in the group.\n */\n public useGroupSalesCodeForAllOutlets: boolean = false;\n private _salesCodeId: Guid | null = null;\n /**\n * Sales Code Id. if UseGroupSalesCodeForAllOutlets is true then this applies to all outlets in group.\n */\n public get salesCodeId(): Guid | null { return this._salesCodeId }\n public set salesCodeId(value: Guid | null) {\n this._salesCodeId = value === undefined ? null : value;\n }\n /**\n * Tax number for posting to accounts. Only shown for countries which require a Tax Number of invoice recipients such as Germany (Steuernummer).\n * Not Nullable\n * Max Length : 1000\n */\n public invoiceRecipientTaxNumber: string = \"\";\n /**\n * If true, then this Group's product requirements apply to all outlets in the group.\n */\n public useGroupProductRequirementsForAllOutlets: boolean = false;\n /**\n * Product Requirements, eg minimum batch expiry lifetime.\n * Not Nullable\n * Max Length : 1000\n */\n public productRequirements: string = \"\";\n public onHoldReason: string = \"\";\n /**\n * True if PlacedOnHoldAt is not null\n */\n public onHold: boolean = false;\n /**\n * Credit Terms Set\n */\n public creditTermsSet: boolean = false;\n private _creditTermsId: Guid | null = null;\n /**\n * Credit Terms\n */\n public get creditTermsId(): Guid | null { return this._creditTermsId }\n public set creditTermsId(value: Guid | null) {\n this._creditTermsId = value === undefined ? null : value;\n }\n private _creditLimit: number | null = null;\n /**\n * Credit Limit\n * Not Negative\n */\n public get creditLimit(): number | null { return this._creditLimit }\n public set creditLimit(value: number | null) {\n this._creditLimit = value === undefined ? null : value;\n }\n private _creditReviewDate: LocalDate | null = null;\n /**\n * Credit Review Date\n */\n public get creditReviewDate(): LocalDate | null { return this._creditReviewDate }\n public set creditReviewDate(value: LocalDate | null) {\n this._creditReviewDate = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.isHidden = jsonSerializedObject.isHidden;\n this.name = jsonSerializedObject.name;\n this.telephoneNumber = jsonSerializedObject.telephoneNumber;\n this.emailAddress = jsonSerializedObject.emailAddress;\n this.mainAddressLine1 = jsonSerializedObject.mainAddressLine1;\n this.mainAddressLine2 = jsonSerializedObject.mainAddressLine2;\n this.mainAddressLine3 = jsonSerializedObject.mainAddressLine3;\n this.mainAddressLine4 = jsonSerializedObject.mainAddressLine4;\n this.mainAddressLine5 = jsonSerializedObject.mainAddressLine5;\n this.mainAddressLine6 = jsonSerializedObject.mainAddressLine6;\n this.mainAddressPostcode = jsonSerializedObject.mainAddressPostcode;\n this.vatNumber = jsonSerializedObject.vatNumber;\n this.bankName = jsonSerializedObject.bankName;\n this.bankAccountNumber = jsonSerializedObject.bankAccountNumber;\n this.bankSortCode = jsonSerializedObject.bankSortCode;\n this.sendInvoiceToOutlet = jsonSerializedObject.sendInvoiceToOutlet;\n this.emailInvoices = jsonSerializedObject.emailInvoices;\n this.invoiceEmailAddress = jsonSerializedObject.invoiceEmailAddress;\n this.defaultInvoiceTemplateId = jsonSerializedObject.defaultInvoiceTemplateId == null ? null : Guid.fromString(jsonSerializedObject.defaultInvoiceTemplateId);\n this.invoiceDataExchangeTemplateId = jsonSerializedObject.invoiceDataExchangeTemplateId == null ? null : Guid.fromString(jsonSerializedObject.invoiceDataExchangeTemplateId);\n this.readOnly = new GroupReadOnly(jsonSerializedObject.readOnly);\n this.invoiceCopiesToPrint = jsonSerializedObject.invoiceCopiesToPrint;\n this.deliveryServiceId = jsonSerializedObject.deliveryServiceId == null ? null : Guid.fromString(jsonSerializedObject.deliveryServiceId);\n this.accountsDepartmentNumber = jsonSerializedObject.accountsDepartmentNumber;\n this.emailDocumentGrouping = EnumEmailDocumentGrouping.getByValue(jsonSerializedObject.emailDocumentGrouping, this.emailDocumentGrouping);\n this.useGroupSalesCodeForAllOutlets = jsonSerializedObject.useGroupSalesCodeForAllOutlets;\n this.salesCodeId = jsonSerializedObject.salesCodeId == null ? null : Guid.fromString(jsonSerializedObject.salesCodeId);\n this.invoiceRecipientTaxNumber = jsonSerializedObject.invoiceRecipientTaxNumber;\n this.useGroupProductRequirementsForAllOutlets = jsonSerializedObject.useGroupProductRequirementsForAllOutlets;\n this.productRequirements = jsonSerializedObject.productRequirements;\n this.onHoldReason = jsonSerializedObject.onHoldReason;\n this.onHold = jsonSerializedObject.onHold;\n this.creditTermsSet = jsonSerializedObject.creditTermsSet;\n this.creditTermsId = jsonSerializedObject.creditTermsId == null ? null : Guid.fromString(jsonSerializedObject.creditTermsId);\n this.creditLimit = jsonSerializedObject.creditLimit == null ? null : jsonSerializedObject.creditLimit;\n this.creditReviewDate = jsonSerializedObject.creditReviewDate == null ? null : LocalDate.parse(jsonSerializedObject.creditReviewDate);\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.isHidden = this.isHidden;\n toRet.name = this.name;\n toRet.telephoneNumber = this.telephoneNumber;\n toRet.emailAddress = this.emailAddress;\n toRet.mainAddressLine1 = this.mainAddressLine1;\n toRet.mainAddressLine2 = this.mainAddressLine2;\n toRet.mainAddressLine3 = this.mainAddressLine3;\n toRet.mainAddressLine4 = this.mainAddressLine4;\n toRet.mainAddressLine5 = this.mainAddressLine5;\n toRet.mainAddressLine6 = this.mainAddressLine6;\n toRet.mainAddressPostcode = this.mainAddressPostcode;\n toRet.vatNumber = this.vatNumber;\n toRet.bankName = this.bankName;\n toRet.bankAccountNumber = this.bankAccountNumber;\n toRet.bankSortCode = this.bankSortCode;\n toRet.sendInvoiceToOutlet = this.sendInvoiceToOutlet;\n toRet.emailInvoices = this.emailInvoices;\n toRet.invoiceEmailAddress = this.invoiceEmailAddress;\n toRet.defaultInvoiceTemplateId = this.defaultInvoiceTemplateId == null ? null : this.defaultInvoiceTemplateId.toString();\n toRet.invoiceDataExchangeTemplateId = this.invoiceDataExchangeTemplateId == null ? null : this.invoiceDataExchangeTemplateId.toString();\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.invoiceCopiesToPrint = this.invoiceCopiesToPrint;\n toRet.deliveryServiceId = this.deliveryServiceId == null ? null : this.deliveryServiceId.toString();\n toRet.accountsDepartmentNumber = this.accountsDepartmentNumber;\n toRet.emailDocumentGrouping = this.emailDocumentGrouping.value;\n toRet.useGroupSalesCodeForAllOutlets = this.useGroupSalesCodeForAllOutlets;\n toRet.salesCodeId = this.salesCodeId == null ? null : this.salesCodeId.toString();\n toRet.invoiceRecipientTaxNumber = this.invoiceRecipientTaxNumber;\n toRet.useGroupProductRequirementsForAllOutlets = this.useGroupProductRequirementsForAllOutlets;\n toRet.productRequirements = this.productRequirements;\n toRet.onHoldReason = this.onHoldReason;\n toRet.onHold = this.onHold;\n toRet.creditTermsSet = this.creditTermsSet;\n toRet.creditTermsId = this.creditTermsId == null ? null : this.creditTermsId.toString();\n toRet.creditLimit = this.creditLimit == null ? null : this.creditLimit;\n toRet.creditReviewDate = this.creditReviewDate == null ? null : this.creditReviewDate.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"Group.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"telephoneNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"TelephoneNumber has too many characters (1000)\"},\n {field: \"emailAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"EmailAddress has too many characters (1000)\"},\n {field: \"mainAddressLine1\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressLine1 has too many characters (1000)\"},\n {field: \"mainAddressLine2\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressLine2 has too many characters (1000)\"},\n {field: \"mainAddressLine3\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressLine3 has too many characters (1000)\"},\n {field: \"mainAddressLine4\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressLine4 has too many characters (1000)\"},\n {field: \"mainAddressLine5\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressLine5 has too many characters (1000)\"},\n {field: \"mainAddressLine6\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressLine6 has too many characters (1000)\"},\n {field: \"mainAddressPostcode\", rule: (v: any) => v == null || v.length <= 1000 || \"MainAddressPostcode has too many characters (1000)\"},\n {field: \"vatNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"VatNumber has too many characters (1000)\"},\n {field: \"bankName\", rule: (v: any) => v == null || v.length <= 1000 || \"BankName has too many characters (1000)\"},\n {field: \"bankAccountNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"BankAccountNumber has too many characters (1000)\"},\n {field: \"bankSortCode\", rule: (v: any) => v == null || v.length <= 1000 || \"BankSortCode has too many characters (1000)\"},\n {field: \"invoiceEmailAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"InvoiceEmailAddress has too many characters (1000)\"},\n {field: \"defaultInvoiceTemplateId\", rule: (v: any) => v == null || !v.isEmpty() || \"Group.DefaultInvoiceTemplateId cannot be empty\"},\n {field: \"invoiceDataExchangeTemplateId\", rule: (v: any) => v == null || !v.isEmpty() || \"Group.InvoiceDataExchangeTemplateId cannot be empty\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"invoiceCopiesToPrint\", rule: (v: any) => v == null || v >= 0 || \"InvoiceCopiesToPrint is not greater than minimum allowed value: 0\"},\n {field: \"invoiceCopiesToPrint\", rule: (v: any) => v == null || v <= 2147483647 || \"InvoiceCopiesToPrint is above maximum allowed value: 2147483647\"},\n {field: \"deliveryServiceId\", rule: (v: any) => v == null || !v.isEmpty() || \"Group.DeliveryServiceId cannot be empty\"},\n {field: \"accountsDepartmentNumber\", rule: (v: any) => v == null || v >= -2147483648 || \"AccountsDepartmentNumber is not greater than minimum allowed value: -2147483648\"},\n {field: \"accountsDepartmentNumber\", rule: (v: any) => v == null || v <= 2147483647 || \"AccountsDepartmentNumber is above maximum allowed value: 2147483647\"},\n {field: \"salesCodeId\", rule: (v: any) => v == null || !v.isEmpty() || \"Group.SalesCodeId cannot be empty\"},\n {field: \"invoiceRecipientTaxNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"InvoiceRecipientTaxNumber has too many characters (1000)\"},\n {field: \"productRequirements\", rule: (v: any) => v == null || v.length <= 1000 || \"ProductRequirements has too many characters (1000)\"},\n {field: \"onHoldReason\", rule: (v: any) => v == null || v.length <= 1000 || \"OnHoldReason has too many characters (1000)\"},\n {field: \"creditTermsId\", rule: (v: any) => v == null || !v.isEmpty() || \"Group.CreditTermsId cannot be empty\"},\n ];\n}\n\n\nexport class GroupContact extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Group Id\n */\n public groupId: Guid = Guid.createEmpty();\n /**\n * Forename\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public forename: string = \"\";\n /**\n * Surname\n * Not Nullable\n * Max Length : 1000\n */\n public surname: string = \"\";\n /**\n * Salutation\n * Not Nullable\n * Max Length : 1000\n */\n public salutation: string = \"\";\n /**\n * JobTitle\n * Not Nullable\n * Max Length : 1000\n */\n public jobTitle: string = \"\";\n /**\n * Telephone number\n * Not Nullable\n * Max Length : 1000\n */\n public phoneNumber: string = \"\";\n /**\n * Phone Extension\n * Not Nullable\n * Max Length : 1000\n */\n public phoneExtension: string = \"\";\n /**\n * Mobile Phone Number\n * Not Nullable\n * Max Length : 1000\n */\n public mobileNumber: string = \"\";\n /**\n * Email Address\n * Not Nullable\n * Max Length : 1000\n */\n public emailAddress: string = \"\";\n /**\n * Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n /**\n * Address Line 1\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine1: string = \"\";\n /**\n * Address Line 2\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine2: string = \"\";\n /**\n * Address Line 3\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine3: string = \"\";\n /**\n * Address Line 4\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine4: string = \"\";\n /**\n * Address Line 5\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine5: string = \"\";\n /**\n * Address Line 6\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine6: string = \"\";\n /**\n * Postcode\n * Not Nullable\n * Max Length : 1000\n */\n public postcode: string = \"\";\n /**\n * Receives invoices\n */\n public areasInvoice: boolean = false;\n /**\n * Deals with orders\n */\n public areasOrders: boolean = false;\n /**\n * Receives delivery notes\n */\n public areasDeliveries: boolean = false;\n /**\n * Received marketing communication\n */\n public areasMarketing: boolean = false;\n /**\n * Deals with account queries\n */\n public areasAccounts: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.groupId = Guid.fromString(jsonSerializedObject.groupId);\n this.forename = jsonSerializedObject.forename;\n this.surname = jsonSerializedObject.surname;\n this.salutation = jsonSerializedObject.salutation;\n this.jobTitle = jsonSerializedObject.jobTitle;\n this.phoneNumber = jsonSerializedObject.phoneNumber;\n this.phoneExtension = jsonSerializedObject.phoneExtension;\n this.mobileNumber = jsonSerializedObject.mobileNumber;\n this.emailAddress = jsonSerializedObject.emailAddress;\n this.notes = jsonSerializedObject.notes;\n this.addressLine1 = jsonSerializedObject.addressLine1;\n this.addressLine2 = jsonSerializedObject.addressLine2;\n this.addressLine3 = jsonSerializedObject.addressLine3;\n this.addressLine4 = jsonSerializedObject.addressLine4;\n this.addressLine5 = jsonSerializedObject.addressLine5;\n this.addressLine6 = jsonSerializedObject.addressLine6;\n this.postcode = jsonSerializedObject.postcode;\n this.areasInvoice = jsonSerializedObject.areasInvoice;\n this.areasOrders = jsonSerializedObject.areasOrders;\n this.areasDeliveries = jsonSerializedObject.areasDeliveries;\n this.areasMarketing = jsonSerializedObject.areasMarketing;\n this.areasAccounts = jsonSerializedObject.areasAccounts;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.groupId = this.groupId.toString();\n toRet.forename = this.forename;\n toRet.surname = this.surname;\n toRet.salutation = this.salutation;\n toRet.jobTitle = this.jobTitle;\n toRet.phoneNumber = this.phoneNumber;\n toRet.phoneExtension = this.phoneExtension;\n toRet.mobileNumber = this.mobileNumber;\n toRet.emailAddress = this.emailAddress;\n toRet.notes = this.notes;\n toRet.addressLine1 = this.addressLine1;\n toRet.addressLine2 = this.addressLine2;\n toRet.addressLine3 = this.addressLine3;\n toRet.addressLine4 = this.addressLine4;\n toRet.addressLine5 = this.addressLine5;\n toRet.addressLine6 = this.addressLine6;\n toRet.postcode = this.postcode;\n toRet.areasInvoice = this.areasInvoice;\n toRet.areasOrders = this.areasOrders;\n toRet.areasDeliveries = this.areasDeliveries;\n toRet.areasMarketing = this.areasMarketing;\n toRet.areasAccounts = this.areasAccounts;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"GroupContact.Id cannot be empty\"},\n {field: \"groupId\", rule: (v: any) => !v.isEmpty() || \"GroupContact.GroupId cannot be empty\"},\n {field: \"forename\", rule: (v: any) => v == null || v.length !== 0 || \"Forename cannot be empty\"},\n {field: \"forename\", rule: (v: any) => v == null || v.length <= 1000 || \"Forename has too many characters (1000)\"},\n {field: \"surname\", rule: (v: any) => v == null || v.length <= 1000 || \"Surname has too many characters (1000)\"},\n {field: \"salutation\", rule: (v: any) => v == null || v.length <= 1000 || \"Salutation has too many characters (1000)\"},\n {field: \"jobTitle\", rule: (v: any) => v == null || v.length <= 1000 || \"JobTitle has too many characters (1000)\"},\n {field: \"phoneNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"PhoneNumber has too many characters (1000)\"},\n {field: \"phoneExtension\", rule: (v: any) => v == null || v.length <= 1000 || \"PhoneExtension has too many characters (1000)\"},\n {field: \"mobileNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"MobileNumber has too many characters (1000)\"},\n {field: \"emailAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"EmailAddress has too many characters (1000)\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"addressLine1\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine1 has too many characters (1000)\"},\n {field: \"addressLine2\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine2 has too many characters (1000)\"},\n {field: \"addressLine3\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine3 has too many characters (1000)\"},\n {field: \"addressLine4\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine4 has too many characters (1000)\"},\n {field: \"addressLine5\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine5 has too many characters (1000)\"},\n {field: \"addressLine6\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine6 has too many characters (1000)\"},\n {field: \"postcode\", rule: (v: any) => v == null || v.length <= 1000 || \"Postcode has too many characters (1000)\"},\n ];\n}\n\n\nexport class GroupLatestCreditBalance extends ModelObject {\n\n private _creditBalance: number | null = null;\n /**\n * Credit balance from the accounts package. Captured by system not user editable.\n * Not Negative\n */\n public get creditBalance(): number | null { return this._creditBalance }\n public set creditBalance(value: number | null) {\n this._creditBalance = value === undefined ? null : value;\n }\n private _creditBalanceExpiresAt: Instant | null = null;\n /**\n * The time when the credit balance will expire and need updating from the accounts package. Captured by system not user editable.\n */\n public get creditBalanceExpiresAt(): Instant | null { return this._creditBalanceExpiresAt }\n public set creditBalanceExpiresAt(value: Instant | null) {\n this._creditBalanceExpiresAt = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.creditBalance = jsonSerializedObject.creditBalance == null ? null : jsonSerializedObject.creditBalance;\n this.creditBalanceExpiresAt = jsonSerializedObject.creditBalanceExpiresAt == null ? null : Instant.parse(jsonSerializedObject.creditBalanceExpiresAt);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.creditBalance = this.creditBalance == null ? null : this.creditBalance;\n toRet.creditBalanceExpiresAt = this.creditBalanceExpiresAt == null ? null : this.creditBalanceExpiresAt.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GroupCreditBalance extends ModelObject {\n\n public groupId: Guid = Guid.createEmpty();\n private _creditBalance: number | null = null;\n public get creditBalance(): number | null { return this._creditBalance }\n public set creditBalance(value: number | null) {\n this._creditBalance = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.groupId = Guid.fromString(jsonSerializedObject.groupId);\n this.creditBalance = jsonSerializedObject.creditBalance == null ? null : jsonSerializedObject.creditBalance;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.groupId = this.groupId.toString();\n toRet.creditBalance = this.creditBalance == null ? null : this.creditBalance;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"groupId\", rule: (v: any) => !v.isEmpty() || \"GroupCreditBalance.GroupId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllGroupsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllGroupsResponse extends ModelObject {\n\n public groups: Group[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.groups = jsonSerializedObject.groups.map((v: any) => new Group(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.groups = this.groups.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"groups\", rule: (v: any) => !!v || \"groups is required\"},\n {field: \"groups\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Group[]).reduce((acc: Array, curr: Group) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetGroupsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public groupIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.groupIds = jsonSerializedObject.groupIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.groupIds = this.groupIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetGroupsResponse extends ModelObject {\n\n public group: Group[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.group = jsonSerializedObject.group.map((v: any) => new Group(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.group = this.group.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"group\", rule: (v: any) => !!v || \"group is required\"},\n {field: \"group\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Group[]).reduce((acc: Array, curr: Group) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetGroupRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public groupId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.groupId = Guid.fromString(jsonSerializedObject.groupId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.groupId = this.groupId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"groupId\", rule: (v: any) => !v.isEmpty() || \".GroupId cannot be empty\"},\n ];\n}\n\n\nexport class GetGroupResponse extends ModelObject {\n\n public group: Group = new Group();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.group = new Group(jsonSerializedObject.group);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.group = this.group.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"group\", rule: (v: any) => !!v || \"group is required\"},\n {field: \"group\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class CreateGroupRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public group: Group = new Group();\n public groupCode: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.group = new Group(jsonSerializedObject.group);\n this.groupCode = jsonSerializedObject.groupCode;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.group = this.group.toJsonSerializedObject();\n toRet.groupCode = this.groupCode;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"group\", rule: (v: any) => !!v || \"group is required\"},\n {field: \"group\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class UpdateGroupRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public groupId: Guid = Guid.createEmpty();\n private _expectedVersion: number | null = null;\n public get expectedVersion(): number | null { return this._expectedVersion }\n public set expectedVersion(value: number | null) {\n this._expectedVersion = value === undefined ? null : value;\n }\n public group: Group = new Group();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.groupId = Guid.fromString(jsonSerializedObject.groupId);\n this.expectedVersion = jsonSerializedObject.expectedVersion == null ? null : jsonSerializedObject.expectedVersion;\n this.group = new Group(jsonSerializedObject.group);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.groupId = this.groupId.toString();\n toRet.expectedVersion = this.expectedVersion == null ? null : this.expectedVersion;\n toRet.group = this.group.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"groupId\", rule: (v: any) => !v.isEmpty() || \".GroupId cannot be empty\"},\n {field: \"expectedVersion\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"ExpectedVersion is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"expectedVersion\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"ExpectedVersion is above maximum allowed value: 9223372036854775807\"},\n {field: \"group\", rule: (v: any) => !!v || \"group is required\"},\n {field: \"group\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetGroupIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public groupId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.groupId = Guid.fromString(jsonSerializedObject.groupId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.groupId = this.groupId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"groupId\", rule: (v: any) => !v.isEmpty() || \".GroupId cannot be empty\"},\n ];\n}\n\n\nexport class UpdateGroupLatLngsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public groupId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.groupId = Guid.fromString(jsonSerializedObject.groupId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.groupId = this.groupId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"groupId\", rule: (v: any) => !v.isEmpty() || \".GroupId cannot be empty\"},\n ];\n}\n\n\nexport class GetGroupLatestCreditBalanceRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public groupId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.groupId = Guid.fromString(jsonSerializedObject.groupId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.groupId = this.groupId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"groupId\", rule: (v: any) => !v.isEmpty() || \".GroupId cannot be empty\"},\n ];\n}\n\n\nexport class GetGroupLatestCreditBalanceResponse extends ModelObject {\n\n public latestCreditBalance: GroupLatestCreditBalance = new GroupLatestCreditBalance();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.latestCreditBalance = new GroupLatestCreditBalance(jsonSerializedObject.latestCreditBalance);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.latestCreditBalance = this.latestCreditBalance.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"latestCreditBalance\", rule: (v: any) => !!v || \"latestCreditBalance is required\"},\n {field: \"latestCreditBalance\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class UpdateGroupCreditBalancesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public groupCreditBalances: readonly GroupCreditBalance[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.groupCreditBalances = jsonSerializedObject.groupCreditBalances.map((v: any) => new GroupCreditBalance(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.groupCreditBalances = this.groupCreditBalances.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"groupCreditBalances\", rule: (v: any) => !!v || \"groupCreditBalances is required\"},\n {field: \"groupCreditBalances\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as GroupCreditBalance[]).reduce((acc: Array, curr: GroupCreditBalance) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetGroupContactsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public groupId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.groupId = Guid.fromString(jsonSerializedObject.groupId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.groupId = this.groupId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"groupId\", rule: (v: any) => !v.isEmpty() || \".GroupId cannot be empty\"},\n ];\n}\n\n\nexport class GetGroupContactsResponse extends ModelObject {\n\n public contacts: GroupContact[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.contacts = jsonSerializedObject.contacts.map((v: any) => new GroupContact(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.contacts = this.contacts.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"contacts\", rule: (v: any) => !!v || \"contacts is required\"},\n {field: \"contacts\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as GroupContact[]).reduce((acc: Array, curr: GroupContact) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetMultipleGroupContactsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public groupIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.groupIds = jsonSerializedObject.groupIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.groupIds = this.groupIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetMultipleGroupContactsResponse extends ModelObject {\n\n public contacts: GroupContact[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.contacts = jsonSerializedObject.contacts.map((v: any) => new GroupContact(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.contacts = this.contacts.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"contacts\", rule: (v: any) => !!v || \"contacts is required\"},\n {field: \"contacts\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as GroupContact[]).reduce((acc: Array, curr: GroupContact) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveGroupContactsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public contacts: readonly GroupContact[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.contacts = jsonSerializedObject.contacts.map((v: any) => new GroupContact(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.contacts = this.contacts.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"contacts\", rule: (v: any) => !!v || \"contacts is required\"},\n {field: \"contacts\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as GroupContact[]).reduce((acc: Array, curr: GroupContact) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class DeleteGroupContactsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public contactIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.contactIds = jsonSerializedObject.contactIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.contactIds = this.contactIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllGroupContactsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllGroupContactsResponse extends ModelObject {\n\n public groupContacts: GroupContact[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.groupContacts = jsonSerializedObject.groupContacts.map((v: any) => new GroupContact(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.groupContacts = this.groupContacts.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"groupContacts\", rule: (v: any) => !!v || \"groupContacts is required\"},\n {field: \"groupContacts\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as GroupContact[]).reduce((acc: Array, curr: GroupContact) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GroupService extends ServiceBase {\n\n public async getAllGroups(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllGroupsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllGroupsResponse(response).groups;\n return this.makeJsonRequest(\"group/v1/getAllGroups\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getGroups(tenantId: Guid, groupIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetGroupsRequest();\n req.tenantId = tenantId;\n req.groupIds = groupIds;\n const extractor = (response:any) => new GetGroupsResponse(response).group;\n return this.makeJsonRequest(\"group/v1/getGroups\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getGroup(tenantId: Guid, groupId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetGroupRequest();\n req.tenantId = tenantId;\n req.groupId = groupId;\n const extractor = (response:any) => new GetGroupResponse(response).group;\n return this.makeJsonRequest(\"group/v1/getGroup\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async createGroup(tenantId: Guid, group: Group, groupCode: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CreateGroupRequest();\n req.tenantId = tenantId;\n req.group = group;\n req.groupCode = groupCode;\n const extractor = null;\n return this.makeJsonRequest(\"group/v1/createGroup\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updateGroup(tenantId: Guid, groupId: Guid, expectedVersion: number | null, group: Group, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdateGroupRequest();\n req.tenantId = tenantId;\n req.groupId = groupId;\n req.expectedVersion = expectedVersion;\n req.group = group;\n const extractor = null;\n return this.makeJsonRequest(\"group/v1/updateGroup\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setGroupIsHidden(tenantId: Guid, groupId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetGroupIsHiddenRequest();\n req.tenantId = tenantId;\n req.groupId = groupId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"group/v1/setGroupIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getGroupLatestCreditBalance(tenantId: Guid, groupId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetGroupLatestCreditBalanceRequest();\n req.tenantId = tenantId;\n req.groupId = groupId;\n const extractor = (response:any) => new GetGroupLatestCreditBalanceResponse(response).latestCreditBalance;\n return this.makeJsonRequest(\"group/v1/getGroupLatestCreditBalance\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updateGroupCreditBalances(tenantId: Guid, groupCreditBalances: readonly GroupCreditBalance[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdateGroupCreditBalancesRequest();\n req.tenantId = tenantId;\n req.groupCreditBalances = groupCreditBalances;\n const extractor = null;\n return this.makeJsonRequest(\"group/v1/updateGroupCreditBalances\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getGroupContacts(tenantId: Guid, groupId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetGroupContactsRequest();\n req.tenantId = tenantId;\n req.groupId = groupId;\n const extractor = (response:any) => new GetGroupContactsResponse(response).contacts;\n return this.makeJsonRequest(\"group/v1/getGroupContacts\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getMultipleGroupContacts(tenantId: Guid, groupIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetMultipleGroupContactsRequest();\n req.tenantId = tenantId;\n req.groupIds = groupIds;\n const extractor = (response:any) => new GetMultipleGroupContactsResponse(response).contacts;\n return this.makeJsonRequest(\"group/v1/getMultipleGroupContacts\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveGroupContacts(tenantId: Guid, contacts: readonly GroupContact[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveGroupContactsRequest();\n req.tenantId = tenantId;\n req.contacts = contacts;\n const extractor = null;\n return this.makeJsonRequest(\"group/v1/saveGroupContacts\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async deleteGroupContacts(tenantId: Guid, contactIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new DeleteGroupContactsRequest();\n req.tenantId = tenantId;\n req.contactIds = contactIds;\n const extractor = null;\n return this.makeJsonRequest(\"group/v1/deleteGroupContacts\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllGroupContacts(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllGroupContactsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllGroupContactsResponse(response).groupContacts;\n return this.makeJsonRequest(\"group/v1/getAllGroupContacts\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const groupService = new GroupService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { Group } from \"@/app/services/generated/groupService\";\nimport { groupService } from \"@/app/services/generated/groupService\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\n\nexport interface IHasGroupsCache {\n groups: GroupsCache;\n}\n\n// Singleton cache store\nconst groupsCacheStore = new EntityCacheStore(\n EnumCacheEntityType.group,\n async () => groupService.getAllGroups(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class GroupsCache extends EntityWithGuidKeyCache {\n constructor() {\n super(groupsCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumAlcoholType } from \"./enums/enumAlcoholType.generated\";\nimport { EnumGermanBeerDutyProductType } from \"./enums/enumGermanBeerDutyProductType.generated\";\nimport { EnumItemMainPurpose } from \"./enums/enumItemMainPurpose.generated\";\nimport { EnumSpiritDutyExemptionReason } from \"./enums/enumSpiritDutyExemptionReason.generated\";\n\n// Model Objects\n\nexport class Behaviours extends ModelObject {\n\n /**\n * True if this item is invoicable, therefore able to appear on orders / credits.\n */\n public isInvoiceable: boolean = false;\n /**\n * True if this item is stock tracked.\n */\n public isStockTracked: boolean = false;\n /**\n * True if this item is priced using the standard price lists and discounts structure. Typically all invoiceable items except those which have flat pricing.\n */\n public isPricedByPriceLists: boolean = false;\n /**\n * True if this item is a physical item.\n */\n public isPhysical: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.isInvoiceable = jsonSerializedObject.isInvoiceable;\n this.isStockTracked = jsonSerializedObject.isStockTracked;\n this.isPricedByPriceLists = jsonSerializedObject.isPricedByPriceLists;\n this.isPhysical = jsonSerializedObject.isPhysical;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.isInvoiceable = this.isInvoiceable;\n toRet.isStockTracked = this.isStockTracked;\n toRet.isPricedByPriceLists = this.isPricedByPriceLists;\n toRet.isPhysical = this.isPhysical;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class Details extends ModelObject
{\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n public isHidden: boolean = false;\n /**\n * Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n /**\n * Code\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public code: string = \"\";\n /**\n * Main purpose - mainly for grouping items for management. Immutable\n */\n public mainPurpose: EnumItemMainPurpose = EnumItemMainPurpose.unknown;\n /**\n * Notes.\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n /**\n * Unit of Measure. Immutable\n */\n public unitOfMeasureId: Guid = Guid.createEmpty();\n /**\n * Calculated (ReadOnly) behaviours\n */\n public behaviours: Behaviours = new Behaviours();\n /**\n * Cost Price - Used for GrossProfit calculations when goods are sold.\n * Not Negative\n */\n public costPrice: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.isHidden = jsonSerializedObject.isHidden;\n this.name = jsonSerializedObject.name;\n this.code = jsonSerializedObject.code;\n this.mainPurpose = EnumItemMainPurpose.getByValue(jsonSerializedObject.mainPurpose, this.mainPurpose);\n this.notes = jsonSerializedObject.notes;\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n this.behaviours = new Behaviours(jsonSerializedObject.behaviours);\n this.costPrice = jsonSerializedObject.costPrice;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.isHidden = this.isHidden;\n toRet.name = this.name;\n toRet.code = this.code;\n toRet.mainPurpose = this.mainPurpose.value;\n toRet.notes = this.notes;\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n toRet.behaviours = this.behaviours.toJsonSerializedObject();\n toRet.costPrice = this.costPrice;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"Details.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"code\", rule: (v: any) => v == null || v.length !== 0 || \"Code cannot be empty\"},\n {field: \"code\", rule: (v: any) => v == null || v.length <= 1000 || \"Code has too many characters (1000)\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"Details.UnitOfMeasureId cannot be empty\"},\n {field: \"behaviours\", rule: (v: any) => !!v || \"behaviours is required\"},\n {field: \"behaviours\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class Invoicing extends ModelObject {\n\n /**\n * To indicate that Urn should be captured when printing labels or using in onward assemblies.\n */\n public deliveryBatchTracked: boolean = false;\n /**\n * Are sales currently allowed for this product? (Use to prevent selling of Eg out-of-season products).\n */\n public allowSales: boolean = false;\n private _productBrandId: Guid | null = null;\n /**\n * Product Brand Id. Optional even for Products.\n */\n public get productBrandId(): Guid | null { return this._productBrandId }\n public set productBrandId(value: Guid | null) {\n this._productBrandId = value === undefined ? null : value;\n }\n private _pricingCategoryId: Guid | null = null;\n /**\n * Pricing Category Id. Required for Products.\n */\n public get pricingCategoryId(): Guid | null { return this._pricingCategoryId }\n public set pricingCategoryId(value: Guid | null) {\n this._pricingCategoryId = value === undefined ? null : value;\n }\n /**\n * Gl Code\n */\n public salesGlCodeId: Guid = Guid.createEmpty();\n /**\n * Country Of Origin\n * Not Nullable\n * Max Length : 1000\n */\n public countryOfOrigin: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.deliveryBatchTracked = jsonSerializedObject.deliveryBatchTracked;\n this.allowSales = jsonSerializedObject.allowSales;\n this.productBrandId = jsonSerializedObject.productBrandId == null ? null : Guid.fromString(jsonSerializedObject.productBrandId);\n this.pricingCategoryId = jsonSerializedObject.pricingCategoryId == null ? null : Guid.fromString(jsonSerializedObject.pricingCategoryId);\n this.salesGlCodeId = Guid.fromString(jsonSerializedObject.salesGlCodeId);\n this.countryOfOrigin = jsonSerializedObject.countryOfOrigin;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.deliveryBatchTracked = this.deliveryBatchTracked;\n toRet.allowSales = this.allowSales;\n toRet.productBrandId = this.productBrandId == null ? null : this.productBrandId.toString();\n toRet.pricingCategoryId = this.pricingCategoryId == null ? null : this.pricingCategoryId.toString();\n toRet.salesGlCodeId = this.salesGlCodeId.toString();\n toRet.countryOfOrigin = this.countryOfOrigin;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"productBrandId\", rule: (v: any) => v == null || !v.isEmpty() || \"Invoicing.ProductBrandId cannot be empty\"},\n {field: \"pricingCategoryId\", rule: (v: any) => v == null || !v.isEmpty() || \"Invoicing.PricingCategoryId cannot be empty\"},\n {field: \"salesGlCodeId\", rule: (v: any) => !v.isEmpty() || \"Invoicing.SalesGlCodeId cannot be empty\"},\n {field: \"countryOfOrigin\", rule: (v: any) => v == null || v.length <= 1000 || \"CountryOfOrigin has too many characters (1000)\"},\n ];\n}\n\n\nexport class Labelling extends ModelObject {\n\n /**\n * Use the Product Brand Tasting Notes\n */\n public labelUsesBrandTastingNotes: boolean = false;\n /**\n * Tasting Notes (May be overridden by branding).\n * Not Nullable\n * Max Length : 100000\n */\n public labelTastingNotes: string = \"\";\n /**\n * Use the Product Brand Ingredients and Allergens\n */\n public labelUsesBrandIngredientsAndAllergens: boolean = false;\n /**\n * Ingredients and Allergens\n * Not Nullable\n * Max Length : 100000\n */\n public labelIngredientsAndAllergens: string = \"\";\n private _bestBeforeDays: number | null = null;\n /**\n * Best before days. Used for pre-populating label's best before date.\n */\n public get bestBeforeDays(): number | null { return this._bestBeforeDays }\n public set bestBeforeDays(value: number | null) {\n this._bestBeforeDays = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.labelUsesBrandTastingNotes = jsonSerializedObject.labelUsesBrandTastingNotes;\n this.labelTastingNotes = jsonSerializedObject.labelTastingNotes;\n this.labelUsesBrandIngredientsAndAllergens = jsonSerializedObject.labelUsesBrandIngredientsAndAllergens;\n this.labelIngredientsAndAllergens = jsonSerializedObject.labelIngredientsAndAllergens;\n this.bestBeforeDays = jsonSerializedObject.bestBeforeDays == null ? null : jsonSerializedObject.bestBeforeDays;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.labelUsesBrandTastingNotes = this.labelUsesBrandTastingNotes;\n toRet.labelTastingNotes = this.labelTastingNotes;\n toRet.labelUsesBrandIngredientsAndAllergens = this.labelUsesBrandIngredientsAndAllergens;\n toRet.labelIngredientsAndAllergens = this.labelIngredientsAndAllergens;\n toRet.bestBeforeDays = this.bestBeforeDays == null ? null : this.bestBeforeDays;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"labelTastingNotes\", rule: (v: any) => v == null || v.length <= 100000 || \"LabelTastingNotes has too many characters (100000)\"},\n {field: \"labelIngredientsAndAllergens\", rule: (v: any) => v == null || v.length <= 100000 || \"LabelIngredientsAndAllergens has too many characters (100000)\"},\n {field: \"bestBeforeDays\", rule: (v: any) => v == null || v >= -2147483648 || \"BestBeforeDays is not greater than minimum allowed value: -2147483648\"},\n {field: \"bestBeforeDays\", rule: (v: any) => v == null || v <= 2147483647 || \"BestBeforeDays is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class Packaging extends ModelObject {\n\n private _packageTypeId: Guid | null = null;\n /**\n * Package Type Id. Optional even for Products\n */\n public get packageTypeId(): Guid | null { return this._packageTypeId }\n public set packageTypeId(value: Guid | null) {\n this._packageTypeId = value === undefined ? null : value;\n }\n private _netWeightKg: number | null = null;\n /**\n * Net Weight (kg), Ie if this item is a packaged thing such as a foodstuff then the actual weight of the foodstuff within the package.\n * Not Negative\n */\n public get netWeightKg(): number | null { return this._netWeightKg }\n public set netWeightKg(value: number | null) {\n this._netWeightKg = value === undefined ? null : value;\n }\n /**\n * Weight (kg)\n * Not Negative\n */\n public weightKg: number = 0;\n private _exportWeight: number | null = null;\n /**\n * Export Weight, if different to standard weight.\n * Not Negative\n */\n public get exportWeight(): number | null { return this._exportWeight }\n public set exportWeight(value: number | null) {\n this._exportWeight = value === undefined ? null : value;\n }\n private _produceMaterialId: Guid | null = null;\n /**\n * Id of the produce Item (if any) which this product is a packaged version of. (Eg a product of Best Bitter 500ml Bottle is a package of the produce item Best Bitter.)\n */\n public get produceMaterialId(): Guid | null { return this._produceMaterialId }\n public set produceMaterialId(value: Guid | null) {\n this._produceMaterialId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.packageTypeId = jsonSerializedObject.packageTypeId == null ? null : Guid.fromString(jsonSerializedObject.packageTypeId);\n this.netWeightKg = jsonSerializedObject.netWeightKg == null ? null : jsonSerializedObject.netWeightKg;\n this.weightKg = jsonSerializedObject.weightKg;\n this.exportWeight = jsonSerializedObject.exportWeight == null ? null : jsonSerializedObject.exportWeight;\n this.produceMaterialId = jsonSerializedObject.produceMaterialId == null ? null : Guid.fromString(jsonSerializedObject.produceMaterialId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.packageTypeId = this.packageTypeId == null ? null : this.packageTypeId.toString();\n toRet.netWeightKg = this.netWeightKg == null ? null : this.netWeightKg;\n toRet.weightKg = this.weightKg;\n toRet.exportWeight = this.exportWeight == null ? null : this.exportWeight;\n toRet.produceMaterialId = this.produceMaterialId == null ? null : this.produceMaterialId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"packageTypeId\", rule: (v: any) => v == null || !v.isEmpty() || \"Packaging.PackageTypeId cannot be empty\"},\n {field: \"produceMaterialId\", rule: (v: any) => v == null || !v.isEmpty() || \"Packaging.ProduceMaterialId cannot be empty\"},\n ];\n}\n\n\nexport class Stock extends ModelObject {\n\n /**\n * Stock Group Id\n */\n public stockGroupId: Guid = Guid.createEmpty();\n /**\n * Is this item perishable.\n */\n public isPerishable: boolean = false;\n /**\n * Is Tracked in Batches.\n */\n public isBatchTracked: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockGroupId = Guid.fromString(jsonSerializedObject.stockGroupId);\n this.isPerishable = jsonSerializedObject.isPerishable;\n this.isBatchTracked = jsonSerializedObject.isBatchTracked;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockGroupId = this.stockGroupId.toString();\n toRet.isPerishable = this.isPerishable;\n toRet.isBatchTracked = this.isBatchTracked;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockGroupId\", rule: (v: any) => !v.isEmpty() || \"Stock.StockGroupId cannot be empty\"},\n ];\n}\n\n\nexport class Vat extends ModelObject {\n\n /**\n * Vat Code Id\n */\n public vatCodeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vatCodeId = Guid.fromString(jsonSerializedObject.vatCodeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vatCodeId = this.vatCodeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vatCodeId\", rule: (v: any) => !v.isEmpty() || \"Vat.VatCodeId cannot be empty\"},\n ];\n}\n\n\nexport class AlcoholDuty extends ModelObject {\n\n /**\n * Alcohol Type.\n */\n public alcoholType: EnumAlcoholType = EnumAlcoholType.none;\n /**\n * Abv.\n * Not Negative\n * Maximum : 100\n */\n public abv: number = 0;\n private _dutiableLitres: number | null = null;\n /**\n * Dutiable Litres\n * Not Negative\n */\n public get dutiableLitres(): number | null { return this._dutiableLitres }\n public set dutiableLitres(value: number | null) {\n this._dutiableLitres = value === undefined ? null : value;\n }\n private _manufacturerId: Guid | null = null;\n /**\n * Manufacturer.\n */\n public get manufacturerId(): Guid | null { return this._manufacturerId }\n public set manufacturerId(value: Guid | null) {\n this._manufacturerId = value === undefined ? null : value;\n }\n private _plato: number | null = null;\n /**\n * Plato Value\n */\n public get plato(): number | null { return this._plato }\n public set plato(value: number | null) {\n this._plato = value === undefined ? null : value;\n }\n public germanBeerDutyProductType: EnumGermanBeerDutyProductType = EnumGermanBeerDutyProductType.none;\n private _germanBeerMixedProductPercentageA: number | null = null;\n public get germanBeerMixedProductPercentageA(): number | null { return this._germanBeerMixedProductPercentageA }\n public set germanBeerMixedProductPercentageA(value: number | null) {\n this._germanBeerMixedProductPercentageA = value === undefined ? null : value;\n }\n /**\n * Set true if this item is brewed by members of the public for their personal use by borrowing the Brewery's equipment. This is a service offered by breweries in some countries, such as Australia, and can affect duty.\n */\n public isBrewedForPersonalUse: boolean = false;\n public spiritDutyExemptionReason: EnumSpiritDutyExemptionReason = EnumSpiritDutyExemptionReason.none;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.alcoholType = EnumAlcoholType.getByValue(jsonSerializedObject.alcoholType, this.alcoholType);\n this.abv = jsonSerializedObject.abv;\n this.dutiableLitres = jsonSerializedObject.dutiableLitres == null ? null : jsonSerializedObject.dutiableLitres;\n this.manufacturerId = jsonSerializedObject.manufacturerId == null ? null : Guid.fromString(jsonSerializedObject.manufacturerId);\n this.plato = jsonSerializedObject.plato == null ? null : jsonSerializedObject.plato;\n this.germanBeerDutyProductType = EnumGermanBeerDutyProductType.getByValue(jsonSerializedObject.germanBeerDutyProductType, this.germanBeerDutyProductType);\n this.germanBeerMixedProductPercentageA = jsonSerializedObject.germanBeerMixedProductPercentageA == null ? null : jsonSerializedObject.germanBeerMixedProductPercentageA;\n this.isBrewedForPersonalUse = jsonSerializedObject.isBrewedForPersonalUse;\n this.spiritDutyExemptionReason = EnumSpiritDutyExemptionReason.getByValue(jsonSerializedObject.spiritDutyExemptionReason, this.spiritDutyExemptionReason);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.alcoholType = this.alcoholType.value;\n toRet.abv = this.abv;\n toRet.dutiableLitres = this.dutiableLitres == null ? null : this.dutiableLitres;\n toRet.manufacturerId = this.manufacturerId == null ? null : this.manufacturerId.toString();\n toRet.plato = this.plato == null ? null : this.plato;\n toRet.germanBeerDutyProductType = this.germanBeerDutyProductType.value;\n toRet.germanBeerMixedProductPercentageA = this.germanBeerMixedProductPercentageA == null ? null : this.germanBeerMixedProductPercentageA;\n toRet.isBrewedForPersonalUse = this.isBrewedForPersonalUse;\n toRet.spiritDutyExemptionReason = this.spiritDutyExemptionReason.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"manufacturerId\", rule: (v: any) => v == null || !v.isEmpty() || \"AlcoholDuty.ManufacturerId cannot be empty\"},\n ];\n}\n\n\nexport class purchasingDetailReadOnly extends ModelObject {\n\n /**\n * Stock item this puchasing details belongs to.\n */\n public itemId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.itemId = Guid.fromString(jsonSerializedObject.itemId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.itemId = this.itemId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"itemId\", rule: (v: any) => !v.isEmpty() || \"purchasingDetailReadOnly.ItemId cannot be empty\"},\n ];\n}\n\n\nexport class PurchasingDetails extends ModelObject {\n\n private _supplierId: Guid | null = null;\n /**\n * Unique, nullable suppplier id of the item. Null represents all other suppliers\n */\n public get supplierId(): Guid | null { return this._supplierId }\n public set supplierId(value: Guid | null) {\n this._supplierId = value === undefined ? null : value;\n }\n /**\n * Whether this supplier is ite's default supplier.\n */\n public isDefault: boolean = false;\n /**\n * Supplier Part Number\n * Not Nullable\n * Max Length : 10000\n */\n public supplierPartNo: string = \"\";\n private _purchasePrice: number | null = null;\n /**\n * Purchase Pack Price\n * Not Negative\n */\n public get purchasePrice(): number | null { return this._purchasePrice }\n public set purchasePrice(value: number | null) {\n this._purchasePrice = value === undefined ? null : value;\n }\n private _purchasePackSize: number | null = null;\n /**\n * Supplier Pack Size\n * Not Negative\n * Greater Than : 0\n */\n public get purchasePackSize(): number | null { return this._purchasePackSize }\n public set purchasePackSize(value: number | null) {\n this._purchasePackSize = value === undefined ? null : value;\n }\n private _purchaseGlCodeId: Guid | null = null;\n /**\n * Purchase GL Code\n */\n public get purchaseGlCodeId(): Guid | null { return this._purchaseGlCodeId }\n public set purchaseGlCodeId(value: Guid | null) {\n this._purchaseGlCodeId = value === undefined ? null : value;\n }\n /**\n * Number of days typically between ordering and receiving item.\n * Not Negative\n */\n public leadTimeDays: number = 0;\n public readOnly: purchasingDetailReadOnly = new purchasingDetailReadOnly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.supplierId = jsonSerializedObject.supplierId == null ? null : Guid.fromString(jsonSerializedObject.supplierId);\n this.isDefault = jsonSerializedObject.isDefault;\n this.supplierPartNo = jsonSerializedObject.supplierPartNo;\n this.purchasePrice = jsonSerializedObject.purchasePrice == null ? null : jsonSerializedObject.purchasePrice;\n this.purchasePackSize = jsonSerializedObject.purchasePackSize == null ? null : jsonSerializedObject.purchasePackSize;\n this.purchaseGlCodeId = jsonSerializedObject.purchaseGlCodeId == null ? null : Guid.fromString(jsonSerializedObject.purchaseGlCodeId);\n this.leadTimeDays = jsonSerializedObject.leadTimeDays;\n this.readOnly = new purchasingDetailReadOnly(jsonSerializedObject.readOnly);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.supplierId = this.supplierId == null ? null : this.supplierId.toString();\n toRet.isDefault = this.isDefault;\n toRet.supplierPartNo = this.supplierPartNo;\n toRet.purchasePrice = this.purchasePrice == null ? null : this.purchasePrice;\n toRet.purchasePackSize = this.purchasePackSize == null ? null : this.purchasePackSize;\n toRet.purchaseGlCodeId = this.purchaseGlCodeId == null ? null : this.purchaseGlCodeId.toString();\n toRet.leadTimeDays = this.leadTimeDays;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"supplierId\", rule: (v: any) => v == null || !v.isEmpty() || \"PurchasingDetails.SupplierId cannot be empty\"},\n {field: \"supplierPartNo\", rule: (v: any) => v == null || v.length <= 10000 || \"SupplierPartNo has too many characters (10000)\"},\n {field: \"purchasePackSize\", rule: (v: any) => v == null || v > 0 || \"PurchasePackSize is not greater than minimum allowed value: 0\"},\n {field: \"purchaseGlCodeId\", rule: (v: any) => v == null || !v.isEmpty() || \"PurchasingDetails.PurchaseGlCodeId cannot be empty\"},\n {field: \"leadTimeDays\", rule: (v: any) => v == null || v >= 0 || \"LeadTimeDays is not greater than minimum allowed value: 0\"},\n {field: \"leadTimeDays\", rule: (v: any) => v == null || v <= 2147483647 || \"LeadTimeDays is above maximum allowed value: 2147483647\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class ExternalCodes extends ModelObject {\n\n /**\n * EAN 13/14 Product Code\n * Not Nullable\n * Max Length : 100000\n */\n public eanBarcodeNumber: string = \"\";\n /**\n * Export Commodity Code\n * Not Nullable\n * Max Length : 1000\n */\n public exportCommodityCode: string = \"\";\n /**\n * Harmonized System (HS) Codes\n * Not Nullable\n * Max Length : 1000\n */\n public hsCode: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.eanBarcodeNumber = jsonSerializedObject.eanBarcodeNumber;\n this.exportCommodityCode = jsonSerializedObject.exportCommodityCode;\n this.hsCode = jsonSerializedObject.hsCode;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.eanBarcodeNumber = this.eanBarcodeNumber;\n toRet.exportCommodityCode = this.exportCommodityCode;\n toRet.hsCode = this.hsCode;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"eanBarcodeNumber\", rule: (v: any) => v == null || v.length <= 100000 || \"EanBarcodeNumber has too many characters (100000)\"},\n {field: \"exportCommodityCode\", rule: (v: any) => v == null || v.length <= 1000 || \"ExportCommodityCode has too many characters (1000)\"},\n {field: \"hsCode\", rule: (v: any) => v == null || v.length <= 1000 || \"HsCode has too many characters (1000)\"},\n ];\n}\n\n\nexport class FlatPricing extends ModelObject {\n\n public flatSalesPrice: number = 0;\n /**\n * Determines if the Flat Sales price, if defined, is gross (includes VAT) or Net (of VAT).\n */\n public isFlatSalesPriceGross: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.flatSalesPrice = jsonSerializedObject.flatSalesPrice;\n this.isFlatSalesPriceGross = jsonSerializedObject.isFlatSalesPriceGross;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.flatSalesPrice = this.flatSalesPrice;\n toRet.isFlatSalesPriceGross = this.isFlatSalesPriceGross;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class MaterialDetails extends ModelObject {\n\n private _defaultHopAlpha: number | null = null;\n /**\n * If not null, then this is the default Hop Alpha. If the actual alpha of a specific batch is given, then ingredient usages will scale accoring to the ratio.\n * Not Negative\n */\n public get defaultHopAlpha(): number | null { return this._defaultHopAlpha }\n public set defaultHopAlpha(value: number | null) {\n this._defaultHopAlpha = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.defaultHopAlpha = jsonSerializedObject.defaultHopAlpha == null ? null : jsonSerializedObject.defaultHopAlpha;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.defaultHopAlpha = this.defaultHopAlpha == null ? null : this.defaultHopAlpha;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class AutoAssemblyBomLineReadOnly extends ModelObject {\n\n /**\n * Auto assembled item which this line is a part of.\n */\n public parentAutoAssembledItemId: Guid = Guid.createEmpty();\n /**\n * Sequence for presenting Bom Lines in consistent order.\n */\n public sequence: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.parentAutoAssembledItemId = Guid.fromString(jsonSerializedObject.parentAutoAssembledItemId);\n this.sequence = jsonSerializedObject.sequence;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.parentAutoAssembledItemId = this.parentAutoAssembledItemId.toString();\n toRet.sequence = this.sequence;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"parentAutoAssembledItemId\", rule: (v: any) => !v.isEmpty() || \"AutoAssemblyBomLineReadOnly.ParentAutoAssembledItemId cannot be empty\"},\n {field: \"sequence\", rule: (v: any) => v == null || v >= -2147483648 || \"Sequence is not greater than minimum allowed value: -2147483648\"},\n {field: \"sequence\", rule: (v: any) => v == null || v <= 2147483647 || \"Sequence is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class AutoAssemblyBomLine extends ModelObject {\n\n /**\n * Item which is a component of the auto assembled item.\n */\n public itemId: Guid = Guid.createEmpty();\n /**\n * The quantity of Item required for each ParentAutoAssembledItem created.\n * Greater Than : 0\n */\n public quantity: number = 0;\n public readOnly: AutoAssemblyBomLineReadOnly = new AutoAssemblyBomLineReadOnly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.itemId = Guid.fromString(jsonSerializedObject.itemId);\n this.quantity = jsonSerializedObject.quantity;\n this.readOnly = new AutoAssemblyBomLineReadOnly(jsonSerializedObject.readOnly);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.itemId = this.itemId.toString();\n toRet.quantity = this.quantity;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"itemId\", rule: (v: any) => !v.isEmpty() || \"AutoAssemblyBomLine.ItemId cannot be empty\"},\n {field: \"quantity\", rule: (v: any) => v == null || v > 0 || \"Quantity is not greater than minimum allowed value: 0\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class ItemFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _mainPurposes: EnumItemMainPurpose[] | null = null;\n public get mainPurposes(): EnumItemMainPurpose[] | null { return this._mainPurposes }\n public set mainPurposes(value: EnumItemMainPurpose[] | null) {\n this._mainPurposes = value === undefined ? null : value;\n }\n private _stockGroupIds: Guid[] | null = null;\n public get stockGroupIds(): Guid[] | null { return this._stockGroupIds }\n public set stockGroupIds(value: Guid[] | null) {\n this._stockGroupIds = value === undefined ? null : value;\n }\n private _salesGlCodeIds: Guid[] | null = null;\n public get salesGlCodeIds(): Guid[] | null { return this._salesGlCodeIds }\n public set salesGlCodeIds(value: Guid[] | null) {\n this._salesGlCodeIds = value === undefined ? null : value;\n }\n private _vatCodeIds: Guid[] | null = null;\n public get vatCodeIds(): Guid[] | null { return this._vatCodeIds }\n public set vatCodeIds(value: Guid[] | null) {\n this._vatCodeIds = value === undefined ? null : value;\n }\n private _codes: string[] | null = null;\n public get codes(): string[] | null { return this._codes }\n public set codes(value: string[] | null) {\n this._codes = value === undefined ? null : value;\n }\n private _itemIds: Guid[] | null = null;\n public get itemIds(): Guid[] | null { return this._itemIds }\n public set itemIds(value: Guid[] | null) {\n this._itemIds = value === undefined ? null : value;\n }\n private _productBrandIds: Guid[] | null = null;\n public get productBrandIds(): Guid[] | null { return this._productBrandIds }\n public set productBrandIds(value: Guid[] | null) {\n this._productBrandIds = value === undefined ? null : value;\n }\n private _packageTypeIds: Guid[] | null = null;\n public get packageTypeIds(): Guid[] | null { return this._packageTypeIds }\n public set packageTypeIds(value: Guid[] | null) {\n this._packageTypeIds = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.mainPurposes = jsonSerializedObject.mainPurposes == null ? null : jsonSerializedObject.mainPurposes.map((v: any) => EnumItemMainPurpose.getByValue(v));\n this.stockGroupIds = jsonSerializedObject.stockGroupIds == null ? null : jsonSerializedObject.stockGroupIds.map((v: any) => Guid.fromString(v));\n this.salesGlCodeIds = jsonSerializedObject.salesGlCodeIds == null ? null : jsonSerializedObject.salesGlCodeIds.map((v: any) => Guid.fromString(v));\n this.vatCodeIds = jsonSerializedObject.vatCodeIds == null ? null : jsonSerializedObject.vatCodeIds.map((v: any) => Guid.fromString(v));\n this.codes = jsonSerializedObject.codes == null ? null : jsonSerializedObject.codes.map((v: any) => v);\n this.itemIds = jsonSerializedObject.itemIds == null ? null : jsonSerializedObject.itemIds.map((v: any) => Guid.fromString(v));\n this.productBrandIds = jsonSerializedObject.productBrandIds == null ? null : jsonSerializedObject.productBrandIds.map((v: any) => Guid.fromString(v));\n this.packageTypeIds = jsonSerializedObject.packageTypeIds == null ? null : jsonSerializedObject.packageTypeIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.mainPurposes = this.mainPurposes == null ? null : this.mainPurposes.map(v => v.value);\n toRet.stockGroupIds = this.stockGroupIds == null ? null : this.stockGroupIds.map(v => v.toString());\n toRet.salesGlCodeIds = this.salesGlCodeIds == null ? null : this.salesGlCodeIds.map(v => v.toString());\n toRet.vatCodeIds = this.vatCodeIds == null ? null : this.vatCodeIds.map(v => v.toString());\n toRet.codes = this.codes == null ? null : this.codes.map(v => v);\n toRet.itemIds = this.itemIds == null ? null : this.itemIds.map(v => v.toString());\n toRet.productBrandIds = this.productBrandIds == null ? null : this.productBrandIds.map(v => v.toString());\n toRet.packageTypeIds = this.packageTypeIds == null ? null : this.packageTypeIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class Item extends BaseModelObject {\n\n public details: Details = new Details();\n private _invoicing: Invoicing | null = null;\n public get invoicing(): Invoicing | null { return this._invoicing }\n public set invoicing(value: Invoicing | null) {\n this._invoicing = value === undefined ? null : value;\n }\n public packaging: Packaging = new Packaging();\n private _stock: Stock | null = null;\n public get stock(): Stock | null { return this._stock }\n public set stock(value: Stock | null) {\n this._stock = value === undefined ? null : value;\n }\n private _vat: Vat | null = null;\n public get vat(): Vat | null { return this._vat }\n public set vat(value: Vat | null) {\n this._vat = value === undefined ? null : value;\n }\n private _alcoholDuty: AlcoholDuty | null = null;\n public get alcoholDuty(): AlcoholDuty | null { return this._alcoholDuty }\n public set alcoholDuty(value: AlcoholDuty | null) {\n this._alcoholDuty = value === undefined ? null : value;\n }\n public purchasingDetails: PurchasingDetails[] = [];\n public externalCodes: ExternalCodes = new ExternalCodes();\n private _flatPricing: FlatPricing | null = null;\n public get flatPricing(): FlatPricing | null { return this._flatPricing }\n public set flatPricing(value: FlatPricing | null) {\n this._flatPricing = value === undefined ? null : value;\n }\n public labelling: Labelling = new Labelling();\n private _materialDetails: MaterialDetails | null = null;\n public get materialDetails(): MaterialDetails | null { return this._materialDetails }\n public set materialDetails(value: MaterialDetails | null) {\n this._materialDetails = value === undefined ? null : value;\n }\n private _autoAssemblyBom: AutoAssemblyBomLine[] | null = null;\n public get autoAssemblyBom(): AutoAssemblyBomLine[] | null { return this._autoAssemblyBom }\n public set autoAssemblyBom(value: AutoAssemblyBomLine[] | null) {\n this._autoAssemblyBom = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.details = new Details(jsonSerializedObject.details);\n this.invoicing = jsonSerializedObject.invoicing == null ? null : new Invoicing(jsonSerializedObject.invoicing);\n this.packaging = new Packaging(jsonSerializedObject.packaging);\n this.stock = jsonSerializedObject.stock == null ? null : new Stock(jsonSerializedObject.stock);\n this.vat = jsonSerializedObject.vat == null ? null : new Vat(jsonSerializedObject.vat);\n this.alcoholDuty = jsonSerializedObject.alcoholDuty == null ? null : new AlcoholDuty(jsonSerializedObject.alcoholDuty);\n this.purchasingDetails = jsonSerializedObject.purchasingDetails.map((v: any) => new PurchasingDetails(v));\n this.externalCodes = new ExternalCodes(jsonSerializedObject.externalCodes);\n this.flatPricing = jsonSerializedObject.flatPricing == null ? null : new FlatPricing(jsonSerializedObject.flatPricing);\n this.labelling = new Labelling(jsonSerializedObject.labelling);\n this.materialDetails = jsonSerializedObject.materialDetails == null ? null : new MaterialDetails(jsonSerializedObject.materialDetails);\n this.autoAssemblyBom = jsonSerializedObject.autoAssemblyBom == null ? null : jsonSerializedObject.autoAssemblyBom.map((v: any) => new AutoAssemblyBomLine(v));\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.details = this.details.toJsonSerializedObject();\n toRet.invoicing = this.invoicing == null ? null : this.invoicing?.toJsonSerializedObject() ?? null;\n toRet.packaging = this.packaging.toJsonSerializedObject();\n toRet.stock = this.stock == null ? null : this.stock?.toJsonSerializedObject() ?? null;\n toRet.vat = this.vat == null ? null : this.vat?.toJsonSerializedObject() ?? null;\n toRet.alcoholDuty = this.alcoholDuty == null ? null : this.alcoholDuty?.toJsonSerializedObject() ?? null;\n toRet.purchasingDetails = this.purchasingDetails.map(v => v.toJsonSerializedObject());\n toRet.externalCodes = this.externalCodes.toJsonSerializedObject();\n toRet.flatPricing = this.flatPricing == null ? null : this.flatPricing?.toJsonSerializedObject() ?? null;\n toRet.labelling = this.labelling.toJsonSerializedObject();\n toRet.materialDetails = this.materialDetails == null ? null : this.materialDetails?.toJsonSerializedObject() ?? null;\n toRet.autoAssemblyBom = this.autoAssemblyBom == null ? null : this.autoAssemblyBom.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"details\", rule: (v: any) => !!v || \"details is required\"},\n {field: \"details\", rule: (v: any) => v.validate()},\n {field: \"invoicing\", rule: (v: any) => (v === null) || v.validate()},\n {field: \"packaging\", rule: (v: any) => !!v || \"packaging is required\"},\n {field: \"packaging\", rule: (v: any) => v.validate()},\n {field: \"stock\", rule: (v: any) => (v === null) || v.validate()},\n {field: \"vat\", rule: (v: any) => (v === null) || v.validate()},\n {field: \"alcoholDuty\", rule: (v: any) => (v === null) || v.validate()},\n {field: \"purchasingDetails\", rule: (v: any) => !!v || \"purchasingDetails is required\"},\n {field: \"purchasingDetails\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PurchasingDetails[]).reduce((acc: Array, curr: PurchasingDetails) => acc.concat(curr.validate()), new Array());\n }},\n {field: \"externalCodes\", rule: (v: any) => !!v || \"externalCodes is required\"},\n {field: \"externalCodes\", rule: (v: any) => v.validate()},\n {field: \"flatPricing\", rule: (v: any) => (v === null) || v.validate()},\n {field: \"labelling\", rule: (v: any) => !!v || \"labelling is required\"},\n {field: \"labelling\", rule: (v: any) => v.validate()},\n {field: \"materialDetails\", rule: (v: any) => (v === null) || v.validate()},\n {field: \"autoAssemblyBom\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AutoAssemblyBomLine[]).reduce((acc: Array, curr: AutoAssemblyBomLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class ExpectedDutyForItemResult extends ModelObject {\n\n public itemId: Guid = Guid.createEmpty();\n public dutyCostUnrounded: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.itemId = Guid.fromString(jsonSerializedObject.itemId);\n this.dutyCostUnrounded = jsonSerializedObject.dutyCostUnrounded;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.itemId = this.itemId.toString();\n toRet.dutyCostUnrounded = this.dutyCostUnrounded;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"itemId\", rule: (v: any) => !v.isEmpty() || \"ExpectedDutyForItemResult.ItemId cannot be empty\"},\n ];\n}\n\n\nexport class FilteredItems extends ModelObject {\n\n public matchingCount: number = 0;\n public items: Item[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.items = jsonSerializedObject.items.map((v: any) => new Item(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.items = this.items.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"items\", rule: (v: any) => !!v || \"items is required\"},\n {field: \"items\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Item[]).reduce((acc: Array, curr: Item) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class InvoiceableItem extends ModelObject {\n\n public details: Details = new Details();\n public invoicing: Invoicing = new Invoicing();\n public vat: Vat = new Vat();\n private _alcoholDuty: AlcoholDuty | null = null;\n public get alcoholDuty(): AlcoholDuty | null { return this._alcoholDuty }\n public set alcoholDuty(value: AlcoholDuty | null) {\n this._alcoholDuty = value === undefined ? null : value;\n }\n public externalCodes: ExternalCodes = new ExternalCodes();\n private _flatPricing: FlatPricing | null = null;\n public get flatPricing(): FlatPricing | null { return this._flatPricing }\n public set flatPricing(value: FlatPricing | null) {\n this._flatPricing = value === undefined ? null : value;\n }\n public packaging: Packaging = new Packaging();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.details = new Details(jsonSerializedObject.details);\n this.invoicing = new Invoicing(jsonSerializedObject.invoicing);\n this.vat = new Vat(jsonSerializedObject.vat);\n this.alcoholDuty = jsonSerializedObject.alcoholDuty == null ? null : new AlcoholDuty(jsonSerializedObject.alcoholDuty);\n this.externalCodes = new ExternalCodes(jsonSerializedObject.externalCodes);\n this.flatPricing = jsonSerializedObject.flatPricing == null ? null : new FlatPricing(jsonSerializedObject.flatPricing);\n this.packaging = new Packaging(jsonSerializedObject.packaging);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.details = this.details.toJsonSerializedObject();\n toRet.invoicing = this.invoicing.toJsonSerializedObject();\n toRet.vat = this.vat.toJsonSerializedObject();\n toRet.alcoholDuty = this.alcoholDuty == null ? null : this.alcoholDuty?.toJsonSerializedObject() ?? null;\n toRet.externalCodes = this.externalCodes.toJsonSerializedObject();\n toRet.flatPricing = this.flatPricing == null ? null : this.flatPricing?.toJsonSerializedObject() ?? null;\n toRet.packaging = this.packaging.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"details\", rule: (v: any) => !!v || \"details is required\"},\n {field: \"details\", rule: (v: any) => v.validate()},\n {field: \"invoicing\", rule: (v: any) => !!v || \"invoicing is required\"},\n {field: \"invoicing\", rule: (v: any) => v.validate()},\n {field: \"vat\", rule: (v: any) => !!v || \"vat is required\"},\n {field: \"vat\", rule: (v: any) => v.validate()},\n {field: \"alcoholDuty\", rule: (v: any) => (v === null) || v.validate()},\n {field: \"externalCodes\", rule: (v: any) => !!v || \"externalCodes is required\"},\n {field: \"externalCodes\", rule: (v: any) => v.validate()},\n {field: \"flatPricing\", rule: (v: any) => (v === null) || v.validate()},\n {field: \"packaging\", rule: (v: any) => !!v || \"packaging is required\"},\n {field: \"packaging\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class FilteredInvoiceableItems extends ModelObject {\n\n public matchingCount: number = 0;\n public invoiceableItems: InvoiceableItem[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.invoiceableItems = jsonSerializedObject.invoiceableItems.map((v: any) => new InvoiceableItem(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.invoiceableItems = this.invoiceableItems.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"invoiceableItems\", rule: (v: any) => !!v || \"invoiceableItems is required\"},\n {field: \"invoiceableItems\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as InvoiceableItem[]).reduce((acc: Array, curr: InvoiceableItem) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GlCodeOverrideForItem extends ModelObject {\n\n /**\n * Outlet Type ID\n */\n public outletTypeId: Guid = Guid.createEmpty();\n private _glCodeId: Guid | null = null;\n /**\n * Gl Code Id\n */\n public get glCodeId(): Guid | null { return this._glCodeId }\n public set glCodeId(value: Guid | null) {\n this._glCodeId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outletTypeId = Guid.fromString(jsonSerializedObject.outletTypeId);\n this.glCodeId = jsonSerializedObject.glCodeId == null ? null : Guid.fromString(jsonSerializedObject.glCodeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outletTypeId = this.outletTypeId.toString();\n toRet.glCodeId = this.glCodeId == null ? null : this.glCodeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outletTypeId\", rule: (v: any) => !v.isEmpty() || \"GlCodeOverrideForItem.OutletTypeId cannot be empty\"},\n {field: \"glCodeId\", rule: (v: any) => v == null || !v.isEmpty() || \"GlCodeOverrideForItem.GlCodeId cannot be empty\"},\n ];\n}\n\n\nexport class StockTrackedItem extends ModelObject {\n\n public details: Details = new Details();\n public stock: Stock = new Stock();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.details = new Details(jsonSerializedObject.details);\n this.stock = new Stock(jsonSerializedObject.stock);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.details = this.details.toJsonSerializedObject();\n toRet.stock = this.stock.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"details\", rule: (v: any) => !!v || \"details is required\"},\n {field: \"details\", rule: (v: any) => v.validate()},\n {field: \"stock\", rule: (v: any) => !!v || \"stock is required\"},\n {field: \"stock\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class FilteredStockTrackedItems extends ModelObject {\n\n public matchingCount: number = 0;\n public stockTrackedItems: StockTrackedItem[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.stockTrackedItems = jsonSerializedObject.stockTrackedItems.map((v: any) => new StockTrackedItem(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.stockTrackedItems = this.stockTrackedItems.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"stockTrackedItems\", rule: (v: any) => !!v || \"stockTrackedItems is required\"},\n {field: \"stockTrackedItems\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockTrackedItem[]).reduce((acc: Array, curr: StockTrackedItem) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class PurchasableItemAtLocation extends ModelObject {\n\n /**\n * Stock Item Id\n */\n public stockItemId: Guid = Guid.createEmpty();\n /**\n * Stock Location Id\n */\n public stockLocationId: Guid = Guid.createEmpty();\n private _reorderLevel: number | null = null;\n /**\n * The level at which users should re-order stock.\n * Not Negative\n */\n public get reorderLevel(): number | null { return this._reorderLevel }\n public set reorderLevel(value: number | null) {\n this._reorderLevel = value === undefined ? null : value;\n }\n private _reorderQuantity: number | null = null;\n /**\n * The default amount that the user should order.\n * Not Negative\n */\n public get reorderQuantity(): number | null { return this._reorderQuantity }\n public set reorderQuantity(value: number | null) {\n this._reorderQuantity = value === undefined ? null : value;\n }\n private _stockLevelAlert: number | null = null;\n /**\n * The level at which the user should be notified that more stock is required.\n * Not Negative\n */\n public get stockLevelAlert(): number | null { return this._stockLevelAlert }\n public set stockLevelAlert(value: number | null) {\n this._stockLevelAlert = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.reorderLevel = jsonSerializedObject.reorderLevel == null ? null : jsonSerializedObject.reorderLevel;\n this.reorderQuantity = jsonSerializedObject.reorderQuantity == null ? null : jsonSerializedObject.reorderQuantity;\n this.stockLevelAlert = jsonSerializedObject.stockLevelAlert == null ? null : jsonSerializedObject.stockLevelAlert;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.reorderLevel = this.reorderLevel == null ? null : this.reorderLevel;\n toRet.reorderQuantity = this.reorderQuantity == null ? null : this.reorderQuantity;\n toRet.stockLevelAlert = this.stockLevelAlert == null ? null : this.stockLevelAlert;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"PurchasableItemAtLocation.StockItemId cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \"PurchasableItemAtLocation.StockLocationId cannot be empty\"},\n ];\n}\n\n\nexport class DeliveryServiceItem extends BaseModelObject {\n\n public details: Details = new Details();\n public invoicing: Invoicing = new Invoicing();\n public vat: Vat = new Vat();\n public externalCodes: ExternalCodes = new ExternalCodes();\n public flatPricing: FlatPricing = new FlatPricing();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.details = new Details(jsonSerializedObject.details);\n this.invoicing = new Invoicing(jsonSerializedObject.invoicing);\n this.vat = new Vat(jsonSerializedObject.vat);\n this.externalCodes = new ExternalCodes(jsonSerializedObject.externalCodes);\n this.flatPricing = new FlatPricing(jsonSerializedObject.flatPricing);\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.details = this.details.toJsonSerializedObject();\n toRet.invoicing = this.invoicing.toJsonSerializedObject();\n toRet.vat = this.vat.toJsonSerializedObject();\n toRet.externalCodes = this.externalCodes.toJsonSerializedObject();\n toRet.flatPricing = this.flatPricing.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"details\", rule: (v: any) => !!v || \"details is required\"},\n {field: \"details\", rule: (v: any) => v.validate()},\n {field: \"invoicing\", rule: (v: any) => !!v || \"invoicing is required\"},\n {field: \"invoicing\", rule: (v: any) => v.validate()},\n {field: \"vat\", rule: (v: any) => !!v || \"vat is required\"},\n {field: \"vat\", rule: (v: any) => v.validate()},\n {field: \"externalCodes\", rule: (v: any) => !!v || \"externalCodes is required\"},\n {field: \"externalCodes\", rule: (v: any) => v.validate()},\n {field: \"flatPricing\", rule: (v: any) => !!v || \"flatPricing is required\"},\n {field: \"flatPricing\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class BottleDepositChargeItem extends BaseModelObject {\n\n public details: Details = new Details();\n public invoicing: Invoicing = new Invoicing();\n public vat: Vat = new Vat();\n public externalCodes: ExternalCodes = new ExternalCodes();\n public flatPricing: FlatPricing = new FlatPricing();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.details = new Details(jsonSerializedObject.details);\n this.invoicing = new Invoicing(jsonSerializedObject.invoicing);\n this.vat = new Vat(jsonSerializedObject.vat);\n this.externalCodes = new ExternalCodes(jsonSerializedObject.externalCodes);\n this.flatPricing = new FlatPricing(jsonSerializedObject.flatPricing);\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.details = this.details.toJsonSerializedObject();\n toRet.invoicing = this.invoicing.toJsonSerializedObject();\n toRet.vat = this.vat.toJsonSerializedObject();\n toRet.externalCodes = this.externalCodes.toJsonSerializedObject();\n toRet.flatPricing = this.flatPricing.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"details\", rule: (v: any) => !!v || \"details is required\"},\n {field: \"details\", rule: (v: any) => v.validate()},\n {field: \"invoicing\", rule: (v: any) => !!v || \"invoicing is required\"},\n {field: \"invoicing\", rule: (v: any) => v.validate()},\n {field: \"vat\", rule: (v: any) => !!v || \"vat is required\"},\n {field: \"vat\", rule: (v: any) => v.validate()},\n {field: \"externalCodes\", rule: (v: any) => !!v || \"externalCodes is required\"},\n {field: \"externalCodes\", rule: (v: any) => v.validate()},\n {field: \"flatPricing\", rule: (v: any) => !!v || \"flatPricing is required\"},\n {field: \"flatPricing\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class BottleDepositRedemptionItem extends BaseModelObject {\n\n public details: Details = new Details();\n public invoicing: Invoicing = new Invoicing();\n public vat: Vat = new Vat();\n public externalCodes: ExternalCodes = new ExternalCodes();\n /**\n * FlatPricing required to avoid appearing on price lists. Actual price within is typically ignored as the redemption is typically based on the available balance. So set contents to 0.00 Ex Vat for convenience.\n */\n public flatPricing: FlatPricing = new FlatPricing();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.details = new Details(jsonSerializedObject.details);\n this.invoicing = new Invoicing(jsonSerializedObject.invoicing);\n this.vat = new Vat(jsonSerializedObject.vat);\n this.externalCodes = new ExternalCodes(jsonSerializedObject.externalCodes);\n this.flatPricing = new FlatPricing(jsonSerializedObject.flatPricing);\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.details = this.details.toJsonSerializedObject();\n toRet.invoicing = this.invoicing.toJsonSerializedObject();\n toRet.vat = this.vat.toJsonSerializedObject();\n toRet.externalCodes = this.externalCodes.toJsonSerializedObject();\n toRet.flatPricing = this.flatPricing.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"details\", rule: (v: any) => !!v || \"details is required\"},\n {field: \"details\", rule: (v: any) => v.validate()},\n {field: \"invoicing\", rule: (v: any) => !!v || \"invoicing is required\"},\n {field: \"invoicing\", rule: (v: any) => v.validate()},\n {field: \"vat\", rule: (v: any) => !!v || \"vat is required\"},\n {field: \"vat\", rule: (v: any) => v.validate()},\n {field: \"externalCodes\", rule: (v: any) => !!v || \"externalCodes is required\"},\n {field: \"externalCodes\", rule: (v: any) => v.validate()},\n {field: \"flatPricing\", rule: (v: any) => !!v || \"flatPricing is required\"},\n {field: \"flatPricing\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class AutoAssembledItem extends ModelObject {\n\n public details: Details = new Details();\n public invoicing: Invoicing = new Invoicing();\n public vat: Vat = new Vat();\n private _alcoholDuty: AlcoholDuty | null = null;\n public get alcoholDuty(): AlcoholDuty | null { return this._alcoholDuty }\n public set alcoholDuty(value: AlcoholDuty | null) {\n this._alcoholDuty = value === undefined ? null : value;\n }\n public externalCodes: ExternalCodes = new ExternalCodes();\n private _flatPricing: FlatPricing | null = null;\n public get flatPricing(): FlatPricing | null { return this._flatPricing }\n public set flatPricing(value: FlatPricing | null) {\n this._flatPricing = value === undefined ? null : value;\n }\n public packaging: Packaging = new Packaging();\n public bom: AutoAssemblyBomLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.details = new Details(jsonSerializedObject.details);\n this.invoicing = new Invoicing(jsonSerializedObject.invoicing);\n this.vat = new Vat(jsonSerializedObject.vat);\n this.alcoholDuty = jsonSerializedObject.alcoholDuty == null ? null : new AlcoholDuty(jsonSerializedObject.alcoholDuty);\n this.externalCodes = new ExternalCodes(jsonSerializedObject.externalCodes);\n this.flatPricing = jsonSerializedObject.flatPricing == null ? null : new FlatPricing(jsonSerializedObject.flatPricing);\n this.packaging = new Packaging(jsonSerializedObject.packaging);\n this.bom = jsonSerializedObject.bom.map((v: any) => new AutoAssemblyBomLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.details = this.details.toJsonSerializedObject();\n toRet.invoicing = this.invoicing.toJsonSerializedObject();\n toRet.vat = this.vat.toJsonSerializedObject();\n toRet.alcoholDuty = this.alcoholDuty == null ? null : this.alcoholDuty?.toJsonSerializedObject() ?? null;\n toRet.externalCodes = this.externalCodes.toJsonSerializedObject();\n toRet.flatPricing = this.flatPricing == null ? null : this.flatPricing?.toJsonSerializedObject() ?? null;\n toRet.packaging = this.packaging.toJsonSerializedObject();\n toRet.bom = this.bom.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"details\", rule: (v: any) => !!v || \"details is required\"},\n {field: \"details\", rule: (v: any) => v.validate()},\n {field: \"invoicing\", rule: (v: any) => !!v || \"invoicing is required\"},\n {field: \"invoicing\", rule: (v: any) => v.validate()},\n {field: \"vat\", rule: (v: any) => !!v || \"vat is required\"},\n {field: \"vat\", rule: (v: any) => v.validate()},\n {field: \"alcoholDuty\", rule: (v: any) => (v === null) || v.validate()},\n {field: \"externalCodes\", rule: (v: any) => !!v || \"externalCodes is required\"},\n {field: \"externalCodes\", rule: (v: any) => v.validate()},\n {field: \"flatPricing\", rule: (v: any) => (v === null) || v.validate()},\n {field: \"packaging\", rule: (v: any) => !!v || \"packaging is required\"},\n {field: \"packaging\", rule: (v: any) => v.validate()},\n {field: \"bom\", rule: (v: any) => !!v || \"bom is required\"},\n {field: \"bom\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AutoAssemblyBomLine[]).reduce((acc: Array, curr: AutoAssemblyBomLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class FilteredAutoAssembledItems extends ModelObject {\n\n public matchingCount: number = 0;\n public autoAssembledItems: AutoAssembledItem[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.autoAssembledItems = jsonSerializedObject.autoAssembledItems.map((v: any) => new AutoAssembledItem(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.autoAssembledItems = this.autoAssembledItems.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"autoAssembledItems\", rule: (v: any) => !!v || \"autoAssembledItems is required\"},\n {field: \"autoAssembledItems\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AutoAssembledItem[]).reduce((acc: Array, curr: AutoAssembledItem) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class PoDeliveryServiceItem extends BaseModelObject {\n\n public details: Details = new Details();\n public vat: Vat = new Vat();\n /**\n * Purchasing details are required in order to appear on a purchase order but some details may not be relevant (Eg price is likely to always be overwritten) and should be set to sensible defaults - Eg 0.\n */\n public purchasingDetails: PurchasingDetails[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.details = new Details(jsonSerializedObject.details);\n this.vat = new Vat(jsonSerializedObject.vat);\n this.purchasingDetails = jsonSerializedObject.purchasingDetails.map((v: any) => new PurchasingDetails(v));\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.details = this.details.toJsonSerializedObject();\n toRet.vat = this.vat.toJsonSerializedObject();\n toRet.purchasingDetails = this.purchasingDetails.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"details\", rule: (v: any) => !!v || \"details is required\"},\n {field: \"details\", rule: (v: any) => v.validate()},\n {field: \"vat\", rule: (v: any) => !!v || \"vat is required\"},\n {field: \"vat\", rule: (v: any) => v.validate()},\n {field: \"purchasingDetails\", rule: (v: any) => !!v || \"purchasingDetails is required\"},\n {field: \"purchasingDetails\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PurchasingDetails[]).reduce((acc: Array, curr: PurchasingDetails) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GenerateItemCodeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public name: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.name = jsonSerializedObject.name;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.name = this.name;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n ];\n}\n\n\nexport class GenerateItemCodeResponse extends ModelObject {\n\n /**\n * Code\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public code: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.code = jsonSerializedObject.code;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.code = this.code;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"code\", rule: (v: any) => v == null || v.length !== 0 || \"Code cannot be empty\"},\n {field: \"code\", rule: (v: any) => v == null || v.length <= 1000 || \"Code has too many characters (1000)\"},\n ];\n}\n\n\nexport class GetItemRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public itemId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.itemId = Guid.fromString(jsonSerializedObject.itemId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.itemId = this.itemId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"itemId\", rule: (v: any) => !v.isEmpty() || \".ItemId cannot be empty\"},\n ];\n}\n\n\nexport class GetItemResponse extends ModelObject {\n\n public item: Item = new Item();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.item = new Item(jsonSerializedObject.item);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.item = this.item.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"item\", rule: (v: any) => !!v || \"item is required\"},\n {field: \"item\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetItemsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public itemIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.itemIds = jsonSerializedObject.itemIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.itemIds = this.itemIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetItemsResponse extends ModelObject {\n\n public items: Item[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.items = jsonSerializedObject.items.map((v: any) => new Item(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.items = this.items.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"items\", rule: (v: any) => !!v || \"items is required\"},\n {field: \"items\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Item[]).reduce((acc: Array, curr: Item) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllItemsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllItemsResponse extends ModelObject {\n\n public items: Item[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.items = jsonSerializedObject.items.map((v: any) => new Item(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.items = this.items.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"items\", rule: (v: any) => !!v || \"items is required\"},\n {field: \"items\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Item[]).reduce((acc: Array, curr: Item) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SetItemIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public itemId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.itemId = Guid.fromString(jsonSerializedObject.itemId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.itemId = this.itemId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"itemId\", rule: (v: any) => !v.isEmpty() || \".ItemId cannot be empty\"},\n ];\n}\n\n\nexport class EvaluateExpectedDutyForItemsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public itemIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.itemIds = jsonSerializedObject.itemIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.itemIds = this.itemIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class EvaluateExpectedDutyForItemsResponse extends ModelObject {\n\n public expectedDutyForItemResult: ExpectedDutyForItemResult[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.expectedDutyForItemResult = jsonSerializedObject.expectedDutyForItemResult.map((v: any) => new ExpectedDutyForItemResult(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.expectedDutyForItemResult = this.expectedDutyForItemResult.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"expectedDutyForItemResult\", rule: (v: any) => !!v || \"expectedDutyForItemResult is required\"},\n {field: \"expectedDutyForItemResult\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ExpectedDutyForItemResult[]).reduce((acc: Array, curr: ExpectedDutyForItemResult) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveItemRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public item: Item = new Item();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.item = new Item(jsonSerializedObject.item);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.item = this.item.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"item\", rule: (v: any) => !!v || \"item is required\"},\n {field: \"item\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetItemsByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: ItemFilter = new ItemFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new ItemFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetItemsByFilterResponse extends ModelObject {\n\n public results: FilteredItems = new FilteredItems();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredItems(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetInvoiceableItemRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public itemId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.itemId = Guid.fromString(jsonSerializedObject.itemId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.itemId = this.itemId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"itemId\", rule: (v: any) => !v.isEmpty() || \".ItemId cannot be empty\"},\n ];\n}\n\n\nexport class GetInvoiceableItemResponse extends ModelObject {\n\n public invoiceableItem: InvoiceableItem = new InvoiceableItem();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.invoiceableItem = new InvoiceableItem(jsonSerializedObject.invoiceableItem);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.invoiceableItem = this.invoiceableItem.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"invoiceableItem\", rule: (v: any) => !!v || \"invoiceableItem is required\"},\n {field: \"invoiceableItem\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetInvoiceableItemsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public itemIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.itemIds = jsonSerializedObject.itemIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.itemIds = this.itemIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetInvoiceableItemsResponse extends ModelObject {\n\n public invoiceableItems: InvoiceableItem[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.invoiceableItems = jsonSerializedObject.invoiceableItems.map((v: any) => new InvoiceableItem(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.invoiceableItems = this.invoiceableItems.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"invoiceableItems\", rule: (v: any) => !!v || \"invoiceableItems is required\"},\n {field: \"invoiceableItems\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as InvoiceableItem[]).reduce((acc: Array, curr: InvoiceableItem) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllInvoiceableItemsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllInvoiceableItemsResponse extends ModelObject {\n\n public invoiceableItems: InvoiceableItem[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.invoiceableItems = jsonSerializedObject.invoiceableItems.map((v: any) => new InvoiceableItem(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.invoiceableItems = this.invoiceableItems.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"invoiceableItems\", rule: (v: any) => !!v || \"invoiceableItems is required\"},\n {field: \"invoiceableItems\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as InvoiceableItem[]).reduce((acc: Array, curr: InvoiceableItem) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetInvoiceableItemsByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: ItemFilter = new ItemFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new ItemFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetInvoiceableItemsByFilterResponse extends ModelObject {\n\n public results: FilteredInvoiceableItems = new FilteredInvoiceableItems();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredInvoiceableItems(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetInvoiceableItemsWhichCurrentlyAllowSalesByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: ItemFilter = new ItemFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new ItemFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetInvoiceableItemsWhichCurrentlyAllowSalesByFilterResponse extends ModelObject {\n\n public results: FilteredInvoiceableItems = new FilteredInvoiceableItems();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredInvoiceableItems(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetGlCodeOverridesForInvoiceableItemRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public invoiceableItemId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.invoiceableItemId = Guid.fromString(jsonSerializedObject.invoiceableItemId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.invoiceableItemId = this.invoiceableItemId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"invoiceableItemId\", rule: (v: any) => !v.isEmpty() || \".InvoiceableItemId cannot be empty\"},\n ];\n}\n\n\nexport class GetGlCodeOverridesForInvoiceableItemResponse extends ModelObject {\n\n public glCodeOverrides: GlCodeOverrideForItem[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.glCodeOverrides = jsonSerializedObject.glCodeOverrides.map((v: any) => new GlCodeOverrideForItem(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.glCodeOverrides = this.glCodeOverrides.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"glCodeOverrides\", rule: (v: any) => !!v || \"glCodeOverrides is required\"},\n {field: \"glCodeOverrides\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as GlCodeOverrideForItem[]).reduce((acc: Array, curr: GlCodeOverrideForItem) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class UpdateInvoiceableItemGlCodeOverridesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public invoiceableItemId: Guid = Guid.createEmpty();\n private _expectedVersion: number | null = null;\n public get expectedVersion(): number | null { return this._expectedVersion }\n public set expectedVersion(value: number | null) {\n this._expectedVersion = value === undefined ? null : value;\n }\n public glCodeOverrides: readonly GlCodeOverrideForItem[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.invoiceableItemId = Guid.fromString(jsonSerializedObject.invoiceableItemId);\n this.expectedVersion = jsonSerializedObject.expectedVersion == null ? null : jsonSerializedObject.expectedVersion;\n this.glCodeOverrides = jsonSerializedObject.glCodeOverrides.map((v: any) => new GlCodeOverrideForItem(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.invoiceableItemId = this.invoiceableItemId.toString();\n toRet.expectedVersion = this.expectedVersion == null ? null : this.expectedVersion;\n toRet.glCodeOverrides = this.glCodeOverrides.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"invoiceableItemId\", rule: (v: any) => !v.isEmpty() || \".InvoiceableItemId cannot be empty\"},\n {field: \"expectedVersion\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"ExpectedVersion is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"expectedVersion\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"ExpectedVersion is above maximum allowed value: 9223372036854775807\"},\n {field: \"glCodeOverrides\", rule: (v: any) => !!v || \"glCodeOverrides is required\"},\n {field: \"glCodeOverrides\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as GlCodeOverrideForItem[]).reduce((acc: Array, curr: GlCodeOverrideForItem) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetStockTrackedItemsByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: ItemFilter = new ItemFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new ItemFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetStockTrackedItemsByFilterResponse extends ModelObject {\n\n public results: FilteredStockTrackedItems = new FilteredStockTrackedItems();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredStockTrackedItems(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SavePurchasableItemAtLocationRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public purchasableItemAtLocation: PurchasableItemAtLocation = new PurchasableItemAtLocation();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.purchasableItemAtLocation = new PurchasableItemAtLocation(jsonSerializedObject.purchasableItemAtLocation);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.purchasableItemAtLocation = this.purchasableItemAtLocation.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"purchasableItemAtLocation\", rule: (v: any) => !!v || \"purchasableItemAtLocation is required\"},\n {field: \"purchasableItemAtLocation\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetPurchasableItemAtLocationsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n private _stockItemIds: readonly Guid[] | null = null;\n public get stockItemIds(): readonly Guid[] | null { return this._stockItemIds }\n public set stockItemIds(value: readonly Guid[] | null) {\n this._stockItemIds = value === undefined ? null : value;\n }\n private _stockLocationIds: readonly Guid[] | null = null;\n public get stockLocationIds(): readonly Guid[] | null { return this._stockLocationIds }\n public set stockLocationIds(value: readonly Guid[] | null) {\n this._stockLocationIds = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockItemIds = jsonSerializedObject.stockItemIds == null ? null : jsonSerializedObject.stockItemIds.map((v: any) => Guid.fromString(v));\n this.stockLocationIds = jsonSerializedObject.stockLocationIds == null ? null : jsonSerializedObject.stockLocationIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockItemIds = this.stockItemIds == null ? null : this.stockItemIds.map(v => v.toString());\n toRet.stockLocationIds = this.stockLocationIds == null ? null : this.stockLocationIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetPurchasableItemAtLocationsResponse extends ModelObject {\n\n public purchasableItemAtLocations: PurchasableItemAtLocation[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.purchasableItemAtLocations = jsonSerializedObject.purchasableItemAtLocations.map((v: any) => new PurchasableItemAtLocation(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.purchasableItemAtLocations = this.purchasableItemAtLocations.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"purchasableItemAtLocations\", rule: (v: any) => !!v || \"purchasableItemAtLocations is required\"},\n {field: \"purchasableItemAtLocations\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PurchasableItemAtLocation[]).reduce((acc: Array, curr: PurchasableItemAtLocation) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllDeliveryServiceItemsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllDeliveryServiceItemsResponse extends ModelObject {\n\n public deliveryServiceItem: DeliveryServiceItem[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.deliveryServiceItem = jsonSerializedObject.deliveryServiceItem.map((v: any) => new DeliveryServiceItem(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.deliveryServiceItem = this.deliveryServiceItem.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"deliveryServiceItem\", rule: (v: any) => !!v || \"deliveryServiceItem is required\"},\n {field: \"deliveryServiceItem\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as DeliveryServiceItem[]).reduce((acc: Array, curr: DeliveryServiceItem) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetDeliveryServiceItemRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public itemId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.itemId = Guid.fromString(jsonSerializedObject.itemId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.itemId = this.itemId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"itemId\", rule: (v: any) => !v.isEmpty() || \".ItemId cannot be empty\"},\n ];\n}\n\n\nexport class GetDeliveryServiceItemResponse extends ModelObject {\n\n public deliveryServiceItem: DeliveryServiceItem = new DeliveryServiceItem();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.deliveryServiceItem = new DeliveryServiceItem(jsonSerializedObject.deliveryServiceItem);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.deliveryServiceItem = this.deliveryServiceItem.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"deliveryServiceItem\", rule: (v: any) => !!v || \"deliveryServiceItem is required\"},\n {field: \"deliveryServiceItem\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveDeliveryServiceItemRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public deliveryServiceItem: DeliveryServiceItem = new DeliveryServiceItem();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.deliveryServiceItem = new DeliveryServiceItem(jsonSerializedObject.deliveryServiceItem);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.deliveryServiceItem = this.deliveryServiceItem.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"deliveryServiceItem\", rule: (v: any) => !!v || \"deliveryServiceItem is required\"},\n {field: \"deliveryServiceItem\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetAllBottleDepositChargeItemsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllBottleDepositChargeItemsResponse extends ModelObject {\n\n public items: BottleDepositChargeItem[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.items = jsonSerializedObject.items.map((v: any) => new BottleDepositChargeItem(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.items = this.items.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"items\", rule: (v: any) => !!v || \"items is required\"},\n {field: \"items\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as BottleDepositChargeItem[]).reduce((acc: Array, curr: BottleDepositChargeItem) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetBottleDepositChargeItemRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public itemId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.itemId = Guid.fromString(jsonSerializedObject.itemId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.itemId = this.itemId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"itemId\", rule: (v: any) => !v.isEmpty() || \".ItemId cannot be empty\"},\n ];\n}\n\n\nexport class GetBottleDepositChargeItemResponse extends ModelObject {\n\n public item: BottleDepositChargeItem = new BottleDepositChargeItem();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.item = new BottleDepositChargeItem(jsonSerializedObject.item);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.item = this.item.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"item\", rule: (v: any) => !!v || \"item is required\"},\n {field: \"item\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetBottleDepositChargeItemsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public itemIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.itemIds = jsonSerializedObject.itemIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.itemIds = this.itemIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetBottleDepositChargeItemsResponse extends ModelObject {\n\n public items: BottleDepositChargeItem[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.items = jsonSerializedObject.items.map((v: any) => new BottleDepositChargeItem(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.items = this.items.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"items\", rule: (v: any) => !!v || \"items is required\"},\n {field: \"items\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as BottleDepositChargeItem[]).reduce((acc: Array, curr: BottleDepositChargeItem) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveBottleDepositChargeItemRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public item: BottleDepositChargeItem = new BottleDepositChargeItem();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.item = new BottleDepositChargeItem(jsonSerializedObject.item);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.item = this.item.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"item\", rule: (v: any) => !!v || \"item is required\"},\n {field: \"item\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetBottleDepositRedemptionItemRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetBottleDepositRedemptionItemResponse extends ModelObject {\n\n private _item: BottleDepositRedemptionItem | null = null;\n public get item(): BottleDepositRedemptionItem | null { return this._item }\n public set item(value: BottleDepositRedemptionItem | null) {\n this._item = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.item = jsonSerializedObject.item == null ? null : new BottleDepositRedemptionItem(jsonSerializedObject.item);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.item = this.item == null ? null : this.item?.toJsonSerializedObject() ?? null;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"item\", rule: (v: any) => (v === null) || v.validate()},\n ];\n}\n\n\nexport class SaveBottleDepositRedemptionItemRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public item: BottleDepositRedemptionItem = new BottleDepositRedemptionItem();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.item = new BottleDepositRedemptionItem(jsonSerializedObject.item);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.item = this.item.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"item\", rule: (v: any) => !!v || \"item is required\"},\n {field: \"item\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetAutoAssembledItemRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public itemId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.itemId = Guid.fromString(jsonSerializedObject.itemId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.itemId = this.itemId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"itemId\", rule: (v: any) => !v.isEmpty() || \".ItemId cannot be empty\"},\n ];\n}\n\n\nexport class GetAutoAssembledItemResponse extends ModelObject {\n\n public autoAssembledItem: AutoAssembledItem = new AutoAssembledItem();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.autoAssembledItem = new AutoAssembledItem(jsonSerializedObject.autoAssembledItem);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.autoAssembledItem = this.autoAssembledItem.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"autoAssembledItem\", rule: (v: any) => !!v || \"autoAssembledItem is required\"},\n {field: \"autoAssembledItem\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetAutoAssembledItemsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public itemIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.itemIds = jsonSerializedObject.itemIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.itemIds = this.itemIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAutoAssembledItemsResponse extends ModelObject {\n\n public autoAssembledItems: AutoAssembledItem[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.autoAssembledItems = jsonSerializedObject.autoAssembledItems.map((v: any) => new AutoAssembledItem(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.autoAssembledItems = this.autoAssembledItems.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"autoAssembledItems\", rule: (v: any) => !!v || \"autoAssembledItems is required\"},\n {field: \"autoAssembledItems\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AutoAssembledItem[]).reduce((acc: Array, curr: AutoAssembledItem) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllAutoAssembledItemsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllAutoAssembledItemsResponse extends ModelObject {\n\n public autoAssembledItems: AutoAssembledItem[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.autoAssembledItems = jsonSerializedObject.autoAssembledItems.map((v: any) => new AutoAssembledItem(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.autoAssembledItems = this.autoAssembledItems.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"autoAssembledItems\", rule: (v: any) => !!v || \"autoAssembledItems is required\"},\n {field: \"autoAssembledItems\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AutoAssembledItem[]).reduce((acc: Array, curr: AutoAssembledItem) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveAutoAssembledItemRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public autoAssembledItem: AutoAssembledItem = new AutoAssembledItem();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.autoAssembledItem = new AutoAssembledItem(jsonSerializedObject.autoAssembledItem);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.autoAssembledItem = this.autoAssembledItem.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"autoAssembledItem\", rule: (v: any) => !!v || \"autoAssembledItem is required\"},\n {field: \"autoAssembledItem\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetAutoAssembledItemsByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: ItemFilter = new ItemFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new ItemFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetAutoAssembledItemsByFilterResponse extends ModelObject {\n\n public results: FilteredAutoAssembledItems = new FilteredAutoAssembledItems();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredAutoAssembledItems(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetAutoAssembledItemsWhichContainGivenItemsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public childItemIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.childItemIds = jsonSerializedObject.childItemIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.childItemIds = this.childItemIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAutoAssembledItemsWhichContainGivenItemsResponse extends ModelObject {\n\n public autoAssembledItems: AutoAssembledItem[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.autoAssembledItems = jsonSerializedObject.autoAssembledItems.map((v: any) => new AutoAssembledItem(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.autoAssembledItems = this.autoAssembledItems.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"autoAssembledItems\", rule: (v: any) => !!v || \"autoAssembledItems is required\"},\n {field: \"autoAssembledItems\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as AutoAssembledItem[]).reduce((acc: Array, curr: AutoAssembledItem) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetPoDeliveryServiceItemRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetPoDeliveryServiceItemResponse extends ModelObject {\n\n private _item: PoDeliveryServiceItem | null = null;\n public get item(): PoDeliveryServiceItem | null { return this._item }\n public set item(value: PoDeliveryServiceItem | null) {\n this._item = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.item = jsonSerializedObject.item == null ? null : new PoDeliveryServiceItem(jsonSerializedObject.item);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.item = this.item == null ? null : this.item?.toJsonSerializedObject() ?? null;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"item\", rule: (v: any) => (v === null) || v.validate()},\n ];\n}\n\n\nexport class SavePoDeliveryServiceItemRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public item: PoDeliveryServiceItem = new PoDeliveryServiceItem();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.item = new PoDeliveryServiceItem(jsonSerializedObject.item);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.item = this.item.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"item\", rule: (v: any) => !!v || \"item is required\"},\n {field: \"item\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class ItemService extends ServiceBase {\n\n public async generateItemCode(tenantId: Guid, name: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GenerateItemCodeRequest();\n req.tenantId = tenantId;\n req.name = name;\n const extractor = (response:any) => new GenerateItemCodeResponse(response).code;\n return this.makeJsonRequest(\"item/v1/generateItemCode\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getItem(tenantId: Guid, itemId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetItemRequest();\n req.tenantId = tenantId;\n req.itemId = itemId;\n const extractor = (response:any) => new GetItemResponse(response).item;\n return this.makeJsonRequest(\"item/v1/getItem\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getItems(tenantId: Guid, itemIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetItemsRequest();\n req.tenantId = tenantId;\n req.itemIds = itemIds;\n const extractor = (response:any) => new GetItemsResponse(response).items;\n return this.makeJsonRequest(\"item/v1/getItems\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllItems(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllItemsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllItemsResponse(response).items;\n return this.makeJsonRequest(\"item/v1/getAllItems\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setItemIsHidden(tenantId: Guid, itemId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetItemIsHiddenRequest();\n req.tenantId = tenantId;\n req.itemId = itemId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"item/v1/setItemIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async evaluateExpectedDutyForItems(tenantId: Guid, itemIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new EvaluateExpectedDutyForItemsRequest();\n req.tenantId = tenantId;\n req.itemIds = itemIds;\n const extractor = (response:any) => new EvaluateExpectedDutyForItemsResponse(response).expectedDutyForItemResult;\n return this.makeJsonRequest(\"item/v1/evaluateExpectedDutyForItems\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveItem(tenantId: Guid, item: Item, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveItemRequest();\n req.tenantId = tenantId;\n req.item = item;\n const extractor = null;\n return this.makeJsonRequest(\"item/v1/saveItem\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getItemsByFilter(tenantId: Guid, filter: ItemFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetItemsByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetItemsByFilterResponse(response).results;\n return this.makeJsonRequest(\"item/v1/getItemsByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getInvoiceableItem(tenantId: Guid, itemId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetInvoiceableItemRequest();\n req.tenantId = tenantId;\n req.itemId = itemId;\n const extractor = (response:any) => new GetInvoiceableItemResponse(response).invoiceableItem;\n return this.makeJsonRequest(\"item/v1/getInvoiceableItem\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getInvoiceableItems(tenantId: Guid, itemIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetInvoiceableItemsRequest();\n req.tenantId = tenantId;\n req.itemIds = itemIds;\n const extractor = (response:any) => new GetInvoiceableItemsResponse(response).invoiceableItems;\n return this.makeJsonRequest(\"item/v1/getInvoiceableItems\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllInvoiceableItems(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllInvoiceableItemsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllInvoiceableItemsResponse(response).invoiceableItems;\n return this.makeJsonRequest(\"item/v1/getAllInvoiceableItems\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getInvoiceableItemsByFilter(tenantId: Guid, filter: ItemFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetInvoiceableItemsByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetInvoiceableItemsByFilterResponse(response).results;\n return this.makeJsonRequest(\"item/v1/getInvoiceableItemsByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getInvoiceableItemsWhichCurrentlyAllowSalesByFilter(tenantId: Guid, filter: ItemFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetInvoiceableItemsWhichCurrentlyAllowSalesByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetInvoiceableItemsWhichCurrentlyAllowSalesByFilterResponse(response).results;\n return this.makeJsonRequest(\"item/v1/getInvoiceableItemsWhichCurrentlyAllowSalesByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getGlCodeOverridesForInvoiceableItem(tenantId: Guid, invoiceableItemId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetGlCodeOverridesForInvoiceableItemRequest();\n req.tenantId = tenantId;\n req.invoiceableItemId = invoiceableItemId;\n const extractor = (response:any) => new GetGlCodeOverridesForInvoiceableItemResponse(response).glCodeOverrides;\n return this.makeJsonRequest(\"item/v1/getGlCodeOverridesForInvoiceableItem\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updateInvoiceableItemGlCodeOverrides(tenantId: Guid, invoiceableItemId: Guid, expectedVersion: number | null, glCodeOverrides: readonly GlCodeOverrideForItem[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdateInvoiceableItemGlCodeOverridesRequest();\n req.tenantId = tenantId;\n req.invoiceableItemId = invoiceableItemId;\n req.expectedVersion = expectedVersion;\n req.glCodeOverrides = glCodeOverrides;\n const extractor = null;\n return this.makeJsonRequest(\"item/v1/updateInvoiceableItemGlCodeOverrides\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getStockTrackedItemsByFilter(tenantId: Guid, filter: ItemFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetStockTrackedItemsByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetStockTrackedItemsByFilterResponse(response).results;\n return this.makeJsonRequest(\"item/v1/getStockTrackedItemsByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async savePurchasableItemAtLocation(tenantId: Guid, purchasableItemAtLocation: PurchasableItemAtLocation, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SavePurchasableItemAtLocationRequest();\n req.tenantId = tenantId;\n req.purchasableItemAtLocation = purchasableItemAtLocation;\n const extractor = null;\n return this.makeJsonRequest(\"item/v1/savePurchasableItemAtLocation\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getPurchasableItemAtLocations(tenantId: Guid, stockItemIds: readonly Guid[] | null, stockLocationIds: readonly Guid[] | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPurchasableItemAtLocationsRequest();\n req.tenantId = tenantId;\n req.stockItemIds = stockItemIds;\n req.stockLocationIds = stockLocationIds;\n const extractor = (response:any) => new GetPurchasableItemAtLocationsResponse(response).purchasableItemAtLocations;\n return this.makeJsonRequest(\"item/v1/getPurchasableItemAtLocations\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllDeliveryServiceItems(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllDeliveryServiceItemsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllDeliveryServiceItemsResponse(response).deliveryServiceItem;\n return this.makeJsonRequest(\"item/v1/getAllDeliveryServiceItems\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getDeliveryServiceItem(tenantId: Guid, itemId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetDeliveryServiceItemRequest();\n req.tenantId = tenantId;\n req.itemId = itemId;\n const extractor = (response:any) => new GetDeliveryServiceItemResponse(response).deliveryServiceItem;\n return this.makeJsonRequest(\"item/v1/getDeliveryServiceItem\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveDeliveryServiceItem(tenantId: Guid, deliveryServiceItem: DeliveryServiceItem, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveDeliveryServiceItemRequest();\n req.tenantId = tenantId;\n req.deliveryServiceItem = deliveryServiceItem;\n const extractor = null;\n return this.makeJsonRequest(\"item/v1/saveDeliveryServiceItem\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllBottleDepositChargeItems(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllBottleDepositChargeItemsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllBottleDepositChargeItemsResponse(response).items;\n return this.makeJsonRequest(\"item/v1/getAllBottleDepositChargeItems\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getBottleDepositChargeItem(tenantId: Guid, itemId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetBottleDepositChargeItemRequest();\n req.tenantId = tenantId;\n req.itemId = itemId;\n const extractor = (response:any) => new GetBottleDepositChargeItemResponse(response).item;\n return this.makeJsonRequest(\"item/v1/getBottleDepositChargeItem\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getBottleDepositChargeItems(tenantId: Guid, itemIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetBottleDepositChargeItemsRequest();\n req.tenantId = tenantId;\n req.itemIds = itemIds;\n const extractor = (response:any) => new GetBottleDepositChargeItemsResponse(response).items;\n return this.makeJsonRequest(\"item/v1/getBottleDepositChargeItems\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveBottleDepositChargeItem(tenantId: Guid, item: BottleDepositChargeItem, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveBottleDepositChargeItemRequest();\n req.tenantId = tenantId;\n req.item = item;\n const extractor = null;\n return this.makeJsonRequest(\"item/v1/saveBottleDepositChargeItem\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getBottleDepositRedemptionItem(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetBottleDepositRedemptionItemRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetBottleDepositRedemptionItemResponse(response).item;\n return this.makeJsonRequest(\"item/v1/getBottleDepositRedemptionItem\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveBottleDepositRedemptionItem(tenantId: Guid, item: BottleDepositRedemptionItem, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveBottleDepositRedemptionItemRequest();\n req.tenantId = tenantId;\n req.item = item;\n const extractor = null;\n return this.makeJsonRequest(\"item/v1/saveBottleDepositRedemptionItem\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAutoAssembledItem(tenantId: Guid, itemId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAutoAssembledItemRequest();\n req.tenantId = tenantId;\n req.itemId = itemId;\n const extractor = (response:any) => new GetAutoAssembledItemResponse(response).autoAssembledItem;\n return this.makeJsonRequest(\"item/v1/getAutoAssembledItem\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAutoAssembledItems(tenantId: Guid, itemIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAutoAssembledItemsRequest();\n req.tenantId = tenantId;\n req.itemIds = itemIds;\n const extractor = (response:any) => new GetAutoAssembledItemsResponse(response).autoAssembledItems;\n return this.makeJsonRequest(\"item/v1/getAutoAssembledItems\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllAutoAssembledItems(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllAutoAssembledItemsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllAutoAssembledItemsResponse(response).autoAssembledItems;\n return this.makeJsonRequest(\"item/v1/getAllAutoAssembledItems\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveAutoAssembledItem(tenantId: Guid, autoAssembledItem: AutoAssembledItem, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveAutoAssembledItemRequest();\n req.tenantId = tenantId;\n req.autoAssembledItem = autoAssembledItem;\n const extractor = null;\n return this.makeJsonRequest(\"item/v1/saveAutoAssembledItem\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAutoAssembledItemsByFilter(tenantId: Guid, filter: ItemFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAutoAssembledItemsByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetAutoAssembledItemsByFilterResponse(response).results;\n return this.makeJsonRequest(\"item/v1/getAutoAssembledItemsByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAutoAssembledItemsWhichContainGivenItems(tenantId: Guid, childItemIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAutoAssembledItemsWhichContainGivenItemsRequest();\n req.tenantId = tenantId;\n req.childItemIds = childItemIds;\n const extractor = (response:any) => new GetAutoAssembledItemsWhichContainGivenItemsResponse(response).autoAssembledItems;\n return this.makeJsonRequest(\"item/v1/getAutoAssembledItemsWhichContainGivenItems\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getPoDeliveryServiceItem(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPoDeliveryServiceItemRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetPoDeliveryServiceItemResponse(response).item;\n return this.makeJsonRequest(\"item/v1/getPoDeliveryServiceItem\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async savePoDeliveryServiceItem(tenantId: Guid, item: PoDeliveryServiceItem, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SavePoDeliveryServiceItemRequest();\n req.tenantId = tenantId;\n req.item = item;\n const extractor = null;\n return this.makeJsonRequest(\"item/v1/savePoDeliveryServiceItem\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const itemService = new ItemService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\nimport type { Item } from \"@/app/services/generated/itemService\";\nimport { itemService } from \"@/app/services/generated/itemService\";\n\nexport interface IHasItemsCache {\n items: ItemsCache;\n}\n\n// Singleton cache store\nconst itemCacheStore = new EntityCacheStore(\n EnumCacheEntityType.item,\n async () => itemService.getAllItems(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class ItemsCache extends EntityWithGuidKeyCache {\n _deliveryServices: readonly Item[] = [];\n _depositCharges: readonly Item[] = [];\n _depositRedemptionItem: Item | null = null;\n\n constructor() {\n super(itemCacheStore, (x) => x.details.id);\n }\n\n async update(): Promise {\n await super.update();\n this._depositRedemptionItem =\n this.all.find((x) => x.details.mainPurpose.isBottleDepositRedemption()) ??\n null;\n\n this._deliveryServices = this.all.filter((x) =>\n x.details.mainPurpose.isDeliveryService()\n );\n\n this._depositCharges = this.all.filter((x) =>\n x.details.mainPurpose.isBottleDepositCharge()\n );\n }\n\n onlyBatchTracked() {\n return this.allReactive.value.filter(\n (item) => item.stock?.isBatchTracked ?? false\n );\n }\n\n get deliveryServices() {\n return this._deliveryServices;\n }\n\n get depositCharges() {\n return this._depositCharges;\n }\n\n get depositRedemptionItem() {\n return this._depositRedemptionItem;\n }\n\n get depositRedemptionItemId() {\n return this._depositRedemptionItem?.details.id ?? null;\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumCreditCalculationType } from \"./enums/enumCreditCalculationType.generated\";\n\n// Model Objects\n\nexport class CreditTerm extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Day or Days for Terms Calculation\n */\n public calculationDay: number = 0;\n /**\n * Terms Calculation Code : OFM=Of Following Month, DAI=Days After Invoice, DAM=Days After Invoice Month, OCM=Of Current Month\n */\n public calculationType: EnumCreditCalculationType = EnumCreditCalculationType.none;\n /**\n * Credit Terms Description\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n /**\n * Show Balance on Delivery Notes\n */\n public showBalance: boolean = false;\n /**\n * Accounts Analysis Code\n * Not Nullable\n * Max Length : 1000\n */\n public accountsAnalysisCode: string = \"\";\n public isHidden: boolean = false;\n /**\n * Whether to allow pay on account in Trade Portal\n */\n public allowTradePortalPayOnAccount: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.calculationDay = jsonSerializedObject.calculationDay;\n this.calculationType = EnumCreditCalculationType.getByValue(jsonSerializedObject.calculationType, this.calculationType);\n this.name = jsonSerializedObject.name;\n this.showBalance = jsonSerializedObject.showBalance;\n this.accountsAnalysisCode = jsonSerializedObject.accountsAnalysisCode;\n this.isHidden = jsonSerializedObject.isHidden;\n this.allowTradePortalPayOnAccount = jsonSerializedObject.allowTradePortalPayOnAccount;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.calculationDay = this.calculationDay;\n toRet.calculationType = this.calculationType.value;\n toRet.name = this.name;\n toRet.showBalance = this.showBalance;\n toRet.accountsAnalysisCode = this.accountsAnalysisCode;\n toRet.isHidden = this.isHidden;\n toRet.allowTradePortalPayOnAccount = this.allowTradePortalPayOnAccount;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"CreditTerm.Id cannot be empty\"},\n {field: \"calculationDay\", rule: (v: any) => v == null || v >= -2147483648 || \"CalculationDay is not greater than minimum allowed value: -2147483648\"},\n {field: \"calculationDay\", rule: (v: any) => v == null || v <= 2147483647 || \"CalculationDay is above maximum allowed value: 2147483647\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"accountsAnalysisCode\", rule: (v: any) => v == null || v.length <= 1000 || \"AccountsAnalysisCode has too many characters (1000)\"},\n ];\n}\n\n\nexport class GetAllCreditTermsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllCreditTermsResponse extends ModelObject {\n\n public creditTerms: CreditTerm[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.creditTerms = jsonSerializedObject.creditTerms.map((v: any) => new CreditTerm(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.creditTerms = this.creditTerms.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"creditTerms\", rule: (v: any) => !!v || \"creditTerms is required\"},\n {field: \"creditTerms\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as CreditTerm[]).reduce((acc: Array, curr: CreditTerm) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetCreditTermRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditTermId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditTermId = Guid.fromString(jsonSerializedObject.creditTermId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditTermId = this.creditTermId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"creditTermId\", rule: (v: any) => !v.isEmpty() || \".CreditTermId cannot be empty\"},\n ];\n}\n\n\nexport class GetCreditTermResponse extends ModelObject {\n\n public creditTerm: CreditTerm = new CreditTerm();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.creditTerm = new CreditTerm(jsonSerializedObject.creditTerm);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.creditTerm = this.creditTerm.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"creditTerm\", rule: (v: any) => !!v || \"creditTerm is required\"},\n {field: \"creditTerm\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetCreditTermsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditTermIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditTermIds = jsonSerializedObject.creditTermIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditTermIds = this.creditTermIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetCreditTermsResponse extends ModelObject {\n\n public creditTerms: CreditTerm[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.creditTerms = jsonSerializedObject.creditTerms.map((v: any) => new CreditTerm(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.creditTerms = this.creditTerms.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"creditTerms\", rule: (v: any) => !!v || \"creditTerms is required\"},\n {field: \"creditTerms\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as CreditTerm[]).reduce((acc: Array, curr: CreditTerm) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveCreditTermRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditTerm: CreditTerm = new CreditTerm();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditTerm = new CreditTerm(jsonSerializedObject.creditTerm);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditTerm = this.creditTerm.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"creditTerm\", rule: (v: any) => !!v || \"creditTerm is required\"},\n {field: \"creditTerm\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetCreditTermIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public creditTermId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.creditTermId = Guid.fromString(jsonSerializedObject.creditTermId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.creditTermId = this.creditTermId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"creditTermId\", rule: (v: any) => !v.isEmpty() || \".CreditTermId cannot be empty\"},\n ];\n}\n\n\nexport class CreditTermService extends ServiceBase {\n\n public async getAllCreditTerms(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllCreditTermsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllCreditTermsResponse(response).creditTerms;\n return this.makeJsonRequest(\"creditTerm/v1/getAllCreditTerms\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getCreditTerm(tenantId: Guid, creditTermId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetCreditTermRequest();\n req.tenantId = tenantId;\n req.creditTermId = creditTermId;\n const extractor = (response:any) => new GetCreditTermResponse(response).creditTerm;\n return this.makeJsonRequest(\"creditTerm/v1/getCreditTerm\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getCreditTerms(tenantId: Guid, creditTermIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetCreditTermsRequest();\n req.tenantId = tenantId;\n req.creditTermIds = creditTermIds;\n const extractor = (response:any) => new GetCreditTermsResponse(response).creditTerms;\n return this.makeJsonRequest(\"creditTerm/v1/getCreditTerms\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveCreditTerm(tenantId: Guid, creditTerm: CreditTerm, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveCreditTermRequest();\n req.tenantId = tenantId;\n req.creditTerm = creditTerm;\n const extractor = null;\n return this.makeJsonRequest(\"creditTerm/v1/saveCreditTerm\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setCreditTermIsHidden(tenantId: Guid, creditTermId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetCreditTermIsHiddenRequest();\n req.tenantId = tenantId;\n req.creditTermId = creditTermId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"creditTerm/v1/setCreditTermIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const creditTermService = new CreditTermService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { CreditTerm } from \"@/app/services/generated/credittermService\";\nimport { creditTermService } from \"@/app/services/generated/credittermService\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\n\nexport interface IHasCreditTermsCache {\n creditTerms: CreditTermsCache;\n}\n\n// Singleton cache store\nconst creditTermsCacheStore = new EntityCacheStore(\n EnumCacheEntityType.creditTerm,\n async () => creditTermService.getAllCreditTerms(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class CreditTermsCache extends EntityWithGuidKeyCache {\n constructor() {\n super(creditTermsCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumDayOfWeek } from \"./enums/enumDayOfWeek.generated\";\n\n// Model Objects\n\nexport class DeliveryArea extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Lead Time in Days between Dispatch date and Delivery date.\n * Not Negative\n */\n public leadTimeDays: number = 0;\n /**\n * Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n /**\n * Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n /**\n * Array of days of week on which orders are typically despatched. Will always read in order Monday to Sunday.\n */\n public despatchDays: EnumDayOfWeek[] = [];\n public isHidden: boolean = false;\n private _deliveryServiceId: Guid | null = null;\n /**\n * Delivery Service, if any, to apply by default to orders for delivery in this delivery area. May be overriden by settings at outlet or group level.\n */\n public get deliveryServiceId(): Guid | null { return this._deliveryServiceId }\n public set deliveryServiceId(value: Guid | null) {\n this._deliveryServiceId = value === undefined ? null : value;\n }\n /**\n * Shows whether DispatchCutOffTime is for the same day or next day.If true, order placed before DispatchCutOffTime is dispatched on the same day else the next day.\n */\n public isSameDayDispatchCutOffTime: boolean = false;\n private _dispatchCutOffTime: LocalTime | null = null;\n /**\n * Cut off time for placing an order. Used to calculate dispatch date for this delivery area.\n */\n public get dispatchCutOffTime(): LocalTime | null { return this._dispatchCutOffTime }\n public set dispatchCutOffTime(value: LocalTime | null) {\n this._dispatchCutOffTime = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.leadTimeDays = jsonSerializedObject.leadTimeDays;\n this.name = jsonSerializedObject.name;\n this.notes = jsonSerializedObject.notes;\n this.despatchDays = jsonSerializedObject.despatchDays.map((v: any) => EnumDayOfWeek.getByValue(v));\n this.isHidden = jsonSerializedObject.isHidden;\n this.deliveryServiceId = jsonSerializedObject.deliveryServiceId == null ? null : Guid.fromString(jsonSerializedObject.deliveryServiceId);\n this.isSameDayDispatchCutOffTime = jsonSerializedObject.isSameDayDispatchCutOffTime;\n this.dispatchCutOffTime = jsonSerializedObject.dispatchCutOffTime == null ? null : LocalTime.parse(jsonSerializedObject.dispatchCutOffTime);\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.leadTimeDays = this.leadTimeDays;\n toRet.name = this.name;\n toRet.notes = this.notes;\n toRet.despatchDays = this.despatchDays.map(v => v.value);\n toRet.isHidden = this.isHidden;\n toRet.deliveryServiceId = this.deliveryServiceId == null ? null : this.deliveryServiceId.toString();\n toRet.isSameDayDispatchCutOffTime = this.isSameDayDispatchCutOffTime;\n toRet.dispatchCutOffTime = this.dispatchCutOffTime == null ? null : this.dispatchCutOffTime.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"DeliveryArea.Id cannot be empty\"},\n {field: \"leadTimeDays\", rule: (v: any) => v == null || v >= 0 || \"LeadTimeDays is not greater than minimum allowed value: 0\"},\n {field: \"leadTimeDays\", rule: (v: any) => v == null || v <= 2147483647 || \"LeadTimeDays is above maximum allowed value: 2147483647\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"deliveryServiceId\", rule: (v: any) => v == null || !v.isEmpty() || \"DeliveryArea.DeliveryServiceId cannot be empty\"},\n ];\n}\n\n\nexport class DeliveryAreaDistributionDates extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n public dispatchDate: LocalDate = LocalDate.ofEpochDay(0);\n public deliveryDate: LocalDate = LocalDate.ofEpochDay(0);\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.dispatchDate = LocalDate.parse(jsonSerializedObject.dispatchDate);\n this.deliveryDate = LocalDate.parse(jsonSerializedObject.deliveryDate);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.dispatchDate = this.dispatchDate.toString();\n toRet.deliveryDate = this.deliveryDate.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"DeliveryAreaDistributionDates.Id cannot be empty\"},\n ];\n}\n\n\nexport class GetAllDeliveryAreasRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllDeliveryAreasResponse extends ModelObject {\n\n public deliveryAreas: DeliveryArea[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.deliveryAreas = jsonSerializedObject.deliveryAreas.map((v: any) => new DeliveryArea(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.deliveryAreas = this.deliveryAreas.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"deliveryAreas\", rule: (v: any) => !!v || \"deliveryAreas is required\"},\n {field: \"deliveryAreas\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as DeliveryArea[]).reduce((acc: Array, curr: DeliveryArea) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetDeliveryAreaRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public deliveryAreaId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.deliveryAreaId = Guid.fromString(jsonSerializedObject.deliveryAreaId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.deliveryAreaId = this.deliveryAreaId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"deliveryAreaId\", rule: (v: any) => !v.isEmpty() || \".DeliveryAreaId cannot be empty\"},\n ];\n}\n\n\nexport class GetDeliveryAreaResponse extends ModelObject {\n\n public deliveryArea: DeliveryArea = new DeliveryArea();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.deliveryArea = new DeliveryArea(jsonSerializedObject.deliveryArea);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.deliveryArea = this.deliveryArea.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"deliveryArea\", rule: (v: any) => !!v || \"deliveryArea is required\"},\n {field: \"deliveryArea\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetDeliveryAreasRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public deliveryAreaIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.deliveryAreaIds = jsonSerializedObject.deliveryAreaIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.deliveryAreaIds = this.deliveryAreaIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetDeliveryAreasResponse extends ModelObject {\n\n public deliveryAreas: DeliveryArea[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.deliveryAreas = jsonSerializedObject.deliveryAreas.map((v: any) => new DeliveryArea(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.deliveryAreas = this.deliveryAreas.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"deliveryAreas\", rule: (v: any) => !!v || \"deliveryAreas is required\"},\n {field: \"deliveryAreas\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as DeliveryArea[]).reduce((acc: Array, curr: DeliveryArea) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveDeliveryAreasRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public deliveryAreas: readonly DeliveryArea[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.deliveryAreas = jsonSerializedObject.deliveryAreas.map((v: any) => new DeliveryArea(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.deliveryAreas = this.deliveryAreas.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"deliveryAreas\", rule: (v: any) => !!v || \"deliveryAreas is required\"},\n {field: \"deliveryAreas\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as DeliveryArea[]).reduce((acc: Array, curr: DeliveryArea) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SetDeliveryAreaIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public deliveryAreaId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.deliveryAreaId = Guid.fromString(jsonSerializedObject.deliveryAreaId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.deliveryAreaId = this.deliveryAreaId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"deliveryAreaId\", rule: (v: any) => !v.isEmpty() || \".DeliveryAreaId cannot be empty\"},\n ];\n}\n\n\nexport class CalculateDeliveryAreasDistributionDatesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public deliveryAreaIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.deliveryAreaIds = jsonSerializedObject.deliveryAreaIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.deliveryAreaIds = this.deliveryAreaIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class CalculateDeliveryAreasDistributionDatesResponse extends ModelObject {\n\n public distributionDates: DeliveryAreaDistributionDates[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.distributionDates = jsonSerializedObject.distributionDates.map((v: any) => new DeliveryAreaDistributionDates(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.distributionDates = this.distributionDates.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"distributionDates\", rule: (v: any) => !!v || \"distributionDates is required\"},\n {field: \"distributionDates\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as DeliveryAreaDistributionDates[]).reduce((acc: Array, curr: DeliveryAreaDistributionDates) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class DeliveryAreaService extends ServiceBase {\n\n public async getAllDeliveryAreas(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllDeliveryAreasRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllDeliveryAreasResponse(response).deliveryAreas;\n return this.makeJsonRequest(\"deliveryArea/v1/getAllDeliveryAreas\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getDeliveryArea(tenantId: Guid, deliveryAreaId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetDeliveryAreaRequest();\n req.tenantId = tenantId;\n req.deliveryAreaId = deliveryAreaId;\n const extractor = (response:any) => new GetDeliveryAreaResponse(response).deliveryArea;\n return this.makeJsonRequest(\"deliveryArea/v1/getDeliveryArea\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getDeliveryAreas(tenantId: Guid, deliveryAreaIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetDeliveryAreasRequest();\n req.tenantId = tenantId;\n req.deliveryAreaIds = deliveryAreaIds;\n const extractor = (response:any) => new GetDeliveryAreasResponse(response).deliveryAreas;\n return this.makeJsonRequest(\"deliveryArea/v1/getDeliveryAreas\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveDeliveryAreas(tenantId: Guid, deliveryAreas: readonly DeliveryArea[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveDeliveryAreasRequest();\n req.tenantId = tenantId;\n req.deliveryAreas = deliveryAreas;\n const extractor = null;\n return this.makeJsonRequest(\"deliveryArea/v1/saveDeliveryAreas\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setDeliveryAreaIsHidden(tenantId: Guid, deliveryAreaId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetDeliveryAreaIsHiddenRequest();\n req.tenantId = tenantId;\n req.deliveryAreaId = deliveryAreaId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"deliveryArea/v1/setDeliveryAreaIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async calculateDeliveryAreasDistributionDates(tenantId: Guid, deliveryAreaIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CalculateDeliveryAreasDistributionDatesRequest();\n req.tenantId = tenantId;\n req.deliveryAreaIds = deliveryAreaIds;\n const extractor = (response:any) => new CalculateDeliveryAreasDistributionDatesResponse(response).distributionDates;\n return this.makeJsonRequest(\"deliveryArea/v1/calculateDeliveryAreasDistributionDates\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const deliveryAreaService = new DeliveryAreaService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { DeliveryArea } from \"@/app/services/generated/deliveryareaService\";\nimport { deliveryAreaService } from \"@/app/services/generated/deliveryareaService\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\n\nexport interface IHasDeliveryAreasCache {\n deliveryAreas: DeliveryAreasCache;\n}\n\n// Singleton cache store\nconst deliveryAreasCacheStore = new EntityCacheStore(\n EnumCacheEntityType.deliveryArea,\n async () => deliveryAreaService.getAllDeliveryAreas(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class DeliveryAreasCache extends EntityWithGuidKeyCache {\n constructor() {\n super(deliveryAreasCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class OutletRating extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Rating Description\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n /**\n * Allow Orders?\n */\n public allowOrders: boolean = false;\n /**\n * Exclude from the Outlet List Display\n */\n public excludeFromOutletList: boolean = false;\n public isHidden: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.name = jsonSerializedObject.name;\n this.allowOrders = jsonSerializedObject.allowOrders;\n this.excludeFromOutletList = jsonSerializedObject.excludeFromOutletList;\n this.isHidden = jsonSerializedObject.isHidden;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.name = this.name;\n toRet.allowOrders = this.allowOrders;\n toRet.excludeFromOutletList = this.excludeFromOutletList;\n toRet.isHidden = this.isHidden;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"OutletRating.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n ];\n}\n\n\nexport class GetAllOutletRatingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllOutletRatingsResponse extends ModelObject {\n\n public outletRatings: OutletRating[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outletRatings = jsonSerializedObject.outletRatings.map((v: any) => new OutletRating(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outletRatings = this.outletRatings.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outletRatings\", rule: (v: any) => !!v || \"outletRatings is required\"},\n {field: \"outletRatings\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OutletRating[]).reduce((acc: Array, curr: OutletRating) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetOutletRatingRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletRatingId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletRatingId = Guid.fromString(jsonSerializedObject.outletRatingId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletRatingId = this.outletRatingId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletRatingId\", rule: (v: any) => !v.isEmpty() || \".OutletRatingId cannot be empty\"},\n ];\n}\n\n\nexport class GetOutletRatingResponse extends ModelObject {\n\n public outletRating: OutletRating = new OutletRating();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outletRating = new OutletRating(jsonSerializedObject.outletRating);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outletRating = this.outletRating.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outletRating\", rule: (v: any) => !!v || \"outletRating is required\"},\n {field: \"outletRating\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetOutletRatingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletRatingIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletRatingIds = jsonSerializedObject.outletRatingIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletRatingIds = this.outletRatingIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetOutletRatingsResponse extends ModelObject {\n\n public outletRatings: OutletRating[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outletRatings = jsonSerializedObject.outletRatings.map((v: any) => new OutletRating(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outletRatings = this.outletRatings.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outletRatings\", rule: (v: any) => !!v || \"outletRatings is required\"},\n {field: \"outletRatings\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OutletRating[]).reduce((acc: Array, curr: OutletRating) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveOutletRatingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletRatings: readonly OutletRating[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletRatings = jsonSerializedObject.outletRatings.map((v: any) => new OutletRating(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletRatings = this.outletRatings.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletRatings\", rule: (v: any) => !!v || \"outletRatings is required\"},\n {field: \"outletRatings\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OutletRating[]).reduce((acc: Array, curr: OutletRating) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SetOutletRatingIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletRatingId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletRatingId = Guid.fromString(jsonSerializedObject.outletRatingId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletRatingId = this.outletRatingId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletRatingId\", rule: (v: any) => !v.isEmpty() || \".OutletRatingId cannot be empty\"},\n ];\n}\n\n\nexport class OutletRatingService extends ServiceBase {\n\n public async getAllOutletRatings(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllOutletRatingsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllOutletRatingsResponse(response).outletRatings;\n return this.makeJsonRequest(\"outletRating/v1/getAllOutletRatings\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getOutletRating(tenantId: Guid, outletRatingId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetOutletRatingRequest();\n req.tenantId = tenantId;\n req.outletRatingId = outletRatingId;\n const extractor = (response:any) => new GetOutletRatingResponse(response).outletRating;\n return this.makeJsonRequest(\"outletRating/v1/getOutletRating\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getOutletRatings(tenantId: Guid, outletRatingIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetOutletRatingsRequest();\n req.tenantId = tenantId;\n req.outletRatingIds = outletRatingIds;\n const extractor = (response:any) => new GetOutletRatingsResponse(response).outletRatings;\n return this.makeJsonRequest(\"outletRating/v1/getOutletRatings\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveOutletRatings(tenantId: Guid, outletRatings: readonly OutletRating[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveOutletRatingsRequest();\n req.tenantId = tenantId;\n req.outletRatings = outletRatings;\n const extractor = null;\n return this.makeJsonRequest(\"outletRating/v1/saveOutletRatings\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setOutletRatingIsHidden(tenantId: Guid, outletRatingId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetOutletRatingIsHiddenRequest();\n req.tenantId = tenantId;\n req.outletRatingId = outletRatingId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"outletRating/v1/setOutletRatingIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const outletRatingService = new OutletRatingService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { OutletRating } from \"@/app/services/generated/outletratingService\";\nimport { outletRatingService } from \"@/app/services/generated/outletratingService\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\n\nexport interface IHasOutletRatingsCache {\n outletRatings: OutletRatingsCache;\n}\n\n// Singleton cache store\nconst outletRatingsCacheStore = new EntityCacheStore(\n EnumCacheEntityType.outletRating,\n async () => outletRatingService.getAllOutletRatings(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class OutletRatingsCache extends EntityWithGuidKeyCache {\n constructor() {\n super(outletRatingsCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class SalesArea extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Sales Area Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n /**\n * Sales Area Description\n * Not Nullable\n * Max Length : 1000\n */\n public description: string = \"\";\n public isHidden: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.name = jsonSerializedObject.name;\n this.description = jsonSerializedObject.description;\n this.isHidden = jsonSerializedObject.isHidden;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.name = this.name;\n toRet.description = this.description;\n toRet.isHidden = this.isHidden;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"SalesArea.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"description\", rule: (v: any) => v == null || v.length <= 1000 || \"Description has too many characters (1000)\"},\n ];\n}\n\n\nexport class GetAllSalesAreasRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllSalesAreasResponse extends ModelObject {\n\n public salesAreas: SalesArea[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.salesAreas = jsonSerializedObject.salesAreas.map((v: any) => new SalesArea(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.salesAreas = this.salesAreas.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"salesAreas\", rule: (v: any) => !!v || \"salesAreas is required\"},\n {field: \"salesAreas\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as SalesArea[]).reduce((acc: Array, curr: SalesArea) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetSalesAreaRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public salesAreaId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.salesAreaId = Guid.fromString(jsonSerializedObject.salesAreaId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.salesAreaId = this.salesAreaId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"salesAreaId\", rule: (v: any) => !v.isEmpty() || \".SalesAreaId cannot be empty\"},\n ];\n}\n\n\nexport class GetSalesAreaResponse extends ModelObject {\n\n public salesArea: SalesArea = new SalesArea();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.salesArea = new SalesArea(jsonSerializedObject.salesArea);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.salesArea = this.salesArea.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"salesArea\", rule: (v: any) => !!v || \"salesArea is required\"},\n {field: \"salesArea\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetSalesAreasRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public salesAreaIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.salesAreaIds = jsonSerializedObject.salesAreaIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.salesAreaIds = this.salesAreaIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetSalesAreasResponse extends ModelObject {\n\n public salesAreas: SalesArea[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.salesAreas = jsonSerializedObject.salesAreas.map((v: any) => new SalesArea(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.salesAreas = this.salesAreas.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"salesAreas\", rule: (v: any) => !!v || \"salesAreas is required\"},\n {field: \"salesAreas\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as SalesArea[]).reduce((acc: Array, curr: SalesArea) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveSalesAreasRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public salesAreas: readonly SalesArea[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.salesAreas = jsonSerializedObject.salesAreas.map((v: any) => new SalesArea(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.salesAreas = this.salesAreas.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"salesAreas\", rule: (v: any) => !!v || \"salesAreas is required\"},\n {field: \"salesAreas\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as SalesArea[]).reduce((acc: Array, curr: SalesArea) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SetSalesAreaIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public salesAreaId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.salesAreaId = Guid.fromString(jsonSerializedObject.salesAreaId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.salesAreaId = this.salesAreaId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"salesAreaId\", rule: (v: any) => !v.isEmpty() || \".SalesAreaId cannot be empty\"},\n ];\n}\n\n\nexport class SalesAreaService extends ServiceBase {\n\n public async getAllSalesAreas(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllSalesAreasRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllSalesAreasResponse(response).salesAreas;\n return this.makeJsonRequest(\"salesArea/v1/getAllSalesAreas\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getSalesArea(tenantId: Guid, salesAreaId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetSalesAreaRequest();\n req.tenantId = tenantId;\n req.salesAreaId = salesAreaId;\n const extractor = (response:any) => new GetSalesAreaResponse(response).salesArea;\n return this.makeJsonRequest(\"salesArea/v1/getSalesArea\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getSalesAreas(tenantId: Guid, salesAreaIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetSalesAreasRequest();\n req.tenantId = tenantId;\n req.salesAreaIds = salesAreaIds;\n const extractor = (response:any) => new GetSalesAreasResponse(response).salesAreas;\n return this.makeJsonRequest(\"salesArea/v1/getSalesAreas\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveSalesAreas(tenantId: Guid, salesAreas: readonly SalesArea[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveSalesAreasRequest();\n req.tenantId = tenantId;\n req.salesAreas = salesAreas;\n const extractor = null;\n return this.makeJsonRequest(\"salesArea/v1/saveSalesAreas\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setSalesAreaIsHidden(tenantId: Guid, salesAreaId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetSalesAreaIsHiddenRequest();\n req.tenantId = tenantId;\n req.salesAreaId = salesAreaId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"salesArea/v1/setSalesAreaIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const salesAreaService = new SalesAreaService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { SalesArea } from \"@/app/services/generated/salesareaService\";\nimport { salesAreaService } from \"@/app/services/generated/salesareaService\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\n\nexport interface IHasSalesAreasCache {\n salesAreas: SalesAreasCache;\n}\n\n// Singleton cache store\nconst salesAreasCacheStore = new EntityCacheStore(\n EnumCacheEntityType.salesArea,\n async () => salesAreaService.getAllSalesAreas(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class SalesAreasCache extends EntityWithGuidKeyCache {\n constructor() {\n super(salesAreasCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class SalesCode extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Sales Code Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n /**\n * Sales Code Description\n * Not Nullable\n * Max Length : 1000\n */\n public description: string = \"\";\n public isHidden: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.name = jsonSerializedObject.name;\n this.description = jsonSerializedObject.description;\n this.isHidden = jsonSerializedObject.isHidden;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.name = this.name;\n toRet.description = this.description;\n toRet.isHidden = this.isHidden;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"SalesCode.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"description\", rule: (v: any) => v == null || v.length <= 1000 || \"Description has too many characters (1000)\"},\n ];\n}\n\n\nexport class GetAllSalesCodesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllSalesCodesResponse extends ModelObject {\n\n public salesCodes: SalesCode[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.salesCodes = jsonSerializedObject.salesCodes.map((v: any) => new SalesCode(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.salesCodes = this.salesCodes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"salesCodes\", rule: (v: any) => !!v || \"salesCodes is required\"},\n {field: \"salesCodes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as SalesCode[]).reduce((acc: Array, curr: SalesCode) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetSalesCodeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public salesCodeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.salesCodeId = Guid.fromString(jsonSerializedObject.salesCodeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.salesCodeId = this.salesCodeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"salesCodeId\", rule: (v: any) => !v.isEmpty() || \".SalesCodeId cannot be empty\"},\n ];\n}\n\n\nexport class GetSalesCodeResponse extends ModelObject {\n\n public salesCode: SalesCode = new SalesCode();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.salesCode = new SalesCode(jsonSerializedObject.salesCode);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.salesCode = this.salesCode.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"salesCode\", rule: (v: any) => !!v || \"salesCode is required\"},\n {field: \"salesCode\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetSalesCodesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public salesCodeIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.salesCodeIds = jsonSerializedObject.salesCodeIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.salesCodeIds = this.salesCodeIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetSalesCodesResponse extends ModelObject {\n\n public salesCodes: SalesCode[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.salesCodes = jsonSerializedObject.salesCodes.map((v: any) => new SalesCode(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.salesCodes = this.salesCodes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"salesCodes\", rule: (v: any) => !!v || \"salesCodes is required\"},\n {field: \"salesCodes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as SalesCode[]).reduce((acc: Array, curr: SalesCode) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveSalesCodesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public salesCodes: readonly SalesCode[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.salesCodes = jsonSerializedObject.salesCodes.map((v: any) => new SalesCode(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.salesCodes = this.salesCodes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"salesCodes\", rule: (v: any) => !!v || \"salesCodes is required\"},\n {field: \"salesCodes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as SalesCode[]).reduce((acc: Array, curr: SalesCode) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SetSalesCodeIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public salesCodeId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.salesCodeId = Guid.fromString(jsonSerializedObject.salesCodeId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.salesCodeId = this.salesCodeId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"salesCodeId\", rule: (v: any) => !v.isEmpty() || \".SalesCodeId cannot be empty\"},\n ];\n}\n\n\nexport class SalesCodeService extends ServiceBase {\n\n public async getAllSalesCodes(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllSalesCodesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllSalesCodesResponse(response).salesCodes;\n return this.makeJsonRequest(\"salesCode/v1/getAllSalesCodes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getSalesCode(tenantId: Guid, salesCodeId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetSalesCodeRequest();\n req.tenantId = tenantId;\n req.salesCodeId = salesCodeId;\n const extractor = (response:any) => new GetSalesCodeResponse(response).salesCode;\n return this.makeJsonRequest(\"salesCode/v1/getSalesCode\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getSalesCodes(tenantId: Guid, salesCodeIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetSalesCodesRequest();\n req.tenantId = tenantId;\n req.salesCodeIds = salesCodeIds;\n const extractor = (response:any) => new GetSalesCodesResponse(response).salesCodes;\n return this.makeJsonRequest(\"salesCode/v1/getSalesCodes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveSalesCodes(tenantId: Guid, salesCodes: readonly SalesCode[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveSalesCodesRequest();\n req.tenantId = tenantId;\n req.salesCodes = salesCodes;\n const extractor = null;\n return this.makeJsonRequest(\"salesCode/v1/saveSalesCodes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setSalesCodeIsHidden(tenantId: Guid, salesCodeId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetSalesCodeIsHiddenRequest();\n req.tenantId = tenantId;\n req.salesCodeId = salesCodeId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"salesCode/v1/setSalesCodeIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const salesCodeService = new SalesCodeService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { SalesCode } from \"@/app/services/generated/salescodeService\";\nimport { salesCodeService } from \"@/app/services/generated/salescodeService\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\n\nexport interface IHasSalesCodesCache {\n salesCodes: SalesCodesCache;\n}\n\n// Singleton cache store\nconst salesCodesCacheStore = new EntityCacheStore(\n EnumCacheEntityType.salesCode,\n async () => salesCodeService.getAllSalesCodes(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class SalesCodesCache extends EntityWithGuidKeyCache {\n constructor() {\n super(salesCodesCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class TaskTypeReadOnly extends ModelObject {\n\n /**\n * Sequence for ordering task types.\n */\n public sequence: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.sequence = jsonSerializedObject.sequence;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.sequence = this.sequence;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"sequence\", rule: (v: any) => v == null || v >= -2147483648 || \"Sequence is not greater than minimum allowed value: -2147483648\"},\n {field: \"sequence\", rule: (v: any) => v == null || v <= 2147483647 || \"Sequence is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class TaskType extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Task Type Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n public isHidden: boolean = false;\n /**\n * Duration of this task type in minutes.\n * Minimum : 1\n */\n public durationMinutes: number = 0;\n public readOnly: TaskTypeReadOnly = new TaskTypeReadOnly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.name = jsonSerializedObject.name;\n this.isHidden = jsonSerializedObject.isHidden;\n this.durationMinutes = jsonSerializedObject.durationMinutes;\n this.readOnly = new TaskTypeReadOnly(jsonSerializedObject.readOnly);\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.name = this.name;\n toRet.isHidden = this.isHidden;\n toRet.durationMinutes = this.durationMinutes;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"TaskType.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"durationMinutes\", rule: (v: any) => v == null || v >= 1 || \"DurationMinutes is not greater than minimum allowed value: 1\"},\n {field: \"durationMinutes\", rule: (v: any) => v == null || v <= 2147483647 || \"DurationMinutes is above maximum allowed value: 2147483647\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class GetTaskTypesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public taskTypeIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.taskTypeIds = jsonSerializedObject.taskTypeIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.taskTypeIds = this.taskTypeIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetTaskTypesResponse extends ModelObject {\n\n public taskTypes: TaskType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.taskTypes = jsonSerializedObject.taskTypes.map((v: any) => new TaskType(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.taskTypes = this.taskTypes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"taskTypes\", rule: (v: any) => !!v || \"taskTypes is required\"},\n {field: \"taskTypes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as TaskType[]).reduce((acc: Array, curr: TaskType) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetTaskTypeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public taskTypeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.taskTypeId = Guid.fromString(jsonSerializedObject.taskTypeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.taskTypeId = this.taskTypeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"taskTypeId\", rule: (v: any) => !v.isEmpty() || \".TaskTypeId cannot be empty\"},\n ];\n}\n\n\nexport class GetTaskTypeResponse extends ModelObject {\n\n public taskType: TaskType = new TaskType();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.taskType = new TaskType(jsonSerializedObject.taskType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.taskType = this.taskType.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"taskType\", rule: (v: any) => !!v || \"taskType is required\"},\n {field: \"taskType\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetAllTaskTypesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllTaskTypesResponse extends ModelObject {\n\n public taskTypes: TaskType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.taskTypes = jsonSerializedObject.taskTypes.map((v: any) => new TaskType(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.taskTypes = this.taskTypes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"taskTypes\", rule: (v: any) => !!v || \"taskTypes is required\"},\n {field: \"taskTypes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as TaskType[]).reduce((acc: Array, curr: TaskType) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveTaskTypeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public taskType: TaskType = new TaskType();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.taskType = new TaskType(jsonSerializedObject.taskType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.taskType = this.taskType.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"taskType\", rule: (v: any) => !!v || \"taskType is required\"},\n {field: \"taskType\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetTaskTypeIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public taskTypeId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.taskTypeId = Guid.fromString(jsonSerializedObject.taskTypeId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.taskTypeId = this.taskTypeId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"taskTypeId\", rule: (v: any) => !v.isEmpty() || \".TaskTypeId cannot be empty\"},\n ];\n}\n\n\nexport class UpdateTaskTypesSequenceRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public taskTypeIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.taskTypeIds = jsonSerializedObject.taskTypeIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.taskTypeIds = this.taskTypeIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class TaskTypeService extends ServiceBase {\n\n public async getTaskTypes(tenantId: Guid, taskTypeIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetTaskTypesRequest();\n req.tenantId = tenantId;\n req.taskTypeIds = taskTypeIds;\n const extractor = (response:any) => new GetTaskTypesResponse(response).taskTypes;\n return this.makeJsonRequest(\"taskType/v1/getTaskTypes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getTaskType(tenantId: Guid, taskTypeId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetTaskTypeRequest();\n req.tenantId = tenantId;\n req.taskTypeId = taskTypeId;\n const extractor = (response:any) => new GetTaskTypeResponse(response).taskType;\n return this.makeJsonRequest(\"taskType/v1/getTaskType\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllTaskTypes(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllTaskTypesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllTaskTypesResponse(response).taskTypes;\n return this.makeJsonRequest(\"taskType/v1/getAllTaskTypes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveTaskType(tenantId: Guid, taskType: TaskType, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveTaskTypeRequest();\n req.tenantId = tenantId;\n req.taskType = taskType;\n const extractor = null;\n return this.makeJsonRequest(\"taskType/v1/saveTaskType\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setTaskTypeIsHidden(tenantId: Guid, taskTypeId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetTaskTypeIsHiddenRequest();\n req.tenantId = tenantId;\n req.taskTypeId = taskTypeId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"taskType/v1/setTaskTypeIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updateTaskTypesSequence(tenantId: Guid, taskTypeIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdateTaskTypesSequenceRequest();\n req.tenantId = tenantId;\n req.taskTypeIds = taskTypeIds;\n const extractor = null;\n return this.makeJsonRequest(\"taskType/v1/updateTaskTypesSequence\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const taskTypeService = new TaskTypeService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { TaskType } from \"@/app/services/generated/tasktypeService\";\nimport { taskTypeService } from \"@/app/services/generated/tasktypeService\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\n\nexport interface IHasTaskTypesCache {\n taskTypes: TaskTypesCache;\n}\n// Singleton cache store\nconst taskTypesCacheStore = new EntityCacheStore(\n EnumCacheEntityType.taskType,\n async () => taskTypeService.getAllTaskTypes(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class TaskTypesCache extends EntityWithGuidKeyCache {\n constructor() {\n super(taskTypesCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class TaskQueueReadOnly extends ModelObject {\n\n /**\n * Sequence for ordering task queues.\n */\n public sequence: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.sequence = jsonSerializedObject.sequence;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.sequence = this.sequence;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"sequence\", rule: (v: any) => v == null || v >= -2147483648 || \"Sequence is not greater than minimum allowed value: -2147483648\"},\n {field: \"sequence\", rule: (v: any) => v == null || v <= 2147483647 || \"Sequence is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class TaskQueue extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Queue Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n public isHidden: boolean = false;\n public readOnly: TaskQueueReadOnly = new TaskQueueReadOnly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.name = jsonSerializedObject.name;\n this.isHidden = jsonSerializedObject.isHidden;\n this.readOnly = new TaskQueueReadOnly(jsonSerializedObject.readOnly);\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.name = this.name;\n toRet.isHidden = this.isHidden;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"TaskQueue.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class GetTaskQueuesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public taskQueueIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.taskQueueIds = jsonSerializedObject.taskQueueIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.taskQueueIds = this.taskQueueIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetTaskQueuesResponse extends ModelObject {\n\n public taskQueues: TaskQueue[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.taskQueues = jsonSerializedObject.taskQueues.map((v: any) => new TaskQueue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.taskQueues = this.taskQueues.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"taskQueues\", rule: (v: any) => !!v || \"taskQueues is required\"},\n {field: \"taskQueues\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as TaskQueue[]).reduce((acc: Array, curr: TaskQueue) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetTaskQueueRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public taskQueueId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.taskQueueId = Guid.fromString(jsonSerializedObject.taskQueueId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.taskQueueId = this.taskQueueId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"taskQueueId\", rule: (v: any) => !v.isEmpty() || \".TaskQueueId cannot be empty\"},\n ];\n}\n\n\nexport class GetTaskQueueResponse extends ModelObject {\n\n public taskQueue: TaskQueue = new TaskQueue();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.taskQueue = new TaskQueue(jsonSerializedObject.taskQueue);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.taskQueue = this.taskQueue.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"taskQueue\", rule: (v: any) => !!v || \"taskQueue is required\"},\n {field: \"taskQueue\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetAllTaskQueuesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllTaskQueuesResponse extends ModelObject {\n\n public taskQueues: TaskQueue[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.taskQueues = jsonSerializedObject.taskQueues.map((v: any) => new TaskQueue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.taskQueues = this.taskQueues.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"taskQueues\", rule: (v: any) => !!v || \"taskQueues is required\"},\n {field: \"taskQueues\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as TaskQueue[]).reduce((acc: Array, curr: TaskQueue) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveTaskQueueRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public taskQueue: TaskQueue = new TaskQueue();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.taskQueue = new TaskQueue(jsonSerializedObject.taskQueue);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.taskQueue = this.taskQueue.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"taskQueue\", rule: (v: any) => !!v || \"taskQueue is required\"},\n {field: \"taskQueue\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetTaskQueueIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public taskQueueId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.taskQueueId = Guid.fromString(jsonSerializedObject.taskQueueId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.taskQueueId = this.taskQueueId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"taskQueueId\", rule: (v: any) => !v.isEmpty() || \".TaskQueueId cannot be empty\"},\n ];\n}\n\n\nexport class UpdateTaskQueuesSequenceRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public taskQueueIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.taskQueueIds = jsonSerializedObject.taskQueueIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.taskQueueIds = this.taskQueueIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class TaskQueueService extends ServiceBase {\n\n public async getTaskQueues(tenantId: Guid, taskQueueIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetTaskQueuesRequest();\n req.tenantId = tenantId;\n req.taskQueueIds = taskQueueIds;\n const extractor = (response:any) => new GetTaskQueuesResponse(response).taskQueues;\n return this.makeJsonRequest(\"taskQueue/v1/getTaskQueues\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getTaskQueue(tenantId: Guid, taskQueueId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetTaskQueueRequest();\n req.tenantId = tenantId;\n req.taskQueueId = taskQueueId;\n const extractor = (response:any) => new GetTaskQueueResponse(response).taskQueue;\n return this.makeJsonRequest(\"taskQueue/v1/getTaskQueue\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllTaskQueues(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllTaskQueuesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllTaskQueuesResponse(response).taskQueues;\n return this.makeJsonRequest(\"taskQueue/v1/getAllTaskQueues\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveTaskQueue(tenantId: Guid, taskQueue: TaskQueue, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveTaskQueueRequest();\n req.tenantId = tenantId;\n req.taskQueue = taskQueue;\n const extractor = null;\n return this.makeJsonRequest(\"taskQueue/v1/saveTaskQueue\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setTaskQueueIsHidden(tenantId: Guid, taskQueueId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetTaskQueueIsHiddenRequest();\n req.tenantId = tenantId;\n req.taskQueueId = taskQueueId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"taskQueue/v1/setTaskQueueIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updateTaskQueuesSequence(tenantId: Guid, taskQueueIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdateTaskQueuesSequenceRequest();\n req.tenantId = tenantId;\n req.taskQueueIds = taskQueueIds;\n const extractor = null;\n return this.makeJsonRequest(\"taskQueue/v1/updateTaskQueuesSequence\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const taskQueueService = new TaskQueueService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\nimport type { TaskQueue } from \"@/app/services/generated/taskqueueService\";\nimport { taskQueueService } from \"@/app/services/generated/taskqueueService\";\n\nexport interface IHasTaskQueuesCache {\n taskQueues: TaskQueuesCache;\n}\n\n// Singleton cache store\nconst taskQueuesCacheStore = new EntityCacheStore(\n EnumCacheEntityType.taskQueue,\n async () => taskQueueService.getAllTaskQueues(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class TaskQueuesCache extends EntityWithGuidKeyCache {\n constructor() {\n super(taskQueuesCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class UnitOfMeasureReadOnly extends ModelObject {\n\n /**\n * Identifies if this is the system unit of measure for units, used for all product stock items.\n */\n public isUnits: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.isUnits = jsonSerializedObject.isUnits;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.isUnits = this.isUnits;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class UnitOfMeasure extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n private _litres: number | null = null;\n /**\n * Litres\n * Greater Than : 0\n */\n public get litres(): number | null { return this._litres }\n public set litres(value: number | null) {\n this._litres = value === undefined ? null : value;\n }\n /**\n * Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n public readOnly: UnitOfMeasureReadOnly = new UnitOfMeasureReadOnly();\n public isHidden: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.litres = jsonSerializedObject.litres == null ? null : jsonSerializedObject.litres;\n this.name = jsonSerializedObject.name;\n this.readOnly = new UnitOfMeasureReadOnly(jsonSerializedObject.readOnly);\n this.isHidden = jsonSerializedObject.isHidden;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.litres = this.litres == null ? null : this.litres;\n toRet.name = this.name;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.isHidden = this.isHidden;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"UnitOfMeasure.Id cannot be empty\"},\n {field: \"litres\", rule: (v: any) => v == null || v > 0 || \"Litres is not greater than minimum allowed value: 0\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class GetAllUnitsOfMeasureRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllUnitsOfMeasureResponse extends ModelObject {\n\n public unitsOfMeasure: UnitOfMeasure[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.unitsOfMeasure = jsonSerializedObject.unitsOfMeasure.map((v: any) => new UnitOfMeasure(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.unitsOfMeasure = this.unitsOfMeasure.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"unitsOfMeasure\", rule: (v: any) => !!v || \"unitsOfMeasure is required\"},\n {field: \"unitsOfMeasure\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as UnitOfMeasure[]).reduce((acc: Array, curr: UnitOfMeasure) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetUnitOfMeasureRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public unitOfMeasureId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \".UnitOfMeasureId cannot be empty\"},\n ];\n}\n\n\nexport class GetUnitOfMeasureResponse extends ModelObject {\n\n public unitOfMeasure: UnitOfMeasure = new UnitOfMeasure();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.unitOfMeasure = new UnitOfMeasure(jsonSerializedObject.unitOfMeasure);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.unitOfMeasure = this.unitOfMeasure.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"unitOfMeasure\", rule: (v: any) => !!v || \"unitOfMeasure is required\"},\n {field: \"unitOfMeasure\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetUnitsOfMeasureRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public unitOfMeasureIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.unitOfMeasureIds = jsonSerializedObject.unitOfMeasureIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.unitOfMeasureIds = this.unitOfMeasureIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetUnitsOfMeasureResponse extends ModelObject {\n\n public unitsOfMeasure: UnitOfMeasure[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.unitsOfMeasure = jsonSerializedObject.unitsOfMeasure.map((v: any) => new UnitOfMeasure(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.unitsOfMeasure = this.unitsOfMeasure.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"unitsOfMeasure\", rule: (v: any) => !!v || \"unitsOfMeasure is required\"},\n {field: \"unitsOfMeasure\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as UnitOfMeasure[]).reduce((acc: Array, curr: UnitOfMeasure) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveUnitOfMeasureRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public unitOfMeasure: UnitOfMeasure = new UnitOfMeasure();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.unitOfMeasure = new UnitOfMeasure(jsonSerializedObject.unitOfMeasure);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.unitOfMeasure = this.unitOfMeasure.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"unitOfMeasure\", rule: (v: any) => !!v || \"unitOfMeasure is required\"},\n {field: \"unitOfMeasure\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetUnitOfMeasureIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public unitOfMeasureId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \".UnitOfMeasureId cannot be empty\"},\n ];\n}\n\n\nexport class UnitOfMeasureService extends ServiceBase {\n\n public async getAllUnitsOfMeasure(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllUnitsOfMeasureRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllUnitsOfMeasureResponse(response).unitsOfMeasure;\n return this.makeJsonRequest(\"unitOfMeasure/v1/getAllUnitsOfMeasure\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getUnitOfMeasure(tenantId: Guid, unitOfMeasureId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetUnitOfMeasureRequest();\n req.tenantId = tenantId;\n req.unitOfMeasureId = unitOfMeasureId;\n const extractor = (response:any) => new GetUnitOfMeasureResponse(response).unitOfMeasure;\n return this.makeJsonRequest(\"unitOfMeasure/v1/getUnitOfMeasure\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getUnitsOfMeasure(tenantId: Guid, unitOfMeasureIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetUnitsOfMeasureRequest();\n req.tenantId = tenantId;\n req.unitOfMeasureIds = unitOfMeasureIds;\n const extractor = (response:any) => new GetUnitsOfMeasureResponse(response).unitsOfMeasure;\n return this.makeJsonRequest(\"unitOfMeasure/v1/getUnitsOfMeasure\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveUnitOfMeasure(tenantId: Guid, unitOfMeasure: UnitOfMeasure, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveUnitOfMeasureRequest();\n req.tenantId = tenantId;\n req.unitOfMeasure = unitOfMeasure;\n const extractor = null;\n return this.makeJsonRequest(\"unitOfMeasure/v1/saveUnitOfMeasure\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setUnitOfMeasureIsHidden(tenantId: Guid, unitOfMeasureId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetUnitOfMeasureIsHiddenRequest();\n req.tenantId = tenantId;\n req.unitOfMeasureId = unitOfMeasureId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"unitOfMeasure/v1/setUnitOfMeasureIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const unitOfMeasureService = new UnitOfMeasureService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { UnitOfMeasure } from \"@/app/services/generated/unitofmeasureService\";\nimport { unitOfMeasureService } from \"@/app/services/generated/unitofmeasureService\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\n\nexport interface IHasUnitsOfMeasureCache {\n unitsOfMeasure: UnitsOfMeasuresCache;\n}\n\n// Singleton cache store\nconst unitsOfMeasuresCacheStore = new EntityCacheStore(\n EnumCacheEntityType.unitOfMeasure,\n async () => unitOfMeasureService.getAllUnitsOfMeasure(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class UnitsOfMeasuresCache extends EntityWithGuidKeyCache {\n constructor() {\n super(unitsOfMeasuresCacheStore, (x) => x.id);\n }\n\n /**\n * Gets the 'units' Unit of Measure\n */\n public getUnitsUom() {\n return this.all.find((uom) => uom.readOnly.isUnits)!.id;\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumKegstarContainerType } from \"./enums/enumKegstarContainerType.generated\";\nimport { EnumPackageTypeCategoryType } from \"./enums/enumPackageTypeCategoryType.generated\";\n\n// Model Objects\n\nexport class PackageType extends ModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Package Type\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n private _litres: number | null = null;\n /**\n * Litres usually dispensed into this package, if relevant\n * Greater Than : 0\n */\n public get litres(): number | null { return this._litres }\n public set litres(value: number | null) {\n this._litres = value === undefined ? null : value;\n }\n /**\n * Package is normally traceable, so expect it to be scanned out on orders.\n */\n public isTraceable: boolean = false;\n /**\n * Package is normally returnable, so expect it to be scanned out and in.\n */\n public isReturnable: boolean = false;\n private _defaultReturnableLabelDocumentTemplateId: Guid | null = null;\n /**\n * Label document template that the package type will use for returnable labels.\n */\n public get defaultReturnableLabelDocumentTemplateId(): Guid | null { return this._defaultReturnableLabelDocumentTemplateId }\n public set defaultReturnableLabelDocumentTemplateId(value: Guid | null) {\n this._defaultReturnableLabelDocumentTemplateId = value === undefined ? null : value;\n }\n private _defaultNonReturnableLabelDocumentTemplateId: Guid | null = null;\n /**\n * Label document template that the package type will use for non-returnable labels.\n */\n public get defaultNonReturnableLabelDocumentTemplateId(): Guid | null { return this._defaultNonReturnableLabelDocumentTemplateId }\n public set defaultNonReturnableLabelDocumentTemplateId(value: Guid | null) {\n this._defaultNonReturnableLabelDocumentTemplateId = value === undefined ? null : value;\n }\n public isHidden: boolean = false;\n /**\n * Set true if this is designed to be connected to a pump or pressurised gas system, such as those used in pubs. Some duty systems have different duty rates for beer packaged in these manners for selling to pubs.\n */\n public isDesignedForPump: boolean = false;\n private _finalUnitLitres: number | null = null;\n /**\n * Litres held by the final consumable packaged unit, if relevant. For example, a package type representing a case of 12 x 500ml bottles would have a final unit litres of 0.5. Some duty systems have different rates depending upon this value.\n * Greater Than : 0\n */\n public get finalUnitLitres(): number | null { return this._finalUnitLitres }\n public set finalUnitLitres(value: number | null) {\n this._finalUnitLitres = value === undefined ? null : value;\n }\n /**\n * Kegstar container type if applicable, otherwise default to None.\n */\n public kegstarContainerType: EnumKegstarContainerType = EnumKegstarContainerType.none;\n /**\n * Category type of this package type.\n */\n public categoryType: EnumPackageTypeCategoryType = EnumPackageTypeCategoryType.unknown;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.name = jsonSerializedObject.name;\n this.litres = jsonSerializedObject.litres == null ? null : jsonSerializedObject.litres;\n this.isTraceable = jsonSerializedObject.isTraceable;\n this.isReturnable = jsonSerializedObject.isReturnable;\n this.defaultReturnableLabelDocumentTemplateId = jsonSerializedObject.defaultReturnableLabelDocumentTemplateId == null ? null : Guid.fromString(jsonSerializedObject.defaultReturnableLabelDocumentTemplateId);\n this.defaultNonReturnableLabelDocumentTemplateId = jsonSerializedObject.defaultNonReturnableLabelDocumentTemplateId == null ? null : Guid.fromString(jsonSerializedObject.defaultNonReturnableLabelDocumentTemplateId);\n this.isHidden = jsonSerializedObject.isHidden;\n this.isDesignedForPump = jsonSerializedObject.isDesignedForPump;\n this.finalUnitLitres = jsonSerializedObject.finalUnitLitres == null ? null : jsonSerializedObject.finalUnitLitres;\n this.kegstarContainerType = EnumKegstarContainerType.getByValue(jsonSerializedObject.kegstarContainerType, this.kegstarContainerType);\n this.categoryType = EnumPackageTypeCategoryType.getByValue(jsonSerializedObject.categoryType, this.categoryType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.name = this.name;\n toRet.litres = this.litres == null ? null : this.litres;\n toRet.isTraceable = this.isTraceable;\n toRet.isReturnable = this.isReturnable;\n toRet.defaultReturnableLabelDocumentTemplateId = this.defaultReturnableLabelDocumentTemplateId == null ? null : this.defaultReturnableLabelDocumentTemplateId.toString();\n toRet.defaultNonReturnableLabelDocumentTemplateId = this.defaultNonReturnableLabelDocumentTemplateId == null ? null : this.defaultNonReturnableLabelDocumentTemplateId.toString();\n toRet.isHidden = this.isHidden;\n toRet.isDesignedForPump = this.isDesignedForPump;\n toRet.finalUnitLitres = this.finalUnitLitres == null ? null : this.finalUnitLitres;\n toRet.kegstarContainerType = this.kegstarContainerType.value;\n toRet.categoryType = this.categoryType.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"PackageType.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"litres\", rule: (v: any) => v == null || v > 0 || \"Litres is not greater than minimum allowed value: 0\"},\n {field: \"defaultReturnableLabelDocumentTemplateId\", rule: (v: any) => v == null || !v.isEmpty() || \"PackageType.DefaultReturnableLabelDocumentTemplateId cannot be empty\"},\n {field: \"defaultNonReturnableLabelDocumentTemplateId\", rule: (v: any) => v == null || !v.isEmpty() || \"PackageType.DefaultNonReturnableLabelDocumentTemplateId cannot be empty\"},\n {field: \"finalUnitLitres\", rule: (v: any) => v == null || v > 0 || \"FinalUnitLitres is not greater than minimum allowed value: 0\"},\n ];\n}\n\n\nexport class GetAllPackageTypesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllPackageTypesResponse extends ModelObject {\n\n public packageTypes: PackageType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.packageTypes = jsonSerializedObject.packageTypes.map((v: any) => new PackageType(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.packageTypes = this.packageTypes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"packageTypes\", rule: (v: any) => !!v || \"packageTypes is required\"},\n {field: \"packageTypes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PackageType[]).reduce((acc: Array, curr: PackageType) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetPackageTypeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public packageTypeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.packageTypeId = Guid.fromString(jsonSerializedObject.packageTypeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.packageTypeId = this.packageTypeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"packageTypeId\", rule: (v: any) => !v.isEmpty() || \".PackageTypeId cannot be empty\"},\n ];\n}\n\n\nexport class GetPackageTypeResponse extends ModelObject {\n\n public packageType: PackageType = new PackageType();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.packageType = new PackageType(jsonSerializedObject.packageType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.packageType = this.packageType.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"packageType\", rule: (v: any) => !!v || \"packageType is required\"},\n {field: \"packageType\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetPackageTypesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public packageTypeIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.packageTypeIds = jsonSerializedObject.packageTypeIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.packageTypeIds = this.packageTypeIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetPackageTypesResponse extends ModelObject {\n\n public packageTypes: PackageType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.packageTypes = jsonSerializedObject.packageTypes.map((v: any) => new PackageType(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.packageTypes = this.packageTypes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"packageTypes\", rule: (v: any) => !!v || \"packageTypes is required\"},\n {field: \"packageTypes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PackageType[]).reduce((acc: Array, curr: PackageType) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SavePackageTypeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public packageType: PackageType = new PackageType();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.packageType = new PackageType(jsonSerializedObject.packageType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.packageType = this.packageType.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"packageType\", rule: (v: any) => !!v || \"packageType is required\"},\n {field: \"packageType\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetPackageTypeIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public packageTypeId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.packageTypeId = Guid.fromString(jsonSerializedObject.packageTypeId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.packageTypeId = this.packageTypeId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"packageTypeId\", rule: (v: any) => !v.isEmpty() || \".PackageTypeId cannot be empty\"},\n ];\n}\n\n\nexport class PackageTypeService extends ServiceBase {\n\n public async getAllPackageTypes(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllPackageTypesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllPackageTypesResponse(response).packageTypes;\n return this.makeJsonRequest(\"packageType/v1/getAllPackageTypes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getPackageType(tenantId: Guid, packageTypeId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPackageTypeRequest();\n req.tenantId = tenantId;\n req.packageTypeId = packageTypeId;\n const extractor = (response:any) => new GetPackageTypeResponse(response).packageType;\n return this.makeJsonRequest(\"packageType/v1/getPackageType\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getPackageTypes(tenantId: Guid, packageTypeIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPackageTypesRequest();\n req.tenantId = tenantId;\n req.packageTypeIds = packageTypeIds;\n const extractor = (response:any) => new GetPackageTypesResponse(response).packageTypes;\n return this.makeJsonRequest(\"packageType/v1/getPackageTypes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async savePackageType(tenantId: Guid, packageType: PackageType, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SavePackageTypeRequest();\n req.tenantId = tenantId;\n req.packageType = packageType;\n const extractor = null;\n return this.makeJsonRequest(\"packageType/v1/savePackageType\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setPackageTypeIsHidden(tenantId: Guid, packageTypeId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetPackageTypeIsHiddenRequest();\n req.tenantId = tenantId;\n req.packageTypeId = packageTypeId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"packageType/v1/setPackageTypeIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const packageTypeService = new PackageTypeService();","import type Guid from \"@/app/types/common/guid\";\n\nimport type { PackageType } from \"@/app/services/generated/packagetypeService\";\nimport { PackageTypeService } from \"@/app/services/generated/packagetypeService\";\n\nexport default class PackageTypeServiceExtended extends PackageTypeService {\n /**\n * Returns only the package types that are returnable (can be used in container tracking).\n */\n\n public async getAllReturnablePackageTypes(\n tenantId: Guid\n ): Promise {\n return (await this.getAllPackageTypes(tenantId)).filter(\n (pt) => pt.isReturnable\n );\n }\n\n calculateDutiableLitrePercentage(\n dutiableLitres: number | null,\n packageType: Readonly | null\n ) {\n return dutiableLitres && packageType?.litres\n ? (dutiableLitres / packageType.litres) * 100.0\n : null;\n }\n\n checkDutiableLitresPercentageOk(dutiableLitresPercentage: number | null) {\n // Allow percentage of\n // null (Either dutiable litres or package litres not defined)\n // 0% (Dutiable litres 0, sometimes used for duty pre-paid items)\n // 90% to 100% (Within sensible range)\n return (\n dutiableLitresPercentage === null ||\n dutiableLitresPercentage === 0 ||\n (dutiableLitresPercentage >= 90 && dutiableLitresPercentage <= 100)\n );\n }\n}\n\nexport const packageTypeService = new PackageTypeServiceExtended();\n","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { PackageType } from \"@/app/services/generated/packagetypeService\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\nimport { packageTypeService } from \"@/app/services/extensions/packageTypeServiceExtended\";\n\nexport interface IHasPackageTypesCache {\n packageTypes: PackageTypesCache;\n}\n\n// Singleton cache store\nconst packageTypesCacheStore = new EntityCacheStore(\n EnumCacheEntityType.packageType,\n async () => packageTypeService.getAllPackageTypes(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class PackageTypesCache extends EntityWithGuidKeyCache {\n constructor() {\n super(packageTypesCacheStore, (x) => x.id);\n }\n}\n","import type {\n Outlet,\n OutletSummary,\n} from \"@/app/services/generated/outletService\";\nimport { OutletService } from \"@/app/services/generated/outletService\";\nimport type { Group } from \"@/app/services/generated/groupService\";\nimport type { Maybe } from \"@/components/utils/typeHelpers\";\nimport type { MapMarker } from \"@/components/controls/map/maps\";\n\nexport default class OutletServiceExtended extends OutletService {\n public getProductRequirementsFromOutletAndGroup(\n outlet: Maybe>,\n group: Maybe>\n ): string {\n return group?.useGroupProductRequirementsForAllOutlets\n ? group.productRequirements\n : outlet?.productRequirements ?? \"\";\n }\n\n public outletSummaryToMapMarker(\n outlet: Readonly,\n opts?: Partial>\n ): MapMarker {\n const defaultOptions: MapMarker = {\n key: outlet.id.toString(),\n name: [outlet.displayName, outlet.code].join(\" | \"),\n lat: outlet.mainLatitude,\n lng: outlet.mainLongitude,\n };\n\n return { ...defaultOptions, ...opts };\n }\n}\n\nexport const outletService = new OutletServiceExtended();\n","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\nimport { outletService } from \"@/app/services/extensions/outletServiceExtended\";\nimport type { OutletSummary } from \"@/app/services/generated/outletService\";\n\nexport interface IHasOutletSummariesCache {\n outlets: OutletSummariesCache;\n}\n\n// Singleton cache store\nconst outletSummaryCacheStore = new EntityCacheStore(\n EnumCacheEntityType.outlet,\n async () => outletService.getAllOutletSummaries(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class OutletSummariesCache extends EntityWithGuidKeyCache {\n constructor() {\n super(outletSummaryCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class OutletType extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Type Description\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n public isHidden: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.name = jsonSerializedObject.name;\n this.isHidden = jsonSerializedObject.isHidden;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.name = this.name;\n toRet.isHidden = this.isHidden;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"OutletType.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n ];\n}\n\n\nexport class GetAllOutletTypesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllOutletTypesResponse extends ModelObject {\n\n public outletTypes: OutletType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outletTypes = jsonSerializedObject.outletTypes.map((v: any) => new OutletType(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outletTypes = this.outletTypes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outletTypes\", rule: (v: any) => !!v || \"outletTypes is required\"},\n {field: \"outletTypes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OutletType[]).reduce((acc: Array, curr: OutletType) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetOutletTypeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletTypeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletTypeId = Guid.fromString(jsonSerializedObject.outletTypeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletTypeId = this.outletTypeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletTypeId\", rule: (v: any) => !v.isEmpty() || \".OutletTypeId cannot be empty\"},\n ];\n}\n\n\nexport class GetOutletTypeResponse extends ModelObject {\n\n public outletType: OutletType = new OutletType();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outletType = new OutletType(jsonSerializedObject.outletType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outletType = this.outletType.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outletType\", rule: (v: any) => !!v || \"outletType is required\"},\n {field: \"outletType\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetOutletTypesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletTypeIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletTypeIds = jsonSerializedObject.outletTypeIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletTypeIds = this.outletTypeIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetOutletTypesResponse extends ModelObject {\n\n public outletTypes: OutletType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outletTypes = jsonSerializedObject.outletTypes.map((v: any) => new OutletType(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outletTypes = this.outletTypes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outletTypes\", rule: (v: any) => !!v || \"outletTypes is required\"},\n {field: \"outletTypes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OutletType[]).reduce((acc: Array, curr: OutletType) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveOutletTypesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletTypes: readonly OutletType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletTypes = jsonSerializedObject.outletTypes.map((v: any) => new OutletType(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletTypes = this.outletTypes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletTypes\", rule: (v: any) => !!v || \"outletTypes is required\"},\n {field: \"outletTypes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OutletType[]).reduce((acc: Array, curr: OutletType) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SetOutletTypeIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletTypeId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletTypeId = Guid.fromString(jsonSerializedObject.outletTypeId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletTypeId = this.outletTypeId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletTypeId\", rule: (v: any) => !v.isEmpty() || \".OutletTypeId cannot be empty\"},\n ];\n}\n\n\nexport class OutletTypeService extends ServiceBase {\n\n public async getAllOutletTypes(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllOutletTypesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllOutletTypesResponse(response).outletTypes;\n return this.makeJsonRequest(\"outletType/v1/getAllOutletTypes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getOutletType(tenantId: Guid, outletTypeId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetOutletTypeRequest();\n req.tenantId = tenantId;\n req.outletTypeId = outletTypeId;\n const extractor = (response:any) => new GetOutletTypeResponse(response).outletType;\n return this.makeJsonRequest(\"outletType/v1/getOutletType\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getOutletTypes(tenantId: Guid, outletTypeIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetOutletTypesRequest();\n req.tenantId = tenantId;\n req.outletTypeIds = outletTypeIds;\n const extractor = (response:any) => new GetOutletTypesResponse(response).outletTypes;\n return this.makeJsonRequest(\"outletType/v1/getOutletTypes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveOutletTypes(tenantId: Guid, outletTypes: readonly OutletType[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveOutletTypesRequest();\n req.tenantId = tenantId;\n req.outletTypes = outletTypes;\n const extractor = null;\n return this.makeJsonRequest(\"outletType/v1/saveOutletTypes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setOutletTypeIsHidden(tenantId: Guid, outletTypeId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetOutletTypeIsHiddenRequest();\n req.tenantId = tenantId;\n req.outletTypeId = outletTypeId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"outletType/v1/setOutletTypeIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const outletTypeService = new OutletTypeService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { OutletType } from \"@/app/services/generated/outlettypeService\";\nimport { outletTypeService } from \"@/app/services/generated/outlettypeService\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\n\n// Singleton cache store\nconst outletTypesCacheStore = new EntityCacheStore(\n EnumCacheEntityType.outletType,\n async () => outletTypeService.getAllOutletTypes(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class OutletTypesCache extends EntityWithGuidKeyCache {\n constructor() {\n super(outletTypesCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class StockLocation extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Address 1\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine1: string = \"\";\n /**\n * Address 2\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine2: string = \"\";\n /**\n * Address 3\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine3: string = \"\";\n /**\n * Address 4\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine4: string = \"\";\n /**\n * Address 5\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine5: string = \"\";\n /**\n * Address 6\n * Not Nullable\n * Max Length : 1000\n */\n public addressLine6: string = \"\";\n /**\n * Bonded\n */\n public isBonded: boolean = false;\n /**\n * Contact\n * Not Nullable\n * Max Length : 1000\n */\n public contactName: string = \"\";\n /**\n * Default Location\n */\n public isDefault: boolean = false;\n /**\n * Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n /**\n * Email\n * Not Nullable\n * Max Length : 1000\n */\n public emailAddress: string = \"\";\n /**\n * Postcode\n * Not Nullable\n * Max Length : 1000\n */\n public postcode: string = \"\";\n /**\n * Telephone\n * Not Nullable\n * Max Length : 1000\n */\n public phoneNumber: string = \"\";\n public isHidden: boolean = false;\n /**\n * Tax code for this warehouse, used for duty schemes where duty reporting is required to be broken down by warehouse.\n * Not Nullable\n * Max Length : 1000\n */\n public warehouseTaxCode: string = \"\";\n private _distributionCentre: Guid | null = null;\n /**\n * The distribution centre which distributes stock from this location. If null then the company location is used.\n */\n public get distributionCentre(): Guid | null { return this._distributionCentre }\n public set distributionCentre(value: Guid | null) {\n this._distributionCentre = value === undefined ? null : value;\n }\n /**\n * Whether the stock location is an external stock location.\n */\n public isExternal: boolean = false;\n /**\n * Default Location for production batches.\n */\n public isDefaultForProduction: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.addressLine1 = jsonSerializedObject.addressLine1;\n this.addressLine2 = jsonSerializedObject.addressLine2;\n this.addressLine3 = jsonSerializedObject.addressLine3;\n this.addressLine4 = jsonSerializedObject.addressLine4;\n this.addressLine5 = jsonSerializedObject.addressLine5;\n this.addressLine6 = jsonSerializedObject.addressLine6;\n this.isBonded = jsonSerializedObject.isBonded;\n this.contactName = jsonSerializedObject.contactName;\n this.isDefault = jsonSerializedObject.isDefault;\n this.name = jsonSerializedObject.name;\n this.emailAddress = jsonSerializedObject.emailAddress;\n this.postcode = jsonSerializedObject.postcode;\n this.phoneNumber = jsonSerializedObject.phoneNumber;\n this.isHidden = jsonSerializedObject.isHidden;\n this.warehouseTaxCode = jsonSerializedObject.warehouseTaxCode;\n this.distributionCentre = jsonSerializedObject.distributionCentre == null ? null : Guid.fromString(jsonSerializedObject.distributionCentre);\n this.isExternal = jsonSerializedObject.isExternal;\n this.isDefaultForProduction = jsonSerializedObject.isDefaultForProduction;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.addressLine1 = this.addressLine1;\n toRet.addressLine2 = this.addressLine2;\n toRet.addressLine3 = this.addressLine3;\n toRet.addressLine4 = this.addressLine4;\n toRet.addressLine5 = this.addressLine5;\n toRet.addressLine6 = this.addressLine6;\n toRet.isBonded = this.isBonded;\n toRet.contactName = this.contactName;\n toRet.isDefault = this.isDefault;\n toRet.name = this.name;\n toRet.emailAddress = this.emailAddress;\n toRet.postcode = this.postcode;\n toRet.phoneNumber = this.phoneNumber;\n toRet.isHidden = this.isHidden;\n toRet.warehouseTaxCode = this.warehouseTaxCode;\n toRet.distributionCentre = this.distributionCentre == null ? null : this.distributionCentre.toString();\n toRet.isExternal = this.isExternal;\n toRet.isDefaultForProduction = this.isDefaultForProduction;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"StockLocation.Id cannot be empty\"},\n {field: \"addressLine1\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine1 has too many characters (1000)\"},\n {field: \"addressLine2\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine2 has too many characters (1000)\"},\n {field: \"addressLine3\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine3 has too many characters (1000)\"},\n {field: \"addressLine4\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine4 has too many characters (1000)\"},\n {field: \"addressLine5\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine5 has too many characters (1000)\"},\n {field: \"addressLine6\", rule: (v: any) => v == null || v.length <= 1000 || \"AddressLine6 has too many characters (1000)\"},\n {field: \"contactName\", rule: (v: any) => v == null || v.length <= 1000 || \"ContactName has too many characters (1000)\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"emailAddress\", rule: (v: any) => v == null || v.length <= 1000 || \"EmailAddress has too many characters (1000)\"},\n {field: \"postcode\", rule: (v: any) => v == null || v.length <= 1000 || \"Postcode has too many characters (1000)\"},\n {field: \"phoneNumber\", rule: (v: any) => v == null || v.length <= 1000 || \"PhoneNumber has too many characters (1000)\"},\n {field: \"warehouseTaxCode\", rule: (v: any) => v == null || v.length <= 1000 || \"WarehouseTaxCode has too many characters (1000)\"},\n {field: \"distributionCentre\", rule: (v: any) => v == null || !v.isEmpty() || \"StockLocation.DistributionCentre cannot be empty\"},\n ];\n}\n\n\nexport class GetAllStockLocationsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllStockLocationsResponse extends ModelObject {\n\n public stockLocations: StockLocation[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockLocations = jsonSerializedObject.stockLocations.map((v: any) => new StockLocation(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockLocations = this.stockLocations.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockLocations\", rule: (v: any) => !!v || \"stockLocations is required\"},\n {field: \"stockLocations\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockLocation[]).reduce((acc: Array, curr: StockLocation) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetStockLocationRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockLocationId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockLocationId = this.stockLocationId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \".StockLocationId cannot be empty\"},\n ];\n}\n\n\nexport class GetStockLocationResponse extends ModelObject {\n\n public stockLocation: StockLocation = new StockLocation();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockLocation = new StockLocation(jsonSerializedObject.stockLocation);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockLocation = this.stockLocation.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockLocation\", rule: (v: any) => !!v || \"stockLocation is required\"},\n {field: \"stockLocation\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetStockLocationsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockLocationIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockLocationIds = jsonSerializedObject.stockLocationIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockLocationIds = this.stockLocationIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetStockLocationsResponse extends ModelObject {\n\n public stockLocations: StockLocation[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockLocations = jsonSerializedObject.stockLocations.map((v: any) => new StockLocation(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockLocations = this.stockLocations.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockLocations\", rule: (v: any) => !!v || \"stockLocations is required\"},\n {field: \"stockLocations\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockLocation[]).reduce((acc: Array, curr: StockLocation) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveStockLocationsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockLocations: readonly StockLocation[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockLocations = jsonSerializedObject.stockLocations.map((v: any) => new StockLocation(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockLocations = this.stockLocations.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockLocations\", rule: (v: any) => !!v || \"stockLocations is required\"},\n {field: \"stockLocations\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockLocation[]).reduce((acc: Array, curr: StockLocation) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SetStockLocationIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockLocationId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \".StockLocationId cannot be empty\"},\n ];\n}\n\n\nexport class StockLocationService extends ServiceBase {\n\n public async getAllStockLocations(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllStockLocationsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllStockLocationsResponse(response).stockLocations;\n return this.makeJsonRequest(\"stockLocation/v1/getAllStockLocations\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getStockLocation(tenantId: Guid, stockLocationId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetStockLocationRequest();\n req.tenantId = tenantId;\n req.stockLocationId = stockLocationId;\n const extractor = (response:any) => new GetStockLocationResponse(response).stockLocation;\n return this.makeJsonRequest(\"stockLocation/v1/getStockLocation\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getStockLocations(tenantId: Guid, stockLocationIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetStockLocationsRequest();\n req.tenantId = tenantId;\n req.stockLocationIds = stockLocationIds;\n const extractor = (response:any) => new GetStockLocationsResponse(response).stockLocations;\n return this.makeJsonRequest(\"stockLocation/v1/getStockLocations\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveStockLocations(tenantId: Guid, stockLocations: readonly StockLocation[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveStockLocationsRequest();\n req.tenantId = tenantId;\n req.stockLocations = stockLocations;\n const extractor = null;\n return this.makeJsonRequest(\"stockLocation/v1/saveStockLocations\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setStockLocationIsHidden(tenantId: Guid, stockLocationId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetStockLocationIsHiddenRequest();\n req.tenantId = tenantId;\n req.stockLocationId = stockLocationId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"stockLocation/v1/setStockLocationIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const stockLocationService = new StockLocationService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { StockLocation } from \"@/app/services/generated/stocklocationService\";\nimport { stockLocationService } from \"@/app/services/generated/stocklocationService\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\n\nexport interface IHasStockLocationsCache {\n stockLocations: StockLocationsCache;\n}\n\n// Singleton cache store\nconst stockLocationsCacheStore = new EntityCacheStore(\n EnumCacheEntityType.stockLocation,\n async () => stockLocationService.getAllStockLocations(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class StockLocationsCache extends EntityWithGuidKeyCache {\n constructor() {\n super(stockLocationsCacheStore, (x) => x.id);\n }\n\n public getDefault(): StockLocation | null {\n return this.all.find((x) => x.isDefault) ?? null;\n }\n\n public getProductionDefault(): StockLocation | null {\n return this.all.find((x) => x.isDefaultForProduction) ?? null;\n }\n\n public resolveRequiredStockLocationForAssembly(): StockLocation {\n return (\n this.getProductionDefault() ??\n this.getDefault() ??\n this.all.filter(\n (stockLocation) => !stockLocation.isExternal && !stockLocation.isHidden\n )[0]\n );\n }\n\n public get notExternal(): readonly StockLocation[] {\n return this.all.filter((stockLocation) => !stockLocation.isExternal);\n }\n\n public get notHidden(): readonly StockLocation[] {\n return this.all.filter((stockLocation) => !stockLocation.isHidden);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class VatCode extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * The Code used to communicate this Vat Code to the accounts package for Sales of items with this VAT code. For Sage this is typically 'T0', 'T1', etc. For Xero it is typically 'Standard (20%)', 'Exempt Income', etc.\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public accountsCodeForSales: string = \"\";\n /**\n * The Code used to communicate this Vat Code to the accounts package for Purchases of items with this Vat Code. Only required if different to the code for sales. (Code for sales will be used if this is empty). For Sage this is typically empty as Sage does not distinguish Vat types between sales and purchases. For Xero it is typically '20% (VAT on Expenses)', 'Exempt Expeses', etc.\n * Not Nullable\n * Max Length : 1000\n */\n public accountsCodeForPurchases: string = \"\";\n /**\n * Default Vat Code for new outlets.\n */\n public isDefault: boolean = false;\n /**\n * Exempt Code\n */\n public isExempt: boolean = false;\n /**\n * Export Code\n */\n public isExport: boolean = false;\n /**\n * Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n /**\n * VAT Percentage\n * Not Negative\n */\n public vatPercentage: number = 0;\n public isHidden: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.accountsCodeForSales = jsonSerializedObject.accountsCodeForSales;\n this.accountsCodeForPurchases = jsonSerializedObject.accountsCodeForPurchases;\n this.isDefault = jsonSerializedObject.isDefault;\n this.isExempt = jsonSerializedObject.isExempt;\n this.isExport = jsonSerializedObject.isExport;\n this.name = jsonSerializedObject.name;\n this.vatPercentage = jsonSerializedObject.vatPercentage;\n this.isHidden = jsonSerializedObject.isHidden;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.accountsCodeForSales = this.accountsCodeForSales;\n toRet.accountsCodeForPurchases = this.accountsCodeForPurchases;\n toRet.isDefault = this.isDefault;\n toRet.isExempt = this.isExempt;\n toRet.isExport = this.isExport;\n toRet.name = this.name;\n toRet.vatPercentage = this.vatPercentage;\n toRet.isHidden = this.isHidden;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"VatCode.Id cannot be empty\"},\n {field: \"accountsCodeForSales\", rule: (v: any) => v == null || v.length !== 0 || \"AccountsCodeForSales cannot be empty\"},\n {field: \"accountsCodeForSales\", rule: (v: any) => v == null || v.length <= 1000 || \"AccountsCodeForSales has too many characters (1000)\"},\n {field: \"accountsCodeForPurchases\", rule: (v: any) => v == null || v.length <= 1000 || \"AccountsCodeForPurchases has too many characters (1000)\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n ];\n}\n\n\nexport class GetAllVatCodesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllVatCodesResponse extends ModelObject {\n\n public vatCodes: VatCode[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vatCodes = jsonSerializedObject.vatCodes.map((v: any) => new VatCode(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vatCodes = this.vatCodes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vatCodes\", rule: (v: any) => !!v || \"vatCodes is required\"},\n {field: \"vatCodes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as VatCode[]).reduce((acc: Array, curr: VatCode) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetVatCodeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vatCodeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vatCodeId = Guid.fromString(jsonSerializedObject.vatCodeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vatCodeId = this.vatCodeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"vatCodeId\", rule: (v: any) => !v.isEmpty() || \".VatCodeId cannot be empty\"},\n ];\n}\n\n\nexport class GetVatCodeResponse extends ModelObject {\n\n public vatCode: VatCode = new VatCode();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vatCode = new VatCode(jsonSerializedObject.vatCode);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vatCode = this.vatCode.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vatCode\", rule: (v: any) => !!v || \"vatCode is required\"},\n {field: \"vatCode\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetVatCodesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vatCodeIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vatCodeIds = jsonSerializedObject.vatCodeIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vatCodeIds = this.vatCodeIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetVatCodesResponse extends ModelObject {\n\n public vatCodes: VatCode[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vatCodes = jsonSerializedObject.vatCodes.map((v: any) => new VatCode(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vatCodes = this.vatCodes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vatCodes\", rule: (v: any) => !!v || \"vatCodes is required\"},\n {field: \"vatCodes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as VatCode[]).reduce((acc: Array, curr: VatCode) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetCodeForVatExemptRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetCodeForVatExemptResponse extends ModelObject {\n\n public vatCode: VatCode = new VatCode();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vatCode = new VatCode(jsonSerializedObject.vatCode);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vatCode = this.vatCode.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vatCode\", rule: (v: any) => !!v || \"vatCode is required\"},\n {field: \"vatCode\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveVatCodesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vatCodes: readonly VatCode[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vatCodes = jsonSerializedObject.vatCodes.map((v: any) => new VatCode(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vatCodes = this.vatCodes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"vatCodes\", rule: (v: any) => !!v || \"vatCodes is required\"},\n {field: \"vatCodes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as VatCode[]).reduce((acc: Array, curr: VatCode) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SetVatCodeIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vatCodeId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vatCodeId = Guid.fromString(jsonSerializedObject.vatCodeId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vatCodeId = this.vatCodeId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"vatCodeId\", rule: (v: any) => !v.isEmpty() || \".VatCodeId cannot be empty\"},\n ];\n}\n\n\nexport class VatCodeService extends ServiceBase {\n\n public async getAllVatCodes(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllVatCodesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllVatCodesResponse(response).vatCodes;\n return this.makeJsonRequest(\"vatCode/v1/getAllVatCodes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getVatCode(tenantId: Guid, vatCodeId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetVatCodeRequest();\n req.tenantId = tenantId;\n req.vatCodeId = vatCodeId;\n const extractor = (response:any) => new GetVatCodeResponse(response).vatCode;\n return this.makeJsonRequest(\"vatCode/v1/getVatCode\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getVatCodes(tenantId: Guid, vatCodeIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetVatCodesRequest();\n req.tenantId = tenantId;\n req.vatCodeIds = vatCodeIds;\n const extractor = (response:any) => new GetVatCodesResponse(response).vatCodes;\n return this.makeJsonRequest(\"vatCode/v1/getVatCodes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getCodeForVatExempt(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetCodeForVatExemptRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetCodeForVatExemptResponse(response).vatCode;\n return this.makeJsonRequest(\"vatCode/v1/getCodeForVatExempt\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveVatCodes(tenantId: Guid, vatCodes: readonly VatCode[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveVatCodesRequest();\n req.tenantId = tenantId;\n req.vatCodes = vatCodes;\n const extractor = null;\n return this.makeJsonRequest(\"vatCode/v1/saveVatCodes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setVatCodeIsHidden(tenantId: Guid, vatCodeId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetVatCodeIsHiddenRequest();\n req.tenantId = tenantId;\n req.vatCodeId = vatCodeId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"vatCode/v1/setVatCodeIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const vatCodeService = new VatCodeService();","import type { VatCode } from \"@/app/services/generated/vatcodeService\";\nimport { vatCodeService } from \"@/app/services/generated/vatcodeService\";\nimport { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\n\nexport interface IHasVatCodesCache {\n vatCodes: VatCodesCache;\n}\n\n// Singleton cache store\nconst vatCodesCacheStore = new EntityCacheStore(\n EnumCacheEntityType.vatCode,\n async () => vatCodeService.getAllVatCodes(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class VatCodesCache extends EntityWithGuidKeyCache {\n constructor() {\n super(vatCodesCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumDayOfWeek } from \"./enums/enumDayOfWeek.generated\";\n\n// Model Objects\n\nexport class Courier extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Lead Time in Days.\n * Not Negative\n */\n public leadTimeDays: number = 0;\n /**\n * Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n /**\n * Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n /**\n * Array of days of week on which orders are typically despatched. Will always read in order Monday to Sunday.\n */\n public despatchDays: EnumDayOfWeek[] = [];\n public isHidden: boolean = false;\n private _deliveryServiceId: Guid | null = null;\n /**\n * Delivery Service, if any, to apply by default to orders for delivery by this courier. May be overriden by settings at outlet or group level.\n */\n public get deliveryServiceId(): Guid | null { return this._deliveryServiceId }\n public set deliveryServiceId(value: Guid | null) {\n this._deliveryServiceId = value === undefined ? null : value;\n }\n /**\n * Shows whether DispatchCutOffTime is for the same day or next day.If true, order placed before DispatchCutOffTime is dispatched on the same day else the next day.\n */\n public isSameDayDispatchCutOffTime: boolean = false;\n private _dispatchCutOffTime: LocalTime | null = null;\n /**\n * Cut off time for placing an order. Used to calculate dispatch date for this courier.\n */\n public get dispatchCutOffTime(): LocalTime | null { return this._dispatchCutOffTime }\n public set dispatchCutOffTime(value: LocalTime | null) {\n this._dispatchCutOffTime = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.leadTimeDays = jsonSerializedObject.leadTimeDays;\n this.name = jsonSerializedObject.name;\n this.notes = jsonSerializedObject.notes;\n this.despatchDays = jsonSerializedObject.despatchDays.map((v: any) => EnumDayOfWeek.getByValue(v));\n this.isHidden = jsonSerializedObject.isHidden;\n this.deliveryServiceId = jsonSerializedObject.deliveryServiceId == null ? null : Guid.fromString(jsonSerializedObject.deliveryServiceId);\n this.isSameDayDispatchCutOffTime = jsonSerializedObject.isSameDayDispatchCutOffTime;\n this.dispatchCutOffTime = jsonSerializedObject.dispatchCutOffTime == null ? null : LocalTime.parse(jsonSerializedObject.dispatchCutOffTime);\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.leadTimeDays = this.leadTimeDays;\n toRet.name = this.name;\n toRet.notes = this.notes;\n toRet.despatchDays = this.despatchDays.map(v => v.value);\n toRet.isHidden = this.isHidden;\n toRet.deliveryServiceId = this.deliveryServiceId == null ? null : this.deliveryServiceId.toString();\n toRet.isSameDayDispatchCutOffTime = this.isSameDayDispatchCutOffTime;\n toRet.dispatchCutOffTime = this.dispatchCutOffTime == null ? null : this.dispatchCutOffTime.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"Courier.Id cannot be empty\"},\n {field: \"leadTimeDays\", rule: (v: any) => v == null || v >= 0 || \"LeadTimeDays is not greater than minimum allowed value: 0\"},\n {field: \"leadTimeDays\", rule: (v: any) => v == null || v <= 2147483647 || \"LeadTimeDays is above maximum allowed value: 2147483647\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"deliveryServiceId\", rule: (v: any) => v == null || !v.isEmpty() || \"Courier.DeliveryServiceId cannot be empty\"},\n ];\n}\n\n\nexport class CourierDistributionDates extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n public dispatchDate: LocalDate = LocalDate.ofEpochDay(0);\n public deliveryDate: LocalDate = LocalDate.ofEpochDay(0);\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.dispatchDate = LocalDate.parse(jsonSerializedObject.dispatchDate);\n this.deliveryDate = LocalDate.parse(jsonSerializedObject.deliveryDate);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.dispatchDate = this.dispatchDate.toString();\n toRet.deliveryDate = this.deliveryDate.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"CourierDistributionDates.Id cannot be empty\"},\n ];\n}\n\n\nexport class GetAllCouriersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllCouriersResponse extends ModelObject {\n\n public couriers: Courier[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.couriers = jsonSerializedObject.couriers.map((v: any) => new Courier(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.couriers = this.couriers.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"couriers\", rule: (v: any) => !!v || \"couriers is required\"},\n {field: \"couriers\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Courier[]).reduce((acc: Array, curr: Courier) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetCourierRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public courierId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.courierId = Guid.fromString(jsonSerializedObject.courierId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.courierId = this.courierId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"courierId\", rule: (v: any) => !v.isEmpty() || \".CourierId cannot be empty\"},\n ];\n}\n\n\nexport class GetCourierResponse extends ModelObject {\n\n public courier: Courier = new Courier();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.courier = new Courier(jsonSerializedObject.courier);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.courier = this.courier.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"courier\", rule: (v: any) => !!v || \"courier is required\"},\n {field: \"courier\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetCouriersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public courierIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.courierIds = jsonSerializedObject.courierIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.courierIds = this.courierIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetCouriersResponse extends ModelObject {\n\n public couriers: Courier[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.couriers = jsonSerializedObject.couriers.map((v: any) => new Courier(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.couriers = this.couriers.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"couriers\", rule: (v: any) => !!v || \"couriers is required\"},\n {field: \"couriers\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Courier[]).reduce((acc: Array, curr: Courier) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveCouriersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public couriers: readonly Courier[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.couriers = jsonSerializedObject.couriers.map((v: any) => new Courier(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.couriers = this.couriers.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"couriers\", rule: (v: any) => !!v || \"couriers is required\"},\n {field: \"couriers\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Courier[]).reduce((acc: Array, curr: Courier) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SetCourierIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public courierId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.courierId = Guid.fromString(jsonSerializedObject.courierId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.courierId = this.courierId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"courierId\", rule: (v: any) => !v.isEmpty() || \".CourierId cannot be empty\"},\n ];\n}\n\n\nexport class CalculateCourierDistributionDatesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public courierId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.courierId = Guid.fromString(jsonSerializedObject.courierId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.courierId = this.courierId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"courierId\", rule: (v: any) => !v.isEmpty() || \".CourierId cannot be empty\"},\n ];\n}\n\n\nexport class CalculateCourierDistributionDatesResponse extends ModelObject {\n\n public distributionDates: CourierDistributionDates = new CourierDistributionDates();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.distributionDates = new CourierDistributionDates(jsonSerializedObject.distributionDates);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.distributionDates = this.distributionDates.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"distributionDates\", rule: (v: any) => !!v || \"distributionDates is required\"},\n {field: \"distributionDates\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class CourierService extends ServiceBase {\n\n public async getAllCouriers(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllCouriersRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllCouriersResponse(response).couriers;\n return this.makeJsonRequest(\"courier/v1/getAllCouriers\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getCourier(tenantId: Guid, courierId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetCourierRequest();\n req.tenantId = tenantId;\n req.courierId = courierId;\n const extractor = (response:any) => new GetCourierResponse(response).courier;\n return this.makeJsonRequest(\"courier/v1/getCourier\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getCouriers(tenantId: Guid, courierIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetCouriersRequest();\n req.tenantId = tenantId;\n req.courierIds = courierIds;\n const extractor = (response:any) => new GetCouriersResponse(response).couriers;\n return this.makeJsonRequest(\"courier/v1/getCouriers\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveCouriers(tenantId: Guid, couriers: readonly Courier[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveCouriersRequest();\n req.tenantId = tenantId;\n req.couriers = couriers;\n const extractor = null;\n return this.makeJsonRequest(\"courier/v1/saveCouriers\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setCourierIsHidden(tenantId: Guid, courierId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetCourierIsHiddenRequest();\n req.tenantId = tenantId;\n req.courierId = courierId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"courier/v1/setCourierIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async calculateCourierDistributionDates(tenantId: Guid, courierId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CalculateCourierDistributionDatesRequest();\n req.tenantId = tenantId;\n req.courierId = courierId;\n const extractor = (response:any) => new CalculateCourierDistributionDatesResponse(response).distributionDates;\n return this.makeJsonRequest(\"courier/v1/calculateCourierDistributionDates\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const courierService = new CourierService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { Courier } from \"@/app/services/generated/courierService\";\nimport { courierService } from \"@/app/services/generated/courierService\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\n\nexport interface IHasCouriersCache {\n couriers: CouriersCache;\n}\n\n// Singleton cache store\nconst couriersCacheStore = new EntityCacheStore(\n EnumCacheEntityType.courier,\n async () => courierService.getAllCouriers(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class CouriersCache extends EntityWithGuidKeyCache {\n constructor() {\n super(couriersCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class OutletSubType extends ModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Sub Type Description\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n public isHidden: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.name = jsonSerializedObject.name;\n this.isHidden = jsonSerializedObject.isHidden;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.name = this.name;\n toRet.isHidden = this.isHidden;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"OutletSubType.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n ];\n}\n\n\nexport class GetAllOutletSubTypesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllOutletSubTypesResponse extends ModelObject {\n\n public outletSubTypes: OutletSubType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outletSubTypes = jsonSerializedObject.outletSubTypes.map((v: any) => new OutletSubType(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outletSubTypes = this.outletSubTypes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outletSubTypes\", rule: (v: any) => !!v || \"outletSubTypes is required\"},\n {field: \"outletSubTypes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as OutletSubType[]).reduce((acc: Array, curr: OutletSubType) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetOutletSubTypeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletSubTypeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletSubTypeId = Guid.fromString(jsonSerializedObject.outletSubTypeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletSubTypeId = this.outletSubTypeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletSubTypeId\", rule: (v: any) => !v.isEmpty() || \".OutletSubTypeId cannot be empty\"},\n ];\n}\n\n\nexport class GetOutletSubTypeResponse extends ModelObject {\n\n public outletSubType: OutletSubType = new OutletSubType();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.outletSubType = new OutletSubType(jsonSerializedObject.outletSubType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.outletSubType = this.outletSubType.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"outletSubType\", rule: (v: any) => !!v || \"outletSubType is required\"},\n {field: \"outletSubType\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveOutletSubTypeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletSubType: OutletSubType = new OutletSubType();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletSubType = new OutletSubType(jsonSerializedObject.outletSubType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletSubType = this.outletSubType.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletSubType\", rule: (v: any) => !!v || \"outletSubType is required\"},\n {field: \"outletSubType\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetOutletSubTypeIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletSubTypeId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletSubTypeId = Guid.fromString(jsonSerializedObject.outletSubTypeId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletSubTypeId = this.outletSubTypeId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletSubTypeId\", rule: (v: any) => !v.isEmpty() || \".OutletSubTypeId cannot be empty\"},\n ];\n}\n\n\nexport class OutletSubTypeService extends ServiceBase {\n\n public async getAllOutletSubTypes(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllOutletSubTypesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllOutletSubTypesResponse(response).outletSubTypes;\n return this.makeJsonRequest(\"outletSubType/v1/getAllOutletSubTypes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getOutletSubType(tenantId: Guid, outletSubTypeId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetOutletSubTypeRequest();\n req.tenantId = tenantId;\n req.outletSubTypeId = outletSubTypeId;\n const extractor = (response:any) => new GetOutletSubTypeResponse(response).outletSubType;\n return this.makeJsonRequest(\"outletSubType/v1/getOutletSubType\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveOutletSubType(tenantId: Guid, outletSubType: OutletSubType, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveOutletSubTypeRequest();\n req.tenantId = tenantId;\n req.outletSubType = outletSubType;\n const extractor = null;\n return this.makeJsonRequest(\"outletSubType/v1/saveOutletSubType\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setOutletSubTypeIsHidden(tenantId: Guid, outletSubTypeId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetOutletSubTypeIsHiddenRequest();\n req.tenantId = tenantId;\n req.outletSubTypeId = outletSubTypeId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"outletSubType/v1/setOutletSubTypeIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const outletSubTypeService = new OutletSubTypeService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\nimport type { OutletSubType } from \"@/app/services/generated/outletsubtypeService\";\nimport { outletSubTypeService } from \"@/app/services/generated/outletsubtypeService\";\n\n// Singleton cache store\nconst outletSubTypesCacheStore = new EntityCacheStore(\n EnumCacheEntityType.outletSubType,\n async () => outletSubTypeService.getAllOutletSubTypes(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class OutletSubTypesCache extends EntityWithGuidKeyCache {\n constructor() {\n super(outletSubTypesCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumYesNoEither } from \"./enums/enumYesNoEither.generated\";\n\n// Model Objects\n\nexport class PriceList extends ModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Automatically Calculate Discounts\n */\n public allowsAutomaticDiscounts: boolean = false;\n /**\n * Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n /**\n * Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n /**\n * Use Gross Pricing\n */\n public usesGrossPricing: boolean = false;\n public isHidden: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.allowsAutomaticDiscounts = jsonSerializedObject.allowsAutomaticDiscounts;\n this.name = jsonSerializedObject.name;\n this.notes = jsonSerializedObject.notes;\n this.usesGrossPricing = jsonSerializedObject.usesGrossPricing;\n this.isHidden = jsonSerializedObject.isHidden;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.allowsAutomaticDiscounts = this.allowsAutomaticDiscounts;\n toRet.name = this.name;\n toRet.notes = this.notes;\n toRet.usesGrossPricing = this.usesGrossPricing;\n toRet.isHidden = this.isHidden;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"PriceList.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n ];\n}\n\n\nexport class PriceListLine extends BaseModelObject {\n\n /**\n * Price List\n */\n public priceListId: Guid = Guid.createEmpty();\n /**\n * Stock Item (Expected to be product not material)\n */\n public stockItemId: Guid = Guid.createEmpty();\n private _currentListPrice: number | null = null;\n /**\n * Product Unit List Price\n */\n public get currentListPrice(): number | null { return this._currentListPrice }\n public set currentListPrice(value: number | null) {\n this._currentListPrice = value === undefined ? null : value;\n }\n /**\n * Product is Active on this Price List\n */\n public isAvailable: boolean = false;\n private _plannedListPrice: number | null = null;\n /**\n * Next List Price - prepared for list price\n */\n public get plannedListPrice(): number | null { return this._plannedListPrice }\n public set plannedListPrice(value: number | null) {\n this._plannedListPrice = value === undefined ? null : value;\n }\n private _previousListPrice: number | null = null;\n /**\n * Last List Price - Saved Last List Price so that Prices can be reversed\n */\n public get previousListPrice(): number | null { return this._previousListPrice }\n public set previousListPrice(value: number | null) {\n this._previousListPrice = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.priceListId = Guid.fromString(jsonSerializedObject.priceListId);\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.currentListPrice = jsonSerializedObject.currentListPrice == null ? null : jsonSerializedObject.currentListPrice;\n this.isAvailable = jsonSerializedObject.isAvailable;\n this.plannedListPrice = jsonSerializedObject.plannedListPrice == null ? null : jsonSerializedObject.plannedListPrice;\n this.previousListPrice = jsonSerializedObject.previousListPrice == null ? null : jsonSerializedObject.previousListPrice;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.priceListId = this.priceListId.toString();\n toRet.stockItemId = this.stockItemId.toString();\n toRet.currentListPrice = this.currentListPrice == null ? null : this.currentListPrice;\n toRet.isAvailable = this.isAvailable;\n toRet.plannedListPrice = this.plannedListPrice == null ? null : this.plannedListPrice;\n toRet.previousListPrice = this.previousListPrice == null ? null : this.previousListPrice;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"priceListId\", rule: (v: any) => !v.isEmpty() || \"PriceListLine.PriceListId cannot be empty\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"PriceListLine.StockItemId cannot be empty\"},\n ];\n}\n\n\nexport class NativePriceListLine extends BaseModelObject {\n\n /**\n * Price List\n */\n public priceListId: Guid = Guid.createEmpty();\n /**\n * Stock Item (Expected to be product not material)\n */\n public stockItemId: Guid = Guid.createEmpty();\n private _currentListPrice: number | null = null;\n /**\n * Product Unit List Price\n */\n public get currentListPrice(): number | null { return this._currentListPrice }\n public set currentListPrice(value: number | null) {\n this._currentListPrice = value === undefined ? null : value;\n }\n /**\n * Product is Active on this Price List\n */\n public isAvailable: boolean = false;\n private _plannedListPrice: number | null = null;\n /**\n * Next List Price - prepared for list price\n */\n public get plannedListPrice(): number | null { return this._plannedListPrice }\n public set plannedListPrice(value: number | null) {\n this._plannedListPrice = value === undefined ? null : value;\n }\n private _previousListPrice: number | null = null;\n /**\n * Last List Price - Saved Last List Price so that Prices can be reversed\n */\n public get previousListPrice(): number | null { return this._previousListPrice }\n public set previousListPrice(value: number | null) {\n this._previousListPrice = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.priceListId = Guid.fromString(jsonSerializedObject.priceListId);\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.currentListPrice = jsonSerializedObject.currentListPrice == null ? null : jsonSerializedObject.currentListPrice;\n this.isAvailable = jsonSerializedObject.isAvailable;\n this.plannedListPrice = jsonSerializedObject.plannedListPrice == null ? null : jsonSerializedObject.plannedListPrice;\n this.previousListPrice = jsonSerializedObject.previousListPrice == null ? null : jsonSerializedObject.previousListPrice;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.priceListId = this.priceListId.toString();\n toRet.stockItemId = this.stockItemId.toString();\n toRet.currentListPrice = this.currentListPrice == null ? null : this.currentListPrice;\n toRet.isAvailable = this.isAvailable;\n toRet.plannedListPrice = this.plannedListPrice == null ? null : this.plannedListPrice;\n toRet.previousListPrice = this.previousListPrice == null ? null : this.previousListPrice;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"priceListId\", rule: (v: any) => !v.isEmpty() || \"NativePriceListLine.PriceListId cannot be empty\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"NativePriceListLine.StockItemId cannot be empty\"},\n ];\n}\n\n\nexport class NativePriceListLineFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _priceListIds: Guid[] | null = null;\n public get priceListIds(): Guid[] | null { return this._priceListIds }\n public set priceListIds(value: Guid[] | null) {\n this._priceListIds = value === undefined ? null : value;\n }\n private _itemIds: Guid[] | null = null;\n public get itemIds(): Guid[] | null { return this._itemIds }\n public set itemIds(value: Guid[] | null) {\n this._itemIds = value === undefined ? null : value;\n }\n public availableOrNot: EnumYesNoEither = EnumYesNoEither.either;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.priceListIds = jsonSerializedObject.priceListIds == null ? null : jsonSerializedObject.priceListIds.map((v: any) => Guid.fromString(v));\n this.itemIds = jsonSerializedObject.itemIds == null ? null : jsonSerializedObject.itemIds.map((v: any) => Guid.fromString(v));\n this.availableOrNot = EnumYesNoEither.getByValue(jsonSerializedObject.availableOrNot, this.availableOrNot);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.priceListIds = this.priceListIds == null ? null : this.priceListIds.map(v => v.toString());\n toRet.itemIds = this.itemIds == null ? null : this.itemIds.map(v => v.toString());\n toRet.availableOrNot = this.availableOrNot.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class FilteredNativePriceListLineResults extends ModelObject {\n\n public matchingCount: number = 0;\n public nativePriceListLines: NativePriceListLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.nativePriceListLines = jsonSerializedObject.nativePriceListLines.map((v: any) => new NativePriceListLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.nativePriceListLines = this.nativePriceListLines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"nativePriceListLines\", rule: (v: any) => !!v || \"nativePriceListLines is required\"},\n {field: \"nativePriceListLines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as NativePriceListLine[]).reduce((acc: Array, curr: NativePriceListLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllPriceListsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllPriceListsResponse extends ModelObject {\n\n public priceLists: PriceList[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.priceLists = jsonSerializedObject.priceLists.map((v: any) => new PriceList(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.priceLists = this.priceLists.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"priceLists\", rule: (v: any) => !!v || \"priceLists is required\"},\n {field: \"priceLists\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PriceList[]).reduce((acc: Array, curr: PriceList) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetPriceListRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public priceListId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.priceListId = Guid.fromString(jsonSerializedObject.priceListId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.priceListId = this.priceListId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"priceListId\", rule: (v: any) => !v.isEmpty() || \".PriceListId cannot be empty\"},\n ];\n}\n\n\nexport class GetPriceListResponse extends ModelObject {\n\n public priceList: PriceList = new PriceList();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.priceList = new PriceList(jsonSerializedObject.priceList);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.priceList = this.priceList.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"priceList\", rule: (v: any) => !!v || \"priceList is required\"},\n {field: \"priceList\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetPriceListsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public priceListIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.priceListIds = jsonSerializedObject.priceListIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.priceListIds = this.priceListIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetPriceListsResponse extends ModelObject {\n\n public priceLists: PriceList[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.priceLists = jsonSerializedObject.priceLists.map((v: any) => new PriceList(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.priceLists = this.priceLists.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"priceLists\", rule: (v: any) => !!v || \"priceLists is required\"},\n {field: \"priceLists\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PriceList[]).reduce((acc: Array, curr: PriceList) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SavePriceListRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public priceList: PriceList = new PriceList();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.priceList = new PriceList(jsonSerializedObject.priceList);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.priceList = this.priceList.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"priceList\", rule: (v: any) => !!v || \"priceList is required\"},\n {field: \"priceList\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetPriceListIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public priceListId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.priceListId = Guid.fromString(jsonSerializedObject.priceListId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.priceListId = this.priceListId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"priceListId\", rule: (v: any) => !v.isEmpty() || \".PriceListId cannot be empty\"},\n ];\n}\n\n\nexport class GetLinesForPriceListRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public priceListId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.priceListId = Guid.fromString(jsonSerializedObject.priceListId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.priceListId = this.priceListId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"priceListId\", rule: (v: any) => !v.isEmpty() || \".PriceListId cannot be empty\"},\n ];\n}\n\n\nexport class GetLinesForPriceListResponse extends ModelObject {\n\n public lines: PriceListLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.lines = jsonSerializedObject.lines.map((v: any) => new PriceListLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PriceListLine[]).reduce((acc: Array, curr: PriceListLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllNativePriceListLinesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllNativePriceListLinesResponse extends ModelObject {\n\n public lines: NativePriceListLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.lines = jsonSerializedObject.lines.map((v: any) => new NativePriceListLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as NativePriceListLine[]).reduce((acc: Array, curr: NativePriceListLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllNativePriceListLinesByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: NativePriceListLineFilter = new NativePriceListLineFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new NativePriceListLineFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetAllNativePriceListLinesByFilterResponse extends ModelObject {\n\n public results: FilteredNativePriceListLineResults = new FilteredNativePriceListLineResults();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredNativePriceListLineResults(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SavePriceListLinesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public lines: readonly PriceListLine[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.lines = jsonSerializedObject.lines.map((v: any) => new PriceListLine(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.lines = this.lines.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"lines\", rule: (v: any) => !!v || \"lines is required\"},\n {field: \"lines\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PriceListLine[]).reduce((acc: Array, curr: PriceListLine) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class PriceListService extends ServiceBase {\n\n public async getAllPriceLists(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllPriceListsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllPriceListsResponse(response).priceLists;\n return this.makeJsonRequest(\"priceList/v1/getAllPriceLists\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getPriceList(tenantId: Guid, priceListId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPriceListRequest();\n req.tenantId = tenantId;\n req.priceListId = priceListId;\n const extractor = (response:any) => new GetPriceListResponse(response).priceList;\n return this.makeJsonRequest(\"priceList/v1/getPriceList\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getPriceLists(tenantId: Guid, priceListIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPriceListsRequest();\n req.tenantId = tenantId;\n req.priceListIds = priceListIds;\n const extractor = (response:any) => new GetPriceListsResponse(response).priceLists;\n return this.makeJsonRequest(\"priceList/v1/getPriceLists\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async savePriceList(tenantId: Guid, priceList: PriceList, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SavePriceListRequest();\n req.tenantId = tenantId;\n req.priceList = priceList;\n const extractor = null;\n return this.makeJsonRequest(\"priceList/v1/savePriceList\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setPriceListIsHidden(tenantId: Guid, priceListId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetPriceListIsHiddenRequest();\n req.tenantId = tenantId;\n req.priceListId = priceListId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"priceList/v1/setPriceListIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getLinesForPriceList(tenantId: Guid, priceListId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetLinesForPriceListRequest();\n req.tenantId = tenantId;\n req.priceListId = priceListId;\n const extractor = (response:any) => new GetLinesForPriceListResponse(response).lines;\n return this.makeJsonRequest(\"priceList/v1/getLinesForPriceList\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllNativePriceListLines(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllNativePriceListLinesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllNativePriceListLinesResponse(response).lines;\n return this.makeJsonRequest(\"priceList/v1/getAllNativePriceListLines\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllNativePriceListLinesByFilter(tenantId: Guid, filter: NativePriceListLineFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllNativePriceListLinesByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetAllNativePriceListLinesByFilterResponse(response).results;\n return this.makeJsonRequest(\"priceList/v1/getAllNativePriceListLinesByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async savePriceListLines(tenantId: Guid, lines: readonly PriceListLine[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SavePriceListLinesRequest();\n req.tenantId = tenantId;\n req.lines = lines;\n const extractor = null;\n return this.makeJsonRequest(\"priceList/v1/savePriceListLines\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const priceListService = new PriceListService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\nimport type { PriceList } from \"@/app/services/generated/pricelistService\";\nimport { priceListService } from \"@/app/services/generated/pricelistService\";\n\nexport interface IHasPriceListsCache {\n priceLists: PriceListsCache;\n}\n\n// Singleton cache store\nconst priceListsCacheStore = new EntityCacheStore(\n EnumCacheEntityType.priceList,\n async () => priceListService.getAllPriceLists(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class PriceListsCache extends EntityWithGuidKeyCache {\n constructor() {\n super(priceListsCacheStore, (x) => x.id);\n }\n}\n","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\nimport type { Lead } from \"@/app/services/generated/leadService\";\nimport { leadService } from \"@/app/services/generated/leadService\";\n\n// Singleton cache store\nconst leadsCacheStore = new EntityCacheStore(\n EnumCacheEntityType.lead,\n async () => leadService.getAllLeads(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class LeadsCache extends EntityWithGuidKeyCache {\n constructor() {\n super(leadsCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class PalletType extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Pallet type name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n /**\n * Whether this is the default pallet type. There can be 0 or 1 default pallet types.\n */\n public isDefault: boolean = false;\n public isHidden: boolean = false;\n /**\n * Weight of this type of pallet when empty.\n * Not Negative\n */\n public emptyWeightKg: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.name = jsonSerializedObject.name;\n this.isDefault = jsonSerializedObject.isDefault;\n this.isHidden = jsonSerializedObject.isHidden;\n this.emptyWeightKg = jsonSerializedObject.emptyWeightKg;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.name = this.name;\n toRet.isDefault = this.isDefault;\n toRet.isHidden = this.isHidden;\n toRet.emptyWeightKg = this.emptyWeightKg;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"PalletType.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n ];\n}\n\n\nexport class GetAllPalletTypesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllPalletTypesResponse extends ModelObject {\n\n public palletTypes: PalletType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.palletTypes = jsonSerializedObject.palletTypes.map((v: any) => new PalletType(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.palletTypes = this.palletTypes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"palletTypes\", rule: (v: any) => !!v || \"palletTypes is required\"},\n {field: \"palletTypes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PalletType[]).reduce((acc: Array, curr: PalletType) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetPalletTypeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public palletTypeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.palletTypeId = Guid.fromString(jsonSerializedObject.palletTypeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.palletTypeId = this.palletTypeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"palletTypeId\", rule: (v: any) => !v.isEmpty() || \".PalletTypeId cannot be empty\"},\n ];\n}\n\n\nexport class GetPalletTypeResponse extends ModelObject {\n\n public palletType: PalletType = new PalletType();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.palletType = new PalletType(jsonSerializedObject.palletType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.palletType = this.palletType.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"palletType\", rule: (v: any) => !!v || \"palletType is required\"},\n {field: \"palletType\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetPalletTypesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public palletTypeIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.palletTypeIds = jsonSerializedObject.palletTypeIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.palletTypeIds = this.palletTypeIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetPalletTypesResponse extends ModelObject {\n\n public palletTypes: PalletType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.palletTypes = jsonSerializedObject.palletTypes.map((v: any) => new PalletType(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.palletTypes = this.palletTypes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"palletTypes\", rule: (v: any) => !!v || \"palletTypes is required\"},\n {field: \"palletTypes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PalletType[]).reduce((acc: Array, curr: PalletType) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SavePalletTypeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public palletType: PalletType = new PalletType();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.palletType = new PalletType(jsonSerializedObject.palletType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.palletType = this.palletType.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"palletType\", rule: (v: any) => !!v || \"palletType is required\"},\n {field: \"palletType\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetPalletTypeIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public palletTypeId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.palletTypeId = Guid.fromString(jsonSerializedObject.palletTypeId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.palletTypeId = this.palletTypeId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"palletTypeId\", rule: (v: any) => !v.isEmpty() || \".PalletTypeId cannot be empty\"},\n ];\n}\n\n\nexport class PalletTypeService extends ServiceBase {\n\n public async getAllPalletTypes(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllPalletTypesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllPalletTypesResponse(response).palletTypes;\n return this.makeJsonRequest(\"palletType/v1/getAllPalletTypes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getPalletType(tenantId: Guid, palletTypeId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPalletTypeRequest();\n req.tenantId = tenantId;\n req.palletTypeId = palletTypeId;\n const extractor = (response:any) => new GetPalletTypeResponse(response).palletType;\n return this.makeJsonRequest(\"palletType/v1/getPalletType\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getPalletTypes(tenantId: Guid, palletTypeIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPalletTypesRequest();\n req.tenantId = tenantId;\n req.palletTypeIds = palletTypeIds;\n const extractor = (response:any) => new GetPalletTypesResponse(response).palletTypes;\n return this.makeJsonRequest(\"palletType/v1/getPalletTypes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async savePalletType(tenantId: Guid, palletType: PalletType, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SavePalletTypeRequest();\n req.tenantId = tenantId;\n req.palletType = palletType;\n const extractor = null;\n return this.makeJsonRequest(\"palletType/v1/savePalletType\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setPalletTypeIsHidden(tenantId: Guid, palletTypeId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetPalletTypeIsHiddenRequest();\n req.tenantId = tenantId;\n req.palletTypeId = palletTypeId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"palletType/v1/setPalletTypeIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const palletTypeService = new PalletTypeService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\nimport type { PalletType } from \"@/app/services/generated/pallettypeService\";\nimport { palletTypeService } from \"@/app/services/generated/pallettypeService\";\n\nexport interface IHasPalletTypesCache {\n palletTypes: PalletTypesCache;\n}\n// Singleton cache store\nconst palletTypesCacheStore = new EntityCacheStore(\n EnumCacheEntityType.palletType,\n async () => palletTypeService.getAllPalletTypes(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class PalletTypesCache extends EntityWithGuidKeyCache {\n constructor() {\n super(palletTypesCacheStore, (x) => x.id);\n }\n\n getDefault() {\n return this.allReactive.value.find((palletType) => palletType.isDefault);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumVesselAvailability } from \"./enums/enumVesselAvailability.generated\";\nimport { EnumVesselMainPurpose } from \"./enums/enumVesselMainPurpose.generated\";\n\n// Model Objects\n\nexport class ProductionVessel extends ModelObject {\n\n public vesselTypeId: Guid = Guid.createEmpty();\n /**\n * Display Colour\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public displayColour: string = \"\";\n /**\n * The order for this vessel\n */\n public ordering: number = 0;\n /**\n * Id of the vessel.\n */\n public vesselId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vesselTypeId = Guid.fromString(jsonSerializedObject.vesselTypeId);\n this.displayColour = jsonSerializedObject.displayColour;\n this.ordering = jsonSerializedObject.ordering;\n this.vesselId = Guid.fromString(jsonSerializedObject.vesselId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vesselTypeId = this.vesselTypeId.toString();\n toRet.displayColour = this.displayColour;\n toRet.ordering = this.ordering;\n toRet.vesselId = this.vesselId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vesselTypeId\", rule: (v: any) => !v.isEmpty() || \"ProductionVessel.VesselTypeId cannot be empty\"},\n {field: \"ordering\", rule: (v: any) => v == null || v >= -2147483648 || \"Ordering is not greater than minimum allowed value: -2147483648\"},\n {field: \"ordering\", rule: (v: any) => v == null || v <= 2147483647 || \"Ordering is above maximum allowed value: 2147483647\"},\n {field: \"vesselId\", rule: (v: any) => !v.isEmpty() || \"ProductionVessel.VesselId cannot be empty\"},\n ];\n}\n\n\nexport class CaskVessel extends ModelObject {\n\n /**\n * Id of the vessel.\n */\n public vesselId: Guid = Guid.createEmpty();\n public code: string = \"\";\n private _caskSubLocationId: Guid | null = null;\n public get caskSubLocationId(): Guid | null { return this._caskSubLocationId }\n public set caskSubLocationId(value: Guid | null) {\n this._caskSubLocationId = value === undefined ? null : value;\n }\n private _caskSubSubLocationId: Guid | null = null;\n public get caskSubSubLocationId(): Guid | null { return this._caskSubSubLocationId }\n public set caskSubSubLocationId(value: Guid | null) {\n this._caskSubSubLocationId = value === undefined ? null : value;\n }\n private _caskTypeId: Guid | null = null;\n public get caskTypeId(): Guid | null { return this._caskTypeId }\n public set caskTypeId(value: Guid | null) {\n this._caskTypeId = value === undefined ? null : value;\n }\n private _caskSubTypeId: Guid | null = null;\n public get caskSubTypeId(): Guid | null { return this._caskSubTypeId }\n public set caskSubTypeId(value: Guid | null) {\n this._caskSubTypeId = value === undefined ? null : value;\n }\n public owner: string = \"\";\n private _purchasedDate: LocalDate | null = null;\n public get purchasedDate(): LocalDate | null { return this._purchasedDate }\n public set purchasedDate(value: LocalDate | null) {\n this._purchasedDate = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vesselId = Guid.fromString(jsonSerializedObject.vesselId);\n this.code = jsonSerializedObject.code;\n this.caskSubLocationId = jsonSerializedObject.caskSubLocationId == null ? null : Guid.fromString(jsonSerializedObject.caskSubLocationId);\n this.caskSubSubLocationId = jsonSerializedObject.caskSubSubLocationId == null ? null : Guid.fromString(jsonSerializedObject.caskSubSubLocationId);\n this.caskTypeId = jsonSerializedObject.caskTypeId == null ? null : Guid.fromString(jsonSerializedObject.caskTypeId);\n this.caskSubTypeId = jsonSerializedObject.caskSubTypeId == null ? null : Guid.fromString(jsonSerializedObject.caskSubTypeId);\n this.owner = jsonSerializedObject.owner;\n this.purchasedDate = jsonSerializedObject.purchasedDate == null ? null : LocalDate.parse(jsonSerializedObject.purchasedDate);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vesselId = this.vesselId.toString();\n toRet.code = this.code;\n toRet.caskSubLocationId = this.caskSubLocationId == null ? null : this.caskSubLocationId.toString();\n toRet.caskSubSubLocationId = this.caskSubSubLocationId == null ? null : this.caskSubSubLocationId.toString();\n toRet.caskTypeId = this.caskTypeId == null ? null : this.caskTypeId.toString();\n toRet.caskSubTypeId = this.caskSubTypeId == null ? null : this.caskSubTypeId.toString();\n toRet.owner = this.owner;\n toRet.purchasedDate = this.purchasedDate == null ? null : this.purchasedDate.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vesselId\", rule: (v: any) => !v.isEmpty() || \"CaskVessel.VesselId cannot be empty\"},\n {field: \"code\", rule: (v: any) => v == null || v.length <= 1000 || \"Code has too many characters (1000)\"},\n {field: \"caskSubLocationId\", rule: (v: any) => v == null || !v.isEmpty() || \"CaskVessel.CaskSubLocationId cannot be empty\"},\n {field: \"caskSubSubLocationId\", rule: (v: any) => v == null || !v.isEmpty() || \"CaskVessel.CaskSubSubLocationId cannot be empty\"},\n {field: \"caskTypeId\", rule: (v: any) => v == null || !v.isEmpty() || \"CaskVessel.CaskTypeId cannot be empty\"},\n {field: \"caskSubTypeId\", rule: (v: any) => v == null || !v.isEmpty() || \"CaskVessel.CaskSubTypeId cannot be empty\"},\n {field: \"owner\", rule: (v: any) => v == null || v.length <= 1000 || \"Owner has too many characters (1000)\"},\n ];\n}\n\n\nexport class VesselReadOnly extends ModelObject {\n\n /**\n * Timestamp at which the vessel was created on the system. Captured by system not user editable.\n */\n public createdAt: Instant = Instant.ofEpochMilli(0);\n /**\n * User who created the vessel. Captured by system not user editable.\n */\n public createdBy: Guid = Guid.createEmpty();\n private _currentAssemblyId: Guid | null = null;\n /**\n * The process currently in control of this vessel. Vessel should either be in an Assembly or Process, but not both.\n */\n public get currentAssemblyId(): Guid | null { return this._currentAssemblyId }\n public set currentAssemblyId(value: Guid | null) {\n this._currentAssemblyId = value === undefined ? null : value;\n }\n private _currentProcessId: Guid | null = null;\n /**\n * The process currently in control of this vessel. Vessel should either be in an Assembly or Process, but not both.\n */\n public get currentProcessId(): Guid | null { return this._currentProcessId }\n public set currentProcessId(value: Guid | null) {\n this._currentProcessId = value === undefined ? null : value;\n }\n /**\n * The Use Number for this vessel\n */\n public useNumber: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.createdAt = Instant.parse(jsonSerializedObject.createdAt);\n this.createdBy = Guid.fromString(jsonSerializedObject.createdBy);\n this.currentAssemblyId = jsonSerializedObject.currentAssemblyId == null ? null : Guid.fromString(jsonSerializedObject.currentAssemblyId);\n this.currentProcessId = jsonSerializedObject.currentProcessId == null ? null : Guid.fromString(jsonSerializedObject.currentProcessId);\n this.useNumber = jsonSerializedObject.useNumber;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.createdAt = this.createdAt.toString();\n toRet.createdBy = this.createdBy.toString();\n toRet.currentAssemblyId = this.currentAssemblyId == null ? null : this.currentAssemblyId.toString();\n toRet.currentProcessId = this.currentProcessId == null ? null : this.currentProcessId.toString();\n toRet.useNumber = this.useNumber;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"createdBy\", rule: (v: any) => !v.isEmpty() || \"VesselReadOnly.CreatedBy cannot be empty\"},\n {field: \"currentAssemblyId\", rule: (v: any) => v == null || !v.isEmpty() || \"VesselReadOnly.CurrentAssemblyId cannot be empty\"},\n {field: \"currentProcessId\", rule: (v: any) => v == null || !v.isEmpty() || \"VesselReadOnly.CurrentProcessId cannot be empty\"},\n {field: \"useNumber\", rule: (v: any) => v == null || v >= -2147483648 || \"UseNumber is not greater than minimum allowed value: -2147483648\"},\n {field: \"useNumber\", rule: (v: any) => v == null || v <= 2147483647 || \"UseNumber is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class Vessel extends BaseModelObject {\n\n public id: Guid = Guid.createEmpty();\n public isHidden: boolean = false;\n public version: number = 0;\n /**\n * Capacity of Vessel in Litres\n * Not Negative\n */\n public capacityLitres: number = 0;\n /**\n * Main purpose of the vessel. Used to link the secondary table to this Vessel.\n */\n public mainPurpose: EnumVesselMainPurpose = EnumVesselMainPurpose.unknown;\n /**\n * Display name for this Vessel\n * Not Nullable\n * Not Empty\n * Preserves leading and trailing whitespce.\n */\n public name: string = \"\";\n /**\n * Shortened display name for this Vessel\n * Not Nullable\n * Max Length : 1000\n * Preserves leading and trailing whitespce.\n */\n public shortName: string = \"\";\n /**\n * Notes\n * Not Nullable\n * Max Length : 100000\n * Preserves leading and trailing whitespce.\n */\n public notes: string = \"\";\n /**\n * The Location for this Vessel\n */\n public stockLocationId: Guid = Guid.createEmpty();\n private _supplierId: Guid | null = null;\n /**\n * The Supplier for this Vessel\n */\n public get supplierId(): Guid | null { return this._supplierId }\n public set supplierId(value: Guid | null) {\n this._supplierId = value === undefined ? null : value;\n }\n private _vesselStateId: Guid | null = null;\n /**\n * The current state of the vessel\n */\n public get vesselStateId(): Guid | null { return this._vesselStateId }\n public set vesselStateId(value: Guid | null) {\n this._vesselStateId = value === undefined ? null : value;\n }\n private _weightKg: number | null = null;\n /**\n * Weight of this vessel.\n * Not Negative\n */\n public get weightKg(): number | null { return this._weightKg }\n public set weightKg(value: number | null) {\n this._weightKg = value === undefined ? null : value;\n }\n public readOnly: VesselReadOnly = new VesselReadOnly();\n private _productionVessel: ProductionVessel | null = null;\n public get productionVessel(): ProductionVessel | null { return this._productionVessel }\n public set productionVessel(value: ProductionVessel | null) {\n this._productionVessel = value === undefined ? null : value;\n }\n private _caskVessel: CaskVessel | null = null;\n public get caskVessel(): CaskVessel | null { return this._caskVessel }\n public set caskVessel(value: CaskVessel | null) {\n this._caskVessel = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.isHidden = jsonSerializedObject.isHidden;\n this.version = jsonSerializedObject.version;\n this.capacityLitres = jsonSerializedObject.capacityLitres;\n this.mainPurpose = EnumVesselMainPurpose.getByValue(jsonSerializedObject.mainPurpose, this.mainPurpose);\n this.name = jsonSerializedObject.name;\n this.shortName = jsonSerializedObject.shortName;\n this.notes = jsonSerializedObject.notes;\n this.stockLocationId = Guid.fromString(jsonSerializedObject.stockLocationId);\n this.supplierId = jsonSerializedObject.supplierId == null ? null : Guid.fromString(jsonSerializedObject.supplierId);\n this.vesselStateId = jsonSerializedObject.vesselStateId == null ? null : Guid.fromString(jsonSerializedObject.vesselStateId);\n this.weightKg = jsonSerializedObject.weightKg == null ? null : jsonSerializedObject.weightKg;\n this.readOnly = new VesselReadOnly(jsonSerializedObject.readOnly);\n this.productionVessel = jsonSerializedObject.productionVessel == null ? null : new ProductionVessel(jsonSerializedObject.productionVessel);\n this.caskVessel = jsonSerializedObject.caskVessel == null ? null : new CaskVessel(jsonSerializedObject.caskVessel);\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.isHidden = this.isHidden;\n toRet.version = this.version;\n toRet.capacityLitres = this.capacityLitres;\n toRet.mainPurpose = this.mainPurpose.value;\n toRet.name = this.name;\n toRet.shortName = this.shortName;\n toRet.notes = this.notes;\n toRet.stockLocationId = this.stockLocationId.toString();\n toRet.supplierId = this.supplierId == null ? null : this.supplierId.toString();\n toRet.vesselStateId = this.vesselStateId == null ? null : this.vesselStateId.toString();\n toRet.weightKg = this.weightKg == null ? null : this.weightKg;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.productionVessel = this.productionVessel == null ? null : this.productionVessel?.toJsonSerializedObject() ?? null;\n toRet.caskVessel = this.caskVessel == null ? null : this.caskVessel?.toJsonSerializedObject() ?? null;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"Vessel.Id cannot be empty\"},\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"shortName\", rule: (v: any) => v == null || v.length <= 1000 || \"ShortName has too many characters (1000)\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"stockLocationId\", rule: (v: any) => !v.isEmpty() || \"Vessel.StockLocationId cannot be empty\"},\n {field: \"supplierId\", rule: (v: any) => v == null || !v.isEmpty() || \"Vessel.SupplierId cannot be empty\"},\n {field: \"vesselStateId\", rule: (v: any) => v == null || !v.isEmpty() || \"Vessel.VesselStateId cannot be empty\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"productionVessel\", rule: (v: any) => (v === null) || v.validate()},\n {field: \"caskVessel\", rule: (v: any) => (v === null) || v.validate()},\n ];\n}\n\n\nexport class VesselAvailabilityState extends ModelObject {\n\n public vesselId: Guid = Guid.createEmpty();\n public availability: EnumVesselAvailability = EnumVesselAvailability.available;\n public requiredMaintenanceRecipeId: Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vesselId = Guid.fromString(jsonSerializedObject.vesselId);\n this.availability = EnumVesselAvailability.getByValue(jsonSerializedObject.availability, this.availability);\n this.requiredMaintenanceRecipeId = jsonSerializedObject.requiredMaintenanceRecipeId.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vesselId = this.vesselId.toString();\n toRet.availability = this.availability.value;\n toRet.requiredMaintenanceRecipeId = this.requiredMaintenanceRecipeId.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vesselId\", rule: (v: any) => !v.isEmpty() || \"VesselAvailabilityState.VesselId cannot be empty\"},\n ];\n}\n\n\nexport class VesselCalculatedDetail extends ModelObject {\n\n public vesselId: Guid = Guid.createEmpty();\n private _currentAssemblyFillDate: LocalDate | null = null;\n /**\n * Vessel activity first fill date\n */\n public get currentAssemblyFillDate(): LocalDate | null { return this._currentAssemblyFillDate }\n public set currentAssemblyFillDate(value: LocalDate | null) {\n this._currentAssemblyFillDate = value === undefined ? null : value;\n }\n /**\n * Current assembly/process number\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public number: string = \"\";\n private _currentAbv: number | null = null;\n /**\n * From the latest QC test measurement of type ABV. Null \n */\n public get currentAbv(): number | null { return this._currentAbv }\n public set currentAbv(value: number | null) {\n this._currentAbv = value === undefined ? null : value;\n }\n /**\n * Current assembly/process batch number. Empty if not yet defined.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public batchNumber: string = \"\";\n private _contents: Guid | null = null;\n /**\n * Current assembly/process output produced. Null if not yet defined.\n */\n public get contents(): Guid | null { return this._contents }\n public set contents(value: Guid | null) {\n this._contents = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vesselId = Guid.fromString(jsonSerializedObject.vesselId);\n this.currentAssemblyFillDate = jsonSerializedObject.currentAssemblyFillDate == null ? null : LocalDate.parse(jsonSerializedObject.currentAssemblyFillDate);\n this.number = jsonSerializedObject.number;\n this.currentAbv = jsonSerializedObject.currentAbv == null ? null : jsonSerializedObject.currentAbv;\n this.batchNumber = jsonSerializedObject.batchNumber;\n this.contents = jsonSerializedObject.contents == null ? null : Guid.fromString(jsonSerializedObject.contents);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vesselId = this.vesselId.toString();\n toRet.currentAssemblyFillDate = this.currentAssemblyFillDate == null ? null : this.currentAssemblyFillDate.toString();\n toRet.number = this.number;\n toRet.currentAbv = this.currentAbv == null ? null : this.currentAbv;\n toRet.batchNumber = this.batchNumber;\n toRet.contents = this.contents == null ? null : this.contents.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vesselId\", rule: (v: any) => !v.isEmpty() || \"VesselCalculatedDetail.VesselId cannot be empty\"},\n {field: \"contents\", rule: (v: any) => v == null || !v.isEmpty() || \"VesselCalculatedDetail.Contents cannot be empty\"},\n ];\n}\n\n\nexport class VesselFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _limitMainPurpose: EnumVesselMainPurpose[] | null = null;\n public get limitMainPurpose(): EnumVesselMainPurpose[] | null { return this._limitMainPurpose }\n public set limitMainPurpose(value: EnumVesselMainPurpose[] | null) {\n this._limitMainPurpose = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.limitMainPurpose = jsonSerializedObject.limitMainPurpose == null ? null : jsonSerializedObject.limitMainPurpose.map((v: any) => EnumVesselMainPurpose.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.limitMainPurpose = this.limitMainPurpose == null ? null : this.limitMainPurpose.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class FilteredVesselResults extends ModelObject {\n\n public matchingCount: number = 0;\n public vessels: Vessel[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.vessels = jsonSerializedObject.vessels.map((v: any) => new Vessel(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.vessels = this.vessels.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"vessels\", rule: (v: any) => !!v || \"vessels is required\"},\n {field: \"vessels\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Vessel[]).reduce((acc: Array, curr: Vessel) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class VesselValuation extends ModelObject {\n\n public vesselId: Guid = Guid.createEmpty();\n private _value: number | null = null;\n public get value(): number | null { return this._value }\n public set value(value: number | null) {\n this._value = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vesselId = Guid.fromString(jsonSerializedObject.vesselId);\n this.value = jsonSerializedObject.value == null ? null : jsonSerializedObject.value;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vesselId = this.vesselId.toString();\n toRet.value = this.value == null ? null : this.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vesselId\", rule: (v: any) => !v.isEmpty() || \"VesselValuation.VesselId cannot be empty\"},\n ];\n}\n\n\nexport class GetVesselRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vesselId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vesselId = Guid.fromString(jsonSerializedObject.vesselId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vesselId = this.vesselId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"vesselId\", rule: (v: any) => !v.isEmpty() || \".VesselId cannot be empty\"},\n ];\n}\n\n\nexport class GetVesselResponse extends ModelObject {\n\n public vessel: Vessel = new Vessel();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vessel = new Vessel(jsonSerializedObject.vessel);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vessel = this.vessel.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vessel\", rule: (v: any) => !!v || \"vessel is required\"},\n {field: \"vessel\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetVesselsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vesselIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vesselIds = jsonSerializedObject.vesselIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vesselIds = this.vesselIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetVesselsResponse extends ModelObject {\n\n public vessels: Vessel[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vessels = jsonSerializedObject.vessels.map((v: any) => new Vessel(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vessels = this.vessels.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vessels\", rule: (v: any) => !!v || \"vessels is required\"},\n {field: \"vessels\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Vessel[]).reduce((acc: Array, curr: Vessel) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllVesselsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllVesselsResponse extends ModelObject {\n\n public vessels: Vessel[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vessels = jsonSerializedObject.vessels.map((v: any) => new Vessel(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vessels = this.vessels.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vessels\", rule: (v: any) => !!v || \"vessels is required\"},\n {field: \"vessels\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Vessel[]).reduce((acc: Array, curr: Vessel) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveVesselRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vessel: Vessel = new Vessel();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vessel = new Vessel(jsonSerializedObject.vessel);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vessel = this.vessel.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"vessel\", rule: (v: any) => !!v || \"vessel is required\"},\n {field: \"vessel\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class UpdateProductionVesselOrderingRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vesselIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vesselIds = jsonSerializedObject.vesselIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vesselIds = this.vesselIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetVesselsLockedByAssemblyRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public assemblyId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.assemblyId = Guid.fromString(jsonSerializedObject.assemblyId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.assemblyId = this.assemblyId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"assemblyId\", rule: (v: any) => !v.isEmpty() || \".AssemblyId cannot be empty\"},\n ];\n}\n\n\nexport class GetVesselsLockedByAssemblyResponse extends ModelObject {\n\n public vessels: Vessel[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vessels = jsonSerializedObject.vessels.map((v: any) => new Vessel(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vessels = this.vessels.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vessels\", rule: (v: any) => !!v || \"vessels is required\"},\n {field: \"vessels\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Vessel[]).reduce((acc: Array, curr: Vessel) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class LockVesselsForAssemblyRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public assemblyId: Guid = Guid.createEmpty();\n public vesselIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.assemblyId = Guid.fromString(jsonSerializedObject.assemblyId);\n this.vesselIds = jsonSerializedObject.vesselIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.assemblyId = this.assemblyId.toString();\n toRet.vesselIds = this.vesselIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"assemblyId\", rule: (v: any) => !v.isEmpty() || \".AssemblyId cannot be empty\"},\n ];\n}\n\n\nexport class AreVesselsAvailableRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vesselIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vesselIds = jsonSerializedObject.vesselIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vesselIds = this.vesselIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class AreVesselsAvailableResponse extends ModelObject {\n\n public availabilities: VesselAvailabilityState[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.availabilities = jsonSerializedObject.availabilities.map((v: any) => new VesselAvailabilityState(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.availabilities = this.availabilities.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"availabilities\", rule: (v: any) => !!v || \"availabilities is required\"},\n {field: \"availabilities\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as VesselAvailabilityState[]).reduce((acc: Array, curr: VesselAvailabilityState) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class ReleaseVesselsFromAssemblyRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public assemblyId: Guid = Guid.createEmpty();\n public vesselIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.assemblyId = Guid.fromString(jsonSerializedObject.assemblyId);\n this.vesselIds = jsonSerializedObject.vesselIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.assemblyId = this.assemblyId.toString();\n toRet.vesselIds = this.vesselIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"assemblyId\", rule: (v: any) => !v.isEmpty() || \".AssemblyId cannot be empty\"},\n ];\n}\n\n\nexport class TransferVesselLocksBetweenAssembliesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public sourceAssemblyId: Guid = Guid.createEmpty();\n public targetAssemblyId: Guid = Guid.createEmpty();\n public vesselIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.sourceAssemblyId = Guid.fromString(jsonSerializedObject.sourceAssemblyId);\n this.targetAssemblyId = Guid.fromString(jsonSerializedObject.targetAssemblyId);\n this.vesselIds = jsonSerializedObject.vesselIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.sourceAssemblyId = this.sourceAssemblyId.toString();\n toRet.targetAssemblyId = this.targetAssemblyId.toString();\n toRet.vesselIds = this.vesselIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"sourceAssemblyId\", rule: (v: any) => !v.isEmpty() || \".SourceAssemblyId cannot be empty\"},\n {field: \"targetAssemblyId\", rule: (v: any) => !v.isEmpty() || \".TargetAssemblyId cannot be empty\"},\n ];\n}\n\n\nexport class SetVesselIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vesselId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vesselId = Guid.fromString(jsonSerializedObject.vesselId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vesselId = this.vesselId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"vesselId\", rule: (v: any) => !v.isEmpty() || \".VesselId cannot be empty\"},\n ];\n}\n\n\nexport class GetVesselCalculatedDetailsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vesselIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vesselIds = jsonSerializedObject.vesselIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vesselIds = this.vesselIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetVesselCalculatedDetailsResponse extends ModelObject {\n\n public vesselCalculatedDetails: VesselCalculatedDetail[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vesselCalculatedDetails = jsonSerializedObject.vesselCalculatedDetails.map((v: any) => new VesselCalculatedDetail(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vesselCalculatedDetails = this.vesselCalculatedDetails.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vesselCalculatedDetails\", rule: (v: any) => !!v || \"vesselCalculatedDetails is required\"},\n {field: \"vesselCalculatedDetails\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as VesselCalculatedDetail[]).reduce((acc: Array, curr: VesselCalculatedDetail) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetVesselsByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: VesselFilter = new VesselFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new VesselFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetVesselsByFilterResponse extends ModelObject {\n\n public results: FilteredVesselResults = new FilteredVesselResults();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredVesselResults(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetVesselsLockedByProcessRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processId = this.processId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \".ProcessId cannot be empty\"},\n ];\n}\n\n\nexport class GetVesselsLockedByProcessResponse extends ModelObject {\n\n public vessels: Vessel[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vessels = jsonSerializedObject.vessels.map((v: any) => new Vessel(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vessels = this.vessels.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vessels\", rule: (v: any) => !!v || \"vessels is required\"},\n {field: \"vessels\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Vessel[]).reduce((acc: Array, curr: Vessel) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class LockVesselsForProcessRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processId: Guid = Guid.createEmpty();\n public vesselIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n this.vesselIds = jsonSerializedObject.vesselIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processId = this.processId.toString();\n toRet.vesselIds = this.vesselIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \".ProcessId cannot be empty\"},\n ];\n}\n\n\nexport class ReleaseVesselsFromProcessRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processId: Guid = Guid.createEmpty();\n public vesselIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n this.vesselIds = jsonSerializedObject.vesselIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processId = this.processId.toString();\n toRet.vesselIds = this.vesselIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \".ProcessId cannot be empty\"},\n ];\n}\n\n\nexport class TransferVesselLocksBetweenProcessesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public sourceProcessId: Guid = Guid.createEmpty();\n public targetProcessId: Guid = Guid.createEmpty();\n public vesselIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.sourceProcessId = Guid.fromString(jsonSerializedObject.sourceProcessId);\n this.targetProcessId = Guid.fromString(jsonSerializedObject.targetProcessId);\n this.vesselIds = jsonSerializedObject.vesselIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.sourceProcessId = this.sourceProcessId.toString();\n toRet.targetProcessId = this.targetProcessId.toString();\n toRet.vesselIds = this.vesselIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"sourceProcessId\", rule: (v: any) => !v.isEmpty() || \".SourceProcessId cannot be empty\"},\n {field: \"targetProcessId\", rule: (v: any) => !v.isEmpty() || \".TargetProcessId cannot be empty\"},\n ];\n}\n\n\nexport class GetVesselsLockedByProcessesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processIds = jsonSerializedObject.processIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processIds = this.processIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetVesselsLockedByProcessesResponse extends ModelObject {\n\n public vessels: Vessel[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vessels = jsonSerializedObject.vessels.map((v: any) => new Vessel(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vessels = this.vessels.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vessels\", rule: (v: any) => !!v || \"vessels is required\"},\n {field: \"vessels\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Vessel[]).reduce((acc: Array, curr: Vessel) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetVesselsLockedByAssembliesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public assemblyIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.assemblyIds = jsonSerializedObject.assemblyIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.assemblyIds = this.assemblyIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetVesselsLockedByAssembliesResponse extends ModelObject {\n\n public vessels: Vessel[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vessels = jsonSerializedObject.vessels.map((v: any) => new Vessel(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vessels = this.vessels.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vessels\", rule: (v: any) => !!v || \"vessels is required\"},\n {field: \"vessels\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Vessel[]).reduce((acc: Array, curr: Vessel) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetVesselsCurrentValueRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vesselIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vesselIds = jsonSerializedObject.vesselIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vesselIds = this.vesselIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetVesselsCurrentValueResponse extends ModelObject {\n\n public vesselsValuation: VesselValuation[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vesselsValuation = jsonSerializedObject.vesselsValuation.map((v: any) => new VesselValuation(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vesselsValuation = this.vesselsValuation.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vesselsValuation\", rule: (v: any) => !!v || \"vesselsValuation is required\"},\n {field: \"vesselsValuation\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as VesselValuation[]).reduce((acc: Array, curr: VesselValuation) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class EvaluateVesselsCurrentValueRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class EvaluateVesselsCurrentValueResponse extends ModelObject {\n\n public vesselsValuation: VesselValuation[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vesselsValuation = jsonSerializedObject.vesselsValuation.map((v: any) => new VesselValuation(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vesselsValuation = this.vesselsValuation.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vesselsValuation\", rule: (v: any) => !!v || \"vesselsValuation is required\"},\n {field: \"vesselsValuation\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as VesselValuation[]).reduce((acc: Array, curr: VesselValuation) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class VesselService extends ServiceBase {\n\n public async getVessel(tenantId: Guid, vesselId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetVesselRequest();\n req.tenantId = tenantId;\n req.vesselId = vesselId;\n const extractor = (response:any) => new GetVesselResponse(response).vessel;\n return this.makeJsonRequest(\"vessel/v2/getVessel\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getVessels(tenantId: Guid, vesselIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetVesselsRequest();\n req.tenantId = tenantId;\n req.vesselIds = vesselIds;\n const extractor = (response:any) => new GetVesselsResponse(response).vessels;\n return this.makeJsonRequest(\"vessel/v2/getVessels\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllVessels(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllVesselsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllVesselsResponse(response).vessels;\n return this.makeJsonRequest(\"vessel/v2/getAllVessels\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveVessel(tenantId: Guid, vessel: Vessel, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveVesselRequest();\n req.tenantId = tenantId;\n req.vessel = vessel;\n const extractor = null;\n return this.makeJsonRequest(\"vessel/v2/saveVessel\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updateProductionVesselOrdering(tenantId: Guid, vesselIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdateProductionVesselOrderingRequest();\n req.tenantId = tenantId;\n req.vesselIds = vesselIds;\n const extractor = null;\n return this.makeJsonRequest(\"vessel/v2/updateProductionVesselOrdering\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getVesselsLockedByAssembly(tenantId: Guid, assemblyId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetVesselsLockedByAssemblyRequest();\n req.tenantId = tenantId;\n req.assemblyId = assemblyId;\n const extractor = (response:any) => new GetVesselsLockedByAssemblyResponse(response).vessels;\n return this.makeJsonRequest(\"vessel/v2/getVesselsLockedByAssembly\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async lockVesselsForAssembly(tenantId: Guid, assemblyId: Guid, vesselIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new LockVesselsForAssemblyRequest();\n req.tenantId = tenantId;\n req.assemblyId = assemblyId;\n req.vesselIds = vesselIds;\n const extractor = null;\n return this.makeJsonRequest(\"vessel/v2/lockVesselsForAssembly\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async areVesselsAvailable(tenantId: Guid, vesselIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new AreVesselsAvailableRequest();\n req.tenantId = tenantId;\n req.vesselIds = vesselIds;\n const extractor = (response:any) => new AreVesselsAvailableResponse(response).availabilities;\n return this.makeJsonRequest(\"vessel/v2/areVesselsAvailable\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async releaseVesselsFromAssembly(tenantId: Guid, assemblyId: Guid, vesselIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new ReleaseVesselsFromAssemblyRequest();\n req.tenantId = tenantId;\n req.assemblyId = assemblyId;\n req.vesselIds = vesselIds;\n const extractor = null;\n return this.makeJsonRequest(\"vessel/v2/releaseVesselsFromAssembly\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async transferVesselLocksBetweenAssemblies(tenantId: Guid, sourceAssemblyId: Guid, targetAssemblyId: Guid, vesselIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new TransferVesselLocksBetweenAssembliesRequest();\n req.tenantId = tenantId;\n req.sourceAssemblyId = sourceAssemblyId;\n req.targetAssemblyId = targetAssemblyId;\n req.vesselIds = vesselIds;\n const extractor = null;\n return this.makeJsonRequest(\"vessel/v2/transferVesselLocksBetweenAssemblies\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setVesselIsHidden(tenantId: Guid, vesselId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetVesselIsHiddenRequest();\n req.tenantId = tenantId;\n req.vesselId = vesselId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"vessel/v2/setVesselIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getVesselCalculatedDetails(tenantId: Guid, vesselIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetVesselCalculatedDetailsRequest();\n req.tenantId = tenantId;\n req.vesselIds = vesselIds;\n const extractor = (response:any) => new GetVesselCalculatedDetailsResponse(response).vesselCalculatedDetails;\n return this.makeJsonRequest(\"vessel/v2/getVesselCalculatedDetails\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getVesselsByFilter(tenantId: Guid, filter: VesselFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetVesselsByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetVesselsByFilterResponse(response).results;\n return this.makeJsonRequest(\"vessel/v2/getVesselsByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getVesselsLockedByProcess(tenantId: Guid, processId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetVesselsLockedByProcessRequest();\n req.tenantId = tenantId;\n req.processId = processId;\n const extractor = (response:any) => new GetVesselsLockedByProcessResponse(response).vessels;\n return this.makeJsonRequest(\"vessel/v2/getVesselsLockedByProcess\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async lockVesselsForProcess(tenantId: Guid, processId: Guid, vesselIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new LockVesselsForProcessRequest();\n req.tenantId = tenantId;\n req.processId = processId;\n req.vesselIds = vesselIds;\n const extractor = null;\n return this.makeJsonRequest(\"vessel/v2/lockVesselsForProcess\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async releaseVesselsFromProcess(tenantId: Guid, processId: Guid, vesselIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new ReleaseVesselsFromProcessRequest();\n req.tenantId = tenantId;\n req.processId = processId;\n req.vesselIds = vesselIds;\n const extractor = null;\n return this.makeJsonRequest(\"vessel/v2/releaseVesselsFromProcess\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async transferVesselLocksBetweenProcesses(tenantId: Guid, sourceProcessId: Guid, targetProcessId: Guid, vesselIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new TransferVesselLocksBetweenProcessesRequest();\n req.tenantId = tenantId;\n req.sourceProcessId = sourceProcessId;\n req.targetProcessId = targetProcessId;\n req.vesselIds = vesselIds;\n const extractor = null;\n return this.makeJsonRequest(\"vessel/v2/transferVesselLocksBetweenProcesses\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getVesselsLockedByProcesses(tenantId: Guid, processIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetVesselsLockedByProcessesRequest();\n req.tenantId = tenantId;\n req.processIds = processIds;\n const extractor = (response:any) => new GetVesselsLockedByProcessesResponse(response).vessels;\n return this.makeJsonRequest(\"vessel/v2/getVesselsLockedByProcesses\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getVesselsLockedByAssemblies(tenantId: Guid, assemblyIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetVesselsLockedByAssembliesRequest();\n req.tenantId = tenantId;\n req.assemblyIds = assemblyIds;\n const extractor = (response:any) => new GetVesselsLockedByAssembliesResponse(response).vessels;\n return this.makeJsonRequest(\"vessel/v2/getVesselsLockedByAssemblies\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getVesselsCurrentValue(tenantId: Guid, vesselIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetVesselsCurrentValueRequest();\n req.tenantId = tenantId;\n req.vesselIds = vesselIds;\n const extractor = (response:any) => new GetVesselsCurrentValueResponse(response).vesselsValuation;\n return this.makeJsonRequest(\"vessel/v2/getVesselsCurrentValue\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const vesselService = new VesselService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { Vessel } from \"@/app/services/generated/vesselv2Service\";\nimport { vesselService } from \"@/app/services/generated/vesselv2Service\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\nimport type {\n VesselWithCaskVessel,\n VesselWithProductionVessel,\n} from \"@/app/services/extensions/vesselv2ServiceExtended\";\nimport type Guid from \"@/app/types/common/guid\";\nimport type { ComputedRef } from \"vue\";\nimport { computed } from \"vue\";\n\nexport interface IHasVesselsCache {\n vessels: VesselsCache;\n}\n\n// Singleton cache store\nconst vesselsCacheStore = new EntityCacheStore(\n EnumCacheEntityType.vessel,\n async () => vesselService.getAllVessels(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class VesselsCache extends EntityWithGuidKeyCache {\n private _allOrdered: ComputedRef;\n\n constructor() {\n super(vesselsCacheStore, (x) => x.id);\n this._allOrdered = computed(() =>\n this.all\n .slice()\n .sort(\n (a, b) =>\n (a.productionVessel?.ordering ?? 0) -\n (b.productionVessel?.ordering ?? 0)\n )\n .sort(\n (a, b) => (a.productionVessel ? 0 : 1) - (b.productionVessel ? 0 : 1)\n )\n );\n }\n\n public get allOrdered() {\n return this._allOrdered.value;\n }\n\n public get allProductionVesselsOrderedReactive() {\n return Object.freeze(\n this.allOrdered.filter((x) => x.productionVessel)\n ) as readonly VesselWithProductionVessel[];\n }\n\n public get allCaskVesselsReactive() {\n return Object.freeze(\n this.allOrdered.filter(\n (x) => x.caskVessel\n ) as readonly Readonly[]\n );\n }\n\n public allAssignedToProcess(processId: Guid) {\n return this.allOrdered.filter((x) =>\n x.readOnly.currentProcessId?.equals(processId)\n );\n }\n\n public allUnassigned() {\n return this.allOrdered.filter(\n (x) => !x.readOnly.currentAssemblyId && !x.readOnly.currentProcessId\n );\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumVesselTypeIcon } from \"./enums/enumVesselTypeIcon.generated\";\n\n// Model Objects\n\nexport class VesselType extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Vessel Type Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n public isHidden: boolean = false;\n /**\n * Vessel Icon Type\n */\n public icon: EnumVesselTypeIcon = EnumVesselTypeIcon.cylindrocononical;\n public capabilities: Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.name = jsonSerializedObject.name;\n this.isHidden = jsonSerializedObject.isHidden;\n this.icon = EnumVesselTypeIcon.getByValue(jsonSerializedObject.icon, this.icon);\n this.capabilities = jsonSerializedObject.capabilities.map((v: any) => Guid.fromString(v));\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.name = this.name;\n toRet.isHidden = this.isHidden;\n toRet.icon = this.icon.value;\n toRet.capabilities = this.capabilities.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"VesselType.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n ];\n}\n\n\nexport class GetVesselTypesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vesselTypeIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vesselTypeIds = jsonSerializedObject.vesselTypeIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vesselTypeIds = this.vesselTypeIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetVesselTypesResponse extends ModelObject {\n\n public vesselTypes: VesselType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vesselTypes = jsonSerializedObject.vesselTypes.map((v: any) => new VesselType(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vesselTypes = this.vesselTypes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vesselTypes\", rule: (v: any) => !!v || \"vesselTypes is required\"},\n {field: \"vesselTypes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as VesselType[]).reduce((acc: Array, curr: VesselType) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllVesselTypesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllVesselTypesResponse extends ModelObject {\n\n public vesselTypes: VesselType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vesselTypes = jsonSerializedObject.vesselTypes.map((v: any) => new VesselType(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vesselTypes = this.vesselTypes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vesselTypes\", rule: (v: any) => !!v || \"vesselTypes is required\"},\n {field: \"vesselTypes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as VesselType[]).reduce((acc: Array, curr: VesselType) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveVesselTypeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vesselType: VesselType = new VesselType();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vesselType = new VesselType(jsonSerializedObject.vesselType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vesselType = this.vesselType.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"vesselType\", rule: (v: any) => !!v || \"vesselType is required\"},\n {field: \"vesselType\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetVesselTypeIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vesselTypeId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vesselTypeId = Guid.fromString(jsonSerializedObject.vesselTypeId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vesselTypeId = this.vesselTypeId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"vesselTypeId\", rule: (v: any) => !v.isEmpty() || \".VesselTypeId cannot be empty\"},\n ];\n}\n\n\nexport class VesselTypeService extends ServiceBase {\n\n public async getVesselTypes(tenantId: Guid, vesselTypeIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetVesselTypesRequest();\n req.tenantId = tenantId;\n req.vesselTypeIds = vesselTypeIds;\n const extractor = (response:any) => new GetVesselTypesResponse(response).vesselTypes;\n return this.makeJsonRequest(\"vesselType/v1/getVesselTypes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllVesselTypes(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllVesselTypesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllVesselTypesResponse(response).vesselTypes;\n return this.makeJsonRequest(\"vesselType/v1/getAllVesselTypes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveVesselType(tenantId: Guid, vesselType: VesselType, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveVesselTypeRequest();\n req.tenantId = tenantId;\n req.vesselType = vesselType;\n const extractor = null;\n return this.makeJsonRequest(\"vesselType/v1/saveVesselType\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setVesselTypeIsHidden(tenantId: Guid, vesselTypeId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetVesselTypeIsHiddenRequest();\n req.tenantId = tenantId;\n req.vesselTypeId = vesselTypeId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"vesselType/v1/setVesselTypeIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const vesselTypeService = new VesselTypeService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { VesselType } from \"@/app/services/generated/vesseltypeService\";\nimport { vesselTypeService } from \"@/app/services/generated/vesseltypeService\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\n\nexport interface IHasVesselTypesCache {\n vesselTypes: VesselTypesCache;\n}\n\n// Singleton cache store\nconst vesselTypesCacheStore = new EntityCacheStore(\n EnumCacheEntityType.vesselType,\n async () => vesselTypeService.getAllVesselTypes(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class VesselTypesCache extends EntityWithGuidKeyCache {\n constructor() {\n super(vesselTypesCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumVesselStateIcon } from \"./enums/enumVesselStateIcon.generated\";\n\n// Model Objects\n\nexport class VesselState extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Vessel State Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n public isHidden: boolean = false;\n /**\n * Vessel Icon Type\n */\n public icon: EnumVesselStateIcon = EnumVesselStateIcon.none;\n /**\n * Vessel State Description\n * Not Nullable\n */\n public description: string = \"\";\n /**\n * Vessel State Colour\n * Not Nullable\n */\n public colour: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.name = jsonSerializedObject.name;\n this.isHidden = jsonSerializedObject.isHidden;\n this.icon = EnumVesselStateIcon.getByValue(jsonSerializedObject.icon, this.icon);\n this.description = jsonSerializedObject.description;\n this.colour = jsonSerializedObject.colour;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.name = this.name;\n toRet.isHidden = this.isHidden;\n toRet.icon = this.icon.value;\n toRet.description = this.description;\n toRet.colour = this.colour;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"VesselState.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n ];\n}\n\n\nexport class GetVesselStatesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vesselStateIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vesselStateIds = jsonSerializedObject.vesselStateIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vesselStateIds = this.vesselStateIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetVesselStatesResponse extends ModelObject {\n\n public vesselStates: VesselState[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vesselStates = jsonSerializedObject.vesselStates.map((v: any) => new VesselState(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vesselStates = this.vesselStates.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vesselStates\", rule: (v: any) => !!v || \"vesselStates is required\"},\n {field: \"vesselStates\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as VesselState[]).reduce((acc: Array, curr: VesselState) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllVesselStatesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllVesselStatesResponse extends ModelObject {\n\n public vesselStates: VesselState[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vesselStates = jsonSerializedObject.vesselStates.map((v: any) => new VesselState(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vesselStates = this.vesselStates.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vesselStates\", rule: (v: any) => !!v || \"vesselStates is required\"},\n {field: \"vesselStates\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as VesselState[]).reduce((acc: Array, curr: VesselState) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveVesselStateRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vesselState: VesselState = new VesselState();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vesselState = new VesselState(jsonSerializedObject.vesselState);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vesselState = this.vesselState.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"vesselState\", rule: (v: any) => !!v || \"vesselState is required\"},\n {field: \"vesselState\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetVesselStateIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vesselStateId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vesselStateId = Guid.fromString(jsonSerializedObject.vesselStateId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vesselStateId = this.vesselStateId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"vesselStateId\", rule: (v: any) => !v.isEmpty() || \".VesselStateId cannot be empty\"},\n ];\n}\n\n\nexport class VesselStateService extends ServiceBase {\n\n public async getVesselStates(tenantId: Guid, vesselStateIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetVesselStatesRequest();\n req.tenantId = tenantId;\n req.vesselStateIds = vesselStateIds;\n const extractor = (response:any) => new GetVesselStatesResponse(response).vesselStates;\n return this.makeJsonRequest(\"vesselState/v1/getVesselStates\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllVesselStates(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllVesselStatesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllVesselStatesResponse(response).vesselStates;\n return this.makeJsonRequest(\"vesselState/v1/getAllVesselStates\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveVesselState(tenantId: Guid, vesselState: VesselState, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveVesselStateRequest();\n req.tenantId = tenantId;\n req.vesselState = vesselState;\n const extractor = null;\n return this.makeJsonRequest(\"vesselState/v1/saveVesselState\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setVesselStateIsHidden(tenantId: Guid, vesselStateId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetVesselStateIsHiddenRequest();\n req.tenantId = tenantId;\n req.vesselStateId = vesselStateId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"vesselState/v1/setVesselStateIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const vesselStateService = new VesselStateService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { VesselState } from \"@/app/services/generated/vesselstateService\";\nimport { vesselStateService } from \"@/app/services/generated/vesselstateService\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\n\n// Singleton cache store\nconst vesselStatesCacheStore = new EntityCacheStore(\n EnumCacheEntityType.vesselState,\n async () => vesselStateService.getAllVesselStates(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class VesselStatesCache extends EntityWithGuidKeyCache {\n constructor() {\n super(vesselStatesCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class CollectionTime extends ModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n /**\n * True if this is the default collection time. Simply a marker for the FE to use. Will be automatically set false if another CollectionTime is saved with IsDefault true, thus ensuring there will always be 0 or 1 but no more CollectionTimes with IsDefault set true.\n */\n public isDefault: boolean = false;\n /**\n * Sequence, for ordering CollectionTimes.\n */\n public sequence: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.name = jsonSerializedObject.name;\n this.isDefault = jsonSerializedObject.isDefault;\n this.sequence = jsonSerializedObject.sequence;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.name = this.name;\n toRet.isDefault = this.isDefault;\n toRet.sequence = this.sequence;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"CollectionTime.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"sequence\", rule: (v: any) => v == null || v >= -2147483648 || \"Sequence is not greater than minimum allowed value: -2147483648\"},\n {field: \"sequence\", rule: (v: any) => v == null || v <= 2147483647 || \"Sequence is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class GetAllCollectionTimesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllCollectionTimesResponse extends ModelObject {\n\n public collectionTimes: CollectionTime[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.collectionTimes = jsonSerializedObject.collectionTimes.map((v: any) => new CollectionTime(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.collectionTimes = this.collectionTimes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"collectionTimes\", rule: (v: any) => !!v || \"collectionTimes is required\"},\n {field: \"collectionTimes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as CollectionTime[]).reduce((acc: Array, curr: CollectionTime) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetCollectionTimeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public collectionTimeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.collectionTimeId = Guid.fromString(jsonSerializedObject.collectionTimeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.collectionTimeId = this.collectionTimeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"collectionTimeId\", rule: (v: any) => !v.isEmpty() || \".CollectionTimeId cannot be empty\"},\n ];\n}\n\n\nexport class GetCollectionTimeResponse extends ModelObject {\n\n public collectionTime: CollectionTime = new CollectionTime();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.collectionTime = new CollectionTime(jsonSerializedObject.collectionTime);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.collectionTime = this.collectionTime.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"collectionTime\", rule: (v: any) => !!v || \"collectionTime is required\"},\n {field: \"collectionTime\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetCollectionTimesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public collectionTimeIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.collectionTimeIds = jsonSerializedObject.collectionTimeIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.collectionTimeIds = this.collectionTimeIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetCollectionTimesResponse extends ModelObject {\n\n public collectionTimes: CollectionTime[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.collectionTimes = jsonSerializedObject.collectionTimes.map((v: any) => new CollectionTime(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.collectionTimes = this.collectionTimes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"collectionTimes\", rule: (v: any) => !!v || \"collectionTimes is required\"},\n {field: \"collectionTimes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as CollectionTime[]).reduce((acc: Array, curr: CollectionTime) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveCollectionTimesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public collectionTimes: readonly CollectionTime[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.collectionTimes = jsonSerializedObject.collectionTimes.map((v: any) => new CollectionTime(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.collectionTimes = this.collectionTimes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"collectionTimes\", rule: (v: any) => !!v || \"collectionTimes is required\"},\n {field: \"collectionTimes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as CollectionTime[]).reduce((acc: Array, curr: CollectionTime) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class CollectionTimeService extends ServiceBase {\n\n public async getAllCollectionTimes(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllCollectionTimesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllCollectionTimesResponse(response).collectionTimes;\n return this.makeJsonRequest(\"collectionTime/v1/getAllCollectionTimes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getCollectionTime(tenantId: Guid, collectionTimeId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetCollectionTimeRequest();\n req.tenantId = tenantId;\n req.collectionTimeId = collectionTimeId;\n const extractor = (response:any) => new GetCollectionTimeResponse(response).collectionTime;\n return this.makeJsonRequest(\"collectionTime/v1/getCollectionTime\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getCollectionTimes(tenantId: Guid, collectionTimeIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetCollectionTimesRequest();\n req.tenantId = tenantId;\n req.collectionTimeIds = collectionTimeIds;\n const extractor = (response:any) => new GetCollectionTimesResponse(response).collectionTimes;\n return this.makeJsonRequest(\"collectionTime/v1/getCollectionTimes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveCollectionTimes(tenantId: Guid, collectionTimes: readonly CollectionTime[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveCollectionTimesRequest();\n req.tenantId = tenantId;\n req.collectionTimes = collectionTimes;\n const extractor = null;\n return this.makeJsonRequest(\"collectionTime/v1/saveCollectionTimes\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const collectionTimeService = new CollectionTimeService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\nimport type { CollectionTime } from \"@/app/services/generated/collectiontimeService\";\nimport { collectionTimeService } from \"@/app/services/generated/collectiontimeService\";\n\nexport interface IHasCollectionTimesCache {\n collectionTimes: CollectionTimesCache;\n}\n\n// Singleton cache store\nconst collectionTimesCacheStore = new EntityCacheStore(\n EnumCacheEntityType.collectionTime,\n async () => collectionTimeService.getAllCollectionTimes(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class CollectionTimesCache extends EntityWithGuidKeyCache {\n constructor() {\n super(collectionTimesCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class GlCode extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * General Ledger Code\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public code: string = \"\";\n /**\n * General Ledger Code Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n public isHidden: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.code = jsonSerializedObject.code;\n this.name = jsonSerializedObject.name;\n this.isHidden = jsonSerializedObject.isHidden;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.code = this.code;\n toRet.name = this.name;\n toRet.isHidden = this.isHidden;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"GlCode.Id cannot be empty\"},\n {field: \"code\", rule: (v: any) => v == null || v.length !== 0 || \"Code cannot be empty\"},\n {field: \"code\", rule: (v: any) => v == null || v.length <= 1000 || \"Code has too many characters (1000)\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n ];\n}\n\n\nexport class GlCodeOverride extends ModelObject {\n\n /**\n * Stock Item Id\n */\n public stockItemId: Guid = Guid.createEmpty();\n /**\n * Outlet Type ID\n */\n public outletTypeId: Guid = Guid.createEmpty();\n private _glCodeId: Guid | null = null;\n /**\n * GL Code ID\n */\n public get glCodeId(): Guid | null { return this._glCodeId }\n public set glCodeId(value: Guid | null) {\n this._glCodeId = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.outletTypeId = Guid.fromString(jsonSerializedObject.outletTypeId);\n this.glCodeId = jsonSerializedObject.glCodeId == null ? null : Guid.fromString(jsonSerializedObject.glCodeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.outletTypeId = this.outletTypeId.toString();\n toRet.glCodeId = this.glCodeId == null ? null : this.glCodeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"GlCodeOverride.StockItemId cannot be empty\"},\n {field: \"outletTypeId\", rule: (v: any) => !v.isEmpty() || \"GlCodeOverride.OutletTypeId cannot be empty\"},\n {field: \"glCodeId\", rule: (v: any) => v == null || !v.isEmpty() || \"GlCodeOverride.GlCodeId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllGlCodesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllGlCodesResponse extends ModelObject {\n\n public glCodes: GlCode[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.glCodes = jsonSerializedObject.glCodes.map((v: any) => new GlCode(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.glCodes = this.glCodes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"glCodes\", rule: (v: any) => !!v || \"glCodes is required\"},\n {field: \"glCodes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as GlCode[]).reduce((acc: Array, curr: GlCode) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetGlCodeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public glCodeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.glCodeId = Guid.fromString(jsonSerializedObject.glCodeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.glCodeId = this.glCodeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"glCodeId\", rule: (v: any) => !v.isEmpty() || \".GlCodeId cannot be empty\"},\n ];\n}\n\n\nexport class GetGlCodeResponse extends ModelObject {\n\n public glCode: GlCode = new GlCode();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.glCode = new GlCode(jsonSerializedObject.glCode);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.glCode = this.glCode.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"glCode\", rule: (v: any) => !!v || \"glCode is required\"},\n {field: \"glCode\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetGlCodesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public glCodeIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.glCodeIds = jsonSerializedObject.glCodeIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.glCodeIds = this.glCodeIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetGlCodesResponse extends ModelObject {\n\n public glCodes: GlCode[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.glCodes = jsonSerializedObject.glCodes.map((v: any) => new GlCode(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.glCodes = this.glCodes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"glCodes\", rule: (v: any) => !!v || \"glCodes is required\"},\n {field: \"glCodes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as GlCode[]).reduce((acc: Array, curr: GlCode) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveGlCodeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public glCode: GlCode = new GlCode();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.glCode = new GlCode(jsonSerializedObject.glCode);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.glCode = this.glCode.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"glCode\", rule: (v: any) => !!v || \"glCode is required\"},\n {field: \"glCode\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetGlCodeIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public glCodeId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.glCodeId = Guid.fromString(jsonSerializedObject.glCodeId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.glCodeId = this.glCodeId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"glCodeId\", rule: (v: any) => !v.isEmpty() || \".GlCodeId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllGlCodeOverridesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllGlCodeOverridesResponse extends ModelObject {\n\n public glCodeOverrides: GlCodeOverride[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.glCodeOverrides = jsonSerializedObject.glCodeOverrides.map((v: any) => new GlCodeOverride(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.glCodeOverrides = this.glCodeOverrides.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"glCodeOverrides\", rule: (v: any) => !!v || \"glCodeOverrides is required\"},\n {field: \"glCodeOverrides\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as GlCodeOverride[]).reduce((acc: Array, curr: GlCodeOverride) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetGlCodeOverridesForOutletTypeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public outletTypeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.outletTypeId = Guid.fromString(jsonSerializedObject.outletTypeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.outletTypeId = this.outletTypeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"outletTypeId\", rule: (v: any) => !v.isEmpty() || \".OutletTypeId cannot be empty\"},\n ];\n}\n\n\nexport class GetGlCodeOverridesForOutletTypeResponse extends ModelObject {\n\n public glCodeOverrides: GlCodeOverride[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.glCodeOverrides = jsonSerializedObject.glCodeOverrides.map((v: any) => new GlCodeOverride(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.glCodeOverrides = this.glCodeOverrides.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"glCodeOverrides\", rule: (v: any) => !!v || \"glCodeOverrides is required\"},\n {field: \"glCodeOverrides\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as GlCodeOverride[]).reduce((acc: Array, curr: GlCodeOverride) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetGlCodeOverridesForGlCodeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public glCodeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.glCodeId = Guid.fromString(jsonSerializedObject.glCodeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.glCodeId = this.glCodeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"glCodeId\", rule: (v: any) => !v.isEmpty() || \".GlCodeId cannot be empty\"},\n ];\n}\n\n\nexport class GetGlCodeOverridesForGlCodeResponse extends ModelObject {\n\n public glCodeOverrides: GlCodeOverride[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.glCodeOverrides = jsonSerializedObject.glCodeOverrides.map((v: any) => new GlCodeOverride(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.glCodeOverrides = this.glCodeOverrides.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"glCodeOverrides\", rule: (v: any) => !!v || \"glCodeOverrides is required\"},\n {field: \"glCodeOverrides\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as GlCodeOverride[]).reduce((acc: Array, curr: GlCodeOverride) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetGlCodeOverrideForStockItemAndOutletTypeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockItemId: Guid = Guid.createEmpty();\n public outletTypeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.outletTypeId = Guid.fromString(jsonSerializedObject.outletTypeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockItemId = this.stockItemId.toString();\n toRet.outletTypeId = this.outletTypeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \".StockItemId cannot be empty\"},\n {field: \"outletTypeId\", rule: (v: any) => !v.isEmpty() || \".OutletTypeId cannot be empty\"},\n ];\n}\n\n\nexport class GetGlCodeOverrideForStockItemAndOutletTypeResponse extends ModelObject {\n\n private _glCodeOverride: GlCodeOverride | null = null;\n public get glCodeOverride(): GlCodeOverride | null { return this._glCodeOverride }\n public set glCodeOverride(value: GlCodeOverride | null) {\n this._glCodeOverride = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.glCodeOverride = jsonSerializedObject.glCodeOverride == null ? null : new GlCodeOverride(jsonSerializedObject.glCodeOverride);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.glCodeOverride = this.glCodeOverride == null ? null : this.glCodeOverride?.toJsonSerializedObject() ?? null;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"glCodeOverride\", rule: (v: any) => (v === null) || v.validate()},\n ];\n}\n\n\nexport class SaveSingleGlCodeOverrideRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n private _expectedStockItemVersion: number | null = null;\n public get expectedStockItemVersion(): number | null { return this._expectedStockItemVersion }\n public set expectedStockItemVersion(value: number | null) {\n this._expectedStockItemVersion = value === undefined ? null : value;\n }\n public glCodeOverride: GlCodeOverride = new GlCodeOverride();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.expectedStockItemVersion = jsonSerializedObject.expectedStockItemVersion == null ? null : jsonSerializedObject.expectedStockItemVersion;\n this.glCodeOverride = new GlCodeOverride(jsonSerializedObject.glCodeOverride);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.expectedStockItemVersion = this.expectedStockItemVersion == null ? null : this.expectedStockItemVersion;\n toRet.glCodeOverride = this.glCodeOverride.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"expectedStockItemVersion\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"ExpectedStockItemVersion is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"expectedStockItemVersion\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"ExpectedStockItemVersion is above maximum allowed value: 9223372036854775807\"},\n {field: \"glCodeOverride\", rule: (v: any) => !!v || \"glCodeOverride is required\"},\n {field: \"glCodeOverride\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GlCodeService extends ServiceBase {\n\n public async getAllGlCodes(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllGlCodesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllGlCodesResponse(response).glCodes;\n return this.makeJsonRequest(\"glCode/v1/getAllGlCodes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getGlCode(tenantId: Guid, glCodeId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetGlCodeRequest();\n req.tenantId = tenantId;\n req.glCodeId = glCodeId;\n const extractor = (response:any) => new GetGlCodeResponse(response).glCode;\n return this.makeJsonRequest(\"glCode/v1/getGlCode\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getGlCodes(tenantId: Guid, glCodeIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetGlCodesRequest();\n req.tenantId = tenantId;\n req.glCodeIds = glCodeIds;\n const extractor = (response:any) => new GetGlCodesResponse(response).glCodes;\n return this.makeJsonRequest(\"glCode/v1/getGlCodes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveGlCode(tenantId: Guid, glCode: GlCode, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveGlCodeRequest();\n req.tenantId = tenantId;\n req.glCode = glCode;\n const extractor = null;\n return this.makeJsonRequest(\"glCode/v1/saveGlCode\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setGlCodeIsHidden(tenantId: Guid, glCodeId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetGlCodeIsHiddenRequest();\n req.tenantId = tenantId;\n req.glCodeId = glCodeId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"glCode/v1/setGlCodeIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllGlCodeOverrides(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllGlCodeOverridesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllGlCodeOverridesResponse(response).glCodeOverrides;\n return this.makeJsonRequest(\"glCode/v1/getAllGlCodeOverrides\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getGlCodeOverridesForOutletType(tenantId: Guid, outletTypeId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetGlCodeOverridesForOutletTypeRequest();\n req.tenantId = tenantId;\n req.outletTypeId = outletTypeId;\n const extractor = (response:any) => new GetGlCodeOverridesForOutletTypeResponse(response).glCodeOverrides;\n return this.makeJsonRequest(\"glCode/v1/getGlCodeOverridesForOutletType\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getGlCodeOverridesForGlCode(tenantId: Guid, glCodeId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetGlCodeOverridesForGlCodeRequest();\n req.tenantId = tenantId;\n req.glCodeId = glCodeId;\n const extractor = (response:any) => new GetGlCodeOverridesForGlCodeResponse(response).glCodeOverrides;\n return this.makeJsonRequest(\"glCode/v1/getGlCodeOverridesForGlCode\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getGlCodeOverrideForStockItemAndOutletType(tenantId: Guid, stockItemId: Guid, outletTypeId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetGlCodeOverrideForStockItemAndOutletTypeRequest();\n req.tenantId = tenantId;\n req.stockItemId = stockItemId;\n req.outletTypeId = outletTypeId;\n const extractor = (response:any) => new GetGlCodeOverrideForStockItemAndOutletTypeResponse(response).glCodeOverride;\n return this.makeJsonRequest(\"glCode/v1/getGlCodeOverrideForStockItemAndOutletType\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveSingleGlCodeOverride(tenantId: Guid, expectedStockItemVersion: number | null, glCodeOverride: GlCodeOverride, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveSingleGlCodeOverrideRequest();\n req.tenantId = tenantId;\n req.expectedStockItemVersion = expectedStockItemVersion;\n req.glCodeOverride = glCodeOverride;\n const extractor = null;\n return this.makeJsonRequest(\"glCode/v1/saveSingleGlCodeOverride\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const glCodeService = new GlCodeService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { GlCode } from \"@/app/services/generated/glcodeService\";\nimport { glCodeService } from \"@/app/services/generated/glcodeService\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\n\nexport interface IHasGlCodesCache {\n glCodes: GlCodesCache;\n}\n\n// Singleton cache store\nconst glCodesCacheStore = new EntityCacheStore(\n EnumCacheEntityType.glCode,\n async () => glCodeService.getAllGlCodes(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class GlCodesCache extends EntityWithGuidKeyCache {\n constructor() {\n super(glCodesCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class StockGroup extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n /**\n * Restricted Stock - Raises warning on attempt to over-sell.\n */\n public restrictedStock: boolean = false;\n public isHidden: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.name = jsonSerializedObject.name;\n this.restrictedStock = jsonSerializedObject.restrictedStock;\n this.isHidden = jsonSerializedObject.isHidden;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.name = this.name;\n toRet.restrictedStock = this.restrictedStock;\n toRet.isHidden = this.isHidden;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"StockGroup.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n ];\n}\n\n\nexport class GetAllStockGroupsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllStockGroupsResponse extends ModelObject {\n\n public stockGroups: StockGroup[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockGroups = jsonSerializedObject.stockGroups.map((v: any) => new StockGroup(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockGroups = this.stockGroups.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockGroups\", rule: (v: any) => !!v || \"stockGroups is required\"},\n {field: \"stockGroups\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockGroup[]).reduce((acc: Array, curr: StockGroup) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetStockGroupRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockGroupId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockGroupId = Guid.fromString(jsonSerializedObject.stockGroupId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockGroupId = this.stockGroupId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockGroupId\", rule: (v: any) => !v.isEmpty() || \".StockGroupId cannot be empty\"},\n ];\n}\n\n\nexport class GetStockGroupResponse extends ModelObject {\n\n public stockGroup: StockGroup = new StockGroup();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockGroup = new StockGroup(jsonSerializedObject.stockGroup);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockGroup = this.stockGroup.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockGroup\", rule: (v: any) => !!v || \"stockGroup is required\"},\n {field: \"stockGroup\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetStockGroupsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockGroupIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockGroupIds = jsonSerializedObject.stockGroupIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockGroupIds = this.stockGroupIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetStockGroupsResponse extends ModelObject {\n\n public stockGroups: StockGroup[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockGroups = jsonSerializedObject.stockGroups.map((v: any) => new StockGroup(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockGroups = this.stockGroups.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockGroups\", rule: (v: any) => !!v || \"stockGroups is required\"},\n {field: \"stockGroups\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as StockGroup[]).reduce((acc: Array, curr: StockGroup) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveStockGroupRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockGroup: StockGroup = new StockGroup();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockGroup = new StockGroup(jsonSerializedObject.stockGroup);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockGroup = this.stockGroup.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockGroup\", rule: (v: any) => !!v || \"stockGroup is required\"},\n {field: \"stockGroup\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetStockGroupIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public stockGroupId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.stockGroupId = Guid.fromString(jsonSerializedObject.stockGroupId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.stockGroupId = this.stockGroupId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"stockGroupId\", rule: (v: any) => !v.isEmpty() || \".StockGroupId cannot be empty\"},\n ];\n}\n\n\nexport class StockGroupService extends ServiceBase {\n\n public async getAllStockGroups(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllStockGroupsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllStockGroupsResponse(response).stockGroups;\n return this.makeJsonRequest(\"stockGroup/v1/getAllStockGroups\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getStockGroup(tenantId: Guid, stockGroupId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetStockGroupRequest();\n req.tenantId = tenantId;\n req.stockGroupId = stockGroupId;\n const extractor = (response:any) => new GetStockGroupResponse(response).stockGroup;\n return this.makeJsonRequest(\"stockGroup/v1/getStockGroup\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getStockGroups(tenantId: Guid, stockGroupIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetStockGroupsRequest();\n req.tenantId = tenantId;\n req.stockGroupIds = stockGroupIds;\n const extractor = (response:any) => new GetStockGroupsResponse(response).stockGroups;\n return this.makeJsonRequest(\"stockGroup/v1/getStockGroups\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveStockGroup(tenantId: Guid, stockGroup: StockGroup, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveStockGroupRequest();\n req.tenantId = tenantId;\n req.stockGroup = stockGroup;\n const extractor = null;\n return this.makeJsonRequest(\"stockGroup/v1/saveStockGroup\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setStockGroupIsHidden(tenantId: Guid, stockGroupId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetStockGroupIsHiddenRequest();\n req.tenantId = tenantId;\n req.stockGroupId = stockGroupId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"stockGroup/v1/setStockGroupIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const stockGroupService = new StockGroupService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { StockGroup } from \"@/app/services/generated/stockgroupService\";\nimport { stockGroupService } from \"@/app/services/generated/stockgroupService\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\n\nexport interface IHasStockGroupsCache {\n stockGroups: StockGroupsCache;\n}\n\n// Singleton cache store\nconst stockGroupsCacheStore = new EntityCacheStore(\n EnumCacheEntityType.stockGroup,\n async () => stockGroupService.getAllStockGroups(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class StockGroupsCache extends EntityWithGuidKeyCache {\n constructor() {\n super(stockGroupsCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class PricingCategory extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Pricing Category\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n public isHidden: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.name = jsonSerializedObject.name;\n this.isHidden = jsonSerializedObject.isHidden;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.name = this.name;\n toRet.isHidden = this.isHidden;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"PricingCategory.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n ];\n}\n\n\nexport class GetAllPricingCategoriesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllPricingCategoriesResponse extends ModelObject {\n\n public pricingCategories: PricingCategory[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.pricingCategories = jsonSerializedObject.pricingCategories.map((v: any) => new PricingCategory(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.pricingCategories = this.pricingCategories.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"pricingCategories\", rule: (v: any) => !!v || \"pricingCategories is required\"},\n {field: \"pricingCategories\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PricingCategory[]).reduce((acc: Array, curr: PricingCategory) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetPricingCategoryRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public pricingCategoryId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.pricingCategoryId = Guid.fromString(jsonSerializedObject.pricingCategoryId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.pricingCategoryId = this.pricingCategoryId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"pricingCategoryId\", rule: (v: any) => !v.isEmpty() || \".PricingCategoryId cannot be empty\"},\n ];\n}\n\n\nexport class GetPricingCategoryResponse extends ModelObject {\n\n public pricingCategory: PricingCategory = new PricingCategory();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.pricingCategory = new PricingCategory(jsonSerializedObject.pricingCategory);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.pricingCategory = this.pricingCategory.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"pricingCategory\", rule: (v: any) => !!v || \"pricingCategory is required\"},\n {field: \"pricingCategory\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SavePricingCategoryRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public pricingCategory: PricingCategory = new PricingCategory();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.pricingCategory = new PricingCategory(jsonSerializedObject.pricingCategory);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.pricingCategory = this.pricingCategory.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"pricingCategory\", rule: (v: any) => !!v || \"pricingCategory is required\"},\n {field: \"pricingCategory\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetPricingCategoryIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public pricingCategoryId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.pricingCategoryId = Guid.fromString(jsonSerializedObject.pricingCategoryId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.pricingCategoryId = this.pricingCategoryId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"pricingCategoryId\", rule: (v: any) => !v.isEmpty() || \".PricingCategoryId cannot be empty\"},\n ];\n}\n\n\nexport class GetPricingCategoriesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public pricingCategoryIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.pricingCategoryIds = jsonSerializedObject.pricingCategoryIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.pricingCategoryIds = this.pricingCategoryIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetPricingCategoriesResponse extends ModelObject {\n\n public pricingCategory: PricingCategory[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.pricingCategory = jsonSerializedObject.pricingCategory.map((v: any) => new PricingCategory(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.pricingCategory = this.pricingCategory.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"pricingCategory\", rule: (v: any) => !!v || \"pricingCategory is required\"},\n {field: \"pricingCategory\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as PricingCategory[]).reduce((acc: Array, curr: PricingCategory) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class PricingCategoryService extends ServiceBase {\n\n public async getAllPricingCategories(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllPricingCategoriesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllPricingCategoriesResponse(response).pricingCategories;\n return this.makeJsonRequest(\"pricingCategory/v1/getAllPricingCategories\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getPricingCategory(tenantId: Guid, pricingCategoryId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPricingCategoryRequest();\n req.tenantId = tenantId;\n req.pricingCategoryId = pricingCategoryId;\n const extractor = (response:any) => new GetPricingCategoryResponse(response).pricingCategory;\n return this.makeJsonRequest(\"pricingCategory/v1/getPricingCategory\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async savePricingCategory(tenantId: Guid, pricingCategory: PricingCategory, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SavePricingCategoryRequest();\n req.tenantId = tenantId;\n req.pricingCategory = pricingCategory;\n const extractor = null;\n return this.makeJsonRequest(\"pricingCategory/v1/savePricingCategory\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setPricingCategoryIsHidden(tenantId: Guid, pricingCategoryId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetPricingCategoryIsHiddenRequest();\n req.tenantId = tenantId;\n req.pricingCategoryId = pricingCategoryId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"pricingCategory/v1/setPricingCategoryIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getPricingCategories(tenantId: Guid, pricingCategoryIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetPricingCategoriesRequest();\n req.tenantId = tenantId;\n req.pricingCategoryIds = pricingCategoryIds;\n const extractor = (response:any) => new GetPricingCategoriesResponse(response).pricingCategory;\n return this.makeJsonRequest(\"pricingCategory/v1/getPricingCategories\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const pricingCategoryService = new PricingCategoryService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { PricingCategory } from \"@/app/services/generated/pricingcategoryService\";\nimport { pricingCategoryService } from \"@/app/services/generated/pricingcategoryService\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\n\n// Singleton cache store\nconst pricingCategoriesCacheStore = new EntityCacheStore(\n EnumCacheEntityType.pricingCategory,\n async () => pricingCategoryService.getAllPricingCategories(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class PricingCategoriesCache extends EntityWithGuidKeyCache {\n constructor() {\n super(pricingCategoriesCacheStore, (x) => x.id);\n }\n}\n","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\nimport type { SupplierManufacturer } from \"@/app/services/generated/suppliermanufacturerService\";\nimport { supplierManufacturerService } from \"@/app/services/extensions/suppliermanufacturerServiceExtended\";\n\nexport interface IHasSupplierManufacturersCache {\n supplierManufacturers: SupplierManufacturersCache;\n}\n\n// Singleton cache store\nconst supplierManufacturersCacheStore =\n new EntityCacheStore(\n EnumCacheEntityType.supplierManufacturer,\n async () =>\n supplierManufacturerService.getAllSupplierManufacturers(api.tenantId)\n );\n\n// Ephemeral reader\nexport default class SupplierManufacturersCache extends EntityWithGuidKeyCache {\n constructor() {\n super(supplierManufacturersCacheStore, (x) => x.id);\n }\n\n get onlySuppliers() {\n return this.allReactive.value.filter(\n (supplierManufacturer) => supplierManufacturer.isSupplier\n );\n }\n\n get onlyManufacturer() {\n return this.allReactive.value.filter(\n (supplierManufacturer) => supplierManufacturer.isManufacturer\n );\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class ProductBrand extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Product Brand Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n private _imageId: Guid | null = null;\n /**\n * Alternative Logo for Label Printing\n */\n public get imageId(): Guid | null { return this._imageId }\n public set imageId(value: Guid | null) {\n this._imageId = value === undefined ? null : value;\n }\n /**\n * Are sales currently allowed for products in this brand? (Use to prevent selling of Eg out-of-season products).\n */\n public allowSales: boolean = false;\n /**\n * Product Brand Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n /**\n * Tasting Notes\n * Not Nullable\n * Max Length : 100000\n */\n public tastingNotes: string = \"\";\n /**\n * Ingredients and Allergens\n * Not Nullable\n * Max Length : 100000\n */\n public ingredientsAndAllergens: string = \"\";\n public isHidden: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.name = jsonSerializedObject.name;\n this.imageId = jsonSerializedObject.imageId == null ? null : Guid.fromString(jsonSerializedObject.imageId);\n this.allowSales = jsonSerializedObject.allowSales;\n this.notes = jsonSerializedObject.notes;\n this.tastingNotes = jsonSerializedObject.tastingNotes;\n this.ingredientsAndAllergens = jsonSerializedObject.ingredientsAndAllergens;\n this.isHidden = jsonSerializedObject.isHidden;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.name = this.name;\n toRet.imageId = this.imageId == null ? null : this.imageId.toString();\n toRet.allowSales = this.allowSales;\n toRet.notes = this.notes;\n toRet.tastingNotes = this.tastingNotes;\n toRet.ingredientsAndAllergens = this.ingredientsAndAllergens;\n toRet.isHidden = this.isHidden;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"ProductBrand.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"imageId\", rule: (v: any) => v == null || !v.isEmpty() || \"ProductBrand.ImageId cannot be empty\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"tastingNotes\", rule: (v: any) => v == null || v.length <= 100000 || \"TastingNotes has too many characters (100000)\"},\n {field: \"ingredientsAndAllergens\", rule: (v: any) => v == null || v.length <= 100000 || \"IngredientsAndAllergens has too many characters (100000)\"},\n ];\n}\n\n\nexport class GetAllProductBrandsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllProductBrandsResponse extends ModelObject {\n\n public productBrands: ProductBrand[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.productBrands = jsonSerializedObject.productBrands.map((v: any) => new ProductBrand(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.productBrands = this.productBrands.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"productBrands\", rule: (v: any) => !!v || \"productBrands is required\"},\n {field: \"productBrands\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProductBrand[]).reduce((acc: Array, curr: ProductBrand) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetProductBrandRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public productBrandId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.productBrandId = Guid.fromString(jsonSerializedObject.productBrandId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.productBrandId = this.productBrandId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"productBrandId\", rule: (v: any) => !v.isEmpty() || \".ProductBrandId cannot be empty\"},\n ];\n}\n\n\nexport class GetProductBrandResponse extends ModelObject {\n\n public productBrand: ProductBrand = new ProductBrand();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.productBrand = new ProductBrand(jsonSerializedObject.productBrand);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.productBrand = this.productBrand.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"productBrand\", rule: (v: any) => !!v || \"productBrand is required\"},\n {field: \"productBrand\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetProductBrandsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public productBrandIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.productBrandIds = jsonSerializedObject.productBrandIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.productBrandIds = this.productBrandIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetProductBrandsResponse extends ModelObject {\n\n public productBrands: ProductBrand[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.productBrands = jsonSerializedObject.productBrands.map((v: any) => new ProductBrand(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.productBrands = this.productBrands.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"productBrands\", rule: (v: any) => !!v || \"productBrands is required\"},\n {field: \"productBrands\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ProductBrand[]).reduce((acc: Array, curr: ProductBrand) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveProductBrandRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public productBrand: ProductBrand = new ProductBrand();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.productBrand = new ProductBrand(jsonSerializedObject.productBrand);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.productBrand = this.productBrand.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"productBrand\", rule: (v: any) => !!v || \"productBrand is required\"},\n {field: \"productBrand\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetProductBrandIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public productBrandId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.productBrandId = Guid.fromString(jsonSerializedObject.productBrandId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.productBrandId = this.productBrandId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"productBrandId\", rule: (v: any) => !v.isEmpty() || \".ProductBrandId cannot be empty\"},\n ];\n}\n\n\nexport class ProductBrandService extends ServiceBase {\n\n public async getAllProductBrands(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllProductBrandsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllProductBrandsResponse(response).productBrands;\n return this.makeJsonRequest(\"productBrand/v1/getAllProductBrands\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getProductBrand(tenantId: Guid, productBrandId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetProductBrandRequest();\n req.tenantId = tenantId;\n req.productBrandId = productBrandId;\n const extractor = (response:any) => new GetProductBrandResponse(response).productBrand;\n return this.makeJsonRequest(\"productBrand/v1/getProductBrand\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getProductBrands(tenantId: Guid, productBrandIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetProductBrandsRequest();\n req.tenantId = tenantId;\n req.productBrandIds = productBrandIds;\n const extractor = (response:any) => new GetProductBrandsResponse(response).productBrands;\n return this.makeJsonRequest(\"productBrand/v1/getProductBrands\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveProductBrand(tenantId: Guid, productBrand: ProductBrand, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveProductBrandRequest();\n req.tenantId = tenantId;\n req.productBrand = productBrand;\n const extractor = null;\n return this.makeJsonRequest(\"productBrand/v1/saveProductBrand\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setProductBrandIsHidden(tenantId: Guid, productBrandId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetProductBrandIsHiddenRequest();\n req.tenantId = tenantId;\n req.productBrandId = productBrandId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"productBrand/v1/setProductBrandIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const productBrandService = new ProductBrandService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { ProductBrand } from \"@/app/services/generated/productbrandService\";\nimport { productBrandService } from \"@/app/services/generated/productbrandService\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\n\nexport interface IHasProductBrandsCache {\n productBrands: ProductBrandsCache;\n}\n\n// Singleton cache store\nconst productBrandsCacheStore = new EntityCacheStore(\n EnumCacheEntityType.productBrand,\n async () => productBrandService.getAllProductBrands(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class ProductBrandsCache extends EntityWithGuidKeyCache {\n constructor() {\n super(productBrandsCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumAssemblyType } from \"./enums/enumAssemblyType.generated\";\n\n// Model Objects\n\nexport class RecipeOutputItem extends ModelObject {\n\n public stockItemId: Guid = Guid.createEmpty();\n public unitOfMeasureId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"RecipeOutputItem.StockItemId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"RecipeOutputItem.UnitOfMeasureId cannot be empty\"},\n ];\n}\n\n\nexport class RecipeHeader extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n public isHidden: boolean = false;\n private _bestBeforeDaysFromStart: number | null = null;\n /**\n * Best Before Days From Start\n */\n public get bestBeforeDaysFromStart(): number | null { return this._bestBeforeDaysFromStart }\n public set bestBeforeDaysFromStart(value: number | null) {\n this._bestBeforeDaysFromStart = value === undefined ? null : value;\n }\n /**\n * Name.\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n /**\n * Notes.\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n /**\n * Duration in days this process is planned to take by default.\n * Not Negative\n */\n public plannedDurationDays: number = 0;\n /**\n * Assembly type of this process. : 0 = MaterialProduction, 1 = ProductPackaging, 2 = Maintenance\n */\n public processType: EnumAssemblyType = EnumAssemblyType.materialProduction;\n private _outputItem: RecipeOutputItem | null = null;\n public get outputItem(): RecipeOutputItem | null { return this._outputItem }\n public set outputItem(value: RecipeOutputItem | null) {\n this._outputItem = value === undefined ? null : value;\n }\n private _outputQuantity: number | null = null;\n /**\n * Quantity of output item which is produced by Recipe (null if no output defined). Note that it is now possible for a recipe to know its output quantity even if it does not know the output item (and that in this case the output quantity unit of measure is not known until an actual item is chosen).\n * Not Negative\n */\n public get outputQuantity(): number | null { return this._outputQuantity }\n public set outputQuantity(value: number | null) {\n this._outputQuantity = value === undefined ? null : value;\n }\n /**\n * If true, this recipe scales by duplication, Ie multiple processes are created. If false, this recipe scales by size, Ie a single larger process is created.\n */\n public scalesByDuplication: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.isHidden = jsonSerializedObject.isHidden;\n this.bestBeforeDaysFromStart = jsonSerializedObject.bestBeforeDaysFromStart == null ? null : jsonSerializedObject.bestBeforeDaysFromStart;\n this.name = jsonSerializedObject.name;\n this.notes = jsonSerializedObject.notes;\n this.plannedDurationDays = jsonSerializedObject.plannedDurationDays;\n this.processType = EnumAssemblyType.getByValue(jsonSerializedObject.processType, this.processType);\n this.outputItem = jsonSerializedObject.outputItem == null ? null : new RecipeOutputItem(jsonSerializedObject.outputItem);\n this.outputQuantity = jsonSerializedObject.outputQuantity == null ? null : jsonSerializedObject.outputQuantity;\n this.scalesByDuplication = jsonSerializedObject.scalesByDuplication;\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.isHidden = this.isHidden;\n toRet.bestBeforeDaysFromStart = this.bestBeforeDaysFromStart == null ? null : this.bestBeforeDaysFromStart;\n toRet.name = this.name;\n toRet.notes = this.notes;\n toRet.plannedDurationDays = this.plannedDurationDays;\n toRet.processType = this.processType.value;\n toRet.outputItem = this.outputItem == null ? null : this.outputItem?.toJsonSerializedObject() ?? null;\n toRet.outputQuantity = this.outputQuantity == null ? null : this.outputQuantity;\n toRet.scalesByDuplication = this.scalesByDuplication;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"RecipeHeader.Id cannot be empty\"},\n {field: \"bestBeforeDaysFromStart\", rule: (v: any) => v == null || v >= -2147483648 || \"BestBeforeDaysFromStart is not greater than minimum allowed value: -2147483648\"},\n {field: \"bestBeforeDaysFromStart\", rule: (v: any) => v == null || v <= 2147483647 || \"BestBeforeDaysFromStart is above maximum allowed value: 2147483647\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"plannedDurationDays\", rule: (v: any) => v == null || v >= 0 || \"PlannedDurationDays is not greater than minimum allowed value: 0\"},\n {field: \"plannedDurationDays\", rule: (v: any) => v == null || v <= 2147483647 || \"PlannedDurationDays is above maximum allowed value: 2147483647\"},\n {field: \"outputItem\", rule: (v: any) => (v === null) || v.validate()},\n ];\n}\n\n\nexport class RecipeInstruction extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Parent Recipe Id\n */\n public recipeId: Guid = Guid.createEmpty();\n /**\n * Instruction\n * Not Nullable\n * Max Length : 1000\n */\n public instruction: string = \"\";\n /**\n * Sequence\n */\n public sequence: number = 0;\n /**\n * Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.recipeId = Guid.fromString(jsonSerializedObject.recipeId);\n this.instruction = jsonSerializedObject.instruction;\n this.sequence = jsonSerializedObject.sequence;\n this.notes = jsonSerializedObject.notes;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.recipeId = this.recipeId.toString();\n toRet.instruction = this.instruction;\n toRet.sequence = this.sequence;\n toRet.notes = this.notes;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"RecipeInstruction.Id cannot be empty\"},\n {field: \"recipeId\", rule: (v: any) => !v.isEmpty() || \"RecipeInstruction.RecipeId cannot be empty\"},\n {field: \"instruction\", rule: (v: any) => v == null || v.length <= 1000 || \"Instruction has too many characters (1000)\"},\n {field: \"sequence\", rule: (v: any) => v == null || v >= -2147483648 || \"Sequence is not greater than minimum allowed value: -2147483648\"},\n {field: \"sequence\", rule: (v: any) => v == null || v <= 2147483647 || \"Sequence is above maximum allowed value: 2147483647\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n ];\n}\n\n\nexport class RecipeVesselRequirement extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Parent Recipe Id\n */\n public recipeId: Guid = Guid.createEmpty();\n /**\n * Required minimum capacity of Vessel in Litres\n * Not Negative\n */\n public capacityLitres: number = 0;\n /**\n * Required Vessel Capability.\n */\n public vesselCapabilityId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.recipeId = Guid.fromString(jsonSerializedObject.recipeId);\n this.capacityLitres = jsonSerializedObject.capacityLitres;\n this.vesselCapabilityId = Guid.fromString(jsonSerializedObject.vesselCapabilityId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.recipeId = this.recipeId.toString();\n toRet.capacityLitres = this.capacityLitres;\n toRet.vesselCapabilityId = this.vesselCapabilityId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"RecipeVesselRequirement.Id cannot be empty\"},\n {field: \"recipeId\", rule: (v: any) => !v.isEmpty() || \"RecipeVesselRequirement.RecipeId cannot be empty\"},\n {field: \"vesselCapabilityId\", rule: (v: any) => !v.isEmpty() || \"RecipeVesselRequirement.VesselCapabilityId cannot be empty\"},\n ];\n}\n\n\nexport class RecipeIngredient extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Parent Recipe Id\n */\n public recipeId: Guid = Guid.createEmpty();\n /**\n * Whether this ingredient is fixed to its current quantity regardless of adjustments to process output.If set to true, the ingredient required quantity will not be multiplied when adjusting planned process output quantities.\n */\n public fixedQuantity: boolean = false;\n /**\n * Notes.\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n /**\n * Quantity of ingredient required.\n * Greater Than : 0\n */\n public quantity: number = 0;\n /**\n * Sequence (for ordering Lines).\n */\n public sequence: number = 0;\n /**\n * Stock Item Id Being Used.\n */\n public stockItemId: Guid = Guid.createEmpty();\n /**\n * Unit of Measure\n */\n public unitOfMeasureId: Guid = Guid.createEmpty();\n /**\n * Enables hop alpha scaling for this ingredient if the item and stock batch have hop alpha values.\n */\n public allowsHopAlpha: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.recipeId = Guid.fromString(jsonSerializedObject.recipeId);\n this.fixedQuantity = jsonSerializedObject.fixedQuantity;\n this.notes = jsonSerializedObject.notes;\n this.quantity = jsonSerializedObject.quantity;\n this.sequence = jsonSerializedObject.sequence;\n this.stockItemId = Guid.fromString(jsonSerializedObject.stockItemId);\n this.unitOfMeasureId = Guid.fromString(jsonSerializedObject.unitOfMeasureId);\n this.allowsHopAlpha = jsonSerializedObject.allowsHopAlpha;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.recipeId = this.recipeId.toString();\n toRet.fixedQuantity = this.fixedQuantity;\n toRet.notes = this.notes;\n toRet.quantity = this.quantity;\n toRet.sequence = this.sequence;\n toRet.stockItemId = this.stockItemId.toString();\n toRet.unitOfMeasureId = this.unitOfMeasureId.toString();\n toRet.allowsHopAlpha = this.allowsHopAlpha;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"RecipeIngredient.Id cannot be empty\"},\n {field: \"recipeId\", rule: (v: any) => !v.isEmpty() || \"RecipeIngredient.RecipeId cannot be empty\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"quantity\", rule: (v: any) => v == null || v > 0 || \"Quantity is not greater than minimum allowed value: 0\"},\n {field: \"sequence\", rule: (v: any) => v == null || v >= -2147483648 || \"Sequence is not greater than minimum allowed value: -2147483648\"},\n {field: \"sequence\", rule: (v: any) => v == null || v <= 2147483647 || \"Sequence is above maximum allowed value: 2147483647\"},\n {field: \"stockItemId\", rule: (v: any) => !v.isEmpty() || \"RecipeIngredient.StockItemId cannot be empty\"},\n {field: \"unitOfMeasureId\", rule: (v: any) => !v.isEmpty() || \"RecipeIngredient.UnitOfMeasureId cannot be empty\"},\n ];\n}\n\n\nexport class Recipe extends ModelObject {\n\n public header: RecipeHeader = new RecipeHeader();\n public ingredients: RecipeIngredient[] = [];\n public instructions: RecipeInstruction[] = [];\n public vesselRequirements: RecipeVesselRequirement[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.header = new RecipeHeader(jsonSerializedObject.header);\n this.ingredients = jsonSerializedObject.ingredients.map((v: any) => new RecipeIngredient(v));\n this.instructions = jsonSerializedObject.instructions.map((v: any) => new RecipeInstruction(v));\n this.vesselRequirements = jsonSerializedObject.vesselRequirements.map((v: any) => new RecipeVesselRequirement(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.header = this.header.toJsonSerializedObject();\n toRet.ingredients = this.ingredients.map(v => v.toJsonSerializedObject());\n toRet.instructions = this.instructions.map(v => v.toJsonSerializedObject());\n toRet.vesselRequirements = this.vesselRequirements.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n {field: \"ingredients\", rule: (v: any) => !!v || \"ingredients is required\"},\n {field: \"ingredients\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as RecipeIngredient[]).reduce((acc: Array, curr: RecipeIngredient) => acc.concat(curr.validate()), new Array());\n }},\n {field: \"instructions\", rule: (v: any) => !!v || \"instructions is required\"},\n {field: \"instructions\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as RecipeInstruction[]).reduce((acc: Array, curr: RecipeInstruction) => acc.concat(curr.validate()), new Array());\n }},\n {field: \"vesselRequirements\", rule: (v: any) => !!v || \"vesselRequirements is required\"},\n {field: \"vesselRequirements\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as RecipeVesselRequirement[]).reduce((acc: Array, curr: RecipeVesselRequirement) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class RecipeFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _processTypes: EnumAssemblyType[] | null = null;\n /**\n * If provided only matching types are returned\n */\n public get processTypes(): EnumAssemblyType[] | null { return this._processTypes }\n public set processTypes(value: EnumAssemblyType[] | null) {\n this._processTypes = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.processTypes = jsonSerializedObject.processTypes == null ? null : jsonSerializedObject.processTypes.map((v: any) => EnumAssemblyType.getByValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.processTypes = this.processTypes == null ? null : this.processTypes.map(v => v.value);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class FilteredRecipes extends ModelObject {\n\n public matchingCount: number = 0;\n public recipes: Recipe[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.recipes = jsonSerializedObject.recipes.map((v: any) => new Recipe(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.recipes = this.recipes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"recipes\", rule: (v: any) => !!v || \"recipes is required\"},\n {field: \"recipes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Recipe[]).reduce((acc: Array, curr: Recipe) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class FilteredRecipeHeaders extends ModelObject {\n\n public matchingCount: number = 0;\n public recipeHeaders: RecipeHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.recipeHeaders = jsonSerializedObject.recipeHeaders.map((v: any) => new RecipeHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.recipeHeaders = this.recipeHeaders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"recipeHeaders\", rule: (v: any) => !!v || \"recipeHeaders is required\"},\n {field: \"recipeHeaders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as RecipeHeader[]).reduce((acc: Array, curr: RecipeHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetRecipeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public recipeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.recipeId = Guid.fromString(jsonSerializedObject.recipeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.recipeId = this.recipeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"recipeId\", rule: (v: any) => !v.isEmpty() || \".RecipeId cannot be empty\"},\n ];\n}\n\n\nexport class GetRecipeResponse extends ModelObject {\n\n public recipe: Recipe = new Recipe();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.recipe = new Recipe(jsonSerializedObject.recipe);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.recipe = this.recipe.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"recipe\", rule: (v: any) => !!v || \"recipe is required\"},\n {field: \"recipe\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetRecipesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public recipeIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.recipeIds = jsonSerializedObject.recipeIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.recipeIds = this.recipeIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetRecipesResponse extends ModelObject {\n\n public recipes: Recipe[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.recipes = jsonSerializedObject.recipes.map((v: any) => new Recipe(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.recipes = this.recipes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"recipes\", rule: (v: any) => !!v || \"recipes is required\"},\n {field: \"recipes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Recipe[]).reduce((acc: Array, curr: Recipe) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllRecipesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllRecipesResponse extends ModelObject {\n\n public recipes: Recipe[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.recipes = jsonSerializedObject.recipes.map((v: any) => new Recipe(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.recipes = this.recipes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"recipes\", rule: (v: any) => !!v || \"recipes is required\"},\n {field: \"recipes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as Recipe[]).reduce((acc: Array, curr: Recipe) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SetRecipeIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public recipeId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.recipeId = Guid.fromString(jsonSerializedObject.recipeId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.recipeId = this.recipeId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"recipeId\", rule: (v: any) => !v.isEmpty() || \".RecipeId cannot be empty\"},\n ];\n}\n\n\nexport class CopyRecipeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public recipeId: Guid = Guid.createEmpty();\n public newRecipeName: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.recipeId = Guid.fromString(jsonSerializedObject.recipeId);\n this.newRecipeName = jsonSerializedObject.newRecipeName;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.recipeId = this.recipeId.toString();\n toRet.newRecipeName = this.newRecipeName;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"recipeId\", rule: (v: any) => !v.isEmpty() || \".RecipeId cannot be empty\"},\n {field: \"newRecipeName\", rule: (v: any) => v == null || v.length !== 0 || \"NewRecipeName cannot be empty\"},\n {field: \"newRecipeName\", rule: (v: any) => v == null || v.length <= 1000 || \"NewRecipeName has too many characters (1000)\"},\n ];\n}\n\n\nexport class CopyRecipeResponse extends ModelObject {\n\n public newId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.newId = Guid.fromString(jsonSerializedObject.newId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.newId = this.newId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"newId\", rule: (v: any) => !v.isEmpty() || \".NewId cannot be empty\"},\n ];\n}\n\n\nexport class GetFilteredRecipesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: RecipeFilter = new RecipeFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new RecipeFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetFilteredRecipesResponse extends ModelObject {\n\n public results: FilteredRecipes = new FilteredRecipes();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredRecipes(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetRecipeHeaderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public recipeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.recipeId = Guid.fromString(jsonSerializedObject.recipeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.recipeId = this.recipeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"recipeId\", rule: (v: any) => !v.isEmpty() || \".RecipeId cannot be empty\"},\n ];\n}\n\n\nexport class GetRecipeHeaderResponse extends ModelObject {\n\n public recipeHeader: RecipeHeader = new RecipeHeader();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.recipeHeader = new RecipeHeader(jsonSerializedObject.recipeHeader);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.recipeHeader = this.recipeHeader.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"recipeHeader\", rule: (v: any) => !!v || \"recipeHeader is required\"},\n {field: \"recipeHeader\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetRecipeHeadersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public recipeIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.recipeIds = jsonSerializedObject.recipeIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.recipeIds = this.recipeIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetRecipeHeadersResponse extends ModelObject {\n\n public recipeHeaders: RecipeHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.recipeHeaders = jsonSerializedObject.recipeHeaders.map((v: any) => new RecipeHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.recipeHeaders = this.recipeHeaders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"recipeHeaders\", rule: (v: any) => !!v || \"recipeHeaders is required\"},\n {field: \"recipeHeaders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as RecipeHeader[]).reduce((acc: Array, curr: RecipeHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetAllRecipeHeadersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllRecipeHeadersResponse extends ModelObject {\n\n public recipeHeaders: RecipeHeader[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.recipeHeaders = jsonSerializedObject.recipeHeaders.map((v: any) => new RecipeHeader(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.recipeHeaders = this.recipeHeaders.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"recipeHeaders\", rule: (v: any) => !!v || \"recipeHeaders is required\"},\n {field: \"recipeHeaders\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as RecipeHeader[]).reduce((acc: Array, curr: RecipeHeader) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveRecipeHeaderRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public header: RecipeHeader = new RecipeHeader();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.header = new RecipeHeader(jsonSerializedObject.header);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.header = this.header.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"header\", rule: (v: any) => !!v || \"header is required\"},\n {field: \"header\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetFilteredRecipeHeadersRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: RecipeFilter = new RecipeFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new RecipeFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetFilteredRecipeHeadersResponse extends ModelObject {\n\n public results: FilteredRecipeHeaders = new FilteredRecipeHeaders();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredRecipeHeaders(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveRecipeInstructionRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public instruction: RecipeInstruction = new RecipeInstruction();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.instruction = new RecipeInstruction(jsonSerializedObject.instruction);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.instruction = this.instruction.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"instruction\", rule: (v: any) => !!v || \"instruction is required\"},\n {field: \"instruction\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveRecipeInstructionsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public instructions: readonly RecipeInstruction[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.instructions = jsonSerializedObject.instructions.map((v: any) => new RecipeInstruction(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.instructions = this.instructions.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"instructions\", rule: (v: any) => !!v || \"instructions is required\"},\n {field: \"instructions\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as RecipeInstruction[]).reduce((acc: Array, curr: RecipeInstruction) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class HardDeleteRecipeInstructionRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public recipeInstructionId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.recipeInstructionId = Guid.fromString(jsonSerializedObject.recipeInstructionId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.recipeInstructionId = this.recipeInstructionId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"recipeInstructionId\", rule: (v: any) => !v.isEmpty() || \".RecipeInstructionId cannot be empty\"},\n ];\n}\n\n\nexport class GetIngredientsForRecipesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public recipeIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.recipeIds = jsonSerializedObject.recipeIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.recipeIds = this.recipeIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetIngredientsForRecipesResponse extends ModelObject {\n\n public ingredients: RecipeIngredient[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.ingredients = jsonSerializedObject.ingredients.map((v: any) => new RecipeIngredient(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.ingredients = this.ingredients.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"ingredients\", rule: (v: any) => !!v || \"ingredients is required\"},\n {field: \"ingredients\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as RecipeIngredient[]).reduce((acc: Array, curr: RecipeIngredient) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveRecipeIngredientRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public ingredient: RecipeIngredient = new RecipeIngredient();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.ingredient = new RecipeIngredient(jsonSerializedObject.ingredient);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.ingredient = this.ingredient.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"ingredient\", rule: (v: any) => !!v || \"ingredient is required\"},\n {field: \"ingredient\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveRecipeIngredientsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public ingredients: readonly RecipeIngredient[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.ingredients = jsonSerializedObject.ingredients.map((v: any) => new RecipeIngredient(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.ingredients = this.ingredients.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"ingredients\", rule: (v: any) => !!v || \"ingredients is required\"},\n {field: \"ingredients\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as RecipeIngredient[]).reduce((acc: Array, curr: RecipeIngredient) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class HardDeleteRecipeIngredientsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public recipeIngredientIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.recipeIngredientIds = jsonSerializedObject.recipeIngredientIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.recipeIngredientIds = this.recipeIngredientIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class SaveRecipeVesselRequirementRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public requirement: RecipeVesselRequirement = new RecipeVesselRequirement();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.requirement = new RecipeVesselRequirement(jsonSerializedObject.requirement);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.requirement = this.requirement.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"requirement\", rule: (v: any) => !!v || \"requirement is required\"},\n {field: \"requirement\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class HardDeleteRecipeVesselRequirementRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public requirementId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.requirementId = Guid.fromString(jsonSerializedObject.requirementId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.requirementId = this.requirementId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"requirementId\", rule: (v: any) => !v.isEmpty() || \".RequirementId cannot be empty\"},\n ];\n}\n\n\nexport class RecipeService extends ServiceBase {\n\n public async getRecipe(tenantId: Guid, recipeId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetRecipeRequest();\n req.tenantId = tenantId;\n req.recipeId = recipeId;\n const extractor = (response:any) => new GetRecipeResponse(response).recipe;\n return this.makeJsonRequest(\"recipe/v2/getRecipe\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getRecipes(tenantId: Guid, recipeIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetRecipesRequest();\n req.tenantId = tenantId;\n req.recipeIds = recipeIds;\n const extractor = (response:any) => new GetRecipesResponse(response).recipes;\n return this.makeJsonRequest(\"recipe/v2/getRecipes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllRecipes(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllRecipesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllRecipesResponse(response).recipes;\n return this.makeJsonRequest(\"recipe/v2/getAllRecipes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setRecipeIsHidden(tenantId: Guid, recipeId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetRecipeIsHiddenRequest();\n req.tenantId = tenantId;\n req.recipeId = recipeId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"recipe/v2/setRecipeIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async copyRecipe(tenantId: Guid, recipeId: Guid, newRecipeName: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CopyRecipeRequest();\n req.tenantId = tenantId;\n req.recipeId = recipeId;\n req.newRecipeName = newRecipeName;\n const extractor = (response:any) => new CopyRecipeResponse(response).newId;\n return this.makeJsonRequest(\"recipe/v2/copyRecipe\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getFilteredRecipes(tenantId: Guid, filter: RecipeFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetFilteredRecipesRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetFilteredRecipesResponse(response).results;\n return this.makeJsonRequest(\"recipe/v2/getFilteredRecipes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getRecipeHeader(tenantId: Guid, recipeId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetRecipeHeaderRequest();\n req.tenantId = tenantId;\n req.recipeId = recipeId;\n const extractor = (response:any) => new GetRecipeHeaderResponse(response).recipeHeader;\n return this.makeJsonRequest(\"recipe/v2/getRecipeHeader\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getRecipeHeaders(tenantId: Guid, recipeIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetRecipeHeadersRequest();\n req.tenantId = tenantId;\n req.recipeIds = recipeIds;\n const extractor = (response:any) => new GetRecipeHeadersResponse(response).recipeHeaders;\n return this.makeJsonRequest(\"recipe/v2/getRecipeHeaders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllRecipeHeaders(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllRecipeHeadersRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllRecipeHeadersResponse(response).recipeHeaders;\n return this.makeJsonRequest(\"recipe/v2/getAllRecipeHeaders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveRecipeHeader(tenantId: Guid, header: RecipeHeader, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveRecipeHeaderRequest();\n req.tenantId = tenantId;\n req.header = header;\n const extractor = null;\n return this.makeJsonRequest(\"recipe/v2/saveRecipeHeader\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getFilteredRecipeHeaders(tenantId: Guid, filter: RecipeFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetFilteredRecipeHeadersRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetFilteredRecipeHeadersResponse(response).results;\n return this.makeJsonRequest(\"recipe/v2/getFilteredRecipeHeaders\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveRecipeInstruction(tenantId: Guid, instruction: RecipeInstruction, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveRecipeInstructionRequest();\n req.tenantId = tenantId;\n req.instruction = instruction;\n const extractor = null;\n return this.makeJsonRequest(\"recipe/v2/saveRecipeInstruction\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveRecipeInstructions(tenantId: Guid, instructions: readonly RecipeInstruction[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveRecipeInstructionsRequest();\n req.tenantId = tenantId;\n req.instructions = instructions;\n const extractor = null;\n return this.makeJsonRequest(\"recipe/v2/saveRecipeInstructions\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async hardDeleteRecipeInstruction(tenantId: Guid, recipeInstructionId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new HardDeleteRecipeInstructionRequest();\n req.tenantId = tenantId;\n req.recipeInstructionId = recipeInstructionId;\n const extractor = null;\n return this.makeJsonRequest(\"recipe/v2/hardDeleteRecipeInstruction\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getIngredientsForRecipes(tenantId: Guid, recipeIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetIngredientsForRecipesRequest();\n req.tenantId = tenantId;\n req.recipeIds = recipeIds;\n const extractor = (response:any) => new GetIngredientsForRecipesResponse(response).ingredients;\n return this.makeJsonRequest(\"recipe/v2/getIngredientsForRecipes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveRecipeIngredient(tenantId: Guid, ingredient: RecipeIngredient, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveRecipeIngredientRequest();\n req.tenantId = tenantId;\n req.ingredient = ingredient;\n const extractor = null;\n return this.makeJsonRequest(\"recipe/v2/saveRecipeIngredient\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveRecipeIngredients(tenantId: Guid, ingredients: readonly RecipeIngredient[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveRecipeIngredientsRequest();\n req.tenantId = tenantId;\n req.ingredients = ingredients;\n const extractor = null;\n return this.makeJsonRequest(\"recipe/v2/saveRecipeIngredients\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async hardDeleteRecipeIngredients(tenantId: Guid, recipeIngredientIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new HardDeleteRecipeIngredientsRequest();\n req.tenantId = tenantId;\n req.recipeIngredientIds = recipeIngredientIds;\n const extractor = null;\n return this.makeJsonRequest(\"recipe/v2/hardDeleteRecipeIngredients\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveRecipeVesselRequirement(tenantId: Guid, requirement: RecipeVesselRequirement, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveRecipeVesselRequirementRequest();\n req.tenantId = tenantId;\n req.requirement = requirement;\n const extractor = null;\n return this.makeJsonRequest(\"recipe/v2/saveRecipeVesselRequirement\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async hardDeleteRecipeVesselRequirement(tenantId: Guid, requirementId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new HardDeleteRecipeVesselRequirementRequest();\n req.tenantId = tenantId;\n req.requirementId = requirementId;\n const extractor = null;\n return this.makeJsonRequest(\"recipe/v2/hardDeleteRecipeVesselRequirement\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const recipeService = new RecipeService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\nimport {\n recipeService,\n type Recipe,\n} from \"@/app/services/generated/recipev2Service\";\n\n// Singleton cache store\nconst recipeCacheStore = new EntityCacheStore(\n EnumCacheEntityType.recipe,\n async () => recipeService.getAllRecipes(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class RecipesCache extends EntityWithGuidKeyCache {\n constructor() {\n super(recipeCacheStore, (x) => x.header.id);\n }\n\n public get allMaintenanceRecipes() {\n return Object.freeze(\n [...this.allReactive.value].filter((x) =>\n x.header.processType.isMaintenance()\n ) as readonly Readonly[]\n );\n }\n}\n","import CreditTermsCache from \"@/app/caching/caches/creditTermsCache\";\nimport DeliveryAreasCache from \"@/app/caching/caches/deliveryAreasCache\";\nimport OutletRatingsCache from \"@/app/caching/caches/outletRatingsCache\";\nimport SalesAreasCache from \"@/app/caching/caches/salesAreasCache\";\nimport SalesCodeCache from \"@/app/caching/caches/salesCodeCache\";\nimport TaskTypesCache from \"@/app/caching/caches/taskTypesCache\";\nimport TaskQueuesCache from \"@/app/caching/caches/taskQueuesCache\";\nimport UnitsOfMeasuresCache from \"@/app/caching/caches/unitsOfMeasureCache\";\nimport PackageTypesCache from \"@/app/caching/caches/packageTypesCache\";\nimport OutletSummariesCache from \"@/app/caching/caches/outletSummariesCache\";\nimport type { EntityCacheConstructor } from \"@/app/caching/apiCache\";\nimport apiCache from \"@/app/caching/apiCache\";\nimport ItemsCache from \"@/app/caching/caches/itemCache\";\nimport GroupsCache from \"@/app/caching/caches/groupsCache\";\nimport OutletTypesCache from \"@/app/caching/caches/outletTypesCache\";\nimport StockLocationsCache from \"@/app/caching/caches/stockLocationsCache\";\nimport VatCodesCache from \"@/app/caching/caches/vatCodesCache\";\nimport CouriersCache from \"@/app/caching/caches/couriersCache\";\nimport OutletSubTypesCache from \"@/app/caching/caches/outletSubTypesCache\";\nimport PriceListsCache from \"@/app/caching/caches/priceListsCache\";\nimport LeadsCache from \"@/app/caching/caches/leadsCache\";\nimport PalletTypesCache from \"@/app/caching/caches/palletTypesCache\";\nimport VesselsCache from \"@/app/caching/caches/vesselsCache\";\nimport VesselTypesCache from \"@/app/caching/caches/vesselTypesCache\";\nimport VesselStatesCache from \"@/app/caching/caches/vesselStatesCache\";\nimport CollectionTimesCache from \"@/app/caching/caches/collectionTimesCache\";\nimport GlCodesCache from \"@/app/caching/caches/glCodesCache\";\nimport StockGroupsCache from \"@/app/caching/caches/stockGroupsCache\";\nimport PricingCategoriesCache from \"@/app/caching/caches/pricingCategoriesCache\";\nimport SupplierManufacturersCache from \"@/app/caching/caches/supplierManufacturersCache\";\nimport ProductBrandsCache from \"@/app/caching/caches/productBrandsCache\";\nimport RecipesCache from \"@/app/caching/caches/recipesCache\";\n\nclass BuildCache> {\n private _blueprint: T;\n\n constructor(blueprint: T) {\n this._blueprint = blueprint;\n }\n\n private extend>(\n additional: TMore\n ) {\n return new BuildCache(\n Object.assign({}, this._blueprint, additional)\n );\n }\n\n build() {\n return apiCache.buildCacheSet(this._blueprint);\n }\n\n async buildAndUpdate() {\n const cache = this.build();\n await cache.update();\n return cache;\n }\n\n withCreditTerms() {\n return this.extend({ creditTerms: CreditTermsCache });\n }\n\n withCollectionTimes() {\n return this.extend({ collectionTimes: CollectionTimesCache });\n }\n\n withCouriers() {\n return this.extend({ couriers: CouriersCache });\n }\n\n withDeliveryAreas() {\n return this.extend({ deliveryAreas: DeliveryAreasCache });\n }\n\n withGlCodes() {\n return this.extend({ glCodes: GlCodesCache });\n }\n\n withGroups() {\n return this.extend({ groups: GroupsCache });\n }\n\n withItems() {\n return this.extend({ items: ItemsCache });\n }\n\n withLeads() {\n return this.extend({ leads: LeadsCache });\n }\n\n withOutletRatings() {\n return this.extend({ outletRatings: OutletRatingsCache });\n }\n\n withOutletSummaries() {\n return this.extend({ outlets: OutletSummariesCache });\n }\n\n withOutletSubTypes() {\n return this.extend({ outletSubTypes: OutletSubTypesCache });\n }\n\n withOutletTypes() {\n return this.extend({ outletTypes: OutletTypesCache });\n }\n\n withPackageTypes() {\n return this.extend({ packageTypes: PackageTypesCache });\n }\n\n withPalletTypes() {\n return this.extend({ palletTypes: PalletTypesCache });\n }\n\n withPriceLists() {\n return this.extend({ priceLists: PriceListsCache });\n }\n\n withPricingCategories() {\n return this.extend({ pricingCategories: PricingCategoriesCache });\n }\n\n withProductBrands() {\n return this.extend({ productBrands: ProductBrandsCache });\n }\n\n withRecipes() {\n return this.extend({ recipes: RecipesCache });\n }\n\n withSalesAreas() {\n return this.extend({ salesAreas: SalesAreasCache });\n }\n\n withSalesCodes() {\n return this.extend({ salesCodes: SalesCodeCache });\n }\n\n withStockGroups() {\n return this.extend({ stockGroups: StockGroupsCache });\n }\n\n withStockLocations() {\n return this.extend({ stockLocations: StockLocationsCache });\n }\n\n withSupplierManufacturers() {\n return this.extend({ supplierManufacturers: SupplierManufacturersCache });\n }\n\n withTaskQueues() {\n return this.extend({ taskQueues: TaskQueuesCache });\n }\n\n withTaskTypes() {\n return this.extend({ taskTypes: TaskTypesCache });\n }\n\n withUnitsOfMeasure() {\n return this.extend({ unitsOfMeasure: UnitsOfMeasuresCache });\n }\n\n withVatCodes() {\n return this.extend({ vatCodes: VatCodesCache });\n }\n\n withVessels() {\n return this.extend({ vessels: VesselsCache });\n }\n\n withVesselStates() {\n return this.extend({ vesselStates: VesselStatesCache });\n }\n\n withVesselTypes() {\n return this.extend({ vesselTypes: VesselTypesCache });\n }\n}\n\nexport function buildCache() {\n return new BuildCache({});\n}\n","import api from \"@/app/api\";\nimport { OutletSummary } from \"@/app/services/generated/outletService\";\nimport { SupplierManufacturer } from \"@/app/services/generated/suppliermanufacturerService\";\nimport { Group } from \"@/app/services/generated/groupService\";\nimport {\n PurchaseOrderHeader,\n PurchaseOrderFilter,\n purchaseOrderService,\n} from \"@/app/services/generated/purchaseorderService\";\nimport {\n StockTakeHeader,\n StockTakeFilter,\n stockTakeService,\n} from \"@/app/services/generated/stocktakeService\";\nimport {\n UllageHeader,\n UllageFilter,\n ullageService,\n} from \"@/app/services/generated/ullageService\";\nimport { PriceList } from \"@/app/services/generated/pricelistService\";\nimport type {\n AssemblyProcessLine,\n ProcessLineForAssembly,\n} from \"@/app/services/generated/assemblyService\";\nimport {\n AssemblyFilter,\n assemblyService,\n AssemblyHeader,\n} from \"@/app/services/generated/assemblyService\";\nimport type { BmTask } from \"@/app/services/generated/bmtaskService\";\nimport {\n CreditSummary,\n CreditFilter,\n creditService,\n} from \"@/app/services/generated/creditService\";\nimport { EnumAssemblyType } from \"@/app/services/generated/enums/enumAssemblyType.generated\";\nimport { EnumBmEntityType } from \"@/app/services/generated/enums/enumBmEntityType.generated\";\nimport type { OutletLastOrderTimestamp } from \"@/app/services/generated/orderService\";\nimport {\n OrderFilter,\n OrderSummary,\n} from \"@/app/services/generated/orderService\";\nimport type Guid from \"@/app/types/common/guid\";\nimport { GuidMap, GuidSet } from \"@/app/types/common/guidcollections\";\nimport { contactsMenu } from \"@/app/ui/navigation/contactsMenu\";\nimport { priceListSubRoutes } from \"@/app/ui/navigation/pricingMenu\";\nimport { productionMenu } from \"@/app/ui/navigation/productionMenu\";\nimport { salesMenu } from \"@/app/ui/navigation/salesMenu\";\nimport { stockMenu } from \"@/app/ui/navigation/stockMenu\";\nimport { ullageRoutes } from \"@/app/ui/navigation/ullagesMenu\";\nimport { translateWithParams, useI18n } from \"@/plugins/i18n\";\nimport type { Location } from \"vue-router\";\nimport { orderService } from \"@/app/services/extensions/orderServiceExtended\";\nimport { Lead, leadService } from \"@/app/services/generated/leadService\";\nimport apiCache from \"@/app/caching/apiCache\";\nimport type OutletSummariesCache from \"@/app/caching/caches/outletSummariesCache\";\nimport type SupplierManufacturersCache from \"@/app/caching/caches/supplierManufacturersCache\";\nimport type PriceListsCache from \"@/app/caching/caches/priceListsCache\";\nimport { distinctGuids, isNotNullOrUndefined, toGuidMap } from \"@/app/apiutils\";\nimport { Vessel } from \"@/app/services/generated/vesselv2Service\";\nimport {\n PalletHeader,\n PalletFilter,\n palletService,\n} from \"@/app/services/generated/palletService\";\nimport { distributionMenu } from \"@/app/ui/navigation/distributionMenu\";\nimport { EnumPalletStatus } from \"@/app/services/generated/enums/enumPalletStatus.generated\";\nimport {\n StockTransferHeader,\n StockTransferFilter,\n stockTransferService,\n} from \"@/app/services/generated/stocktransferService\";\nimport {\n StockAdjustmentHeader,\n StockAdjustmentFilter,\n stockAdjustmentService,\n} from \"@/app/services/generated/stockadjustmentService\";\nimport type VesselsCache from \"@/app/caching/caches/vesselsCache\";\nimport type { ProcessHeader } from \"@/app/services/generated/batchService\";\nimport {\n batchService,\n type BatchHeader,\n type ProcessInstruction,\n BatchFilter,\n} from \"@/app/services/generated/batchService\";\nimport { batchMenu } from \"@/app/ui/navigation/batchMenu\";\nimport { EnumFeatureFlag } from \"@/app/services/generated/enums/enumFeatureFlag.generated\";\nimport { hasFeatureUsingUserStore } from \"@/app/featureFlags\";\nimport { tenantService } from \"@/app/services/extensions/tenantServiceExtended\";\nimport GroupsCache from \"@/app/caching/caches/groupsCache\";\nimport ItemsCache from \"@/app/caching/caches/itemCache\";\nimport { EnumItemMainPurpose } from \"@/app/services/generated/enums/enumItemMainPurpose.generated\";\nimport { Item } from \"@/app/services/generated/itemService\";\nimport { EnumStockTakeStatus } from \"@/app/services/generated/enums/enumStockTakeStatus.generated\";\nimport userStore from \"@/store/modules/userStore\";\nimport { buildCache } from \"@/app/caching/buildCache\";\n\nconst { $m, $t } = useI18n();\n\ninterface ProcessLineWithAssembly {\n processLine: AssemblyProcessLine;\n processLineId: Guid;\n assemblyHeader: AssemblyHeader;\n}\n\ninterface ProcessInstructionWithParentDetails {\n instruction: ProcessInstruction;\n process: ProcessHeader;\n batch: BatchHeader | null;\n}\n\nexport interface TaskWithAssociations {\n task: BmTask;\n associationName: string | null;\n associationRoute: Location | null;\n\n // association - at most one of these objects will be populated\n associatedOutlet?: Readonly;\n associatedOutletLastOrder?: Readonly;\n associatedOutletGroup?: Readonly;\n associatedOrder?: Readonly;\n associatedAssembly?: Readonly;\n associatedAssemblyProcessLine?: Readonly;\n associatedCredit?: Readonly;\n associatedLead?: Readonly;\n associatedPriceList?: Readonly;\n associatedMaterial?: Readonly;\n associatedProduct?: Readonly;\n associatedPurchaseOrder?: Readonly;\n associatedStockTake?: Readonly;\n associatedSupplier?: Readonly;\n associatedUllage?: Readonly;\n associatedVessel?: Readonly;\n associatedPallet?: Readonly;\n associatedStockTransfer?: Readonly;\n associatedStockAdjustment?: Readonly;\n associatedBatch?: Readonly;\n associatedBatchProcessInstruction?: Readonly;\n}\n\nexport interface Associations {\n getRoute: (item: T, task?: BmTask) => Location;\n getText: (item: T) => string; // For dropdowns\n getValue: (item: T) => Guid; // For dropdowns\n getAll: (opts: { initialItemId?: Guid | null }) => Promise;\n}\n\nexport const availableEntityTypesFilter = (type: EnumBmEntityType) => {\n return (\n type === EnumBmEntityType.assembly ||\n type === EnumBmEntityType.assemblyProcedure ||\n type === EnumBmEntityType.credit ||\n type === EnumBmEntityType.lead ||\n type === EnumBmEntityType.material ||\n type === EnumBmEntityType.order ||\n type === EnumBmEntityType.outlet ||\n type === EnumBmEntityType.outletGroup ||\n type === EnumBmEntityType.priceList ||\n type === EnumBmEntityType.product ||\n type === EnumBmEntityType.purchaseOrder ||\n type === EnumBmEntityType.stockTake ||\n type === EnumBmEntityType.supplier ||\n type === EnumBmEntityType.ullage ||\n type === EnumBmEntityType.vessel ||\n type === EnumBmEntityType.pallet ||\n type === EnumBmEntityType.none ||\n type === EnumBmEntityType.stockTransfer ||\n type === EnumBmEntityType.stockAdjustment ||\n (hasFeatureUsingUserStore(EnumFeatureFlag.onlyDev) &&\n type === EnumBmEntityType.batch) ||\n (hasFeatureUsingUserStore(EnumFeatureFlag.onlyDev) &&\n type === EnumBmEntityType.batchProcessInstruction)\n );\n};\n\nconst mapProcessLines = async (\n processLinesForAssemblies: ProcessLineForAssembly[]\n): Promise => {\n const processWithAssemblies: ProcessLineWithAssembly[] = [];\n\n const headerIds = processLinesForAssemblies.map((p) => p.assemblyId);\n const assemblyHeaders = await assemblyService\n .getAssemblyHeadersByIds(api.tenantId, headerIds)\n .then((val) => new GuidMap(val.map((assembly) => [assembly.id, assembly])));\n\n processLinesForAssemblies.forEach((processLineForAssembly) => {\n let header = assemblyHeaders.get(processLineForAssembly.assemblyId);\n\n processWithAssemblies.push({\n processLine: processLineForAssembly.processLine,\n processLineId: processLineForAssembly.processLine.id,\n assemblyHeader: header!,\n });\n });\n\n return processWithAssemblies;\n};\n\nconst mapProcessInstructions = async (\n instructions: ProcessInstruction[]\n): Promise => {\n const processIds = distinctGuids(instructions.map((i) => i.processId));\n const processes = await batchService.getProcessHeaders(\n api.tenantId,\n processIds\n );\n const processMap = toGuidMap(processes, (i) => i.id);\n\n const batchIds = distinctGuids(processes.map((p) => p.batchId));\n const batches = await batchService.getBatchHeaders(api.tenantId, batchIds);\n const batchMap = toGuidMap(batches, (i) => i.id);\n\n return instructions\n .map((i): ProcessInstructionWithParentDetails | null => {\n const process = processMap.get(i.processId);\n\n if (!process) {\n return null;\n }\n\n return {\n instruction: i,\n process: process,\n batch: batchMap.get(process.batchId) ?? null,\n };\n })\n .filter(isNotNullOrUndefined);\n};\n\nexport const getAssociationFromType = (\n type: EnumBmEntityType | null,\n cache: {\n outlets: OutletSummariesCache;\n supplierManufacturers: SupplierManufacturersCache;\n groups: GroupsCache;\n items: ItemsCache;\n priceLists: PriceListsCache;\n vessels: VesselsCache;\n }\n): Associations | null => {\n const DAYS_IN_PAST = 28;\n\n switch (type) {\n case EnumBmEntityType.outlet:\n return {\n getRoute: (outlet, task) => {\n // If the task is for the current user then we will open outlet at CRM tab with \"current task\"\n const isForCurrentUser = !!task?.assignedToUserId?.equals(\n userStore.state.user?.id\n );\n return contactsMenu.viewOutlet(\n outlet.id,\n outlet.isRetail,\n isForCurrentUser ? task!.id : null\n );\n },\n getText: (outlet) => outlet.displayName + \" | \" + outlet.code,\n getValue: (outlet) => outlet.id,\n getAll: () => Promise.resolve(cache.outlets.all),\n } satisfies Associations>;\n\n case EnumBmEntityType.order:\n return {\n getRoute: (order) => salesMenu.viewOrder(order.id),\n getText: (order) =>\n $m.enum_bm_entity_type_order + \" \" + order.orderNumber,\n getValue: (order) => order.id,\n getAll: async ({ initialItemId }) => {\n const orderFilter = new OrderFilter();\n orderFilter.fromCreatedAt = tenantService.now.minusSeconds(\n 60 * 60 * 24 * DAYS_IN_PAST\n );\n\n const orderSummaries = await orderService\n .getOrderSummaries(api.tenantId, orderFilter)\n .then((val) => val.orders);\n\n if (initialItemId) {\n const orderIds = new GuidSet(\n orderSummaries.map((order) => order.id)\n );\n\n if (!orderIds.has(initialItemId)) {\n const singleOrderFilter = new OrderFilter();\n singleOrderFilter.limitOrderHeaderIds = [initialItemId];\n\n orderSummaries.push(\n ...(await orderService\n .getOrderSummaries(api.tenantId, singleOrderFilter)\n .then((res) => res.orders))\n );\n }\n }\n\n return orderSummaries;\n },\n } satisfies Associations;\n\n case EnumBmEntityType.credit:\n return {\n getRoute: (credit) => salesMenu.viewCreditNote(credit.id),\n getText: (credit) =>\n $m.enum_bm_entity_type_credit + \" \" + credit.creditNumber,\n getValue: (credit) => credit.id,\n getAll: async ({ initialItemId }) => {\n const creditFilter = new CreditFilter();\n creditFilter.fromCreatedAt = tenantService.now.minusSeconds(\n 60 * 60 * 24 * DAYS_IN_PAST\n );\n\n const creditSummaries = await creditService\n .getCreditSummaries(api.tenantId, creditFilter)\n .then((val) => val.credits);\n\n if (initialItemId) {\n const creditIds = new GuidSet(\n creditSummaries.map((credit) => credit.id)\n );\n\n if (!creditIds.has(initialItemId)) {\n const singleCreditFilter = new CreditFilter();\n singleCreditFilter.limitCreditIds = [initialItemId];\n\n creditSummaries.push(\n ...(await creditService\n .getCreditSummaries(api.tenantId, singleCreditFilter)\n .then((val) => val.credits))\n );\n }\n }\n\n return creditSummaries;\n },\n } satisfies Associations;\n\n case EnumBmEntityType.assembly:\n return {\n getRoute: (assembly) => {\n switch (assembly.assemblyType) {\n case EnumAssemblyType.productPackaging:\n return productionMenu.assembly.viewAssembly(assembly.id);\n case EnumAssemblyType.materialProduction:\n return productionMenu.batch.viewBatch(assembly.id);\n default:\n return productionMenu.assembly.viewAssembly(assembly.id);\n }\n },\n getText: (assembly) =>\n $m.enum_bm_entity_type_assembly + \" \" + assembly.name,\n getValue: (assembly) => assembly.id,\n getAll: async ({ initialItemId }) => {\n const assemblyFilter = new AssemblyFilter();\n assemblyFilter.fromPlannedStartDateInclusive =\n tenantService.today.minusDays(DAYS_IN_PAST);\n\n const assemblyHeaders = await assemblyService\n .getFilteredAssemblySummaries(api.tenantId, assemblyFilter)\n .then((res) =>\n res.assemblySummaries.map((summary) => summary.header)\n );\n\n if (initialItemId) {\n assemblyHeaders.push(\n ...(await assemblyService.getAssemblyHeadersByIds(api.tenantId, [\n initialItemId,\n ]))\n );\n }\n\n return assemblyHeaders;\n },\n } satisfies Associations;\n\n case EnumBmEntityType.assemblyProcedure:\n return {\n getRoute: (processWithAssembly) => {\n switch (processWithAssembly.assemblyHeader.assemblyType) {\n case EnumAssemblyType.productPackaging:\n return productionMenu.assembly.viewAssembly(\n processWithAssembly.assemblyHeader.id\n );\n case EnumAssemblyType.materialProduction:\n return productionMenu.batch.viewBatch(\n processWithAssembly.assemblyHeader.id\n );\n default:\n return productionMenu.assembly.viewAssembly(\n processWithAssembly.assemblyHeader.id\n );\n }\n },\n getText: (processWithAssembly) =>\n $m.enum_bm_entity_type_assembly +\n \" \" +\n processWithAssembly.assemblyHeader?.name +\n \" | \" +\n processWithAssembly.processLine?.instruction,\n getValue: (processWithAssembly) => processWithAssembly.processLineId,\n getAll: () =>\n assemblyService\n .getAllAssemblyProcessLines(api.tenantId)\n .then((process) => mapProcessLines(process)),\n } satisfies Associations;\n\n case EnumBmEntityType.supplier:\n return {\n getRoute: (supplier) => contactsMenu.viewSupplier(supplier.id),\n getText: (supplier) => supplier.businessName,\n getValue: (supplier) => supplier.id,\n getAll: () => Promise.resolve(cache.supplierManufacturers.all),\n } satisfies Associations>;\n\n case EnumBmEntityType.outletGroup:\n return {\n getRoute: (outletGroup) => contactsMenu.viewOutletGroup(outletGroup.id),\n getText: (outletGroup) => outletGroup.name,\n getValue: (outletGroup) => outletGroup.id,\n getAll: () => Promise.resolve(cache.groups.all),\n } satisfies Associations>;\n\n case EnumBmEntityType.purchaseOrder:\n return {\n getRoute: (po) => stockMenu.purchaseOrdering.viewPurchaseOrder(po.id),\n getText: (po) =>\n $m.enum_bm_entity_type_purchase_order + \" \" + po.readOnly?.number,\n getValue: (po) => po.id,\n getAll: async ({ initialItemId }) => {\n const purchaseOrderFilter = new PurchaseOrderFilter();\n purchaseOrderFilter.createdFrom =\n tenantService.today.minusDays(DAYS_IN_PAST);\n\n const purchaseOrderHeaders = await purchaseOrderService\n .getPurchaseOrderHeadersByFilter(api.tenantId, purchaseOrderFilter)\n .then((res) => res.purchaseOrderHeaders);\n\n if (initialItemId) {\n const purchaseOrderIds = new GuidSet(\n purchaseOrderHeaders.map((po) => po.id)\n );\n\n if (!purchaseOrderIds.has(initialItemId)) {\n const singlePurchaseOrderFilter = new PurchaseOrderFilter();\n singlePurchaseOrderFilter.purchaseOrderIds = [initialItemId];\n\n purchaseOrderHeaders.push(\n ...(await purchaseOrderService\n .getPurchaseOrderHeadersByFilter(\n api.tenantId,\n singlePurchaseOrderFilter\n )\n .then((res) => res.purchaseOrderHeaders))\n );\n }\n }\n\n return purchaseOrderHeaders;\n },\n } satisfies Associations;\n\n case EnumBmEntityType.product:\n return {\n getRoute: (item) => stockMenu.stock.viewLocation(item.details.id),\n getText: (item) => item.details.name,\n getValue: (item) => item.details.id,\n getAll: () => {\n return Promise.resolve(\n cache.items.all.filter(\n (item) => item.details.mainPurpose === EnumItemMainPurpose.product\n )\n );\n },\n } satisfies Associations>;\n\n case EnumBmEntityType.material:\n return {\n getRoute: (item) => stockMenu.stock.viewLocation(item.details.id),\n getText: (item) => item.details.name,\n getValue: (item) => item.details.id,\n getAll: () => {\n return Promise.resolve(\n cache.items.all.filter(\n (item) =>\n item.details.mainPurpose === EnumItemMainPurpose.material\n )\n );\n },\n } satisfies Associations>;\n\n case EnumBmEntityType.lead:\n return {\n getRoute: (lead) => salesMenu.leads.viewLead(lead.id),\n getText: (lead) => lead.businessName,\n getValue: (lead) => lead.id,\n getAll: async () => await leadService.getAllLeads(api.tenantId),\n } satisfies Associations;\n\n case EnumBmEntityType.stockTake:\n return {\n getRoute: (stockTake) => stockMenu.stockTake.viewLocation(stockTake.id),\n getText: (stockTake) =>\n $m.enum_bm_entity_type_stock_take + \" \" + stockTake.readOnly.number,\n getValue: (stockTake) => stockTake.id,\n getAll: async ({ initialItemId }) => {\n const stockTakeFilter = new StockTakeFilter();\n stockTakeFilter.statuses = [\n EnumStockTakeStatus.open,\n EnumStockTakeStatus.inProgress,\n EnumStockTakeStatus.complete,\n ];\n\n const stockTakeHeaders = await stockTakeService\n .getStockTakeHeadersByFilter(api.tenantId, stockTakeFilter)\n .then((res) => res.stockTakeHeaders);\n\n if (initialItemId) {\n const stockTakeIds = new GuidSet(\n stockTakeHeaders.map((header) => header.id)\n );\n\n if (!stockTakeIds.has(initialItemId)) {\n stockTakeHeaders.push(\n ...(await stockTakeService.getStockTakeHeaders(api.tenantId, [\n initialItemId,\n ]))\n );\n }\n }\n\n return stockTakeHeaders;\n },\n } satisfies Associations;\n\n case EnumBmEntityType.ullage:\n return {\n getRoute: (ullage) => ullageRoutes.view.location(ullage.id),\n getText: (ullage) =>\n $m.enum_bm_entity_type_ullage + \" \" + ullage.readOnly.ullageNumber,\n getValue: (ullage) => ullage.id,\n getAll: async ({ initialItemId }) => {\n const ullageFilter = new UllageFilter();\n ullageFilter.fromCreatedDate = tenantService.instantToDate(\n tenantService.now.minusSeconds(60 * 60 * 24 * DAYS_IN_PAST)\n );\n\n // Map to header to avoid vuetify \"header\" bug\n const ullageHeaders = await ullageService\n .getUllagesByFilter(api.tenantId, ullageFilter)\n .then((res) => res.ullages.map((ullage) => ullage.header));\n\n if (initialItemId) {\n const ullageIds = new GuidSet(\n ullageHeaders.map((header) => header.id)\n );\n\n if (!ullageIds.has(initialItemId)) {\n ullageHeaders.push(\n ...(await ullageService.getUllageHeaders(api.tenantId, [\n initialItemId,\n ]))\n );\n }\n }\n\n return ullageHeaders;\n },\n } satisfies Associations;\n\n case EnumBmEntityType.priceList:\n return {\n getRoute: (priceList) =>\n priceListSubRoutes.pricesTab.location(priceList.id),\n getText: (priceList) =>\n $m.enum_bm_entity_type_price_list + \" \" + priceList.name,\n getValue: (priceList) => priceList.id,\n getAll: () => Promise.resolve(cache.priceLists.all),\n } satisfies Associations>;\n\n case EnumBmEntityType.vessel:\n return {\n getRoute: (vessel) =>\n productionMenu.vessel.viewMaintenanceTab(vessel.id),\n getText: (vessel) => vessel.name,\n getValue: (vessel) => vessel.id,\n getAll: () => Promise.resolve(cache.vessels.all),\n } satisfies Associations>;\n\n case EnumBmEntityType.pallet:\n return {\n getRoute: (pallet) => distributionMenu.pallets.viewLocation(pallet.id),\n getText: (pallet) =>\n $t($m.keys.pallet_with_number, {\n number: pallet.readOnly.number,\n }).toString(),\n getValue: (pallet) => pallet.id,\n getAll: async ({ initialItemId }) => {\n const palletFilter = new PalletFilter();\n palletFilter.statuses = [EnumPalletStatus.in];\n\n // Map to only headers to prevent bloat and vuetify \"header\" bug\n const palletHeaders = await palletService\n .getPalletsByFilter(api.tenantId, palletFilter)\n .then((v) => v.pallets.map((p) => p.header));\n\n if (initialItemId) {\n const palletIds = new GuidSet(\n palletHeaders.map((header) => header.id)\n );\n\n if (!palletIds.has(initialItemId)) {\n const singlePalletFilter = new PalletFilter();\n singlePalletFilter.palletIds = [initialItemId];\n\n palletHeaders.push(\n ...(await palletService\n .getPalletsByFilter(api.tenantId, singlePalletFilter)\n .then((v) => v.pallets.map((p) => p.header)))\n );\n }\n }\n\n return palletHeaders;\n },\n } satisfies Associations>;\n\n case EnumBmEntityType.stockTransfer:\n return {\n getRoute: (stockTransfer) =>\n stockMenu.stockMovements.stockTransfer.editStockTransfer(\n stockTransfer.id,\n false\n ),\n getText: (stockTransfer) =>\n $m.enum_bm_entity_type_stock_transfer +\n \" \" +\n stockTransfer.readOnly.number,\n getValue: (stockTransfer) => stockTransfer.id,\n getAll: async ({ initialItemId }) => {\n const stockTransferFilter = new StockTransferFilter();\n stockTransferFilter.fromDespatchDateInclusive =\n tenantService.today.minusDays(DAYS_IN_PAST);\n\n const stockTransferHeaders = await stockTransferService\n .getFilteredStockTransferHeaders(api.tenantId, stockTransferFilter)\n .then((res) => res.stockTransferHeaders);\n\n if (initialItemId) {\n const stockTransferIds = new GuidSet(\n stockTransferHeaders.map((header) => header.id)\n );\n\n if (!stockTransferIds.has(initialItemId)) {\n stockTransferHeaders.push(\n ...(await stockTransferService.getStockTransferHeaders(\n api.tenantId,\n [initialItemId]\n ))\n );\n }\n }\n\n return stockTransferHeaders;\n },\n } satisfies Associations;\n\n case EnumBmEntityType.stockAdjustment:\n return {\n getRoute: (stockAdjustment) =>\n stockMenu.stockMovements.stockAdjustment.viewStockAdjustment(\n stockAdjustment.id\n ),\n getText: (stockAdjustment) =>\n $m.enum_bm_entity_type_stock_adjustment +\n \" \" +\n stockAdjustment.readOnly.adjustmentNumber,\n getValue: (stockAdjustment) => stockAdjustment.id,\n getAll: async ({ initialItemId }) => {\n const stockAdjustmentFilter = new StockAdjustmentFilter();\n stockAdjustmentFilter.fromAdjustmentDateInclusive =\n tenantService.today.minusDays(DAYS_IN_PAST);\n\n const stockAdjustments = await stockAdjustmentService\n .getFilteredStockAdjustmentHeaders(\n api.tenantId,\n stockAdjustmentFilter\n )\n .then((res) => res.stockAdjustments);\n\n if (initialItemId) {\n const stockAdjustmentIds = new GuidSet(\n stockAdjustments.map((adjustment) => adjustment.id)\n );\n\n if (!stockAdjustmentIds.has(initialItemId)) {\n const singleStockAdjustmentFilter = new StockAdjustmentFilter();\n singleStockAdjustmentFilter.limitStockAdjustmentIds = [\n initialItemId,\n ];\n\n stockAdjustments.push(\n ...(await stockAdjustmentService\n .getFilteredStockAdjustmentHeaders(\n api.tenantId,\n singleStockAdjustmentFilter\n )\n .then((res) => res.stockAdjustments))\n );\n }\n }\n\n return stockAdjustments;\n },\n } satisfies Associations;\n\n case EnumBmEntityType.batch:\n return {\n getRoute: (batch) => batchMenu.batch.viewBatch(batch.id),\n getText: (batch) => $m.enum_bm_entity_type_batch + \" \" + batch.urn,\n getValue: (batch) => batch.id,\n getAll: async ({ initialItemId }) => {\n const batchFilter = new BatchFilter();\n batchFilter.fromStartDateInclusive =\n tenantService.today.minusDays(DAYS_IN_PAST);\n\n const batchHeaders = await batchService\n .getFilteredBatchHeaders(api.tenantId, batchFilter)\n .then((res) => res.batchHeaders);\n\n if (initialItemId) {\n const batchIds = new GuidSet(\n batchHeaders.map((header) => header.id)\n );\n\n if (!batchIds.has(initialItemId)) {\n batchHeaders.push(\n await batchService.getBatchHeader(api.tenantId, initialItemId)\n );\n }\n }\n\n return batchHeaders;\n },\n } satisfies Associations;\n\n case EnumBmEntityType.batchProcessInstruction:\n return {\n getRoute: (processInstruction) =>\n batchMenu.batch.viewProcess(processInstruction.process.id),\n getText: (processInstruction) =>\n batchProcessInstructionText(processInstruction),\n getValue: (processInstruction) => processInstruction.instruction.id,\n getAll: async ({ initialItemId }) =>\n // TODO add filter endpoint\n await batchService\n .getAllProcessInstructions(api.tenantId)\n .then((instruction) => mapProcessInstructions(instruction)),\n } satisfies Associations;\n\n default:\n return null;\n }\n};\n\nconst batchProcessInstructionText = (\n processInstruction: ProcessInstructionWithParentDetails\n) => {\n if (processInstruction.batch) {\n return translateWithParams(\"batch_process_instruction_with_batch\", {\n batchName: processInstruction.batch.urn,\n processName: processInstruction.process.name,\n instruction: processInstruction.instruction.instruction,\n });\n }\n\n return translateWithParams(\"batch_process_instruction_no_batch\", {\n processName: processInstruction.process.name,\n instruction: processInstruction.instruction.instruction,\n });\n};\n\nconst fetchTaskAssociationDependencies = async (tasks: BmTask[]) => {\n const outletIds = new GuidSet();\n let outletLastOrderTimestamp = new GuidMap();\n\n const orderIds = new GuidSet();\n let orders = new GuidMap();\n\n const creditIds = new GuidSet();\n let credits = new GuidMap();\n\n const assemblyIds = new GuidSet();\n let assemblies = new GuidMap();\n\n const assemblyProcessIds = new GuidSet();\n let assemblyProcessLines = new GuidMap();\n\n const outletGroupIds = new GuidSet();\n let outletGroups = new GuidMap>();\n\n const purchaseOrderIds = new GuidSet();\n let purchaseOrders = new GuidMap();\n\n const stockItemIds = new GuidSet();\n let products = new GuidMap>();\n let materials = new GuidMap>();\n\n const leadIds = new GuidSet();\n let leads = new GuidMap();\n\n const stockTakeIds = new GuidSet();\n let stockTakes = new GuidMap();\n\n const ullageIds = new GuidSet();\n let ullages = new GuidMap();\n\n const palletIds = new GuidSet();\n let palletHeaders = new GuidMap();\n\n const stockTransferIds = new GuidSet();\n let stockTransfers = new GuidMap();\n\n const stockAdjustmentIds = new GuidSet();\n let stockAdjustments = new GuidMap();\n\n const batchIds = new GuidSet();\n let batches = new GuidMap();\n\n const processInstructionIds = new GuidSet();\n let processInstructions = new GuidMap();\n\n const cache = apiCache.buildCacheSet({\n items: ItemsCache,\n groups: GroupsCache,\n });\n\n await cache.update();\n\n // Separate out all ids to the relevant sets\n tasks.forEach((task) => {\n if (!task.associatedBmEntityType || !task.associatedBmEntityId) {\n return;\n }\n\n if (task.associatedBmEntityType === EnumBmEntityType.outlet) {\n outletIds.add(task.associatedBmEntityId);\n } else if (task.associatedBmEntityType === EnumBmEntityType.order) {\n orderIds.add(task.associatedBmEntityId);\n } else if (task.associatedBmEntityType === EnumBmEntityType.credit) {\n creditIds.add(task.associatedBmEntityId);\n } else if (task.associatedBmEntityType === EnumBmEntityType.assembly) {\n assemblyIds.add(task.associatedBmEntityId);\n } else if (\n task.associatedBmEntityType === EnumBmEntityType.assemblyProcedure\n ) {\n assemblyProcessIds.add(task.associatedBmEntityId);\n } else if (task.associatedBmEntityType === EnumBmEntityType.outletGroup) {\n outletGroupIds.add(task.associatedBmEntityId);\n } else if (task.associatedBmEntityType === EnumBmEntityType.purchaseOrder) {\n purchaseOrderIds.add(task.associatedBmEntityId);\n } else if (task.associatedBmEntityType === EnumBmEntityType.product) {\n stockItemIds.add(task.associatedBmEntityId);\n } else if (task.associatedBmEntityType === EnumBmEntityType.material) {\n stockItemIds.add(task.associatedBmEntityId);\n } else if (task.associatedBmEntityType === EnumBmEntityType.lead) {\n leadIds.add(task.associatedBmEntityId);\n } else if (task.associatedBmEntityType === EnumBmEntityType.stockTake) {\n stockTakeIds.add(task.associatedBmEntityId);\n } else if (task.associatedBmEntityType === EnumBmEntityType.ullage) {\n ullageIds.add(task.associatedBmEntityId);\n } else if (task.associatedBmEntityType === EnumBmEntityType.pallet) {\n palletIds.add(task.associatedBmEntityId);\n } else if (task.associatedBmEntityType === EnumBmEntityType.stockTransfer) {\n stockTransferIds.add(task.associatedBmEntityId);\n } else if (\n task.associatedBmEntityType === EnumBmEntityType.stockAdjustment\n ) {\n stockAdjustmentIds.add(task.associatedBmEntityId);\n } else if (task.associatedBmEntityType === EnumBmEntityType.batch) {\n batchIds.add(task.associatedBmEntityId);\n } else if (\n task.associatedBmEntityType === EnumBmEntityType.batchProcessInstruction\n ) {\n processInstructionIds.add(task.associatedBmEntityId);\n }\n });\n\n const promises: Promise[] = [];\n\n // Only if we have ids for type, push our promise to the array\n if (outletIds.size) {\n promises.push(\n orderService\n .getLastOrderTimestamps(api.tenantId, Array.from(outletIds))\n .then(\n (val) =>\n (outletLastOrderTimestamp = toGuidMap(\n val,\n (outletTimestamp) => outletTimestamp.outletId\n ))\n )\n );\n }\n\n if (orderIds.size) {\n const orderFilter = new OrderFilter();\n orderFilter.limitOrderHeaderIds = Array.from(orderIds);\n\n promises.push(\n orderService\n .getOrderSummaries(api.tenantId, orderFilter)\n .then(\n (val) =>\n (orders = new GuidMap(val.orders.map((order) => [order.id, order])))\n )\n );\n }\n if (creditIds.size) {\n const creditFilter = new CreditFilter();\n creditFilter.limitCreditIds = Array.from(creditIds);\n\n promises.push(\n creditService\n .getCreditSummaries(api.tenantId, creditFilter)\n .then(\n (val) =>\n (credits = new GuidMap(\n val.credits.map((credit) => [credit.id, credit])\n ))\n )\n );\n }\n if (assemblyIds.size) {\n promises.push(\n assemblyService\n .getAssemblyHeadersByIds(api.tenantId, Array.from(assemblyIds))\n .then(\n (val) =>\n (assemblies = new GuidMap(\n val.map((assembly) => [assembly.id, assembly])\n ))\n )\n );\n }\n if (assemblyProcessIds.size) {\n promises.push(\n assemblyService\n .getAssemblyProcessLines(api.tenantId, Array.from(assemblyProcessIds))\n .then(\n async (val) =>\n (assemblyProcessLines = new GuidMap(\n (await mapProcessLines(val)).map((x) => [x.processLineId, x])\n ))\n )\n );\n }\n if (outletGroupIds.size) {\n outletGroups = toGuidMap(cache.groups.all, (group) => group.id);\n }\n if (purchaseOrderIds.size) {\n promises.push(\n purchaseOrderService\n .getPurchaseOrders(api.tenantId, Array.from(purchaseOrderIds))\n .then(\n (val) =>\n (purchaseOrders = new GuidMap(\n val.map((po) => [po.header.id, po.header])\n ))\n )\n );\n }\n if (stockItemIds.size) {\n products = toGuidMap(\n cache.items.all.filter(\n (item) => item.details.mainPurpose === EnumItemMainPurpose.product\n ),\n (item) => item.details.id\n );\n\n materials = toGuidMap(\n cache.items.all.filter(\n (item) => item.details.mainPurpose === EnumItemMainPurpose.material\n ),\n (item) => item.details.id\n );\n }\n if (leadIds.size) {\n promises.push(\n leadService\n .getLeads(api.tenantId, Array.from(leadIds))\n .then((val) => (leads = new GuidMap(val.map((ld) => [ld.id, ld]))))\n );\n }\n if (stockTakeIds.size) {\n promises.push(\n stockTakeService\n .getStockTakeHeaders(api.tenantId, Array.from(stockTakeIds))\n .then((val) => (stockTakes = new GuidMap(val.map((st) => [st.id, st]))))\n );\n }\n if (ullageIds.size) {\n promises.push(\n ullageService\n .getUllageHeaders(api.tenantId, Array.from(ullageIds))\n .then((val) => (ullages = new GuidMap(val.map((u) => [u.id, u]))))\n );\n }\n if (palletIds.size) {\n promises.push(\n palletService.getPallets(api.tenantId, Array.from(palletIds)).then(\n (val) =>\n (palletHeaders = toGuidMap(\n // Only store headers to prevent bloat, and Vuetify \"header\" property bug\n val.map((v) => v.header),\n (p) => p.id\n ))\n )\n );\n }\n if (stockTransferIds.size) {\n promises.push(\n stockTransferService\n .getStockTransferHeaders(api.tenantId, Array.from(stockTransferIds))\n .then((val) => (stockTransfers = toGuidMap(val, (st) => st.id)))\n );\n }\n if (stockAdjustmentIds.size) {\n promises.push(\n stockAdjustmentService\n .getStockAdjustments(api.tenantId, Array.from(stockAdjustmentIds))\n .then(\n (val) =>\n (stockAdjustments = toGuidMap(\n val.map((v) => v.header),\n (sa) => sa.id\n ))\n )\n );\n }\n if (batchIds.size) {\n promises.push(\n batchService\n .getBatchHeaders(api.tenantId, Array.from(batchIds))\n .then(\n (val) =>\n (batches = new GuidMap(val.map((batch) => [batch.id, batch])))\n )\n );\n }\n if (processInstructionIds.size) {\n promises.push(\n batchService\n .getProcessInstructions(api.tenantId, Array.from(processInstructionIds))\n .then(\n async (val) =>\n (processInstructions = new GuidMap(\n (await mapProcessInstructions(val)).map((x) => [\n x.instruction.id,\n x,\n ])\n ))\n )\n );\n }\n\n // Get all dependencies together\n await Promise.all(promises);\n\n return {\n orders,\n credits,\n assemblies,\n assemblyProcessLines,\n outletGroups,\n purchaseOrders,\n products,\n materials,\n leads,\n stockTakes,\n ullages,\n outletLastOrderTimestamp,\n palletHeaders,\n stockTransfers,\n stockAdjustments,\n batches,\n processInstructions,\n };\n};\n\nexport const joinTasksWithAssociations = async (\n tasks: BmTask[]\n): Promise => {\n const cache = buildCache()\n .withOutletSummaries()\n .withSupplierManufacturers()\n .withPriceLists()\n .withVessels()\n .withGroups()\n .withItems()\n .build();\n\n const [dependencies] = await Promise.all([\n fetchTaskAssociationDependencies(tasks),\n cache.update(),\n ]);\n return tasks.map((task): TaskWithAssociations => {\n const associations = getAssociationFromType(\n task.associatedBmEntityType,\n cache\n );\n\n // If we don't have a relevant association\n if (\n !task.associatedBmEntityId ||\n !task.associatedBmEntityType ||\n !associations\n ) {\n return {\n task,\n associationName: null,\n associationRoute: null,\n };\n }\n\n const { getText, getRoute } = associations;\n\n switch (task.associatedBmEntityType) {\n case EnumBmEntityType.outlet: {\n const outletId = task.associatedBmEntityId;\n const associatedOutlet = cache.outlets.getById(outletId) ?? undefined;\n\n const associatedOutletLastOrder =\n dependencies.outletLastOrderTimestamp.get(outletId);\n return {\n task,\n associationName: getText(associatedOutlet),\n associationRoute: getRoute(associatedOutlet, task),\n associatedOutlet,\n associatedOutletLastOrder,\n };\n }\n\n case EnumBmEntityType.order: {\n const associatedOrder = dependencies.orders.get(\n task.associatedBmEntityId\n );\n return {\n task,\n associationName: getText(associatedOrder),\n associationRoute: getRoute(associatedOrder),\n associatedOrder,\n };\n }\n\n case EnumBmEntityType.credit: {\n const associatedCredit = dependencies.credits.get(\n task.associatedBmEntityId\n );\n return {\n task,\n associationName: getText(associatedCredit),\n associationRoute: getRoute(associatedCredit),\n associatedCredit,\n };\n }\n\n case EnumBmEntityType.assembly: {\n const associatedAssembly = dependencies.assemblies.get(\n task.associatedBmEntityId\n );\n return {\n task,\n associationName: getText(associatedAssembly),\n associationRoute: getRoute(associatedAssembly),\n associatedAssembly,\n };\n }\n\n case EnumBmEntityType.assemblyProcedure: {\n const associatedAssemblyProcessLine =\n dependencies.assemblyProcessLines.get(task.associatedBmEntityId);\n return {\n task,\n associationName: getText(associatedAssemblyProcessLine),\n associationRoute: getRoute(associatedAssemblyProcessLine),\n associatedAssemblyProcessLine,\n };\n }\n\n case EnumBmEntityType.supplier: {\n const associatedSupplierManufacturer =\n cache.supplierManufacturers.getById(task.associatedBmEntityId) ??\n undefined;\n return {\n task,\n associationName: getText(associatedSupplierManufacturer),\n associationRoute: getRoute(associatedSupplierManufacturer),\n associatedSupplier: associatedSupplierManufacturer,\n };\n }\n\n case EnumBmEntityType.outletGroup: {\n const associatedOutletGroup = dependencies.outletGroups.get(\n task.associatedBmEntityId\n );\n return {\n task,\n associationName: getText(associatedOutletGroup),\n associationRoute: getRoute(associatedOutletGroup),\n associatedOutletGroup,\n };\n }\n\n case EnumBmEntityType.purchaseOrder: {\n const associatedPurchaseOrder = dependencies.purchaseOrders.get(\n task.associatedBmEntityId\n );\n return {\n task,\n associationName: getText(associatedPurchaseOrder),\n associationRoute: getRoute(associatedPurchaseOrder),\n associatedPurchaseOrder,\n };\n }\n\n case EnumBmEntityType.product: {\n const associatedProduct = dependencies.products.get(\n task.associatedBmEntityId\n );\n return {\n task,\n associationName: getText(associatedProduct),\n associationRoute: getRoute(associatedProduct),\n associatedProduct,\n };\n }\n\n case EnumBmEntityType.material: {\n const associatedMaterial = dependencies.materials.get(\n task.associatedBmEntityId\n );\n return {\n task,\n associationName: getText(associatedMaterial),\n associationRoute: getRoute(associatedMaterial),\n associatedMaterial,\n };\n }\n\n case EnumBmEntityType.lead: {\n const associatedLead = dependencies.leads.get(\n task.associatedBmEntityId\n );\n return {\n task,\n associationName: getText(associatedLead),\n associationRoute: getRoute(associatedLead),\n associatedLead,\n };\n }\n\n case EnumBmEntityType.stockTake: {\n const associatedStockTake = dependencies.stockTakes.get(\n task.associatedBmEntityId\n );\n return {\n task,\n associationName: getText(associatedStockTake),\n associationRoute: getRoute(associatedStockTake),\n associatedStockTake,\n };\n }\n\n case EnumBmEntityType.ullage: {\n const associatedUllage = dependencies.ullages.get(\n task.associatedBmEntityId\n );\n return {\n task,\n associationName: getText(associatedUllage),\n associationRoute: getRoute(associatedUllage),\n associatedUllage,\n };\n }\n\n case EnumBmEntityType.priceList: {\n const associatedPriceList =\n cache.priceLists.getById(task.associatedBmEntityId) ?? undefined;\n return {\n task,\n associationName: getText(associatedPriceList),\n associationRoute: getRoute(associatedPriceList),\n associatedPriceList,\n };\n }\n\n case EnumBmEntityType.vessel: {\n const associatedVessel =\n cache.vessels.getById(task.associatedBmEntityId) ?? undefined;\n return {\n task,\n associationName: getText(associatedVessel),\n associationRoute: getRoute(associatedVessel),\n associatedVessel,\n };\n }\n\n case EnumBmEntityType.pallet: {\n const associatedPalletHeader = dependencies.palletHeaders.get(\n task.associatedBmEntityId\n );\n\n return {\n task,\n associationName: getText(associatedPalletHeader),\n associationRoute: getRoute(associatedPalletHeader),\n associatedPallet: associatedPalletHeader,\n };\n }\n\n case EnumBmEntityType.stockTransfer: {\n const associatedStockTransfer = dependencies.stockTransfers.get(\n task.associatedBmEntityId\n );\n return {\n task,\n associationName: getText(associatedStockTransfer),\n associationRoute: getRoute(associatedStockTransfer),\n associatedStockTransfer,\n };\n }\n\n case EnumBmEntityType.stockAdjustment: {\n const associatedStockAdjustment = dependencies.stockAdjustments.get(\n task.associatedBmEntityId\n );\n return {\n task,\n associationName: getText(associatedStockAdjustment),\n associationRoute: getRoute(associatedStockAdjustment),\n associatedStockAdjustment,\n };\n }\n\n case EnumBmEntityType.batch: {\n const associatedBatch = dependencies.batches.get(\n task.associatedBmEntityId\n );\n return {\n task,\n associationName: getText(associatedBatch),\n associationRoute: getRoute(associatedBatch),\n associatedBatch,\n };\n }\n\n case EnumBmEntityType.batchProcessInstruction: {\n const associatedProcessInstruction =\n dependencies.processInstructions.get(task.associatedBmEntityId);\n return {\n task,\n associationName: getText(associatedProcessInstruction),\n associationRoute: getRoute(associatedProcessInstruction),\n associatedBatchProcessInstruction: associatedProcessInstruction,\n };\n }\n\n default:\n return {\n task,\n associationName: null,\n associationRoute: null,\n };\n }\n });\n};\n","/**\n * This method returns the first argument it receives.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {*} value Any value.\n * @returns {*} Returns `value`.\n * @example\n *\n * var object = { 'a': 1 };\n *\n * console.log(_.identity(object) === object);\n * // => true\n */\nfunction identity(value) {\n return value;\n}\n\nexport default identity;\n","import isObject from './isObject.js';\n\n/** Built-in value references. */\nvar objectCreate = Object.create;\n\n/**\n * The base implementation of `_.create` without support for assigning\n * properties to the created object.\n *\n * @private\n * @param {Object} proto The object to inherit from.\n * @returns {Object} Returns the new object.\n */\nvar baseCreate = (function() {\n function object() {}\n return function(proto) {\n if (!isObject(proto)) {\n return {};\n }\n if (objectCreate) {\n return objectCreate(proto);\n }\n object.prototype = proto;\n var result = new object;\n object.prototype = undefined;\n return result;\n };\n}());\n\nexport default baseCreate;\n","/**\n * Copies the values of `source` to `array`.\n *\n * @private\n * @param {Array} source The array to copy values from.\n * @param {Array} [array=[]] The array to copy values to.\n * @returns {Array} Returns `array`.\n */\nfunction copyArray(source, array) {\n var index = -1,\n length = source.length;\n\n array || (array = Array(length));\n while (++index < length) {\n array[index] = source[index];\n }\n return array;\n}\n\nexport default copyArray;\n","import getNative from './_getNative.js';\n\nvar defineProperty = (function() {\n try {\n var func = getNative(Object, 'defineProperty');\n func({}, '', {});\n return func;\n } catch (e) {}\n}());\n\nexport default defineProperty;\n","/**\n * A specialized version of `_.forEach` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\nfunction arrayEach(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (iteratee(array[index], index, array) === false) {\n break;\n }\n }\n return array;\n}\n\nexport default arrayEach;\n","import defineProperty from './_defineProperty.js';\n\n/**\n * The base implementation of `assignValue` and `assignMergeValue` without\n * value checks.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction baseAssignValue(object, key, value) {\n if (key == '__proto__' && defineProperty) {\n defineProperty(object, key, {\n 'configurable': true,\n 'enumerable': true,\n 'value': value,\n 'writable': true\n });\n } else {\n object[key] = value;\n }\n}\n\nexport default baseAssignValue;\n","import baseAssignValue from './_baseAssignValue.js';\nimport eq from './eq.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Assigns `value` to `key` of `object` if the existing value is not equivalent\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignValue(object, key, value) {\n var objValue = object[key];\n if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||\n (value === undefined && !(key in object))) {\n baseAssignValue(object, key, value);\n }\n}\n\nexport default assignValue;\n","import assignValue from './_assignValue.js';\nimport baseAssignValue from './_baseAssignValue.js';\n\n/**\n * Copies properties of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy properties from.\n * @param {Array} props The property identifiers to copy.\n * @param {Object} [object={}] The object to copy properties to.\n * @param {Function} [customizer] The function to customize copied values.\n * @returns {Object} Returns `object`.\n */\nfunction copyObject(source, props, object, customizer) {\n var isNew = !object;\n object || (object = {});\n\n var index = -1,\n length = props.length;\n\n while (++index < length) {\n var key = props[index];\n\n var newValue = customizer\n ? customizer(object[key], source[key], key, object, source)\n : undefined;\n\n if (newValue === undefined) {\n newValue = source[key];\n }\n if (isNew) {\n baseAssignValue(object, key, newValue);\n } else {\n assignValue(object, key, newValue);\n }\n }\n return object;\n}\n\nexport default copyObject;\n","/**\n * This function is like\n * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * except that it includes inherited enumerable properties.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction nativeKeysIn(object) {\n var result = [];\n if (object != null) {\n for (var key in Object(object)) {\n result.push(key);\n }\n }\n return result;\n}\n\nexport default nativeKeysIn;\n","import isObject from './isObject.js';\nimport isPrototype from './_isPrototype.js';\nimport nativeKeysIn from './_nativeKeysIn.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeysIn(object) {\n if (!isObject(object)) {\n return nativeKeysIn(object);\n }\n var isProto = isPrototype(object),\n result = [];\n\n for (var key in object) {\n if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\n result.push(key);\n }\n }\n return result;\n}\n\nexport default baseKeysIn;\n","import arrayLikeKeys from './_arrayLikeKeys.js';\nimport baseKeysIn from './_baseKeysIn.js';\nimport isArrayLike from './isArrayLike.js';\n\n/**\n * Creates an array of the own and inherited enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keysIn(new Foo);\n * // => ['a', 'b', 'c'] (iteration order is not guaranteed)\n */\nfunction keysIn(object) {\n return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);\n}\n\nexport default keysIn;\n","import overArg from './_overArg.js';\n\n/** Built-in value references. */\nvar getPrototype = overArg(Object.getPrototypeOf, Object);\n\nexport default getPrototype;\n","import copyObject from './_copyObject.js';\nimport keys from './keys.js';\n\n/**\n * The base implementation of `_.assign` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\nfunction baseAssign(object, source) {\n return object && copyObject(source, keys(source), object);\n}\n\nexport default baseAssign;\n","import copyObject from './_copyObject.js';\nimport keysIn from './keysIn.js';\n\n/**\n * The base implementation of `_.assignIn` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\nfunction baseAssignIn(object, source) {\n return object && copyObject(source, keysIn(source), object);\n}\n\nexport default baseAssignIn;\n","import root from './_root.js';\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined;\n\n/**\n * Creates a clone of `buffer`.\n *\n * @private\n * @param {Buffer} buffer The buffer to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Buffer} Returns the cloned buffer.\n */\nfunction cloneBuffer(buffer, isDeep) {\n if (isDeep) {\n return buffer.slice();\n }\n var length = buffer.length,\n result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length);\n\n buffer.copy(result);\n return result;\n}\n\nexport default cloneBuffer;\n","import copyObject from './_copyObject.js';\nimport getSymbols from './_getSymbols.js';\n\n/**\n * Copies own symbols of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\nfunction copySymbols(source, object) {\n return copyObject(source, getSymbols(source), object);\n}\n\nexport default copySymbols;\n","import arrayPush from './_arrayPush.js';\nimport getPrototype from './_getPrototype.js';\nimport getSymbols from './_getSymbols.js';\nimport stubArray from './stubArray.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own and inherited enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbolsIn = !nativeGetSymbols ? stubArray : function(object) {\n var result = [];\n while (object) {\n arrayPush(result, getSymbols(object));\n object = getPrototype(object);\n }\n return result;\n};\n\nexport default getSymbolsIn;\n","import copyObject from './_copyObject.js';\nimport getSymbolsIn from './_getSymbolsIn.js';\n\n/**\n * Copies own and inherited symbols of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\nfunction copySymbolsIn(source, object) {\n return copyObject(source, getSymbolsIn(source), object);\n}\n\nexport default copySymbolsIn;\n","import baseGetAllKeys from './_baseGetAllKeys.js';\nimport getSymbolsIn from './_getSymbolsIn.js';\nimport keysIn from './keysIn.js';\n\n/**\n * Creates an array of own and inherited enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeysIn(object) {\n return baseGetAllKeys(object, keysIn, getSymbolsIn);\n}\n\nexport default getAllKeysIn;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Initializes an array clone.\n *\n * @private\n * @param {Array} array The array to clone.\n * @returns {Array} Returns the initialized clone.\n */\nfunction initCloneArray(array) {\n var length = array.length,\n result = new array.constructor(length);\n\n // Add properties assigned by `RegExp#exec`.\n if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) {\n result.index = array.index;\n result.input = array.input;\n }\n return result;\n}\n\nexport default initCloneArray;\n","import Uint8Array from './_Uint8Array.js';\n\n/**\n * Creates a clone of `arrayBuffer`.\n *\n * @private\n * @param {ArrayBuffer} arrayBuffer The array buffer to clone.\n * @returns {ArrayBuffer} Returns the cloned array buffer.\n */\nfunction cloneArrayBuffer(arrayBuffer) {\n var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\n new Uint8Array(result).set(new Uint8Array(arrayBuffer));\n return result;\n}\n\nexport default cloneArrayBuffer;\n","import cloneArrayBuffer from './_cloneArrayBuffer.js';\n\n/**\n * Creates a clone of `dataView`.\n *\n * @private\n * @param {Object} dataView The data view to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned data view.\n */\nfunction cloneDataView(dataView, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer;\n return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);\n}\n\nexport default cloneDataView;\n","/** Used to match `RegExp` flags from their coerced string values. */\nvar reFlags = /\\w*$/;\n\n/**\n * Creates a clone of `regexp`.\n *\n * @private\n * @param {Object} regexp The regexp to clone.\n * @returns {Object} Returns the cloned regexp.\n */\nfunction cloneRegExp(regexp) {\n var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));\n result.lastIndex = regexp.lastIndex;\n return result;\n}\n\nexport default cloneRegExp;\n","import Symbol from './_Symbol.js';\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a clone of the `symbol` object.\n *\n * @private\n * @param {Object} symbol The symbol object to clone.\n * @returns {Object} Returns the cloned symbol object.\n */\nfunction cloneSymbol(symbol) {\n return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};\n}\n\nexport default cloneSymbol;\n","import cloneArrayBuffer from './_cloneArrayBuffer.js';\n\n/**\n * Creates a clone of `typedArray`.\n *\n * @private\n * @param {Object} typedArray The typed array to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned typed array.\n */\nfunction cloneTypedArray(typedArray, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n}\n\nexport default cloneTypedArray;\n","import cloneArrayBuffer from './_cloneArrayBuffer.js';\nimport cloneDataView from './_cloneDataView.js';\nimport cloneRegExp from './_cloneRegExp.js';\nimport cloneSymbol from './_cloneSymbol.js';\nimport cloneTypedArray from './_cloneTypedArray.js';\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/**\n * Initializes an object clone based on its `toStringTag`.\n *\n * **Note:** This function only supports cloning values with tags of\n * `Boolean`, `Date`, `Error`, `Map`, `Number`, `RegExp`, `Set`, or `String`.\n *\n * @private\n * @param {Object} object The object to clone.\n * @param {string} tag The `toStringTag` of the object to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneByTag(object, tag, isDeep) {\n var Ctor = object.constructor;\n switch (tag) {\n case arrayBufferTag:\n return cloneArrayBuffer(object);\n\n case boolTag:\n case dateTag:\n return new Ctor(+object);\n\n case dataViewTag:\n return cloneDataView(object, isDeep);\n\n case float32Tag: case float64Tag:\n case int8Tag: case int16Tag: case int32Tag:\n case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag:\n return cloneTypedArray(object, isDeep);\n\n case mapTag:\n return new Ctor;\n\n case numberTag:\n case stringTag:\n return new Ctor(object);\n\n case regexpTag:\n return cloneRegExp(object);\n\n case setTag:\n return new Ctor;\n\n case symbolTag:\n return cloneSymbol(object);\n }\n}\n\nexport default initCloneByTag;\n","import baseCreate from './_baseCreate.js';\nimport getPrototype from './_getPrototype.js';\nimport isPrototype from './_isPrototype.js';\n\n/**\n * Initializes an object clone.\n *\n * @private\n * @param {Object} object The object to clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneObject(object) {\n return (typeof object.constructor == 'function' && !isPrototype(object))\n ? baseCreate(getPrototype(object))\n : {};\n}\n\nexport default initCloneObject;\n","import getTag from './_getTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]';\n\n/**\n * The base implementation of `_.isMap` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n */\nfunction baseIsMap(value) {\n return isObjectLike(value) && getTag(value) == mapTag;\n}\n\nexport default baseIsMap;\n","import baseIsMap from './_baseIsMap.js';\nimport baseUnary from './_baseUnary.js';\nimport nodeUtil from './_nodeUtil.js';\n\n/* Node.js helper references. */\nvar nodeIsMap = nodeUtil && nodeUtil.isMap;\n\n/**\n * Checks if `value` is classified as a `Map` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n * @example\n *\n * _.isMap(new Map);\n * // => true\n *\n * _.isMap(new WeakMap);\n * // => false\n */\nvar isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap;\n\nexport default isMap;\n","import getTag from './_getTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar setTag = '[object Set]';\n\n/**\n * The base implementation of `_.isSet` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n */\nfunction baseIsSet(value) {\n return isObjectLike(value) && getTag(value) == setTag;\n}\n\nexport default baseIsSet;\n","import baseIsSet from './_baseIsSet.js';\nimport baseUnary from './_baseUnary.js';\nimport nodeUtil from './_nodeUtil.js';\n\n/* Node.js helper references. */\nvar nodeIsSet = nodeUtil && nodeUtil.isSet;\n\n/**\n * Checks if `value` is classified as a `Set` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n * @example\n *\n * _.isSet(new Set);\n * // => true\n *\n * _.isSet(new WeakSet);\n * // => false\n */\nvar isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet;\n\nexport default isSet;\n","import Stack from './_Stack.js';\nimport arrayEach from './_arrayEach.js';\nimport assignValue from './_assignValue.js';\nimport baseAssign from './_baseAssign.js';\nimport baseAssignIn from './_baseAssignIn.js';\nimport cloneBuffer from './_cloneBuffer.js';\nimport copyArray from './_copyArray.js';\nimport copySymbols from './_copySymbols.js';\nimport copySymbolsIn from './_copySymbolsIn.js';\nimport getAllKeys from './_getAllKeys.js';\nimport getAllKeysIn from './_getAllKeysIn.js';\nimport getTag from './_getTag.js';\nimport initCloneArray from './_initCloneArray.js';\nimport initCloneByTag from './_initCloneByTag.js';\nimport initCloneObject from './_initCloneObject.js';\nimport isArray from './isArray.js';\nimport isBuffer from './isBuffer.js';\nimport isMap from './isMap.js';\nimport isObject from './isObject.js';\nimport isSet from './isSet.js';\nimport keys from './keys.js';\nimport keysIn from './keysIn.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n CLONE_FLAT_FLAG = 2,\n CLONE_SYMBOLS_FLAG = 4;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n objectTag = '[object Object]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values supported by `_.clone`. */\nvar cloneableTags = {};\ncloneableTags[argsTag] = cloneableTags[arrayTag] =\ncloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] =\ncloneableTags[boolTag] = cloneableTags[dateTag] =\ncloneableTags[float32Tag] = cloneableTags[float64Tag] =\ncloneableTags[int8Tag] = cloneableTags[int16Tag] =\ncloneableTags[int32Tag] = cloneableTags[mapTag] =\ncloneableTags[numberTag] = cloneableTags[objectTag] =\ncloneableTags[regexpTag] = cloneableTags[setTag] =\ncloneableTags[stringTag] = cloneableTags[symbolTag] =\ncloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =\ncloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;\ncloneableTags[errorTag] = cloneableTags[funcTag] =\ncloneableTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.clone` and `_.cloneDeep` which tracks\n * traversed objects.\n *\n * @private\n * @param {*} value The value to clone.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Deep clone\n * 2 - Flatten inherited properties\n * 4 - Clone symbols\n * @param {Function} [customizer] The function to customize cloning.\n * @param {string} [key] The key of `value`.\n * @param {Object} [object] The parent object of `value`.\n * @param {Object} [stack] Tracks traversed objects and their clone counterparts.\n * @returns {*} Returns the cloned value.\n */\nfunction baseClone(value, bitmask, customizer, key, object, stack) {\n var result,\n isDeep = bitmask & CLONE_DEEP_FLAG,\n isFlat = bitmask & CLONE_FLAT_FLAG,\n isFull = bitmask & CLONE_SYMBOLS_FLAG;\n\n if (customizer) {\n result = object ? customizer(value, key, object, stack) : customizer(value);\n }\n if (result !== undefined) {\n return result;\n }\n if (!isObject(value)) {\n return value;\n }\n var isArr = isArray(value);\n if (isArr) {\n result = initCloneArray(value);\n if (!isDeep) {\n return copyArray(value, result);\n }\n } else {\n var tag = getTag(value),\n isFunc = tag == funcTag || tag == genTag;\n\n if (isBuffer(value)) {\n return cloneBuffer(value, isDeep);\n }\n if (tag == objectTag || tag == argsTag || (isFunc && !object)) {\n result = (isFlat || isFunc) ? {} : initCloneObject(value);\n if (!isDeep) {\n return isFlat\n ? copySymbolsIn(value, baseAssignIn(result, value))\n : copySymbols(value, baseAssign(result, value));\n }\n } else {\n if (!cloneableTags[tag]) {\n return object ? value : {};\n }\n result = initCloneByTag(value, tag, isDeep);\n }\n }\n // Check for circular references and return its corresponding clone.\n stack || (stack = new Stack);\n var stacked = stack.get(value);\n if (stacked) {\n return stacked;\n }\n stack.set(value, result);\n\n if (isSet(value)) {\n value.forEach(function(subValue) {\n result.add(baseClone(subValue, bitmask, customizer, subValue, value, stack));\n });\n } else if (isMap(value)) {\n value.forEach(function(subValue, key) {\n result.set(key, baseClone(subValue, bitmask, customizer, key, value, stack));\n });\n }\n\n var keysFunc = isFull\n ? (isFlat ? getAllKeysIn : getAllKeys)\n : (isFlat ? keysIn : keys);\n\n var props = isArr ? undefined : keysFunc(value);\n arrayEach(props || value, function(subValue, key) {\n if (props) {\n key = subValue;\n subValue = value[key];\n }\n // Recursively populate clone (susceptible to call stack limits).\n assignValue(result, key, baseClone(subValue, bitmask, customizer, key, value, stack));\n });\n return result;\n}\n\nexport default baseClone;\n","import baseClone from './_baseClone.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n CLONE_SYMBOLS_FLAG = 4;\n\n/**\n * This method is like `_.clone` except that it recursively clones `value`.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Lang\n * @param {*} value The value to recursively clone.\n * @returns {*} Returns the deep cloned value.\n * @see _.clone\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var deep = _.cloneDeep(objects);\n * console.log(deep[0] === objects[0]);\n * // => false\n */\nfunction cloneDeep(value) {\n return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG);\n}\n\nexport default cloneDeep;\n","import baseClone from './_baseClone.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n CLONE_SYMBOLS_FLAG = 4;\n\n/**\n * This method is like `_.cloneWith` except that it recursively clones `value`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to recursively clone.\n * @param {Function} [customizer] The function to customize cloning.\n * @returns {*} Returns the deep cloned value.\n * @see _.cloneWith\n * @example\n *\n * function customizer(value) {\n * if (_.isElement(value)) {\n * return value.cloneNode(true);\n * }\n * }\n *\n * var el = _.cloneDeepWith(document.body, customizer);\n *\n * console.log(el === document.body);\n * // => false\n * console.log(el.nodeName);\n * // => 'BODY'\n * console.log(el.childNodes.length);\n * // => 20\n */\nfunction cloneDeepWith(value, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG, customizer);\n}\n\nexport default cloneDeepWith;\n","import Stack from './_Stack.js';\nimport baseIsEqual from './_baseIsEqual.js';\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * The base implementation of `_.isMatch` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @param {Array} matchData The property names, values, and compare flags to match.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n */\nfunction baseIsMatch(object, source, matchData, customizer) {\n var index = matchData.length,\n length = index,\n noCustomizer = !customizer;\n\n if (object == null) {\n return !length;\n }\n object = Object(object);\n while (index--) {\n var data = matchData[index];\n if ((noCustomizer && data[2])\n ? data[1] !== object[data[0]]\n : !(data[0] in object)\n ) {\n return false;\n }\n }\n while (++index < length) {\n data = matchData[index];\n var key = data[0],\n objValue = object[key],\n srcValue = data[1];\n\n if (noCustomizer && data[2]) {\n if (objValue === undefined && !(key in object)) {\n return false;\n }\n } else {\n var stack = new Stack;\n if (customizer) {\n var result = customizer(objValue, srcValue, key, object, source, stack);\n }\n if (!(result === undefined\n ? baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG, customizer, stack)\n : result\n )) {\n return false;\n }\n }\n }\n return true;\n}\n\nexport default baseIsMatch;\n","import isObject from './isObject.js';\n\n/**\n * Checks if `value` is suitable for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` if suitable for strict\n * equality comparisons, else `false`.\n */\nfunction isStrictComparable(value) {\n return value === value && !isObject(value);\n}\n\nexport default isStrictComparable;\n","import isStrictComparable from './_isStrictComparable.js';\nimport keys from './keys.js';\n\n/**\n * Gets the property names, values, and compare flags of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the match data of `object`.\n */\nfunction getMatchData(object) {\n var result = keys(object),\n length = result.length;\n\n while (length--) {\n var key = result[length],\n value = object[key];\n\n result[length] = [key, value, isStrictComparable(value)];\n }\n return result;\n}\n\nexport default getMatchData;\n","/**\n * A specialized version of `matchesProperty` for source values suitable\n * for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction matchesStrictComparable(key, srcValue) {\n return function(object) {\n if (object == null) {\n return false;\n }\n return object[key] === srcValue &&\n (srcValue !== undefined || (key in Object(object)));\n };\n}\n\nexport default matchesStrictComparable;\n","import baseIsMatch from './_baseIsMatch.js';\nimport getMatchData from './_getMatchData.js';\nimport matchesStrictComparable from './_matchesStrictComparable.js';\n\n/**\n * The base implementation of `_.matches` which doesn't clone `source`.\n *\n * @private\n * @param {Object} source The object of property values to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction baseMatches(source) {\n var matchData = getMatchData(source);\n if (matchData.length == 1 && matchData[0][2]) {\n return matchesStrictComparable(matchData[0][0], matchData[0][1]);\n }\n return function(object) {\n return object === source || baseIsMatch(object, source, matchData);\n };\n}\n\nexport default baseMatches;\n","/**\n * The base implementation of `_.hasIn` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\nfunction baseHasIn(object, key) {\n return object != null && key in Object(object);\n}\n\nexport default baseHasIn;\n","import castPath from './_castPath.js';\nimport isArguments from './isArguments.js';\nimport isArray from './isArray.js';\nimport isIndex from './_isIndex.js';\nimport isLength from './isLength.js';\nimport toKey from './_toKey.js';\n\n/**\n * Checks if `path` exists on `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @param {Function} hasFunc The function to check properties.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n */\nfunction hasPath(object, path, hasFunc) {\n path = castPath(path, object);\n\n var index = -1,\n length = path.length,\n result = false;\n\n while (++index < length) {\n var key = toKey(path[index]);\n if (!(result = object != null && hasFunc(object, key))) {\n break;\n }\n object = object[key];\n }\n if (result || ++index != length) {\n return result;\n }\n length = object == null ? 0 : object.length;\n return !!length && isLength(length) && isIndex(key, length) &&\n (isArray(object) || isArguments(object));\n}\n\nexport default hasPath;\n","import baseHasIn from './_baseHasIn.js';\nimport hasPath from './_hasPath.js';\n\n/**\n * Checks if `path` is a direct or inherited property of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.hasIn(object, 'a');\n * // => true\n *\n * _.hasIn(object, 'a.b');\n * // => true\n *\n * _.hasIn(object, ['a', 'b']);\n * // => true\n *\n * _.hasIn(object, 'b');\n * // => false\n */\nfunction hasIn(object, path) {\n return object != null && hasPath(object, path, baseHasIn);\n}\n\nexport default hasIn;\n","import baseIsEqual from './_baseIsEqual.js';\nimport get from './get.js';\nimport hasIn from './hasIn.js';\nimport isKey from './_isKey.js';\nimport isStrictComparable from './_isStrictComparable.js';\nimport matchesStrictComparable from './_matchesStrictComparable.js';\nimport toKey from './_toKey.js';\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/**\n * The base implementation of `_.matchesProperty` which doesn't clone `srcValue`.\n *\n * @private\n * @param {string} path The path of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\nfunction baseMatchesProperty(path, srcValue) {\n if (isKey(path) && isStrictComparable(srcValue)) {\n return matchesStrictComparable(toKey(path), srcValue);\n }\n return function(object) {\n var objValue = get(object, path);\n return (objValue === undefined && objValue === srcValue)\n ? hasIn(object, path)\n : baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG);\n };\n}\n\nexport default baseMatchesProperty;\n","import baseGet from './_baseGet.js';\n\n/**\n * A specialized version of `baseProperty` which supports deep paths.\n *\n * @private\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\nfunction basePropertyDeep(path) {\n return function(object) {\n return baseGet(object, path);\n };\n}\n\nexport default basePropertyDeep;\n","import baseProperty from './_baseProperty.js';\nimport basePropertyDeep from './_basePropertyDeep.js';\nimport isKey from './_isKey.js';\nimport toKey from './_toKey.js';\n\n/**\n * Creates a function that returns the value at `path` of a given object.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Util\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new accessor function.\n * @example\n *\n * var objects = [\n * { 'a': { 'b': 2 } },\n * { 'a': { 'b': 1 } }\n * ];\n *\n * _.map(objects, _.property('a.b'));\n * // => [2, 1]\n *\n * _.map(_.sortBy(objects, _.property(['a', 'b'])), 'a.b');\n * // => [1, 2]\n */\nfunction property(path) {\n return isKey(path) ? baseProperty(toKey(path)) : basePropertyDeep(path);\n}\n\nexport default property;\n","import baseMatches from './_baseMatches.js';\nimport baseMatchesProperty from './_baseMatchesProperty.js';\nimport identity from './identity.js';\nimport isArray from './isArray.js';\nimport property from './property.js';\n\n/**\n * The base implementation of `_.iteratee`.\n *\n * @private\n * @param {*} [value=_.identity] The value to convert to an iteratee.\n * @returns {Function} Returns the iteratee.\n */\nfunction baseIteratee(value) {\n // Don't store the `typeof` result in a variable to avoid a JIT bug in Safari 9.\n // See https://bugs.webkit.org/show_bug.cgi?id=156034 for more details.\n if (typeof value == 'function') {\n return value;\n }\n if (value == null) {\n return identity;\n }\n if (typeof value == 'object') {\n return isArray(value)\n ? baseMatchesProperty(value[0], value[1])\n : baseMatches(value);\n }\n return property(value);\n}\n\nexport default baseIteratee;\n","/**\n * A specialized version of `baseAggregator` for arrays.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform keys.\n * @param {Object} accumulator The initial aggregated object.\n * @returns {Function} Returns `accumulator`.\n */\nfunction arrayAggregator(array, setter, iteratee, accumulator) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n var value = array[index];\n setter(accumulator, value, iteratee(value), array);\n }\n return accumulator;\n}\n\nexport default arrayAggregator;\n","/**\n * Creates a base function for methods like `_.forIn` and `_.forOwn`.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseFor(fromRight) {\n return function(object, iteratee, keysFunc) {\n var index = -1,\n iterable = Object(object),\n props = keysFunc(object),\n length = props.length;\n\n while (length--) {\n var key = props[fromRight ? length : ++index];\n if (iteratee(iterable[key], key, iterable) === false) {\n break;\n }\n }\n return object;\n };\n}\n\nexport default createBaseFor;\n","import createBaseFor from './_createBaseFor.js';\n\n/**\n * The base implementation of `baseForOwn` which iterates over `object`\n * properties returned by `keysFunc` and invokes `iteratee` for each property.\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\nvar baseFor = createBaseFor();\n\nexport default baseFor;\n","import baseFor from './_baseFor.js';\nimport keys from './keys.js';\n\n/**\n * The base implementation of `_.forOwn` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\nfunction baseForOwn(object, iteratee) {\n return object && baseFor(object, iteratee, keys);\n}\n\nexport default baseForOwn;\n","import isArrayLike from './isArrayLike.js';\n\n/**\n * Creates a `baseEach` or `baseEachRight` function.\n *\n * @private\n * @param {Function} eachFunc The function to iterate over a collection.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\nfunction createBaseEach(eachFunc, fromRight) {\n return function(collection, iteratee) {\n if (collection == null) {\n return collection;\n }\n if (!isArrayLike(collection)) {\n return eachFunc(collection, iteratee);\n }\n var length = collection.length,\n index = fromRight ? length : -1,\n iterable = Object(collection);\n\n while ((fromRight ? index-- : ++index < length)) {\n if (iteratee(iterable[index], index, iterable) === false) {\n break;\n }\n }\n return collection;\n };\n}\n\nexport default createBaseEach;\n","import baseForOwn from './_baseForOwn.js';\nimport createBaseEach from './_createBaseEach.js';\n\n/**\n * The base implementation of `_.forEach` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n */\nvar baseEach = createBaseEach(baseForOwn);\n\nexport default baseEach;\n","import baseEach from './_baseEach.js';\n\n/**\n * Aggregates elements of `collection` on `accumulator` with keys transformed\n * by `iteratee` and values set by `setter`.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform keys.\n * @param {Object} accumulator The initial aggregated object.\n * @returns {Function} Returns `accumulator`.\n */\nfunction baseAggregator(collection, setter, iteratee, accumulator) {\n baseEach(collection, function(value, key, collection) {\n setter(accumulator, value, iteratee(value), collection);\n });\n return accumulator;\n}\n\nexport default baseAggregator;\n","import arrayAggregator from './_arrayAggregator.js';\nimport baseAggregator from './_baseAggregator.js';\nimport baseIteratee from './_baseIteratee.js';\nimport isArray from './isArray.js';\n\n/**\n * Creates a function like `_.groupBy`.\n *\n * @private\n * @param {Function} setter The function to set accumulator values.\n * @param {Function} [initializer] The accumulator object initializer.\n * @returns {Function} Returns the new aggregator function.\n */\nfunction createAggregator(setter, initializer) {\n return function(collection, iteratee) {\n var func = isArray(collection) ? arrayAggregator : baseAggregator,\n accumulator = initializer ? initializer() : {};\n\n return func(collection, setter, baseIteratee(iteratee, 2), accumulator);\n };\n}\n\nexport default createAggregator;\n","import root from './_root.js';\n\n/**\n * Gets the timestamp of the number of milliseconds that have elapsed since\n * the Unix epoch (1 January 1970 00:00:00 UTC).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Date\n * @returns {number} Returns the timestamp.\n * @example\n *\n * _.defer(function(stamp) {\n * console.log(_.now() - stamp);\n * }, _.now());\n * // => Logs the number of milliseconds it took for the deferred invocation.\n */\nvar now = function() {\n return root.Date.now();\n};\n\nexport default now;\n","import isObject from './isObject.js';\nimport now from './now.js';\nimport toNumber from './toNumber.js';\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max,\n nativeMin = Math.min;\n\n/**\n * Creates a debounced function that delays invoking `func` until after `wait`\n * milliseconds have elapsed since the last time the debounced function was\n * invoked. The debounced function comes with a `cancel` method to cancel\n * delayed `func` invocations and a `flush` method to immediately invoke them.\n * Provide `options` to indicate whether `func` should be invoked on the\n * leading and/or trailing edge of the `wait` timeout. The `func` is invoked\n * with the last arguments provided to the debounced function. Subsequent\n * calls to the debounced function return the result of the last `func`\n * invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the debounced function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.debounce` and `_.throttle`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to debounce.\n * @param {number} [wait=0] The number of milliseconds to delay.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=false]\n * Specify invoking on the leading edge of the timeout.\n * @param {number} [options.maxWait]\n * The maximum time `func` is allowed to be delayed before it's invoked.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new debounced function.\n * @example\n *\n * // Avoid costly calculations while the window size is in flux.\n * jQuery(window).on('resize', _.debounce(calculateLayout, 150));\n *\n * // Invoke `sendMail` when clicked, debouncing subsequent calls.\n * jQuery(element).on('click', _.debounce(sendMail, 300, {\n * 'leading': true,\n * 'trailing': false\n * }));\n *\n * // Ensure `batchLog` is invoked once after 1 second of debounced calls.\n * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });\n * var source = new EventSource('/stream');\n * jQuery(source).on('message', debounced);\n *\n * // Cancel the trailing debounced invocation.\n * jQuery(window).on('popstate', debounced.cancel);\n */\nfunction debounce(func, wait, options) {\n var lastArgs,\n lastThis,\n maxWait,\n result,\n timerId,\n lastCallTime,\n lastInvokeTime = 0,\n leading = false,\n maxing = false,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n wait = toNumber(wait) || 0;\n if (isObject(options)) {\n leading = !!options.leading;\n maxing = 'maxWait' in options;\n maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n\n function invokeFunc(time) {\n var args = lastArgs,\n thisArg = lastThis;\n\n lastArgs = lastThis = undefined;\n lastInvokeTime = time;\n result = func.apply(thisArg, args);\n return result;\n }\n\n function leadingEdge(time) {\n // Reset any `maxWait` timer.\n lastInvokeTime = time;\n // Start the timer for the trailing edge.\n timerId = setTimeout(timerExpired, wait);\n // Invoke the leading edge.\n return leading ? invokeFunc(time) : result;\n }\n\n function remainingWait(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime,\n timeWaiting = wait - timeSinceLastCall;\n\n return maxing\n ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke)\n : timeWaiting;\n }\n\n function shouldInvoke(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime;\n\n // Either this is the first call, activity has stopped and we're at the\n // trailing edge, the system time has gone backwards and we're treating\n // it as the trailing edge, or we've hit the `maxWait` limit.\n return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||\n (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));\n }\n\n function timerExpired() {\n var time = now();\n if (shouldInvoke(time)) {\n return trailingEdge(time);\n }\n // Restart the timer.\n timerId = setTimeout(timerExpired, remainingWait(time));\n }\n\n function trailingEdge(time) {\n timerId = undefined;\n\n // Only invoke if we have `lastArgs` which means `func` has been\n // debounced at least once.\n if (trailing && lastArgs) {\n return invokeFunc(time);\n }\n lastArgs = lastThis = undefined;\n return result;\n }\n\n function cancel() {\n if (timerId !== undefined) {\n clearTimeout(timerId);\n }\n lastInvokeTime = 0;\n lastArgs = lastCallTime = lastThis = timerId = undefined;\n }\n\n function flush() {\n return timerId === undefined ? result : trailingEdge(now());\n }\n\n function debounced() {\n var time = now(),\n isInvoking = shouldInvoke(time);\n\n lastArgs = arguments;\n lastThis = this;\n lastCallTime = time;\n\n if (isInvoking) {\n if (timerId === undefined) {\n return leadingEdge(lastCallTime);\n }\n if (maxing) {\n // Handle invocations in a tight loop.\n clearTimeout(timerId);\n timerId = setTimeout(timerExpired, wait);\n return invokeFunc(lastCallTime);\n }\n }\n if (timerId === undefined) {\n timerId = setTimeout(timerExpired, wait);\n }\n return result;\n }\n debounced.cancel = cancel;\n debounced.flush = flush;\n return debounced;\n}\n\nexport default debounce;\n","import baseAssignValue from './_baseAssignValue.js';\nimport createAggregator from './_createAggregator.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates an object composed of keys generated from the results of running\n * each element of `collection` thru `iteratee`. The order of grouped values\n * is determined by the order they occur in `collection`. The corresponding\n * value of each key is an array of elements responsible for generating the\n * key. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\n * @returns {Object} Returns the composed aggregate object.\n * @example\n *\n * _.groupBy([6.1, 4.2, 6.3], Math.floor);\n * // => { '4': [4.2], '6': [6.1, 6.3] }\n *\n * // The `_.property` iteratee shorthand.\n * _.groupBy(['one', 'two', 'three'], 'length');\n * // => { '3': ['one', 'two'], '5': ['three'] }\n */\nvar groupBy = createAggregator(function(result, value, key) {\n if (hasOwnProperty.call(result, key)) {\n result[key].push(value);\n } else {\n baseAssignValue(result, key, [value]);\n }\n});\n\nexport default groupBy;\n","import { translate } from \"@/plugins/i18n\";\nimport { isEnum } from \"@/app/services/baseEnumType\";\nimport { LocalDate, Instant } from \"@js-joda/core\";\nimport { tenantService } from \"@/app/services/extensions/tenantServiceExtended\";\nimport type Guid from \"@/app/types/common/guid\";\nimport type { Ref } from \"vue\";\nimport { computed } from \"vue\";\nimport { cloneDeepWith } from \"lodash-es\";\nimport Key from \"@/app/types/common/key\";\n\nexport type Optional = Pick, K> & Omit;\n\ntype IsNullable = null extends T ? K : never;\nexport type NullableKeys = {\n [K in keyof T]-?: IsNullable;\n}[keyof T];\n\nexport type Matcher = (itemValue: any, search: string) => boolean;\n\nexport const stringMatcher: Matcher = (itemValue: any, search: string) => {\n return (\n itemValue &&\n itemValue.toString().toLowerCase().indexOf(search.toLowerCase()) !== -1\n );\n};\n\n/**\n * Returns a string formatted how the user should see it on screen\n * @param item The item to format\n * @returns formatted string\n */\nexport const localeFormattedStringExtractor = (item: any): string => {\n if (item instanceof LocalDate) {\n return tenantService.formatDate(item);\n }\n if (item instanceof Instant) {\n return tenantService.formatDateTime(item);\n }\n if (isEnum(item)) {\n return item.translationKey\n ? translate(Key.fromString(item.translationKey)).toString()\n : item.value;\n }\n if (typeof item === \"number\") {\n // Remove separators from numbers (e.g. 1,234.56 => 1234.56)\n return item.toString();\n }\n return item.toLocaleString();\n};\n\nexport function guidHasValue(id: Guid | null | undefined): id is Guid {\n return !!id && !id.isEmpty();\n}\n\nexport const useArrayWithPlaceholderItem = (\n items: Ref[]>,\n placeholderItem: T,\n idExtractor: (item: T) => Guid\n) => {\n const itemsWithPlaceholder = computed(() => [\n ...items.value,\n placeholderItem,\n ]);\n\n return {\n items: itemsWithPlaceholder,\n placeholderId: idExtractor(placeholderItem),\n };\n};\n\n/**\n * To prevent multiple instances BmEnums and therefore not equal, this to preserve the BmEnum instances\n *\n * @param item - Item To clone\n * @returns Cloned Item\n */\nexport const cloneDeepPreserveBmEnum = (item: any) => {\n const cloneItemPreserveBmEnum = (value: any) => {\n if (value != null && isEnum(value)) {\n return value;\n }\n };\n return cloneDeepWith(item, cloneItemPreserveBmEnum);\n};\n\nexport const sortByFieldWithTiebreak = (\n initialSortByFieldExtractor: (line: T) => string | null | undefined,\n tiebreakFieldExtractor: (line: T) => string | null | undefined\n) => {\n return (lineA: T, lineB: T): number => {\n // Sort initial field\n const initialFieldA = initialSortByFieldExtractor(lineA);\n const initialFieldB = initialSortByFieldExtractor(lineB);\n\n const initialCompare = (initialFieldA ?? \"\").localeCompare(\n initialFieldB ?? \"\"\n );\n\n if (initialCompare === 0) {\n // Use tiebreak field if initial field is the same\n return (tiebreakFieldExtractor(lineA) ?? \"\").localeCompare(\n tiebreakFieldExtractor(lineB) ?? \"\"\n );\n }\n\n return initialCompare;\n };\n};\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumActivityLogType } from \"./enums/enumActivityLogType.generated\";\nimport { EnumBmEntityType } from \"./enums/enumBmEntityType.generated\";\n\n// Model Objects\n\nexport class ActivityLogEntry extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Type of the entity with which the task is associated, if any. Association is only supported to entity types which are tenant-level with a single guid id.\n */\n public activityLogType: EnumActivityLogType = EnumActivityLogType.none;\n /**\n * Type of the entity on which the activity occurred. Currently Outlet or Lead.\n */\n public activityOnEntityType: EnumBmEntityType = EnumBmEntityType.none;\n /**\n * Id of the entity on which the activity occurred. (Currently an OutletId or LeadId).\n */\n public activityOnEntityId: Guid = Guid.createEmpty();\n /**\n * Type of the entity which caused the log entry. Association is only supported to entity types which are tenant-level with a single guid id.\n */\n public relatedBmEntityType: EnumBmEntityType = EnumBmEntityType.none;\n private _relatedBmEntityId: Guid | null = null;\n /**\n * Id of the entity with which the task is associated, if any.\n */\n public get relatedBmEntityId(): Guid | null { return this._relatedBmEntityId }\n public set relatedBmEntityId(value: Guid | null) {\n this._relatedBmEntityId = value === undefined ? null : value;\n }\n /**\n * Timestamp at which the activity occurred.\n */\n public timestamp: Instant = Instant.ofEpochMilli(0);\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.activityLogType = EnumActivityLogType.getByValue(jsonSerializedObject.activityLogType, this.activityLogType);\n this.activityOnEntityType = EnumBmEntityType.getByValue(jsonSerializedObject.activityOnEntityType, this.activityOnEntityType);\n this.activityOnEntityId = Guid.fromString(jsonSerializedObject.activityOnEntityId);\n this.relatedBmEntityType = EnumBmEntityType.getByValue(jsonSerializedObject.relatedBmEntityType, this.relatedBmEntityType);\n this.relatedBmEntityId = jsonSerializedObject.relatedBmEntityId == null ? null : Guid.fromString(jsonSerializedObject.relatedBmEntityId);\n this.timestamp = Instant.parse(jsonSerializedObject.timestamp);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.activityLogType = this.activityLogType.value;\n toRet.activityOnEntityType = this.activityOnEntityType.value;\n toRet.activityOnEntityId = this.activityOnEntityId.toString();\n toRet.relatedBmEntityType = this.relatedBmEntityType.value;\n toRet.relatedBmEntityId = this.relatedBmEntityId == null ? null : this.relatedBmEntityId.toString();\n toRet.timestamp = this.timestamp.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"ActivityLogEntry.Id cannot be empty\"},\n {field: \"activityOnEntityId\", rule: (v: any) => !v.isEmpty() || \"ActivityLogEntry.ActivityOnEntityId cannot be empty\"},\n {field: \"relatedBmEntityId\", rule: (v: any) => v == null || !v.isEmpty() || \"ActivityLogEntry.RelatedBmEntityId cannot be empty\"},\n ];\n}\n\n\nexport class ActivityLogFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _logTypes: EnumActivityLogType[] | null = null;\n public get logTypes(): EnumActivityLogType[] | null { return this._logTypes }\n public set logTypes(value: EnumActivityLogType[] | null) {\n this._logTypes = value === undefined ? null : value;\n }\n private _activityOnEntityTypes: EnumBmEntityType[] | null = null;\n public get activityOnEntityTypes(): EnumBmEntityType[] | null { return this._activityOnEntityTypes }\n public set activityOnEntityTypes(value: EnumBmEntityType[] | null) {\n this._activityOnEntityTypes = value === undefined ? null : value;\n }\n private _activityOnEntityIds: Guid[] | null = null;\n public get activityOnEntityIds(): Guid[] | null { return this._activityOnEntityIds }\n public set activityOnEntityIds(value: Guid[] | null) {\n this._activityOnEntityIds = value === undefined ? null : value;\n }\n private _fromTimestamp: Instant | null = null;\n /**\n * Minimum (inclusive) timestamp.\n */\n public get fromTimestamp(): Instant | null { return this._fromTimestamp }\n public set fromTimestamp(value: Instant | null) {\n this._fromTimestamp = value === undefined ? null : value;\n }\n private _toTimestamp: Instant | null = null;\n /**\n * Maximum (inclusive) timestamp.\n */\n public get toTimestamp(): Instant | null { return this._toTimestamp }\n public set toTimestamp(value: Instant | null) {\n this._toTimestamp = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.logTypes = jsonSerializedObject.logTypes == null ? null : jsonSerializedObject.logTypes.map((v: any) => EnumActivityLogType.getByValue(v));\n this.activityOnEntityTypes = jsonSerializedObject.activityOnEntityTypes == null ? null : jsonSerializedObject.activityOnEntityTypes.map((v: any) => EnumBmEntityType.getByValue(v));\n this.activityOnEntityIds = jsonSerializedObject.activityOnEntityIds == null ? null : jsonSerializedObject.activityOnEntityIds.map((v: any) => Guid.fromString(v));\n this.fromTimestamp = jsonSerializedObject.fromTimestamp == null ? null : Instant.parse(jsonSerializedObject.fromTimestamp);\n this.toTimestamp = jsonSerializedObject.toTimestamp == null ? null : Instant.parse(jsonSerializedObject.toTimestamp);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.logTypes = this.logTypes == null ? null : this.logTypes.map(v => v.value);\n toRet.activityOnEntityTypes = this.activityOnEntityTypes == null ? null : this.activityOnEntityTypes.map(v => v.value);\n toRet.activityOnEntityIds = this.activityOnEntityIds == null ? null : this.activityOnEntityIds.map(v => v.toString());\n toRet.fromTimestamp = this.fromTimestamp == null ? null : this.fromTimestamp.toString();\n toRet.toTimestamp = this.toTimestamp == null ? null : this.toTimestamp.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class FilteredActivityLogResults extends ModelObject {\n\n public matchingCount: number = 0;\n public activityLogEntries: ActivityLogEntry[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.activityLogEntries = jsonSerializedObject.activityLogEntries.map((v: any) => new ActivityLogEntry(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.activityLogEntries = this.activityLogEntries.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"activityLogEntries\", rule: (v: any) => !!v || \"activityLogEntries is required\"},\n {field: \"activityLogEntries\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ActivityLogEntry[]).reduce((acc: Array, curr: ActivityLogEntry) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class AddActivityLogEntryRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n /**\n * Type of the entity with which the task is associated, if any. Association is only supported to entity types which are tenant-level with a single guid id.\n */\n public activityLogType: EnumActivityLogType = EnumActivityLogType.none;\n /**\n * Type of the entity on which the activity occurred. Currently Outlet or Lead.\n */\n public activityOnEntityType: EnumBmEntityType = EnumBmEntityType.none;\n /**\n * Id of the entity on which the activity occurred. (Currently an OutletId or LeadId).\n */\n public activityOnEntityId: Guid = Guid.createEmpty();\n /**\n * Type of the entity which caused the log entry. Association is only supported to entity types which are tenant-level with a single guid id.\n */\n public relatedBmEntityType: EnumBmEntityType = EnumBmEntityType.none;\n private _relatedBmEntityId: Guid | null = null;\n /**\n * Id of the entity with which the task is associated, if any.\n */\n public get relatedBmEntityId(): Guid | null { return this._relatedBmEntityId }\n public set relatedBmEntityId(value: Guid | null) {\n this._relatedBmEntityId = value === undefined ? null : value;\n }\n private _timestampIfNotDbNow: Instant | null = null;\n public get timestampIfNotDbNow(): Instant | null { return this._timestampIfNotDbNow }\n public set timestampIfNotDbNow(value: Instant | null) {\n this._timestampIfNotDbNow = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.activityLogType = EnumActivityLogType.getByValue(jsonSerializedObject.activityLogType, this.activityLogType);\n this.activityOnEntityType = EnumBmEntityType.getByValue(jsonSerializedObject.activityOnEntityType, this.activityOnEntityType);\n this.activityOnEntityId = Guid.fromString(jsonSerializedObject.activityOnEntityId);\n this.relatedBmEntityType = EnumBmEntityType.getByValue(jsonSerializedObject.relatedBmEntityType, this.relatedBmEntityType);\n this.relatedBmEntityId = jsonSerializedObject.relatedBmEntityId == null ? null : Guid.fromString(jsonSerializedObject.relatedBmEntityId);\n this.timestampIfNotDbNow = jsonSerializedObject.timestampIfNotDbNow == null ? null : Instant.parse(jsonSerializedObject.timestampIfNotDbNow);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.activityLogType = this.activityLogType.value;\n toRet.activityOnEntityType = this.activityOnEntityType.value;\n toRet.activityOnEntityId = this.activityOnEntityId.toString();\n toRet.relatedBmEntityType = this.relatedBmEntityType.value;\n toRet.relatedBmEntityId = this.relatedBmEntityId == null ? null : this.relatedBmEntityId.toString();\n toRet.timestampIfNotDbNow = this.timestampIfNotDbNow == null ? null : this.timestampIfNotDbNow.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"activityOnEntityId\", rule: (v: any) => !v.isEmpty() || \".ActivityOnEntityId cannot be empty\"},\n {field: \"relatedBmEntityId\", rule: (v: any) => v == null || !v.isEmpty() || \".RelatedBmEntityId cannot be empty\"},\n ];\n}\n\n\nexport class GetActivityLogEntriesByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: ActivityLogFilter = new ActivityLogFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new ActivityLogFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetActivityLogEntriesByFilterResponse extends ModelObject {\n\n public results: FilteredActivityLogResults = new FilteredActivityLogResults();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredActivityLogResults(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetMostRecentActivityLogEntriesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n /**\n * Type of the entity with which the task is associated, if any. Association is only supported to entity types which are tenant-level with a single guid id.\n */\n public activityLogType: EnumActivityLogType = EnumActivityLogType.none;\n /**\n * Type of the entity on which the activity occurred. Currently Outlet or Lead.\n */\n public activityOnEntityType: EnumBmEntityType = EnumBmEntityType.none;\n public activityOnEntityIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.activityLogType = EnumActivityLogType.getByValue(jsonSerializedObject.activityLogType, this.activityLogType);\n this.activityOnEntityType = EnumBmEntityType.getByValue(jsonSerializedObject.activityOnEntityType, this.activityOnEntityType);\n this.activityOnEntityIds = jsonSerializedObject.activityOnEntityIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.activityLogType = this.activityLogType.value;\n toRet.activityOnEntityType = this.activityOnEntityType.value;\n toRet.activityOnEntityIds = this.activityOnEntityIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetMostRecentActivityLogEntriesResponse extends ModelObject {\n\n public activityLogEntries: ActivityLogEntry[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.activityLogEntries = jsonSerializedObject.activityLogEntries.map((v: any) => new ActivityLogEntry(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.activityLogEntries = this.activityLogEntries.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"activityLogEntries\", rule: (v: any) => !!v || \"activityLogEntries is required\"},\n {field: \"activityLogEntries\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as ActivityLogEntry[]).reduce((acc: Array, curr: ActivityLogEntry) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class ActivityLogService extends ServiceBase {\n\n public async getActivityLogEntriesByFilter(tenantId: Guid, filter: ActivityLogFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetActivityLogEntriesByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetActivityLogEntriesByFilterResponse(response).results;\n return this.makeJsonRequest(\"activityLog/v1/getActivityLogEntriesByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getMostRecentActivityLogEntries(tenantId: Guid, activityLogType: EnumActivityLogType, activityOnEntityType: EnumBmEntityType, activityOnEntityIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetMostRecentActivityLogEntriesRequest();\n req.tenantId = tenantId;\n req.activityLogType = activityLogType;\n req.activityOnEntityType = activityOnEntityType;\n req.activityOnEntityIds = activityOnEntityIds;\n const extractor = (response:any) => new GetMostRecentActivityLogEntriesResponse(response).activityLogEntries;\n return this.makeJsonRequest(\"activityLog/v1/getMostRecentActivityLogEntries\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const activityLogService = new ActivityLogService();","import type { LocalDate, LocalDateTime } from \"@js-joda/core\";\nimport api from \"@/app/api\";\nimport { tenantService } from \"@/app/services/extensions/tenantServiceExtended\";\nimport type { BmTask } from \"@/app/services/generated/bmtaskService\";\nimport {\n bmTaskService,\n BmTaskFilter,\n} from \"@/app/services/generated/bmtaskService\";\nimport { User } from \"@/app/services/generated/userService\";\nimport {\n withLoading,\n wrapPromiseWithErrorHandling,\n makeRef,\n makeDeepRef,\n wrapLoading,\n} from \"@/components/composables/componentTools\";\nimport { EnumTaskStatus } from \"@/app/services/generated/enums/enumTaskStatus.generated\";\nimport type { Ref } from \"vue\";\nimport { computed, ref, watch } from \"vue\";\nimport { GuidMap, GuidSet } from \"@/app/types/common/guidcollections\";\nimport Guid from \"@/app/types/common/guid\";\nimport { appendOrdinalSuffix, useI18n } from \"@/plugins/i18n\";\nimport type { TaskWithAssociations } from \"@/components/pages/tasks/composables/taskAssociations\";\nimport { joinTasksWithAssociations } from \"@/components/pages/tasks/composables/taskAssociations\";\nimport tasksStore from \"@/store/modules/tasksStore\";\nimport { userService } from \"@/app/services/extensions/userServiceExtended\";\nimport { useArrayWithPlaceholderItem } from \"@/components/composables/dataUtils\";\nimport type { EnumTaskRepeatBasis } from \"@/app/services/generated/enums/enumTaskRepeatBasis.generated\";\nimport apiCache from \"@/app/caching/apiCache\";\nimport TaskTypesCache from \"@/app/caching/caches/taskTypesCache\";\nimport TaskQueuesCache from \"@/app/caching/caches/taskQueuesCache\";\nimport SalesCodesCache from \"@/app/caching/caches/salesCodeCache\";\nimport SalesAreasCache from \"@/app/caching/caches/salesAreasCache\";\nimport DeliveryAreasCache from \"@/app/caching/caches/deliveryAreasCache\";\nimport { deliveryAreaService } from \"@/app/services/generated/deliveryareaService\";\nimport { EnumDayOfWeek } from \"@/app/services/generated/enums/enumDayOfWeek.generated\";\nimport { distinctGuids, toGuidMap } from \"@/app/apiutils\";\nimport type { Contact } from \"@/app/services/generated/outletService\";\nimport { outletService } from \"@/app/services/generated/outletService\";\nimport Key from \"@/app/types/common/key\";\nimport type { ActivityLogEntry } from \"@/app/services/generated/activitylogService\";\nimport { activityLogService } from \"@/app/services/generated/activitylogService\";\nimport { EnumBmEntityType } from \"@/app/services/generated/enums/enumBmEntityType.generated\";\nimport { EnumActivityLogType } from \"@/app/services/generated/enums/enumActivityLogType.generated\";\nimport GroupsCache from \"@/app/caching/caches/groupsCache\";\n\nconst PLACEHOLDER_USER_ID = Guid.createEmpty();\n\n/**\n * Determines if the supplied task is overdue in respect to the supplied datetime.\n *\n * `now` would most likely be: LocalDateTime.now(tenantService.getTimezone());\n */\nexport function isTaskOverdue(task: BmTask, now: LocalDateTime) {\n return (\n !!task.dueDate &&\n (task.dueDate.isBefore(now.toLocalDate()) ||\n (!!task.dueTime &&\n task.dueDate.equals(now.toLocalDate()) &&\n task.dueTime.isBefore(now.toLocalTime())))\n );\n}\n\n/**\n * Determines if the task is required to be done on the same day\n * that `now` references\n *\n * We expect not overdue tasks, with no due date, to be in the todo section\n */\nexport function isTaskInToDoSection(task: BmTask, now: LocalDateTime): boolean {\n if (task.dueDate) {\n if (task.dueTime) {\n return (\n task.dueDate.isEqual(now.toLocalDate()) &&\n task.dueTime.isAfter(now.toLocalTime())\n );\n }\n\n return task.dueDate.isEqual(now.toLocalDate());\n }\n\n return true;\n}\n\nexport function isTaskSelected(\n task: BmTask,\n taskTypeIds: Guid[],\n taskQueueIds: Guid[],\n userOptions: Guid[]\n) {\n const taskTypeIsSelected = !!taskTypeIds?.find((typeId) =>\n typeId.equals(task.taskTypeId)\n );\n const taskQueueIsSelected = !!taskQueueIds?.find((queueId) =>\n queueId.equals(task.taskQueueId)\n );\n const taskAssignedUserIsSelected = !!userOptions.find((userId) => {\n // If our selected userId is unassigned, check our task's is also\n if (userId.equals(PLACEHOLDER_USER_ID)) {\n return task.assignedToUserId === null;\n }\n\n return task.assignedToUserId?.equals(userId);\n });\n\n return (\n taskTypeIsSelected && taskQueueIsSelected && taskAssignedUserIsSelected\n );\n}\n\nexport function getRepeatBasisText(task: BmTask, basis?: EnumTaskRepeatBasis) {\n const { $t } = useI18n();\n\n basis = basis ?? task.taskRepeatBasis;\n const dayOfWeekValue = task.dueDate?.dayOfWeek().value();\n\n const dayOfWeekTranslated = dayOfWeekValue\n ? EnumDayOfWeek.getByKey(dayOfWeekValue).translation\n : \"\";\n\n return $t(Key.fromString(basis.translationKey), {\n day: dayOfWeekTranslated,\n repeatParameter: task.taskRepeatParameter,\n ordinalNumber: appendOrdinalSuffix(task.taskRepeatParameter),\n }).toString();\n}\n\nexport function useTasksList(\n dueDateRange: Ref = ref([])\n) {\n const { $m } = useI18n();\n const users = makeRef([]);\n const nextDeliveryAreaDespatchDateLookup = makeRef(\n new GuidMap()\n );\n const outletContactsLookup = makeRef(new GuidMap());\n const recentActivityLogEntriesLookup = makeRef(\n new GuidMap()\n );\n const cache = apiCache.buildCacheSet({\n taskTypes: TaskTypesCache,\n taskQueues: TaskQueuesCache,\n salesCodes: SalesCodesCache,\n salesAreas: SalesAreasCache,\n deliveryAreas: DeliveryAreasCache,\n groups: GroupsCache,\n });\n\n // create unassigned user placeholder\n const placeholderNoneUser = new User();\n placeholderNoneUser.id = PLACEHOLDER_USER_ID;\n placeholderNoneUser.name = $m.tasks_no_user_assigned;\n const usersFilterOptions = computed(() => {\n // We query all assigned users so we can determine if we need to add support\n // and system users to the filter options.\n const allAssignedUserIdsInTasks = new GuidSet(\n distinctGuids(\n openTaskRows.value\n .map((tr) => tr.task.assignedToUserId)\n .concat(closedTasks.value.map((tr) => tr.task.assignedToUserId))\n )\n );\n\n const usersAssignedUsersInTasks = users.value.filter((option) =>\n allAssignedUserIdsInTasks.has(option.id)\n );\n\n const { items: filterUsers } = useArrayWithPlaceholderItem(\n makeDeepRef(usersAssignedUsersInTasks),\n placeholderNoneUser,\n (user) => user.id\n );\n\n return filterUsers.value;\n });\n\n const selectedTaskTypeIds = ref([]);\n const selectedTaskQueueIds = ref([]);\n const selectedUserIds = ref([]);\n\n const openTaskRows = makeRef([]);\n const cancelledOrCompletedTasks = makeRef(\n []\n );\n\n // Is our closed tasks card open?\n const closedTasksVisible = ref(false);\n\n // The most common use of 'now', for ease of use\n let dateTimeNow = tenantService.nowDateTime;\n\n const refreshOpenTasks = withLoading(async () => {\n dateTimeNow = tenantService.nowDateTime;\n\n const taskFilter = new BmTaskFilter();\n taskFilter.limitStatuses = [EnumTaskStatus.open];\n\n if (dueDateRange.value.length) {\n taskFilter.fromDueDate = dueDateRange.value[0];\n taskFilter.toDueDate = dueDateRange.value[1] ?? dueDateRange.value[0];\n }\n\n const openTasks = (\n await bmTaskService.getBmTasksByFilter(api.tenantId, taskFilter)\n ).bmTasks;\n\n openTaskRows.value = await joinTasksWithAssociations(openTasks);\n\n return openTasks;\n });\n\n const refreshClosedTasks = async () => {\n dateTimeNow = tenantService.nowDateTime;\n\n const closedTasksFilter = new BmTaskFilter();\n\n closedTasksFilter.limitStatuses = [\n EnumTaskStatus.cancelled,\n EnumTaskStatus.complete,\n ];\n\n closedTasksFilter.maximumResults = 1000;\n\n const closedTasks = (\n await bmTaskService.getBmTasksByFilter(api.tenantId, closedTasksFilter)\n ).bmTasks;\n\n cancelledOrCompletedTasks.value =\n await joinTasksWithAssociations(closedTasks);\n };\n\n const refreshDependencies = async () => {\n await cache.update();\n\n const outletIds = distinctGuids(\n openTaskRows.value\n .map((x) => x.associatedOutlet?.id)\n .concat(\n todoTasks.value.map((x) => x.associatedOutlet?.id),\n closedTasks.value.map((x) => x.associatedOutlet?.id)\n )\n );\n\n const leadIds = distinctGuids(\n openTaskRows.value\n .map((x) => x.associatedLead?.id)\n .concat(\n todoTasks.value.map((x) => x.associatedLead?.id),\n closedTasks.value.map((x) => x.associatedLead?.id)\n )\n );\n\n const [\n allUsers,\n despatchDatesResult,\n outletContacts,\n outletActivityLogEntries,\n leadActivityLogEntries,\n ] = await Promise.all([\n userService.getAllUsers(api.tenantGroupId),\n deliveryAreaService\n .calculateDeliveryAreasDistributionDates(\n api.tenantId,\n cache.deliveryAreas.all.map((x) => x.id)\n )\n .then(\n (result) => new GuidMap(result.map((r) => [r.id, r.dispatchDate]))\n ),\n outletService.getPrimaryContactsForOutlets(api.tenantId, outletIds),\n activityLogService.getMostRecentActivityLogEntries(\n api.tenantId,\n EnumActivityLogType.communication,\n EnumBmEntityType.outlet,\n outletIds\n ),\n activityLogService.getMostRecentActivityLogEntries(\n api.tenantId,\n EnumActivityLogType.communication,\n EnumBmEntityType.lead,\n leadIds\n ),\n ]);\n\n recentActivityLogEntriesLookup.value = toGuidMap(\n [...outletActivityLogEntries, ...leadActivityLogEntries].filter(\n (entry) => !!entry.activityOnEntityId\n ),\n (entry) => entry.activityOnEntityId!\n );\n\n nextDeliveryAreaDespatchDateLookup.value = despatchDatesResult;\n outletContactsLookup.value = toGuidMap(outletContacts, (x) => x.outletId);\n users.value = allUsers;\n };\n\n const cancelTask = withLoading(async (task: BmTask) => {\n await bmTaskService.cancelBmTask(api.tenantId, task.id);\n await refreshTasksAndDependencies();\n });\n\n const completeTask = withLoading(async (task: BmTask) => {\n await bmTaskService.completeBmTask(api.tenantId, task.id);\n await refreshTasksAndDependencies();\n });\n\n const refreshTasksAndDependencies = async (refreshTaskStore = true) => {\n if (refreshTaskStore) {\n // Do not await this refresh call - it doesn't affect any data on the\n // tasks page so does not need to potentially block the UI with a loading\n // dialog\n tasksStore.refresh().then();\n }\n\n await wrapLoading(async () => {\n const promises: Promise[] = [refreshOpenTasks()];\n\n // Only attempt to load closed tasks if they have been loaded before\n // by the header click.\n if (closedTasksVisible.value) {\n promises.push(refreshClosedTasks());\n }\n\n await Promise.all(promises);\n await refreshDependencies();\n });\n };\n\n const selectedOpenTasks = computed(() =>\n openTaskRows.value.filter((row) =>\n isTaskSelected(\n row.task,\n selectedTaskTypeIds.value,\n selectedTaskQueueIds.value,\n selectedUserIds.value\n )\n )\n );\n\n // All open tasks that are not overdue, but due today\n const todoTasks = computed(() =>\n selectedOpenTasks.value.filter(\n (row) =>\n !isTaskOverdue(row.task, dateTimeNow) &&\n isTaskInToDoSection(row.task, dateTimeNow)\n )\n );\n\n // All open tasks that are not overdue, and also not due today\n const upcomingTasks = computed(() =>\n selectedOpenTasks.value.filter(\n (row) =>\n !isTaskOverdue(row.task, dateTimeNow) &&\n !isTaskInToDoSection(row.task, dateTimeNow)\n )\n );\n\n const overdueTasks = computed(() =>\n selectedOpenTasks.value.filter((row) =>\n isTaskOverdue(row.task, dateTimeNow)\n )\n );\n\n const closedTasks = computed(() =>\n cancelledOrCompletedTasks.value.filter((row) =>\n isTaskSelected(\n row.task,\n selectedTaskTypeIds.value,\n selectedTaskQueueIds.value,\n selectedUserIds.value\n )\n )\n );\n\n watch(\n closedTasksVisible,\n withLoading(\n wrapPromiseWithErrorHandling(async () => {\n if (closedTasksVisible.value) {\n await refreshTasksAndDependencies();\n } else {\n cancelledOrCompletedTasks.value = [];\n }\n })\n )\n );\n\n return {\n users,\n cache,\n nextDeliveryAreaDespatchDateLookup,\n outletContactsLookup,\n recentActivityLogEntriesLookup,\n\n usersMap: computed(\n () => new GuidMap(users.value.map((user) => [user.id, user]))\n ),\n\n // Task lists\n openTaskRows,\n todoTasks,\n upcomingTasks,\n overdueTasks,\n closedTasks,\n\n closedTasksVisible,\n\n // Filter items\n usersFilterOptions,\n selectedTaskTypeIds,\n selectedTaskQueueIds,\n selectedUserIds,\n\n cancelTask,\n completeTask,\n refreshTasksAndDependencies,\n };\n}\n","import userStore from \"@/store/modules/userStore\";\nimport {\n BmTaskFilter,\n bmTaskService,\n} from \"@/app/services/generated/bmtaskService\";\nimport api from \"@/app/api\";\nimport { tenantService } from \"@/app/services/extensions/tenantServiceExtended\";\nimport { LocalDateTime } from \"@js-joda/core\";\nimport {\n isTaskInToDoSection,\n isTaskOverdue,\n} from \"@/components/pages/tasks/composables/tasks\";\nimport { EnumTaskStatus } from \"@/app/services/generated/enums/enumTaskStatus.generated\";\nimport { reactive, readonly } from \"vue\";\n\nlet timerId = 0;\n\ninterface TaskStoreState {\n assignedTasksCount: number;\n assignedOverdueTasksCount: number;\n}\n\nconst state = reactive({\n assignedTasksCount: 0,\n assignedOverdueTasksCount: 0,\n});\n\nasync function refresh() {\n if (\n !userStore.isAuthenticatedWithSelectedTenant.value ||\n !userStore.state.user\n ) {\n return;\n }\n\n const bmTaskFilter = new BmTaskFilter();\n bmTaskFilter.limitAssignedUserIds = [userStore.state.user.id];\n bmTaskFilter.limitStatuses = [EnumTaskStatus.open];\n\n const { bmTasks } = await bmTaskService.getBmTasksByFilter(\n api.tenantId,\n bmTaskFilter\n );\n\n const dateTimeNow = LocalDateTime.now(tenantService.getTimezone());\n\n state.assignedTasksCount = bmTasks.filter((task) =>\n isTaskInToDoSection(task, dateTimeNow)\n ).length;\n\n state.assignedOverdueTasksCount = bmTasks.filter((task) =>\n isTaskOverdue(task, dateTimeNow)\n ).length;\n}\n\nasync function startAutoRefresh() {\n if (timerId) {\n clearInterval(timerId);\n timerId = 0;\n state.assignedTasksCount = 0;\n state.assignedOverdueTasksCount = 0;\n }\n\n await refresh();\n\n timerId = +setInterval(refresh, 30000);\n}\n\nexport default {\n state: readonly(state),\n startAutoRefresh,\n refresh,\n};\n","\n\n\n\n\n","import { MenuItem } from \"@/app/ui/navigation/types\";\nimport TasksMenuItem from \"@/components/controls/tasks/TasksMenuItem.vue\";\nimport type { Location } from \"vue-router\";\nimport { EnumExternalCalendarProvider } from \"@/app/services/generated/enums/enumExternalCalendarProvider.generated\";\nimport { EnumFeatureFlag } from \"@/app/services/generated/enums/enumFeatureFlag.generated\";\nimport { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\n\nexport const mainMenu = {\n home: \"home\",\n brewmanNews: \"brewman_news\",\n viewBrewmanNews: (): Location => ({\n name: mainMenu.brewmanNews,\n }),\n goHome: (): Location => ({ name: mainMenu.home }),\n tasks: \"tasks\",\n viewTasks: (): Location => ({\n name: mainMenu.tasks,\n }),\n search: \"search\",\n calendar: \"calendar\",\n viewCalendar: (): Location => ({ name: mainMenu.calendar }),\n calendarGoogleSuccess: \"calendar_link_success\",\n viewCalendarGoogleSuccess: (): Location => ({\n name: mainMenu.calendarGoogleSuccess,\n }),\n calendarMicrosoftSuccess: \"calendar_microsoft_success\",\n viewCalendarMicrosoftSuccess: (): Location => ({\n name: mainMenu.calendarMicrosoftSuccess,\n }),\n};\n\nexport const buildMainMenuItems: () => MenuItem[] = () => [\n MenuItem.fromOpts({\n name: mainMenu.home,\n icon: \"home\",\n url: \"/home\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"common\" */ \"@/components/pages/dashboard/Dashboard.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: mainMenu.brewmanNews,\n url: \"/news\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"common\" */ \"@/components/pages/news/BrewmanNews.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: mainMenu.calendar,\n icon: \"calendar_month\",\n url: \"/calendar\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"common\" */ \"@/components/pages/calendar/Calendar.vue\"\n ),\n visible: () =>\n hasPermissionsUsingUserStore([EnumUserPermission.menuCalendarView]),\n }),\n MenuItem.fromOpts({\n name: mainMenu.calendarGoogleSuccess,\n url: \"/calendar-link-success/google\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"common\" */ \"@/components/pages/calendar/CalendarLink.vue\"\n ),\n componentProps: (route) => ({\n state: route.query.state,\n code: route.query.code,\n provider: EnumExternalCalendarProvider.google,\n }),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: mainMenu.calendarMicrosoftSuccess,\n url: \"/calendar-link-success/microsoft\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"common\" */ \"@/components/pages/calendar/CalendarLink.vue\"\n ),\n componentProps: (route) => ({\n state: route.query.state,\n code: route.query.code,\n provider: EnumExternalCalendarProvider.microsoft,\n }),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: mainMenu.tasks,\n icon: \"format_list_bulleted\",\n url: \"/tasks\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"tasks\" */ \"@/components/pages/tasks/ViewTasks.vue\"\n ),\n menuComponent: TasksMenuItem,\n visible: () =>\n hasPermissionsUsingUserStore([EnumUserPermission.menuTasksView]),\n }),\n MenuItem.fromOpts({\n name: mainMenu.search,\n url: \"/search\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"common\" */ \"@/components/pages/search/SearchResults.vue\"\n ),\n visible: false,\n requiredFeatureFlag: EnumFeatureFlag.onlyDev,\n }),\n];\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumCustomerHappinessRating } from \"./enums/enumCustomerHappinessRating.generated\";\n\n// Model Objects\n\nexport class LeadCommunicationLogEntry extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * Id of the communication log's communication subject.\n */\n public communicationSubjectId: Guid = Guid.createEmpty();\n /**\n * Id of the communication log's communication type.\n */\n public communicationTypeId: Guid = Guid.createEmpty();\n /**\n * Rating of the customer happiness.\n */\n public customerHappinessRating: EnumCustomerHappinessRating = EnumCustomerHappinessRating.neutral;\n /**\n * Description of the communication log entry.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public description: string = \"\";\n /**\n * Lead relating to which the communication occurred.\n */\n public leadId: Guid = Guid.createEmpty();\n /**\n * Timestamp at which the communication occurred.\n */\n public timestamp: Instant = Instant.ofEpochMilli(0);\n /**\n * User who created the communication log entry.\n */\n public userId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.communicationSubjectId = Guid.fromString(jsonSerializedObject.communicationSubjectId);\n this.communicationTypeId = Guid.fromString(jsonSerializedObject.communicationTypeId);\n this.customerHappinessRating = EnumCustomerHappinessRating.getByValue(jsonSerializedObject.customerHappinessRating, this.customerHappinessRating);\n this.description = jsonSerializedObject.description;\n this.leadId = Guid.fromString(jsonSerializedObject.leadId);\n this.timestamp = Instant.parse(jsonSerializedObject.timestamp);\n this.userId = Guid.fromString(jsonSerializedObject.userId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.communicationSubjectId = this.communicationSubjectId.toString();\n toRet.communicationTypeId = this.communicationTypeId.toString();\n toRet.customerHappinessRating = this.customerHappinessRating.value;\n toRet.description = this.description;\n toRet.leadId = this.leadId.toString();\n toRet.timestamp = this.timestamp.toString();\n toRet.userId = this.userId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"LeadCommunicationLogEntry.Id cannot be empty\"},\n {field: \"communicationSubjectId\", rule: (v: any) => !v.isEmpty() || \"LeadCommunicationLogEntry.CommunicationSubjectId cannot be empty\"},\n {field: \"communicationTypeId\", rule: (v: any) => !v.isEmpty() || \"LeadCommunicationLogEntry.CommunicationTypeId cannot be empty\"},\n {field: \"leadId\", rule: (v: any) => !v.isEmpty() || \"LeadCommunicationLogEntry.LeadId cannot be empty\"},\n {field: \"userId\", rule: (v: any) => !v.isEmpty() || \"LeadCommunicationLogEntry.UserId cannot be empty\"},\n ];\n}\n\n\nexport class LeadLogEntryFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _leadIds: Guid[] | null = null;\n public get leadIds(): Guid[] | null { return this._leadIds }\n public set leadIds(value: Guid[] | null) {\n this._leadIds = value === undefined ? null : value;\n }\n private _userIds: Guid[] | null = null;\n public get userIds(): Guid[] | null { return this._userIds }\n public set userIds(value: Guid[] | null) {\n this._userIds = value === undefined ? null : value;\n }\n private _fromTimestamp: Instant | null = null;\n /**\n * Minimum (inclusive) timestamp.\n */\n public get fromTimestamp(): Instant | null { return this._fromTimestamp }\n public set fromTimestamp(value: Instant | null) {\n this._fromTimestamp = value === undefined ? null : value;\n }\n private _toTimestamp: Instant | null = null;\n /**\n * Maximum (inclusive) timestamp.\n */\n public get toTimestamp(): Instant | null { return this._toTimestamp }\n public set toTimestamp(value: Instant | null) {\n this._toTimestamp = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.leadIds = jsonSerializedObject.leadIds == null ? null : jsonSerializedObject.leadIds.map((v: any) => Guid.fromString(v));\n this.userIds = jsonSerializedObject.userIds == null ? null : jsonSerializedObject.userIds.map((v: any) => Guid.fromString(v));\n this.fromTimestamp = jsonSerializedObject.fromTimestamp == null ? null : Instant.parse(jsonSerializedObject.fromTimestamp);\n this.toTimestamp = jsonSerializedObject.toTimestamp == null ? null : Instant.parse(jsonSerializedObject.toTimestamp);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.leadIds = this.leadIds == null ? null : this.leadIds.map(v => v.toString());\n toRet.userIds = this.userIds == null ? null : this.userIds.map(v => v.toString());\n toRet.fromTimestamp = this.fromTimestamp == null ? null : this.fromTimestamp.toString();\n toRet.toTimestamp = this.toTimestamp == null ? null : this.toTimestamp.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class FilteredLeadLogEntryResults extends ModelObject {\n\n public matchingCount: number = 0;\n public leadLogEntries: LeadCommunicationLogEntry[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.leadLogEntries = jsonSerializedObject.leadLogEntries.map((v: any) => new LeadCommunicationLogEntry(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.leadLogEntries = this.leadLogEntries.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"leadLogEntries\", rule: (v: any) => !!v || \"leadLogEntries is required\"},\n {field: \"leadLogEntries\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as LeadCommunicationLogEntry[]).reduce((acc: Array, curr: LeadCommunicationLogEntry) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class AddLeadLogEntryRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n /**\n * Id of the communication log's communication subject.\n */\n public communicationSubjectId: Guid = Guid.createEmpty();\n /**\n * Id of the communication log's communication type.\n */\n public communicationTypeId: Guid = Guid.createEmpty();\n /**\n * Rating of the customer happiness.\n */\n public customerHappinessRating: EnumCustomerHappinessRating = EnumCustomerHappinessRating.neutral;\n /**\n * Description of the communication log entry.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public description: string = \"\";\n /**\n * Lead relating to which the communication occurred.\n */\n public leadId: Guid = Guid.createEmpty();\n /**\n * User who created the communication log entry.\n */\n public userId: Guid = Guid.createEmpty();\n private _timestampIfNotDbNow: Instant | null = null;\n public get timestampIfNotDbNow(): Instant | null { return this._timestampIfNotDbNow }\n public set timestampIfNotDbNow(value: Instant | null) {\n this._timestampIfNotDbNow = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.communicationSubjectId = Guid.fromString(jsonSerializedObject.communicationSubjectId);\n this.communicationTypeId = Guid.fromString(jsonSerializedObject.communicationTypeId);\n this.customerHappinessRating = EnumCustomerHappinessRating.getByValue(jsonSerializedObject.customerHappinessRating, this.customerHappinessRating);\n this.description = jsonSerializedObject.description;\n this.leadId = Guid.fromString(jsonSerializedObject.leadId);\n this.userId = Guid.fromString(jsonSerializedObject.userId);\n this.timestampIfNotDbNow = jsonSerializedObject.timestampIfNotDbNow == null ? null : Instant.parse(jsonSerializedObject.timestampIfNotDbNow);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.communicationSubjectId = this.communicationSubjectId.toString();\n toRet.communicationTypeId = this.communicationTypeId.toString();\n toRet.customerHappinessRating = this.customerHappinessRating.value;\n toRet.description = this.description;\n toRet.leadId = this.leadId.toString();\n toRet.userId = this.userId.toString();\n toRet.timestampIfNotDbNow = this.timestampIfNotDbNow == null ? null : this.timestampIfNotDbNow.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"communicationSubjectId\", rule: (v: any) => !v.isEmpty() || \".CommunicationSubjectId cannot be empty\"},\n {field: \"communicationTypeId\", rule: (v: any) => !v.isEmpty() || \".CommunicationTypeId cannot be empty\"},\n {field: \"leadId\", rule: (v: any) => !v.isEmpty() || \".LeadId cannot be empty\"},\n {field: \"userId\", rule: (v: any) => !v.isEmpty() || \".UserId cannot be empty\"},\n ];\n}\n\n\nexport class AddLeadLogEntryResponse extends ModelObject {\n\n public leadLogEntry: LeadCommunicationLogEntry = new LeadCommunicationLogEntry();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.leadLogEntry = new LeadCommunicationLogEntry(jsonSerializedObject.leadLogEntry);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.leadLogEntry = this.leadLogEntry.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"leadLogEntry\", rule: (v: any) => !!v || \"leadLogEntry is required\"},\n {field: \"leadLogEntry\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetLeadLogEntryRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public leadLogEntryId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.leadLogEntryId = Guid.fromString(jsonSerializedObject.leadLogEntryId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.leadLogEntryId = this.leadLogEntryId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"leadLogEntryId\", rule: (v: any) => !v.isEmpty() || \".LeadLogEntryId cannot be empty\"},\n ];\n}\n\n\nexport class GetLeadLogEntryResponse extends ModelObject {\n\n public leadLogEntry: LeadCommunicationLogEntry = new LeadCommunicationLogEntry();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.leadLogEntry = new LeadCommunicationLogEntry(jsonSerializedObject.leadLogEntry);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.leadLogEntry = this.leadLogEntry.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"leadLogEntry\", rule: (v: any) => !!v || \"leadLogEntry is required\"},\n {field: \"leadLogEntry\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetLeadLogEntriesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public leadLogEntryIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.leadLogEntryIds = jsonSerializedObject.leadLogEntryIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.leadLogEntryIds = this.leadLogEntryIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetLeadLogEntriesResponse extends ModelObject {\n\n public leadLogEntries: LeadCommunicationLogEntry[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.leadLogEntries = jsonSerializedObject.leadLogEntries.map((v: any) => new LeadCommunicationLogEntry(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.leadLogEntries = this.leadLogEntries.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"leadLogEntries\", rule: (v: any) => !!v || \"leadLogEntries is required\"},\n {field: \"leadLogEntries\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as LeadCommunicationLogEntry[]).reduce((acc: Array, curr: LeadCommunicationLogEntry) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetLeadLogEntriesByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: LeadLogEntryFilter = new LeadLogEntryFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new LeadLogEntryFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetLeadLogEntriesByFilterResponse extends ModelObject {\n\n public results: FilteredLeadLogEntryResults = new FilteredLeadLogEntryResults();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredLeadLogEntryResults(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class LeadCommunicationLogService extends ServiceBase {\n\n public async addLeadLogEntry(tenantId: Guid, communicationSubjectId: Guid, communicationTypeId: Guid, customerHappinessRating: EnumCustomerHappinessRating, description: string, leadId: Guid, userId: Guid, timestampIfNotDbNow: Instant | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new AddLeadLogEntryRequest();\n req.tenantId = tenantId;\n req.communicationSubjectId = communicationSubjectId;\n req.communicationTypeId = communicationTypeId;\n req.customerHappinessRating = customerHappinessRating;\n req.description = description;\n req.leadId = leadId;\n req.userId = userId;\n req.timestampIfNotDbNow = timestampIfNotDbNow;\n const extractor = (response:any) => new AddLeadLogEntryResponse(response).leadLogEntry;\n return this.makeJsonRequest(\"leadCommunicationLog/v1/addLeadLogEntry\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getLeadLogEntry(tenantId: Guid, leadLogEntryId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetLeadLogEntryRequest();\n req.tenantId = tenantId;\n req.leadLogEntryId = leadLogEntryId;\n const extractor = (response:any) => new GetLeadLogEntryResponse(response).leadLogEntry;\n return this.makeJsonRequest(\"leadCommunicationLog/v1/getLeadLogEntry\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getLeadLogEntries(tenantId: Guid, leadLogEntryIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetLeadLogEntriesRequest();\n req.tenantId = tenantId;\n req.leadLogEntryIds = leadLogEntryIds;\n const extractor = (response:any) => new GetLeadLogEntriesResponse(response).leadLogEntries;\n return this.makeJsonRequest(\"leadCommunicationLog/v1/getLeadLogEntries\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getLeadLogEntriesByFilter(tenantId: Guid, filter: LeadLogEntryFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetLeadLogEntriesByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetLeadLogEntriesByFilterResponse(response).results;\n return this.makeJsonRequest(\"leadCommunicationLog/v1/getLeadLogEntriesByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const leadCommunicationLogService = new LeadCommunicationLogService();","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class CommunicationTypeReadOnly extends ModelObject {\n\n /**\n * Sequence for ordering communication types.\n */\n public sequence: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.sequence = jsonSerializedObject.sequence;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.sequence = this.sequence;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"sequence\", rule: (v: any) => v == null || v >= -2147483648 || \"Sequence is not greater than minimum allowed value: -2147483648\"},\n {field: \"sequence\", rule: (v: any) => v == null || v <= 2147483647 || \"Sequence is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class CommunicationType extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Communication Type Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n public isHidden: boolean = false;\n public readOnly: CommunicationTypeReadOnly = new CommunicationTypeReadOnly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.name = jsonSerializedObject.name;\n this.isHidden = jsonSerializedObject.isHidden;\n this.readOnly = new CommunicationTypeReadOnly(jsonSerializedObject.readOnly);\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.name = this.name;\n toRet.isHidden = this.isHidden;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"CommunicationType.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class GetAllCommunicationTypesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllCommunicationTypesResponse extends ModelObject {\n\n public communicationTypes: CommunicationType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.communicationTypes = jsonSerializedObject.communicationTypes.map((v: any) => new CommunicationType(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.communicationTypes = this.communicationTypes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"communicationTypes\", rule: (v: any) => !!v || \"communicationTypes is required\"},\n {field: \"communicationTypes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as CommunicationType[]).reduce((acc: Array, curr: CommunicationType) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetCommunicationTypeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public communicationTypeId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.communicationTypeId = Guid.fromString(jsonSerializedObject.communicationTypeId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.communicationTypeId = this.communicationTypeId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"communicationTypeId\", rule: (v: any) => !v.isEmpty() || \".CommunicationTypeId cannot be empty\"},\n ];\n}\n\n\nexport class GetCommunicationTypeResponse extends ModelObject {\n\n public communicationType: CommunicationType = new CommunicationType();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.communicationType = new CommunicationType(jsonSerializedObject.communicationType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.communicationType = this.communicationType.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"communicationType\", rule: (v: any) => !!v || \"communicationType is required\"},\n {field: \"communicationType\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetCommunicationTypesRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public communicationTypeIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.communicationTypeIds = jsonSerializedObject.communicationTypeIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.communicationTypeIds = this.communicationTypeIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetCommunicationTypesResponse extends ModelObject {\n\n public communicationTypes: CommunicationType[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.communicationTypes = jsonSerializedObject.communicationTypes.map((v: any) => new CommunicationType(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.communicationTypes = this.communicationTypes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"communicationTypes\", rule: (v: any) => !!v || \"communicationTypes is required\"},\n {field: \"communicationTypes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as CommunicationType[]).reduce((acc: Array, curr: CommunicationType) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveCommunicationTypeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public communicationType: CommunicationType = new CommunicationType();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.communicationType = new CommunicationType(jsonSerializedObject.communicationType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.communicationType = this.communicationType.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"communicationType\", rule: (v: any) => !!v || \"communicationType is required\"},\n {field: \"communicationType\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetCommunicationTypeIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public communicationTypeId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.communicationTypeId = Guid.fromString(jsonSerializedObject.communicationTypeId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.communicationTypeId = this.communicationTypeId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"communicationTypeId\", rule: (v: any) => !v.isEmpty() || \".CommunicationTypeId cannot be empty\"},\n ];\n}\n\n\nexport class UpdateCommunicationTypesSequenceRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public communicationTypeIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.communicationTypeIds = jsonSerializedObject.communicationTypeIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.communicationTypeIds = this.communicationTypeIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class CommunicationTypeService extends ServiceBase {\n\n public async getAllCommunicationTypes(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllCommunicationTypesRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllCommunicationTypesResponse(response).communicationTypes;\n return this.makeJsonRequest(\"communicationType/v1/getAllCommunicationTypes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getCommunicationType(tenantId: Guid, communicationTypeId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetCommunicationTypeRequest();\n req.tenantId = tenantId;\n req.communicationTypeId = communicationTypeId;\n const extractor = (response:any) => new GetCommunicationTypeResponse(response).communicationType;\n return this.makeJsonRequest(\"communicationType/v1/getCommunicationType\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getCommunicationTypes(tenantId: Guid, communicationTypeIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetCommunicationTypesRequest();\n req.tenantId = tenantId;\n req.communicationTypeIds = communicationTypeIds;\n const extractor = (response:any) => new GetCommunicationTypesResponse(response).communicationTypes;\n return this.makeJsonRequest(\"communicationType/v1/getCommunicationTypes\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveCommunicationType(tenantId: Guid, communicationType: CommunicationType, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveCommunicationTypeRequest();\n req.tenantId = tenantId;\n req.communicationType = communicationType;\n const extractor = null;\n return this.makeJsonRequest(\"communicationType/v1/saveCommunicationType\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setCommunicationTypeIsHidden(tenantId: Guid, communicationTypeId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetCommunicationTypeIsHiddenRequest();\n req.tenantId = tenantId;\n req.communicationTypeId = communicationTypeId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"communicationType/v1/setCommunicationTypeIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updateCommunicationTypesSequence(tenantId: Guid, communicationTypeIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdateCommunicationTypesSequenceRequest();\n req.tenantId = tenantId;\n req.communicationTypeIds = communicationTypeIds;\n const extractor = null;\n return this.makeJsonRequest(\"communicationType/v1/updateCommunicationTypesSequence\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const communicationTypeService = new CommunicationTypeService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { CommunicationType } from \"@/app/services/generated/communicationtypeService\";\nimport { communicationTypeService } from \"@/app/services/generated/communicationtypeService\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\n\n// Singleton cache store\nconst communicationTypesCacheStore = new EntityCacheStore(\n EnumCacheEntityType.communicationType,\n async () => communicationTypeService.getAllCommunicationTypes(api.tenantId)\n);\n\n// Ephemeral reader\nexport default class CommunicationTypesCache extends EntityWithGuidKeyCache {\n constructor() {\n super(communicationTypesCacheStore, (x) => x.id);\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class CommunicationSubjectReadOnly extends ModelObject {\n\n /**\n * Sequence for ordering communication subjects.\n */\n public sequence: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.sequence = jsonSerializedObject.sequence;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.sequence = this.sequence;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"sequence\", rule: (v: any) => v == null || v >= -2147483648 || \"Sequence is not greater than minimum allowed value: -2147483648\"},\n {field: \"sequence\", rule: (v: any) => v == null || v <= 2147483647 || \"Sequence is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class CommunicationSubject extends BaseModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Communication Subject Name\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public name: string = \"\";\n public isHidden: boolean = false;\n public readOnly: CommunicationSubjectReadOnly = new CommunicationSubjectReadOnly();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.name = jsonSerializedObject.name;\n this.isHidden = jsonSerializedObject.isHidden;\n this.readOnly = new CommunicationSubjectReadOnly(jsonSerializedObject.readOnly);\n }\n\n this.setDirtyCheckpoint();\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.name = this.name;\n toRet.isHidden = this.isHidden;\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"CommunicationSubject.Id cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length !== 0 || \"Name cannot be empty\"},\n {field: \"name\", rule: (v: any) => v == null || v.length <= 1000 || \"Name has too many characters (1000)\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n ];\n}\n\n\nexport class GetAllCommunicationSubjectsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllCommunicationSubjectsResponse extends ModelObject {\n\n public communicationSubjects: CommunicationSubject[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.communicationSubjects = jsonSerializedObject.communicationSubjects.map((v: any) => new CommunicationSubject(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.communicationSubjects = this.communicationSubjects.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"communicationSubjects\", rule: (v: any) => !!v || \"communicationSubjects is required\"},\n {field: \"communicationSubjects\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as CommunicationSubject[]).reduce((acc: Array, curr: CommunicationSubject) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetCommunicationSubjectRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public communicationSubjectId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.communicationSubjectId = Guid.fromString(jsonSerializedObject.communicationSubjectId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.communicationSubjectId = this.communicationSubjectId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"communicationSubjectId\", rule: (v: any) => !v.isEmpty() || \".CommunicationSubjectId cannot be empty\"},\n ];\n}\n\n\nexport class GetCommunicationSubjectResponse extends ModelObject {\n\n public communicationSubject: CommunicationSubject = new CommunicationSubject();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.communicationSubject = new CommunicationSubject(jsonSerializedObject.communicationSubject);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.communicationSubject = this.communicationSubject.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"communicationSubject\", rule: (v: any) => !!v || \"communicationSubject is required\"},\n {field: \"communicationSubject\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetCommunicationSubjectsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public communicationSubjectIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.communicationSubjectIds = jsonSerializedObject.communicationSubjectIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.communicationSubjectIds = this.communicationSubjectIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetCommunicationSubjectsResponse extends ModelObject {\n\n public communicationSubjects: CommunicationSubject[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.communicationSubjects = jsonSerializedObject.communicationSubjects.map((v: any) => new CommunicationSubject(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.communicationSubjects = this.communicationSubjects.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"communicationSubjects\", rule: (v: any) => !!v || \"communicationSubjects is required\"},\n {field: \"communicationSubjects\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as CommunicationSubject[]).reduce((acc: Array, curr: CommunicationSubject) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveCommunicationSubjectRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public communicationSubject: CommunicationSubject = new CommunicationSubject();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.communicationSubject = new CommunicationSubject(jsonSerializedObject.communicationSubject);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.communicationSubject = this.communicationSubject.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"communicationSubject\", rule: (v: any) => !!v || \"communicationSubject is required\"},\n {field: \"communicationSubject\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SetCommunicationSubjectIsHiddenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public communicationSubjectId: Guid = Guid.createEmpty();\n /**\n * True to hide, false to unhide.\n */\n public hide: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.communicationSubjectId = Guid.fromString(jsonSerializedObject.communicationSubjectId);\n this.hide = jsonSerializedObject.hide;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.communicationSubjectId = this.communicationSubjectId.toString();\n toRet.hide = this.hide;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"communicationSubjectId\", rule: (v: any) => !v.isEmpty() || \".CommunicationSubjectId cannot be empty\"},\n ];\n}\n\n\nexport class UpdateCommunicationSubjectsSequenceRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public communicationSubjectIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.communicationSubjectIds = jsonSerializedObject.communicationSubjectIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.communicationSubjectIds = this.communicationSubjectIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class CommunicationSubjectService extends ServiceBase {\n\n public async getAllCommunicationSubjects(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllCommunicationSubjectsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAllCommunicationSubjectsResponse(response).communicationSubjects;\n return this.makeJsonRequest(\"communicationSubject/v1/getAllCommunicationSubjects\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getCommunicationSubject(tenantId: Guid, communicationSubjectId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetCommunicationSubjectRequest();\n req.tenantId = tenantId;\n req.communicationSubjectId = communicationSubjectId;\n const extractor = (response:any) => new GetCommunicationSubjectResponse(response).communicationSubject;\n return this.makeJsonRequest(\"communicationSubject/v1/getCommunicationSubject\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getCommunicationSubjects(tenantId: Guid, communicationSubjectIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetCommunicationSubjectsRequest();\n req.tenantId = tenantId;\n req.communicationSubjectIds = communicationSubjectIds;\n const extractor = (response:any) => new GetCommunicationSubjectsResponse(response).communicationSubjects;\n return this.makeJsonRequest(\"communicationSubject/v1/getCommunicationSubjects\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveCommunicationSubject(tenantId: Guid, communicationSubject: CommunicationSubject, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveCommunicationSubjectRequest();\n req.tenantId = tenantId;\n req.communicationSubject = communicationSubject;\n const extractor = null;\n return this.makeJsonRequest(\"communicationSubject/v1/saveCommunicationSubject\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async setCommunicationSubjectIsHidden(tenantId: Guid, communicationSubjectId: Guid, hide: boolean, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SetCommunicationSubjectIsHiddenRequest();\n req.tenantId = tenantId;\n req.communicationSubjectId = communicationSubjectId;\n req.hide = hide;\n const extractor = null;\n return this.makeJsonRequest(\"communicationSubject/v1/setCommunicationSubjectIsHidden\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async updateCommunicationSubjectsSequence(tenantId: Guid, communicationSubjectIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new UpdateCommunicationSubjectsSequenceRequest();\n req.tenantId = tenantId;\n req.communicationSubjectIds = communicationSubjectIds;\n const extractor = null;\n return this.makeJsonRequest(\"communicationSubject/v1/updateCommunicationSubjectsSequence\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const communicationSubjectService = new CommunicationSubjectService();","import { EnumCacheEntityType } from \"@/app/services/generated/enums/enumCacheEntityType.generated\";\nimport api from \"@/app/api\";\nimport type { CommunicationSubject } from \"@/app/services/generated/communicationsubjectService\";\nimport { communicationSubjectService } from \"@/app/services/generated/communicationsubjectService\";\nimport {\n EntityWithGuidKeyCache,\n EntityCacheStore,\n} from \"@/app/caching/apiCache\";\n\n// Singleton cache store\nconst communicationSubjectsCacheStore =\n new EntityCacheStore(\n EnumCacheEntityType.communicationSubject,\n async () =>\n communicationSubjectService.getAllCommunicationSubjects(api.tenantId)\n );\n\n// Ephemeral reader\nexport default class CommunicationSubjectsCache extends EntityWithGuidKeyCache {\n constructor() {\n super(communicationSubjectsCacheStore, (x) => x.id);\n }\n}\n","import api from \"@/app/api\";\nimport { tenantService } from \"@/app/services/extensions/tenantServiceExtended\";\nimport { toGuidMap } from \"@/app/apiutils\";\nimport type BaseEnumType from \"@/app/services/baseEnumType\";\nimport type { ActivityLogEntry } from \"@/app/services/generated/activitylogService\";\nimport type { BmTask } from \"@/app/services/generated/bmtaskService\";\nimport { bmTaskService } from \"@/app/services/generated/bmtaskService\";\nimport type { CommunicationSubject } from \"@/app/services/generated/communicationsubjectService\";\nimport type { CommunicationType } from \"@/app/services/generated/communicationtypeService\";\nimport type { Credit } from \"@/app/services/generated/creditService\";\nimport { creditService } from \"@/app/services/generated/creditService\";\nimport { EnumActivityLogType } from \"@/app/services/generated/enums/enumActivityLogType.generated\";\nimport { EnumBmEntityType } from \"@/app/services/generated/enums/enumBmEntityType.generated\";\nimport { EnumCustomerHappinessRating } from \"@/app/services/generated/enums/enumCustomerHappinessRating.generated\";\nimport type { Order } from \"@/app/services/generated/orderService\";\nimport type { OutletCommunicationLogEntry } from \"@/app/services/generated/outletcommunicationlogService\";\nimport { outletCommunicationLogService } from \"@/app/services/generated/outletcommunicationlogService\";\nimport type { User } from \"@/app/services/generated/userService\";\nimport type Guid from \"@/app/types/common/guid\";\nimport { GuidMap, GuidSet } from \"@/app/types/common/guidcollections\";\nimport { mainMenu } from \"@/app/ui/navigation/mainMenu\";\nimport { salesMenu } from \"@/app/ui/navigation/salesMenu\";\nimport { translate, useI18n } from \"@/plugins/i18n\";\nimport type { Location } from \"vue-router\";\nimport { orderService } from \"@/app/services/extensions/orderServiceExtended\";\nimport { userService } from \"@/app/services/extensions/userServiceExtended\";\nimport type { LeadCommunicationLogEntry } from \"@/app/services/generated/leadcommunicationlogService\";\nimport { leadCommunicationLogService } from \"@/app/services/generated/leadcommunicationlogService\";\nimport CommunicationTypesCache from \"@/app/caching/caches/communicationTypesCache\";\nimport CommunicationSubjectsCache from \"@/app/caching/caches/communicationSubjectsCache\";\nimport apiCache from \"@/app/caching/apiCache\";\nimport Key from \"@/app/types/common/key\";\n\nconst { $t, $m } = useI18n();\n\ninterface ActivityAssociationLine {\n name?: string; // Appears in Bold:\n value: string;\n}\ninterface ActivityAssociation {\n textLines: ActivityAssociationLine[];\n route?: Location;\n name?: string;\n icon?: string;\n}\n\nexport interface ActivityLogCardType {\n refresh: () => Promise;\n}\n\nexport interface ActivityLogEntryCardType {\n timestampString: string;\n taskType: string;\n entityType: string;\n status: EnumLogEntryStatus | null;\n association: ActivityAssociation | null;\n}\n\nfunction getActivityLogStatus(logEntry: ActivityLogEntry) {\n switch (logEntry.activityLogType) {\n case EnumActivityLogType.creditCreated:\n case EnumActivityLogType.orderCreated:\n case EnumActivityLogType.taskCreated:\n return EnumLogEntryStatus.created;\n\n case EnumActivityLogType.creditCancelled:\n case EnumActivityLogType.orderCancelled:\n case EnumActivityLogType.taskCancelled:\n return EnumLogEntryStatus.cancelled;\n\n case EnumActivityLogType.creditCompleted:\n case EnumActivityLogType.orderCompleted:\n case EnumActivityLogType.taskCompleted:\n return EnumLogEntryStatus.completed;\n\n default:\n return null;\n }\n}\n\nfunction mapTaskToActivityAssociation(\n task: BmTask,\n users: GuidMap,\n status: EnumLogEntryStatus | null\n): ActivityAssociation {\n const textLines = [];\n if (status === EnumLogEntryStatus.created) {\n let dueDateTime = \"\";\n const assignedTo = task.assignedToUserId\n ? users.get(task.assignedToUserId)?.name ?? \"\"\n : $m.none;\n\n if (task.dueDate) {\n dueDateTime += \" \" + tenantService.formatDate(task.dueDate);\n }\n\n if (task.dueTime) {\n dueDateTime += \" \" + tenantService.formatTime(task.dueTime);\n }\n\n textLines.push(\n { name: $m.tasks_due.toString(), value: dueDateTime },\n { name: $m.tasks_assigned_to, value: assignedTo },\n { value: task.description },\n {\n name: $m.created_by,\n value: users.get(task.readOnly.createdByUserId)!.name,\n }\n );\n }\n\n if (status === EnumLogEntryStatus.cancelled) {\n textLines.push({\n name: $m.cancelled_by,\n value: users.get(task.readOnly.cancelledByUserId!)!.name,\n });\n }\n\n if (status === EnumLogEntryStatus.completed) {\n textLines.push({\n name: $m.completed_by,\n value: users.get(task.readOnly.completedByUserId!)!.name,\n });\n }\n\n return {\n textLines,\n icon: \"format_list_bulleted\",\n route: { name: mainMenu.tasks },\n name: $m.tasks,\n };\n}\n\nfunction getIconForHappinessRating(rating: EnumCustomerHappinessRating) {\n switch (rating) {\n case EnumCustomerHappinessRating.negative:\n return \"sentiment_very_dissatisfied\";\n\n case EnumCustomerHappinessRating.neutral:\n return \"sentiment_neutral\";\n\n case EnumCustomerHappinessRating.positive:\n return \"sentiment_very_satisfied\";\n }\n}\n\nfunction mapCommunicationLogToAssociation(\n log: OutletCommunicationLogEntry | LeadCommunicationLogEntry,\n users: GuidMap,\n types: GuidMap,\n subjects: GuidMap\n): ActivityAssociation {\n const textLines = [];\n textLines.push(\n {\n name: $m.crm_communication_type,\n value: types.get(log.communicationTypeId)!.name,\n },\n {\n name: $m.crm_subject,\n value: subjects.get(log.communicationSubjectId)!.name,\n },\n { value: log.description },\n {\n name: $m.created_by,\n value: users.get(log.userId)!.name,\n }\n );\n return {\n textLines,\n icon: getIconForHappinessRating(log.customerHappinessRating),\n };\n}\n\nfunction mapCreditToAssociation(\n credit: Credit,\n users: GuidMap,\n status: EnumLogEntryStatus | null\n): ActivityAssociation {\n const textLines = [];\n if (status === EnumLogEntryStatus.completed) {\n const creditTotal = credit.lines.reduce(\n (acc, line) =>\n acc +\n (line.readOnly?.lineNetPrice ?? 0) +\n (line.readOnly?.lineVat ?? 0),\n 0\n );\n textLines.push({\n name: $m.price_total,\n value: tenantService.formatCurrency(creditTotal),\n });\n }\n if (status === EnumLogEntryStatus.cancelled) {\n textLines.push({\n name: $m.cancelled_by,\n value: users.get(credit.header.readOnly!.cancelledByUserId!)!.name,\n });\n }\n return {\n textLines,\n icon: \"shopping_basket\",\n route: salesMenu.viewCreditNote(credit.header.readOnly!.id),\n name: credit.header.readOnly!.creditNumber,\n };\n}\n\nfunction mapOrderToAssociation(\n order: Order,\n users: GuidMap,\n status: EnumLogEntryStatus | null\n): ActivityAssociation {\n const textLines = [];\n if (status === EnumLogEntryStatus.completed) {\n const orderTotal = order.lines.reduce(\n (acc, line) => acc + line.readOnly.lineNetPrice + line.readOnly.lineVat,\n 0\n );\n textLines.push({\n name: $m.price_total,\n value: tenantService.formatCurrency(orderTotal),\n });\n }\n if (status === EnumLogEntryStatus.cancelled) {\n textLines.push({\n name: $m.cancelled_by,\n value: users.get(order.header.readOnly!.cancelledByUserId!)!.name,\n });\n }\n return {\n textLines,\n icon: \"shopping_basket\",\n route: salesMenu.viewOrder(order.header.readOnly!.id),\n name: order.header.readOnly!.orderNumber,\n };\n}\n\nconst cache = apiCache.buildCacheSet({\n communicationTypes: CommunicationTypesCache,\n communicationSubjects: CommunicationSubjectsCache,\n});\n\nexport async function fetchActivityLogDependencies(\n activityLogEntries: ActivityLogEntry[]\n) {\n const taskIds = new GuidSet();\n const outletCommunicationLogIds = new GuidSet();\n const leadCommunicationLogIds = new GuidSet();\n const creditIds = new GuidSet();\n const orderIds = new GuidSet();\n\n activityLogEntries.forEach((entry) => {\n if (!entry.relatedBmEntityId) {\n return;\n }\n\n switch (entry.relatedBmEntityType) {\n case EnumBmEntityType.bmTask:\n taskIds.add(entry.relatedBmEntityId);\n break;\n case EnumBmEntityType.communicationLogEntry:\n outletCommunicationLogIds.add(entry.relatedBmEntityId);\n break;\n case EnumBmEntityType.leadCommunicationLogEntry:\n leadCommunicationLogIds.add(entry.relatedBmEntityId);\n break;\n case EnumBmEntityType.credit:\n creditIds.add(entry.relatedBmEntityId);\n break;\n case EnumBmEntityType.order:\n orderIds.add(entry.relatedBmEntityId);\n break;\n }\n });\n\n const [tasks, logEntries, leadLogEntries, credits, orders, users] =\n await Promise.all([\n bmTaskService\n .getBmTasks(api.tenantId, Array.from(taskIds.values()))\n .then((tasks) => toGuidMap(tasks, (o) => o.id)),\n outletCommunicationLogService\n .getOutletLogEntries(\n api.tenantId,\n Array.from(outletCommunicationLogIds.values())\n )\n .then((outletCommunications) =>\n toGuidMap(outletCommunications, (o) => o.id)\n ),\n leadCommunicationLogService\n .getLeadLogEntries(\n api.tenantId,\n Array.from(leadCommunicationLogIds.values())\n )\n .then((leadCommunications) =>\n toGuidMap(leadCommunications, (l) => l.id)\n ),\n creditService\n .getCredits(api.tenantId, Array.from(creditIds.values()))\n .then(\n (credits) =>\n new GuidMap(\n credits.map((credit) => [credit.header.readOnly!.id, credit])\n )\n ),\n orderService\n .getOrders(api.tenantId, Array.from(orderIds.values()), false)\n .then(\n (orders) =>\n new GuidMap(\n orders.map((order) => [order.header.readOnly!.id, order])\n )\n ),\n // Not much benefit to getting specifics here\n userService\n .getAllUsers(api.tenantGroupId)\n .then((users) => toGuidMap(users, (o) => o.id)),\n cache.update(),\n ]);\n\n const types = toGuidMap(cache.communicationTypes.all, (item) => item.id);\n const subjects = toGuidMap(\n cache.communicationSubjects.all,\n (item) => item.id\n );\n\n return {\n tasks,\n logEntries,\n leadLogEntries,\n credits,\n orders,\n users,\n types,\n subjects,\n };\n}\n\nfunction getAssociationForEntity(\n entityType: EnumBmEntityType | null,\n entityId: Guid | null,\n status: EnumLogEntryStatus | null,\n tasks: GuidMap,\n logEntries: GuidMap,\n leadLogEntries: GuidMap,\n credits: GuidMap,\n orders: GuidMap,\n users: GuidMap,\n types: GuidMap,\n subjects: GuidMap\n) {\n if (!entityType || !entityId) {\n return null;\n }\n\n switch (entityType) {\n case EnumBmEntityType.bmTask:\n return mapTaskToActivityAssociation(tasks.get(entityId)!, users, status);\n case EnumBmEntityType.communicationLogEntry:\n return mapCommunicationLogToAssociation(\n logEntries.get(entityId)!,\n users,\n types,\n subjects\n );\n case EnumBmEntityType.leadCommunicationLogEntry:\n return mapCommunicationLogToAssociation(\n leadLogEntries.get(entityId)!,\n users,\n types,\n subjects\n );\n case EnumBmEntityType.credit: {\n const credit = credits.get(entityId)!;\n return mapCreditToAssociation(credit!, users, status);\n }\n case EnumBmEntityType.order: {\n const order = orders.get(entityId)!;\n return mapOrderToAssociation(order!, users, status);\n }\n default:\n return null;\n }\n}\n\nexport async function mapActivityLogEntries(\n activityLogEntries: ActivityLogEntry[]\n) {\n const {\n tasks,\n logEntries,\n leadLogEntries,\n credits,\n orders,\n users,\n types,\n subjects,\n } = await fetchActivityLogDependencies(activityLogEntries);\n\n return activityLogEntries.map((entry): ActivityLogEntryCardType => {\n const status = getActivityLogStatus(entry);\n const association = getAssociationForEntity(\n entry.relatedBmEntityType,\n entry.relatedBmEntityId,\n status,\n tasks,\n logEntries,\n leadLogEntries,\n credits,\n orders,\n users,\n types,\n subjects\n );\n\n return {\n timestampString: tenantService.formatDateTime(entry.timestamp),\n taskType: entry.activityLogType.translation,\n entityType: entry.relatedBmEntityType.translation,\n status,\n association,\n };\n });\n}\n\nexport class EnumLogEntryStatus implements BaseEnumType {\n private static allValues: EnumLogEntryStatus[] = []; // make sure this is top-most\n\n public static created = new EnumLogEntryStatus(\n 0,\n \"Created\",\n \"crm_log_created\",\n \"primary\",\n \"brand02\"\n );\n public static cancelled = new EnumLogEntryStatus(\n 1,\n \"Cancelled\",\n \"crm_log_cancelled\",\n \"error\",\n \"errorMedium\"\n );\n public static completed = new EnumLogEntryStatus(\n 2,\n \"Completed\",\n \"crm_log_completed\",\n \"success\"\n );\n\n public key: number;\n public value: string;\n public translationKey: string;\n public chipColour: string;\n public chipColourDark?: string;\n\n private constructor(\n key: number,\n value: string,\n translationKey: string,\n chipColour: string,\n chipColourDark?: string\n ) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n this.chipColour = chipColour;\n this.chipColourDark = chipColourDark;\n EnumLogEntryStatus.allValues.push(this);\n }\n\n public get translation() {\n return translate(Key.fromString(this.translationKey));\n }\n\n public static getValues(): EnumLogEntryStatus[] {\n return EnumLogEntryStatus.allValues;\n }\n\n public static getByKey(key: number): EnumLogEntryStatus {\n const found = EnumLogEntryStatus.allValues.find((e) => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumLogEntryStatus - Key not found: ${key}`);\n }\n\n return found;\n }\n}\n","import type BaseEnumType from \"@/app/services/baseEnumType\";\n\nimport { EnumAssemblyType } from \"@/app/services/generated/enums/enumAssemblyType.generated\";\nimport { keys } from \"@/plugins/i18n\";\n\nexport class EnumOutputMovementType implements BaseEnumType {\n private static allValues: EnumOutputMovementType[] = [];\n\n public static moveToBatch = new EnumOutputMovementType(\n 0,\n \"Move to Batch\",\n keys.assembly_move_to_batch.value,\n EnumAssemblyType.materialProduction\n );\n public static package = new EnumOutputMovementType(\n 1,\n \"Package\",\n keys.assembly_package.value,\n EnumAssemblyType.productPackaging\n );\n public static moveToStock = new EnumOutputMovementType(\n 2,\n \"Move to Stock\",\n keys.assembly_move_to_stock.value,\n undefined\n );\n\n public static scanAndFillTrackedContainers = new EnumOutputMovementType(\n 3,\n \"Scan and Fill Tracked Containers\",\n keys.assembly_scan_fill_tracked_containers.value,\n undefined\n );\n\n public key: number;\n public value: string;\n public translationKey: string;\n public assemblyType: EnumAssemblyType | undefined;\n\n private constructor(\n key: number,\n value: string,\n translationKey: string,\n assemblyType: EnumAssemblyType | undefined\n ) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n this.assemblyType = assemblyType;\n\n EnumOutputMovementType.allValues.push(this);\n }\n\n public static getValues(): EnumOutputMovementType[] {\n return EnumOutputMovementType.allValues;\n }\n\n public static getByKey(key: number): EnumOutputMovementType {\n const found = EnumOutputMovementType.allValues.find((e) => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumOutputMovementType - Key not found: ${key}`);\n }\n\n return found;\n }\n}\n","import type BaseEnumType from \"@/app/services/baseEnumType\";\n\nexport class EnumVesselSummaryView implements BaseEnumType {\n private static allValues: EnumVesselSummaryView[] = []; // make sure this is top-most\n\n public static standard = new EnumVesselSummaryView(\n 0,\n \"standard\",\n \"enum_vessel_summary_view_standard\"\n );\n\n public static compact = new EnumVesselSummaryView(\n 1,\n \"compact\",\n \"enum_vessel_summary_view_compact\"\n );\n\n public static list = new EnumVesselSummaryView(\n 2,\n \"list\",\n \"enum_vessel_summary_view_list\"\n );\n\n public key: number;\n public value: string;\n public translationKey?: string;\n\n private constructor(key: number, value: string, translationKey?: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumVesselSummaryView.allValues.push(this);\n }\n\n public static getValues(): EnumVesselSummaryView[] {\n return EnumVesselSummaryView.allValues;\n }\n\n public static getByKey(key: number): EnumVesselSummaryView {\n const found = EnumVesselSummaryView.allValues.find((e) => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumVesselSummaryView - Key not found: ${key}`);\n }\n\n return found;\n }\n}\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumVesselMovementSourceType } from \"./enums/enumVesselMovementSourceType.generated\";\nimport { EnumVesselMovementTargetType } from \"./enums/enumVesselMovementTargetType.generated\";\n\n// Model Objects\n\nexport class FromVesselDetails extends ModelObject {\n\n private _sourceAssemblyId: Guid | null = null;\n public get sourceAssemblyId(): Guid | null { return this._sourceAssemblyId }\n public set sourceAssemblyId(value: Guid | null) {\n this._sourceAssemblyId = value === undefined ? null : value;\n }\n private _sourceProcessId: Guid | null = null;\n public get sourceProcessId(): Guid | null { return this._sourceProcessId }\n public set sourceProcessId(value: Guid | null) {\n this._sourceProcessId = value === undefined ? null : value;\n }\n public sourceVesselId: Guid = Guid.createEmpty();\n public sourceLitresLeaving: number = 0;\n private _sourceFinalLitres: number | null = null;\n /**\n * Litres which remain in the source vessel, if measured. Optional even if SourceType=Vessel.\n */\n public get sourceFinalLitres(): number | null { return this._sourceFinalLitres }\n public set sourceFinalLitres(value: number | null) {\n this._sourceFinalLitres = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.sourceAssemblyId = jsonSerializedObject.sourceAssemblyId == null ? null : Guid.fromString(jsonSerializedObject.sourceAssemblyId);\n this.sourceProcessId = jsonSerializedObject.sourceProcessId == null ? null : Guid.fromString(jsonSerializedObject.sourceProcessId);\n this.sourceVesselId = Guid.fromString(jsonSerializedObject.sourceVesselId);\n this.sourceLitresLeaving = jsonSerializedObject.sourceLitresLeaving;\n this.sourceFinalLitres = jsonSerializedObject.sourceFinalLitres == null ? null : jsonSerializedObject.sourceFinalLitres;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.sourceAssemblyId = this.sourceAssemblyId == null ? null : this.sourceAssemblyId.toString();\n toRet.sourceProcessId = this.sourceProcessId == null ? null : this.sourceProcessId.toString();\n toRet.sourceVesselId = this.sourceVesselId.toString();\n toRet.sourceLitresLeaving = this.sourceLitresLeaving;\n toRet.sourceFinalLitres = this.sourceFinalLitres == null ? null : this.sourceFinalLitres;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"sourceAssemblyId\", rule: (v: any) => v == null || !v.isEmpty() || \"FromVesselDetails.SourceAssemblyId cannot be empty\"},\n {field: \"sourceProcessId\", rule: (v: any) => v == null || !v.isEmpty() || \"FromVesselDetails.SourceProcessId cannot be empty\"},\n {field: \"sourceVesselId\", rule: (v: any) => !v.isEmpty() || \"FromVesselDetails.SourceVesselId cannot be empty\"},\n ];\n}\n\n\nexport class ToVesselDetails extends ModelObject {\n\n private _targetAssemblyId: Guid | null = null;\n public get targetAssemblyId(): Guid | null { return this._targetAssemblyId }\n public set targetAssemblyId(value: Guid | null) {\n this._targetAssemblyId = value === undefined ? null : value;\n }\n public targetVesselId: Guid = Guid.createEmpty();\n public targetLitresArriving: number = 0;\n private _targetFinalLitres: number | null = null;\n /**\n * Litres which remain in the target vessel, if measured. Optional even if TargetType=Vessel.\n */\n public get targetFinalLitres(): number | null { return this._targetFinalLitres }\n public set targetFinalLitres(value: number | null) {\n this._targetFinalLitres = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.targetAssemblyId = jsonSerializedObject.targetAssemblyId == null ? null : Guid.fromString(jsonSerializedObject.targetAssemblyId);\n this.targetVesselId = Guid.fromString(jsonSerializedObject.targetVesselId);\n this.targetLitresArriving = jsonSerializedObject.targetLitresArriving;\n this.targetFinalLitres = jsonSerializedObject.targetFinalLitres == null ? null : jsonSerializedObject.targetFinalLitres;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.targetAssemblyId = this.targetAssemblyId == null ? null : this.targetAssemblyId.toString();\n toRet.targetVesselId = this.targetVesselId.toString();\n toRet.targetLitresArriving = this.targetLitresArriving;\n toRet.targetFinalLitres = this.targetFinalLitres == null ? null : this.targetFinalLitres;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"targetAssemblyId\", rule: (v: any) => v == null || !v.isEmpty() || \"ToVesselDetails.TargetAssemblyId cannot be empty\"},\n {field: \"targetVesselId\", rule: (v: any) => !v.isEmpty() || \"ToVesselDetails.TargetVesselId cannot be empty\"},\n ];\n}\n\n\nexport class VesselMovementReadOnly extends ModelObject {\n\n private _createdBy: Guid | null = null;\n /**\n * User who created this vessel movement. Captured by system not user editable.\n */\n public get createdBy(): Guid | null { return this._createdBy }\n public set createdBy(value: Guid | null) {\n this._createdBy = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.createdBy = jsonSerializedObject.createdBy == null ? null : Guid.fromString(jsonSerializedObject.createdBy);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.createdBy = this.createdBy == null ? null : this.createdBy.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"createdBy\", rule: (v: any) => v == null || !v.isEmpty() || \"VesselMovementReadOnly.CreatedBy cannot be empty\"},\n ];\n}\n\n\nexport class VesselMovement extends ModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n /**\n * Notes\n * Not Nullable\n * Max Length : 100000\n */\n public notes: string = \"\";\n /**\n * Source Type of movement. Either SourceType or TargetType or Both must be Vessel. : 0 = Ingredients, 1 = Vessel, 2 = Measurement\n */\n public sourceType: EnumVesselMovementSourceType = EnumVesselMovementSourceType.ingredients;\n /**\n * Target Type of movement. Either SourceType or TargetType or Both must be Vessel. : 0 = Drain, 1 = Vessel, 2 = Output\n */\n public targetType: EnumVesselMovementTargetType = EnumVesselMovementTargetType.drain;\n /**\n * Timestamp at which the movement occurred.\n */\n public timestamp: Instant = Instant.ofEpochMilli(0);\n private _targetProcessId: Guid | null = null;\n /**\n * Id of Target Process if this movement went to a vessel. Required if TargetType=Vessel.\n */\n public get targetProcessId(): Guid | null { return this._targetProcessId }\n public set targetProcessId(value: Guid | null) {\n this._targetProcessId = value === undefined ? null : value;\n }\n public readOnly: VesselMovementReadOnly = new VesselMovementReadOnly();\n private _fromVesselDetails: FromVesselDetails | null = null;\n /**\n * Details of the liquid leaving vessel. Required if SourceType=Vessel.\n */\n public get fromVesselDetails(): FromVesselDetails | null { return this._fromVesselDetails }\n public set fromVesselDetails(value: FromVesselDetails | null) {\n this._fromVesselDetails = value === undefined ? null : value;\n }\n private _toVesselDetails: ToVesselDetails | null = null;\n /**\n * Details of the liquid arriving vessel. Required if TargetType=Vessel.\n */\n public get toVesselDetails(): ToVesselDetails | null { return this._toVesselDetails }\n public set toVesselDetails(value: ToVesselDetails | null) {\n this._toVesselDetails = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.notes = jsonSerializedObject.notes;\n this.sourceType = EnumVesselMovementSourceType.getByValue(jsonSerializedObject.sourceType, this.sourceType);\n this.targetType = EnumVesselMovementTargetType.getByValue(jsonSerializedObject.targetType, this.targetType);\n this.timestamp = Instant.parse(jsonSerializedObject.timestamp);\n this.targetProcessId = jsonSerializedObject.targetProcessId == null ? null : Guid.fromString(jsonSerializedObject.targetProcessId);\n this.readOnly = new VesselMovementReadOnly(jsonSerializedObject.readOnly);\n this.fromVesselDetails = jsonSerializedObject.fromVesselDetails == null ? null : new FromVesselDetails(jsonSerializedObject.fromVesselDetails);\n this.toVesselDetails = jsonSerializedObject.toVesselDetails == null ? null : new ToVesselDetails(jsonSerializedObject.toVesselDetails);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.notes = this.notes;\n toRet.sourceType = this.sourceType.value;\n toRet.targetType = this.targetType.value;\n toRet.timestamp = this.timestamp.toString();\n toRet.targetProcessId = this.targetProcessId == null ? null : this.targetProcessId.toString();\n toRet.readOnly = this.readOnly.toJsonSerializedObject();\n toRet.fromVesselDetails = this.fromVesselDetails == null ? null : this.fromVesselDetails?.toJsonSerializedObject() ?? null;\n toRet.toVesselDetails = this.toVesselDetails == null ? null : this.toVesselDetails?.toJsonSerializedObject() ?? null;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"VesselMovement.Id cannot be empty\"},\n {field: \"notes\", rule: (v: any) => v == null || v.length <= 100000 || \"Notes has too many characters (100000)\"},\n {field: \"targetProcessId\", rule: (v: any) => v == null || !v.isEmpty() || \"VesselMovement.TargetProcessId cannot be empty\"},\n {field: \"readOnly\", rule: (v: any) => !!v || \"readOnly is required\"},\n {field: \"fromVesselDetails\", rule: (v: any) => (v === null) || v.validate()},\n {field: \"toVesselDetails\", rule: (v: any) => (v === null) || v.validate()},\n ];\n}\n\n\nexport class VesselMovementWithFinal extends ModelObject {\n\n public vesselMovement: VesselMovement = new VesselMovement();\n private _sourceExpectedFinalLitres: number | null = null;\n /**\n * The expected volume in the source vessel after the movement, if source is a vessel in the current assembly. Evaluated from the final litres (measured or expected) of the previous movement for the vessel and the SourceLitresLeaving.\n */\n public get sourceExpectedFinalLitres(): number | null { return this._sourceExpectedFinalLitres }\n public set sourceExpectedFinalLitres(value: number | null) {\n this._sourceExpectedFinalLitres = value === undefined ? null : value;\n }\n private _targetExpectedFinalLitres: number | null = null;\n /**\n * The volume in the target vessel after the movement, if target is a vessel in the current assembly. Evaluated from the final litres (measured or expected) of the previous movement for the vessel and the TargetLitresArriving.\n */\n public get targetExpectedFinalLitres(): number | null { return this._targetExpectedFinalLitres }\n public set targetExpectedFinalLitres(value: number | null) {\n this._targetExpectedFinalLitres = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vesselMovement = new VesselMovement(jsonSerializedObject.vesselMovement);\n this.sourceExpectedFinalLitres = jsonSerializedObject.sourceExpectedFinalLitres == null ? null : jsonSerializedObject.sourceExpectedFinalLitres;\n this.targetExpectedFinalLitres = jsonSerializedObject.targetExpectedFinalLitres == null ? null : jsonSerializedObject.targetExpectedFinalLitres;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vesselMovement = this.vesselMovement.toJsonSerializedObject();\n toRet.sourceExpectedFinalLitres = this.sourceExpectedFinalLitres == null ? null : this.sourceExpectedFinalLitres;\n toRet.targetExpectedFinalLitres = this.targetExpectedFinalLitres == null ? null : this.targetExpectedFinalLitres;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vesselMovement\", rule: (v: any) => !!v || \"vesselMovement is required\"},\n {field: \"vesselMovement\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class VesselMovementFilter extends ModelObject {\n\n private _maximumResults: number | null = null;\n public get maximumResults(): number | null { return this._maximumResults }\n public set maximumResults(value: number | null) {\n this._maximumResults = value === undefined ? null : value;\n }\n private _vesselIds: Guid[] | null = null;\n /**\n * Vessel to include\n */\n public get vesselIds(): Guid[] | null { return this._vesselIds }\n public set vesselIds(value: Guid[] | null) {\n this._vesselIds = value === undefined ? null : value;\n }\n private _fromMovementTimestamp: Instant | null = null;\n /**\n * Minimum (inclusive) movement timestamp\n */\n public get fromMovementTimestamp(): Instant | null { return this._fromMovementTimestamp }\n public set fromMovementTimestamp(value: Instant | null) {\n this._fromMovementTimestamp = value === undefined ? null : value;\n }\n private _toMovementTimestamp: Instant | null = null;\n /**\n * Maximum (inclusive) movement timestamp\n */\n public get toMovementTimestamp(): Instant | null { return this._toMovementTimestamp }\n public set toMovementTimestamp(value: Instant | null) {\n this._toMovementTimestamp = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.maximumResults = jsonSerializedObject.maximumResults == null ? null : jsonSerializedObject.maximumResults;\n this.vesselIds = jsonSerializedObject.vesselIds == null ? null : jsonSerializedObject.vesselIds.map((v: any) => Guid.fromString(v));\n this.fromMovementTimestamp = jsonSerializedObject.fromMovementTimestamp == null ? null : Instant.parse(jsonSerializedObject.fromMovementTimestamp);\n this.toMovementTimestamp = jsonSerializedObject.toMovementTimestamp == null ? null : Instant.parse(jsonSerializedObject.toMovementTimestamp);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.maximumResults = this.maximumResults == null ? null : this.maximumResults;\n toRet.vesselIds = this.vesselIds == null ? null : this.vesselIds.map(v => v.toString());\n toRet.fromMovementTimestamp = this.fromMovementTimestamp == null ? null : this.fromMovementTimestamp.toString();\n toRet.toMovementTimestamp = this.toMovementTimestamp == null ? null : this.toMovementTimestamp.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"maximumResults\", rule: (v: any) => v == null || v >= 0 || \"MaximumResults is not greater than minimum allowed value: 0\"},\n {field: \"maximumResults\", rule: (v: any) => v == null || v <= 2147483647 || \"MaximumResults is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class FilteredVesselMovementsResult extends ModelObject {\n\n public matchingCount: number = 0;\n public vesselMovements: VesselMovement[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.matchingCount = jsonSerializedObject.matchingCount;\n this.vesselMovements = jsonSerializedObject.vesselMovements.map((v: any) => new VesselMovement(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.matchingCount = this.matchingCount;\n toRet.vesselMovements = this.vesselMovements.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"matchingCount\", rule: (v: any) => v == null || v >= -2147483648 || \"MatchingCount is not greater than minimum allowed value: -2147483648\"},\n {field: \"matchingCount\", rule: (v: any) => v == null || v <= 2147483647 || \"MatchingCount is above maximum allowed value: 2147483647\"},\n {field: \"vesselMovements\", rule: (v: any) => !!v || \"vesselMovements is required\"},\n {field: \"vesselMovements\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as VesselMovement[]).reduce((acc: Array, curr: VesselMovement) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class VesselContentVolume extends ModelObject {\n\n public vesselId: Guid = Guid.createEmpty();\n private _assemblyId: Guid | null = null;\n public get assemblyId(): Guid | null { return this._assemblyId }\n public set assemblyId(value: Guid | null) {\n this._assemblyId = value === undefined ? null : value;\n }\n private _processId: Guid | null = null;\n public get processId(): Guid | null { return this._processId }\n public set processId(value: Guid | null) {\n this._processId = value === undefined ? null : value;\n }\n public currentLitres: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vesselId = Guid.fromString(jsonSerializedObject.vesselId);\n this.assemblyId = jsonSerializedObject.assemblyId == null ? null : Guid.fromString(jsonSerializedObject.assemblyId);\n this.processId = jsonSerializedObject.processId == null ? null : Guid.fromString(jsonSerializedObject.processId);\n this.currentLitres = jsonSerializedObject.currentLitres;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vesselId = this.vesselId.toString();\n toRet.assemblyId = this.assemblyId == null ? null : this.assemblyId.toString();\n toRet.processId = this.processId == null ? null : this.processId.toString();\n toRet.currentLitres = this.currentLitres;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vesselId\", rule: (v: any) => !v.isEmpty() || \"VesselContentVolume.VesselId cannot be empty\"},\n {field: \"assemblyId\", rule: (v: any) => v == null || !v.isEmpty() || \"VesselContentVolume.AssemblyId cannot be empty\"},\n {field: \"processId\", rule: (v: any) => v == null || !v.isEmpty() || \"VesselContentVolume.ProcessId cannot be empty\"},\n ];\n}\n\n\nexport class VesselAssemblyCount extends ModelObject {\n\n public vesselId: Guid = Guid.createEmpty();\n /**\n * The number of different assemblies which the vessel has been filled within.\n */\n public countOfAssemblies: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vesselId = Guid.fromString(jsonSerializedObject.vesselId);\n this.countOfAssemblies = jsonSerializedObject.countOfAssemblies;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vesselId = this.vesselId.toString();\n toRet.countOfAssemblies = this.countOfAssemblies;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vesselId\", rule: (v: any) => !v.isEmpty() || \"VesselAssemblyCount.VesselId cannot be empty\"},\n {field: \"countOfAssemblies\", rule: (v: any) => v == null || v >= -2147483648 || \"CountOfAssemblies is not greater than minimum allowed value: -2147483648\"},\n {field: \"countOfAssemblies\", rule: (v: any) => v == null || v <= 2147483647 || \"CountOfAssemblies is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class VesselProcessCount extends ModelObject {\n\n public vesselId: Guid = Guid.createEmpty();\n /**\n * The number of different processes which the vessel has been filled within.\n */\n public countOfProcess: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vesselId = Guid.fromString(jsonSerializedObject.vesselId);\n this.countOfProcess = jsonSerializedObject.countOfProcess;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vesselId = this.vesselId.toString();\n toRet.countOfProcess = this.countOfProcess;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vesselId\", rule: (v: any) => !v.isEmpty() || \"VesselProcessCount.VesselId cannot be empty\"},\n {field: \"countOfProcess\", rule: (v: any) => v == null || v >= -2147483648 || \"CountOfProcess is not greater than minimum allowed value: -2147483648\"},\n {field: \"countOfProcess\", rule: (v: any) => v == null || v <= 2147483647 || \"CountOfProcess is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class GetVesselMovementsForAssemblyRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public assemblyId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.assemblyId = Guid.fromString(jsonSerializedObject.assemblyId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.assemblyId = this.assemblyId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"assemblyId\", rule: (v: any) => !v.isEmpty() || \".AssemblyId cannot be empty\"},\n ];\n}\n\n\nexport class GetVesselMovementsForAssemblyResponse extends ModelObject {\n\n /**\n * Movements affecting this assembly (either source or target), ordered by timestamp. Final volumes will be provided for each movement where the source / target is a vessel within this assembly.\n */\n public results: VesselMovementWithFinal[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new VesselMovementWithFinal(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as VesselMovementWithFinal[]).reduce((acc: Array, curr: VesselMovementWithFinal) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class SaveVesselMovementRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vesselMovement: VesselMovement = new VesselMovement();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vesselMovement = new VesselMovement(jsonSerializedObject.vesselMovement);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vesselMovement = this.vesselMovement.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"vesselMovement\", rule: (v: any) => !!v || \"vesselMovement is required\"},\n {field: \"vesselMovement\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetVesselMovementsByFilterRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public filter: VesselMovementFilter = new VesselMovementFilter();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.filter = new VesselMovementFilter(jsonSerializedObject.filter);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.filter = this.filter.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"filter\", rule: (v: any) => !!v || \"filter is required\"},\n {field: \"filter\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetVesselMovementsByFilterResponse extends ModelObject {\n\n public results: FilteredVesselMovementsResult = new FilteredVesselMovementsResult();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = new FilteredVesselMovementsResult(jsonSerializedObject.results);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class GetContentVolumesOfAllVesselsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetContentVolumesOfAllVesselsResponse extends ModelObject {\n\n public vesselVolumes: VesselContentVolume[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vesselVolumes = jsonSerializedObject.vesselVolumes.map((v: any) => new VesselContentVolume(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vesselVolumes = this.vesselVolumes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vesselVolumes\", rule: (v: any) => !!v || \"vesselVolumes is required\"},\n {field: \"vesselVolumes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as VesselContentVolume[]).reduce((acc: Array, curr: VesselContentVolume) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetContentVolumesOfVesselsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vesselIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vesselIds = jsonSerializedObject.vesselIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vesselIds = this.vesselIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetContentVolumesOfVesselsResponse extends ModelObject {\n\n public vesselVolumes: VesselContentVolume[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.vesselVolumes = jsonSerializedObject.vesselVolumes.map((v: any) => new VesselContentVolume(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.vesselVolumes = this.vesselVolumes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"vesselVolumes\", rule: (v: any) => !!v || \"vesselVolumes is required\"},\n {field: \"vesselVolumes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as VesselContentVolume[]).reduce((acc: Array, curr: VesselContentVolume) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetCountOfAssembliesForVesselsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vesselIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vesselIds = jsonSerializedObject.vesselIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vesselIds = this.vesselIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetCountOfAssembliesForVesselsResponse extends ModelObject {\n\n public counts: VesselAssemblyCount[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.counts = jsonSerializedObject.counts.map((v: any) => new VesselAssemblyCount(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.counts = this.counts.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"counts\", rule: (v: any) => !!v || \"counts is required\"},\n {field: \"counts\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as VesselAssemblyCount[]).reduce((acc: Array, curr: VesselAssemblyCount) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetVesselMovementsForProcessRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public processId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.processId = Guid.fromString(jsonSerializedObject.processId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.processId = this.processId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"processId\", rule: (v: any) => !v.isEmpty() || \".ProcessId cannot be empty\"},\n ];\n}\n\n\nexport class GetVesselMovementsForProcessResponse extends ModelObject {\n\n /**\n * Movements affecting this process (either source or target), ordered by timestamp. Final volumes will be provided for each movement where the source / target is a vessel within this process.\n */\n public results: VesselMovementWithFinal[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.results = jsonSerializedObject.results.map((v: any) => new VesselMovementWithFinal(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.results = this.results.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"results\", rule: (v: any) => !!v || \"results is required\"},\n {field: \"results\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as VesselMovementWithFinal[]).reduce((acc: Array, curr: VesselMovementWithFinal) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GetCountOfProcessesForVesselsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public vesselIds: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.vesselIds = jsonSerializedObject.vesselIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.vesselIds = this.vesselIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetCountOfProcessesForVesselsResponse extends ModelObject {\n\n public counts: VesselProcessCount[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.counts = jsonSerializedObject.counts.map((v: any) => new VesselProcessCount(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.counts = this.counts.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"counts\", rule: (v: any) => !!v || \"counts is required\"},\n {field: \"counts\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as VesselProcessCount[]).reduce((acc: Array, curr: VesselProcessCount) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class VesselMovementService extends ServiceBase {\n\n public async getVesselMovementsForAssembly(tenantId: Guid, assemblyId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetVesselMovementsForAssemblyRequest();\n req.tenantId = tenantId;\n req.assemblyId = assemblyId;\n const extractor = (response:any) => new GetVesselMovementsForAssemblyResponse(response).results;\n return this.makeJsonRequest(\"vesselMovement/v1/getVesselMovementsForAssembly\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveVesselMovement(tenantId: Guid, vesselMovement: VesselMovement, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveVesselMovementRequest();\n req.tenantId = tenantId;\n req.vesselMovement = vesselMovement;\n const extractor = null;\n return this.makeJsonRequest(\"vesselMovement/v1/saveVesselMovement\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getVesselMovementsByFilter(tenantId: Guid, filter: VesselMovementFilter, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetVesselMovementsByFilterRequest();\n req.tenantId = tenantId;\n req.filter = filter;\n const extractor = (response:any) => new GetVesselMovementsByFilterResponse(response).results;\n return this.makeJsonRequest(\"vesselMovement/v1/getVesselMovementsByFilter\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getContentVolumesOfAllVessels(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetContentVolumesOfAllVesselsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetContentVolumesOfAllVesselsResponse(response).vesselVolumes;\n return this.makeJsonRequest(\"vesselMovement/v1/getContentVolumesOfAllVessels\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getContentVolumesOfVessels(tenantId: Guid, vesselIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetContentVolumesOfVesselsRequest();\n req.tenantId = tenantId;\n req.vesselIds = vesselIds;\n const extractor = (response:any) => new GetContentVolumesOfVesselsResponse(response).vesselVolumes;\n return this.makeJsonRequest(\"vesselMovement/v1/getContentVolumesOfVessels\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getCountOfAssembliesForVessels(tenantId: Guid, vesselIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetCountOfAssembliesForVesselsRequest();\n req.tenantId = tenantId;\n req.vesselIds = vesselIds;\n const extractor = (response:any) => new GetCountOfAssembliesForVesselsResponse(response).counts;\n return this.makeJsonRequest(\"vesselMovement/v1/getCountOfAssembliesForVessels\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getVesselMovementsForProcess(tenantId: Guid, processId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetVesselMovementsForProcessRequest();\n req.tenantId = tenantId;\n req.processId = processId;\n const extractor = (response:any) => new GetVesselMovementsForProcessResponse(response).results;\n return this.makeJsonRequest(\"vesselMovement/v1/getVesselMovementsForProcess\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getCountOfProcessesForVessels(tenantId: Guid, vesselIds: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetCountOfProcessesForVesselsRequest();\n req.tenantId = tenantId;\n req.vesselIds = vesselIds;\n const extractor = (response:any) => new GetCountOfProcessesForVesselsResponse(response).counts;\n return this.makeJsonRequest(\"vesselMovement/v1/getCountOfProcessesForVessels\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const vesselMovementService = new VesselMovementService();","import type BaseEnumType from \"@/app/services/baseEnumType\";\nimport { EnumVesselMovementSourceType } from \"@/app/services/generated/enums/enumVesselMovementSourceType.generated\";\nimport { EnumVesselMovementTargetType } from \"@/app/services/generated/enums/enumVesselMovementTargetType.generated\";\nimport type { VesselMovement } from \"@/app/services/generated/vesselmovementService\";\nimport { ToVesselDetails } from \"@/app/services/generated/vesselmovementService\";\nimport Key from \"@/app/types/common/key\";\nimport { translate } from \"@/plugins/i18n\";\nimport { useRuleSets } from \"@/plugins/validation\";\nimport type { Ref } from \"vue\";\nimport { computed, ref, watch } from \"vue\";\n\nexport function movementTypeRequiresToVessel(\n type: EnumVesselMovementType,\n optionalOutputChosen: boolean\n) {\n switch (type) {\n case EnumVesselMovementType.updateVolume:\n case EnumVesselMovementType.vesselToVessel:\n case EnumVesselMovementType.addIngredientsToVessel:\n return true;\n\n case EnumVesselMovementType.vesselToExistingBatch:\n case EnumVesselMovementType.vesselToExistingPackaging:\n case EnumVesselMovementType.vesselToNewBatch:\n case EnumVesselMovementType.vesselToNewPackaging:\n return optionalOutputChosen;\n\n default:\n return false;\n }\n}\n\nexport function movementTypeRequiresFromVessel(type: EnumVesselMovementType) {\n return type.sourceType.isVessel();\n}\n\nexport function useVesselMovementState(\n vesselMovement: Ref,\n vesselMovementType: Ref\n) {\n const { ruleSet } = useRuleSets();\n const includeVesselMovementWithOutput = ref(\n vesselMovementType.value.prefersToTargetVessel\n );\n\n const movementRequiresToVessel = computed(() =>\n movementTypeRequiresToVessel(\n vesselMovementType.value,\n includeVesselMovementWithOutput.value\n )\n );\n\n const movementRequiresFromVessel = computed(() =>\n movementTypeRequiresFromVessel(vesselMovementType.value)\n );\n\n // Require at least sourceFinalLitres or sourceLitresLeaving to be defined at minimum\n const fromVesselVolumeIsRequired = computed(() => {\n return vesselMovement.value.fromVesselDetails?.sourceFinalLitres ??\n vesselMovement.value.fromVesselDetails?.sourceLitresLeaving\n ? []\n : [ruleSet.required()];\n });\n\n // Require one of targetFinalLitres or targetLitresArriving to be defined at minimum\n const toVesselVolumeIsRequired = computed(() => {\n return !vesselMovement.value.toVesselDetails?.targetFinalLitres &&\n !vesselMovement.value.toVesselDetails?.targetLitresArriving\n ? [ruleSet.required()]\n : [];\n });\n\n // If we are in double\n const vesselMovementSectionColumns = computed(() => {\n switch (vesselMovementType.value) {\n case EnumVesselMovementType.vesselToVessel:\n case EnumVesselMovementType.vesselToExistingBatch:\n case EnumVesselMovementType.vesselToExistingPackaging:\n case EnumVesselMovementType.vesselToNewBatch:\n case EnumVesselMovementType.vesselToNewPackaging:\n return 6;\n\n default:\n return 12;\n }\n });\n\n const lockMovementToMeasuredVolumeOnly = computed(\n () => vesselMovementType.value === EnumVesselMovementType.updateVolume\n );\n\n const vesselMovementIsToExternalAssembly = computed(() => {\n switch (vesselMovementType.value) {\n case EnumVesselMovementType.vesselToExistingBatch:\n case EnumVesselMovementType.vesselToExistingPackaging:\n case EnumVesselMovementType.vesselToNewBatch:\n case EnumVesselMovementType.vesselToNewPackaging:\n return true;\n\n default:\n return false;\n }\n });\n\n const vesselMovementIsOptional = computed(() => {\n switch (vesselMovementType.value) {\n case EnumVesselMovementType.vesselToExistingBatch:\n case EnumVesselMovementType.vesselToExistingPackaging:\n case EnumVesselMovementType.vesselToNewBatch:\n case EnumVesselMovementType.vesselToNewPackaging:\n return true;\n\n default:\n return false;\n }\n });\n\n watch(includeVesselMovementWithOutput, () => {\n if (includeVesselMovementWithOutput.value) {\n vesselMovement.value.toVesselDetails = new ToVesselDetails();\n vesselMovement.value.targetType = EnumVesselMovementTargetType.vessel;\n vesselMovement.value.toVesselDetails.targetLitresArriving =\n vesselMovement.value.fromVesselDetails?.sourceLitresLeaving ?? 0;\n } else {\n vesselMovement.value.toVesselDetails = null;\n vesselMovement.value.targetType = EnumVesselMovementTargetType.output;\n }\n });\n\n return {\n // Boolean state vars\n movementRequiresFromVessel,\n movementRequiresToVessel,\n lockMovementToMeasuredVolumeOnly,\n vesselMovementIsToExternalAssembly,\n vesselMovementIsOptional,\n includeVesselMovementWithOutput,\n\n // Rulesets for controls\n fromVesselVolumeIsRequired,\n toVesselVolumeIsRequired,\n\n // Columns\n vesselMovementSectionColumns,\n };\n}\n\nexport class EnumVesselMovementType implements BaseEnumType {\n private static allValues: EnumVesselMovementType[] = [];\n\n public static vesselToVessel = new EnumVesselMovementType(\n 0,\n \"Vessel To Vessel\",\n \"vessel_logs_add_vessel_movement\",\n EnumVesselMovementSourceType.vessel,\n EnumVesselMovementTargetType.vessel,\n true,\n false,\n true\n );\n public static updateVolume = new EnumVesselMovementType(\n 1,\n \"Update Volume\",\n \"vessel_logs_update_volume\",\n EnumVesselMovementSourceType.measurement,\n EnumVesselMovementTargetType.vessel,\n false,\n false,\n true\n );\n public static addIngredientsToVessel = new EnumVesselMovementType(\n 2,\n \"Ingredients to Vessel\",\n \"vessel_logs_add_ingredients_to_vessel\",\n EnumVesselMovementSourceType.ingredients,\n EnumVesselMovementTargetType.vessel,\n false,\n false,\n true\n );\n public static addOutput = new EnumVesselMovementType(\n 3,\n \"Vessel Output\",\n \"vessel_logs_output\",\n EnumVesselMovementSourceType.vessel,\n EnumVesselMovementTargetType.output,\n false,\n true,\n false\n );\n public static vesselToExistingBatch = new EnumVesselMovementType(\n 4,\n \"Vessel To Existing Batch\",\n \"vessel_logs_add_vessel_movement\",\n EnumVesselMovementSourceType.vessel,\n EnumVesselMovementTargetType.output,\n true,\n true,\n true\n );\n public static vesselToExistingPackaging = new EnumVesselMovementType(\n 5,\n \"Vessel To Existing Packaging\",\n \"vessel_logs_add_vessel_movement\",\n EnumVesselMovementSourceType.vessel,\n EnumVesselMovementTargetType.output,\n true,\n true,\n false\n );\n public static vesselToNewBatch = new EnumVesselMovementType(\n 6,\n \"Vessel To New Batch\",\n \"vessel_logs_add_vessel_movement\",\n EnumVesselMovementSourceType.vessel,\n EnumVesselMovementTargetType.output,\n true,\n true,\n true\n );\n public static vesselToNewPackaging = new EnumVesselMovementType(\n 7,\n \"Vessel To New Packaging\",\n \"vessel_logs_add_vessel_movement\",\n EnumVesselMovementSourceType.vessel,\n EnumVesselMovementTargetType.output,\n true,\n true,\n false\n );\n\n public key: number;\n public value: string;\n public translationKey: string;\n public sourceType: EnumVesselMovementSourceType;\n public targetType: EnumVesselMovementTargetType;\n public hasInterVesselMovement: boolean;\n public isOutputtingMovement: boolean;\n public prefersToTargetVessel: boolean;\n\n private constructor(\n key: number,\n value: string,\n translationKey: string,\n sourceType: EnumVesselMovementSourceType,\n targetType: EnumVesselMovementTargetType,\n hasInterVesselMovement: boolean,\n isOutputtingMovement: boolean,\n prefersToTargetVessel: boolean\n ) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n this.sourceType = sourceType;\n this.targetType = targetType;\n this.hasInterVesselMovement = hasInterVesselMovement;\n this.isOutputtingMovement = isOutputtingMovement;\n this.prefersToTargetVessel = prefersToTargetVessel;\n EnumVesselMovementType.allValues.push(this);\n }\n\n public get translation() {\n return translate(Key.fromString(this.translationKey));\n }\n\n public static getValues(): EnumVesselMovementType[] {\n return EnumVesselMovementType.allValues;\n }\n\n public static getByKey(key: number): EnumVesselMovementType {\n const found = EnumVesselMovementType.allValues.find((e) => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumVesselMovementType - Key not found: ${key}`);\n }\n\n return found;\n }\n}\n","import type BaseEnumType from \"@/app/services/baseEnumType\";\n\nexport class EnumCostPriceUpdateStrategyType implements BaseEnumType {\n private static allValues: EnumCostPriceUpdateStrategyType[] = []; // make sure this is top-most\n\n /**\n * Suggests the latest cost price seen for a stock item as the new cost price.\n */\n public static latestCostPrice = new EnumCostPriceUpdateStrategyType(\n 0,\n \"LatestCostPrice\",\n \"enum_cost_price_update_strategy_latest\"\n );\n\n /**\n * \"The Deya model\"\n *\n * Suggested cost price comes from applying the new cost price and quantity on top\n * of the current stock price and in-stock quantity. The effect on the cost price\n * will be proportional to the amount of stock being \"diluted\" into the main stock\n * pool.\n *\n * e.g. Current stock (qty=100, unitcostprice=10), New stock being applied (qty=10, unitcostprice=20)\n * New suggested cost price = (100*10 + 10*20) / 110 = 10.91.\n */\n public static runningAverageCostPrice = new EnumCostPriceUpdateStrategyType(\n 1,\n \"RunningAverageCostPrice\",\n \"enum_cost_price_update_strategy_running_average\"\n );\n\n public key: number;\n public value: string;\n public translationKey?: string;\n\n private constructor(key: number, value: string, translationKey?: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumCostPriceUpdateStrategyType.allValues.push(this);\n }\n\n public static getValues(): EnumCostPriceUpdateStrategyType[] {\n return EnumCostPriceUpdateStrategyType.allValues;\n }\n\n public static getByKey(key: number): EnumCostPriceUpdateStrategyType {\n const found = EnumCostPriceUpdateStrategyType.allValues.find(\n (e) => e.key === key\n );\n if (found === undefined) {\n throw new Error(\n `EnumCostPriceUpdateStrategyType - Key not found: ${key}`\n );\n }\n\n return found;\n }\n}\n","import type BaseEnumType from \"@/app/services/baseEnumType\";\n\nexport class EnumStockType implements BaseEnumType {\n private static allValues: EnumStockType[] = []; // make sure this is top-most\n\n public static all = new EnumStockType(\n 0,\n \"All\",\n \"enum_stock_take_stock_type_all\"\n );\n public static materials = new EnumStockType(\n 1,\n \"Materials\",\n \"enum_stock_take_stock_type_materials\"\n );\n public static products = new EnumStockType(\n 2,\n \"Products\",\n \"enum_stock_take_stock_type_products\"\n );\n\n public key: number;\n public value: string;\n public translationKey?: string;\n\n private constructor(key: number, value: string, translationKey?: string) {\n this.key = key;\n this.value = value;\n this.translationKey = translationKey;\n EnumStockType.allValues.push(this);\n }\n\n public static getValues(): EnumStockType[] {\n return EnumStockType.allValues;\n }\n\n public static getByKey(key: number): EnumStockType {\n const found = EnumStockType.allValues.find((e) => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumStockType - Key not found: ${key}`);\n }\n\n return found;\n }\n}\n","import type BaseEnumType from \"@/app/services/baseEnumType\";\n\nexport class EnumCompanyFeatureFlag implements BaseEnumType {\n private static allValues: EnumCompanyFeatureFlag[] = [];\n\n public static bottleDeposit = new EnumCompanyFeatureFlag(\n 0,\n \"enum_company_feature_bottle_deposit\"\n );\n\n public key: number;\n public value: string;\n\n private constructor(key: number, value: string) {\n this.key = key;\n this.value = value;\n EnumCompanyFeatureFlag.allValues.push(this);\n }\n\n public static getValues(): EnumCompanyFeatureFlag[] {\n return EnumCompanyFeatureFlag.allValues;\n }\n\n public static getByKey(key: number): EnumCompanyFeatureFlag {\n const found = EnumCompanyFeatureFlag.allValues.find((e) => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumCompanyFeatureFlag - Key not found: ${key}`);\n }\n\n return found;\n }\n}\n","import type BaseEnumType from \"@/app/services/baseEnumType\";\n\nexport class EnumStopListItem implements BaseEnumType {\n private static allValues: EnumStopListItem[] = [];\n\n public static delivery = new EnumStopListItem(\n 0,\n \"delivery_app_delivery\",\n \"delivery_app_start_delivery\",\n \"delivery_app_edit_delivery\",\n \"delivery_app_complete_delivery\",\n \"delivery_app_unable_to_deliver\"\n );\n public static visit = new EnumStopListItem(\n 1,\n \"delivery_app_visit\",\n \"delivery_app_start_visit\",\n \"delivery_app_edit_visit\",\n \"delivery_app_complete_visit\",\n \"delivery_app_unable_to_visit\"\n );\n public static pickup = new EnumStopListItem(\n 2,\n \"delivery_app_pickup\",\n \"delivery_app_start_pickup\",\n \"delivery_app_edit_pickup\",\n \"delivery_app_complete_pickup\",\n \"delivery_app_unable_to_pickup\"\n );\n\n public key: number;\n public value: string;\n public startKey: string;\n public editKey: string;\n public completeKey: string;\n public unableKey: string;\n\n private constructor(\n key: number,\n value: string,\n startKey: string,\n editKey: string,\n completeKey: string,\n unableKey: string\n ) {\n this.key = key;\n this.value = value;\n this.startKey = startKey;\n this.editKey = editKey;\n this.completeKey = completeKey;\n this.unableKey = unableKey;\n EnumStopListItem.allValues.push(this);\n }\n\n public static getValues(): EnumStopListItem[] {\n return EnumStopListItem.allValues;\n }\n\n public static getByKey(key: number): EnumStopListItem {\n const found = EnumStopListItem.allValues.find((e) => e.key === key);\n if (found === undefined) {\n throw new Error(`EnumStopListItem - Key not found: ${key}`);\n }\n\n return found;\n }\n}\n","import { toMap } from \"@/app/apiutils\";\nimport { EnumLocaleAwareField } from \"@/app/services/extensions/localisationServiceExtended\";\nimport { EnumBusinessType } from \"@/app/services/extensions/suppliermanufacturerServiceExtended\";\nimport { getAllGeneratedEnumValues } from \"@/app/services/generated/enums/registerEnumValues.generated\";\nimport { EnumDistributionStatus } from \"@/app/types/common/distribution\";\nimport { EnumListItemStatus } from \"@/components/controls/listselector/BmListTypes\";\nimport { EnumSnackbarType } from \"@/components/controls/snackbar/SnackbarTypes\";\nimport { EnumDialogType } from \"@/components/dialogs/DialogTypes\";\nimport EnumUserPermissionAccess from \"@/components/pages/administration/user_roles/EnumUserPermissionAccess\";\nimport { EnumProcessOutputMovementType } from \"@/components/pages/batches/composables/processOutputMovementType\";\nimport {\n EnumDistributionItemAction,\n EnumDistributionItemType,\n} from \"@/components/pages/distribution/types\";\nimport { EnumIntegrationStatus } from \"@/components/pages/integrations/types\";\nimport { EnumChangelogEntryType } from \"@/components/pages/news/enumChangelogEntryType\";\nimport { EnumCommunicationLogLineType } from \"@/components/pages/outlet/communications/types\";\nimport { EnumLogEntryStatus } from \"@/components/pages/outlet/crm/subcomponents/activityLogEntryCard\";\nimport { EnumOutputMovementType } from \"@/components/pages/production/assemblies/composables/enumOutputMovementType\";\nimport { EnumVesselSummaryView } from \"@/components/pages/production/vessels/enumVesselSummaryView\";\nimport { EnumVesselMovementType } from \"@/components/pages/production/vessels/logs/composables/vesselMovementState\";\nimport { EnumCostPriceUpdateStrategyType } from \"@/components/pages/stock/costpriceupdater/enumCostPriceUpdateStrategyType\";\nimport { EnumStockType } from \"@/components/pages/stock/stocktake/enumStockType\";\nimport { translate } from \"@/plugins/i18n\";\nimport { EnumCompanyFeatureFlag } from \"@da/state/companyFeaturesEnum\";\nimport { EnumStopListItem } from \"@da/state/daStopListTypes\";\n\nlet valuesByEnumName: Map | null = null;\n\nexport interface IEnumReviver {\n getByKey: (key: number) => BaseEnumType | null;\n}\n\nexport default interface BaseEnumType {\n key: number;\n value: string;\n translationKey?: string;\n}\n\n// Very crude implementation of isEnum - Would like a better way to do this\nexport function isEnum(item: any): item is BaseEnumType {\n return item.key !== undefined && item.value !== undefined;\n}\n\nfunction formAllEnumValueRegistry() {\n const generatedEnumValues = getAllGeneratedEnumValues();\n\n const craftedEnumValues: readonly BaseEnumType[] = [\n EnumLocaleAwareField.getValues(),\n EnumBusinessType.getValues(),\n EnumDistributionStatus.getValues(),\n EnumListItemStatus.getValues(),\n EnumSnackbarType.getValues(),\n EnumDialogType.getValues(),\n EnumUserPermissionAccess.getValues(),\n EnumProcessOutputMovementType.getValues(),\n EnumDistributionItemAction.getValues(),\n EnumDistributionItemType.getValues(),\n EnumIntegrationStatus.getValues(),\n EnumChangelogEntryType.getValues(),\n EnumCommunicationLogLineType.getValues(),\n EnumLogEntryStatus.getValues(),\n EnumOutputMovementType.getValues(),\n EnumVesselSummaryView.getValues(),\n EnumVesselMovementType.getValues(),\n EnumCostPriceUpdateStrategyType.getValues(),\n EnumStockType.getValues(),\n EnumCompanyFeatureFlag.getValues(),\n EnumStopListItem.getValues(),\n ].flat();\n\n return toMap(\n generatedEnumValues.concat(craftedEnumValues),\n (x) => x.constructor.name + \"|\" + x.key\n );\n}\n\nexport function enumFromJson(json: any): BaseEnumType {\n if (!valuesByEnumName) {\n valuesByEnumName = formAllEnumValueRegistry();\n }\n\n if (json.enumName) {\n const revived = valuesByEnumName.get(json.enumName + \"|\" + json.key);\n\n if (revived) {\n return revived;\n }\n }\n\n // Should have found the value above, but didn't, so revert to the old style simple\n // inflation of the main enum properties.\n let result = {\n // Mark the result specially - may help in debugging if this occurs.\n revivedByInflation: true,\n key: json.key,\n value: json.value,\n translationKey: json.translationKey,\n // Our generated enum types have a translation function, so implement that on any json inflated enums\n get translation() {\n return translate(this.translationKey ?? \"\");\n },\n };\n return result;\n}\n\nexport type BmEnumType = { getValues: () => any };\n","import { BrewManError } from \"@/app/errors\";\nimport errorLoggerService from \"@/app/errors/errorLoggerService\";\nimport { enumFromJson, isEnum } from \"@/app/services/baseEnumType\";\nimport Guid from \"@/app/types/common/guid\";\nimport type { NamedModelObject } from \"@/app/namedModelObjectStore\";\nimport { Instant, LocalDate, LocalDateTime, LocalTime } from \"@js-joda/core\";\n\n/**\n * Provides a uniform way to serialize and deserialize objects with non diverging types\n */\nexport function useReviverReplacer(namedModelObjects: NamedModelObject[] = []) {\n return {\n reviver: createJsonParseReviver(namedModelObjects),\n replacer: createJsonStringifyReplacer(namedModelObjects),\n };\n}\n\nexport function createJsonParseReviver(\n namedModelObjects: NamedModelObject[] = []\n) {\n return (key: string, value: any) => {\n const reviveType = value?.reviveType ?? value?.type ?? value?.modelType; // @TODO: [BREW-6555] Remove modelType and type from non NamedModelObject types\n\n if (value && reviveType && value.value) {\n switch (reviveType) {\n case \"GUID\":\n return Guid.parse(value.value);\n case \"BMO\":\n return value.value;\n case \"ENUM\":\n // @FIXME: [BREW-6536] Will not be revived as the same instance of the enum\n return enumFromJson(value);\n case \"LOCALDATE\":\n return LocalDate.parse(value.value);\n case \"LOCALTIME\":\n return LocalTime.parse(value.value);\n case \"LOCALDATETIME\":\n return LocalDateTime.parse(value.value);\n case \"INSTANT\":\n return Instant.parse(value.value);\n case \"MAP\":\n return new Map(value.value);\n case \"BMOTYPED_JSON\":\n return deserializeBmoJson(namedModelObjects, value);\n case \"BMOTYPED\":\n // Could not successfully deserialize the object\n errorLoggerService.logError(\n `Could not deserialize Legacy Proto value of type ${value.modelType}`\n );\n return null;\n default:\n if (value?.reviveType) {\n // [BREW-6555] remove this wrapping if after all types have been migrated\n errorLoggerService.logError(\n \"Unknown type in json parse reviver\" + reviveType\n );\n }\n return value;\n }\n }\n return value;\n };\n}\n\nfunction deserializeBmoJson(\n namedModelObjects: NamedModelObject[],\n value: { modelType: string; value: string }\n) {\n const foundModelObject = namedModelObjects.find(\n ({ objectTypeName }) => objectTypeName === value.modelType\n );\n\n if (foundModelObject) {\n return new foundModelObject.objectJsonClass(value.value);\n } else {\n throw new BrewManError(\n `Could not deserialize JSON value of type ${value.modelType}`\n );\n }\n}\n\nexport function createJsonStringifyReplacer(\n namedModelObjects: NamedModelObject[] = []\n) {\n /**\n * @warning Runs recursively on all properties of an object and replaces any\n */\n return function (this: any, key: string, value: any) {\n // This seems a small bug - if value is a string representation of a guid it will incorrectly inflate as a guid not a string.\n if (value && value.value && Guid.canParse(value.value.toString())) {\n return { reviveType: \"GUID\", value: value.value };\n }\n if (isBmoObject(value)) {\n // Warning: The replacer will run recursively on all properties of this object and replace any sub objects\n return bmoObjectSerialization(value, namedModelObjects);\n }\n\n if (value && isEnum(value)) {\n return {\n reviveType: \"ENUM\",\n value: value.value,\n key: value.key,\n translationKey: value.translationKey,\n enumName: value.constructor.name,\n };\n }\n\n // Check if an instance of a known type\n const objectValue = this[key];\n if (objectValue) {\n let objectTypeName;\n\n if (objectValue instanceof Map) {\n return {\n reviveType: \"MAP\",\n value: Array.from(value),\n };\n }\n\n if (objectValue instanceof LocalDate) {\n objectTypeName = \"LOCALDATE\";\n } else if (objectValue instanceof LocalTime) {\n objectTypeName = \"LOCALTIME\";\n } else if (objectValue instanceof LocalDateTime) {\n objectTypeName = \"LOCALDATETIME\";\n } else if (objectValue instanceof Instant) {\n objectTypeName = \"INSTANT\";\n }\n\n if (objectTypeName) {\n return {\n reviveType: objectTypeName,\n value,\n };\n }\n }\n\n return value;\n };\n}\n\nfunction isBmoObject(value: any) {\n return value && value.validate;\n}\n\nfunction bmoObjectSerialization(\n value: any,\n namedModelObjects: NamedModelObject[] = []\n) {\n const modelObjectType = namedModelObjects.find(\n ({ objectJsonClass }) => objectJsonClass.name === value.constructor.name\n );\n\n if (modelObjectType) {\n return {\n reviveType: \"BMOTYPED_JSON\",\n modelType: modelObjectType.objectTypeName,\n value: value.toJsonSerializedObject(),\n };\n }\n\n // BaseModelObjects contain private fields with computed getters..\n // move the private \"_\" prefixed fields up one\n return { reviveType: \"BMO\", value: removeUnderscoreRecursive(value) };\n}\n\nfunction removeUnderscoreRecursive(obj: Object) {\n const newObj = {} as any;\n for (let [key, value] of Object.entries(obj)) {\n if (key.startsWith(\"_\") && key.length > 1) {\n newObj[key.slice(1)] = value;\n } else {\n newObj[key] = value;\n }\n }\n return newObj;\n}\n","/*!\n * vue-router v3.6.5\n * (c) 2022 Evan You\n * @license MIT\n */\n/* */\n\nfunction assert (condition, message) {\n if (!condition) {\n throw new Error((\"[vue-router] \" + message))\n }\n}\n\nfunction warn (condition, message) {\n if (!condition) {\n typeof console !== 'undefined' && console.warn((\"[vue-router] \" + message));\n }\n}\n\nfunction extend (a, b) {\n for (var key in b) {\n a[key] = b[key];\n }\n return a\n}\n\n/* */\n\nvar encodeReserveRE = /[!'()*]/g;\nvar encodeReserveReplacer = function (c) { return '%' + c.charCodeAt(0).toString(16); };\nvar commaRE = /%2C/g;\n\n// fixed encodeURIComponent which is more conformant to RFC3986:\n// - escapes [!'()*]\n// - preserve commas\nvar encode = function (str) { return encodeURIComponent(str)\n .replace(encodeReserveRE, encodeReserveReplacer)\n .replace(commaRE, ','); };\n\nfunction decode (str) {\n try {\n return decodeURIComponent(str)\n } catch (err) {\n if (process.env.NODE_ENV !== 'production') {\n warn(false, (\"Error decoding \\\"\" + str + \"\\\". Leaving it intact.\"));\n }\n }\n return str\n}\n\nfunction resolveQuery (\n query,\n extraQuery,\n _parseQuery\n) {\n if ( extraQuery === void 0 ) extraQuery = {};\n\n var parse = _parseQuery || parseQuery;\n var parsedQuery;\n try {\n parsedQuery = parse(query || '');\n } catch (e) {\n process.env.NODE_ENV !== 'production' && warn(false, e.message);\n parsedQuery = {};\n }\n for (var key in extraQuery) {\n var value = extraQuery[key];\n parsedQuery[key] = Array.isArray(value)\n ? value.map(castQueryParamValue)\n : castQueryParamValue(value);\n }\n return parsedQuery\n}\n\nvar castQueryParamValue = function (value) { return (value == null || typeof value === 'object' ? value : String(value)); };\n\nfunction parseQuery (query) {\n var res = {};\n\n query = query.trim().replace(/^(\\?|#|&)/, '');\n\n if (!query) {\n return res\n }\n\n query.split('&').forEach(function (param) {\n var parts = param.replace(/\\+/g, ' ').split('=');\n var key = decode(parts.shift());\n var val = parts.length > 0 ? decode(parts.join('=')) : null;\n\n if (res[key] === undefined) {\n res[key] = val;\n } else if (Array.isArray(res[key])) {\n res[key].push(val);\n } else {\n res[key] = [res[key], val];\n }\n });\n\n return res\n}\n\nfunction stringifyQuery (obj) {\n var res = obj\n ? Object.keys(obj)\n .map(function (key) {\n var val = obj[key];\n\n if (val === undefined) {\n return ''\n }\n\n if (val === null) {\n return encode(key)\n }\n\n if (Array.isArray(val)) {\n var result = [];\n val.forEach(function (val2) {\n if (val2 === undefined) {\n return\n }\n if (val2 === null) {\n result.push(encode(key));\n } else {\n result.push(encode(key) + '=' + encode(val2));\n }\n });\n return result.join('&')\n }\n\n return encode(key) + '=' + encode(val)\n })\n .filter(function (x) { return x.length > 0; })\n .join('&')\n : null;\n return res ? (\"?\" + res) : ''\n}\n\n/* */\n\nvar trailingSlashRE = /\\/?$/;\n\nfunction createRoute (\n record,\n location,\n redirectedFrom,\n router\n) {\n var stringifyQuery = router && router.options.stringifyQuery;\n\n var query = location.query || {};\n try {\n query = clone(query);\n } catch (e) {}\n\n var route = {\n name: location.name || (record && record.name),\n meta: (record && record.meta) || {},\n path: location.path || '/',\n hash: location.hash || '',\n query: query,\n params: location.params || {},\n fullPath: getFullPath(location, stringifyQuery),\n matched: record ? formatMatch(record) : []\n };\n if (redirectedFrom) {\n route.redirectedFrom = getFullPath(redirectedFrom, stringifyQuery);\n }\n return Object.freeze(route)\n}\n\nfunction clone (value) {\n if (Array.isArray(value)) {\n return value.map(clone)\n } else if (value && typeof value === 'object') {\n var res = {};\n for (var key in value) {\n res[key] = clone(value[key]);\n }\n return res\n } else {\n return value\n }\n}\n\n// the starting route that represents the initial state\nvar START = createRoute(null, {\n path: '/'\n});\n\nfunction formatMatch (record) {\n var res = [];\n while (record) {\n res.unshift(record);\n record = record.parent;\n }\n return res\n}\n\nfunction getFullPath (\n ref,\n _stringifyQuery\n) {\n var path = ref.path;\n var query = ref.query; if ( query === void 0 ) query = {};\n var hash = ref.hash; if ( hash === void 0 ) hash = '';\n\n var stringify = _stringifyQuery || stringifyQuery;\n return (path || '/') + stringify(query) + hash\n}\n\nfunction isSameRoute (a, b, onlyPath) {\n if (b === START) {\n return a === b\n } else if (!b) {\n return false\n } else if (a.path && b.path) {\n return a.path.replace(trailingSlashRE, '') === b.path.replace(trailingSlashRE, '') && (onlyPath ||\n a.hash === b.hash &&\n isObjectEqual(a.query, b.query))\n } else if (a.name && b.name) {\n return (\n a.name === b.name &&\n (onlyPath || (\n a.hash === b.hash &&\n isObjectEqual(a.query, b.query) &&\n isObjectEqual(a.params, b.params))\n )\n )\n } else {\n return false\n }\n}\n\nfunction isObjectEqual (a, b) {\n if ( a === void 0 ) a = {};\n if ( b === void 0 ) b = {};\n\n // handle null value #1566\n if (!a || !b) { return a === b }\n var aKeys = Object.keys(a).sort();\n var bKeys = Object.keys(b).sort();\n if (aKeys.length !== bKeys.length) {\n return false\n }\n return aKeys.every(function (key, i) {\n var aVal = a[key];\n var bKey = bKeys[i];\n if (bKey !== key) { return false }\n var bVal = b[key];\n // query values can be null and undefined\n if (aVal == null || bVal == null) { return aVal === bVal }\n // check nested equality\n if (typeof aVal === 'object' && typeof bVal === 'object') {\n return isObjectEqual(aVal, bVal)\n }\n return String(aVal) === String(bVal)\n })\n}\n\nfunction isIncludedRoute (current, target) {\n return (\n current.path.replace(trailingSlashRE, '/').indexOf(\n target.path.replace(trailingSlashRE, '/')\n ) === 0 &&\n (!target.hash || current.hash === target.hash) &&\n queryIncludes(current.query, target.query)\n )\n}\n\nfunction queryIncludes (current, target) {\n for (var key in target) {\n if (!(key in current)) {\n return false\n }\n }\n return true\n}\n\nfunction handleRouteEntered (route) {\n for (var i = 0; i < route.matched.length; i++) {\n var record = route.matched[i];\n for (var name in record.instances) {\n var instance = record.instances[name];\n var cbs = record.enteredCbs[name];\n if (!instance || !cbs) { continue }\n delete record.enteredCbs[name];\n for (var i$1 = 0; i$1 < cbs.length; i$1++) {\n if (!instance._isBeingDestroyed) { cbs[i$1](instance); }\n }\n }\n }\n}\n\nvar View = {\n name: 'RouterView',\n functional: true,\n props: {\n name: {\n type: String,\n default: 'default'\n }\n },\n render: function render (_, ref) {\n var props = ref.props;\n var children = ref.children;\n var parent = ref.parent;\n var data = ref.data;\n\n // used by devtools to display a router-view badge\n data.routerView = true;\n\n // directly use parent context's createElement() function\n // so that components rendered by router-view can resolve named slots\n var h = parent.$createElement;\n var name = props.name;\n var route = parent.$route;\n var cache = parent._routerViewCache || (parent._routerViewCache = {});\n\n // determine current view depth, also check to see if the tree\n // has been toggled inactive but kept-alive.\n var depth = 0;\n var inactive = false;\n while (parent && parent._routerRoot !== parent) {\n var vnodeData = parent.$vnode ? parent.$vnode.data : {};\n if (vnodeData.routerView) {\n depth++;\n }\n if (vnodeData.keepAlive && parent._directInactive && parent._inactive) {\n inactive = true;\n }\n parent = parent.$parent;\n }\n data.routerViewDepth = depth;\n\n // render previous view if the tree is inactive and kept-alive\n if (inactive) {\n var cachedData = cache[name];\n var cachedComponent = cachedData && cachedData.component;\n if (cachedComponent) {\n // #2301\n // pass props\n if (cachedData.configProps) {\n fillPropsinData(cachedComponent, data, cachedData.route, cachedData.configProps);\n }\n return h(cachedComponent, data, children)\n } else {\n // render previous empty view\n return h()\n }\n }\n\n var matched = route.matched[depth];\n var component = matched && matched.components[name];\n\n // render empty node if no matched route or no config component\n if (!matched || !component) {\n cache[name] = null;\n return h()\n }\n\n // cache component\n cache[name] = { component: component };\n\n // attach instance registration hook\n // this will be called in the instance's injected lifecycle hooks\n data.registerRouteInstance = function (vm, val) {\n // val could be undefined for unregistration\n var current = matched.instances[name];\n if (\n (val && current !== vm) ||\n (!val && current === vm)\n ) {\n matched.instances[name] = val;\n }\n }\n\n // also register instance in prepatch hook\n // in case the same component instance is reused across different routes\n ;(data.hook || (data.hook = {})).prepatch = function (_, vnode) {\n matched.instances[name] = vnode.componentInstance;\n };\n\n // register instance in init hook\n // in case kept-alive component be actived when routes changed\n data.hook.init = function (vnode) {\n if (vnode.data.keepAlive &&\n vnode.componentInstance &&\n vnode.componentInstance !== matched.instances[name]\n ) {\n matched.instances[name] = vnode.componentInstance;\n }\n\n // if the route transition has already been confirmed then we weren't\n // able to call the cbs during confirmation as the component was not\n // registered yet, so we call it here.\n handleRouteEntered(route);\n };\n\n var configProps = matched.props && matched.props[name];\n // save route and configProps in cache\n if (configProps) {\n extend(cache[name], {\n route: route,\n configProps: configProps\n });\n fillPropsinData(component, data, route, configProps);\n }\n\n return h(component, data, children)\n }\n};\n\nfunction fillPropsinData (component, data, route, configProps) {\n // resolve props\n var propsToPass = data.props = resolveProps(route, configProps);\n if (propsToPass) {\n // clone to prevent mutation\n propsToPass = data.props = extend({}, propsToPass);\n // pass non-declared props as attrs\n var attrs = data.attrs = data.attrs || {};\n for (var key in propsToPass) {\n if (!component.props || !(key in component.props)) {\n attrs[key] = propsToPass[key];\n delete propsToPass[key];\n }\n }\n }\n}\n\nfunction resolveProps (route, config) {\n switch (typeof config) {\n case 'undefined':\n return\n case 'object':\n return config\n case 'function':\n return config(route)\n case 'boolean':\n return config ? route.params : undefined\n default:\n if (process.env.NODE_ENV !== 'production') {\n warn(\n false,\n \"props in \\\"\" + (route.path) + \"\\\" is a \" + (typeof config) + \", \" +\n \"expecting an object, function or boolean.\"\n );\n }\n }\n}\n\n/* */\n\nfunction resolvePath (\n relative,\n base,\n append\n) {\n var firstChar = relative.charAt(0);\n if (firstChar === '/') {\n return relative\n }\n\n if (firstChar === '?' || firstChar === '#') {\n return base + relative\n }\n\n var stack = base.split('/');\n\n // remove trailing segment if:\n // - not appending\n // - appending to trailing slash (last segment is empty)\n if (!append || !stack[stack.length - 1]) {\n stack.pop();\n }\n\n // resolve relative path\n var segments = relative.replace(/^\\//, '').split('/');\n for (var i = 0; i < segments.length; i++) {\n var segment = segments[i];\n if (segment === '..') {\n stack.pop();\n } else if (segment !== '.') {\n stack.push(segment);\n }\n }\n\n // ensure leading slash\n if (stack[0] !== '') {\n stack.unshift('');\n }\n\n return stack.join('/')\n}\n\nfunction parsePath (path) {\n var hash = '';\n var query = '';\n\n var hashIndex = path.indexOf('#');\n if (hashIndex >= 0) {\n hash = path.slice(hashIndex);\n path = path.slice(0, hashIndex);\n }\n\n var queryIndex = path.indexOf('?');\n if (queryIndex >= 0) {\n query = path.slice(queryIndex + 1);\n path = path.slice(0, queryIndex);\n }\n\n return {\n path: path,\n query: query,\n hash: hash\n }\n}\n\nfunction cleanPath (path) {\n return path.replace(/\\/(?:\\s*\\/)+/g, '/')\n}\n\nvar isarray = Array.isArray || function (arr) {\n return Object.prototype.toString.call(arr) == '[object Array]';\n};\n\n/**\n * Expose `pathToRegexp`.\n */\nvar pathToRegexp_1 = pathToRegexp;\nvar parse_1 = parse;\nvar compile_1 = compile;\nvar tokensToFunction_1 = tokensToFunction;\nvar tokensToRegExp_1 = 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 = res[2] || defaultDelimiter;\n var pattern = capture || group;\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 ? '.*' : '[^' + escapeString(delimiter) + ']+?')\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\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}\npathToRegexp_1.parse = parse_1;\npathToRegexp_1.compile = compile_1;\npathToRegexp_1.tokensToFunction = tokensToFunction_1;\npathToRegexp_1.tokensToRegExp = tokensToRegExp_1;\n\n/* */\n\n// $flow-disable-line\nvar regexpCompileCache = Object.create(null);\n\nfunction fillParams (\n path,\n params,\n routeMsg\n) {\n params = params || {};\n try {\n var filler =\n regexpCompileCache[path] ||\n (regexpCompileCache[path] = pathToRegexp_1.compile(path));\n\n // Fix #2505 resolving asterisk routes { name: 'not-found', params: { pathMatch: '/not-found' }}\n // and fix #3106 so that you can work with location descriptor object having params.pathMatch equal to empty string\n if (typeof params.pathMatch === 'string') { params[0] = params.pathMatch; }\n\n return filler(params, { pretty: true })\n } catch (e) {\n if (process.env.NODE_ENV !== 'production') {\n // Fix #3072 no warn if `pathMatch` is string\n warn(typeof params.pathMatch === 'string', (\"missing param for \" + routeMsg + \": \" + (e.message)));\n }\n return ''\n } finally {\n // delete the 0 if it was added\n delete params[0];\n }\n}\n\n/* */\n\nfunction normalizeLocation (\n raw,\n current,\n append,\n router\n) {\n var next = typeof raw === 'string' ? { path: raw } : raw;\n // named target\n if (next._normalized) {\n return next\n } else if (next.name) {\n next = extend({}, raw);\n var params = next.params;\n if (params && typeof params === 'object') {\n next.params = extend({}, params);\n }\n return next\n }\n\n // relative params\n if (!next.path && next.params && current) {\n next = extend({}, next);\n next._normalized = true;\n var params$1 = extend(extend({}, current.params), next.params);\n if (current.name) {\n next.name = current.name;\n next.params = params$1;\n } else if (current.matched.length) {\n var rawPath = current.matched[current.matched.length - 1].path;\n next.path = fillParams(rawPath, params$1, (\"path \" + (current.path)));\n } else if (process.env.NODE_ENV !== 'production') {\n warn(false, \"relative params navigation requires a current route.\");\n }\n return next\n }\n\n var parsedPath = parsePath(next.path || '');\n var basePath = (current && current.path) || '/';\n var path = parsedPath.path\n ? resolvePath(parsedPath.path, basePath, append || next.append)\n : basePath;\n\n var query = resolveQuery(\n parsedPath.query,\n next.query,\n router && router.options.parseQuery\n );\n\n var hash = next.hash || parsedPath.hash;\n if (hash && hash.charAt(0) !== '#') {\n hash = \"#\" + hash;\n }\n\n return {\n _normalized: true,\n path: path,\n query: query,\n hash: hash\n }\n}\n\n/* */\n\n// work around weird flow bug\nvar toTypes = [String, Object];\nvar eventTypes = [String, Array];\n\nvar noop = function () {};\n\nvar warnedCustomSlot;\nvar warnedTagProp;\nvar warnedEventProp;\n\nvar Link = {\n name: 'RouterLink',\n props: {\n to: {\n type: toTypes,\n required: true\n },\n tag: {\n type: String,\n default: 'a'\n },\n custom: Boolean,\n exact: Boolean,\n exactPath: Boolean,\n append: Boolean,\n replace: Boolean,\n activeClass: String,\n exactActiveClass: String,\n ariaCurrentValue: {\n type: String,\n default: 'page'\n },\n event: {\n type: eventTypes,\n default: 'click'\n }\n },\n render: function render (h) {\n var this$1$1 = this;\n\n var router = this.$router;\n var current = this.$route;\n var ref = router.resolve(\n this.to,\n current,\n this.append\n );\n var location = ref.location;\n var route = ref.route;\n var href = ref.href;\n\n var classes = {};\n var globalActiveClass = router.options.linkActiveClass;\n var globalExactActiveClass = router.options.linkExactActiveClass;\n // Support global empty active class\n var activeClassFallback =\n globalActiveClass == null ? 'router-link-active' : globalActiveClass;\n var exactActiveClassFallback =\n globalExactActiveClass == null\n ? 'router-link-exact-active'\n : globalExactActiveClass;\n var activeClass =\n this.activeClass == null ? activeClassFallback : this.activeClass;\n var exactActiveClass =\n this.exactActiveClass == null\n ? exactActiveClassFallback\n : this.exactActiveClass;\n\n var compareTarget = route.redirectedFrom\n ? createRoute(null, normalizeLocation(route.redirectedFrom), null, router)\n : route;\n\n classes[exactActiveClass] = isSameRoute(current, compareTarget, this.exactPath);\n classes[activeClass] = this.exact || this.exactPath\n ? classes[exactActiveClass]\n : isIncludedRoute(current, compareTarget);\n\n var ariaCurrentValue = classes[exactActiveClass] ? this.ariaCurrentValue : null;\n\n var handler = function (e) {\n if (guardEvent(e)) {\n if (this$1$1.replace) {\n router.replace(location, noop);\n } else {\n router.push(location, noop);\n }\n }\n };\n\n var on = { click: guardEvent };\n if (Array.isArray(this.event)) {\n this.event.forEach(function (e) {\n on[e] = handler;\n });\n } else {\n on[this.event] = handler;\n }\n\n var data = { class: classes };\n\n var scopedSlot =\n !this.$scopedSlots.$hasNormal &&\n this.$scopedSlots.default &&\n this.$scopedSlots.default({\n href: href,\n route: route,\n navigate: handler,\n isActive: classes[activeClass],\n isExactActive: classes[exactActiveClass]\n });\n\n if (scopedSlot) {\n if (process.env.NODE_ENV !== 'production' && !this.custom) {\n !warnedCustomSlot && warn(false, 'In Vue Router 4, the v-slot API will by default wrap its content with an element. Use the custom prop to remove this warning:\\n\\n');\n warnedCustomSlot = true;\n }\n if (scopedSlot.length === 1) {\n return scopedSlot[0]\n } else if (scopedSlot.length > 1 || !scopedSlot.length) {\n if (process.env.NODE_ENV !== 'production') {\n warn(\n false,\n (\" with to=\\\"\" + (this.to) + \"\\\" is trying to use a scoped slot but it didn't provide exactly one child. Wrapping the content with a span element.\")\n );\n }\n return scopedSlot.length === 0 ? h() : h('span', {}, scopedSlot)\n }\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if ('tag' in this.$options.propsData && !warnedTagProp) {\n warn(\n false,\n \"'s tag prop is deprecated and has been removed in Vue Router 4. Use the v-slot API to remove this warning: https://next.router.vuejs.org/guide/migration/#removal-of-event-and-tag-props-in-router-link.\"\n );\n warnedTagProp = true;\n }\n if ('event' in this.$options.propsData && !warnedEventProp) {\n warn(\n false,\n \"'s event prop is deprecated and has been removed in Vue Router 4. Use the v-slot API to remove this warning: https://next.router.vuejs.org/guide/migration/#removal-of-event-and-tag-props-in-router-link.\"\n );\n warnedEventProp = true;\n }\n }\n\n if (this.tag === 'a') {\n data.on = on;\n data.attrs = { href: href, 'aria-current': ariaCurrentValue };\n } else {\n // find the first child and apply listener and href\n var a = findAnchor(this.$slots.default);\n if (a) {\n // in case the is a static node\n a.isStatic = false;\n var aData = (a.data = extend({}, a.data));\n aData.on = aData.on || {};\n // transform existing events in both objects into arrays so we can push later\n for (var event in aData.on) {\n var handler$1 = aData.on[event];\n if (event in on) {\n aData.on[event] = Array.isArray(handler$1) ? handler$1 : [handler$1];\n }\n }\n // append new listeners for router-link\n for (var event$1 in on) {\n if (event$1 in aData.on) {\n // on[event] is always a function\n aData.on[event$1].push(on[event$1]);\n } else {\n aData.on[event$1] = handler;\n }\n }\n\n var aAttrs = (a.data.attrs = extend({}, a.data.attrs));\n aAttrs.href = href;\n aAttrs['aria-current'] = ariaCurrentValue;\n } else {\n // doesn't have child, apply listener to self\n data.on = on;\n }\n }\n\n return h(this.tag, data, this.$slots.default)\n }\n};\n\nfunction guardEvent (e) {\n // don't redirect with control keys\n if (e.metaKey || e.altKey || e.ctrlKey || e.shiftKey) { return }\n // don't redirect when preventDefault called\n if (e.defaultPrevented) { return }\n // don't redirect on right click\n if (e.button !== undefined && e.button !== 0) { return }\n // don't redirect if `target=\"_blank\"`\n if (e.currentTarget && e.currentTarget.getAttribute) {\n var target = e.currentTarget.getAttribute('target');\n if (/\\b_blank\\b/i.test(target)) { return }\n }\n // this may be a Weex event which doesn't have this method\n if (e.preventDefault) {\n e.preventDefault();\n }\n return true\n}\n\nfunction findAnchor (children) {\n if (children) {\n var child;\n for (var i = 0; i < children.length; i++) {\n child = children[i];\n if (child.tag === 'a') {\n return child\n }\n if (child.children && (child = findAnchor(child.children))) {\n return child\n }\n }\n }\n}\n\nvar _Vue;\n\nfunction install (Vue) {\n if (install.installed && _Vue === Vue) { return }\n install.installed = true;\n\n _Vue = Vue;\n\n var isDef = function (v) { return v !== undefined; };\n\n var registerInstance = function (vm, callVal) {\n var i = vm.$options._parentVnode;\n if (isDef(i) && isDef(i = i.data) && isDef(i = i.registerRouteInstance)) {\n i(vm, callVal);\n }\n };\n\n Vue.mixin({\n beforeCreate: function beforeCreate () {\n if (isDef(this.$options.router)) {\n this._routerRoot = this;\n this._router = this.$options.router;\n this._router.init(this);\n Vue.util.defineReactive(this, '_route', this._router.history.current);\n } else {\n this._routerRoot = (this.$parent && this.$parent._routerRoot) || this;\n }\n registerInstance(this, this);\n },\n destroyed: function destroyed () {\n registerInstance(this);\n }\n });\n\n Object.defineProperty(Vue.prototype, '$router', {\n get: function get () { return this._routerRoot._router }\n });\n\n Object.defineProperty(Vue.prototype, '$route', {\n get: function get () { return this._routerRoot._route }\n });\n\n Vue.component('RouterView', View);\n Vue.component('RouterLink', Link);\n\n var strats = Vue.config.optionMergeStrategies;\n // use the same hook merging strategy for route hooks\n strats.beforeRouteEnter = strats.beforeRouteLeave = strats.beforeRouteUpdate = strats.created;\n}\n\n/* */\n\nvar inBrowser = typeof window !== 'undefined';\n\n/* */\n\nfunction createRouteMap (\n routes,\n oldPathList,\n oldPathMap,\n oldNameMap,\n parentRoute\n) {\n // the path list is used to control path matching priority\n var pathList = oldPathList || [];\n // $flow-disable-line\n var pathMap = oldPathMap || Object.create(null);\n // $flow-disable-line\n var nameMap = oldNameMap || Object.create(null);\n\n routes.forEach(function (route) {\n addRouteRecord(pathList, pathMap, nameMap, route, parentRoute);\n });\n\n // ensure wildcard routes are always at the end\n for (var i = 0, l = pathList.length; i < l; i++) {\n if (pathList[i] === '*') {\n pathList.push(pathList.splice(i, 1)[0]);\n l--;\n i--;\n }\n }\n\n if (process.env.NODE_ENV === 'development') {\n // warn if routes do not include leading slashes\n var found = pathList\n // check for missing leading slash\n .filter(function (path) { return path && path.charAt(0) !== '*' && path.charAt(0) !== '/'; });\n\n if (found.length > 0) {\n var pathNames = found.map(function (path) { return (\"- \" + path); }).join('\\n');\n warn(false, (\"Non-nested routes must include a leading slash character. Fix the following routes: \\n\" + pathNames));\n }\n }\n\n return {\n pathList: pathList,\n pathMap: pathMap,\n nameMap: nameMap\n }\n}\n\nfunction addRouteRecord (\n pathList,\n pathMap,\n nameMap,\n route,\n parent,\n matchAs\n) {\n var path = route.path;\n var name = route.name;\n if (process.env.NODE_ENV !== 'production') {\n assert(path != null, \"\\\"path\\\" is required in a route configuration.\");\n assert(\n typeof route.component !== 'string',\n \"route config \\\"component\\\" for path: \" + (String(\n path || name\n )) + \" cannot be a \" + \"string id. Use an actual component instead.\"\n );\n\n warn(\n // eslint-disable-next-line no-control-regex\n !/[^\\u0000-\\u007F]+/.test(path),\n \"Route with path \\\"\" + path + \"\\\" contains unencoded characters, make sure \" +\n \"your path is correctly encoded before passing it to the router. Use \" +\n \"encodeURI to encode static segments of your path.\"\n );\n }\n\n var pathToRegexpOptions =\n route.pathToRegexpOptions || {};\n var normalizedPath = normalizePath(path, parent, pathToRegexpOptions.strict);\n\n if (typeof route.caseSensitive === 'boolean') {\n pathToRegexpOptions.sensitive = route.caseSensitive;\n }\n\n var record = {\n path: normalizedPath,\n regex: compileRouteRegex(normalizedPath, pathToRegexpOptions),\n components: route.components || { default: route.component },\n alias: route.alias\n ? typeof route.alias === 'string'\n ? [route.alias]\n : route.alias\n : [],\n instances: {},\n enteredCbs: {},\n name: name,\n parent: parent,\n matchAs: matchAs,\n redirect: route.redirect,\n beforeEnter: route.beforeEnter,\n meta: route.meta || {},\n props:\n route.props == null\n ? {}\n : route.components\n ? route.props\n : { default: route.props }\n };\n\n if (route.children) {\n // Warn if route is named, does not redirect and has a default child route.\n // If users navigate to this route by name, the default child will\n // not be rendered (GH Issue #629)\n if (process.env.NODE_ENV !== 'production') {\n if (\n route.name &&\n !route.redirect &&\n route.children.some(function (child) { return /^\\/?$/.test(child.path); })\n ) {\n warn(\n false,\n \"Named Route '\" + (route.name) + \"' has a default child route. \" +\n \"When navigating to this named route (:to=\\\"{name: '\" + (route.name) + \"'}\\\"), \" +\n \"the default child route will not be rendered. Remove the name from \" +\n \"this route and use the name of the default child route for named \" +\n \"links instead.\"\n );\n }\n }\n route.children.forEach(function (child) {\n var childMatchAs = matchAs\n ? cleanPath((matchAs + \"/\" + (child.path)))\n : undefined;\n addRouteRecord(pathList, pathMap, nameMap, child, record, childMatchAs);\n });\n }\n\n if (!pathMap[record.path]) {\n pathList.push(record.path);\n pathMap[record.path] = record;\n }\n\n if (route.alias !== undefined) {\n var aliases = Array.isArray(route.alias) ? route.alias : [route.alias];\n for (var i = 0; i < aliases.length; ++i) {\n var alias = aliases[i];\n if (process.env.NODE_ENV !== 'production' && alias === path) {\n warn(\n false,\n (\"Found an alias with the same value as the path: \\\"\" + path + \"\\\". You have to remove that alias. It will be ignored in development.\")\n );\n // skip in dev to make it work\n continue\n }\n\n var aliasRoute = {\n path: alias,\n children: route.children\n };\n addRouteRecord(\n pathList,\n pathMap,\n nameMap,\n aliasRoute,\n parent,\n record.path || '/' // matchAs\n );\n }\n }\n\n if (name) {\n if (!nameMap[name]) {\n nameMap[name] = record;\n } else if (process.env.NODE_ENV !== 'production' && !matchAs) {\n warn(\n false,\n \"Duplicate named routes definition: \" +\n \"{ name: \\\"\" + name + \"\\\", path: \\\"\" + (record.path) + \"\\\" }\"\n );\n }\n }\n}\n\nfunction compileRouteRegex (\n path,\n pathToRegexpOptions\n) {\n var regex = pathToRegexp_1(path, [], pathToRegexpOptions);\n if (process.env.NODE_ENV !== 'production') {\n var keys = Object.create(null);\n regex.keys.forEach(function (key) {\n warn(\n !keys[key.name],\n (\"Duplicate param keys in route with path: \\\"\" + path + \"\\\"\")\n );\n keys[key.name] = true;\n });\n }\n return regex\n}\n\nfunction normalizePath (\n path,\n parent,\n strict\n) {\n if (!strict) { path = path.replace(/\\/$/, ''); }\n if (path[0] === '/') { return path }\n if (parent == null) { return path }\n return cleanPath(((parent.path) + \"/\" + path))\n}\n\n/* */\n\n\n\nfunction createMatcher (\n routes,\n router\n) {\n var ref = createRouteMap(routes);\n var pathList = ref.pathList;\n var pathMap = ref.pathMap;\n var nameMap = ref.nameMap;\n\n function addRoutes (routes) {\n createRouteMap(routes, pathList, pathMap, nameMap);\n }\n\n function addRoute (parentOrRoute, route) {\n var parent = (typeof parentOrRoute !== 'object') ? nameMap[parentOrRoute] : undefined;\n // $flow-disable-line\n createRouteMap([route || parentOrRoute], pathList, pathMap, nameMap, parent);\n\n // add aliases of parent\n if (parent && parent.alias.length) {\n createRouteMap(\n // $flow-disable-line route is defined if parent is\n parent.alias.map(function (alias) { return ({ path: alias, children: [route] }); }),\n pathList,\n pathMap,\n nameMap,\n parent\n );\n }\n }\n\n function getRoutes () {\n return pathList.map(function (path) { return pathMap[path]; })\n }\n\n function match (\n raw,\n currentRoute,\n redirectedFrom\n ) {\n var location = normalizeLocation(raw, currentRoute, false, router);\n var name = location.name;\n\n if (name) {\n var record = nameMap[name];\n if (process.env.NODE_ENV !== 'production') {\n warn(record, (\"Route with name '\" + name + \"' does not exist\"));\n }\n if (!record) { return _createRoute(null, location) }\n var paramNames = record.regex.keys\n .filter(function (key) { return !key.optional; })\n .map(function (key) { return key.name; });\n\n if (typeof location.params !== 'object') {\n location.params = {};\n }\n\n if (currentRoute && typeof currentRoute.params === 'object') {\n for (var key in currentRoute.params) {\n if (!(key in location.params) && paramNames.indexOf(key) > -1) {\n location.params[key] = currentRoute.params[key];\n }\n }\n }\n\n location.path = fillParams(record.path, location.params, (\"named route \\\"\" + name + \"\\\"\"));\n return _createRoute(record, location, redirectedFrom)\n } else if (location.path) {\n location.params = {};\n for (var i = 0; i < pathList.length; i++) {\n var path = pathList[i];\n var record$1 = pathMap[path];\n if (matchRoute(record$1.regex, location.path, location.params)) {\n return _createRoute(record$1, location, redirectedFrom)\n }\n }\n }\n // no match\n return _createRoute(null, location)\n }\n\n function redirect (\n record,\n location\n ) {\n var originalRedirect = record.redirect;\n var redirect = typeof originalRedirect === 'function'\n ? originalRedirect(createRoute(record, location, null, router))\n : originalRedirect;\n\n if (typeof redirect === 'string') {\n redirect = { path: redirect };\n }\n\n if (!redirect || typeof redirect !== 'object') {\n if (process.env.NODE_ENV !== 'production') {\n warn(\n false, (\"invalid redirect option: \" + (JSON.stringify(redirect)))\n );\n }\n return _createRoute(null, location)\n }\n\n var re = redirect;\n var name = re.name;\n var path = re.path;\n var query = location.query;\n var hash = location.hash;\n var params = location.params;\n query = re.hasOwnProperty('query') ? re.query : query;\n hash = re.hasOwnProperty('hash') ? re.hash : hash;\n params = re.hasOwnProperty('params') ? re.params : params;\n\n if (name) {\n // resolved named direct\n var targetRecord = nameMap[name];\n if (process.env.NODE_ENV !== 'production') {\n assert(targetRecord, (\"redirect failed: named route \\\"\" + name + \"\\\" not found.\"));\n }\n return match({\n _normalized: true,\n name: name,\n query: query,\n hash: hash,\n params: params\n }, undefined, location)\n } else if (path) {\n // 1. resolve relative redirect\n var rawPath = resolveRecordPath(path, record);\n // 2. resolve params\n var resolvedPath = fillParams(rawPath, params, (\"redirect route with path \\\"\" + rawPath + \"\\\"\"));\n // 3. rematch with existing query and hash\n return match({\n _normalized: true,\n path: resolvedPath,\n query: query,\n hash: hash\n }, undefined, location)\n } else {\n if (process.env.NODE_ENV !== 'production') {\n warn(false, (\"invalid redirect option: \" + (JSON.stringify(redirect))));\n }\n return _createRoute(null, location)\n }\n }\n\n function alias (\n record,\n location,\n matchAs\n ) {\n var aliasedPath = fillParams(matchAs, location.params, (\"aliased route with path \\\"\" + matchAs + \"\\\"\"));\n var aliasedMatch = match({\n _normalized: true,\n path: aliasedPath\n });\n if (aliasedMatch) {\n var matched = aliasedMatch.matched;\n var aliasedRecord = matched[matched.length - 1];\n location.params = aliasedMatch.params;\n return _createRoute(aliasedRecord, location)\n }\n return _createRoute(null, location)\n }\n\n function _createRoute (\n record,\n location,\n redirectedFrom\n ) {\n if (record && record.redirect) {\n return redirect(record, redirectedFrom || location)\n }\n if (record && record.matchAs) {\n return alias(record, location, record.matchAs)\n }\n return createRoute(record, location, redirectedFrom, router)\n }\n\n return {\n match: match,\n addRoute: addRoute,\n getRoutes: getRoutes,\n addRoutes: addRoutes\n }\n}\n\nfunction matchRoute (\n regex,\n path,\n params\n) {\n var m = path.match(regex);\n\n if (!m) {\n return false\n } else if (!params) {\n return true\n }\n\n for (var i = 1, len = m.length; i < len; ++i) {\n var key = regex.keys[i - 1];\n if (key) {\n // Fix #1994: using * with props: true generates a param named 0\n params[key.name || 'pathMatch'] = typeof m[i] === 'string' ? decode(m[i]) : m[i];\n }\n }\n\n return true\n}\n\nfunction resolveRecordPath (path, record) {\n return resolvePath(path, record.parent ? record.parent.path : '/', true)\n}\n\n/* */\n\n// use User Timing api (if present) for more accurate key precision\nvar Time =\n inBrowser && window.performance && window.performance.now\n ? window.performance\n : Date;\n\nfunction genStateKey () {\n return Time.now().toFixed(3)\n}\n\nvar _key = genStateKey();\n\nfunction getStateKey () {\n return _key\n}\n\nfunction setStateKey (key) {\n return (_key = key)\n}\n\n/* */\n\nvar positionStore = Object.create(null);\n\nfunction setupScroll () {\n // Prevent browser scroll behavior on History popstate\n if ('scrollRestoration' in window.history) {\n window.history.scrollRestoration = 'manual';\n }\n // Fix for #1585 for Firefox\n // Fix for #2195 Add optional third attribute to workaround a bug in safari https://bugs.webkit.org/show_bug.cgi?id=182678\n // Fix for #2774 Support for apps loaded from Windows file shares not mapped to network drives: replaced location.origin with\n // window.location.protocol + '//' + window.location.host\n // location.host contains the port and location.hostname doesn't\n var protocolAndPath = window.location.protocol + '//' + window.location.host;\n var absolutePath = window.location.href.replace(protocolAndPath, '');\n // preserve existing history state as it could be overriden by the user\n var stateCopy = extend({}, window.history.state);\n stateCopy.key = getStateKey();\n window.history.replaceState(stateCopy, '', absolutePath);\n window.addEventListener('popstate', handlePopState);\n return function () {\n window.removeEventListener('popstate', handlePopState);\n }\n}\n\nfunction handleScroll (\n router,\n to,\n from,\n isPop\n) {\n if (!router.app) {\n return\n }\n\n var behavior = router.options.scrollBehavior;\n if (!behavior) {\n return\n }\n\n if (process.env.NODE_ENV !== 'production') {\n assert(typeof behavior === 'function', \"scrollBehavior must be a function\");\n }\n\n // wait until re-render finishes before scrolling\n router.app.$nextTick(function () {\n var position = getScrollPosition();\n var shouldScroll = behavior.call(\n router,\n to,\n from,\n isPop ? position : null\n );\n\n if (!shouldScroll) {\n return\n }\n\n if (typeof shouldScroll.then === 'function') {\n shouldScroll\n .then(function (shouldScroll) {\n scrollToPosition((shouldScroll), position);\n })\n .catch(function (err) {\n if (process.env.NODE_ENV !== 'production') {\n assert(false, err.toString());\n }\n });\n } else {\n scrollToPosition(shouldScroll, position);\n }\n });\n}\n\nfunction saveScrollPosition () {\n var key = getStateKey();\n if (key) {\n positionStore[key] = {\n x: window.pageXOffset,\n y: window.pageYOffset\n };\n }\n}\n\nfunction handlePopState (e) {\n saveScrollPosition();\n if (e.state && e.state.key) {\n setStateKey(e.state.key);\n }\n}\n\nfunction getScrollPosition () {\n var key = getStateKey();\n if (key) {\n return positionStore[key]\n }\n}\n\nfunction getElementPosition (el, offset) {\n var docEl = document.documentElement;\n var docRect = docEl.getBoundingClientRect();\n var elRect = el.getBoundingClientRect();\n return {\n x: elRect.left - docRect.left - offset.x,\n y: elRect.top - docRect.top - offset.y\n }\n}\n\nfunction isValidPosition (obj) {\n return isNumber(obj.x) || isNumber(obj.y)\n}\n\nfunction normalizePosition (obj) {\n return {\n x: isNumber(obj.x) ? obj.x : window.pageXOffset,\n y: isNumber(obj.y) ? obj.y : window.pageYOffset\n }\n}\n\nfunction normalizeOffset (obj) {\n return {\n x: isNumber(obj.x) ? obj.x : 0,\n y: isNumber(obj.y) ? obj.y : 0\n }\n}\n\nfunction isNumber (v) {\n return typeof v === 'number'\n}\n\nvar hashStartsWithNumberRE = /^#\\d/;\n\nfunction scrollToPosition (shouldScroll, position) {\n var isObject = typeof shouldScroll === 'object';\n if (isObject && typeof shouldScroll.selector === 'string') {\n // getElementById would still fail if the selector contains a more complicated query like #main[data-attr]\n // but at the same time, it doesn't make much sense to select an element with an id and an extra selector\n var el = hashStartsWithNumberRE.test(shouldScroll.selector) // $flow-disable-line\n ? document.getElementById(shouldScroll.selector.slice(1)) // $flow-disable-line\n : document.querySelector(shouldScroll.selector);\n\n if (el) {\n var offset =\n shouldScroll.offset && typeof shouldScroll.offset === 'object'\n ? shouldScroll.offset\n : {};\n offset = normalizeOffset(offset);\n position = getElementPosition(el, offset);\n } else if (isValidPosition(shouldScroll)) {\n position = normalizePosition(shouldScroll);\n }\n } else if (isObject && isValidPosition(shouldScroll)) {\n position = normalizePosition(shouldScroll);\n }\n\n if (position) {\n // $flow-disable-line\n if ('scrollBehavior' in document.documentElement.style) {\n window.scrollTo({\n left: position.x,\n top: position.y,\n // $flow-disable-line\n behavior: shouldScroll.behavior\n });\n } else {\n window.scrollTo(position.x, position.y);\n }\n }\n}\n\n/* */\n\nvar supportsPushState =\n inBrowser &&\n (function () {\n var ua = window.navigator.userAgent;\n\n if (\n (ua.indexOf('Android 2.') !== -1 || ua.indexOf('Android 4.0') !== -1) &&\n ua.indexOf('Mobile Safari') !== -1 &&\n ua.indexOf('Chrome') === -1 &&\n ua.indexOf('Windows Phone') === -1\n ) {\n return false\n }\n\n return window.history && typeof window.history.pushState === 'function'\n })();\n\nfunction pushState (url, replace) {\n saveScrollPosition();\n // try...catch the pushState call to get around Safari\n // DOM Exception 18 where it limits to 100 pushState calls\n var history = window.history;\n try {\n if (replace) {\n // preserve existing history state as it could be overriden by the user\n var stateCopy = extend({}, history.state);\n stateCopy.key = getStateKey();\n history.replaceState(stateCopy, '', url);\n } else {\n history.pushState({ key: setStateKey(genStateKey()) }, '', url);\n }\n } catch (e) {\n window.location[replace ? 'replace' : 'assign'](url);\n }\n}\n\nfunction replaceState (url) {\n pushState(url, true);\n}\n\n// When changing thing, also edit router.d.ts\nvar NavigationFailureType = {\n redirected: 2,\n aborted: 4,\n cancelled: 8,\n duplicated: 16\n};\n\nfunction createNavigationRedirectedError (from, to) {\n return createRouterError(\n from,\n to,\n NavigationFailureType.redirected,\n (\"Redirected when going from \\\"\" + (from.fullPath) + \"\\\" to \\\"\" + (stringifyRoute(\n to\n )) + \"\\\" via a navigation guard.\")\n )\n}\n\nfunction createNavigationDuplicatedError (from, to) {\n var error = createRouterError(\n from,\n to,\n NavigationFailureType.duplicated,\n (\"Avoided redundant navigation to current location: \\\"\" + (from.fullPath) + \"\\\".\")\n );\n // backwards compatible with the first introduction of Errors\n error.name = 'NavigationDuplicated';\n return error\n}\n\nfunction createNavigationCancelledError (from, to) {\n return createRouterError(\n from,\n to,\n NavigationFailureType.cancelled,\n (\"Navigation cancelled from \\\"\" + (from.fullPath) + \"\\\" to \\\"\" + (to.fullPath) + \"\\\" with a new navigation.\")\n )\n}\n\nfunction createNavigationAbortedError (from, to) {\n return createRouterError(\n from,\n to,\n NavigationFailureType.aborted,\n (\"Navigation aborted from \\\"\" + (from.fullPath) + \"\\\" to \\\"\" + (to.fullPath) + \"\\\" via a navigation guard.\")\n )\n}\n\nfunction createRouterError (from, to, type, message) {\n var error = new Error(message);\n error._isRouter = true;\n error.from = from;\n error.to = to;\n error.type = type;\n\n return error\n}\n\nvar propertiesToLog = ['params', 'query', 'hash'];\n\nfunction stringifyRoute (to) {\n if (typeof to === 'string') { return to }\n if ('path' in to) { return to.path }\n var location = {};\n propertiesToLog.forEach(function (key) {\n if (key in to) { location[key] = to[key]; }\n });\n return JSON.stringify(location, null, 2)\n}\n\nfunction isError (err) {\n return Object.prototype.toString.call(err).indexOf('Error') > -1\n}\n\nfunction isNavigationFailure (err, errorType) {\n return (\n isError(err) &&\n err._isRouter &&\n (errorType == null || err.type === errorType)\n )\n}\n\n/* */\n\nfunction runQueue (queue, fn, cb) {\n var step = function (index) {\n if (index >= queue.length) {\n cb();\n } else {\n if (queue[index]) {\n fn(queue[index], function () {\n step(index + 1);\n });\n } else {\n step(index + 1);\n }\n }\n };\n step(0);\n}\n\n/* */\n\nfunction resolveAsyncComponents (matched) {\n return function (to, from, next) {\n var hasAsync = false;\n var pending = 0;\n var error = null;\n\n flatMapComponents(matched, function (def, _, match, key) {\n // if it's a function and doesn't have cid attached,\n // assume it's an async component resolve function.\n // we are not using Vue's default async resolving mechanism because\n // we want to halt the navigation until the incoming component has been\n // resolved.\n if (typeof def === 'function' && def.cid === undefined) {\n hasAsync = true;\n pending++;\n\n var resolve = once(function (resolvedDef) {\n if (isESModule(resolvedDef)) {\n resolvedDef = resolvedDef.default;\n }\n // save resolved on async factory in case it's used elsewhere\n def.resolved = typeof resolvedDef === 'function'\n ? resolvedDef\n : _Vue.extend(resolvedDef);\n match.components[key] = resolvedDef;\n pending--;\n if (pending <= 0) {\n next();\n }\n });\n\n var reject = once(function (reason) {\n var msg = \"Failed to resolve async component \" + key + \": \" + reason;\n process.env.NODE_ENV !== 'production' && warn(false, msg);\n if (!error) {\n error = isError(reason)\n ? reason\n : new Error(msg);\n next(error);\n }\n });\n\n var res;\n try {\n res = def(resolve, reject);\n } catch (e) {\n reject(e);\n }\n if (res) {\n if (typeof res.then === 'function') {\n res.then(resolve, reject);\n } else {\n // new syntax in Vue 2.3\n var comp = res.component;\n if (comp && typeof comp.then === 'function') {\n comp.then(resolve, reject);\n }\n }\n }\n }\n });\n\n if (!hasAsync) { next(); }\n }\n}\n\nfunction flatMapComponents (\n matched,\n fn\n) {\n return flatten(matched.map(function (m) {\n return Object.keys(m.components).map(function (key) { return fn(\n m.components[key],\n m.instances[key],\n m, key\n ); })\n }))\n}\n\nfunction flatten (arr) {\n return Array.prototype.concat.apply([], arr)\n}\n\nvar hasSymbol =\n typeof Symbol === 'function' &&\n typeof Symbol.toStringTag === 'symbol';\n\nfunction isESModule (obj) {\n return obj.__esModule || (hasSymbol && obj[Symbol.toStringTag] === 'Module')\n}\n\n// in Webpack 2, require.ensure now also returns a Promise\n// so the resolve/reject functions may get called an extra time\n// if the user uses an arrow function shorthand that happens to\n// return that Promise.\nfunction once (fn) {\n var called = false;\n return function () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n if (called) { return }\n called = true;\n return fn.apply(this, args)\n }\n}\n\n/* */\n\nvar History = function History (router, base) {\n this.router = router;\n this.base = normalizeBase(base);\n // start with a route object that stands for \"nowhere\"\n this.current = START;\n this.pending = null;\n this.ready = false;\n this.readyCbs = [];\n this.readyErrorCbs = [];\n this.errorCbs = [];\n this.listeners = [];\n};\n\nHistory.prototype.listen = function listen (cb) {\n this.cb = cb;\n};\n\nHistory.prototype.onReady = function onReady (cb, errorCb) {\n if (this.ready) {\n cb();\n } else {\n this.readyCbs.push(cb);\n if (errorCb) {\n this.readyErrorCbs.push(errorCb);\n }\n }\n};\n\nHistory.prototype.onError = function onError (errorCb) {\n this.errorCbs.push(errorCb);\n};\n\nHistory.prototype.transitionTo = function transitionTo (\n location,\n onComplete,\n onAbort\n) {\n var this$1$1 = this;\n\n var route;\n // catch redirect option https://github.com/vuejs/vue-router/issues/3201\n try {\n route = this.router.match(location, this.current);\n } catch (e) {\n this.errorCbs.forEach(function (cb) {\n cb(e);\n });\n // Exception should still be thrown\n throw e\n }\n var prev = this.current;\n this.confirmTransition(\n route,\n function () {\n this$1$1.updateRoute(route);\n onComplete && onComplete(route);\n this$1$1.ensureURL();\n this$1$1.router.afterHooks.forEach(function (hook) {\n hook && hook(route, prev);\n });\n\n // fire ready cbs once\n if (!this$1$1.ready) {\n this$1$1.ready = true;\n this$1$1.readyCbs.forEach(function (cb) {\n cb(route);\n });\n }\n },\n function (err) {\n if (onAbort) {\n onAbort(err);\n }\n if (err && !this$1$1.ready) {\n // Initial redirection should not mark the history as ready yet\n // because it's triggered by the redirection instead\n // https://github.com/vuejs/vue-router/issues/3225\n // https://github.com/vuejs/vue-router/issues/3331\n if (!isNavigationFailure(err, NavigationFailureType.redirected) || prev !== START) {\n this$1$1.ready = true;\n this$1$1.readyErrorCbs.forEach(function (cb) {\n cb(err);\n });\n }\n }\n }\n );\n};\n\nHistory.prototype.confirmTransition = function confirmTransition (route, onComplete, onAbort) {\n var this$1$1 = this;\n\n var current = this.current;\n this.pending = route;\n var abort = function (err) {\n // changed after adding errors with\n // https://github.com/vuejs/vue-router/pull/3047 before that change,\n // redirect and aborted navigation would produce an err == null\n if (!isNavigationFailure(err) && isError(err)) {\n if (this$1$1.errorCbs.length) {\n this$1$1.errorCbs.forEach(function (cb) {\n cb(err);\n });\n } else {\n if (process.env.NODE_ENV !== 'production') {\n warn(false, 'uncaught error during route navigation:');\n }\n console.error(err);\n }\n }\n onAbort && onAbort(err);\n };\n var lastRouteIndex = route.matched.length - 1;\n var lastCurrentIndex = current.matched.length - 1;\n if (\n isSameRoute(route, current) &&\n // in the case the route map has been dynamically appended to\n lastRouteIndex === lastCurrentIndex &&\n route.matched[lastRouteIndex] === current.matched[lastCurrentIndex]\n ) {\n this.ensureURL();\n if (route.hash) {\n handleScroll(this.router, current, route, false);\n }\n return abort(createNavigationDuplicatedError(current, route))\n }\n\n var ref = resolveQueue(\n this.current.matched,\n route.matched\n );\n var updated = ref.updated;\n var deactivated = ref.deactivated;\n var activated = ref.activated;\n\n var queue = [].concat(\n // in-component leave guards\n extractLeaveGuards(deactivated),\n // global before hooks\n this.router.beforeHooks,\n // in-component update hooks\n extractUpdateHooks(updated),\n // in-config enter guards\n activated.map(function (m) { return m.beforeEnter; }),\n // async components\n resolveAsyncComponents(activated)\n );\n\n var iterator = function (hook, next) {\n if (this$1$1.pending !== route) {\n return abort(createNavigationCancelledError(current, route))\n }\n try {\n hook(route, current, function (to) {\n if (to === false) {\n // next(false) -> abort navigation, ensure current URL\n this$1$1.ensureURL(true);\n abort(createNavigationAbortedError(current, route));\n } else if (isError(to)) {\n this$1$1.ensureURL(true);\n abort(to);\n } else if (\n typeof to === 'string' ||\n (typeof to === 'object' &&\n (typeof to.path === 'string' || typeof to.name === 'string'))\n ) {\n // next('/') or next({ path: '/' }) -> redirect\n abort(createNavigationRedirectedError(current, route));\n if (typeof to === 'object' && to.replace) {\n this$1$1.replace(to);\n } else {\n this$1$1.push(to);\n }\n } else {\n // confirm transition and pass on the value\n next(to);\n }\n });\n } catch (e) {\n abort(e);\n }\n };\n\n runQueue(queue, iterator, function () {\n // wait until async components are resolved before\n // extracting in-component enter guards\n var enterGuards = extractEnterGuards(activated);\n var queue = enterGuards.concat(this$1$1.router.resolveHooks);\n runQueue(queue, iterator, function () {\n if (this$1$1.pending !== route) {\n return abort(createNavigationCancelledError(current, route))\n }\n this$1$1.pending = null;\n onComplete(route);\n if (this$1$1.router.app) {\n this$1$1.router.app.$nextTick(function () {\n handleRouteEntered(route);\n });\n }\n });\n });\n};\n\nHistory.prototype.updateRoute = function updateRoute (route) {\n this.current = route;\n this.cb && this.cb(route);\n};\n\nHistory.prototype.setupListeners = function setupListeners () {\n // Default implementation is empty\n};\n\nHistory.prototype.teardown = function teardown () {\n // clean up event listeners\n // https://github.com/vuejs/vue-router/issues/2341\n this.listeners.forEach(function (cleanupListener) {\n cleanupListener();\n });\n this.listeners = [];\n\n // reset current history route\n // https://github.com/vuejs/vue-router/issues/3294\n this.current = START;\n this.pending = null;\n};\n\nfunction normalizeBase (base) {\n if (!base) {\n if (inBrowser) {\n // respect tag\n var baseEl = document.querySelector('base');\n base = (baseEl && baseEl.getAttribute('href')) || '/';\n // strip full URL origin\n base = base.replace(/^https?:\\/\\/[^\\/]+/, '');\n } else {\n base = '/';\n }\n }\n // make sure there's the starting slash\n if (base.charAt(0) !== '/') {\n base = '/' + base;\n }\n // remove trailing slash\n return base.replace(/\\/$/, '')\n}\n\nfunction resolveQueue (\n current,\n next\n) {\n var i;\n var max = Math.max(current.length, next.length);\n for (i = 0; i < max; i++) {\n if (current[i] !== next[i]) {\n break\n }\n }\n return {\n updated: next.slice(0, i),\n activated: next.slice(i),\n deactivated: current.slice(i)\n }\n}\n\nfunction extractGuards (\n records,\n name,\n bind,\n reverse\n) {\n var guards = flatMapComponents(records, function (def, instance, match, key) {\n var guard = extractGuard(def, name);\n if (guard) {\n return Array.isArray(guard)\n ? guard.map(function (guard) { return bind(guard, instance, match, key); })\n : bind(guard, instance, match, key)\n }\n });\n return flatten(reverse ? guards.reverse() : guards)\n}\n\nfunction extractGuard (\n def,\n key\n) {\n if (typeof def !== 'function') {\n // extend now so that global mixins are applied.\n def = _Vue.extend(def);\n }\n return def.options[key]\n}\n\nfunction extractLeaveGuards (deactivated) {\n return extractGuards(deactivated, 'beforeRouteLeave', bindGuard, true)\n}\n\nfunction extractUpdateHooks (updated) {\n return extractGuards(updated, 'beforeRouteUpdate', bindGuard)\n}\n\nfunction bindGuard (guard, instance) {\n if (instance) {\n return function boundRouteGuard () {\n return guard.apply(instance, arguments)\n }\n }\n}\n\nfunction extractEnterGuards (\n activated\n) {\n return extractGuards(\n activated,\n 'beforeRouteEnter',\n function (guard, _, match, key) {\n return bindEnterGuard(guard, match, key)\n }\n )\n}\n\nfunction bindEnterGuard (\n guard,\n match,\n key\n) {\n return function routeEnterGuard (to, from, next) {\n return guard(to, from, function (cb) {\n if (typeof cb === 'function') {\n if (!match.enteredCbs[key]) {\n match.enteredCbs[key] = [];\n }\n match.enteredCbs[key].push(cb);\n }\n next(cb);\n })\n }\n}\n\n/* */\n\nvar HTML5History = /*@__PURE__*/(function (History) {\n function HTML5History (router, base) {\n History.call(this, router, base);\n\n this._startLocation = getLocation(this.base);\n }\n\n if ( History ) HTML5History.__proto__ = History;\n HTML5History.prototype = Object.create( History && History.prototype );\n HTML5History.prototype.constructor = HTML5History;\n\n HTML5History.prototype.setupListeners = function setupListeners () {\n var this$1$1 = this;\n\n if (this.listeners.length > 0) {\n return\n }\n\n var router = this.router;\n var expectScroll = router.options.scrollBehavior;\n var supportsScroll = supportsPushState && expectScroll;\n\n if (supportsScroll) {\n this.listeners.push(setupScroll());\n }\n\n var handleRoutingEvent = function () {\n var current = this$1$1.current;\n\n // Avoiding first `popstate` event dispatched in some browsers but first\n // history route not updated since async guard at the same time.\n var location = getLocation(this$1$1.base);\n if (this$1$1.current === START && location === this$1$1._startLocation) {\n return\n }\n\n this$1$1.transitionTo(location, function (route) {\n if (supportsScroll) {\n handleScroll(router, route, current, true);\n }\n });\n };\n window.addEventListener('popstate', handleRoutingEvent);\n this.listeners.push(function () {\n window.removeEventListener('popstate', handleRoutingEvent);\n });\n };\n\n HTML5History.prototype.go = function go (n) {\n window.history.go(n);\n };\n\n HTML5History.prototype.push = function push (location, onComplete, onAbort) {\n var this$1$1 = this;\n\n var ref = this;\n var fromRoute = ref.current;\n this.transitionTo(location, function (route) {\n pushState(cleanPath(this$1$1.base + route.fullPath));\n handleScroll(this$1$1.router, route, fromRoute, false);\n onComplete && onComplete(route);\n }, onAbort);\n };\n\n HTML5History.prototype.replace = function replace (location, onComplete, onAbort) {\n var this$1$1 = this;\n\n var ref = this;\n var fromRoute = ref.current;\n this.transitionTo(location, function (route) {\n replaceState(cleanPath(this$1$1.base + route.fullPath));\n handleScroll(this$1$1.router, route, fromRoute, false);\n onComplete && onComplete(route);\n }, onAbort);\n };\n\n HTML5History.prototype.ensureURL = function ensureURL (push) {\n if (getLocation(this.base) !== this.current.fullPath) {\n var current = cleanPath(this.base + this.current.fullPath);\n push ? pushState(current) : replaceState(current);\n }\n };\n\n HTML5History.prototype.getCurrentLocation = function getCurrentLocation () {\n return getLocation(this.base)\n };\n\n return HTML5History;\n}(History));\n\nfunction getLocation (base) {\n var path = window.location.pathname;\n var pathLowerCase = path.toLowerCase();\n var baseLowerCase = base.toLowerCase();\n // base=\"/a\" shouldn't turn path=\"/app\" into \"/a/pp\"\n // https://github.com/vuejs/vue-router/issues/3555\n // so we ensure the trailing slash in the base\n if (base && ((pathLowerCase === baseLowerCase) ||\n (pathLowerCase.indexOf(cleanPath(baseLowerCase + '/')) === 0))) {\n path = path.slice(base.length);\n }\n return (path || '/') + window.location.search + window.location.hash\n}\n\n/* */\n\nvar HashHistory = /*@__PURE__*/(function (History) {\n function HashHistory (router, base, fallback) {\n History.call(this, router, base);\n // check history fallback deeplinking\n if (fallback && checkFallback(this.base)) {\n return\n }\n ensureSlash();\n }\n\n if ( History ) HashHistory.__proto__ = History;\n HashHistory.prototype = Object.create( History && History.prototype );\n HashHistory.prototype.constructor = HashHistory;\n\n // this is delayed until the app mounts\n // to avoid the hashchange listener being fired too early\n HashHistory.prototype.setupListeners = function setupListeners () {\n var this$1$1 = this;\n\n if (this.listeners.length > 0) {\n return\n }\n\n var router = this.router;\n var expectScroll = router.options.scrollBehavior;\n var supportsScroll = supportsPushState && expectScroll;\n\n if (supportsScroll) {\n this.listeners.push(setupScroll());\n }\n\n var handleRoutingEvent = function () {\n var current = this$1$1.current;\n if (!ensureSlash()) {\n return\n }\n this$1$1.transitionTo(getHash(), function (route) {\n if (supportsScroll) {\n handleScroll(this$1$1.router, route, current, true);\n }\n if (!supportsPushState) {\n replaceHash(route.fullPath);\n }\n });\n };\n var eventType = supportsPushState ? 'popstate' : 'hashchange';\n window.addEventListener(\n eventType,\n handleRoutingEvent\n );\n this.listeners.push(function () {\n window.removeEventListener(eventType, handleRoutingEvent);\n });\n };\n\n HashHistory.prototype.push = function push (location, onComplete, onAbort) {\n var this$1$1 = this;\n\n var ref = this;\n var fromRoute = ref.current;\n this.transitionTo(\n location,\n function (route) {\n pushHash(route.fullPath);\n handleScroll(this$1$1.router, route, fromRoute, false);\n onComplete && onComplete(route);\n },\n onAbort\n );\n };\n\n HashHistory.prototype.replace = function replace (location, onComplete, onAbort) {\n var this$1$1 = this;\n\n var ref = this;\n var fromRoute = ref.current;\n this.transitionTo(\n location,\n function (route) {\n replaceHash(route.fullPath);\n handleScroll(this$1$1.router, route, fromRoute, false);\n onComplete && onComplete(route);\n },\n onAbort\n );\n };\n\n HashHistory.prototype.go = function go (n) {\n window.history.go(n);\n };\n\n HashHistory.prototype.ensureURL = function ensureURL (push) {\n var current = this.current.fullPath;\n if (getHash() !== current) {\n push ? pushHash(current) : replaceHash(current);\n }\n };\n\n HashHistory.prototype.getCurrentLocation = function getCurrentLocation () {\n return getHash()\n };\n\n return HashHistory;\n}(History));\n\nfunction checkFallback (base) {\n var location = getLocation(base);\n if (!/^\\/#/.test(location)) {\n window.location.replace(cleanPath(base + '/#' + location));\n return true\n }\n}\n\nfunction ensureSlash () {\n var path = getHash();\n if (path.charAt(0) === '/') {\n return true\n }\n replaceHash('/' + path);\n return false\n}\n\nfunction getHash () {\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 index = href.indexOf('#');\n // empty path\n if (index < 0) { return '' }\n\n href = href.slice(index + 1);\n\n return href\n}\n\nfunction getUrl (path) {\n var href = window.location.href;\n var i = href.indexOf('#');\n var base = i >= 0 ? href.slice(0, i) : href;\n return (base + \"#\" + path)\n}\n\nfunction pushHash (path) {\n if (supportsPushState) {\n pushState(getUrl(path));\n } else {\n window.location.hash = path;\n }\n}\n\nfunction replaceHash (path) {\n if (supportsPushState) {\n replaceState(getUrl(path));\n } else {\n window.location.replace(getUrl(path));\n }\n}\n\n/* */\n\nvar AbstractHistory = /*@__PURE__*/(function (History) {\n function AbstractHistory (router, base) {\n History.call(this, router, base);\n this.stack = [];\n this.index = -1;\n }\n\n if ( History ) AbstractHistory.__proto__ = History;\n AbstractHistory.prototype = Object.create( History && History.prototype );\n AbstractHistory.prototype.constructor = AbstractHistory;\n\n AbstractHistory.prototype.push = function push (location, onComplete, onAbort) {\n var this$1$1 = this;\n\n this.transitionTo(\n location,\n function (route) {\n this$1$1.stack = this$1$1.stack.slice(0, this$1$1.index + 1).concat(route);\n this$1$1.index++;\n onComplete && onComplete(route);\n },\n onAbort\n );\n };\n\n AbstractHistory.prototype.replace = function replace (location, onComplete, onAbort) {\n var this$1$1 = this;\n\n this.transitionTo(\n location,\n function (route) {\n this$1$1.stack = this$1$1.stack.slice(0, this$1$1.index).concat(route);\n onComplete && onComplete(route);\n },\n onAbort\n );\n };\n\n AbstractHistory.prototype.go = function go (n) {\n var this$1$1 = this;\n\n var targetIndex = this.index + n;\n if (targetIndex < 0 || targetIndex >= this.stack.length) {\n return\n }\n var route = this.stack[targetIndex];\n this.confirmTransition(\n route,\n function () {\n var prev = this$1$1.current;\n this$1$1.index = targetIndex;\n this$1$1.updateRoute(route);\n this$1$1.router.afterHooks.forEach(function (hook) {\n hook && hook(route, prev);\n });\n },\n function (err) {\n if (isNavigationFailure(err, NavigationFailureType.duplicated)) {\n this$1$1.index = targetIndex;\n }\n }\n );\n };\n\n AbstractHistory.prototype.getCurrentLocation = function getCurrentLocation () {\n var current = this.stack[this.stack.length - 1];\n return current ? current.fullPath : '/'\n };\n\n AbstractHistory.prototype.ensureURL = function ensureURL () {\n // noop\n };\n\n return AbstractHistory;\n}(History));\n\n/* */\n\n\n\nvar VueRouter = function VueRouter (options) {\n if ( options === void 0 ) options = {};\n\n if (process.env.NODE_ENV !== 'production') {\n warn(this instanceof VueRouter, \"Router must be called with the new operator.\");\n }\n this.app = null;\n this.apps = [];\n this.options = options;\n this.beforeHooks = [];\n this.resolveHooks = [];\n this.afterHooks = [];\n this.matcher = createMatcher(options.routes || [], this);\n\n var mode = options.mode || 'hash';\n this.fallback =\n mode === 'history' && !supportsPushState && options.fallback !== false;\n if (this.fallback) {\n mode = 'hash';\n }\n if (!inBrowser) {\n mode = 'abstract';\n }\n this.mode = mode;\n\n switch (mode) {\n case 'history':\n this.history = new HTML5History(this, options.base);\n break\n case 'hash':\n this.history = new HashHistory(this, options.base, this.fallback);\n break\n case 'abstract':\n this.history = new AbstractHistory(this, options.base);\n break\n default:\n if (process.env.NODE_ENV !== 'production') {\n assert(false, (\"invalid mode: \" + mode));\n }\n }\n};\n\nvar prototypeAccessors = { currentRoute: { configurable: true } };\n\nVueRouter.prototype.match = function match (raw, current, redirectedFrom) {\n return this.matcher.match(raw, current, redirectedFrom)\n};\n\nprototypeAccessors.currentRoute.get = function () {\n return this.history && this.history.current\n};\n\nVueRouter.prototype.init = function init (app /* Vue component instance */) {\n var this$1$1 = this;\n\n process.env.NODE_ENV !== 'production' &&\n assert(\n install.installed,\n \"not installed. Make sure to call `Vue.use(VueRouter)` \" +\n \"before creating root instance.\"\n );\n\n this.apps.push(app);\n\n // set up app destroyed handler\n // https://github.com/vuejs/vue-router/issues/2639\n app.$once('hook:destroyed', function () {\n // clean out app from this.apps array once destroyed\n var index = this$1$1.apps.indexOf(app);\n if (index > -1) { this$1$1.apps.splice(index, 1); }\n // ensure we still have a main app or null if no apps\n // we do not release the router so it can be reused\n if (this$1$1.app === app) { this$1$1.app = this$1$1.apps[0] || null; }\n\n if (!this$1$1.app) { this$1$1.history.teardown(); }\n });\n\n // main app previously initialized\n // return as we don't need to set up new history listener\n if (this.app) {\n return\n }\n\n this.app = app;\n\n var history = this.history;\n\n if (history instanceof HTML5History || history instanceof HashHistory) {\n var handleInitialScroll = function (routeOrError) {\n var from = history.current;\n var expectScroll = this$1$1.options.scrollBehavior;\n var supportsScroll = supportsPushState && expectScroll;\n\n if (supportsScroll && 'fullPath' in routeOrError) {\n handleScroll(this$1$1, routeOrError, from, false);\n }\n };\n var setupListeners = function (routeOrError) {\n history.setupListeners();\n handleInitialScroll(routeOrError);\n };\n history.transitionTo(\n history.getCurrentLocation(),\n setupListeners,\n setupListeners\n );\n }\n\n history.listen(function (route) {\n this$1$1.apps.forEach(function (app) {\n app._route = route;\n });\n });\n};\n\nVueRouter.prototype.beforeEach = function beforeEach (fn) {\n return registerHook(this.beforeHooks, fn)\n};\n\nVueRouter.prototype.beforeResolve = function beforeResolve (fn) {\n return registerHook(this.resolveHooks, fn)\n};\n\nVueRouter.prototype.afterEach = function afterEach (fn) {\n return registerHook(this.afterHooks, fn)\n};\n\nVueRouter.prototype.onReady = function onReady (cb, errorCb) {\n this.history.onReady(cb, errorCb);\n};\n\nVueRouter.prototype.onError = function onError (errorCb) {\n this.history.onError(errorCb);\n};\n\nVueRouter.prototype.push = function push (location, onComplete, onAbort) {\n var this$1$1 = this;\n\n // $flow-disable-line\n if (!onComplete && !onAbort && typeof Promise !== 'undefined') {\n return new Promise(function (resolve, reject) {\n this$1$1.history.push(location, resolve, reject);\n })\n } else {\n this.history.push(location, onComplete, onAbort);\n }\n};\n\nVueRouter.prototype.replace = function replace (location, onComplete, onAbort) {\n var this$1$1 = this;\n\n // $flow-disable-line\n if (!onComplete && !onAbort && typeof Promise !== 'undefined') {\n return new Promise(function (resolve, reject) {\n this$1$1.history.replace(location, resolve, reject);\n })\n } else {\n this.history.replace(location, onComplete, onAbort);\n }\n};\n\nVueRouter.prototype.go = function go (n) {\n this.history.go(n);\n};\n\nVueRouter.prototype.back = function back () {\n this.go(-1);\n};\n\nVueRouter.prototype.forward = function forward () {\n this.go(1);\n};\n\nVueRouter.prototype.getMatchedComponents = function getMatchedComponents (to) {\n var route = to\n ? to.matched\n ? to\n : this.resolve(to).route\n : this.currentRoute;\n if (!route) {\n return []\n }\n return [].concat.apply(\n [],\n route.matched.map(function (m) {\n return Object.keys(m.components).map(function (key) {\n return m.components[key]\n })\n })\n )\n};\n\nVueRouter.prototype.resolve = function resolve (\n to,\n current,\n append\n) {\n current = current || this.history.current;\n var location = normalizeLocation(to, current, append, this);\n var route = this.match(location, current);\n var fullPath = route.redirectedFrom || route.fullPath;\n var base = this.history.base;\n var href = createHref(base, fullPath, this.mode);\n return {\n location: location,\n route: route,\n href: href,\n // for backwards compat\n normalizedTo: location,\n resolved: route\n }\n};\n\nVueRouter.prototype.getRoutes = function getRoutes () {\n return this.matcher.getRoutes()\n};\n\nVueRouter.prototype.addRoute = function addRoute (parentOrRoute, route) {\n this.matcher.addRoute(parentOrRoute, route);\n if (this.history.current !== START) {\n this.history.transitionTo(this.history.getCurrentLocation());\n }\n};\n\nVueRouter.prototype.addRoutes = function addRoutes (routes) {\n if (process.env.NODE_ENV !== 'production') {\n warn(false, 'router.addRoutes() is deprecated and has been removed in Vue Router 4. Use router.addRoute() instead.');\n }\n this.matcher.addRoutes(routes);\n if (this.history.current !== START) {\n this.history.transitionTo(this.history.getCurrentLocation());\n }\n};\n\nObject.defineProperties( VueRouter.prototype, prototypeAccessors );\n\nvar VueRouter$1 = VueRouter;\n\nfunction registerHook (list, fn) {\n list.push(fn);\n return function () {\n var i = list.indexOf(fn);\n if (i > -1) { list.splice(i, 1); }\n }\n}\n\nfunction createHref (base, fullPath, mode) {\n var path = mode === 'hash' ? '#' + fullPath : fullPath;\n return base ? cleanPath(base + '/' + path) : path\n}\n\n// We cannot remove this as it would be a breaking change\nVueRouter.install = install;\nVueRouter.version = '3.6.5';\nVueRouter.isNavigationFailure = isNavigationFailure;\nVueRouter.NavigationFailureType = NavigationFailureType;\nVueRouter.START_LOCATION = START;\n\nif (inBrowser && window.Vue) {\n window.Vue.use(VueRouter);\n}\n\nvar version = '3.6.5';\n\nexport { NavigationFailureType, Link as RouterLink, View as RouterView, START as START_LOCATION, VueRouter$1 as default, isNavigationFailure, version };\n","import type Guid from \"@/app/types/common/guid\";\nimport { MenuItem } from \"@/app/ui/navigation/types\";\nimport type { Location } from \"vue-router\";\nimport { EnumFeatureFlag } from \"@/app/services/generated/enums/enumFeatureFlag.generated\";\nimport tenantStore from \"@/store/modules/tenantStore\";\nimport { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\n\nexport const containerTrackingMenu = {\n root: \"navigation_container_tracking_group\",\n list: \"tracked_containers\",\n listLocation: (): Location => ({ name: containerTrackingMenu.list }),\n v6List: \"tracked_containers_v6\",\n v6ListLocation: (): Location => ({ name: containerTrackingMenu.v6List }),\n create: \"containers_create\",\n v6Create: \"migrate_containers\",\n v6CreateLocation: (): Location => ({ name: containerTrackingMenu.v6Create }),\n view: \"containers_edit\",\n viewContainer: (id: Guid): Location => ({\n name: containerTrackingMenu.view,\n params: {\n id: id.toString(),\n },\n }),\n kegstarList: \"tracked_kegstar_containers\",\n viewKegstarListLocation: (): Location => ({\n name: containerTrackingMenu.kegstarList,\n }),\n containerTreatmentReport: \"container_treatment_report\",\n};\n\nexport const buildContainerTrackingMenuItems = () => [\n MenuItem.forBranch({\n name: containerTrackingMenu.root,\n icon: \"gps_fixed\",\n visible: () =>\n hasPermissionsUsingUserStore([\n EnumUserPermission.menuContainerTrackingView,\n ]),\n subMenus: [\n MenuItem.fromOpts({\n name: containerTrackingMenu.list,\n url: \"/containers/list\",\n view: () =>\n import(\n /* webpackChunkName: \"containers\" */ \"@/components/pages/containers/ListContainers.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: containerTrackingMenu.v6List,\n url: \"/containers/v6list\",\n view: () =>\n import(\n /* webpackChunkName: \"migrate\" */ \"@/components/pages/containers/ListV6Containers.vue\"\n ),\n requiredFeatureFlag: EnumFeatureFlag.v6ContainerMigrator,\n }),\n MenuItem.fromOpts({\n name: containerTrackingMenu.kegstarList,\n url: \"/containers/kegstar\",\n view: () =>\n import(\n /* webpackChunkName: \"migrate\" */ \"@/components/pages/containers/ListKegstarContainers\"\n ),\n visible: tenantStore.state.kegstarSettings.isEnabled,\n }),\n MenuItem.fromOpts({\n name: containerTrackingMenu.create,\n url: \"/containers/create\",\n breadcrumbParentName: containerTrackingMenu.list,\n view: () =>\n import(\n /* webpackChunkName: \"containers\" */ \"@/components/pages/containers/CreateContainers.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: containerTrackingMenu.v6Create,\n url: \"/containers/migrate\",\n breadcrumbParentName: containerTrackingMenu.v6List,\n view: () =>\n import(\n /* webpackChunkName: \"migrate\" */ \"@/components/pages/containers/MigrateContainers.vue\"\n ),\n visible: false,\n requiredFeatureFlag: EnumFeatureFlag.v6ContainerMigrator,\n }),\n MenuItem.fromOpts({\n name: containerTrackingMenu.containerTreatmentReport,\n url: \"/containers/container-treatment-report\",\n view: () =>\n import(\n /* webpackChunkName: \"containers\" */ \"@/components/pages/containers/ContainerTreatmentReport.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: containerTrackingMenu.view,\n url: \"/containers/:id\",\n breadcrumbParentName: containerTrackingMenu.list,\n view: () =>\n import(\n /* webpackChunkName: \"containers\" */ \"@/components/pages/containers/EditContainer.vue\"\n ),\n visible: false,\n }),\n ],\n }),\n];\n","import { MenuItem } from \"@/app/ui/navigation/types\";\nimport { EnumAlcoholType } from \"@/app/services/generated/enums/enumAlcoholType.generated\";\nimport { LocalDate } from \"@js-joda/core\";\nimport type { Location } from \"vue-router\";\nimport type Guid from \"@/app/types/common/guid\";\nimport {\n dutySchemeType,\n useDutyRulesForHeaders,\n} from \"@/components/pages/duty/composables/dutyConfiguration\";\nimport { EnumDutyScheme } from \"@/app/services/generated/enums/enumDutyScheme.generated\";\nimport { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\n\nconst { dutyRules } = useDutyRulesForHeaders();\n\nexport const dutyMenuGerman = {\n root: \"navigation_duty_group_german\",\n beerDuty: {\n root: \"navigation_beer_duty_group\",\n dutyReturnList: \"german_duty_beer_duty_return_list\",\n dutyReturnListLocation: (): Location => ({\n name: dutyMenuGerman.beerDuty.dutyReturnList,\n }),\n editReturn: \"german_duty_beer_duty_edit_return\",\n editReturnLocation: (id: Guid, isEditing: boolean): Location => ({\n name: dutyMenuGerman.beerDuty.editReturn,\n params: {\n id: id.toString(),\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n createReturn: \"german_duty_beer_duty_create_return\",\n createReturnLocation: (): Location => ({\n name: dutyMenuGerman.beerDuty.createReturn,\n }),\n audit: \"german_duty_beer_duty_audit_report\",\n viewAudit: (fromDate: LocalDate, toDate: LocalDate): Location => ({\n name: dutyMenuGerman.beerDuty.audit,\n params: {\n fromDateInclusive: fromDate.toString(),\n toDateInclusive: toDate.toString(),\n },\n }),\n },\n};\n\nexport const buildDutyMenuGermanItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n name: dutyMenuGerman.root,\n icon: \"assignment\",\n visible: () =>\n dutySchemeType.value === EnumDutyScheme.germany &&\n hasPermissionsUsingUserStore([EnumUserPermission.menuDutyView]),\n subMenus: [\n MenuItem.fromOpts({\n name: dutyMenuGerman.beerDuty.dutyReturnList,\n url: \"/duty/german/beerreturn/list\",\n breadcrumbParentName: dutyMenuGerman.beerDuty.root,\n // german duty is enabled if movement type is shown\n visible: () => dutyRules.value.germanBeerDutyMovementType.show,\n view: () =>\n import(\n /* webpackChunkName: \"duty\" */ \"@/components/pages/duty/german/ListGermanBeerDutyReturns\"\n ),\n }),\n MenuItem.fromOpts({\n name: dutyMenuGerman.beerDuty.editReturn,\n url: \"/duty/german/beerreturn/:id/:mode\",\n breadcrumbParentName: dutyMenuGerman.beerDuty.dutyReturnList,\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/duty/german/EditGermanBeerDutyReturn\"\n ),\n visible: false,\n componentProps: (route) => {\n return {\n id: route.params.id,\n editing:\n route.params.id &&\n route.params.mode.toLowerCase().trim() === \"edit\",\n };\n },\n }),\n MenuItem.fromOpts({\n name: dutyMenuGerman.beerDuty.createReturn,\n url: \"/duty/german/beerreturn/create\",\n breadcrumbParentName: dutyMenuGerman.beerDuty.dutyReturnList,\n view: () =>\n import(\n /* webpackChunkName: \"distribution\" */ \"@/components/pages/duty/german/EditGermanBeerDutyReturn\"\n ),\n visible: false,\n componentProps: (route) => ({\n editing: true,\n }),\n }),\n MenuItem.fromOpts({\n name: dutyMenuGerman.beerDuty.audit,\n url: \"/duty/german/audit\",\n componentProps: (r) => ({\n fromDateInclusive:\n r.params.fromDateInclusive &&\n LocalDate.parse(r.params.fromDateInclusive),\n toDateInclusive:\n r.params.toDateInclusive &&\n LocalDate.parse(r.params.toDateInclusive),\n alcoholType: [EnumAlcoholType.beer],\n }),\n view: () => import(\"@/components/pages/duty/de/DutyAudit.vue\"),\n visible: () => dutyRules.value.germanBeerDutyMovementType.show,\n }),\n ],\n }),\n];\n","import { MenuItem } from \"@/app/ui/navigation/types\";\nimport type { Location } from \"vue-router\";\nimport { dutySchemeType } from \"@/components/pages/duty/composables/dutyConfiguration\";\nimport { EnumDutyScheme } from \"@/app/services/generated/enums/enumDutyScheme.generated\";\nimport type Guid from \"@/app/types/common/guid\";\nimport { LocalDate } from \"@js-joda/core\";\nimport { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\n\nexport const dutyMenuAustralian = {\n root: \"navigation_duty_group_australian\",\n dutyReturnList: \"australian_duty_return_list\",\n dutyReturnListLocation: (): Location => ({\n name: dutyMenuAustralian.dutyReturnList,\n }),\n editReturn: \"australian_duty_edit_return\",\n editReturnLocation: (id: Guid, isEditing: boolean): Location => ({\n name: dutyMenuAustralian.editReturn,\n params: {\n id: id.toString(),\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n createReturn: \"australian_duty_create_return\",\n createReturnLocation: (): Location => ({\n name: dutyMenuAustralian.createReturn,\n }),\n audit: \"australian_duty_audit_report\",\n viewAudit: (fromDate: LocalDate, toDate: LocalDate): Location => ({\n name: dutyMenuAustralian.audit,\n params: {\n fromDateInclusive: fromDate.toString(),\n toDateInclusive: toDate.toString(),\n },\n }),\n liquorReturn: \"australian_duty_liquor_return\",\n viewLiquorReturn: (fromDate: LocalDate, toDate: LocalDate): Location => ({\n name: dutyMenuAustralian.liquorReturn,\n params: {\n fromDateInclusive: fromDate.toString(),\n toDateInclusive: toDate.toString(),\n },\n }),\n};\n\nexport const buildDutyMenuAustralianItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n name: dutyMenuAustralian.root,\n icon: \"assignment\",\n visible: () =>\n dutySchemeType.value === EnumDutyScheme.australia &&\n hasPermissionsUsingUserStore([EnumUserPermission.menuDutyView]),\n subMenus: [\n MenuItem.fromOpts({\n name: dutyMenuAustralian.dutyReturnList,\n url: \"/duty/australian/list\",\n breadcrumbParentName: dutyMenuAustralian.root,\n view: () =>\n import(\n /* webpackChunkName: \"australian-duty\" */ \"@/components/pages/duty/australian/ListAustralianDutyReturn\"\n ),\n }),\n MenuItem.fromOpts({\n name: dutyMenuAustralian.editReturn,\n url: \"/duty/australian/:id/:mode\",\n breadcrumbParentName: dutyMenuAustralian.dutyReturnList,\n view: () =>\n import(\n /* webpackChunkName: \"australian-duty\" */ \"@/components/pages/duty/australian/EditAustralianDutyReturn\"\n ),\n visible: false,\n componentProps: (route) => {\n return {\n id: route.params.id,\n editing:\n route.params.id &&\n route.params.mode.toLowerCase().trim() === \"edit\",\n };\n },\n }),\n MenuItem.fromOpts({\n name: dutyMenuAustralian.createReturn,\n url: \"/duty/australian/create\",\n breadcrumbParentName: dutyMenuAustralian.dutyReturnList,\n view: () =>\n import(\n /* webpackChunkName: \"australian-duty\" */ \"@/components/pages/duty/australian/EditAustralianDutyReturn\"\n ),\n visible: false,\n componentProps: (route) => ({\n editing: true,\n }),\n }),\n MenuItem.fromOpts({\n name: dutyMenuAustralian.audit,\n url: \"/duty/australian/audit\",\n componentProps: (r) => ({\n fromDateInclusive:\n r.params.fromDateInclusive &&\n LocalDate.parse(r.params.fromDateInclusive),\n toDateInclusive:\n r.params.toDateInclusive &&\n LocalDate.parse(r.params.toDateInclusive),\n }),\n view: () =>\n import(\"@/components/pages/duty/australian/AustralianDutyAudit.vue\"),\n }),\n MenuItem.fromOpts({\n name: dutyMenuAustralian.liquorReturn,\n url: \"/duty/australian/westernaustralialiquorreturn\",\n componentProps: (r) => ({\n fromDateInclusive:\n r.params.fromDateInclusive &&\n LocalDate.parse(r.params.fromDateInclusive),\n toDateInclusive:\n r.params.toDateInclusive &&\n LocalDate.parse(r.params.toDateInclusive),\n }),\n view: () =>\n import(\n \"@/components/pages/duty/australian/WesternAustraliaLiquorReturn\"\n ),\n }),\n ],\n }),\n];\n","import type { Location } from \"vue-router\";\nimport { MenuItem } from \"@/app/ui/navigation/types\";\nimport { dutySchemeType } from \"@/components/pages/duty/composables/dutyConfiguration\";\nimport { EnumDutyScheme } from \"@/app/services/generated/enums/enumDutyScheme.generated\";\nimport type Guid from \"@/app/types/common/guid\";\nimport { LocalDate } from \"@js-joda/core\";\nimport { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\n\nexport const dutyMenuSouthAfrican = {\n root: \"navigation_duty_group_south_african\",\n dutyReturnList: \"south_african_duty_returns_list\",\n dutyReturnListLocation: (): Location => ({\n name: dutyMenuSouthAfrican.dutyReturnList,\n }),\n editReturn: \"south_african_duty_edit_return\",\n editReturnLocation: (id: Guid, isEditing: boolean): Location => ({\n name: dutyMenuSouthAfrican.editReturn,\n params: {\n id: id.toString(),\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n createReturn: \"south_african_duty_create_return\",\n createReturnLocation: (): Location => ({\n name: dutyMenuSouthAfrican.createReturn,\n }),\n audit: \"south_african_duty_audit_report\",\n viewAudit: (fromDate: LocalDate, toDate: LocalDate): Location => ({\n name: dutyMenuSouthAfrican.audit,\n params: {\n fromDateInclusive: fromDate.toString(),\n toDateInclusive: toDate.toString(),\n },\n }),\n};\n\nexport const buildDutyMenuSouthAfricanItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n name: dutyMenuSouthAfrican.root,\n icon: \"assignment\",\n visible: () =>\n dutySchemeType.value === EnumDutyScheme.southAfrica &&\n hasPermissionsUsingUserStore([EnumUserPermission.menuDutyView]),\n subMenus: [\n MenuItem.fromOpts({\n name: dutyMenuSouthAfrican.dutyReturnList,\n url: \"/duty/southafrica/list\",\n breadcrumbParentName: dutyMenuSouthAfrican.root,\n view: () =>\n import(\n /* webpackChunkName: \"south-african-duty\" */ \"@/components/pages/duty/south_african/ListSouthAfricanDutyReturns\"\n ),\n }),\n MenuItem.fromOpts({\n name: dutyMenuSouthAfrican.editReturn,\n url: \"/duty/southafrica/:id/:mode\",\n breadcrumbParentName: dutyMenuSouthAfrican.dutyReturnList,\n view: () =>\n import(\n /* webpackChunkName: \"south-african-duty\" */ \"@/components/pages/duty/south_african/EditSouthAfricanDutyReturn\"\n ),\n visible: false,\n componentProps: (route) => {\n return {\n id: route.params.id,\n editing:\n route.params.id &&\n route.params.mode.toLowerCase().trim() === \"edit\",\n };\n },\n }),\n MenuItem.fromOpts({\n name: dutyMenuSouthAfrican.createReturn,\n url: \"/duty/southafrica/create\",\n breadcrumbParentName: dutyMenuSouthAfrican.dutyReturnList,\n view: () =>\n import(\n /* webpackChunkName: \"south-african-duty\" */ \"@/components/pages/duty/south_african/EditSouthAfricanDutyReturn\"\n ),\n visible: false,\n componentProps: (route) => ({\n editing: true,\n }),\n }),\n MenuItem.fromOpts({\n name: dutyMenuSouthAfrican.audit,\n url: \"/duty/southafrica/audit\",\n componentProps: (r) => ({\n fromDateInclusive:\n r.params.fromDateInclusive &&\n LocalDate.parse(r.params.fromDateInclusive),\n toDateInclusive:\n r.params.toDateInclusive &&\n LocalDate.parse(r.params.toDateInclusive),\n }),\n view: () =>\n import(\n \"@/components/pages/duty/south_african/SouthAfricanDutyAudit.vue\"\n ),\n }),\n ],\n }),\n];\n","import { MenuItem } from \"@/app/ui/navigation/types\";\nimport { EnumAlcoholType } from \"@/app/services/generated/enums/enumAlcoholType.generated\";\nimport { LocalDate } from \"@js-joda/core\";\nimport type { Location } from \"vue-router\";\nimport type Guid from \"@/app/types/common/guid\";\nimport { dutySchemeType } from \"@/components/pages/duty/composables/dutyConfiguration\";\nimport { EnumDutyScheme } from \"@/app/services/generated/enums/enumDutyScheme.generated\";\nimport { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\n\nexport const dutyMenuUk = {\n root: \"navigation_duty_group_uk\",\n suspendedReceipts: \"duty_suspended_receipts\",\n dutySuspendedOrders: \"duty_suspended_orders\",\n alcoholProduction: \"duty_alcohol_production\",\n newDutyAudit: \"duty_new_duty_audit\",\n viewNewAudit: (fromDate: LocalDate, toDate: LocalDate): Location => ({\n name: dutyMenuUk.newDutyAudit,\n params: {\n fromDate: fromDate.toString(),\n toDate: toDate.toString(),\n },\n }),\n newDutyReturn: \"duty_new_duty_return\",\n viewNewReturn: (id: Guid): Location => ({\n name: dutyMenuUk.newDutyReturn,\n params: { id: id.toString() },\n }),\n createNewReturn: (): Location => ({\n name: dutyMenuUk.newDutyReturn,\n }),\n newDutyReturnList: \"duty_new_duty_return_list\",\n viewNewDutyReturnList: (): Location => ({\n name: dutyMenuUk.newDutyReturnList,\n }),\n oldDutyStockList: \"duty_old_duty_stock_list\",\n newDutyAllOnlineSubmissionDetails:\n \"duty_new_duty_all_online_submission_details\",\n viewNewDutyAllOnlineSubmissionDetails: (id: Guid): Location => ({\n name: dutyMenuUk.newDutyAllOnlineSubmissionDetails,\n params: { id: id.toString() },\n }),\n newDutyBeerOnlineSubmissionDetails:\n \"duty_new_duty_beer_online_submission_details\",\n viewNewDutyBeerOnlineSubmissionDetails: (id: Guid): Location => ({\n name: dutyMenuUk.newDutyBeerOnlineSubmissionDetails,\n params: { id: id.toString() },\n }),\n dutyRatesCalculator: \"duty_rates_calculator\",\n legacy: {\n root: \"navigation_duty_legacy_group\",\n beerDuty: {\n root: \"navigation_beer_duty_group\",\n dashboard: \"beer_duty_dashboard\",\n return: \"beer_duty_return\",\n viewReturn: (id: Guid): Location => ({\n name: dutyMenuUk.legacy.beerDuty.return,\n params: { id: id.toString() },\n }),\n audit: \"beer_duty_audit_report\",\n viewAudit: (fromDate: LocalDate, toDate: LocalDate): Location => ({\n name: dutyMenuUk.legacy.beerDuty.audit,\n params: {\n fromDate: fromDate.toString(),\n toDate: toDate.toString(),\n },\n }),\n spoiltBeerList: \"spoilt_beer_list\",\n dutyReturnList: \"beer_duty_return_list\",\n },\n spiritDuty: {\n root: \"navigation_spirit_duty_group\",\n audit: \"spirit_duty_audit_report\",\n },\n ciderDuty: {\n root: \"navigation_cider_duty_group\",\n audit: \"cider_duty_audit_report\",\n },\n wineDuty: {\n root: \"navigation_wine_duty_group\",\n audit: \"wine_duty_audit_report\",\n },\n dutyLists: \"duty_rates_list\",\n },\n};\n\nexport const buildDutyMenuUkItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n name: dutyMenuUk.root,\n icon: \"assignment\",\n visible: () =>\n dutySchemeType.value === EnumDutyScheme.uk &&\n hasPermissionsUsingUserStore([EnumUserPermission.menuDutyView]),\n subMenus: [\n MenuItem.fromOpts({\n name: dutyMenuUk.suspendedReceipts,\n url: \"/duty/dutysuspendedreceipts/list\",\n view: () =>\n import(\n /* webpackChunkName: \"duty\" */ \"@/components/pages/duty/uk/ListDutySuspendedReceipts.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: dutyMenuUk.dutySuspendedOrders,\n url: \"/duty/dutysuspendedorders\",\n view: () =>\n import(\n /* webpackChunkName: \"duty\" */ \"@/components/pages/duty/uk/DutySuspendedOrdersReport.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: dutyMenuUk.alcoholProduction,\n url: \"/duty/alcoholproduction\",\n view: () =>\n import(\n /* webpackChunkName: \"duty\" */ \"@/components/pages/duty/uk/AlcoholProductionFigures.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: dutyMenuUk.newDutyAudit,\n url: \"/duty/audit\",\n componentProps: (r) => ({\n fromDateInclusive:\n r.params.fromDate && LocalDate.parse(r.params.fromDate),\n toDateInclusive: r.params.toDate && LocalDate.parse(r.params.toDate),\n }),\n view: () =>\n import(\n /* webpackChunkName: \"duty\" */ \"@/components/pages/duty/uk/NewDutyAudit.vue\"\n ),\n routeMetadata: {\n key: dutyMenuUk.newDutyAudit,\n },\n }),\n MenuItem.fromOpts({\n name: dutyMenuUk.newDutyReturn,\n url: \"/duty/return/:id?\",\n view: () =>\n import(\n /* webpackChunkName: \"duty\" */ \"@/components/pages/duty/uk/NewDutyReturn.vue\"\n ),\n componentProps: (route) => ({\n id: route.params.id,\n }),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: dutyMenuUk.newDutyReturnList,\n url: \"/duty/return-list\",\n view: () =>\n import(\n /* webpackChunkName: \"duty\" */ \"@/components/pages/duty/uk/NewDutyReturnList.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: dutyMenuUk.oldDutyStockList,\n url: \"/duty/old-duty-stock-list\",\n view: () =>\n import(\n /* webpackChunkName: \"duty\" */ \"@/components/pages/duty/uk/ListOldDutyStockPage.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: dutyMenuUk.newDutyAllOnlineSubmissionDetails,\n url: \"/duty/return/all-online-submission-details/:id\",\n view: () =>\n import(\n /* webpackChunkName: \"duty\" */ \"@/components/pages/duty/uk/NewDutyAllOnlineSubmissionDetails.vue\"\n ),\n componentProps: (route) => ({\n id: route.params.id,\n }),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: dutyMenuUk.newDutyBeerOnlineSubmissionDetails,\n url: \"/duty/return/:id/beer-online-submission-details\",\n view: () =>\n import(\n /* webpackChunkName: \"duty\" */ \"@/components/pages/duty/uk/NewDutyBeerOnlineSubmissionDetails.vue\"\n ),\n componentProps: (route) => ({\n id: route.params.id,\n }),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: dutyMenuUk.dutyRatesCalculator,\n url: \"/duty/duty-rates-calculator\",\n view: () =>\n import(\n /* webpackChunkName: \"duty\" */ \"@/components/pages/duty/uk/ViewNewDutyRatesCalculatorPage.vue\"\n ),\n }),\n MenuItem.forBranch({\n name: dutyMenuUk.legacy.root,\n subMenus: [\n MenuItem.forBranch({\n name: dutyMenuUk.legacy.beerDuty.root,\n subMenus: [\n MenuItem.fromOpts({\n name: dutyMenuUk.legacy.beerDuty.dashboard,\n url: \"/duty/legacy/beer/dashboard\",\n breadcrumbParentName: dutyMenuUk.legacy.beerDuty.root,\n view: () =>\n import(\n /* webpackChunkName: \"duty\" */ \"@/components/pages/duty/uk/BeerDutyDashboard.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: dutyMenuUk.legacy.beerDuty.dutyReturnList,\n url: \"/duty/legacy/beer/beerreturn/list\",\n breadcrumbParentName: dutyMenuUk.legacy.beerDuty.root,\n view: () =>\n import(\n /* webpackChunkName: \"duty\" */ \"@/components/pages/duty/uk/BeerDutyReturnsList.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: dutyMenuUk.legacy.beerDuty.return,\n url: \"/duty/legacy/beer/beerreturn/:id\",\n breadcrumbParentName: dutyMenuUk.legacy.beerDuty.root,\n view: () =>\n import(\n /* webpackChunkName: \"duty\" */ \"@/components/pages/duty/uk/BeerDutyReturn.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: dutyMenuUk.legacy.beerDuty.audit,\n url: \"/duty/legacy/beer/audit\",\n componentProps: (r) => ({\n fromDateInclusive:\n r.params.fromDate && LocalDate.parse(r.params.fromDate),\n toDateInclusive:\n r.params.toDate && LocalDate.parse(r.params.toDate),\n alcoholType: [EnumAlcoholType.beer],\n }),\n view: () =>\n import(\n /* webpackChunkName: \"duty\" */ \"@/components/pages/duty/uk/DutyAudit.vue\"\n ),\n routeMetadata: {\n key: dutyMenuUk.legacy.beerDuty.audit,\n },\n }),\n MenuItem.fromOpts({\n name: dutyMenuUk.legacy.beerDuty.spoiltBeerList,\n url: \"/duty/legacy/beer/spoiltbeer/list\",\n breadcrumbParentName: dutyMenuUk.legacy.beerDuty.root,\n view: () =>\n import(\n /* webpackChunkName: \"duty\" */ \"@/components/pages/duty/uk/ListSpoiltBeer.vue\"\n ),\n }),\n ],\n }),\n MenuItem.forBranch({\n name: dutyMenuUk.legacy.spiritDuty.root,\n subMenus: [\n MenuItem.fromOpts({\n name: dutyMenuUk.legacy.spiritDuty.audit,\n url: \"/duty/legacy/spirit/audit\",\n breadcrumbParentName: dutyMenuUk.legacy.spiritDuty.root,\n componentProps: {\n alcoholType: [EnumAlcoholType.spirits],\n },\n view: () =>\n import(\n /* webpackChunkName: \"duty\" */ \"@/components/pages/duty/uk/DutyAudit.vue\"\n ),\n routeMetadata: {\n key: dutyMenuUk.legacy.spiritDuty.audit,\n },\n }),\n ],\n }),\n MenuItem.forBranch({\n name: dutyMenuUk.legacy.ciderDuty.root,\n subMenus: [\n MenuItem.fromOpts({\n name: dutyMenuUk.legacy.ciderDuty.audit,\n url: \"/duty/legacy/cider/audit\",\n breadcrumbParentName: dutyMenuUk.legacy.ciderDuty.root,\n componentProps: {\n alcoholType: [\n EnumAlcoholType.stillCiderPerry,\n EnumAlcoholType.sparklingCiderPerry,\n ],\n },\n\n view: () =>\n import(\n /* webpackChunkName: \"duty\" */ \"@/components/pages/duty/uk/DutyAudit.vue\"\n ),\n routeMetadata: {\n key: dutyMenuUk.legacy.ciderDuty.audit,\n },\n }),\n ],\n }),\n MenuItem.forBranch({\n name: dutyMenuUk.legacy.wineDuty.root,\n subMenus: [\n MenuItem.fromOpts({\n name: dutyMenuUk.legacy.wineDuty.audit,\n breadcrumbParentName: dutyMenuUk.legacy.wineDuty.root,\n url: \"/duty/legacy/wine/audit\",\n componentProps: {\n alcoholType: [\n EnumAlcoholType.stillWine,\n EnumAlcoholType.sparklingWine,\n ],\n },\n\n view: () =>\n import(\n /* webpackChunkName: \"duty\" */ \"@/components/pages/duty/uk/DutyAudit.vue\"\n ),\n routeMetadata: {\n key: dutyMenuUk.legacy.wineDuty.audit,\n },\n }),\n ],\n }),\n MenuItem.fromOpts({\n name: dutyMenuUk.legacy.dutyLists,\n url: \"/duty/legacy/list\",\n view: () =>\n import(\n /* webpackChunkName: \"duty\" */ \"@/components/pages/duty/uk/DutyRatesList.vue\"\n ),\n }),\n ],\n }),\n ],\n }),\n];\n","import { MenuItem } from \"@/app/ui/navigation/types\";\nimport type { Location } from \"vue-router\";\nimport { dutySchemeType } from \"@/components/pages/duty/composables/dutyConfiguration\";\nimport { EnumDutyScheme } from \"@/app/services/generated/enums/enumDutyScheme.generated\";\nimport type Guid from \"@/app/types/common/guid\";\nimport { LocalDate } from \"@js-joda/core\";\nimport { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\n\nexport const dutyMenuSwedish = {\n root: \"navigation_duty_group_sweden\",\n dutyReturnList: \"swedish_duty_return_list\",\n dutyReturnListLocation: (): Location => ({\n name: dutyMenuSwedish.dutyReturnList,\n }),\n editReturn: \"swedish_duty_edit_return\",\n editReturnLocation: (id: Guid, isEditing: boolean): Location => ({\n name: dutyMenuSwedish.editReturn,\n params: {\n id: id.toString(),\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n createReturn: \"swedish_duty_create_return\",\n createReturnLocation: (): Location => ({\n name: dutyMenuSwedish.createReturn,\n }),\n audit: \"swedish_duty_audit_report\",\n viewAudit: (fromDate: LocalDate, toDate: LocalDate): Location => ({\n name: dutyMenuSwedish.audit,\n params: {\n fromDateInclusive: fromDate.toString(),\n toDateInclusive: toDate.toString(),\n },\n }),\n};\n\nexport const buildDutyMenuSwedishItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n name: dutyMenuSwedish.root,\n icon: \"assignment\",\n visible: () =>\n dutySchemeType.value === EnumDutyScheme.sweden &&\n hasPermissionsUsingUserStore([EnumUserPermission.menuDutyView]),\n subMenus: [\n MenuItem.fromOpts({\n name: dutyMenuSwedish.dutyReturnList,\n url: \"/duty/swedish/list\",\n breadcrumbParentName: dutyMenuSwedish.root,\n view: () =>\n import(\n /* webpackChunkName: \"swedish-duty\" */ \"@/components/pages/duty/swedish/ListSwedishDutyReturn\"\n ),\n }),\n MenuItem.fromOpts({\n name: dutyMenuSwedish.editReturn,\n url: \"/duty/swedish/:id/:mode\",\n breadcrumbParentName: dutyMenuSwedish.dutyReturnList,\n view: () =>\n import(\n /* webpackChunkName: \"swedish-duty\" */ \"@/components/pages/duty/swedish/EditSwedishDutyReturn\"\n ),\n visible: false,\n componentProps: (route) => {\n return {\n id: route.params.id,\n editing:\n route.params.id &&\n route.params.mode.toLowerCase().trim() === \"edit\",\n };\n },\n }),\n MenuItem.fromOpts({\n name: dutyMenuSwedish.createReturn,\n url: \"/duty/swedish/create\",\n breadcrumbParentName: dutyMenuSwedish.dutyReturnList,\n view: () =>\n import(\n /* webpackChunkName: \"swedish-duty\" */ \"@/components/pages/duty/swedish/EditSwedishDutyReturn\"\n ),\n visible: false,\n componentProps: (route) => ({\n editing: true,\n }),\n }),\n MenuItem.fromOpts({\n name: dutyMenuSwedish.audit,\n url: \"/duty/swedish/audit\",\n componentProps: (r) => ({\n fromDateInclusive:\n r.params.fromDateInclusive &&\n LocalDate.parse(r.params.fromDateInclusive),\n toDateInclusive:\n r.params.toDateInclusive &&\n LocalDate.parse(r.params.toDateInclusive),\n }),\n view: () =>\n import(\"@/components/pages/duty/swedish/SwedishDutyAudit.vue\"),\n }),\n ],\n }),\n];\n","import { MenuItem } from \"@/app/ui/navigation/types\";\nimport type { Location } from \"vue-router\";\nimport { dutySchemeType } from \"@/components/pages/duty/composables/dutyConfiguration\";\nimport { EnumDutyScheme } from \"@/app/services/generated/enums/enumDutyScheme.generated\";\nimport type Guid from \"@/app/types/common/guid\";\nimport { EnumFeatureFlag } from \"@/app/services/generated/enums/enumFeatureFlag.generated\";\nimport { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\n\nexport const dutyMenuUs = {\n root: \"navigation_duty_group_us\",\n smallBrewersReportList: \"us_small_brewers_report_list\",\n smallBrewersReportListLocation: (): Location => ({\n name: dutyMenuUs.smallBrewersReportList,\n }),\n editReport: \"us_small_brewers_report_edit\",\n editReportLocation: (id: Guid, isEditing: boolean): Location => ({\n name: dutyMenuUs.editReport,\n params: {\n id: id.toString(),\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n createReport: \"us_small_brewers_report_create\",\n createReportLocation: (): Location => ({\n name: dutyMenuUs.createReport,\n }),\n liquidProductionAndHoldingsReport: \"us_liquid_production_and_holdings_report\",\n liquidProductionAndHoldingsReportLocation: (): Location => ({\n name: dutyMenuUs.liquidProductionAndHoldingsReport,\n }),\n stockAudit: \"us_stock_audit\",\n stockAuditLocation: (): Location => ({\n name: dutyMenuUs.stockAudit,\n }),\n\n illinois: {\n root: \"illinois_menu_item\",\n taxReport: {\n view: \"illinois_tax_report\",\n viewLocation: (): Location => ({\n name: dutyMenuUs.illinois.taxReport.view,\n }),\n },\n },\n};\n\nexport const buildDutyMenuUsItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n name: dutyMenuUs.root,\n icon: \"assignment\",\n visible: () =>\n dutySchemeType.value === EnumDutyScheme.us &&\n hasPermissionsUsingUserStore([EnumUserPermission.menuDutyView]),\n subMenus: [\n MenuItem.fromOpts({\n name: dutyMenuUs.smallBrewersReportList,\n url: \"/duty/us/list\",\n breadcrumbParentName: dutyMenuUs.root,\n view: () =>\n import(\n /* webpackChunkName: \"us-duty\" */ \"@/components/pages/duty/us/ListUsSmallBrewersReport\"\n ),\n }),\n MenuItem.fromOpts({\n name: dutyMenuUs.editReport,\n url: \"/duty/us/:id/:mode\",\n breadcrumbParentName: dutyMenuUs.smallBrewersReportList,\n view: () =>\n import(\n /* webpackChunkName: \"us-duty\" */ \"@/components/pages/duty/us/EditUsSmallBrewersReport\"\n ),\n visible: false,\n componentProps: (route) => {\n return {\n id: route.params.id,\n editing:\n route.params.id &&\n route.params.mode.toLowerCase().trim() === \"edit\",\n };\n },\n }),\n MenuItem.fromOpts({\n name: dutyMenuUs.createReport,\n url: \"/duty/us/create\",\n breadcrumbParentName: dutyMenuUs.smallBrewersReportList,\n view: () =>\n import(\n /* webpackChunkName: \"us-duty\" */ \"@/components/pages/duty/us/EditUsSmallBrewersReport\"\n ),\n visible: false,\n componentProps: (route) => ({\n editing: true,\n }),\n }),\n MenuItem.fromOpts({\n name: dutyMenuUs.liquidProductionAndHoldingsReport,\n url: \"/duty/us/liquidholdingreport\",\n breadcrumbParentName: dutyMenuUs.root,\n view: () =>\n import(\n /* webpackChunkName: \"us-duty\" */ \"@/components/pages/duty/us/LiquidProductionAndHoldingsReport\"\n ),\n }),\n MenuItem.fromOpts({\n name: dutyMenuUs.stockAudit,\n url: \"/duty/us/stockaudit\",\n breadcrumbParentName: dutyMenuUs.root,\n view: () =>\n import(\n /* webpackChunkName: \"us-duty\" */ \"@/components/pages/duty/us/StockAuditReport.vue\"\n ),\n }),\n MenuItem.forBranch({\n name: dutyMenuUs.illinois.root,\n subMenus: [\n MenuItem.fromOpts({\n name: dutyMenuUs.illinois.taxReport.view,\n url: \"/duty/us/illinois-tax-report\",\n breadcrumbParentName: dutyMenuUs.illinois.root,\n view: () =>\n import(\n /* webpackChunkName: us-duty */ \"@/components/pages/duty/us/illinois/IllinoisTaxReport.vue\"\n ),\n }),\n ],\n requiredFeatureFlag: EnumFeatureFlag.showIllinoisTaxReturn,\n }),\n ],\n }),\n];\n","import { MenuItem } from \"@/app/ui/navigation/types\";\nimport { dutySchemeType } from \"@/components/pages/duty/composables/dutyConfiguration\";\nimport { EnumDutyScheme } from \"@/app/services/generated/enums/enumDutyScheme.generated\";\nimport type { Location } from \"vue-router\";\nimport type Guid from \"@/app/types/common/guid\";\nimport { LocalDate } from \"@js-joda/core\";\nimport { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\n\nexport const dutyMenuEire = {\n root: \"navigation_duty_group_eire\",\n beerDutyReturn: {\n list: \"eire_beer_duty_return_list\",\n listLocation: (): Location => ({\n name: dutyMenuEire.beerDutyReturn.list,\n }),\n edit: \"eire_beer_duty_return_edit\",\n editLocation: (id: Guid, isEditing: boolean): Location => ({\n name: dutyMenuEire.beerDutyReturn.edit,\n params: {\n id: id.toString(),\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n createLocation: (): Location => ({\n name: dutyMenuEire.beerDutyReturn.edit,\n }),\n },\n stockReturn: {\n list: \"eire_stock_return_list\",\n listLocation: (): Location => ({\n name: dutyMenuEire.stockReturn.list,\n }),\n edit: \"eire_stock_return_edit\",\n editLocation: (id: Guid, isEditing: boolean): Location => ({\n name: dutyMenuEire.stockReturn.edit,\n params: {\n id: id.toString(),\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n createLocation: (): Location => ({\n name: dutyMenuEire.stockReturn.edit,\n }),\n },\n audit: \"eire_duty_audit_report\",\n viewAudit: (fromDate: LocalDate, toDate: LocalDate): Location => ({\n name: dutyMenuEire.audit,\n params: {\n fromDateInclusive: fromDate.toString(),\n toDateInclusive: toDate.toString(),\n },\n }),\n};\n\nexport const buildDutyMenuEireItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n name: dutyMenuEire.root,\n icon: \"assignment\",\n visible: () =>\n dutySchemeType.value === EnumDutyScheme.eire &&\n hasPermissionsUsingUserStore([EnumUserPermission.menuDutyView]),\n subMenus: [\n MenuItem.fromOpts({\n name: dutyMenuEire.beerDutyReturn.list,\n url: \"/duty/eire/beer-duty-returns-list\",\n breadcrumbParentName: dutyMenuEire.root,\n view: () =>\n import(\n /* webpackChunkName: \"eire-duty\" */ \"@/components/pages/duty/eire/ListEireBeerDutyReturn.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: dutyMenuEire.beerDutyReturn.edit,\n url: \"/duty/eire/beer-duty-return/:id?/:mode?\",\n breadcrumbParentName: dutyMenuEire.beerDutyReturn.list,\n view: () =>\n import(\n /* webpackChunkName: \"eire-duty\" */ \"@/components/pages/duty/eire/EditEireBeerDutyReturn.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: dutyMenuEire.stockReturn.list,\n url: \"/duty/eire/stock-returns-list\",\n breadcrumbParentName: dutyMenuEire.root,\n view: () =>\n import(\n /* webpackChunkName: \"eire-duty\" */ \"@/components/pages/duty/eire/ListEireStockReturn.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: dutyMenuEire.stockReturn.edit,\n url: \"/duty/eire/stock-return/:id?/:mode?\",\n breadcrumbParentName: dutyMenuEire.beerDutyReturn.list,\n view: () =>\n import(\n /* webpackChunkName: \"eire-duty\" */ \"@/components/pages/duty/eire/EditEireStockReturn.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: dutyMenuEire.audit,\n url: \"/duty/eire/audit\",\n componentProps: (r) => ({\n fromDateInclusive:\n r.params.fromDateInclusive &&\n LocalDate.parse(r.params.fromDateInclusive),\n toDateInclusive:\n r.params.toDateInclusive &&\n LocalDate.parse(r.params.toDateInclusive),\n }),\n view: () =>\n import(\n /* webpackChunkName: \"eire-duty\" */ \"@/components/pages/duty/eire/DutyAudit.vue\"\n ),\n }),\n ],\n }),\n];\n","import { MenuItem } from \"@/app/ui/navigation/types\";\nimport { dutySchemeType } from \"@/components/pages/duty/composables/dutyConfiguration\";\nimport { EnumDutyScheme } from \"@/app/services/generated/enums/enumDutyScheme.generated\";\nimport type { Location } from \"vue-router\";\nimport { LocalDate } from \"@js-joda/core\";\nimport { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\n\nexport const dutyMenuNz = {\n root: \"navigation_duty_group_nz\",\n audit: \"duty_audit_report\",\n viewAudit: (fromDate: LocalDate, toDate: LocalDate): Location => ({\n name: dutyMenuNz.audit,\n params: {\n fromDateInclusive: fromDate.toString(),\n toDateInclusive: toDate.toString(),\n },\n }),\n};\n\nexport const buildDutyMenuNzItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n name: dutyMenuNz.root,\n icon: \"assignment\",\n visible: () =>\n dutySchemeType.value === EnumDutyScheme.nz &&\n hasPermissionsUsingUserStore([EnumUserPermission.menuDutyView]),\n subMenus: [\n MenuItem.fromOpts({\n name: dutyMenuNz.audit,\n url: \"/duty/nz/audit\",\n componentProps: (r) => ({\n fromDateInclusive:\n r.params.fromDateInclusive &&\n LocalDate.parse(r.params.fromDateInclusive),\n toDateInclusive:\n r.params.toDateInclusive &&\n LocalDate.parse(r.params.toDateInclusive),\n }),\n view: () =>\n import(\n /* webpackChunkName: \"nz-duty\" */ \"@/components/pages/duty/nz/DutyAudit.vue\"\n ),\n }),\n ],\n }),\n];\n","import { buildDutyMenuGermanItems } from \"@/app/ui/navigation/dutyMenuGerman\";\nimport { buildDutyMenuAustralianItems } from \"@/app/ui/navigation/dutyMenuAustralian\";\nimport { buildDutyMenuSouthAfricanItems } from \"@/app/ui/navigation/dutyMenuSouthAfrican\";\nimport { buildDutyMenuUkItems } from \"@/app/ui/navigation/dutyMenuUk\";\nimport { buildDutyMenuSwedishItems } from \"@/app/ui/navigation/dutyMenuSwedish\";\nimport { buildDutyMenuUsItems } from \"@/app/ui/navigation/dutyMenuUs\";\nimport type { MenuItem } from \"@/app/ui/navigation/types\";\nimport { buildDutyMenuEireItems } from \"@/app/ui/navigation/dutyMenuEire\";\nimport { buildDutyMenuNzItems } from \"@/app/ui/navigation/dutyMenuNz\";\n\nexport const buildDutyMenuItems: () => MenuItem[] = () => [\n ...buildDutyMenuUkItems(),\n ...buildDutyMenuGermanItems(),\n ...buildDutyMenuAustralianItems(),\n ...buildDutyMenuSouthAfricanItems(),\n ...buildDutyMenuSwedishItems(),\n ...buildDutyMenuUsItems(),\n ...buildDutyMenuEireItems(),\n ...buildDutyMenuNzItems(),\n];\n","import { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport type Key from \"@/app/types/common/key\";\nimport { MenuItem } from \"@/app/ui/navigation/types\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\nimport { keys } from \"@/plugins/i18n\";\nimport tenantStore from \"@/store/modules/tenantStore\";\n\ninterface ReportingMenuItem {\n key: string;\n reports: TableauReport[];\n}\n\ninterface TableauReport {\n translationKey: Key;\n workbook: string;\n presentView: string | null;\n historicView: string | null;\n visible?: () => boolean;\n}\n\nexport const reportingMenu = {\n root: \"navigation_reporting_group\",\n present: \"present\",\n historic: \"historic\",\n\n sales: \"reporting_sales\",\n production: \"reporting_production\",\n newProduction: \"reporting_new_production\",\n stock: \"reporting_stock\",\n batchTracking: \"reporting_batch_tracking\",\n tasks: \"reporting_tasks\",\n deposits: \"reporting_deposits\",\n};\n\nconst tableauSalesReports: TableauReport[] = [\n {\n translationKey: keys.performance_dashboard,\n workbook: \"Reporting\",\n presentView: \"PerformanceDashboard\",\n historicView: \"PerformanceDashboardHistoric\",\n },\n {\n translationKey: keys.performance_graph,\n workbook: \"Reporting\",\n presentView: \"PerformanceGraph\",\n historicView: \"PerformanceGraphHistoric\",\n },\n {\n translationKey: keys.yoy_graph,\n workbook: \"Reporting\",\n presentView: \"YOYGraph\",\n historicView: \"YOYGraphHistoric\",\n },\n {\n translationKey: keys.performance_table,\n workbook: \"Reporting\",\n presentView: \"PerformanceTable\",\n historicView: \"PerformanceTableHistoric\",\n },\n {\n translationKey: keys.order_date_table,\n workbook: \"Reporting\",\n presentView: \"OrderDateTable\",\n historicView: \"OrderDateTableHistoric\",\n },\n {\n translationKey: keys.despatch_date_table,\n workbook: \"Reporting\",\n presentView: \"DespatchDateTable\",\n historicView: \"DespatchDateTableHistoric\",\n },\n {\n translationKey: keys.yoy_table,\n workbook: \"Reporting\",\n presentView: \"YOYTable\",\n historicView: \"YOYTableHistoric\",\n },\n {\n translationKey: keys.reporting_yoy_table_side_by_side,\n workbook: \"Reporting\",\n presentView: \"YOYSide-by-Side\",\n historicView: \"YOYSide-by-SideHistoric\",\n },\n {\n translationKey: keys.mat_table,\n workbook: \"Reporting\",\n presentView: \"MATTable\",\n historicView: \"MATTable-Historic\",\n },\n {\n translationKey: keys.performance_table_over_time,\n workbook: \"Reporting\",\n presentView: \"PerformanceTableOverTime\",\n historicView: \"PerformanceTableOverTimeHistoric\",\n },\n {\n translationKey: keys.performance_graph_by_dimension,\n workbook: \"Reporting\",\n presentView: \"PerformanceGraphbyDimension\",\n historicView: \"PerformanceGraphbyDimensionHistoric\",\n },\n {\n translationKey: keys.performance_by_map,\n workbook: \"Reporting\",\n presentView: \"PerformanceMap\",\n historicView: \"PerformanceMapHistoric\",\n },\n {\n translationKey: keys.customer_leakage_table,\n workbook: \"Reporting\",\n presentView: \"CustomerLeakageTable\",\n historicView: \"CustomerLeakageTableHistoric\",\n },\n {\n translationKey: keys.customer_leakage_last_delivery,\n workbook: \"Reporting\",\n presentView: \"CustomerLeakageLastDelivery\",\n historicView: \"CustomerLeakageLastDeliveryHistoric\",\n },\n {\n translationKey: keys.new_customer_table,\n workbook: \"Reporting\",\n presentView: \"NewCustomerTable\",\n historicView: \"NewCustomerTableHistoric\",\n },\n {\n translationKey: keys.litres_sold_trend_and_forecast,\n workbook: \"Reporting\",\n presentView: \"Forecast-Trend\",\n historicView: \"Forecast-TrendHistoric\",\n },\n {\n translationKey: keys.litres_sold_trend_and_seasonal,\n workbook: \"Reporting\",\n presentView: \"Forecast-SeasonalandTrend\",\n historicView: \"Forecast-SeasonalandTrendHistoric\",\n },\n {\n translationKey: keys.top_products_by_outlet,\n workbook: \"Reporting\",\n presentView: \"TopProductsbyOutlet\",\n historicView: \"TopProductsbyOutletHistoric\",\n },\n {\n translationKey: keys.top_outlets_by_product,\n workbook: \"Reporting\",\n presentView: \"TopOutletsbyProduct\",\n historicView: \"TopOutletsbyProductHistoric\",\n },\n {\n translationKey: keys.sales_by_day,\n workbook: \"Reporting\",\n presentView: \"SalesbyDay\",\n historicView: \"SalesbyDayHistoric\",\n },\n {\n translationKey: keys.sales_export_by_date,\n workbook: \"Reporting\",\n presentView: \"SalesExportbyDate\",\n historicView: \"SalesExportbyDateHistoric\",\n },\n {\n translationKey: keys.yoy_bar_chart,\n workbook: \"Reporting\",\n presentView: \"YOYBarChart\",\n historicView: \"YOYBarChartHistoric\",\n },\n];\n\nconst tableauStockReports: TableauReport[] = [\n {\n translationKey: keys.reporting_stock_levels_report,\n workbook: \"Reporting\",\n presentView: \"StockValuation\",\n historicView: null,\n },\n {\n translationKey: keys.reporting_wip_valuation,\n workbook: \"Reporting\",\n presentView: \"WIPValuation\",\n historicView: null,\n visible: () => !tenantStore.state.tenantSettings.isMegaBatchesEnabled,\n },\n {\n translationKey: keys.reporting_wip_valuation,\n workbook: \"Reporting\",\n presentView: \"WIPValuationNewProd\",\n historicView: null,\n visible: () => tenantStore.state.tenantSettings.isMegaBatchesEnabled,\n },\n {\n translationKey: keys.reporting_future_stock_availability,\n workbook: \"Reporting\",\n presentView: \"FutureStockAvailability\",\n historicView: \"FutureStockAvailabilityHistoric\",\n },\n {\n translationKey: keys.reporting_number_of_weeks_stock_cover,\n workbook: \"Reporting\",\n presentView: \"No_WeeksStockCover\",\n historicView: \"No_WeeksStockCover\", // This is desired - as apparently it's more discoverable.\n },\n {\n translationKey: keys.reporting_allocated_stock_by_outlet,\n workbook: \"Reporting\",\n presentView: \"AllocatedStockbyOutlet\",\n historicView: \"AllocatedStockbyOutletHistoric\",\n },\n {\n translationKey: keys.reporting_litres_of_alcohol,\n workbook: \"Reporting\",\n presentView: \"LitresofAlcohol\",\n historicView: null,\n },\n];\n\nconst tableauProductionReports: TableauReport[] = [\n {\n translationKey: keys.volume_graph,\n workbook: \"Reporting\",\n presentView: \"ProductionVolumeGraph\",\n historicView: \"ProductionVolumeGraphHistoric\",\n },\n {\n translationKey: keys.packaging_graph,\n workbook: \"Reporting\",\n presentView: \"ProductionPackagingGraph\",\n historicView: \"ProductionPackagingGraphHistoric\",\n },\n {\n translationKey: keys.summary_table,\n workbook: \"Reporting\",\n presentView: \"ProductionSummaryTable\",\n historicView: \"ProductionSummaryTableHistoric\",\n },\n {\n translationKey: keys.ingredient_summary_table,\n workbook: \"Reporting\",\n presentView: \"ProductionIngredientSummaryTable\",\n historicView: \"ProductionIngredientSummaryTableHistoric\",\n },\n {\n translationKey: keys.recipe_cost_vs_expectation,\n workbook: \"Reporting\",\n presentView: \"ProductionRecipeCostvsExpectation\",\n historicView: \"ProductionRecipeCostvsExpectationHistoric\",\n },\n {\n translationKey: keys.packaging_cost_vs_expectation,\n workbook: \"Reporting\",\n presentView: \"ProductionPackagingCostvsExpectation\",\n historicView: \"ProductionPackagingCostvsExpectationHistoric\",\n },\n {\n translationKey: keys.reporting_vessel_movements_table,\n workbook: \"Reporting\",\n presentView: \"VesselMovementsTable\",\n historicView: \"VesselMovementsTable-Historic\",\n },\n {\n translationKey: keys.reporting_qc_graph,\n workbook: \"Reporting\",\n presentView: \"QCGraph\",\n historicView: \"QCGraphHistoric\",\n },\n {\n translationKey: keys.reporting_qc_table,\n workbook: \"Reporting\",\n presentView: \"QCTable\",\n historicView: \"QCTableHistoric\",\n },\n];\n\nconst tableauNewProductionReports: TableauReport[] = [\n {\n translationKey: keys.new_production_batch_summary,\n workbook: \"Reporting\",\n presentView: \"NewProduction-BatchSummary\",\n historicView: \"NewProduction-BatchSummary-Historic\",\n },\n {\n translationKey: keys.new_production_process_summary,\n workbook: \"Reporting\",\n presentView: \"NewProduction-ProcessSummaryTable\",\n historicView: \"NewProduction-ProcessSummaryTable-Historic\",\n },\n {\n translationKey: keys.ingredient_summary_table,\n workbook: \"Reporting\",\n presentView: \"NewProduction-IngredientSummary\",\n historicView: \"NewProduction-IngredientSummaryHistoric\",\n },\n {\n translationKey: keys.reporting_qc_graph,\n workbook: \"Reporting\",\n presentView: \"QCGraph-NewProduction\",\n historicView: \"QCGraph-NewProductionHistoric\",\n },\n {\n translationKey: keys.reporting_qc_table,\n workbook: \"Reporting\",\n presentView: \"QCTable-NewProduction\",\n historicView: \"QCTable-NewProductionHistoric\",\n },\n];\n\nconst tableauBatchTrackingReports: TableauReport[] = [\n {\n translationKey: keys.reporting_delivery_batch_tracking,\n workbook: \"Reporting\",\n presentView: \"DeliveryBatchTracking-Present\",\n historicView: \"DeliveryBatchTracking\",\n },\n {\n translationKey: keys.reporting_traceable_items_used,\n workbook: \"Reporting\",\n presentView: \"TraceableItemsUsed\",\n historicView: \"TraceableItemsUsedHistoric\",\n visible: () => !tenantStore.state.tenantSettings.isMegaBatchesEnabled,\n },\n {\n translationKey: keys.reporting_traceable_items_used,\n workbook: \"Reporting\",\n presentView: \"TraceableItemsUsedNewProd\",\n historicView: \"TraceableItemsUsedNewProdHistoric\",\n visible: () => tenantStore.state.tenantSettings.isMegaBatchesEnabled,\n },\n];\n\nconst tableauTasksReports: TableauReport[] = [\n {\n translationKey: keys.reporting_tasks_by_user,\n workbook: \"Reporting\",\n presentView: \"TasksbyUser\",\n historicView: \"TasksbyUserHistoric\",\n },\n {\n translationKey: keys.reporting_tasks_by_type,\n workbook: \"Reporting\",\n presentView: \"TasksbyType\",\n historicView: \"TasksbyTypeHistoric\",\n },\n {\n translationKey: keys.reporting_tasks_overdue,\n workbook: \"Reporting\",\n presentView: \"OverdueTasks\",\n historicView: \"OverdueTasksHistoric\",\n },\n {\n translationKey: keys.reporting_tasks_completed,\n workbook: \"Reporting\",\n presentView: \"CompletedTasks\",\n historicView: \"CompletedTasksHistoric\",\n },\n];\n\nconst tableauDepositReports: TableauReport[] = [\n {\n translationKey: keys.reporting_deposit_returns,\n workbook: \"Reporting\",\n presentView: \"DepositsReturns\",\n historicView: \"DepositsReturnsHistoric\",\n },\n];\n\nexport const buildReportingMenuItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n name: reportingMenu.root,\n icon: \"description\",\n visible: () =>\n hasPermissionsUsingUserStore([EnumUserPermission.menuReportingView]),\n subMenus: (\n [\n {\n key: reportingMenu.sales,\n reports: tableauSalesReports,\n },\n {\n key: reportingMenu.stock,\n reports: tableauStockReports,\n },\n {\n key: reportingMenu.production,\n reports: tableauProductionReports,\n },\n {\n key: reportingMenu.newProduction,\n reports: tableauNewProductionReports,\n },\n {\n key: reportingMenu.batchTracking,\n reports: tableauBatchTrackingReports,\n },\n {\n key: reportingMenu.tasks,\n reports: tableauTasksReports,\n },\n {\n key: reportingMenu.deposits,\n reports: tableauDepositReports,\n },\n ] as ReportingMenuItem[]\n ).map((menuDetails) => {\n return MenuItem.forBranch({\n name: menuDetails.key,\n subMenus: [\n MenuItem.forBranch({\n name: `${menuDetails.key}-present`,\n translationKey: \"present\",\n subMenus: menuDetails.reports\n .filter((report) => report.presentView)\n .map((report) => {\n return MenuItem.fromOpts({\n name: `${menuDetails.key}-present-${report.presentView}`,\n url: `/reporting/reports/${report.workbook}/${report.presentView}`,\n translationKey: report.translationKey.value,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"reporting\" */ \"@/components/pages/reporting/embeddedtableau/EmbeddedTableauReport.vue\"\n ),\n componentProps: {\n workbook: report.workbook,\n view: report.presentView,\n translationKey: report.translationKey,\n },\n visible: report.visible,\n });\n }),\n }),\n MenuItem.forBranch({\n name: `${menuDetails.key}-historic`,\n translationKey: \"historic\",\n subMenus: menuDetails.reports\n .filter((report) => report.historicView)\n .map((report) => {\n return MenuItem.fromOpts({\n name: `${menuDetails.key}-historic-${report.historicView}`,\n url: `/reporting/reports/${report.workbook}/${report.historicView}`,\n translationKey: report.translationKey.value,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"reporting\" */ \"@/components/pages/reporting/embeddedtableau/EmbeddedTableauReport.vue\"\n ),\n componentProps: {\n workbook: report.workbook,\n view: report.historicView,\n translationKey: report.translationKey,\n },\n visible: report.visible,\n });\n }),\n }),\n ],\n });\n }),\n requiredUserPermissions: [EnumUserPermission.reporting],\n }),\n];\n","export default \"__VITE_ASSET__6ee41363__\"","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\n\n// Model Objects\n\nexport class AmazonSettings extends ModelObject {\n\n public version: number = 0;\n public id: Guid = Guid.createEmpty();\n private _defaultDeliveryStockItemId: Guid | null = null;\n /**\n * Default Stock Item Id to be used for delivery charge of imported orders. This will be used if no BrewMan product name matches the Shipping Option Name in Amazon\n */\n public get defaultDeliveryStockItemId(): Guid | null { return this._defaultDeliveryStockItemId }\n public set defaultDeliveryStockItemId(value: Guid | null) {\n this._defaultDeliveryStockItemId = value === undefined ? null : value;\n }\n private _ignoreBeforeDate: LocalDate | null = null;\n /**\n * If provided then Orders on Amazon from before this date will be ignored.\n */\n public get ignoreBeforeDate(): LocalDate | null { return this._ignoreBeforeDate }\n public set ignoreBeforeDate(value: LocalDate | null) {\n this._ignoreBeforeDate = value === undefined ? null : value;\n }\n private _outletId: Guid | null = null;\n /**\n * Outlet Id for all Amazon orders import to a single outlet. Should be null only if tenant doesn't use Amazon.\n */\n public get outletId(): Guid | null { return this._outletId }\n public set outletId(value: Guid | null) {\n this._outletId = value === undefined ? null : value;\n }\n /**\n * Whether the current integration should run continuously in the background.\n */\n public runInBackground: boolean = false;\n /**\n * The identifier for the selling partner Amazon account of this tenant.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public amazonSellerPartnerId: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.version = jsonSerializedObject.version;\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.defaultDeliveryStockItemId = jsonSerializedObject.defaultDeliveryStockItemId == null ? null : Guid.fromString(jsonSerializedObject.defaultDeliveryStockItemId);\n this.ignoreBeforeDate = jsonSerializedObject.ignoreBeforeDate == null ? null : LocalDate.parse(jsonSerializedObject.ignoreBeforeDate);\n this.outletId = jsonSerializedObject.outletId == null ? null : Guid.fromString(jsonSerializedObject.outletId);\n this.runInBackground = jsonSerializedObject.runInBackground;\n this.amazonSellerPartnerId = jsonSerializedObject.amazonSellerPartnerId;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.version = this.version;\n toRet.id = this.id.toString();\n toRet.defaultDeliveryStockItemId = this.defaultDeliveryStockItemId == null ? null : this.defaultDeliveryStockItemId.toString();\n toRet.ignoreBeforeDate = this.ignoreBeforeDate == null ? null : this.ignoreBeforeDate.toString();\n toRet.outletId = this.outletId == null ? null : this.outletId.toString();\n toRet.runInBackground = this.runInBackground;\n toRet.amazonSellerPartnerId = this.amazonSellerPartnerId;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"version\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"Version is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"version\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"Version is above maximum allowed value: 9223372036854775807\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"AmazonSettings.Id cannot be empty\"},\n {field: \"defaultDeliveryStockItemId\", rule: (v: any) => v == null || !v.isEmpty() || \"AmazonSettings.DefaultDeliveryStockItemId cannot be empty\"},\n {field: \"outletId\", rule: (v: any) => v == null || !v.isEmpty() || \"AmazonSettings.OutletId cannot be empty\"},\n ];\n}\n\n\nexport class GetAmazonSettingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAmazonSettingsResponse extends ModelObject {\n\n public amazonSettings: AmazonSettings = new AmazonSettings();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.amazonSettings = new AmazonSettings(jsonSerializedObject.amazonSettings);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.amazonSettings = this.amazonSettings.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"amazonSettings\", rule: (v: any) => !!v || \"amazonSettings is required\"},\n {field: \"amazonSettings\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class SaveAmazonSettingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public amazonSettings: AmazonSettings = new AmazonSettings();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.amazonSettings = new AmazonSettings(jsonSerializedObject.amazonSettings);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.amazonSettings = this.amazonSettings.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"amazonSettings\", rule: (v: any) => !!v || \"amazonSettings is required\"},\n {field: \"amazonSettings\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class HardDeleteAmazonSettingsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public amazonSettingsId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.amazonSettingsId = Guid.fromString(jsonSerializedObject.amazonSettingsId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.amazonSettingsId = this.amazonSettingsId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"amazonSettingsId\", rule: (v: any) => !v.isEmpty() || \".AmazonSettingsId cannot be empty\"},\n ];\n}\n\n\nexport class GetTenantSettingsIdsUsingAmazonInBackgroundRequest extends ModelObject {\n\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GetTenantSettingsIdsUsingAmazonInBackgroundResponse extends ModelObject {\n\n public tenantIds: Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantIds = jsonSerializedObject.tenantIds.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantIds = this.tenantIds.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class CreateAmazonLoginUrlRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public amazonSettingsId: Guid = Guid.createEmpty();\n public returnPageUrl: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.amazonSettingsId = Guid.fromString(jsonSerializedObject.amazonSettingsId);\n this.returnPageUrl = jsonSerializedObject.returnPageUrl;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.amazonSettingsId = this.amazonSettingsId.toString();\n toRet.returnPageUrl = this.returnPageUrl;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"amazonSettingsId\", rule: (v: any) => !v.isEmpty() || \".AmazonSettingsId cannot be empty\"},\n ];\n}\n\n\nexport class CreateAmazonLoginUrlResponse extends ModelObject {\n\n public url: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.url = jsonSerializedObject.url;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.url = this.url;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class CompleteAmazonAuthenticationRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public amazonSettingsId: Guid = Guid.createEmpty();\n /**\n * The query string as received in the redirect URL from Amazon.\n * Not Nullable\n * Preserves leading and trailing whitespce.\n */\n public queryString: string = \"\";\n public returnPageUrl: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.amazonSettingsId = Guid.fromString(jsonSerializedObject.amazonSettingsId);\n this.queryString = jsonSerializedObject.queryString;\n this.returnPageUrl = jsonSerializedObject.returnPageUrl;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.amazonSettingsId = this.amazonSettingsId.toString();\n toRet.queryString = this.queryString;\n toRet.returnPageUrl = this.returnPageUrl;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"amazonSettingsId\", rule: (v: any) => !v.isEmpty() || \".AmazonSettingsId cannot be empty\"},\n ];\n}\n\n\nexport class CompleteAmazonAuthenticationResponse extends ModelObject {\n\n public amazonSettings: AmazonSettings = new AmazonSettings();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.amazonSettings = new AmazonSettings(jsonSerializedObject.amazonSettings);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.amazonSettings = this.amazonSettings.toJsonSerializedObject();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"amazonSettings\", rule: (v: any) => !!v || \"amazonSettings is required\"},\n {field: \"amazonSettings\", rule: (v: any) => v.validate()},\n ];\n}\n\n\nexport class IsAmazonAuthenticatedRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public amazonSettingsId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.amazonSettingsId = Guid.fromString(jsonSerializedObject.amazonSettingsId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.amazonSettingsId = this.amazonSettingsId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"amazonSettingsId\", rule: (v: any) => !v.isEmpty() || \".AmazonSettingsId cannot be empty\"},\n ];\n}\n\n\nexport class IsAmazonAuthenticatedResponse extends ModelObject {\n\n public authenticated: boolean = false;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.authenticated = jsonSerializedObject.authenticated;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.authenticated = this.authenticated;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GetAmazonAccessTokenRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public amazonSettingsId: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.amazonSettingsId = Guid.fromString(jsonSerializedObject.amazonSettingsId);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.amazonSettingsId = this.amazonSettingsId.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"amazonSettingsId\", rule: (v: any) => !v.isEmpty() || \".AmazonSettingsId cannot be empty\"},\n ];\n}\n\n\nexport class GetAmazonAccessTokenResponse extends ModelObject {\n\n public accessToken: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.accessToken = jsonSerializedObject.accessToken;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.accessToken = this.accessToken;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class AmazonSettingsService extends ServiceBase {\n\n public async getAmazonSettings(tenantId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAmazonSettingsRequest();\n req.tenantId = tenantId;\n const extractor = (response:any) => new GetAmazonSettingsResponse(response).amazonSettings;\n return this.makeJsonRequest(\"amazonSettings/v1/getAmazonSettings\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveAmazonSettings(tenantId: Guid, amazonSettings: AmazonSettings, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveAmazonSettingsRequest();\n req.tenantId = tenantId;\n req.amazonSettings = amazonSettings;\n const extractor = null;\n return this.makeJsonRequest(\"amazonSettings/v1/saveAmazonSettings\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async hardDeleteAmazonSettings(tenantId: Guid, amazonSettingsId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new HardDeleteAmazonSettingsRequest();\n req.tenantId = tenantId;\n req.amazonSettingsId = amazonSettingsId;\n const extractor = null;\n return this.makeJsonRequest(\"amazonSettings/v1/hardDeleteAmazonSettings\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async createAmazonLoginUrl(tenantId: Guid, amazonSettingsId: Guid, returnPageUrl: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CreateAmazonLoginUrlRequest();\n req.tenantId = tenantId;\n req.amazonSettingsId = amazonSettingsId;\n req.returnPageUrl = returnPageUrl;\n const extractor = (response:any) => new CreateAmazonLoginUrlResponse(response).url;\n return this.makeJsonRequest(\"amazonSettings/v1/createAmazonLoginUrl\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async completeAmazonAuthentication(tenantId: Guid, amazonSettingsId: Guid, queryString: string, returnPageUrl: string, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new CompleteAmazonAuthenticationRequest();\n req.tenantId = tenantId;\n req.amazonSettingsId = amazonSettingsId;\n req.queryString = queryString;\n req.returnPageUrl = returnPageUrl;\n const extractor = (response:any) => new CompleteAmazonAuthenticationResponse(response).amazonSettings;\n return this.makeJsonRequest(\"amazonSettings/v1/completeAmazonAuthentication\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async isAmazonAuthenticated(tenantId: Guid, amazonSettingsId: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new IsAmazonAuthenticatedRequest();\n req.tenantId = tenantId;\n req.amazonSettingsId = amazonSettingsId;\n const extractor = (response:any) => new IsAmazonAuthenticatedResponse(response).authenticated;\n return this.makeJsonRequest(\"amazonSettings/v1/isAmazonAuthenticated\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const amazonSettingsService = new AmazonSettingsService();","import { EnumIntegrationStatus } from \"@/components/pages/integrations/types\";\nimport type { IntegrationMeta } from \"@/components/pages/integrations/composables/types\";\nimport { integrationsMenu } from \"@/app/ui/navigation/integrationsMenu\";\nimport img from \"@/assets/images/app/integrations/amazon_logo.png\";\nimport api from \"@/app/api\";\nimport messages from \"@/plugins/i18n\";\nimport {\n amazonSettingsService,\n type AmazonSettings,\n} from \"@/app/services/generated/amazonsettingsService\";\nimport type BmTabItem from \"@/components/controls/tabs/BmTabItem\";\n\nexport type AmazonLinkStatus = {\n settings: AmazonSettings;\n canConnect: boolean;\n status: EnumIntegrationStatus;\n};\n\nexport async function getAmazonLinkStatus(): Promise {\n const settings = await amazonSettingsService.getAmazonSettings(api.tenantId);\n\n let status = EnumIntegrationStatus.inactive;\n let canConnect = false;\n\n if (settings.outletId) {\n canConnect = await amazonSettingsService.isAmazonAuthenticated(\n api.tenantId,\n settings.id\n );\n\n status = canConnect\n ? EnumIntegrationStatus.active\n : EnumIntegrationStatus.unauthenticated;\n }\n\n return {\n settings,\n canConnect,\n status,\n };\n}\n\nexport function amazonMeta(\n linkStatus: AmazonLinkStatus | null\n): IntegrationMeta {\n const status = linkStatus?.status ?? EnumIntegrationStatus.inactive;\n return {\n name: messages.amazon_title,\n description: messages.amazon_description,\n longDescription: messages.amazon_description,\n integrationRoute: status.isInactive()\n ? integrationsMenu.amazon.viewIntroduction()\n : integrationsMenu.amazon.viewOverview(status.isActive()),\n miniImg: img,\n img,\n activated: linkStatus?.status.isActive() ?? false,\n status: status,\n };\n}\n\nexport function amazonTabs(): BmTabItem[] {\n return [\n {\n label: messages.integrations_overview,\n route: integrationsMenu.amazon.viewOverview(true),\n },\n {\n label: messages.integrations_settings,\n route: integrationsMenu.amazon.viewSettings(true),\n },\n ];\n}\n","import { EnumAccountsPackageType } from \"@/app/services/generated/enums/enumAccountsPackageType.generated\";\nimport type { EnumEcommerceOrderOriginType } from \"@/app/services/generated/enums/enumEcommerceOrderOriginType.generated\";\nimport type Guid from \"@/app/types/common/guid\";\nimport { MenuItem } from \"@/app/ui/navigation/types\";\nimport type { Location } from \"vue-router\";\nimport { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\nimport { amazonTabs } from \"@/components/pages/integrations/amazon/integrationsAmazon\";\nimport messages from \"@/plugins/i18n\";\nimport { EnumIntegrationType } from \"@/app/services/generated/enums/enumIntegrationType.generated\";\n\nexport const integrationsMenu = {\n root: \"navigation_integrations_group\",\n rootViewLocation: (): Location => ({\n name: integrationsMenu.root,\n }),\n list: \"integrations_list\",\n brewmanTradePortal: {\n view: \"brewman_trade_portal\",\n viewLocation: (): Location => ({\n name: integrationsMenu.brewmanTradePortal.view,\n }),\n },\n commerce7: {\n view: \"commerce7\",\n viewLocation: (): Location => ({\n name: integrationsMenu.commerce7.view,\n }),\n },\n ptvRo: {\n view: \"ptv_ro\",\n viewLocation: (): Location => ({\n name: integrationsMenu.ptvRo.view,\n }),\n },\n xero: \"xero\",\n fortnox: \"fortnox\",\n square: {\n view: \"square\",\n squareViewLocation: (id: Guid): Location => ({\n name: integrationsMenu.square.view,\n params: {\n id: id.toString(),\n },\n }),\n create: \"square_create\",\n squareCreateLocation: (): Location => ({\n name: integrationsMenu.square.create,\n }),\n callback: \"square_callback\",\n },\n quickBooks: \"quickBooks\",\n sageOne: \"sage_one\",\n sageOneZa: \"sage_one_za\",\n sage50: \"sage_50\",\n sage200: \"sage_200\",\n brewmanApi: \"brewman_api\",\n noAccountsPackage: \"no_accounts_package\",\n sellar: {\n view: \"sellar\",\n viewLocation: (id: Guid): Location => ({\n name: integrationsMenu.sellar.view,\n params: {\n id: id.toString(),\n },\n }),\n create: \"sellar_create\",\n createLocation: (): Location => ({\n name: integrationsMenu.sellar.create,\n }),\n },\n zettle: \"zettle\",\n beerflex: \"beerflex\",\n greentree: {\n view: \"greentree_navigation\",\n viewLocation: (): Location => ({\n name: integrationsMenu.greentree.view,\n }),\n edit: \"greentree_edit\",\n editLocation: (id: Guid, isEditing: boolean): Location => ({\n name: integrationsMenu.greentree.edit,\n params: {\n id: id.toString(),\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n },\n customCsv: {\n view: \"custom_csv_navigation\",\n viewLocation: (): Location => ({\n name: integrationsMenu.customCsv.view,\n }),\n edit: \"custom_csv_edit\",\n editLocation: (id: Guid, isEditing: boolean): Location => ({\n name: integrationsMenu.customCsv.edit,\n params: {\n id: id.toString(),\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n create: \"custom_csv_create\",\n createLocation: (): Location => ({\n name: integrationsMenu.customCsv.create,\n }),\n },\n eposNow: {\n view: \"epos_now\",\n viewLocation: (id: Guid): Location => ({\n name: integrationsMenu.eposNow.view,\n params: {\n id: id.toString(),\n },\n }),\n create: \"epos_now_create\",\n createLocation: (): Location => ({\n name: integrationsMenu.eposNow.create,\n }),\n },\n wooCommerce: {\n view: \"woo_commerce\",\n viewLocation: (id: Guid): Location => ({\n name: integrationsMenu.wooCommerce.view,\n params: {\n id: id.toString(),\n },\n }),\n create: \"woo_commerce_create\",\n createLocation: (): Location => ({\n name: integrationsMenu.wooCommerce.create,\n }),\n },\n ecommerce: {\n view: \"ecommerce\",\n viewLocation: (id: Guid): Location => ({\n name: integrationsMenu.ecommerce.view,\n params: {\n id: id.toString(),\n },\n }),\n create: \"ecommerce_create\",\n createLocation: (type: EnumEcommerceOrderOriginType): Location => ({\n name: integrationsMenu.ecommerce.create,\n params: {\n keyAsString: type.key.toString(),\n },\n }),\n },\n productionMonitoringTools: {\n list: \"production_monitoring_tools\",\n },\n lexoffice: {\n view: \"lexoffice\",\n viewLocation: (): Location => ({\n name: integrationsMenu.lexoffice.view,\n }),\n },\n squarespace: {\n view: \"squarespace\",\n viewLocation: (): Location => ({\n name: integrationsMenu.squarespace.view,\n }),\n },\n ecwid: {\n view: \"ecwid\",\n viewLocation: (): Location => ({\n name: integrationsMenu.ecwid.view,\n }),\n },\n maxoptra: {\n view: \"maxoptra\",\n viewLocation: (): Location => ({\n name: integrationsMenu.maxoptra.view,\n }),\n },\n zevero: {\n view: \"zevero\",\n viewLocation: (): Location => ({\n name: integrationsMenu.zevero.view,\n }),\n },\n netZeroNow: {\n view: \"netZeroNow\",\n viewLocation: (): Location => ({\n name: integrationsMenu.netZeroNow.view,\n }),\n },\n eebria: {\n view: \"eebria\",\n viewLocation: (): Location => ({\n name: integrationsMenu.eebria.view,\n }),\n },\n amazon: {\n overview: \"amazon_overview\",\n viewOverview: (isActive: boolean): Location => ({\n name: integrationsMenu.amazon.overview,\n params: {\n activated: isActive.toString(),\n },\n }),\n settings: \"amazon_settings\",\n viewSettings: (isActive: boolean): Location => ({\n name: integrationsMenu.amazon.settings,\n params: {\n activated: isActive.toString(),\n },\n }),\n introduction: \"amazon_introduction\",\n viewIntroduction: (): Location => ({\n name: integrationsMenu.amazon.introduction,\n }),\n },\n};\n\nexport const buildIntegrationsMenuItems: () => MenuItem[] = () => [\n MenuItem.fromOpts({\n name: integrationsMenu.root,\n icon: \"link\",\n url: \"/integrations\",\n visible: () =>\n hasPermissionsUsingUserStore([EnumUserPermission.menuIntegrationsView]),\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/Integrations.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.brewmanTradePortal.view,\n url: \"/integrations/brewman_trade_portal\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/brewmanTradePortal/BrewmanTradePortalPage.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.commerce7.view,\n url: \"/integrations/commerce7\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/commerce7/Commerce7Page.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.ptvRo.view,\n url: \"/integrations/ptv_ro\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/ptvro/PtvRoPage.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.wooCommerce.create,\n url: \"/integrations/woocommerce/create\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/WooCommerce.vue\"\n ),\n componentProps: {\n creating: true,\n },\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.wooCommerce.view,\n url: \"/integrations/woocommerce/view/:id\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/WooCommerce.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n idAsString: route.params.id,\n }),\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.ecommerce.create,\n url: \"/integrations/ecommerce/create/:keyAsString\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/EcommerceIntegration.vue\"\n ),\n componentProps: (route) => ({\n creating: true,\n keyAsString: route.params.keyAsString,\n }),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.ecommerce.view,\n url: \"/integrations/ecommerce/view/:id\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/EcommerceIntegration.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n idAsString: route.params.id,\n }),\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.xero,\n url: \"/integrations/xero\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/Xero.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.fortnox,\n url: \"/integrations/fortnox\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/Fortnox.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.quickBooks,\n url: \"/integrations/quickbooks\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/QuickBooks.vue\"\n ),\n componentProps: (route) => ({\n isSandbox: route.query.isSandbox\n ? route.query.isSandbox === \"true\"\n : false,\n }),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.sageOne,\n url: \"/integrations/sageone\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/SageOne.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.sageOneZa,\n url: \"/integrations/sage-one-za\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/SageOneZa.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.sage50,\n url: \"/integrations/sage50\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/Sage50.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.sage200,\n url: \"/integrations/sage200\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/Sage200.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.brewmanApi,\n url: \"/integrations/brewmanApi\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/BrewmanApi.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.noAccountsPackage,\n url: \"/integrations/noaccountspackage\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/NoAccountsPackage.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.sellar.view,\n url: \"/integrations/sellar/view/:id\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/Sellar.vue\"\n ),\n componentProps: (route) => ({\n settingsIdAsString: route.params.id,\n }),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.sellar.create,\n url: \"/integrations/sellar/create\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/Sellar.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.zettle,\n url: \"/integrations/zettle\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/Zettle.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.beerflex,\n url: \"/integrations/beerflex\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/Beerflex.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.eposNow.create,\n url: \"/integrations/eposnow/create\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/EposNow.vue\"\n ),\n componentProps: {\n creating: true,\n },\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.eposNow.view,\n url: \"/integrations/eposnow/view/:id\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/EposNow.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n idAsString: route.params.id,\n }),\n }),\n // whitelisted callback uri route used for authorisation\n MenuItem.fromOpts({\n name: integrationsMenu.square.callback,\n url: \"/integrations/square/\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/Square.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.square.create,\n url: \"/integrations/square/create\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/Square.vue\"\n ),\n visible: false,\n componentProps: {\n creating: true,\n },\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.square.view,\n url: \"/integrations/square/view/:id\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/Square.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n idAsString: route.params.id,\n }),\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.productionMonitoringTools.list,\n url: \"/integrations/productionmonitoring/list/\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/productionMonitoring/ListProductionMonitors.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.greentree.view,\n url: \"/integrations/greetree/\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/ListAccountsCsvFiles\"\n ),\n componentProps: () => ({\n accountsPackageType: EnumAccountsPackageType.greenTree,\n editLocation: integrationsMenu.greentree.editLocation,\n }),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.greentree.edit,\n url: \"/integrations/greentree/:id/:mode\",\n breadcrumbParentName: integrationsMenu.greentree.view,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/EditAccountsCsvFile\"\n ),\n componentProps: (route) => ({\n id: route.params.id,\n editing:\n route.params.id && route.params.mode.toLowerCase().trim() === \"edit\",\n editLocation: integrationsMenu.greentree.editLocation,\n viewLocation: integrationsMenu.greentree.viewLocation,\n }),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.customCsv.view,\n url: \"/integrations/customcsv/\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/ListCustomCsvFiles\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.customCsv.edit,\n url: \"/integrations/customcsv/:id/:mode\",\n breadcrumbParentName: integrationsMenu.customCsv.view,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/EditCustomCsvFile\"\n ),\n componentProps: (route) => ({\n id: route.params.id,\n editing:\n route.params.id && route.params.mode.toLowerCase().trim() === \"edit\",\n }),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.customCsv.create,\n url: \"/integrations/customcsv/create\",\n breadcrumbParentName: integrationsMenu.customCsv.view,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/EditCustomCsvFile\"\n ),\n componentProps: (route) => ({\n editing: true,\n }),\n visible: false,\n }),\n\n MenuItem.fromOpts({\n name: integrationsMenu.lexoffice.view,\n url: \"/integrations/lexoffice\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/Lexoffice.vue\"\n ),\n visible: false,\n }),\n\n MenuItem.fromOpts({\n name: integrationsMenu.squarespace.view,\n url: \"/integrations/squarespace\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/Squarespace.vue\"\n ),\n visible: false,\n }),\n\n MenuItem.fromOpts({\n name: integrationsMenu.ecwid.view,\n url: \"/integrations/ecwid\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/Ecwid.vue\"\n ),\n visible: false,\n }),\n\n MenuItem.fromOpts({\n name: integrationsMenu.maxoptra.view,\n url: \"/integrations/maxoptra\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/Maxoptra.vue\"\n ),\n visible: false,\n }),\n\n MenuItem.fromOpts({\n name: integrationsMenu.zevero.view,\n url: \"/integrations/zevero\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/Zevero.vue\"\n ),\n visible: false,\n }),\n\n MenuItem.fromOpts({\n name: integrationsMenu.netZeroNow.view,\n url: \"/integrations/net-zero-now\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/NetZeroNow.vue\"\n ),\n visible: false,\n }),\n\n MenuItem.fromOpts({\n name: integrationsMenu.eebria.view,\n url: \"/integrations/eebria\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/Eebria.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.amazon.overview,\n url: \"/integrations/amazon/\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/newComponents/IntegrationPage.vue\"\n ),\n visible: false,\n redirect: \"/integrations/amazon/overview\",\n componentProps: (route) => ({\n integrationType: EnumIntegrationType.amazon,\n pageTitle: messages.amazon_title,\n tabItems: amazonTabs(),\n activated: route.params.activated\n ? route.params.activated === \"true\"\n : false,\n }),\n childRoutes: [\n {\n name: integrationsMenu.amazon.overview,\n path: \"overview\",\n component: () =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/amazon/AmazonOverviewTab.vue\"\n ),\n },\n {\n name: integrationsMenu.amazon.settings,\n path: \"settings\",\n component: () =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/amazon/AmazonSettingsTab.vue\"\n ),\n },\n ],\n }),\n MenuItem.fromOpts({\n name: integrationsMenu.amazon.introduction,\n url: \"/integrations/amazon/introduction\",\n breadcrumbParentName: integrationsMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"integrations\" */ \"@/components/pages/integrations/amazon/AmazonSettingsPage.vue\"\n ),\n visible: false,\n }),\n];\n","import Guid from \"@/app/types/common/guid\";\nimport { MenuItem } from \"@/app/ui/navigation/types\";\nimport type { Location, Route } from \"vue-router\";\nimport tenantStore from \"@/store/modules/tenantStore\";\nimport { EnumAccountsPackageType } from \"@/app/services/generated/enums/enumAccountsPackageType.generated\";\nimport { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\nimport { hasFeatureUsingUserStore } from \"@/app/featureFlags\";\nimport { EnumFeatureFlag } from \"@/app/services/generated/enums/enumFeatureFlag.generated\";\nimport { RouteBuilder } from \"@/app/ui/navigation/routeBuilder\";\nimport { keys } from \"@/plugins/i18n\";\n\nconst builder = new RouteBuilder(\"Admin_\");\n\nconst extractIdEditingPropsFromIdModeRoute = (route: Route) => ({\n id: route.params.id,\n editing: route.params.id && route.params.mode.toLowerCase().trim() === \"edit\",\n});\n\nconst formIdAndModeLocationParams = (opts: { id: Guid; editing: boolean }) => ({\n id: opts.id.value,\n mode: opts.editing ? \"edit\" : \"view\",\n});\n\nexport const adminRoutes = {\n taskQueues: builder.route({\n url: \"/administration/settings/production/taskqueues\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListTaskQueues.vue\"\n ),\n }),\n taskTypes: builder.route({\n url: \"/administration/settings/production/tasktypes\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListTaskTypes.vue\"\n ),\n }),\n leadsLossReasons: builder.route({\n url: \"/administration/settings/tasks/leadlossreaons\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListLeadLossReasons.vue\"\n ),\n }),\n leadsSources: builder.route({\n url: \"/administration/settings/tasks/leadsources\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListLeadSources.vue\"\n ),\n }),\n leadsSalesPipelineStages: builder.route({\n url: \"/administration/settings/tasks/leadspipelinestages\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListLeadPipelineStages.vue\"\n ),\n }),\n\n creditTerms: builder.route({\n url: \"/administration/settings/contacts/creditterms\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListCreditTerms.vue\"\n ),\n }),\n communicationSubjects: builder.route({\n url: \"/administration/settings/production/communicationsubjects\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListCommunicationSubjects.vue\"\n ),\n }),\n communicationTypes: builder.route({\n url: \"/administration/settings/production/communicationtypes\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListCommunicationTypes.vue\"\n ),\n }),\n outletRatings: builder.route({\n url: \"/administration/settings/contacts/outletratings\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListOutletRatings.vue\"\n ),\n }),\n outletTypes: builder.route({\n url: \"/administration/settings/contacts/outlettypes\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListOutletTypes.vue\"\n ),\n }),\n outletSubTypes: builder.route({\n url: \"/administration/settings/contacts/list-outlet-sub-types\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListOutletSubTypesPage.vue\"\n ),\n }),\n salesAreas: builder.route({\n url: \"/administration/settings/contacts/salesareas\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListSalesAreas.vue\"\n ),\n }),\n salesCodes: builder.route({\n url: \"/administration/settings/contacts/salescodes\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListSalesCodes.vue\"\n ),\n }),\n\n glCodes: builder.route({\n url: \"/administration/settings/contacts/glcodes\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListGlCodes.vue\"\n ),\n }),\n packageTypes: builder.route({\n url: \"/administration/settings/contacts/packagetypes\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListPackageTypes.vue\"\n ),\n }),\n listPoDeliveryServices: builder.route({\n url: \"/administration/settings/contacts/podeliveryservices\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListPoDeliveryService\"\n ),\n }),\n editPoDeliveryService: builder.routeWithParams(\n {\n url: \"/administration/settings/contacts/podeliveryservices/:id/:mode\",\n view: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/EditPoDeliveryService\"\n ),\n componentProps: extractIdEditingPropsFromIdModeRoute,\n },\n formIdAndModeLocationParams\n ),\n createPoDeliveryService: builder.route({\n url: \"/administration/settings/contacts/podeliveryservices/create\",\n view: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/EditPoDeliveryService\"\n ),\n componentProps: () => ({\n editing: true,\n }),\n }),\n pricingCategories: builder.route({\n url: \"/administration/settings/contacts/pricingcategories\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListPricingCategories.vue\"\n ),\n }),\n stockLocations: builder.route({\n url: \"/administration/settings/contacts/stocklocations\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListStockLocations.vue\"\n ),\n }),\n stockGroups: builder.route({\n url: \"/administration/settings/contacts/stockgroups\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListStockGroups.vue\"\n ),\n }),\n unitsOfMeasure: builder.route({\n url: \"/administration/settings/contacts/unitsofmeasure\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListUnitsOfMeasure.vue\"\n ),\n }),\n vatCodes: builder.route({\n url: \"/administration/settings/contacts/vatcodes\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListVatCodes.vue\"\n ),\n }),\n caskTypes: builder.route({\n url: \"/administration/settings/agingcasks/casktype\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListCaskTypes.vue\"\n ),\n }),\n caskSubTypes: builder.route({\n url: \"/administration/settings/agingcasks/casksubtypes\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListCaskSubTypes.vue\"\n ),\n }),\n caskSubLocations: builder.route({\n url: \"/administration/settings/agingcasks/casksublocations\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListCaskSubLocations.vue\"\n ),\n }),\n caskSubSubLocations: builder.route({\n url: \"/administration/settings/agingcasks/casksubsublocations\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListCaskSubSubLocations.vue\"\n ),\n }),\n vesselTypes: builder.route({\n url: \"/administration/settings/production/vesseltypes\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListVesselTypes.vue\"\n ),\n }),\n vesselStates: builder.route({\n url: \"/administration/settings/production/vesselstates\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListVesselStates.vue\"\n ),\n }),\n vessels: builder.route({\n url: \"/administration/settings/production/vessels\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListVessels.vue\"\n ),\n }),\n vesselSummarySettings: builder.route({\n url: \"/administration/settings/production/vessel-summary-settings\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/VesselSummarySettings.vue\"\n ),\n }),\n maintenanceProcesses: builder.route({\n url: \"/administration/settings/production/maintenanceprocesses\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListMaintenanceProcesses.vue\"\n ),\n }),\n qualityControlTests: builder.route({\n url: \"/administration/settings/production/qctests\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListQcTests.vue\"\n ),\n }),\n vesselCapabilities: builder.route({\n url: \"/administration/settings/production/vesselcapabilities\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListVesselCapabilities.vue\"\n ),\n }),\n listBottleDepositRedemptionItems: builder.route({\n url: \"/administration/settings/bottledeposit/redemptionitem\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListRedemptionItem\"\n ),\n }),\n listBottleDepositChargeItems: builder.route({\n url: \"/administration/settings/bottledeposit/chargeitems\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListChargeItems\"\n ),\n }),\n editBottleDepositRedemptionItem: builder.routeWithParams(\n {\n url: \"/administration/settings/bottledeposit/redemptionitem/:id/:mode\",\n view: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/EditRedemptionItem\"\n ),\n componentProps: extractIdEditingPropsFromIdModeRoute,\n },\n formIdAndModeLocationParams\n ),\n createBottleDepositRedemptionItem: builder.route({\n url: \"/administration/settings/bottledeposit/redemptionitem/create\",\n view: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/EditRedemptionItem\"\n ),\n componentProps: () => ({\n editing: true,\n }),\n }),\n editBottleDepositChargeItem: builder.routeWithParams(\n {\n url: \"/administration/settings/bottledeposit/chargeitems/:id/:mode\",\n view: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/EditChargeItem\"\n ),\n componentProps: extractIdEditingPropsFromIdModeRoute,\n },\n formIdAndModeLocationParams\n ),\n createBottleDepositChargeItem: builder.route({\n url: \"/administration/settings/bottledeposit/chargeitems/create\",\n view: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/EditChargeItem\"\n ),\n componentProps: () => ({\n editing: true,\n }),\n }),\n\n customNumberingSchemas: builder.route({\n url: \"/administration/settings/production/numberschemas\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListNumberSchemes.vue\"\n ),\n }),\n orderTypeText: builder.route({\n url: \"/administration/settings/other/ordertypetext\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListOrderTypeText.vue\"\n ),\n }),\n listPalletTypes: builder.route({\n url: \"/administration/settings/other/pallettypes\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/ListPalletTypes\"\n ),\n }),\n editPalletType: builder.routeWithParams(\n {\n url: \"/administration/settings/other/pallettypes/:id/:mode\",\n view: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/EditPalletType\"\n ),\n componentProps: extractIdEditingPropsFromIdModeRoute,\n },\n formIdAndModeLocationParams\n ),\n createPalletType: builder.route({\n url: \"/administration/settings/other/pallettypes/create\",\n view: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/code_files/EditPalletType\"\n ),\n componentProps: () => ({\n editing: true,\n }),\n }),\n\n accountsPost: builder.routeWithParams(\n {\n url: \"/administration/accountslink/post\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/accounts_posting/PostTransactions.vue\"\n ),\n componentProps: (r) => ({\n filterToOrderIds:\n r.params.filterToOrderIds\n ?.split(\"|\")\n .map((guidString) => Guid.tryParse(guidString))\n .filter((guid) => guid) ?? undefined,\n }),\n },\n (orderIds?: readonly Guid[]) => ({\n filterToOrderIds: orderIds\n ? orderIds.map((x) => x.value).join(\"|\")\n : undefined,\n })\n ),\n accountsRepost: builder.route({\n url: \"/administration/accountslink/repost\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/accounts_posting/Repost.vue\"\n ),\n }),\n\n importList: builder.route({\n url: \"/administration/import\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/import/ImportOverview.vue\"\n ),\n }),\n importCreate: builder.routeWithParams(\n {\n url: \"/administration/import/create\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/import/ImportWizard.vue\"\n ),\n componentProps: (r) => ({\n bulkUpdateAtStart: r.params.bulkUpdateAtStart === \"true\",\n }),\n },\n (opts: { bulkUpdateAtStart: boolean }) => ({\n bulkUpdateAtStart: opts.bulkUpdateAtStart.toString(),\n })\n ),\n importView: builder.routeWithParams(\n {\n url: \"/administration/import/:id\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/import/ImportWizard.vue\"\n ),\n },\n // Page does not use prop for id so we do not provide it as a prop. Page inspects the route params directly.\n (id?: Guid) => ({\n id: id?.toString(),\n })\n ),\n export: builder.route({\n url: \"/administration/export\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/export/Export.vue\"\n ),\n }),\n emailSettings: builder.route({\n url: \"/administration/emailsettings\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/email_settings/EmailSettings.vue\"\n ),\n }),\n emailAudit: builder.route({\n url: \"/administration/emailaudit\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/email_audit/EmailAudit.vue\"\n ),\n }),\n smsAudit: builder.route({\n url: \"/administration/smsaudit\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/SmsAudit\"\n ),\n }),\n taskNotifications: builder.route({\n url: \"/administration/taskNotifications\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/TaskNotifications.vue\"\n ),\n }),\n updateOpenOrders: builder.route({\n url: \"/administration/updateopenorders\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/pages/admin/UpdateOpenOrdersPage.vue\"\n ),\n }),\n};\n\nexport const administrationMenu = {\n root: \"navigation_administration_group\",\n documents: {\n list: \"document_template_list\",\n view: \"document_manager_design\",\n viewLocation: (id: Guid) => ({\n name: administrationMenu.documents.view,\n params: {\n id: id.toString(),\n },\n }),\n content: \"document_manager_content\",\n contentLocation: (id: Guid) => ({\n name: administrationMenu.documents.content,\n params: {\n id: id.toString(),\n },\n }),\n email: \"document_manager_email\",\n emailLocation: (id: Guid) => ({\n name: administrationMenu.documents.email,\n params: {\n id: id.toString(),\n },\n }),\n settings: \"document_manager_settings\",\n settingsLocation: (id: Guid) => ({\n name: administrationMenu.documents.settings,\n params: {\n id: id.toString(),\n },\n }),\n tags: {\n view: \"document_tag_list\",\n viewLocation: () => ({\n name: administrationMenu.documents.tags.view,\n }),\n },\n },\n dispatchNotificationTemplates: {\n root: \"dispatch_notifications\",\n email: {\n list: \"dispatch_notification_email_template_list\",\n listLocation: (): Location => ({\n name: administrationMenu.dispatchNotificationTemplates.email.list,\n }),\n edit: \"dispatch_notification_email_template_edit\",\n editLocation: (id: Guid, isEditing: boolean): Location => ({\n name: administrationMenu.dispatchNotificationTemplates.email.edit,\n params: {\n id: id.toString(),\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n create: \"dispatch_notification_email_template_create\",\n createLocation: (): Location => ({\n name: administrationMenu.dispatchNotificationTemplates.email.create,\n }),\n },\n sms: {\n list: \"dispatch_notification_sms_template_list\",\n listLocation: (): Location => ({\n name: administrationMenu.dispatchNotificationTemplates.sms.list,\n }),\n edit: \"dispatch_notification_sms_template_edit\",\n editLocation: (id: Guid, isEditing: boolean): Location => ({\n name: administrationMenu.dispatchNotificationTemplates.sms.edit,\n params: {\n id: id.toString(),\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n create: \"dispatch_notification_sms_template_create\",\n createLocation: (): Location => ({\n name: administrationMenu.dispatchNotificationTemplates.sms.create,\n }),\n },\n },\n systemSetup: {\n edit: \"system_setup\",\n editLocation: (isEditing: boolean): Location => ({\n name: administrationMenu.systemSetup.edit,\n params: {\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n },\n\n yourCompany: {\n companySetup: {\n edit: \"company_setup_edit\",\n view: \"company_setup\",\n editLocation: (isEditing: boolean): Location => ({\n name: isEditing\n ? administrationMenu.yourCompany.companySetup.edit\n : administrationMenu.yourCompany.companySetup.view,\n }),\n },\n root: \"your_company\",\n users: {\n list: \"user_setup\",\n listLocation: (): Location => ({\n name: administrationMenu.yourCompany.users.list,\n }),\n create: \"user_create\",\n createLocation: (): Location => ({ name: \"user_create\" }),\n view: \"user_admin\",\n viewLocation: (userId: Guid): Location => ({\n name: \"user_admin\",\n params: { id: userId.toString() },\n }),\n },\n userRoles: {\n list: \"user_roles\",\n listLocation: (): Location => ({\n name: administrationMenu.yourCompany.userRoles.list,\n }),\n edit: \"user_roles_edit\",\n editLocation: (id: Guid, isEditing: boolean): Location => ({\n name: administrationMenu.yourCompany.userRoles.edit,\n params: {\n id: id.toString(),\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n createLocation: (): Location => ({\n name: administrationMenu.yourCompany.userRoles.edit,\n }),\n },\n billingDetails: \"billing_details\",\n labelOrders: {\n view: \"label_orders\",\n viewLocation: (): Location => ({\n name: administrationMenu.yourCompany.labelOrders.view,\n }),\n },\n },\n accounts: {\n postTransactions: {\n view: \"accounts_posting_transactions\",\n viewLocation: () => ({\n name: administrationMenu.accounts.postTransactions.view,\n }),\n },\n accountsRepost: \"accounts_repost\",\n },\n resetDemoData: \"reset_demo_data\",\n currentSessions: \"auth_current_sessions\",\n};\n\nexport const buildAdministrationMenuItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n name: keys.navigation_administration_group.value,\n icon: \"settings\",\n visible: () =>\n hasPermissionsUsingUserStore([EnumUserPermission.menuAdministrationView]),\n subMenus: [\n MenuItem.forBranch({\n name: keys.administration_settings.value,\n subMenus: [\n MenuItem.forBranch({\n name: keys.administration_tasks_and_leads.value,\n subMenus: [\n MenuItem.forRoute(keys.task_queues, adminRoutes.taskQueues),\n MenuItem.forRoute(keys.task_types, adminRoutes.taskTypes),\n MenuItem.forRoute(\n keys.leads_lead_loss_reasons,\n adminRoutes.leadsLossReasons\n ),\n MenuItem.forRoute(keys.leads_sources, adminRoutes.leadsSources),\n MenuItem.forRoute(\n keys.leads_pipeline_stages,\n adminRoutes.leadsSalesPipelineStages\n ),\n ],\n }),\n MenuItem.forBranch({\n name: keys.administration_contacts.value,\n subMenus: [\n MenuItem.forRoute(keys.credit_terms, adminRoutes.creditTerms),\n MenuItem.forRoute(\n keys.communication_subjects,\n adminRoutes.communicationSubjects\n ),\n MenuItem.forRoute(\n keys.communication_types,\n adminRoutes.communicationTypes\n ),\n MenuItem.forRoute(keys.outlet_ratings, adminRoutes.outletRatings),\n MenuItem.forRoute(keys.outlet_types, adminRoutes.outletTypes),\n MenuItem.forRoute(\n keys.list_outlet_sub_types,\n adminRoutes.outletSubTypes\n ),\n MenuItem.forRoute(keys.sales_areas, adminRoutes.salesAreas),\n MenuItem.forRoute(keys.sales_codes, adminRoutes.salesCodes),\n ],\n }),\n MenuItem.forBranch({\n name: keys.products.value,\n subMenus: [\n MenuItem.forRoute(keys.gl_codes, adminRoutes.glCodes),\n MenuItem.forRoute(keys.package_types, adminRoutes.packageTypes),\n MenuItem.forRoute(\n keys.po_delivery_service,\n adminRoutes.listPoDeliveryServices\n ),\n MenuItem.forRoute(\n keys.pricing_categories,\n adminRoutes.pricingCategories\n ),\n MenuItem.forRoute(\n keys.stock_locations,\n adminRoutes.stockLocations\n ),\n MenuItem.forRoute(keys.stock_groups, adminRoutes.stockGroups),\n MenuItem.forRoute(\n keys.units_of_measure,\n adminRoutes.unitsOfMeasure\n ),\n MenuItem.forRoute(keys.vat_codes, adminRoutes.vatCodes),\n ],\n }),\n MenuItem.forBranch({\n name: keys.aging_casks.value,\n subMenus: [\n MenuItem.forRoute(\n keys.code_files_cask_type,\n adminRoutes.caskTypes\n ),\n MenuItem.forRoute(\n keys.code_files_cask_sub_type,\n adminRoutes.caskSubTypes\n ),\n MenuItem.forRoute(\n keys.code_files_cask_sub_location1,\n adminRoutes.caskSubLocations\n ),\n MenuItem.forRoute(\n keys.code_files_cask_sub_location2,\n adminRoutes.caskSubSubLocations\n ),\n ],\n }),\n MenuItem.forBranch({\n name: keys.production.value,\n subMenus: [\n MenuItem.forRoute(keys.vessel_types, adminRoutes.vesselTypes),\n MenuItem.forRoute(keys.vessel_states, adminRoutes.vesselStates),\n MenuItem.forRoute(keys.vessel_vessels, adminRoutes.vessels),\n MenuItem.forRoute(\n keys.vessel_summary_settings,\n adminRoutes.vesselSummarySettings\n ),\n MenuItem.forRoute(\n keys.vessels_maintenance_processes,\n adminRoutes.maintenanceProcesses,\n {\n visible: () =>\n hasFeatureUsingUserStore(EnumFeatureFlag.onlyDev) ||\n !tenantStore.state.tenantSettings.isMegaBatchesEnabled,\n }\n ),\n MenuItem.forRoute(\n keys.qctests_title,\n adminRoutes.qualityControlTests\n ),\n MenuItem.forRoute(\n keys.vessel_capabilities,\n adminRoutes.vesselCapabilities\n ),\n ],\n }),\n MenuItem.forBranch({\n name: keys.bottle_deposit.value,\n visible: () =>\n tenantStore.state.bottleDepositSettings.isBottleDepositEnabled,\n subMenus: [\n MenuItem.forRoute(\n keys.bottle_deposit_redemption_item,\n adminRoutes.listBottleDepositRedemptionItems\n ),\n MenuItem.forRoute(\n keys.bottle_deposit_charge_items,\n adminRoutes.listBottleDepositChargeItems\n ),\n ],\n }),\n MenuItem.forBranch({\n name: keys.administration_other.value,\n subMenus: [\n MenuItem.forRoute(\n keys.number_schemes_title,\n adminRoutes.customNumberingSchemas\n ),\n MenuItem.forRoute(\n keys.orders_order_type_text,\n adminRoutes.orderTypeText\n ),\n MenuItem.forRoute(keys.pallet_types, adminRoutes.listPalletTypes),\n ],\n }),\n ],\n }),\n MenuItem.forBranch({\n name: keys.accounts_posting.value,\n subMenus: [\n MenuItem.forRoute(\n keys.accounts_posting_transactions,\n adminRoutes.accountsPost\n ),\n MenuItem.forRoute(keys.accounts_repost, adminRoutes.accountsRepost, {\n visible: () => {\n // We have to use .key here as the userStore injects additional data into the state object properties, meaning\n // that checking for equality doesn't work as expected\n return (\n tenantStore.state.accountsLinkDetails.accountsPackageType\n .key !== EnumAccountsPackageType.lexoffice.key\n );\n },\n }),\n ],\n }),\n MenuItem.forRoute(keys.import_external, adminRoutes.importList),\n MenuItem.forRoute(keys.export_external, adminRoutes.export),\n MenuItem.forRoute(\n keys.administration_email_settings,\n adminRoutes.emailSettings\n ),\n MenuItem.forRoute(keys.email_audit, adminRoutes.emailAudit),\n MenuItem.forRoute(keys.sms_audit, adminRoutes.smsAudit),\n MenuItem.forRoute(keys.task_notifications, adminRoutes.taskNotifications),\n MenuItem.fromOpts({\n name: administrationMenu.documents.list,\n url: \"/administration/documents/list\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/documents/ListDocumentTemplates.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: administrationMenu.documents.tags.view,\n url: \"/administration/documents/tags\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/documents/ListDocumentTags.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: \"\",\n icon: \"edit\",\n url: \"/administration/documents/:id\",\n breadcrumbParentName: administrationMenu.documents.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/documents/ViewDocument.vue\"\n ),\n visible: false,\n componentProps: (route) => ({\n id: route.params.id,\n }),\n childRoutes: [\n {\n name: administrationMenu.documents.view,\n path: \"\",\n component: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/documents/DesignTab.vue\"\n ),\n },\n {\n name: administrationMenu.documents.content,\n path: \"/administration/documents/:id/content\",\n component: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/documents/ContentTab.vue\"\n ),\n },\n {\n name: administrationMenu.documents.email,\n path: \"/administration/documents/:id/email\",\n component: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/documents/EmailTab.vue\"\n ),\n },\n {\n name: administrationMenu.documents.settings,\n path: \"/administration/documents/:id/settings\",\n component: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/documents/SettingsTab.vue\"\n ),\n },\n ],\n }),\n\n MenuItem.forBranch({\n name: administrationMenu.dispatchNotificationTemplates.root,\n subMenus: [\n // Email Delivery Notification Templates\n\n MenuItem.fromOpts({\n name: administrationMenu.dispatchNotificationTemplates.email.list,\n url: \"/administration/dispatch_notifications/templates/email\",\n view: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/dispatchNotifications/ListEmailDispatchNotificationTemplates\"\n ),\n }),\n MenuItem.fromOpts({\n name: administrationMenu.dispatchNotificationTemplates.email.edit,\n url: \"/administration/dispatch_notifications/templates/email/:id/:mode\",\n breadcrumbParentName:\n administrationMenu.dispatchNotificationTemplates.email.list,\n view: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/dispatchNotifications/EditDispatchNotificationTemplateEmail\"\n ),\n visible: false,\n componentProps: (route) => {\n return {\n id: route.params.id,\n editing:\n route.params.id &&\n route.params.mode.toLowerCase().trim() === \"edit\",\n };\n },\n }),\n MenuItem.fromOpts({\n name: administrationMenu.dispatchNotificationTemplates.email.create,\n url: \"/administration/dispatch_notifications/templates/email/create\",\n breadcrumbParentName:\n administrationMenu.dispatchNotificationTemplates.email.list,\n view: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/dispatchNotifications/EditDispatchNotificationTemplateEmail\"\n ),\n visible: false,\n componentProps: (route) => ({\n editing: true,\n id: route.params.id,\n }),\n }),\n\n // SMS Delivery Notification Templates\n\n MenuItem.fromOpts({\n name: administrationMenu.dispatchNotificationTemplates.sms.list,\n url: \"/administration/dispatch_notifications/templates/sms\",\n view: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/dispatchNotifications/ListSmsDispatchNotificationTemplates\"\n ),\n }),\n MenuItem.fromOpts({\n name: administrationMenu.dispatchNotificationTemplates.sms.edit,\n url: \"/administration/dispatch_notifications/templates/sms/:id/:mode\",\n breadcrumbParentName:\n administrationMenu.dispatchNotificationTemplates.sms.list,\n view: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/dispatchNotifications/EditDispatchNotificationTemplateSms\"\n ),\n visible: false,\n componentProps: (route) => {\n return {\n id: route.params.id,\n editing:\n route.params.id &&\n route.params.mode.toLowerCase().trim() === \"edit\",\n };\n },\n }),\n MenuItem.fromOpts({\n name: administrationMenu.dispatchNotificationTemplates.sms.create,\n url: \"/administration/dispatch_notifications/templates/sms/create\",\n breadcrumbParentName:\n administrationMenu.dispatchNotificationTemplates.sms.list,\n view: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/dispatchNotifications/EditDispatchNotificationTemplateSms\"\n ),\n visible: false,\n componentProps: (route) => ({\n editing: true,\n id: route.params.id,\n }),\n }),\n ],\n }),\n\n MenuItem.fromOpts({\n name: administrationMenu.currentSessions,\n url: \"/administration/currentsessions\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/CurrentSessions.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: administrationMenu.systemSetup.edit,\n url: \"/administration/systemsetup\",\n breadcrumbParentName: administrationMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/SystemSetup.vue\"\n ),\n }),\n MenuItem.forBranch({\n name: administrationMenu.yourCompany.root,\n subMenus: [\n MenuItem.fromOpts({\n name: administrationMenu.yourCompany.companySetup.edit,\n url: \"/administration/companysetup/edit\",\n breadcrumbParentName: administrationMenu.yourCompany.root,\n visible: false,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/CompanySetup\"\n ),\n componentProps: (route) => {\n return {\n editing: true,\n };\n },\n }),\n MenuItem.fromOpts({\n name: administrationMenu.yourCompany.companySetup.view,\n url: \"/administration/companysetup/view\",\n breadcrumbParentName: administrationMenu.yourCompany.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/CompanySetup\"\n ),\n componentProps: (route) => {\n return {\n editing: false,\n };\n },\n }),\n MenuItem.fromOpts({\n name: administrationMenu.yourCompany.users.list,\n url: \"/administration/users\",\n breadcrumbParentName: administrationMenu.yourCompany.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/Users.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: administrationMenu.yourCompany.users.create,\n url: \"/administration/users/create\",\n breadcrumbParentName: administrationMenu.yourCompany.users.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/users/UserAdmin.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: administrationMenu.yourCompany.users.view,\n url: \"/administration/users/:id\",\n breadcrumbParentName: administrationMenu.yourCompany.users.list,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/users/UserAdmin.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: administrationMenu.yourCompany.billingDetails,\n url: \"/administration/billing\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/billing/BillingDetails.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: administrationMenu.yourCompany.labelOrders.view,\n url: \"/administration/labelOrders\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/label_ordering/ConsumablesOrderForm.vue\"\n ),\n visible: false,\n }),\n MenuItem.fromOpts({\n name: administrationMenu.yourCompany.userRoles.list,\n url: \"/administration/user/roles\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/user_roles/ListUserRoles.vue\"\n ),\n }),\n MenuItem.fromOpts({\n name: administrationMenu.yourCompany.userRoles.edit,\n url: \"/administration/user/role/:id?/:mode?\",\n breadcrumbParentName: administrationMenu.yourCompany.userRoles.list,\n view: () =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/user_roles/EditUserRole.vue\"\n ),\n visible: false,\n }),\n ],\n }),\n\n MenuItem.forRoute(keys.update_open_orders, adminRoutes.updateOpenOrders),\n\n MenuItem.fromOpts({\n name: administrationMenu.resetDemoData,\n url: \"/administration/resetdemodata\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"administration\" */ \"@/components/pages/administration/ResetDemoData.vue\"\n ),\n }),\n // Temporary invisible node. Required while routes are still being added via the Menu items.\n // Can be removed once AdminRoutes are used for the actual route registrations.\n MenuItem.forBranch({\n name: \"invisible\",\n visible: false,\n subMenus: [\n adminRoutes.editPoDeliveryService,\n adminRoutes.createPoDeliveryService,\n adminRoutes.editBottleDepositRedemptionItem,\n adminRoutes.createBottleDepositRedemptionItem,\n adminRoutes.editBottleDepositChargeItem,\n adminRoutes.createBottleDepositChargeItem,\n adminRoutes.editPalletType,\n adminRoutes.createPalletType,\n adminRoutes.importCreate,\n adminRoutes.importView,\n ].map((x) => MenuItem.forRoute(\"\", x)),\n }),\n ],\n requiredUserPermissions: [EnumUserPermission.administration],\n }),\n];\n","import { MenuItem } from \"@/app/ui/navigation/types\";\nimport { EnumFeatureFlag } from \"@/app/services/generated/enums/enumFeatureFlag.generated\";\nimport Guid from \"@/app/types/common/guid\";\nimport { RouteBuilder } from \"@/app/ui/navigation/routeBuilder\";\nimport { keys } from \"@/plugins/i18n\";\n\nconst builder = new RouteBuilder(\"Support_\");\n\nexport const supportRoutes = {\n tools: builder.route({\n url: \"/support/tools\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"support\" */ \"@/components/pages/support/SupportTools.vue\"\n ),\n }),\n customers: builder.route({\n url: \"/support/customers\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"support\" */ \"@/components/pages/support/SupportTenantGroupView.vue\"\n ),\n }),\n stripe2Xero: builder.route({\n url: \"/support/stripe2xero\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"support\" */ \"@/components/pages/support/SupportStripeToXeroSync.vue\"\n ),\n }),\n users: builder.routeWithParams(\n {\n url: \"/support/customers/:id/users\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"support\" */ \"@/components/pages/support/SupportTenantGroupUsersView.vue\"\n ),\n componentProps: (route) => ({\n tenantGroupId: Guid.tryParse(route.params.id) ?? undefined,\n }),\n },\n (opts: { tenantGroupId: Guid }) => ({\n id: opts.tenantGroupId.value,\n })\n ),\n migrateAssemblies: builder.route({\n url: \"/support/migrate-assemblies\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"support\" */ \"@/components/pages/support/SupportMigrateAssembliesToMegaBatches.vue\"\n ),\n }),\n orderCreditDutyUpdate: builder.route({\n url: \"/support/order-credit-duty-update\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"support\" */ \"@/components/pages/support/SupportOrderCreditDutyUpdate.vue\"\n ),\n }),\n consumablesUpdate: builder.route({\n url: \"/support/consumables-update\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"support\" */ \"@/components/pages/support/SupportConsumables.vue\"\n ),\n }),\n};\n\nexport const buildSupportMenuItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n translationKey: keys.brewman_support.value,\n icon: \"support_agent\",\n requiredFeatureFlag: EnumFeatureFlag.showSupportFunctions,\n subMenus: [\n MenuItem.forRoute(\"BrewMan Support Tools\", supportRoutes.tools),\n MenuItem.forRoute(\"BrewMan Support Customers\", supportRoutes.customers),\n MenuItem.forRoute(\"Stripe To Xero\", supportRoutes.stripe2Xero),\n MenuItem.forRoute(\"Migrate Assemblies\", supportRoutes.migrateAssemblies),\n MenuItem.forRoute(\n \"Order Credit Duty Update\",\n supportRoutes.orderCreditDutyUpdate\n ),\n MenuItem.forRoute(\"Consumables Update\", supportRoutes.consumablesUpdate),\n ],\n }),\n];\n","import { MenuItem } from \"@/app/ui/navigation/types\";\nimport { EnumFeatureFlag } from \"@/app/services/generated/enums/enumFeatureFlag.generated\";\nimport { RouteBuilder } from \"@/app/ui/navigation/routeBuilder\";\nimport type Guid from \"@/app/types/common/guid\";\nimport { keys } from \"@/plugins/i18n\";\n\nconst builder = new RouteBuilder(\"Gallery_\");\n\nexport const galleryRoutes = {\n typography: builder.route({\n url: \"/gallery/typography\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/Typography.vue\"\n ),\n }),\n controls: builder.route({\n url: \"/gallery/controls\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/Controls.vue\"\n ),\n }),\n singleControls: builder.route({\n url: \"/gallery/singleControls\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/SingleControls.vue\"\n ),\n }),\n production: builder.route({\n url: \"/gallery/production\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/Production.vue\"\n ),\n }),\n grids: builder.route({\n url: \"/gallery/grids\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/Grids.vue\"\n ),\n }),\n largeGrid: builder.route({\n url: \"/gallery/largegrid\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/LargeGrid.vue\"\n ),\n }),\n geocode: builder.route({\n url: \"/gallery/geocode\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/Geocode.vue\"\n ),\n }),\n maps: builder.route({\n url: \"/gallery/maps\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/Maps.vue\"\n ),\n }),\n pageLayout: builder.route({\n url: \"/gallery/page_layout\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/PageLayout.vue\"\n ),\n }),\n validation: builder.route({\n url: \"/gallery/validation\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/Validation.vue\"\n ),\n }),\n tableau: builder.route({\n url: \"/gallery/tableau/reporting/RevenueMap\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/reporting/embeddedtableau/EmbeddedTableauReport.vue\"\n ),\n componentProps: (route) => ({\n workbook: \"Reporting\",\n view: \"RevenueMap\",\n }),\n }),\n timeline: builder.route({\n url: \"/gallery/timeline\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/Timeline.vue\"\n ),\n }),\n pipeline: builder.route({\n url: \"/gallery/pipeline\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/LeadsPipelineGallery.vue\"\n ),\n }),\n errorTests: builder.route({\n url: \"/gallery/error_testing\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/ErrorTests.vue\"\n ),\n }),\n platformSingleList: builder.route({\n url: \"/gallery/platform\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/platformSingleList\"\n ),\n }),\n editPage: builder.routeWithParams(\n {\n url: \"/gallery/editpage/:id/:mode\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/platformEditPage\"\n ),\n componentProps: (route) => {\n return {\n id: route.params.id,\n editing:\n route.params.id &&\n route.params.mode.toLowerCase().trim() === \"edit\",\n };\n },\n },\n (opts: { id: Guid; editing: boolean }) => ({\n id: opts.id.value,\n mode: opts.editing ? \"edit\" : \"view\",\n })\n ),\n editPageList: builder.route({\n url: \"/gallery/editpage\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/platformSingleList\"\n ),\n }),\n editPageCreate: builder.route({\n url: \"/gallery/editpage/create\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/platformEditPage\"\n ),\n componentProps: (route) => ({\n editing: true,\n }),\n }),\n buttonBarPlayground: builder.route({\n url: \"/gallery/buttonbar\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/ButtonBarPlayground.vue\"\n ),\n }),\n platformFlowForm: builder.route({\n url: \"/gallery/flowform\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/platformFlowForm\"\n ),\n }),\n logging: builder.route({\n url: \"/gallery/logging\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/Logging.vue\"\n ),\n }),\n forms: builder.route({\n url: \"/gallery/forms\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"gallery\" */ \"@/components/pages/gallery/forms/GalleryFormParent.vue\"\n ),\n }),\n};\n\nexport const buildGalleryMenuItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n translationKey: keys.navigation_gallery_group.value,\n icon: \"web\",\n requiredFeatureFlag: EnumFeatureFlag.showGallery,\n subMenus: [\n MenuItem.forRoute(\"Typography\", galleryRoutes.typography),\n MenuItem.forRoute(\"Controls\", galleryRoutes.controls),\n MenuItem.forRoute(\"Single Controls\", galleryRoutes.singleControls),\n MenuItem.forRoute(\"Production\", galleryRoutes.production),\n MenuItem.forRoute(\"Grids\", galleryRoutes.grids),\n MenuItem.forRoute(\"Large Grid\", galleryRoutes.largeGrid),\n MenuItem.forRoute(\"Geocode\", galleryRoutes.geocode),\n MenuItem.forRoute(\"Maps\", galleryRoutes.maps),\n MenuItem.forRoute(\"Page Layout\", galleryRoutes.pageLayout),\n MenuItem.forRoute(\"Validation\", galleryRoutes.validation),\n MenuItem.forRoute(\"Tableau Embedded\", galleryRoutes.tableau),\n MenuItem.forRoute(\"Timeline\", galleryRoutes.timeline),\n MenuItem.forRoute(\"Pipeline\", galleryRoutes.pipeline),\n MenuItem.forRoute(\"Error Tests\", galleryRoutes.errorTests),\n MenuItem.forRoute(\"Platform List\", galleryRoutes.platformSingleList),\n MenuItem.forRoute(\"Edit Page\", galleryRoutes.editPage),\n MenuItem.forRoute(\"Edit Page List\", galleryRoutes.editPageList),\n MenuItem.forRoute(\"Edit Page Create\", galleryRoutes.editPageCreate),\n MenuItem.forRoute(\"Button Bar\", galleryRoutes.buttonBarPlayground),\n MenuItem.forRoute(\"Platform Flow Form\", galleryRoutes.platformFlowForm),\n MenuItem.forRoute(\"Logging\", galleryRoutes.logging),\n MenuItem.forRoute(\"Forms\", galleryRoutes.forms),\n ],\n }),\n];\n\n//export const buildGalleryMenuItems: () => MenuItem[] = () => [];\n\n/*export const galleryMenu = {\n root: \"navigation_gallery_group\",\n typography: \"typography\",\n controls: \"controls\",\n singleControls: \"singleControls\",\n production: \"production_gallery\",\n grids: \"grids\",\n viewGrids: (): Location => ({\n name: galleryMenu.grids,\n }),\n largeGrid: \"large_grid\",\n geocode: \"geocode\",\n maps: \"maps\",\n pageLayout: \"page_layout\",\n async: \"async\",\n validation: \"validation\",\n timeline: \"timeline\",\n pipeline: \"pipeline\",\n dataProviders: \"data_providers\",\n tableauEmbedded: \"tableau_embedded\",\n errorTests: \"error_tests\",\n platformSingleList: \"platformSingleList\",\n editPage: \"edit_page\",\n editPageList: \"edit_page_list\",\n editPageCreate: \"edit_page_create\",\n galleryCreateEntity: (): Location => ({\n name: galleryMenu.editPageCreate,\n }),\n galleryEditEntity: (id: Guid, isEditing: boolean): Location => ({\n name: galleryMenu.editPage,\n params: {\n id: id.toString(),\n mode: isEditing ? \"edit\" : \"view\",\n },\n }),\n galleryListEntity: (): Location => ({\n name: galleryMenu.editPageList,\n }),\n buttonBarPlayground: \"buttonBarPlayground\",\n platformFlowForm: \"platformFlowForm\",\n logging: \"logging\",\n forms: \"forms\",\n};\n*/\n","import { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { MenuItem } from \"@/app/ui/navigation/types\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\n\nexport const distributionAppMenu = {\n distributionApp: \"distribution_app\",\n};\n\nexport const buildDistributionAppItems: () => MenuItem[] = () => [\n MenuItem.fromOpts({\n name: distributionAppMenu.distributionApp,\n icon: \"smartphone\",\n url: \"/distributionapp/\",\n\n // Router will redirect to the correct page, but we need to provide an empty component for\n // the navigation logic to show the button, as we hide anything which has no\n // visible children or a viewable component\n view: async () => ({}),\n\n requiredUserPermissions: [EnumUserPermission.distributionApp],\n\n visible: () =>\n hasPermissionsUsingUserStore([\n EnumUserPermission.menuDistributionAppView,\n ]),\n }),\n];\n","import { EmailVerificationCallbackSignInQueryStringName } from \"@/components/pages/account/composables/authentication\";\nimport { RouteBuilder } from \"@/app/ui/navigation/routeBuilder\";\n\nexport type SignInQueryOpts = {\n support?: string;\n redirect?: string;\n token?: string | (string | null)[];\n};\n\nconst builder = new RouteBuilder(\"Account_\");\nexport const accountRoutes = {\n signIn: builder.route({\n url: \"/signin\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"account\" */ \"@/components/pages/account/LoginPage.vue\"\n ),\n componentProps: {\n isSignIn: true,\n },\n preSession: true,\n }),\n signUp: builder.route({\n url: \"/signup\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"account\" */ \"@/components/pages/account/LoginPage.vue\"\n ),\n componentProps: {\n isSignIn: false,\n },\n preSession: true,\n }),\n firebaseActionRedirector: builder.route({\n url: \"/account/actions\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"account\" */ \"@/components/pages/account/FirebaseActionRedirector.vue\"\n ),\n componentProps: (route) => ({\n isSignIn: route.params.isSignIn !== undefined,\n }),\n preSession: true,\n }),\n verifyEmail: builder.routeWithParams(\n {\n url: \"/account/verifyemail\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"account\" */ \"@/components/pages/account/VerifyEmail.vue\"\n ),\n componentProps: (route) => ({\n isSignIn: route.params.isSignIn !== undefined,\n }),\n preSession: true,\n },\n (isSignIn: boolean) => ({ isSignIn: isSignIn.toString() })\n ),\n verifiedEmail: builder.route({\n url: \"/account/verifiedemail\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"account\" */ \"@/components/pages/account/VerifiedEmail.vue\"\n ),\n componentProps: (route) => ({\n // The callback url should contain a clue to whether this is an email verification straight after sign in (rather than create).\n isSignIn: Object.keys(route.query).includes(\n EmailVerificationCallbackSignInQueryStringName\n ),\n }),\n preSession: true,\n }),\n tenantGroupSelector: builder.routeWithParams(\n {\n url: \"/account/selectcompany\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"account\" */ \"@/components/pages/account/TenantGroupSelector.vue\"\n ),\n componentProps: (route) => {\n return {\n isSignIn: route.params.isSignIn?.toString()?.toLowerCase() === \"true\",\n isPrefilled:\n route.params.isPrefilled?.toString()?.toLowerCase() === \"true\",\n redirect: route.params.redirect?.toString()?.toLowerCase(),\n countryCode: route.params.countryCode,\n fullName: route.params.fullName,\n };\n },\n preSession: true,\n },\n (\n isSignIn: boolean,\n isPrefilled: boolean = false,\n redirect: string = \"\",\n countryCode: string = \"\",\n fullName: string = \"\"\n ) => {\n return {\n isSignIn: isSignIn.toString(),\n isPrefilled: isPrefilled.toString(),\n redirect: redirect,\n countryCode,\n fullName,\n };\n }\n ),\n createTenantGroup: builder.routeWithParams(\n {\n url: \"/account/create\",\n view: (): Promise =>\n import(\n /* webpackChunkName: \"account\" */ \"@/components/pages/account/CreateTenantGroup.vue\"\n ),\n componentProps: (route) => ({\n isPrefilled:\n route.params.isPrefilled?.toString()?.toLocaleLowerCase() === \"true\",\n countryCode: route.params.countryCode,\n fullName: route.params.fullName,\n }),\n preSession: true,\n },\n (opts?: {\n isPrefilled?: boolean;\n countryCode?: string;\n fullName?: string;\n }) => ({\n isPrefilled: opts?.isPrefilled?.toString() ?? \"\",\n countryCode: opts?.countryCode ?? \"\",\n fullName: opts?.fullName ?? \"\",\n })\n ),\n};\n\nexport const signInWithQuery = (query: SignInQueryOpts) => ({\n name: accountRoutes.signIn.name,\n query,\n});\n","import { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { MenuItem } from \"@/app/ui/navigation/types\";\nimport type { Location } from \"vue-router\";\nimport { parseEnumArrayQuery } from \"@/app/ui/navigation/queryHelpers\";\n\nexport const unauthorisedPath = \"/unauthorised\" as const;\n\nexport const unauthorisedMenu = {\n landing: \"unauthorised\",\n landingLocation: (opts: {\n requiredPermissions: EnumUserPermission[];\n }): Location => ({\n name: unauthorisedMenu.landing,\n query: {\n requiredPermissions: opts.requiredPermissions.map((permission) =>\n permission.key.toString()\n ),\n },\n path: unauthorisedPath,\n }),\n};\n\nexport const buildUnauthorisedItems: () => MenuItem[] = () => [\n MenuItem.fromOpts({\n name: unauthorisedMenu.landing,\n url: unauthorisedPath,\n view: (): Promise =>\n import(/* webpackChunkName */ \"@/components/pages/Unauthorised.vue\"),\n visible: false,\n componentProps: (route) => ({\n requiredPermissions: parseEnumArrayQuery(\n route.query.requiredPermissions,\n EnumUserPermission\n ),\n }),\n }),\n];\n","import { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { MenuItem } from \"@/app/ui/navigation/types\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\n\nexport const multiTenantMenu = {\n root: \"navigation_multi_tenant_group\",\n products_in_stock: \"products_in_stock\",\n};\n\nexport const buildMultiTenantMenuItems: () => MenuItem[] = () => [\n MenuItem.forBranch({\n name: multiTenantMenu.root,\n icon: \"share\",\n visible: () =>\n hasPermissionsUsingUserStore([EnumUserPermission.menuMultiTenantView]),\n subMenus: [\n MenuItem.fromOpts({\n name: multiTenantMenu.products_in_stock,\n url: \"/multi-tenant/products-in-stock\",\n breadcrumbParentName: multiTenantMenu.root,\n view: (): Promise =>\n import(\n /* webpackChunkName: \"multi-tenant\" */ \"@/components/pages/multi-tenant/MultiTenantProductsInStockPage.vue\"\n ),\n }),\n ],\n requiredUserPermissions: [EnumUserPermission.multiTenant],\n }),\n];\n","import type { IRouteItem, MenuItem } from \"@/app/ui/navigation/types\";\nimport { salesMenu, buildSalesMenuItems } from \"@/app/ui/navigation/salesMenu\";\nimport {\n contactsMenu,\n buildContactsMenuItems,\n} from \"@/app/ui/navigation/contactsMenu\";\nimport { stockMenu, buildStockMenuItems } from \"@/app/ui/navigation/stockMenu\";\nimport {\n distributionMenu,\n buildDistributionMenuItems,\n} from \"@/app/ui/navigation/distributionMenu\";\nimport {\n productionMenu,\n buildProductionMenuItems,\n} from \"@/app/ui/navigation/productionMenu\";\nimport {\n buildPricingMenuItems,\n pricingRoutes,\n} from \"@/app/ui/navigation/pricingMenu\";\nimport {\n containerTrackingMenu,\n buildContainerTrackingMenuItems,\n} from \"@/app/ui/navigation/containerTrackingMenu\";\nimport { buildDutyMenuItems } from \"@/app/ui/navigation/dutyMenu\";\nimport {\n reportingMenu,\n buildReportingMenuItems,\n} from \"@/app/ui/navigation/reportingMenu\";\nimport {\n integrationsMenu,\n buildIntegrationsMenuItems,\n} from \"@/app/ui/navigation/integrationsMenu\";\nimport {\n administrationMenu,\n buildAdministrationMenuItems,\n} from \"@/app/ui/navigation/administrationMenu\";\nimport {\n buildSupportMenuItems,\n supportRoutes,\n} from \"@/app/ui/navigation/supportMenu\";\nimport {\n galleryRoutes,\n buildGalleryMenuItems,\n} from \"@/app/ui/navigation/galleryMenu\";\nimport { mainMenu, buildMainMenuItems } from \"@/app/ui/navigation/mainMenu\";\nimport {\n buildUllagesMenuItems,\n ullageRoutes,\n} from \"@/app/ui/navigation/ullagesMenu\";\nimport {\n distributionAppMenu,\n buildDistributionAppItems,\n} from \"./distributionAppMenu\";\nimport { accountRoutes } from \"@/app/ui/navigation/accountManagement\";\nimport { dutyMenuUk } from \"@/app/ui/navigation/dutyMenuUk\";\nimport { dutyMenuGerman } from \"@/app/ui/navigation/dutyMenuGerman\";\nimport { dutyMenuAustralian } from \"@/app/ui/navigation/dutyMenuAustralian\";\nimport {\n buildUnauthorisedItems,\n unauthorisedMenu,\n} from \"@/app/ui/navigation/unauthorisedMenu\";\nimport { batchMenu, buildBatchMenuItems } from \"@/app/ui/navigation/batchMenu\";\nimport {\n multiTenantMenu,\n buildMultiTenantMenuItems,\n} from \"@/app/ui/navigation/multiTenantMenu\";\n\nexport function buildMenuItems(): MenuItem[] {\n return [\n ...buildMainMenuItems(),\n ...buildSalesMenuItems(),\n ...buildContactsMenuItems(),\n ...buildStockMenuItems(),\n ...buildDistributionMenuItems(),\n ...buildProductionMenuItems(),\n ...buildBatchMenuItems(),\n ...buildUllagesMenuItems(),\n ...buildPricingMenuItems(),\n ...buildContainerTrackingMenuItems(),\n ...buildDutyMenuItems(),\n ...buildReportingMenuItems(),\n ...buildIntegrationsMenuItems(),\n ...buildAdministrationMenuItems(),\n ...buildMultiTenantMenuItems(),\n ...buildGalleryMenuItems(),\n ...buildSupportMenuItems(),\n ...buildDistributionAppItems(),\n ...buildUnauthorisedItems(),\n ];\n}\n\nexport function buildRouteItems(): IRouteItem[] {\n const fromOldMenus: IRouteItem[] = [\n ...buildMainMenuItems(),\n ...buildSalesMenuItems(),\n ...buildContactsMenuItems(),\n ...buildStockMenuItems(),\n ...buildDistributionMenuItems(),\n ...buildProductionMenuItems(),\n ...buildBatchMenuItems(),\n ...buildContainerTrackingMenuItems(),\n ...buildDutyMenuItems(),\n ...buildReportingMenuItems(),\n ...buildIntegrationsMenuItems(),\n ...buildAdministrationMenuItems(),\n ...buildMultiTenantMenuItems(),\n ...buildSupportMenuItems(),\n ...buildDistributionAppItems(),\n ...buildUnauthorisedItems(),\n ];\n\n // Because all the keys in Eg ullageRoutes are for IRouteItem\n // typescript knows that these all resolve to IRouteItem\n const fromRoutes = [\n accountRoutes,\n ullageRoutes,\n pricingRoutes,\n galleryRoutes,\n supportRoutes,\n ]\n .flatMap((x) => Object.entries(x))\n .map((kvp): IRouteItem => kvp[1]);\n\n return fromOldMenus.concat(fromRoutes);\n}\n\nexport const routes = {\n mainMenu,\n salesMenu,\n contactsMenu,\n stockMenu,\n distributionMenu,\n productionMenu,\n batchMenu,\n containerTrackingMenu,\n dutyMenuAustralian,\n dutyMenuGerman,\n dutyMenuUk,\n reportingMenu,\n integrationsMenu,\n administrationMenu,\n multiTenantMenu,\n distributionAppMenu,\n unauthorisedMenu,\n};\n","export default \"__VITE_ASSET__82b938b9__\"","\n\n\n","\n\n\n","import Vue, {\n defineComponent,\n toRef,\n watch,\n type Ref,\n type SetupContext,\n} from \"vue\";\nimport type { EmitFn } from \"vue/types/v3-setup-context\";\n\nexport const ReactiveDialog = defineComponent({\n model: {\n prop: \"visible\",\n event: \"input\",\n },\n props: {\n width: { type: [Number, String], default: 600, required: false },\n visible: { type: Boolean, required: false },\n },\n data() {\n return {\n savedFocus: null as HTMLElement | null,\n };\n },\n watch: {\n visible: {\n handler: function (val) {\n if (this.visible) {\n this.storeFocus();\n } else {\n this.setFocus();\n }\n },\n },\n },\n methods: {\n close() {\n this.$emit(\"input\", false);\n },\n open() {\n this.$emit(\"input\", true);\n },\n cancel() {\n this.$emit(\"cancel\");\n this.close();\n },\n accept(value?: any) {\n this.$emit(\"accept\", value);\n this.close();\n },\n storeFocus() {\n this.savedFocus = document.activeElement as HTMLElement;\n },\n setFocus() {\n Vue.nextTick(() => {\n if (this.savedFocus !== null) this.savedFocus.focus();\n this.savedFocus = null;\n });\n },\n },\n});\nexport const useReactiveDialogSetup = (\n visible: Ref,\n context: SetupContext // Defining emits gives type SetupContext<(\"a\"|\"b\"|\"c\")[]>, so allow for any.\n) => {\n return useReactiveDialogScriptSetup(\n visible,\n context.emit,\n toRef(context, \"attrs\")\n );\n};\n\nexport const useReactiveDialogScriptSetup = (\n visible: Ref,\n emit: EmitFn | DialogEvents, // Defining emits gives type EmitFn<(\"a\"|\"b\"|\"c\")[]>, so allow for any.\n reactiveAttrs?: Ref\n) => {\n let savedFocus: HTMLElement | null = null;\n\n let close = () => emit(\"input\", false);\n let storeFocus = () => (savedFocus = document.activeElement as HTMLElement);\n let setFocus = () => {\n Vue.nextTick(() => {\n savedFocus?.focus();\n savedFocus = null;\n });\n };\n\n watch(\n () => visible,\n (val) => {\n if (val) {\n storeFocus();\n } else {\n setFocus();\n }\n }\n );\n\n return {\n open: () => emit(\"input\", true),\n close,\n accept: (payload?: T) => {\n emit(\"accept\", payload);\n close();\n },\n cancel: () => {\n emit(\"cancel\");\n close();\n },\n storeFocus,\n setFocus,\n reactiveAttrs: reactiveAttrs,\n };\n};\n\n/**\n * To use imported types with `defineEmits()` and `defineProps()`, the\n * imported type must be an extension of another type which is defined\n * inside `\n\n\n","\n\n\n\n","\n\n\n","import { environment } from \"@/plugins/commonImports\";\nimport errorLoggerService from \"@/app/errors/errorLoggerService\";\nimport type { ComponentOptions } from \"vue\";\nimport type Vue from \"vue\";\nimport appStore from \"@/store/modules/appStore\";\n\n/**\n * Problems with errors being captured within an async function on a watcher, this is a currently known bug:\n * https://github.com/vuejs/vue/issues/10009\n */\nexport const errorCaptured: ComponentOptions[\"errorCaptured\"] = (\n e: Error,\n v: Vue,\n info: string\n) => {\n const vueErrorContext = [info, v?.$vnode?.tag ?? \"\"]\n .filter((x) => x)\n .join(\" -- \");\n appStore.showError(e, vueErrorContext);\n errorLoggerService.logError(\"Unhandled global error\", e, vueErrorContext);\n\n return environment.isDevelopment; // Suppress errors in production mode\n};\n","/* eslint-disable vue/one-component-per-file */\nimport Vue, { ref } from \"vue\";\nimport { i18n } from \"@/plugins/commonImports\";\nimport vuetify from \"@/plugins/vuetify\";\nimport type { ComponentPublicInstanceConstructor } from \"vue/types/v3-component-public-instance\";\nimport { errorCaptured } from \"@/plugins/vueErrorHandler\";\n\ntype ComponentProps = Omit<\n InstanceType[\"$props\"],\n \"value\"\n>;\n\nexport interface DialogResult {\n wasSuccessful: boolean;\n value: T | null;\n}\n\n/**\n * Mounts and displays a dialog - can be executed from any async handler.\n */\nexport function showModalDialog<\n T,\n D extends ComponentPublicInstanceConstructor,\n>(\n dialog: ComponentPublicInstanceConstructor,\n options: {\n props: ComponentProps;\n attrs?: Record;\n }\n): Promise> {\n const { props: propsData, attrs } = options;\n const showDialog = ref(true);\n\n const props: Record = {\n value: showDialog.value,\n visible: showDialog.value,\n ...propsData,\n };\n\n // Wrap our dialog component into a shim so we can correctly pass in props/attrs\n const shimCtor = Vue.extend({\n render: (h) =>\n h(dialog as any, {\n props,\n attrs,\n }),\n });\n\n // Bind in our vuetify, i18n and error capturing behaviours\n const shimComp = new shimCtor({\n vuetify,\n i18n,\n errorCaptured,\n });\n\n const mountEl = document.createElement(\"div\");\n document.getElementsByClassName(\"v-application\")[0].appendChild(mountEl);\n shimComp.$mount(mountEl);\n\n function close() {\n showDialog.value = false;\n shimComp.$destroy();\n shimComp.$el.remove();\n }\n\n return new Promise>((resolve, _) => {\n // Listen to first child events as we have now wrapped our dialog in a shim\n shimComp.$children[0].$on(\"accept\", async (value: any) => {\n close();\n resolve({\n wasSuccessful: true,\n value: value,\n });\n });\n\n shimComp.$children[0].$on(\"cancel\", () => {\n close();\n resolve({\n wasSuccessful: false,\n value: null,\n });\n });\n });\n}\n","\n\n\n\n\n","\n\n\n","import BmConfirmationDialog from \"@/components/dialogs/BmConfirmationDialog.vue\";\nimport type { VueConstructor } from \"vue\";\nimport Vue from \"vue\";\nimport { BrewManError } from \"@/app/errors\";\nimport { useRoot } from \"@/components/composables/root\";\nimport BmInformationDialog from \"@/components/dialogs/BmInformationDialog.vue\";\nimport type {\n BmConfirmationDialogOptions,\n BmInformationDialogOptions,\n} from \"@/components/dialogs/DialogTypes\";\nimport type { ComponentPublicInstanceConstructor } from \"vue/types/v3-component-public-instance\";\nimport { showModalDialog } from \"@/components/platform/common/showModalDialog\";\nimport BmUnauthorisedDialog from \"@/components/dialogs/BmUnauthorisedDialog.vue\";\nimport type { UnauthorisedComponentProps } from \"@/components/pages/UnauthorisedComponent.vue\";\n\nexport function showConfirmationDialog(\n title: string,\n message: string,\n options?: Partial\n): Promise {\n return attachAndDisplay(\n \"ConfirmationDialog\",\n BmConfirmationDialog,\n title,\n message,\n options\n );\n}\n\nexport function showInformationDialog(\n title: string,\n message: string,\n options?: Partial\n): Promise {\n return attachAndDisplay(\n \"InformationDialog\",\n BmInformationDialog,\n title,\n message,\n options\n );\n}\n\nexport async function showUnauthorisedDialog(opts: UnauthorisedComponentProps) {\n return await showModalDialog(\n BmUnauthorisedDialog,\n {\n props: {\n ...opts,\n },\n }\n );\n}\n\nfunction attachAndDisplay(\n componentName: string,\n component: VueConstructor | ComponentPublicInstanceConstructor,\n title: string,\n message: string,\n options?: Partial\n) {\n const currentInstance = useRoot();\n let dialogInstance = currentInstance.$children.find(\n (c) => c.$options.name === componentName\n );\n\n if (!dialogInstance) {\n const confirmationDialogCtor = Vue.extend(component);\n dialogInstance = new confirmationDialogCtor({\n name: componentName,\n parent: currentInstance,\n });\n dialogInstance.$mount();\n currentInstance.$children.push(dialogInstance);\n }\n\n if (!dialogInstance) {\n throw new BrewManError(\"Could not attach dialog\");\n }\n\n return (dialogInstance as any).open(title, message, options);\n}\n","import Vue, { computed, reactive, ref, toRef } from \"vue\";\nimport type { RawLocation, Route, RouterOptions } from \"vue-router\";\nimport Router from \"vue-router\";\nimport { buildRouteItems } from \"@/app/ui/navigation/menuItems\";\nimport type { IRouteItem } from \"@/app/ui/navigation/types\";\nimport NotFound from \"@/components/pages/NotFound.vue\";\nimport userStore from \"@/store/modules/userStore\";\nimport { BrewManError } from \"@/app/errors\";\nimport { useI18n } from \"@/plugins/i18n\";\nimport versionManager from \"@/store/modules/versionManager\";\nimport { signInWithQuery } from \"@/app/ui/navigation/accountManagement\";\nimport type {\n Dictionary,\n Location,\n RouteConfig,\n} from \"vue-router/types/router\";\nimport type { EnumUserPermission } from \"@/app/services/generated/enums/enumUserPermission.generated\";\nimport { unauthorisedMenu } from \"@/app/ui/navigation/unauthorisedMenu\";\nimport { showUnauthorisedDialog } from \"@/components/composables/promptDialogs\";\nimport { hasPermissionsUsingUserStore } from \"@/components/pages/administration/user_roles/UserAccessHandler\";\nimport { isNotNullOrUndefined } from \"@/app/apiutils\";\nimport eventShipper from \"@/app/eventlogging/eventShipper\";\n\nVue.use(Router);\n\nexport const pageCounter = ref(0);\nexport const query = ref>();\n\nconst { $t } = useI18n();\n\nconst routerOptions: RouterOptions = {\n mode: \"history\",\n};\n\n// Make the router reactive so we can detect updates to 'currentRoute'\n// @ts-ignore\nconst router = reactive(new Router(routerOptions)) as Router;\n\nexport const configureRouterForBm = () => {\n const routes: RouteConfig[] = [\n { path: \"/\", redirect: \"/home\" },\n {\n name: \"distributionapp_redirect\",\n path: \"/distributionapp\",\n beforeEnter: () => {\n // If the window is already open, just open it.\n const distributionAppWindow = window.open(\"\", \"distributionapp\");\n if (!distributionAppWindow) {\n // Handle has failed (window is closed or blocked).\n // allow the user to open the window manually.\n window.location.href = \"/distributionapp/\";\n } else if (\n distributionAppWindow.location.pathname !== \"/distributionapp/\"\n ) {\n // The tab is open, but not on the correct page.\n distributionAppWindow.location.href = \"/distributionapp/\";\n distributionAppWindow.focus();\n }\n },\n },\n // Fall-through 404\n { path: \"*\", name: \"not-found\", component: NotFound },\n ];\n\n // The routes for the menu items are added via the UI component.\n const routeAdder = (ri: IRouteItem): void => {\n // TODO - make url mandatory for routes once they are properly split from menus.\n if (ri.url) {\n routes.push({\n name: ri.childRoutes.some((r) => r.path === \"\") ? undefined : ri.name, // dont set a name if any of our child routes have a default path\n path: ri.url,\n component: ri.view,\n meta: {\n ...ri.routeMetadata,\n requiredUserPermissions: ri.requiredUserPermissions,\n },\n children: ri.childRoutes,\n props: ri.componentProps,\n redirect: ri.redirect,\n });\n }\n\n if (ri.subMenus) {\n ri.subMenus.forEach(routeAdder);\n }\n };\n\n buildRouteItems().forEach(routeAdder);\n\n for (const route of routes) {\n router.addRoute(route);\n }\n\n // This guard will ensure the router forwards to the signin page if the user is not logged in.\n router.beforeEach(async (to, from, next): Promise => {\n // Check to see if our view of the server version is consistent with the latest API calls\n // if not perform a full refresh.\n if (versionManager.requiresRefresh()) {\n location.href = to.fullPath;\n }\n\n // Check for logged in state.\n if (!to.meta?.preSession && to.query.token) {\n const token = to.query.token;\n delete to.query.token;\n\n if (to.name === null) {\n throw new BrewManError(\"Unexpected null route name\");\n }\n\n const ret = router.resolve({\n name: to.name,\n params: to.params,\n query: to.query,\n hash: to.hash,\n path: to.path,\n });\n\n next(\n signInWithQuery({\n redirect: ret.resolved.fullPath,\n token,\n })\n );\n return;\n }\n\n // Not authenticated, ask to sign in\n if (\n !to.meta?.preSession &&\n !userStore.isAuthenticatedWithSelectedTenant.value\n ) {\n userStore.logSessionState(\"route not authenticated\");\n await eventShipper.flush(2000);\n\n next(signInWithQuery({ redirect: to.fullPath }));\n return;\n }\n\n // For all matched routes (where this will include parent routes, where we have child route definitions)\n const requiredPermissions: EnumUserPermission[] = to.matched\n .flatMap(\n (matchedRoute): EnumUserPermission[] | undefined =>\n matchedRoute.meta.requiredUserPermissions\n )\n .filter(isNotNullOrUndefined);\n\n // If we have permissions that are required for the route\n if (requiredPermissions.length) {\n const userHasPermissions =\n hasPermissionsUsingUserStore(requiredPermissions);\n\n if (!userHasPermissions) {\n // We are coming from a URL that isn't within brewman, or go directly to the URL\n if (!from.matched.length) {\n next(\n unauthorisedMenu.landingLocation({\n requiredPermissions,\n })\n );\n return;\n }\n\n // Internal redirects should get caught here\n await showUnauthorisedDialog({ requiredPermissions });\n return;\n }\n }\n\n pageCounter.value++;\n next();\n });\n\n addCommonBmTpRouterAfterEach();\n useCommonBmTpRouterBackWithFallback();\n};\n\nexport default router;\n\nexport const addCommonBmTpRouterAfterEach = () => {\n router.afterEach((to: Route): any => {\n query.value = to.query;\n });\n};\n\nexport const useCommonBmTpRouterBackWithFallback = () => {\n /**\n * Will navigate to the previous page if it's within our application.\n * @param location to fallback to if we cannot go back safely.\n */\n router.backWithFallback = async (\n location: RawLocation = { path: \"/\" }\n ): Promise => {\n if (pageCounter.value > 1) {\n router.back();\n } else {\n return router.push(location);\n }\n };\n};\n\nexport const useRouter = () => {\n return {\n router,\n route: toRef(router, \"currentRoute\"),\n };\n};\n\nexport const useRouterQueryParams = (...items: T) => {\n type QueryParams = {\n [K in (typeof items)[number]]: string | undefined;\n };\n\n type ParamsToChange

= { [K in keyof P]?: string };\n\n const queryParams = computed(\n () =>\n Object.fromEntries(\n items.map((item) => [\n item,\n query.value ? (query.value[item] as string | undefined) : undefined,\n ])\n ) as QueryParams\n );\n\n async function updateQueryParams

(\n paramsToChange: ParamsToChange

\n ) {\n await router.push({\n path: router.currentRoute.fullPath,\n query: paramsToChange,\n });\n }\n\n return {\n queryParams,\n updateQueryParams,\n };\n};\n\nexport const pushRouteOrNewWindow = async (\n location: Location,\n event: {\n ctrlKey: boolean;\n metaKey: boolean;\n }\n) => {\n if (event.ctrlKey || event.metaKey) {\n window.open(router.resolve(location).href, \"_blank\");\n } else {\n await router.push(location);\n }\n};\n// Vue router does not support component hooks in setup for vue 2. For progress:\n// https://github.com/vuejs/composition-api/issues/49#issuecomment-701015268\n","import type BaseEnumType from \"@/app/services/baseEnumType\";\nimport type Guid from \"@/app/types/common/guid\";\nimport userStore from \"@/store/modules/userStore\";\nimport {\n createJsonParseReviver,\n createJsonStringifyReplacer,\n} from \"@/app/storageReplacerReviverUtils\";\nimport type { LocalDate } from \"@js-joda/core\";\nimport router from \"@/router/router\";\nimport { watch } from \"vue\";\n\nexport type BmUiStateTypes =\n | LocalDate[]\n | BaseEnumType[]\n | BaseEnumType\n | boolean\n | Guid[]\n | Guid\n | string\n | string[]\n | undefined;\n\nexport interface BmUiState {\n [key: string]: BmUiStateTypes | Readonly;\n}\n\nexport class BmUiStateRepository {\n public static load(key: string): Partial {\n const item =\n localStorage.getItem(\n BmUiStateRepository.calculateStorageKeyForRequest()\n ) ?? \"{}\";\n const storage = JSON.parse(item, createJsonParseReviver());\n return storage[key] ?? {};\n }\n\n public static save(key: string, state: T): void {\n const storage = JSON.parse(\n localStorage.getItem(\n BmUiStateRepository.calculateStorageKeyForRequest()\n ) ?? \"{}\"\n );\n storage[key] = state;\n localStorage.setItem(\n BmUiStateRepository.calculateStorageKeyForRequest(),\n JSON.stringify(storage, createJsonStringifyReplacer())\n );\n }\n\n public static preserve(\n key: string,\n extract: () => T,\n restore: (state: Partial) => void\n ) {\n watch(\n () => extract(),\n (newState) => BmUiStateRepository.save(key, newState)\n );\n restore(BmUiStateRepository.load(key));\n }\n\n private static calculateStorageKeyForRequest() {\n return `${userStore.state.user?.id.toString() ?? \"\"}-bmuistate`.replace(\n /^-/,\n \"\"\n );\n }\n\n public static getKeyForCurrentRoute() {\n const currentRouteName = router.currentRoute.name;\n if (!currentRouteName) {\n // eslint-disable-next-line no-console\n console.error(\n \"Key requested for current route, when no route is available.\"\n );\n return \"\";\n }\n\n return currentRouteName;\n }\n}\n","\n\n\n\n\n","\n\n\n\n\n","\n\n\n\n\n","\n\n\n\n\n","\n\n\n\n\n","\n\n\n","\n\n\n\n\n","\n\n\n\n\n","\n\n\n\n\n","\n\n\n\n\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': '\n\n\n","import type { Comparer } from \"@/components/controls/grid/BmGridData\";\nimport isEqual from \"lodash-es/isEqual\";\nimport userStore from \"@/store/modules/userStore\";\n\nexport const autoComparer: Comparer = (itemValueA: any, itemValueB: any) => {\n if (isEqual(itemValueA, itemValueB)) {\n return 0;\n }\n\n if (itemValueA === undefined) {\n return -1;\n }\n\n if (itemValueB === undefined) {\n return 1;\n }\n\n if (itemValueA === null) {\n return -1;\n }\n\n if (itemValueB === null) {\n return 1;\n }\n\n // Handler for items that implement a compareTo method (e.g. js-joda)\n if (itemValueA.compareTo && typeof itemValueA.compareTo === \"function\") {\n return itemValueA.compareTo(itemValueB);\n }\n\n // Resort to default handling (e.g. values / valueOf / toString)\n return itemValueA > itemValueB ? 1 : -1;\n};\n\nexport const alphanumericComparer: Comparer = (\n itemValueA: any,\n itemValueB: any\n) => {\n if (isEqual(itemValueA, itemValueB)) {\n return 0;\n }\n\n if (itemValueA === null || itemValueA === undefined) {\n return -1;\n }\n\n if (itemValueB === null || itemValueB === undefined) {\n return 1;\n }\n\n // See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/Collator/Collator#numeric\n // for description of numeric collation.\n // This sorts numeric portions of the strings as numbers.\n // Eg \"1\" < \"2\" < \"03\" < \"5\" < \"11\" < \"33\"\n // And \"3\" == \"03\"\n // And \"A1\" < \"A2\" < \"A3\" < \"A11\" < \"A33\"\n return itemValueA.localeCompare(\n itemValueB,\n userStore.state.userLanguageLocale,\n {\n sensitity: \"base\",\n numeric: true,\n }\n );\n};\n\nexport const indexedKeyComparer =\n (keys: string[], valueExtractor: (item: any) => string): Comparer =>\n (a: any, b: any) => {\n const aIndex = keys.indexOf(valueExtractor(a));\n const bIndex = keys.indexOf(valueExtractor(b));\n // Ignore if not found in the list\n if (aIndex === -1 || bIndex === -1) {\n return 0;\n }\n\n return aIndex - bIndex > 0 ? 1 : -1;\n };\n","import { tenantService } from \"@/app/services/extensions/tenantServiceExtended\";\nimport type { Matcher } from \"./BmGridData\";\n\nexport const stringMatcher: Matcher = (itemValue: any, search: string) => {\n return (\n itemValue &&\n itemValue.toString().toLowerCase().indexOf(search.toLowerCase()) !== -1\n );\n};\n\nexport const dateMatcher: Matcher = (itemValue: any, search: string) => {\n return (\n itemValue &&\n tenantService\n .formatDate(itemValue)\n .toLowerCase()\n .indexOf(search.toLowerCase()) !== -1\n );\n};\n","/**\n * Aggregator that looks to see if all grouped item values are the same and returns that value.\n */\nexport function allTheSameAggregator(itemValues: any[]): any {\n return itemValues.every((itemValue) => itemValue === itemValues[0])\n ? itemValues[0]\n : \"\";\n}\n\n/**\n * Aggregator that sums the values. Unparsable values will default to 0.\n */\nexport function summingAggregator(itemValues: any[]): any {\n if (!itemValues.length) {\n return 0;\n }\n\n return itemValues.reduce(\n (currentSum, itemValue) => currentSum + Number(itemValue) || 0,\n 0\n );\n}\n","import Vue from \"vue\";\nimport Guid from \"@/app/types/common/guid\";\n\nexport interface BmGridColumnSortState {\n columnKey: string;\n descending?: boolean;\n}\n\nexport interface BmGridExportEvent {\n filename: string;\n fileTitle: string;\n stateId: string;\n format: \"csv\" | \"pdf\";\n}\n\nexport class BmGridState {\n // Whether the grid should use the default state. Set this to true to reset the\n // grid state back to the default grid state as defined by the column definitions.\n useGridDefault: boolean = false;\n\n // Ranked array of sort criteria to apply.\n sortBy: BmGridColumnSortState[] = [];\n\n // Ranked array of groupings to apply.\n groupBy: string[] = [];\n\n // The state of the applied column filters\n columnFilters: { [columnKey: string]: any } = {};\n\n removedColumnKeys: string[] = [];\n\n columnOrder: string[] = [];\n\n gridSearchFilter: string = \"\";\n\n stateId: string;\n\n columnPixelWidthMap = new Map();\n\n public constructor(state?: Partial) {\n if (!state) {\n this.useGridDefault = true;\n } else {\n Object.assign(this, state || {});\n }\n this.stateId = state?.stateId || Guid.create().toString();\n }\n\n /**\n * Resets the grid state to indicate that the grid should use the default (as\n * defined by the column definitions).\n */\n public reset() {\n this.sortBy = [];\n this.groupBy = [];\n this.columnFilters = {};\n this.removedColumnKeys = [];\n this.columnOrder = [];\n this.gridSearchFilter = \"\";\n this.useGridDefault = true;\n this.columnPixelWidthMap = new Map();\n }\n\n public deleteFilter(key: string) {\n Vue.delete(this.columnFilters, key);\n }\n\n /**\n * Applies a new column sort to the existing sort state. I have borrowed this logic from\n * ag-grid (ascend, descend, remove + stacking). https://www.ag-grid.com/\n *\n * @param columnKey The column key being sorted\n * @param stack Whether to stack this on to the existing sort state or not.\n */\n applyColumnSort(columnKey: string, stack: boolean = false): void {\n const sortByIndex = this.sortBy.findIndex(\n (sortBy) => sortBy.columnKey === columnKey\n );\n\n if (sortByIndex !== -1) {\n if (!this.sortBy[sortByIndex]?.descending) {\n // adjust descending state\n Vue.set(this.sortBy[sortByIndex], \"descending\", true);\n if (!stack) {\n this.sortBy = [this.sortBy[sortByIndex]];\n }\n } else {\n // add new sort state\n if (stack) {\n this.sortBy.splice(sortByIndex, 1); // remove stacked item\n } else {\n this.sortBy = [];\n }\n }\n } else {\n // adding new\n if (stack) {\n this.sortBy.push({ columnKey });\n } else {\n this.sortBy = [{ columnKey }];\n }\n }\n }\n\n applyExternalSorting(sortStatus: BmGridColumnSortState[]): void {\n this.sortBy = sortStatus;\n }\n\n applyColumnOrder(columnOrder: string[]) {\n this.columnOrder = columnOrder;\n }\n\n setColumnPixelWidth(key: string, pixels: number) {\n this.columnPixelWidthMap.set(key, pixels);\n }\n}\n","import { BmGridState } from \"@/components/controls/grid/state/BmGridState\";\nimport userStore from \"@/store/modules/userStore\";\nimport router from \"@/router/router\";\nimport Vue from \"vue\";\nimport {\n createJsonParseReviver,\n createJsonStringifyReplacer,\n} from \"@/app/storageReplacerReviverUtils\";\n\ninterface IBmGridStateStorage {\n [key: string]: BmGridState;\n}\n\n/**\n * A repository of grid states loaded from a user isolated storage bucket.\n *\n * It is intended that the state objects are passed as reference so when the store is saved the changes are persisted.\n */\nclass BmGridStateRepository {\n private storage: IBmGridStateStorage = {};\n private activeStorageKey: string | null = null;\n\n private loadStorageBucket(newStorageKey: string): void {\n this.save();\n let rawObj = JSON.parse(\n localStorage.getItem(newStorageKey) ?? \"{}\",\n createJsonParseReviver()\n ) as IBmGridStateStorage;\n this.storage = Object.fromEntries(\n Object.entries(rawObj).map(([key, entry]) => {\n return [key, new BmGridState(entry)]; // newing up here to convert plain deserialised data object into a class with methods etc.\n })\n );\n this.activeStorageKey = newStorageKey;\n }\n\n public save() {\n if (this.activeStorageKey) {\n localStorage.setItem(\n this.activeStorageKey,\n JSON.stringify(this.storage, createJsonStringifyReplacer())\n );\n }\n }\n\n private static calculateStorageKeyForRequest() {\n return `${\n userStore.state.user?.id.toString() ?? \"\"\n }-bmgridstates-v2`.replace(/^-/, \"\");\n }\n\n /**\n * Loads a grid state keyed from the current route name. Useful if only one grid is expected on the current page (e.g. list pages)\n */\n public getFromCurrentRoute(defaultState?: Partial) {\n const currentRouteName = router.currentRoute.name;\n if (!currentRouteName) {\n // eslint-disable-next-line no-console\n console.error(\n \"Grid state requested for current route, when no route is available.\"\n );\n return this.getEphemeral(defaultState);\n }\n\n return this.getFromKey(currentRouteName, defaultState);\n }\n\n /**\n * Loads a grid state by a user specified key.\n */\n public getFromKey(\n persistenceKey: string,\n defaultState?: Partial\n ): BmGridState {\n // First ensure the correct storage bucket is loaded\n const storageKey = BmGridStateRepository.calculateStorageKeyForRequest();\n if (this.activeStorageKey !== storageKey) {\n // If not.. load it\n this.loadStorageBucket(storageKey);\n }\n\n // Now see if we have state for it, and create it if not.\n let state = this.storage[persistenceKey];\n if (!state) {\n state = new BmGridState(defaultState);\n this.storage[persistenceKey] = state;\n }\n\n // Clear any grid search filters defined in the cache.\n state.gridSearchFilter = \"\";\n\n return Vue.observable(state);\n }\n\n /**\n * Get ephemeral state (not persisted).\n */\n public getEphemeral(defaultState?: Partial) {\n return Vue.observable(new BmGridState(defaultState));\n }\n}\n\nexport default new BmGridStateRepository();\n","import groupBy from \"lodash-es/groupBy\";\nimport type {\n Component as VueComponent,\n CreateElement,\n VNode,\n VueConstructor,\n PropType,\n} from \"vue\";\nimport { defineComponent } from \"vue\";\nimport DataCellText from \"@/components/controls/grid/renderers/DataCellText.vue\";\nimport { autoComparer } from \"@/components/controls/grid/BmGridComparers\";\nimport { stringMatcher } from \"@/components/controls/grid/BmGridMatchers\";\nimport { allTheSameAggregator } from \"@/components/controls/grid/BmGridAggregators\";\nimport type { BmEnumType } from \"@/app/services/baseEnumType\";\nimport type BaseEnumType from \"@/app/services/baseEnumType\";\nimport { BmGridState } from \"@/components/controls/grid/state/BmGridState\";\nimport BmGridStateRepository from \"@/components/controls/grid/state/BmGridStateRepository\";\nimport type { FilterFunc } from \"@/components/controls/grid/columnfilters/ColumnFilters\";\nimport { cloneDeep, isEqual } from \"lodash-es\";\nimport eventLogger from \"@/app/eventlogging/eventLogger\";\nimport { toMap } from \"@/app/apiutils\";\nimport type { RawLocation } from \"vue-router\";\n\nexport * from \"@/components/controls/grid/state/BmGridState\";\n\nexport type Comparer = (itemValueA: any, itemValueB: any) => 1 | 0 | -1;\nexport type Matcher = (itemValue: any, search: string) => boolean;\nexport type ColumnAlignment = \"start\" | \"center\" | \"end\";\nexport type Renderer = (\n h: CreateElement,\n value: any,\n item: any,\n context: Renderable\n) => VNode;\nexport type ColumnFooterRenderer = (h: CreateElement) => VNode;\nexport type GroupSummaryValueExtractor = (\n itemValues: any[],\n groupRowValue?: any,\n parentGroupValues?: string[]\n) => any;\nexport type ColumnFilter = {\n /**\n * Component to render the controls for the filter. Will set properties 'gridState' and 'columnKey'.\n */\n columnFilterComponent: VueConstructor;\n\n /**\n * Create a filter function from a given filterState\n */\n buildApply: (filterState: any) => FilterFunc;\n};\n\n/**\n * Function to transform a vue component with properties matching the renderer function arguments.\n * @param component A vue component.\n */\nexport function componentToRenderer(\n component: VueConstructor | VueComponent\n): Renderer {\n return (\n h: CreateElement,\n value: any,\n item: any,\n context: Renderable\n ): VNode =>\n h(\n component,\n {\n attrs: { value: value, item: item, context: context },\n },\n []\n );\n}\n\nexport function getGroupRowKey(\n columnId: string,\n groupRowValue: string,\n parentGroupValues: string[] = []\n): string {\n // If any are not strings throw an error. Parent group values should already have been checked.\n if (typeof groupRowValue !== \"string\" || typeof columnId !== \"string\") {\n eventLogger.logEvent(\"group-row-key-invalid\", {\n columnId,\n groupRowValue,\n });\n }\n\n return [columnId, ...parentGroupValues, groupRowValue].join(\"-\");\n}\n\nexport interface SortableAndSearchable {\n comparer: Comparer;\n matcher: Matcher;\n columnFilter?: ColumnFilter;\n}\n\n// Formatter for changing the extracted value. For more complex cases you may need to change the renderer.\nexport interface Formattable {\n formatter: (value: any, item: any) => any;\n csvformatter: (\n value: any,\n item: any,\n stringFormatter: (s: string) => string\n ) => string;\n}\n\nexport interface RowAction {\n translation: (item: any) => string;\n onClick?: (item: any) => void;\n route?: ((item: any) => RawLocation | undefined) | RawLocation;\n isActive: (item: any) => boolean;\n}\n\nexport interface RendererMetadata {\n actions?: (RowAction | ((item: any) => RowAction[]))[];\n isAgTruncated?: any;\n textTruncationOptions?: any;\n suffixExtractor?: any;\n prefixExtractor?: any;\n iconSuffixExtractor?: any;\n locationExtractor?: any;\n newTab?: any;\n externalLinkExtractor?: any;\n emailExtractor?: any;\n phoneExtractor?: any;\n editRenderer?: any;\n control?: any;\n}\n\nexport interface Renderable {\n cardColumnSpan: number;\n align: ColumnAlignment;\n renderer: Renderer;\n rendererMetadata: RendererMetadata;\n}\n\ntype GridStateMigrator = (opts: {\n gridState: BmGridState;\n columnKey: string;\n columnConfiguration: BmGridColumnConfiguration;\n}) => void;\n\n/**\n * Ensure columns that are marked as not removable are not hidden\n */\nconst removableColumnMigrator: GridStateMigrator = ({\n gridState,\n columnKey,\n columnConfiguration,\n}) => {\n if (!columnConfiguration.removable) {\n gridState.removedColumnKeys = gridState.removedColumnKeys.filter(\n (key) => key !== columnKey\n );\n }\n};\n\nconst gridStateMigrators: GridStateMigrator[] = [removableColumnMigrator];\n\nexport class BmGridColumnConfiguration\n implements SortableAndSearchable, Formattable, Renderable\n{\n // The title to display on the column header row\n public headingText: string;\n\n // Extracts the itemValue from the item.\n public extractor: (item: any) => any;\n public classExtractor: (item: any) => string = () => \"\";\n\n // Formatter. Note item will be undefined if formatting an aggregate column\n public formatter: (value: any, item: any | undefined) => any = (item) => item;\n\n // CSV Formatter - default to the same as the normal Formatter but with some string safety\n public csvformatter: (\n value: any,\n item: any | undefined,\n stringFormatter: (s: string) => string\n ) => string = function (\n this: BmGridColumnConfiguration,\n value: any,\n item: any,\n stringFormatter: (s: string) => string\n ) {\n const ob = this.formatter(value, item);\n if (ob instanceof String || typeof ob == \"string\") {\n return stringFormatter(ob as string);\n }\n return ob?.toString() ?? \"\";\n };\n\n // width?\n public shrink: boolean = false;\n\n // Renderable\n public cardColumnSpan: number = 1;\n public align: ColumnAlignment = \"start\";\n public renderer: Renderer = componentToRenderer(DataCellText);\n public rendererMetadata: RendererMetadata = {}; // supplemental data to send to the display component\n\n // Footer\n public footer: ColumnFooterRenderer | null = null;\n\n // Sort and Search\n public comparer: Comparer = autoComparer;\n public matcher: Matcher = stringMatcher;\n public columnFilter?: ColumnFilter;\n public enumType?: BmEnumType;\n public enumFilter?: (item: BaseEnumType) => boolean;\n\n // capability\n public sortableAndFilterable: boolean = true;\n public groupable: boolean = true;\n public removable: boolean = true;\n\n // Grid Controls\n public showInGridControls: boolean = true;\n\n public extractAndFormat(item: any) {\n return this.formatter(this.extractor(item), item);\n }\n\n public constructor(\n headingText: string,\n extractor: (item: any) => any,\n options: Partial\n ) {\n this.headingText = headingText;\n this.extractor = extractor;\n Object.assign(this, options);\n }\n}\n\nexport type SummaryExtractor = (\n item: any,\n cols: BmGridColumnConfigurations\n) => any;\n\nexport enum SummaryPlacement {\n Column,\n}\n\nexport class BmGridSummaryConfiguration implements Renderable {\n public extractor: SummaryExtractor;\n public groupSummaryValueExtractor: GroupSummaryValueExtractor =\n allTheSameAggregator;\n public placement: SummaryPlacement = SummaryPlacement.Column;\n\n // The column to place the groupSummaryValueExtractor into if using Column placement\n public columnKey?: string;\n\n public cardColumnSpan: number = 1;\n public align: ColumnAlignment = \"start\";\n public renderer: Renderer = componentToRenderer(DataCellText);\n public rendererMetadata: any = {};\n\n public constructor(\n extractor: SummaryExtractor,\n groupSummaryValueExtractor: GroupSummaryValueExtractor,\n options: Partial\n ) {\n this.extractor = extractor;\n this.groupSummaryValueExtractor = groupSummaryValueExtractor;\n Object.assign(this, options);\n }\n}\n\nexport type BmGridColumnConfigurations = {\n [columnKey: string]: BmGridColumnConfiguration;\n};\n\nexport class BmGridConfiguration {\n public defaultGridState?: BmGridState;\n public columns: BmGridColumnConfigurations = {};\n public summaries: BmGridSummaryConfiguration[] = [];\n // TODO - Once itemKey is initialised in every use case make it mandatory and remove\n // itemKey as an option in BmGridData component props.\n public itemKey?: (item: any) => string;\n public title?: string;\n}\n\n// Internal Types\n\ntype RowType = \"content\" | \"group\";\nexport const isContentRow = (row?: Row): row is ContentRow =>\n row?.rowType === \"content\";\nexport const isRowGroup = (row?: Row): row is RowGroup =>\n row?.rowType === \"group\";\n\nexport interface Row {\n // internal state\n isSelected: boolean;\n isExpanded: boolean;\n isVisible: boolean;\n rowType: RowType;\n rowKey: string;\n dropBelow: boolean;\n}\n\nexport interface ContentRow extends Row {\n rowType: \"content\";\n item: T;\n}\n\nexport interface RowGroup extends Row {\n rowType: \"group\";\n\n // The key of the column this group is grouping on\n columnKey: string;\n\n // The value from the grouped column this is grouping\n columnValue: string;\n\n // child rows/groups\n children: Row[];\n\n // whether this group is a parent of other groups\n isParentOfGroups: boolean;\n\n // The aggregate values by column key\n aggregateValues: {\n [columnKey: string]: { value: any; summary: BmGridSummaryConfiguration };\n };\n}\n\n/**\n * The base component for the grid that is responsible for the data processing only.\n */\nexport default defineComponent({\n name: \"BmGridData\",\n model: {\n prop: \"selectedItemKeys\",\n event: \"update:selected-item-keys\",\n },\n props: {\n itemKey: {\n type: Function as PropType<(item: any) => string>,\n required: false,\n },\n /**\n * The current user modifiable state of the grid (sorting, grouping, filtering, etc). You can specify the initial\n * state of the grid, and also use this property to load/save state if desired.\n */\n gridState: {\n type: Object as PropType,\n default: () => BmGridStateRepository.getEphemeral(),\n },\n /**\n * The configuration (types, keys, etc.) of the columns in the grid and the default state (filters).\n */\n gridConfiguration: {\n type: Object as PropType,\n required: true,\n },\n /**\n * The array of items to display in the grid. The array is not modified by this grid.\n */\n items: {\n type: Array as PropType,\n required: true,\n },\n /**\n * Whether expandable rows are defaulted to expanded.\n */\n defaultExpandExpandable: {\n type: Boolean,\n default: false,\n },\n /**\n * Whether group rows are defaulted to expanded.\n */\n defaultExpandGroups: {\n type: Boolean,\n default: true,\n },\n /**\n * The plural noun of the items displayed in the grid.\n */\n itemNoun: {\n type: String,\n default: \"\",\n },\n selectedItemKeys: {\n type: Array as PropType,\n default: () => [],\n },\n expandedItemKeys: {\n type: Array as PropType,\n default: () => [],\n },\n // Only allows one row to be expanded (top-level)\n // will require expanded-item-keys.sync\n accordian: {\n type: Boolean,\n required: false,\n default: false,\n },\n rowSelectable: {\n type: Function as PropType<(item: any) => boolean>,\n default: (item: any) => true,\n },\n allowSort: {\n type: Boolean,\n required: false,\n default: true,\n },\n },\n data() {\n return {\n virtualGrid: [] as readonly Row[],\n gridStateInternal: new BmGridState() as BmGridState,\n disableReactiveRows: false as boolean,\n hasNonStringOrDuplicateKeys: false as boolean,\n };\n },\n computed: {\n hasGrouping(): boolean {\n return Object.keys(this.computedGroupedColumns).length > 0;\n },\n /**\n * The column definitions from the virtual grid. Rendering should be performed from the column data from this getter.\n * Only includes visisble (not removed) columns\n */\n visibleColumns(): BmGridColumnConfigurations {\n let toRet = {} as BmGridColumnConfigurations;\n\n Object.entries(this.gridConfiguration.columns)\n // remove grouped\n .filter(\n ([key]) =>\n Object.keys(this.computedGroupedColumns).indexOf(key) === -1\n )\n .filter(\n // remove \"removed\" columns\n ([key]) => !this.gridState.removedColumnKeys.some((g) => g === key)\n )\n .forEach(([key, col]) => (toRet[key] = col));\n return toRet;\n },\n /**\n * The column definitions from the virtual grid. Row filtering should be performed from these columns\n * Only includes columns with filters applied\n */\n filterableColumns(): BmGridColumnConfigurations {\n let toRet = {} as BmGridColumnConfigurations;\n\n Object.entries(this.gridConfiguration.columns)\n // remove grouped\n .filter(\n ([key]) =>\n Object.keys(this.computedGroupedColumns).indexOf(key) === -1\n )\n .filter(\n // Remove all columns that don't have filters\n ([key]) => this.gridState.columnFilters[key]\n )\n .forEach(([key, col]) => (toRet[key] = col));\n return toRet;\n },\n /**\n * Get the columns that are used in the groupings. The order of the keys defines the grouping level.\n */\n computedGroupedColumns(): BmGridColumnConfigurations {\n return Object.fromEntries(\n Object.entries(this.gridConfiguration.columns)\n .filter(([, value]) => value.groupable)\n .filter(([key]) => this.gridState?.groupBy.indexOf(key) !== -1)\n );\n },\n /**\n * Get the columns that are used for sorting. The order of the keys defines the sorting priority.\n * The returned columns have an augmented variable 'sortDescending' to indicate direction.\n */\n computedSortableColumns(): {\n [columnKey: string]: BmGridColumnConfiguration & {\n sortDescending?: boolean;\n };\n } {\n return Object.fromEntries(\n this.gridState.sortBy\n .map((colMatcher) => {\n const value = this.gridConfiguration.columns[colMatcher.columnKey];\n if (value === undefined) {\n /* eslint-disable no-console */\n console.error(\n `sort defined on column ${colMatcher.columnKey}, but column does not exist`\n );\n return null;\n }\n if (!value.sortableAndFilterable) {\n return null;\n }\n return [\n colMatcher.columnKey,\n Object.assign({ sortDescending: colMatcher?.descending }, value),\n ];\n })\n .filter((x) => x != null) as any[]\n );\n },\n currentRowsMapWithIndex() {\n return toMap(\n this.getFlattenedRows(this.virtualGrid).map(\n (row, idx) => [row, idx] as [Row, number]\n ),\n ([row]) => row.rowKey + row.rowType\n );\n },\n },\n created() {\n // Apply migrations to grid state\n gridStateMigrators.forEach((gridStateMigrator) =>\n Object.entries(this.gridConfiguration.columns).forEach(\n ([columnKey, columnConfiguration]) =>\n gridStateMigrator({\n gridState: this.gridState,\n columnKey,\n columnConfiguration,\n })\n )\n );\n\n this.gridStateInternal = cloneDeep(this.gridState);\n\n // Watch the grid state property and validate it before updating internal state.\n this.$watch(\"gridState\", this.updateGridState, {\n immediate: true,\n deep: true,\n });\n\n // Create a watcher than reloads the grid if the key properties change.\n [\"columns\", \"gridStateInternal\", \"selectedItemKeys\"].forEach((prop) =>\n this.$watch(prop, this.refreshVirtualGrid, { deep: true })\n );\n\n [\n \"defaultExpandExpandable\",\n \"defaultExpandGroups\",\n \"expandedItemKeys\",\n ].forEach((prop) =>\n this.$watch(prop, () => this.refreshVirtualGrid(false))\n );\n\n this.$watch(\n \"items\",\n (newItems: any[], oldItems: any[]) => {\n this.refreshVirtualGrid(true);\n this.checkItemsForDuplicateOrUndefinedKeys(newItems, oldItems);\n },\n { deep: true }\n );\n\n this.refreshVirtualGrid(false);\n },\n methods: {\n extractKey(item: any) {\n return (this.gridConfiguration.itemKey ?? this.itemKey)?.(item) ?? \"\";\n },\n\n /** Temporary solution to check for duplicate or undefined keys*/\n checkItemsForDuplicateOrUndefinedKeys(newItems: any[], oldItems: any[]) {\n if (\n oldItems.length !== 0 ||\n !newItems.length ||\n this.hasNonStringOrDuplicateKeys\n ) {\n return;\n }\n\n const uniqueKeys = new Set();\n let invalidKeyReason = \"\";\n\n const hasInvalidKeys = newItems.some((item) => {\n const key = this.extractKey(item);\n if (key === undefined) {\n invalidKeyReason = \"undefined\";\n return true;\n }\n if (typeof key !== \"string\") {\n invalidKeyReason = \"non_string\";\n return true;\n }\n if (uniqueKeys.has(key)) {\n invalidKeyReason = \"duplicate\";\n return true;\n }\n uniqueKeys.add(key);\n });\n\n if (hasInvalidKeys) {\n this.hasNonStringOrDuplicateKeys = true;\n eventLogger.logEvent(\"grid_keys\" + invalidKeyReason, {}); // Just log the event, need only context of the page\n }\n },\n setDisableReactiveRows(value: boolean) {\n this.disableReactiveRows = value;\n if (!value) {\n this.refreshVirtualGrid();\n }\n },\n toggleSelectedRow(row: Row | undefined) {\n let selectedItems = new Set(this.selectedItemKeys);\n\n if (row) {\n if (row.isSelected || !this.rowSelectable(row)) {\n selectedItems.delete(row?.rowKey);\n } else {\n selectedItems.add(row?.rowKey);\n }\n } else {\n // it was the header cell\n const isAllSelected = this.virtualGrid.every(\n (row) => row.isSelected || !this.rowSelectable(row)\n );\n\n if (isAllSelected) {\n const visibleSelectedRows = this.virtualGrid.filter((row) =>\n selectedItems.has(row.rowKey)\n );\n\n visibleSelectedRows.forEach((row) => {\n selectedItems.delete(row.rowKey);\n });\n } else {\n const visibleSelectableRows = this.virtualGrid.filter((row) =>\n this.rowSelectable(row)\n );\n\n visibleSelectableRows.forEach((row) => {\n selectedItems.add(row.rowKey);\n });\n }\n }\n\n this.$emit(\"update:selected-item-keys\", [...selectedItems.values()]);\n },\n /**\n * A flat view (ContentRow and RowGroup in a 2D array).\n */\n getFlattenedRows(rootNode: readonly Row[]): Row[] {\n const recursiveCrawler = (rows: readonly Row[]) => {\n let returnRows: Row[] = [];\n for (const row of rows) {\n returnRows.push(row);\n if (row.rowType === \"group\") {\n returnRows = returnRows.concat(\n recursiveCrawler((row as RowGroup).children)\n );\n }\n }\n\n return returnRows;\n };\n\n return recursiveCrawler(rootNode);\n },\n countGroupedRows() {\n if (Object.keys(this.computedGroupedColumns).length == 0) {\n return this.items.length;\n } else {\n const groupColumnKey = Object.keys(this.computedGroupedColumns)[0];\n const valueExtractor =\n this.gridConfiguration.columns[groupColumnKey].extractor;\n return new Set(this.items.map(valueExtractor)).size;\n }\n },\n /**\n * Recursive grouping function. Breaks the virtual grid down into their specified groups.\n */\n calculateRowGroups(\n rows: ContentRow[],\n groupIndex = 0,\n reapplyRowStates: boolean = true,\n parentGroupValues: string[] = []\n ): RowGroup[] {\n let groupRows = [];\n const groupColumnKey = Object.keys(this.computedGroupedColumns)[\n groupIndex\n ];\n const valueExtractor =\n this.gridConfiguration.columns[groupColumnKey].extractor;\n\n // @TODO: [BREW-4732] Grouping on a nullish value should resolve to a placeholder\n\n // This is a bit on a blunt instrument as it simply toStrings the extracted value in the item to determine the\n // groups. Ideally this should use the comparers on the columns - although performance will suffer.\n const groupByValue = groupBy(rows, (row) => valueExtractor(row.item));\n\n for (const entry of Object.entries(groupByValue)) {\n let childRows: Row[] | RowGroup[] = [];\n const childGroup = groupIndex === this.gridState.groupBy.length - 1;\n\n if (!childGroup) {\n childRows = this.calculateRowGroups(\n entry[1],\n groupIndex + 1,\n reapplyRowStates,\n [...parentGroupValues, entry[0]]\n );\n } else {\n childRows = entry[1];\n }\n\n const childItems = this.getFlattenedRows(childRows)\n .filter((r) => r.rowType === \"content\")\n .map((r) => (r as ContentRow).item);\n\n const aggregateValues: {\n [key: string]: { value: any; summary: BmGridSummaryConfiguration };\n } = {};\n\n // Calculate aggregates\n for (const summary of this.gridConfiguration.summaries) {\n const extractedValues = childItems.map((item) =>\n summary.extractor(item, this.gridConfiguration.columns)\n );\n\n if (summary.placement === SummaryPlacement.Column) {\n if (\n !summary.columnKey ||\n !Object.prototype.hasOwnProperty.call(\n this.gridConfiguration.columns,\n summary.columnKey\n )\n ) {\n throw new Error(\n \"Summary with column placement must specify a column key to an existing column.\"\n );\n }\n aggregateValues[summary.columnKey] = {\n value: summary.groupSummaryValueExtractor(\n extractedValues,\n entry[0],\n parentGroupValues\n ),\n summary: summary,\n };\n }\n }\n const groupRowKey = getGroupRowKey(\n groupColumnKey,\n entry[0],\n parentGroupValues\n );\n\n // try to retrieve existing rowgroup to reapply expansion state.\n const existingRow = reapplyRowStates\n ? this.currentRowsMapWithIndex.get(groupRowKey + \"group\")\n : undefined;\n\n groupRows.push({\n rowKey: groupRowKey,\n columnKey: groupColumnKey,\n columnValue: entry[0],\n get isSelected() {\n return childRows.every((r: Row | RowGroup) => r.isSelected);\n },\n set isSelected(value: boolean) {\n childRows.forEach((r: Row | RowGroup) => (r.isSelected = value));\n },\n isExpanded: existingRow\n ? existingRow[0].isExpanded\n : this.defaultExpandGroups,\n children: childRows,\n isParentOfGroups: !childGroup,\n rowType: \"group\",\n aggregateValues,\n } as RowGroup);\n }\n\n return groupRows;\n },\n /**\n * Performs a full refresh of the virtual grid, will cause the grid to re-render and internal state will be lost.\n */\n refreshVirtualGrid(reapplyRowStates: boolean = true) {\n if (this.disableReactiveRows) {\n return;\n }\n\n const selectedKeysSet = new Set(this.selectedItemKeys);\n\n // Create row objects from items. We try and find an existing row using the item key and rank the new items\n // accordingly. The sort function before we return ensures existing items remain in the same order as before.\n\n let newGrid: Row[] = [];\n\n // We only want to map-in out original row indexes if we're sorting\n // sort & map will still take time, and are pointless if we don't care\n if (this.allowSort) {\n newGrid = this.items\n .map((i: any) => {\n const rowKey = this.extractKey(i);\n const existingRow = reapplyRowStates\n ? this.currentRowsMapWithIndex.get(rowKey + \"content\")\n : undefined;\n\n return [\n existingRow ? existingRow[1] : -1,\n {\n rowKey: rowKey,\n item: i,\n isExpanded: existingRow\n ? existingRow[0].isExpanded\n : this.defaultExpandExpandable ||\n this.expandedItemKeys.indexOf(rowKey) > -1,\n isSelected: selectedKeysSet.has(rowKey),\n rowType: \"content\",\n dropBelow: false,\n } as ContentRow,\n ];\n })\n .sort((a, b) => {\n return a[0] < b[0] ? -1 : a[0] > b[0] ? 1 : 0;\n })\n .map(([_, row]) => row as ContentRow);\n } else {\n newGrid = this.items.map((i: any) => {\n const rowKey = this.extractKey(i);\n const existingRow = reapplyRowStates\n ? this.currentRowsMapWithIndex.get(rowKey + \"content\")\n : undefined;\n\n return {\n rowKey: rowKey,\n item: i,\n isExpanded: existingRow\n ? existingRow[0].isExpanded\n : this.defaultExpandExpandable ||\n this.expandedItemKeys.indexOf(rowKey) > -1,\n isSelected: selectedKeysSet.has(rowKey),\n rowType: \"content\",\n dropBelow: false,\n } as ContentRow;\n });\n }\n\n // grid search filter\n // filter on all visible columns including those that are grouped\n if (this.gridState.gridSearchFilter) {\n const searchString = this.gridState.gridSearchFilter;\n newGrid = (newGrid as ContentRow[]).filter((row) =>\n Object.values({\n ...this.visibleColumns,\n ...this.computedGroupedColumns,\n }).some((col) => col.matcher(col.extractor(row.item), searchString))\n );\n }\n\n // Column Filters\n newGrid = applyColumnFilters(\n newGrid as ContentRow[],\n {\n ...this.filterableColumns,\n ...this.computedGroupedColumns,\n },\n this.gridState.columnFilters\n );\n\n // Group the rows\n if (Object.keys(this.computedGroupedColumns).length > 0) {\n newGrid = this.calculateRowGroups(\n newGrid as ContentRow[],\n 0,\n reapplyRowStates\n ) as Row[];\n }\n\n // Sort in priority order\n // Don't sort if we don't allow it, our items are normally\n // already in the order we want them to be\n if (\n Object.keys(this.computedSortableColumns).length > 0 &&\n this.allowSort\n ) {\n applySorting(newGrid, this.computedSortableColumns);\n }\n\n this.$emit(\n \"filter-summary\",\n `${newGrid.length} / ${this.countGroupedRows()} ${this.itemNoun}`\n );\n\n this.virtualGrid = Object.freeze(newGrid);\n },\n updateGridState(): void {\n // Validate the requested state and reset it if it contains columns that are\n // not valid.\n if (!this.gridState.useGridDefault) {\n const availableColumnKeys = new Set(\n Object.keys(this.gridConfiguration.columns)\n );\n const referencedColumnKeys = new Set(\n this.gridState.groupBy\n .concat(this.gridState.sortBy.map((sb) => sb.columnKey))\n .concat(Object.keys(this.gridState.columnFilters))\n );\n\n // Check the requested state referenced keys are all valid. There is more\n // validation that could be done here but this should be sufficient for\n // the more common sync issues.\n if (\n [...referencedColumnKeys].some(\n (columnKey) => !availableColumnKeys.has(columnKey)\n ) ||\n // Requested sort on column that is not sortable\n this.gridState.sortBy.some(\n (sb) =>\n !this.gridConfiguration.columns[sb.columnKey]\n .sortableAndFilterable\n ) ||\n // Requested filter on column that is not filterable\n Object.keys(this.gridState.columnFilters).some(\n (columnKey) =>\n !this.gridConfiguration.columns[columnKey].sortableAndFilterable\n )\n ) {\n // the supplied state is invalid so clear it - technically this is mutating\n // a prop that ideally we should avoid but this is much easier than wiring\n // up 'sync' everywhere.\n this.gridState.reset();\n }\n }\n\n if (this.gridState.useGridDefault) {\n const stateId = this.gridState.stateId;\n // Clone deep used as object.assign uses a shallow copy.\n // This caused defaultGridState to point to the same object as this.gridState\n Object.assign(\n this.gridState,\n cloneDeep(this.gridConfiguration.defaultGridState)\n );\n // eslint-disable-next-line vue/no-mutating-props\n this.gridState.stateId = stateId;\n\n // eslint-disable-next-line vue/no-mutating-props\n this.gridState.useGridDefault = false;\n }\n\n // Do not update the grid unless the state is different to current.\n if (!isEqual(this.gridState, this.gridStateInternal)) {\n this.gridStateInternal = cloneDeep(this.gridState);\n // Save any modified grid state information\n BmGridStateRepository.save();\n }\n },\n },\n});\n\n/**\n * Fitlers a flat (ContentRows only) grid by the column filters.\n * @param flatGrid The grid to filter.\n * @param columns The columns to apply the filters from.\n * @param columnFilterState The full column filter state object from the gridState.\n */\nfunction applyColumnFilters(\n flatGrid: ContentRow[],\n columns: BmGridColumnConfigurations,\n columnFilterState: { [columnKey: string]: any }\n): ContentRow[] {\n for (const [columnKey, columnDef] of Object.entries(columns).filter(\n ([_, col]) => col.columnFilter !== undefined\n )) {\n // Apply each column filter in any order\n let filterState = columnFilterState[columnKey];\n\n // If there is no state for a column filter it is deemed inactive\n if (filterState === undefined) {\n continue;\n }\n\n let columnFilter = columnDef.columnFilter;\n\n if (columnFilter !== undefined) {\n let filterFunction = columnFilter.buildApply(filterState);\n flatGrid = flatGrid.filter((row) =>\n filterFunction(\n columnDef.extractor(row.item),\n columnDef.extractAndFormat(row.item)\n )\n );\n }\n }\n\n return flatGrid;\n}\n\n/**\n * Sorts a flat or nested grid (RowGroup and ContentRow tree).\n */\nfunction applySorting(\n flatOrGroupedGrid: Row[],\n sortBy: {\n [columnKey: string]: BmGridColumnConfiguration & {\n sortDescending?: boolean;\n };\n }\n) {\n const recursiveGroupSorter = (rows: Row[], depth: number = 0) => {\n if (!rows.length) {\n return;\n }\n\n if (rows[0].rowType === \"content\") {\n // List of contents rows - so sort by criteria one by one\n (rows as ContentRow[]).sort((a, b) => {\n for (const [sortColumnKey, sortColumn] of Object.entries(sortBy)) {\n if (!sortColumn.sortableAndFilterable) {\n continue;\n }\n\n const valA = sortColumn.extractor(a.item);\n const valB = sortColumn.extractor(b.item);\n const sortVal = sortColumn.comparer(valA, valB);\n if (sortVal !== 0) {\n return sortVal * (sortColumn.sortDescending ? -1 : 1);\n }\n }\n\n return 0;\n });\n } else if (rows[0].rowType === \"group\") {\n // List of group rows\n (rows as RowGroup[]).sort((a, b) => {\n for (const [sortColumnKey, sortColumn] of Object.entries(sortBy)) {\n if (!sortColumn.sortableAndFilterable) {\n continue;\n }\n\n let sortVal = 0;\n\n if (a.columnKey === sortColumnKey) {\n sortVal = sortColumn.comparer(a.columnValue, b.columnValue);\n } else {\n // otherwise we check to see if we have an aggregated value for this group and sort on that\n if (\n Object.prototype.hasOwnProperty.call(\n a.aggregateValues,\n sortColumnKey\n )\n ) {\n sortVal = sortColumn.comparer(\n a.aggregateValues[sortColumnKey].value,\n b.aggregateValues[sortColumnKey].value\n );\n }\n }\n\n if (sortVal !== 0) {\n return sortVal * (sortColumn.sortDescending ? -1 : 1);\n }\n }\n\n return 0;\n });\n\n for (const row of rows as RowGroup[]) {\n recursiveGroupSorter(row.children, depth + 1);\n }\n }\n };\n\n // start recursive sort\n recursiveGroupSorter(flatOrGroupedGrid, 0);\n}\n","\n\n\n","/*! *****************************************************************************\nCopyright (C) Microsoft. All rights reserved.\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use\nthis file except in compliance with the License. You may obtain a copy of the\nLicense at http://www.apache.org/licenses/LICENSE-2.0\n\nTHIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\nKIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\nWARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\nMERCHANTABLITY OR NON-INFRINGEMENT.\n\nSee the Apache Version 2.0 License for specific language governing permissions\nand limitations under the License.\n***************************************************************************** */\nvar Reflect;\n(function (Reflect) {\n // Metadata Proposal\n // https://rbuckton.github.io/reflect-metadata/\n (function (factory) {\n var root = typeof global === \"object\" ? global :\n typeof self === \"object\" ? self :\n typeof this === \"object\" ? this :\n Function(\"return this;\")();\n var exporter = makeExporter(Reflect);\n if (typeof root.Reflect === \"undefined\") {\n root.Reflect = Reflect;\n }\n else {\n exporter = makeExporter(root.Reflect, exporter);\n }\n factory(exporter);\n function makeExporter(target, previous) {\n return function (key, value) {\n if (typeof target[key] !== \"function\") {\n Object.defineProperty(target, key, { configurable: true, writable: true, value: value });\n }\n if (previous)\n previous(key, value);\n };\n }\n })(function (exporter) {\n var hasOwn = Object.prototype.hasOwnProperty;\n // feature test for Symbol support\n var supportsSymbol = typeof Symbol === \"function\";\n var toPrimitiveSymbol = supportsSymbol && typeof Symbol.toPrimitive !== \"undefined\" ? Symbol.toPrimitive : \"@@toPrimitive\";\n var iteratorSymbol = supportsSymbol && typeof Symbol.iterator !== \"undefined\" ? Symbol.iterator : \"@@iterator\";\n var supportsCreate = typeof Object.create === \"function\"; // feature test for Object.create support\n var supportsProto = { __proto__: [] } instanceof Array; // feature test for __proto__ support\n var downLevel = !supportsCreate && !supportsProto;\n var HashMap = {\n // create an object in dictionary mode (a.k.a. \"slow\" mode in v8)\n create: supportsCreate\n ? function () { return MakeDictionary(Object.create(null)); }\n : supportsProto\n ? function () { return MakeDictionary({ __proto__: null }); }\n : function () { return MakeDictionary({}); },\n has: downLevel\n ? function (map, key) { return hasOwn.call(map, key); }\n : function (map, key) { return key in map; },\n get: downLevel\n ? function (map, key) { return hasOwn.call(map, key) ? map[key] : undefined; }\n : function (map, key) { return map[key]; },\n };\n // Load global or shim versions of Map, Set, and WeakMap\n var functionPrototype = Object.getPrototypeOf(Function);\n var usePolyfill = typeof process === \"object\" && process.env && process.env[\"REFLECT_METADATA_USE_MAP_POLYFILL\"] === \"true\";\n var _Map = !usePolyfill && typeof Map === \"function\" && typeof Map.prototype.entries === \"function\" ? Map : CreateMapPolyfill();\n var _Set = !usePolyfill && typeof Set === \"function\" && typeof Set.prototype.entries === \"function\" ? Set : CreateSetPolyfill();\n var _WeakMap = !usePolyfill && typeof WeakMap === \"function\" ? WeakMap : CreateWeakMapPolyfill();\n // [[Metadata]] internal slot\n // https://rbuckton.github.io/reflect-metadata/#ordinary-object-internal-methods-and-internal-slots\n var Metadata = new _WeakMap();\n /**\n * Applies a set of decorators to a property of a target object.\n * @param decorators An array of decorators.\n * @param target The target object.\n * @param propertyKey (Optional) The property key to decorate.\n * @param attributes (Optional) The property descriptor for the target key.\n * @remarks Decorators are applied in reverse order.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * Example = Reflect.decorate(decoratorsArray, Example);\n *\n * // property (on constructor)\n * Reflect.decorate(decoratorsArray, Example, \"staticProperty\");\n *\n * // property (on prototype)\n * Reflect.decorate(decoratorsArray, Example.prototype, \"property\");\n *\n * // method (on constructor)\n * Object.defineProperty(Example, \"staticMethod\",\n * Reflect.decorate(decoratorsArray, Example, \"staticMethod\",\n * Object.getOwnPropertyDescriptor(Example, \"staticMethod\")));\n *\n * // method (on prototype)\n * Object.defineProperty(Example.prototype, \"method\",\n * Reflect.decorate(decoratorsArray, Example.prototype, \"method\",\n * Object.getOwnPropertyDescriptor(Example.prototype, \"method\")));\n *\n */\n function decorate(decorators, target, propertyKey, attributes) {\n if (!IsUndefined(propertyKey)) {\n if (!IsArray(decorators))\n throw new TypeError();\n if (!IsObject(target))\n throw new TypeError();\n if (!IsObject(attributes) && !IsUndefined(attributes) && !IsNull(attributes))\n throw new TypeError();\n if (IsNull(attributes))\n attributes = undefined;\n propertyKey = ToPropertyKey(propertyKey);\n return DecorateProperty(decorators, target, propertyKey, attributes);\n }\n else {\n if (!IsArray(decorators))\n throw new TypeError();\n if (!IsConstructor(target))\n throw new TypeError();\n return DecorateConstructor(decorators, target);\n }\n }\n exporter(\"decorate\", decorate);\n // 4.1.2 Reflect.metadata(metadataKey, metadataValue)\n // https://rbuckton.github.io/reflect-metadata/#reflect.metadata\n /**\n * A default metadata decorator factory that can be used on a class, class member, or parameter.\n * @param metadataKey The key for the metadata entry.\n * @param metadataValue The value for the metadata entry.\n * @returns A decorator function.\n * @remarks\n * If `metadataKey` is already defined for the target and target key, the\n * metadataValue for that key will be overwritten.\n * @example\n *\n * // constructor\n * @Reflect.metadata(key, value)\n * class Example {\n * }\n *\n * // property (on constructor, TypeScript only)\n * class Example {\n * @Reflect.metadata(key, value)\n * static staticProperty;\n * }\n *\n * // property (on prototype, TypeScript only)\n * class Example {\n * @Reflect.metadata(key, value)\n * property;\n * }\n *\n * // method (on constructor)\n * class Example {\n * @Reflect.metadata(key, value)\n * static staticMethod() { }\n * }\n *\n * // method (on prototype)\n * class Example {\n * @Reflect.metadata(key, value)\n * method() { }\n * }\n *\n */\n function metadata(metadataKey, metadataValue) {\n function decorator(target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey) && !IsPropertyKey(propertyKey))\n throw new TypeError();\n OrdinaryDefineOwnMetadata(metadataKey, metadataValue, target, propertyKey);\n }\n return decorator;\n }\n exporter(\"metadata\", metadata);\n /**\n * Define a unique metadata entry on the target.\n * @param metadataKey A key used to store and retrieve metadata.\n * @param metadataValue A value that contains attached metadata.\n * @param target The target object on which to define metadata.\n * @param propertyKey (Optional) The property key for the target.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * Reflect.defineMetadata(\"custom:annotation\", options, Example);\n *\n * // property (on constructor)\n * Reflect.defineMetadata(\"custom:annotation\", options, Example, \"staticProperty\");\n *\n * // property (on prototype)\n * Reflect.defineMetadata(\"custom:annotation\", options, Example.prototype, \"property\");\n *\n * // method (on constructor)\n * Reflect.defineMetadata(\"custom:annotation\", options, Example, \"staticMethod\");\n *\n * // method (on prototype)\n * Reflect.defineMetadata(\"custom:annotation\", options, Example.prototype, \"method\");\n *\n * // decorator factory as metadata-producing annotation.\n * function MyAnnotation(options): Decorator {\n * return (target, key?) => Reflect.defineMetadata(\"custom:annotation\", options, target, key);\n * }\n *\n */\n function defineMetadata(metadataKey, metadataValue, target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryDefineOwnMetadata(metadataKey, metadataValue, target, propertyKey);\n }\n exporter(\"defineMetadata\", defineMetadata);\n /**\n * Gets a value indicating whether the target object or its prototype chain has the provided metadata key defined.\n * @param metadataKey A key used to store and retrieve metadata.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns `true` if the metadata key was defined on the target object or its prototype chain; otherwise, `false`.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.hasMetadata(\"custom:annotation\", Example);\n *\n * // property (on constructor)\n * result = Reflect.hasMetadata(\"custom:annotation\", Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.hasMetadata(\"custom:annotation\", Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.hasMetadata(\"custom:annotation\", Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.hasMetadata(\"custom:annotation\", Example.prototype, \"method\");\n *\n */\n function hasMetadata(metadataKey, target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryHasMetadata(metadataKey, target, propertyKey);\n }\n exporter(\"hasMetadata\", hasMetadata);\n /**\n * Gets a value indicating whether the target object has the provided metadata key defined.\n * @param metadataKey A key used to store and retrieve metadata.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns `true` if the metadata key was defined on the target object; otherwise, `false`.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.hasOwnMetadata(\"custom:annotation\", Example);\n *\n * // property (on constructor)\n * result = Reflect.hasOwnMetadata(\"custom:annotation\", Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.hasOwnMetadata(\"custom:annotation\", Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.hasOwnMetadata(\"custom:annotation\", Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.hasOwnMetadata(\"custom:annotation\", Example.prototype, \"method\");\n *\n */\n function hasOwnMetadata(metadataKey, target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryHasOwnMetadata(metadataKey, target, propertyKey);\n }\n exporter(\"hasOwnMetadata\", hasOwnMetadata);\n /**\n * Gets the metadata value for the provided metadata key on the target object or its prototype chain.\n * @param metadataKey A key used to store and retrieve metadata.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns The metadata value for the metadata key if found; otherwise, `undefined`.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.getMetadata(\"custom:annotation\", Example);\n *\n * // property (on constructor)\n * result = Reflect.getMetadata(\"custom:annotation\", Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.getMetadata(\"custom:annotation\", Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.getMetadata(\"custom:annotation\", Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.getMetadata(\"custom:annotation\", Example.prototype, \"method\");\n *\n */\n function getMetadata(metadataKey, target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryGetMetadata(metadataKey, target, propertyKey);\n }\n exporter(\"getMetadata\", getMetadata);\n /**\n * Gets the metadata value for the provided metadata key on the target object.\n * @param metadataKey A key used to store and retrieve metadata.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns The metadata value for the metadata key if found; otherwise, `undefined`.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.getOwnMetadata(\"custom:annotation\", Example);\n *\n * // property (on constructor)\n * result = Reflect.getOwnMetadata(\"custom:annotation\", Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.getOwnMetadata(\"custom:annotation\", Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.getOwnMetadata(\"custom:annotation\", Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.getOwnMetadata(\"custom:annotation\", Example.prototype, \"method\");\n *\n */\n function getOwnMetadata(metadataKey, target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryGetOwnMetadata(metadataKey, target, propertyKey);\n }\n exporter(\"getOwnMetadata\", getOwnMetadata);\n /**\n * Gets the metadata keys defined on the target object or its prototype chain.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns An array of unique metadata keys.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.getMetadataKeys(Example);\n *\n * // property (on constructor)\n * result = Reflect.getMetadataKeys(Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.getMetadataKeys(Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.getMetadataKeys(Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.getMetadataKeys(Example.prototype, \"method\");\n *\n */\n function getMetadataKeys(target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryMetadataKeys(target, propertyKey);\n }\n exporter(\"getMetadataKeys\", getMetadataKeys);\n /**\n * Gets the unique metadata keys defined on the target object.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns An array of unique metadata keys.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.getOwnMetadataKeys(Example);\n *\n * // property (on constructor)\n * result = Reflect.getOwnMetadataKeys(Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.getOwnMetadataKeys(Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.getOwnMetadataKeys(Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.getOwnMetadataKeys(Example.prototype, \"method\");\n *\n */\n function getOwnMetadataKeys(target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n return OrdinaryOwnMetadataKeys(target, propertyKey);\n }\n exporter(\"getOwnMetadataKeys\", getOwnMetadataKeys);\n /**\n * Deletes the metadata entry from the target object with the provided key.\n * @param metadataKey A key used to store and retrieve metadata.\n * @param target The target object on which the metadata is defined.\n * @param propertyKey (Optional) The property key for the target.\n * @returns `true` if the metadata entry was found and deleted; otherwise, false.\n * @example\n *\n * class Example {\n * // property declarations are not part of ES6, though they are valid in TypeScript:\n * // static staticProperty;\n * // property;\n *\n * constructor(p) { }\n * static staticMethod(p) { }\n * method(p) { }\n * }\n *\n * // constructor\n * result = Reflect.deleteMetadata(\"custom:annotation\", Example);\n *\n * // property (on constructor)\n * result = Reflect.deleteMetadata(\"custom:annotation\", Example, \"staticProperty\");\n *\n * // property (on prototype)\n * result = Reflect.deleteMetadata(\"custom:annotation\", Example.prototype, \"property\");\n *\n * // method (on constructor)\n * result = Reflect.deleteMetadata(\"custom:annotation\", Example, \"staticMethod\");\n *\n * // method (on prototype)\n * result = Reflect.deleteMetadata(\"custom:annotation\", Example.prototype, \"method\");\n *\n */\n function deleteMetadata(metadataKey, target, propertyKey) {\n if (!IsObject(target))\n throw new TypeError();\n if (!IsUndefined(propertyKey))\n propertyKey = ToPropertyKey(propertyKey);\n var metadataMap = GetOrCreateMetadataMap(target, propertyKey, /*Create*/ false);\n if (IsUndefined(metadataMap))\n return false;\n if (!metadataMap.delete(metadataKey))\n return false;\n if (metadataMap.size > 0)\n return true;\n var targetMetadata = Metadata.get(target);\n targetMetadata.delete(propertyKey);\n if (targetMetadata.size > 0)\n return true;\n Metadata.delete(target);\n return true;\n }\n exporter(\"deleteMetadata\", deleteMetadata);\n function DecorateConstructor(decorators, target) {\n for (var i = decorators.length - 1; i >= 0; --i) {\n var decorator = decorators[i];\n var decorated = decorator(target);\n if (!IsUndefined(decorated) && !IsNull(decorated)) {\n if (!IsConstructor(decorated))\n throw new TypeError();\n target = decorated;\n }\n }\n return target;\n }\n function DecorateProperty(decorators, target, propertyKey, descriptor) {\n for (var i = decorators.length - 1; i >= 0; --i) {\n var decorator = decorators[i];\n var decorated = decorator(target, propertyKey, descriptor);\n if (!IsUndefined(decorated) && !IsNull(decorated)) {\n if (!IsObject(decorated))\n throw new TypeError();\n descriptor = decorated;\n }\n }\n return descriptor;\n }\n function GetOrCreateMetadataMap(O, P, Create) {\n var targetMetadata = Metadata.get(O);\n if (IsUndefined(targetMetadata)) {\n if (!Create)\n return undefined;\n targetMetadata = new _Map();\n Metadata.set(O, targetMetadata);\n }\n var metadataMap = targetMetadata.get(P);\n if (IsUndefined(metadataMap)) {\n if (!Create)\n return undefined;\n metadataMap = new _Map();\n targetMetadata.set(P, metadataMap);\n }\n return metadataMap;\n }\n // 3.1.1.1 OrdinaryHasMetadata(MetadataKey, O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinaryhasmetadata\n function OrdinaryHasMetadata(MetadataKey, O, P) {\n var hasOwn = OrdinaryHasOwnMetadata(MetadataKey, O, P);\n if (hasOwn)\n return true;\n var parent = OrdinaryGetPrototypeOf(O);\n if (!IsNull(parent))\n return OrdinaryHasMetadata(MetadataKey, parent, P);\n return false;\n }\n // 3.1.2.1 OrdinaryHasOwnMetadata(MetadataKey, O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinaryhasownmetadata\n function OrdinaryHasOwnMetadata(MetadataKey, O, P) {\n var metadataMap = GetOrCreateMetadataMap(O, P, /*Create*/ false);\n if (IsUndefined(metadataMap))\n return false;\n return ToBoolean(metadataMap.has(MetadataKey));\n }\n // 3.1.3.1 OrdinaryGetMetadata(MetadataKey, O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinarygetmetadata\n function OrdinaryGetMetadata(MetadataKey, O, P) {\n var hasOwn = OrdinaryHasOwnMetadata(MetadataKey, O, P);\n if (hasOwn)\n return OrdinaryGetOwnMetadata(MetadataKey, O, P);\n var parent = OrdinaryGetPrototypeOf(O);\n if (!IsNull(parent))\n return OrdinaryGetMetadata(MetadataKey, parent, P);\n return undefined;\n }\n // 3.1.4.1 OrdinaryGetOwnMetadata(MetadataKey, O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinarygetownmetadata\n function OrdinaryGetOwnMetadata(MetadataKey, O, P) {\n var metadataMap = GetOrCreateMetadataMap(O, P, /*Create*/ false);\n if (IsUndefined(metadataMap))\n return undefined;\n return metadataMap.get(MetadataKey);\n }\n // 3.1.5.1 OrdinaryDefineOwnMetadata(MetadataKey, MetadataValue, O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinarydefineownmetadata\n function OrdinaryDefineOwnMetadata(MetadataKey, MetadataValue, O, P) {\n var metadataMap = GetOrCreateMetadataMap(O, P, /*Create*/ true);\n metadataMap.set(MetadataKey, MetadataValue);\n }\n // 3.1.6.1 OrdinaryMetadataKeys(O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinarymetadatakeys\n function OrdinaryMetadataKeys(O, P) {\n var ownKeys = OrdinaryOwnMetadataKeys(O, P);\n var parent = OrdinaryGetPrototypeOf(O);\n if (parent === null)\n return ownKeys;\n var parentKeys = OrdinaryMetadataKeys(parent, P);\n if (parentKeys.length <= 0)\n return ownKeys;\n if (ownKeys.length <= 0)\n return parentKeys;\n var set = new _Set();\n var keys = [];\n for (var _i = 0, ownKeys_1 = ownKeys; _i < ownKeys_1.length; _i++) {\n var key = ownKeys_1[_i];\n var hasKey = set.has(key);\n if (!hasKey) {\n set.add(key);\n keys.push(key);\n }\n }\n for (var _a = 0, parentKeys_1 = parentKeys; _a < parentKeys_1.length; _a++) {\n var key = parentKeys_1[_a];\n var hasKey = set.has(key);\n if (!hasKey) {\n set.add(key);\n keys.push(key);\n }\n }\n return keys;\n }\n // 3.1.7.1 OrdinaryOwnMetadataKeys(O, P)\n // https://rbuckton.github.io/reflect-metadata/#ordinaryownmetadatakeys\n function OrdinaryOwnMetadataKeys(O, P) {\n var keys = [];\n var metadataMap = GetOrCreateMetadataMap(O, P, /*Create*/ false);\n if (IsUndefined(metadataMap))\n return keys;\n var keysObj = metadataMap.keys();\n var iterator = GetIterator(keysObj);\n var k = 0;\n while (true) {\n var next = IteratorStep(iterator);\n if (!next) {\n keys.length = k;\n return keys;\n }\n var nextValue = IteratorValue(next);\n try {\n keys[k] = nextValue;\n }\n catch (e) {\n try {\n IteratorClose(iterator);\n }\n finally {\n throw e;\n }\n }\n k++;\n }\n }\n // 6 ECMAScript Data Typ0es and Values\n // https://tc39.github.io/ecma262/#sec-ecmascript-data-types-and-values\n function Type(x) {\n if (x === null)\n return 1 /* Null */;\n switch (typeof x) {\n case \"undefined\": return 0 /* Undefined */;\n case \"boolean\": return 2 /* Boolean */;\n case \"string\": return 3 /* String */;\n case \"symbol\": return 4 /* Symbol */;\n case \"number\": return 5 /* Number */;\n case \"object\": return x === null ? 1 /* Null */ : 6 /* Object */;\n default: return 6 /* Object */;\n }\n }\n // 6.1.1 The Undefined Type\n // https://tc39.github.io/ecma262/#sec-ecmascript-language-types-undefined-type\n function IsUndefined(x) {\n return x === undefined;\n }\n // 6.1.2 The Null Type\n // https://tc39.github.io/ecma262/#sec-ecmascript-language-types-null-type\n function IsNull(x) {\n return x === null;\n }\n // 6.1.5 The Symbol Type\n // https://tc39.github.io/ecma262/#sec-ecmascript-language-types-symbol-type\n function IsSymbol(x) {\n return typeof x === \"symbol\";\n }\n // 6.1.7 The Object Type\n // https://tc39.github.io/ecma262/#sec-object-type\n function IsObject(x) {\n return typeof x === \"object\" ? x !== null : typeof x === \"function\";\n }\n // 7.1 Type Conversion\n // https://tc39.github.io/ecma262/#sec-type-conversion\n // 7.1.1 ToPrimitive(input [, PreferredType])\n // https://tc39.github.io/ecma262/#sec-toprimitive\n function ToPrimitive(input, PreferredType) {\n switch (Type(input)) {\n case 0 /* Undefined */: return input;\n case 1 /* Null */: return input;\n case 2 /* Boolean */: return input;\n case 3 /* String */: return input;\n case 4 /* Symbol */: return input;\n case 5 /* Number */: return input;\n }\n var hint = PreferredType === 3 /* String */ ? \"string\" : PreferredType === 5 /* Number */ ? \"number\" : \"default\";\n var exoticToPrim = GetMethod(input, toPrimitiveSymbol);\n if (exoticToPrim !== undefined) {\n var result = exoticToPrim.call(input, hint);\n if (IsObject(result))\n throw new TypeError();\n return result;\n }\n return OrdinaryToPrimitive(input, hint === \"default\" ? \"number\" : hint);\n }\n // 7.1.1.1 OrdinaryToPrimitive(O, hint)\n // https://tc39.github.io/ecma262/#sec-ordinarytoprimitive\n function OrdinaryToPrimitive(O, hint) {\n if (hint === \"string\") {\n var toString_1 = O.toString;\n if (IsCallable(toString_1)) {\n var result = toString_1.call(O);\n if (!IsObject(result))\n return result;\n }\n var valueOf = O.valueOf;\n if (IsCallable(valueOf)) {\n var result = valueOf.call(O);\n if (!IsObject(result))\n return result;\n }\n }\n else {\n var valueOf = O.valueOf;\n if (IsCallable(valueOf)) {\n var result = valueOf.call(O);\n if (!IsObject(result))\n return result;\n }\n var toString_2 = O.toString;\n if (IsCallable(toString_2)) {\n var result = toString_2.call(O);\n if (!IsObject(result))\n return result;\n }\n }\n throw new TypeError();\n }\n // 7.1.2 ToBoolean(argument)\n // https://tc39.github.io/ecma262/2016/#sec-toboolean\n function ToBoolean(argument) {\n return !!argument;\n }\n // 7.1.12 ToString(argument)\n // https://tc39.github.io/ecma262/#sec-tostring\n function ToString(argument) {\n return \"\" + argument;\n }\n // 7.1.14 ToPropertyKey(argument)\n // https://tc39.github.io/ecma262/#sec-topropertykey\n function ToPropertyKey(argument) {\n var key = ToPrimitive(argument, 3 /* String */);\n if (IsSymbol(key))\n return key;\n return ToString(key);\n }\n // 7.2 Testing and Comparison Operations\n // https://tc39.github.io/ecma262/#sec-testing-and-comparison-operations\n // 7.2.2 IsArray(argument)\n // https://tc39.github.io/ecma262/#sec-isarray\n function IsArray(argument) {\n return Array.isArray\n ? Array.isArray(argument)\n : argument instanceof Object\n ? argument instanceof Array\n : Object.prototype.toString.call(argument) === \"[object Array]\";\n }\n // 7.2.3 IsCallable(argument)\n // https://tc39.github.io/ecma262/#sec-iscallable\n function IsCallable(argument) {\n // NOTE: This is an approximation as we cannot check for [[Call]] internal method.\n return typeof argument === \"function\";\n }\n // 7.2.4 IsConstructor(argument)\n // https://tc39.github.io/ecma262/#sec-isconstructor\n function IsConstructor(argument) {\n // NOTE: This is an approximation as we cannot check for [[Construct]] internal method.\n return typeof argument === \"function\";\n }\n // 7.2.7 IsPropertyKey(argument)\n // https://tc39.github.io/ecma262/#sec-ispropertykey\n function IsPropertyKey(argument) {\n switch (Type(argument)) {\n case 3 /* String */: return true;\n case 4 /* Symbol */: return true;\n default: return false;\n }\n }\n // 7.3 Operations on Objects\n // https://tc39.github.io/ecma262/#sec-operations-on-objects\n // 7.3.9 GetMethod(V, P)\n // https://tc39.github.io/ecma262/#sec-getmethod\n function GetMethod(V, P) {\n var func = V[P];\n if (func === undefined || func === null)\n return undefined;\n if (!IsCallable(func))\n throw new TypeError();\n return func;\n }\n // 7.4 Operations on Iterator Objects\n // https://tc39.github.io/ecma262/#sec-operations-on-iterator-objects\n function GetIterator(obj) {\n var method = GetMethod(obj, iteratorSymbol);\n if (!IsCallable(method))\n throw new TypeError(); // from Call\n var iterator = method.call(obj);\n if (!IsObject(iterator))\n throw new TypeError();\n return iterator;\n }\n // 7.4.4 IteratorValue(iterResult)\n // https://tc39.github.io/ecma262/2016/#sec-iteratorvalue\n function IteratorValue(iterResult) {\n return iterResult.value;\n }\n // 7.4.5 IteratorStep(iterator)\n // https://tc39.github.io/ecma262/#sec-iteratorstep\n function IteratorStep(iterator) {\n var result = iterator.next();\n return result.done ? false : result;\n }\n // 7.4.6 IteratorClose(iterator, completion)\n // https://tc39.github.io/ecma262/#sec-iteratorclose\n function IteratorClose(iterator) {\n var f = iterator[\"return\"];\n if (f)\n f.call(iterator);\n }\n // 9.1 Ordinary Object Internal Methods and Internal Slots\n // https://tc39.github.io/ecma262/#sec-ordinary-object-internal-methods-and-internal-slots\n // 9.1.1.1 OrdinaryGetPrototypeOf(O)\n // https://tc39.github.io/ecma262/#sec-ordinarygetprototypeof\n function OrdinaryGetPrototypeOf(O) {\n var proto = Object.getPrototypeOf(O);\n if (typeof O !== \"function\" || O === functionPrototype)\n return proto;\n // TypeScript doesn't set __proto__ in ES5, as it's non-standard.\n // Try to determine the superclass constructor. Compatible implementations\n // must either set __proto__ on a subclass constructor to the superclass constructor,\n // or ensure each class has a valid `constructor` property on its prototype that\n // points back to the constructor.\n // If this is not the same as Function.[[Prototype]], then this is definately inherited.\n // This is the case when in ES6 or when using __proto__ in a compatible browser.\n if (proto !== functionPrototype)\n return proto;\n // If the super prototype is Object.prototype, null, or undefined, then we cannot determine the heritage.\n var prototype = O.prototype;\n var prototypeProto = prototype && Object.getPrototypeOf(prototype);\n if (prototypeProto == null || prototypeProto === Object.prototype)\n return proto;\n // If the constructor was not a function, then we cannot determine the heritage.\n var constructor = prototypeProto.constructor;\n if (typeof constructor !== \"function\")\n return proto;\n // If we have some kind of self-reference, then we cannot determine the heritage.\n if (constructor === O)\n return proto;\n // we have a pretty good guess at the heritage.\n return constructor;\n }\n // naive Map shim\n function CreateMapPolyfill() {\n var cacheSentinel = {};\n var arraySentinel = [];\n var MapIterator = /** @class */ (function () {\n function MapIterator(keys, values, selector) {\n this._index = 0;\n this._keys = keys;\n this._values = values;\n this._selector = selector;\n }\n MapIterator.prototype[\"@@iterator\"] = function () { return this; };\n MapIterator.prototype[iteratorSymbol] = function () { return this; };\n MapIterator.prototype.next = function () {\n var index = this._index;\n if (index >= 0 && index < this._keys.length) {\n var result = this._selector(this._keys[index], this._values[index]);\n if (index + 1 >= this._keys.length) {\n this._index = -1;\n this._keys = arraySentinel;\n this._values = arraySentinel;\n }\n else {\n this._index++;\n }\n return { value: result, done: false };\n }\n return { value: undefined, done: true };\n };\n MapIterator.prototype.throw = function (error) {\n if (this._index >= 0) {\n this._index = -1;\n this._keys = arraySentinel;\n this._values = arraySentinel;\n }\n throw error;\n };\n MapIterator.prototype.return = function (value) {\n if (this._index >= 0) {\n this._index = -1;\n this._keys = arraySentinel;\n this._values = arraySentinel;\n }\n return { value: value, done: true };\n };\n return MapIterator;\n }());\n return /** @class */ (function () {\n function Map() {\n this._keys = [];\n this._values = [];\n this._cacheKey = cacheSentinel;\n this._cacheIndex = -2;\n }\n Object.defineProperty(Map.prototype, \"size\", {\n get: function () { return this._keys.length; },\n enumerable: true,\n configurable: true\n });\n Map.prototype.has = function (key) { return this._find(key, /*insert*/ false) >= 0; };\n Map.prototype.get = function (key) {\n var index = this._find(key, /*insert*/ false);\n return index >= 0 ? this._values[index] : undefined;\n };\n Map.prototype.set = function (key, value) {\n var index = this._find(key, /*insert*/ true);\n this._values[index] = value;\n return this;\n };\n Map.prototype.delete = function (key) {\n var index = this._find(key, /*insert*/ false);\n if (index >= 0) {\n var size = this._keys.length;\n for (var i = index + 1; i < size; i++) {\n this._keys[i - 1] = this._keys[i];\n this._values[i - 1] = this._values[i];\n }\n this._keys.length--;\n this._values.length--;\n if (key === this._cacheKey) {\n this._cacheKey = cacheSentinel;\n this._cacheIndex = -2;\n }\n return true;\n }\n return false;\n };\n Map.prototype.clear = function () {\n this._keys.length = 0;\n this._values.length = 0;\n this._cacheKey = cacheSentinel;\n this._cacheIndex = -2;\n };\n Map.prototype.keys = function () { return new MapIterator(this._keys, this._values, getKey); };\n Map.prototype.values = function () { return new MapIterator(this._keys, this._values, getValue); };\n Map.prototype.entries = function () { return new MapIterator(this._keys, this._values, getEntry); };\n Map.prototype[\"@@iterator\"] = function () { return this.entries(); };\n Map.prototype[iteratorSymbol] = function () { return this.entries(); };\n Map.prototype._find = function (key, insert) {\n if (this._cacheKey !== key) {\n this._cacheIndex = this._keys.indexOf(this._cacheKey = key);\n }\n if (this._cacheIndex < 0 && insert) {\n this._cacheIndex = this._keys.length;\n this._keys.push(key);\n this._values.push(undefined);\n }\n return this._cacheIndex;\n };\n return Map;\n }());\n function getKey(key, _) {\n return key;\n }\n function getValue(_, value) {\n return value;\n }\n function getEntry(key, value) {\n return [key, value];\n }\n }\n // naive Set shim\n function CreateSetPolyfill() {\n return /** @class */ (function () {\n function Set() {\n this._map = new _Map();\n }\n Object.defineProperty(Set.prototype, \"size\", {\n get: function () { return this._map.size; },\n enumerable: true,\n configurable: true\n });\n Set.prototype.has = function (value) { return this._map.has(value); };\n Set.prototype.add = function (value) { return this._map.set(value, value), this; };\n Set.prototype.delete = function (value) { return this._map.delete(value); };\n Set.prototype.clear = function () { this._map.clear(); };\n Set.prototype.keys = function () { return this._map.keys(); };\n Set.prototype.values = function () { return this._map.values(); };\n Set.prototype.entries = function () { return this._map.entries(); };\n Set.prototype[\"@@iterator\"] = function () { return this.keys(); };\n Set.prototype[iteratorSymbol] = function () { return this.keys(); };\n return Set;\n }());\n }\n // naive WeakMap shim\n function CreateWeakMapPolyfill() {\n var UUID_SIZE = 16;\n var keys = HashMap.create();\n var rootKey = CreateUniqueKey();\n return /** @class */ (function () {\n function WeakMap() {\n this._key = CreateUniqueKey();\n }\n WeakMap.prototype.has = function (target) {\n var table = GetOrCreateWeakMapTable(target, /*create*/ false);\n return table !== undefined ? HashMap.has(table, this._key) : false;\n };\n WeakMap.prototype.get = function (target) {\n var table = GetOrCreateWeakMapTable(target, /*create*/ false);\n return table !== undefined ? HashMap.get(table, this._key) : undefined;\n };\n WeakMap.prototype.set = function (target, value) {\n var table = GetOrCreateWeakMapTable(target, /*create*/ true);\n table[this._key] = value;\n return this;\n };\n WeakMap.prototype.delete = function (target) {\n var table = GetOrCreateWeakMapTable(target, /*create*/ false);\n return table !== undefined ? delete table[this._key] : false;\n };\n WeakMap.prototype.clear = function () {\n // NOTE: not a real clear, just makes the previous data unreachable\n this._key = CreateUniqueKey();\n };\n return WeakMap;\n }());\n function CreateUniqueKey() {\n var key;\n do\n key = \"@@WeakMap@@\" + CreateUUID();\n while (HashMap.has(keys, key));\n keys[key] = true;\n return key;\n }\n function GetOrCreateWeakMapTable(target, create) {\n if (!hasOwn.call(target, rootKey)) {\n if (!create)\n return undefined;\n Object.defineProperty(target, rootKey, { value: HashMap.create() });\n }\n return target[rootKey];\n }\n function FillRandomBytes(buffer, size) {\n for (var i = 0; i < size; ++i)\n buffer[i] = Math.random() * 0xff | 0;\n return buffer;\n }\n function GenRandomBytes(size) {\n if (typeof Uint8Array === \"function\") {\n if (typeof crypto !== \"undefined\")\n return crypto.getRandomValues(new Uint8Array(size));\n if (typeof msCrypto !== \"undefined\")\n return msCrypto.getRandomValues(new Uint8Array(size));\n return FillRandomBytes(new Uint8Array(size), size);\n }\n return FillRandomBytes(new Array(size), size);\n }\n function CreateUUID() {\n var data = GenRandomBytes(UUID_SIZE);\n // mark as random - RFC 4122 § 4.4\n data[6] = data[6] & 0x4f | 0x40;\n data[8] = data[8] & 0xbf | 0x80;\n var result = \"\";\n for (var offset = 0; offset < UUID_SIZE; ++offset) {\n var byte = data[offset];\n if (offset === 4 || offset === 6 || offset === 8)\n result += \"-\";\n if (byte < 16)\n result += \"0\";\n result += byte.toString(16).toLowerCase();\n }\n return result;\n }\n }\n // uses a heuristic used by v8 and chakra to force an object into dictionary mode.\n function MakeDictionary(obj) {\n obj.__ = undefined;\n delete obj.__;\n return obj;\n }\n });\n})(Reflect || (Reflect = {}));\n","/**\n * vue-class-component v7.2.6\n * (c) 2015-present Evan You\n * @license MIT\n */\nimport Vue from 'vue';\n\nfunction _typeof(obj) {\n if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") {\n _typeof = function (obj) {\n return typeof obj;\n };\n } else {\n _typeof = function (obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n };\n }\n\n return _typeof(obj);\n}\n\nfunction _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}\n\nfunction _toConsumableArray(arr) {\n return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread();\n}\n\nfunction _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) {\n for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) arr2[i] = arr[i];\n\n return arr2;\n }\n}\n\nfunction _iterableToArray(iter) {\n if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === \"[object Arguments]\") return Array.from(iter);\n}\n\nfunction _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance\");\n}\n\n// The rational behind the verbose Reflect-feature check below is the fact that there are polyfills\n// which add an implementation for Reflect.defineMetadata but not for Reflect.getOwnMetadataKeys.\n// Without this check consumers will encounter hard to track down runtime errors.\nfunction reflectionIsSupported() {\n return typeof Reflect !== 'undefined' && Reflect.defineMetadata && Reflect.getOwnMetadataKeys;\n}\nfunction copyReflectionMetadata(to, from) {\n forwardMetadata(to, from);\n Object.getOwnPropertyNames(from.prototype).forEach(function (key) {\n forwardMetadata(to.prototype, from.prototype, key);\n });\n Object.getOwnPropertyNames(from).forEach(function (key) {\n forwardMetadata(to, from, key);\n });\n}\n\nfunction forwardMetadata(to, from, propertyKey) {\n var metaKeys = propertyKey ? Reflect.getOwnMetadataKeys(from, propertyKey) : Reflect.getOwnMetadataKeys(from);\n metaKeys.forEach(function (metaKey) {\n var metadata = propertyKey ? Reflect.getOwnMetadata(metaKey, from, propertyKey) : Reflect.getOwnMetadata(metaKey, from);\n\n if (propertyKey) {\n Reflect.defineMetadata(metaKey, metadata, to, propertyKey);\n } else {\n Reflect.defineMetadata(metaKey, metadata, to);\n }\n });\n}\n\nvar fakeArray = {\n __proto__: []\n};\nvar hasProto = fakeArray instanceof Array;\nfunction createDecorator(factory) {\n return function (target, key, index) {\n var Ctor = typeof target === 'function' ? target : target.constructor;\n\n if (!Ctor.__decorators__) {\n Ctor.__decorators__ = [];\n }\n\n if (typeof index !== 'number') {\n index = undefined;\n }\n\n Ctor.__decorators__.push(function (options) {\n return factory(options, key, index);\n });\n };\n}\nfunction mixins() {\n for (var _len = arguments.length, Ctors = new Array(_len), _key = 0; _key < _len; _key++) {\n Ctors[_key] = arguments[_key];\n }\n\n return Vue.extend({\n mixins: Ctors\n });\n}\nfunction isPrimitive(value) {\n var type = _typeof(value);\n\n return value == null || type !== 'object' && type !== 'function';\n}\nfunction warn(message) {\n if (typeof console !== 'undefined') {\n console.warn('[vue-class-component] ' + message);\n }\n}\n\nfunction collectDataFromConstructor(vm, Component) {\n // override _init to prevent to init as Vue instance\n var originalInit = Component.prototype._init;\n\n Component.prototype._init = function () {\n var _this = this;\n\n // proxy to actual vm\n var keys = Object.getOwnPropertyNames(vm); // 2.2.0 compat (props are no longer exposed as self properties)\n\n if (vm.$options.props) {\n for (var key in vm.$options.props) {\n if (!vm.hasOwnProperty(key)) {\n keys.push(key);\n }\n }\n }\n\n keys.forEach(function (key) {\n Object.defineProperty(_this, key, {\n get: function get() {\n return vm[key];\n },\n set: function set(value) {\n vm[key] = value;\n },\n configurable: true\n });\n });\n }; // should be acquired class property values\n\n\n var data = new Component(); // restore original _init to avoid memory leak (#209)\n\n Component.prototype._init = originalInit; // create plain data object\n\n var plainData = {};\n Object.keys(data).forEach(function (key) {\n if (data[key] !== undefined) {\n plainData[key] = data[key];\n }\n });\n\n if (process.env.NODE_ENV !== 'production') {\n if (!(Component.prototype instanceof Vue) && Object.keys(plainData).length > 0) {\n warn('Component class must inherit Vue or its descendant class ' + 'when class property is used.');\n }\n }\n\n return plainData;\n}\n\nvar $internalHooks = ['data', 'beforeCreate', 'created', 'beforeMount', 'mounted', 'beforeDestroy', 'destroyed', 'beforeUpdate', 'updated', 'activated', 'deactivated', 'render', 'errorCaptured', 'serverPrefetch' // 2.6\n];\nfunction componentFactory(Component) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n options.name = options.name || Component._componentTag || Component.name; // prototype props.\n\n var proto = Component.prototype;\n Object.getOwnPropertyNames(proto).forEach(function (key) {\n if (key === 'constructor') {\n return;\n } // hooks\n\n\n if ($internalHooks.indexOf(key) > -1) {\n options[key] = proto[key];\n return;\n }\n\n var descriptor = Object.getOwnPropertyDescriptor(proto, key);\n\n if (descriptor.value !== void 0) {\n // methods\n if (typeof descriptor.value === 'function') {\n (options.methods || (options.methods = {}))[key] = descriptor.value;\n } else {\n // typescript decorated data\n (options.mixins || (options.mixins = [])).push({\n data: function data() {\n return _defineProperty({}, key, descriptor.value);\n }\n });\n }\n } else if (descriptor.get || descriptor.set) {\n // computed properties\n (options.computed || (options.computed = {}))[key] = {\n get: descriptor.get,\n set: descriptor.set\n };\n }\n });\n (options.mixins || (options.mixins = [])).push({\n data: function data() {\n return collectDataFromConstructor(this, Component);\n }\n }); // decorate options\n\n var decorators = Component.__decorators__;\n\n if (decorators) {\n decorators.forEach(function (fn) {\n return fn(options);\n });\n delete Component.__decorators__;\n } // find super\n\n\n var superProto = Object.getPrototypeOf(Component.prototype);\n var Super = superProto instanceof Vue ? superProto.constructor : Vue;\n var Extended = Super.extend(options);\n forwardStaticMembers(Extended, Component, Super);\n\n if (reflectionIsSupported()) {\n copyReflectionMetadata(Extended, Component);\n }\n\n return Extended;\n}\nvar reservedPropertyNames = [// Unique id\n'cid', // Super Vue constructor\n'super', // Component options that will be used by the component\n'options', 'superOptions', 'extendOptions', 'sealedOptions', // Private assets\n'component', 'directive', 'filter'];\nvar shouldIgnore = {\n prototype: true,\n arguments: true,\n callee: true,\n caller: true\n};\n\nfunction forwardStaticMembers(Extended, Original, Super) {\n // We have to use getOwnPropertyNames since Babel registers methods as non-enumerable\n Object.getOwnPropertyNames(Original).forEach(function (key) {\n // Skip the properties that should not be overwritten\n if (shouldIgnore[key]) {\n return;\n } // Some browsers does not allow reconfigure built-in properties\n\n\n var extendedDescriptor = Object.getOwnPropertyDescriptor(Extended, key);\n\n if (extendedDescriptor && !extendedDescriptor.configurable) {\n return;\n }\n\n var descriptor = Object.getOwnPropertyDescriptor(Original, key); // If the user agent does not support `__proto__` or its family (IE <= 10),\n // the sub class properties may be inherited properties from the super class in TypeScript.\n // We need to exclude such properties to prevent to overwrite\n // the component options object which stored on the extended constructor (See #192).\n // If the value is a referenced value (object or function),\n // we can check equality of them and exclude it if they have the same reference.\n // If it is a primitive value, it will be forwarded for safety.\n\n if (!hasProto) {\n // Only `cid` is explicitly exluded from property forwarding\n // because we cannot detect whether it is a inherited property or not\n // on the no `__proto__` environment even though the property is reserved.\n if (key === 'cid') {\n return;\n }\n\n var superDescriptor = Object.getOwnPropertyDescriptor(Super, key);\n\n if (!isPrimitive(descriptor.value) && superDescriptor && superDescriptor.value === descriptor.value) {\n return;\n }\n } // Warn if the users manually declare reserved properties\n\n\n if (process.env.NODE_ENV !== 'production' && reservedPropertyNames.indexOf(key) >= 0) {\n warn(\"Static property name '\".concat(key, \"' declared on class '\").concat(Original.name, \"' \") + 'conflicts with reserved property name of Vue internal. ' + 'It may cause unexpected behavior of the component. Consider renaming the property.');\n }\n\n Object.defineProperty(Extended, key, descriptor);\n });\n}\n\nfunction Component(options) {\n if (typeof options === 'function') {\n return componentFactory(options);\n }\n\n return function (Component) {\n return componentFactory(Component, options);\n };\n}\n\nComponent.registerHooks = function registerHooks(keys) {\n $internalHooks.push.apply($internalHooks, _toConsumableArray(keys));\n};\n\nexport default Component;\nexport { createDecorator, mixins };\n","/** vue-property-decorator verson 8.5.1 MIT LICENSE copyright 2020 kaorun343 */\n/// \n'use strict';\nimport Vue from 'vue';\nimport Component, { createDecorator, mixins } from 'vue-class-component';\nexport { Component, Vue, mixins as Mixins };\n/** Used for keying reactive provide/inject properties */\nvar reactiveInjectKey = '__reactiveInject__';\n/**\n * decorator of an inject\n * @param from key\n * @return PropertyDecorator\n */\nexport function Inject(options) {\n return createDecorator(function (componentOptions, key) {\n if (typeof componentOptions.inject === 'undefined') {\n componentOptions.inject = {};\n }\n if (!Array.isArray(componentOptions.inject)) {\n componentOptions.inject[key] = options || key;\n }\n });\n}\n/**\n * decorator of a reactive inject\n * @param from key\n * @return PropertyDecorator\n */\nexport function InjectReactive(options) {\n return createDecorator(function (componentOptions, key) {\n if (typeof componentOptions.inject === 'undefined') {\n componentOptions.inject = {};\n }\n if (!Array.isArray(componentOptions.inject)) {\n var fromKey_1 = !!options ? options.from || options : key;\n var defaultVal_1 = (!!options && options.default) || undefined;\n if (!componentOptions.computed)\n componentOptions.computed = {};\n componentOptions.computed[key] = function () {\n var obj = this[reactiveInjectKey];\n return obj ? obj[fromKey_1] : defaultVal_1;\n };\n componentOptions.inject[reactiveInjectKey] = reactiveInjectKey;\n }\n });\n}\nfunction produceProvide(original) {\n var provide = function () {\n var _this = this;\n var rv = typeof original === 'function' ? original.call(this) : original;\n rv = Object.create(rv || null);\n // set reactive services (propagates previous services if necessary)\n rv[reactiveInjectKey] = this[reactiveInjectKey] || {};\n for (var i in provide.managed) {\n rv[provide.managed[i]] = this[i];\n }\n var _loop_1 = function (i) {\n rv[provide.managedReactive[i]] = this_1[i]; // Duplicates the behavior of `@Provide`\n Object.defineProperty(rv[reactiveInjectKey], provide.managedReactive[i], {\n enumerable: true,\n get: function () { return _this[i]; },\n });\n };\n var this_1 = this;\n for (var i in provide.managedReactive) {\n _loop_1(i);\n }\n return rv;\n };\n provide.managed = {};\n provide.managedReactive = {};\n return provide;\n}\nfunction needToProduceProvide(original) {\n return (typeof original !== 'function' ||\n (!original.managed && !original.managedReactive));\n}\n/**\n * decorator of a provide\n * @param key key\n * @return PropertyDecorator | void\n */\nexport function Provide(key) {\n return createDecorator(function (componentOptions, k) {\n var provide = componentOptions.provide;\n if (needToProduceProvide(provide)) {\n provide = componentOptions.provide = produceProvide(provide);\n }\n provide.managed[k] = key || k;\n });\n}\n/**\n * decorator of a reactive provide\n * @param key key\n * @return PropertyDecorator | void\n */\nexport function ProvideReactive(key) {\n return createDecorator(function (componentOptions, k) {\n var provide = componentOptions.provide;\n // inject parent reactive services (if any)\n if (!Array.isArray(componentOptions.inject)) {\n componentOptions.inject = componentOptions.inject || {};\n componentOptions.inject[reactiveInjectKey] = {\n from: reactiveInjectKey,\n default: {},\n };\n }\n if (needToProduceProvide(provide)) {\n provide = componentOptions.provide = produceProvide(provide);\n }\n provide.managedReactive[k] = key || k;\n });\n}\n/** @see {@link https://github.com/vuejs/vue-class-component/blob/master/src/reflect.ts} */\nvar reflectMetadataIsSupported = typeof Reflect !== 'undefined' && typeof Reflect.getMetadata !== 'undefined';\nfunction applyMetadata(options, target, key) {\n if (reflectMetadataIsSupported) {\n if (!Array.isArray(options) &&\n typeof options !== 'function' &&\n typeof options.type === 'undefined') {\n var type = Reflect.getMetadata('design:type', target, key);\n if (type !== Object) {\n options.type = type;\n }\n }\n }\n}\n/**\n * decorator of model\n * @param event event name\n * @param options options\n * @return PropertyDecorator\n */\nexport function Model(event, options) {\n if (options === void 0) { options = {}; }\n return function (target, key) {\n applyMetadata(options, target, key);\n createDecorator(function (componentOptions, k) {\n ;\n (componentOptions.props || (componentOptions.props = {}))[k] = options;\n componentOptions.model = { prop: k, event: event || k };\n })(target, key);\n };\n}\n/**\n * decorator of a prop\n * @param options the options for the prop\n * @return PropertyDecorator | void\n */\nexport function Prop(options) {\n if (options === void 0) { options = {}; }\n return function (target, key) {\n applyMetadata(options, target, key);\n createDecorator(function (componentOptions, k) {\n ;\n (componentOptions.props || (componentOptions.props = {}))[k] = options;\n })(target, key);\n };\n}\n/**\n * decorator of a synced prop\n * @param propName the name to interface with from outside, must be different from decorated property\n * @param options the options for the synced prop\n * @return PropertyDecorator | void\n */\nexport function PropSync(propName, options) {\n if (options === void 0) { options = {}; }\n // @ts-ignore\n return function (target, key) {\n applyMetadata(options, target, key);\n createDecorator(function (componentOptions, k) {\n ;\n (componentOptions.props || (componentOptions.props = {}))[propName] = options;\n (componentOptions.computed || (componentOptions.computed = {}))[k] = {\n get: function () {\n return this[propName];\n },\n set: function (value) {\n // @ts-ignore\n this.$emit(\"update:\" + propName, value);\n },\n };\n })(target, key);\n };\n}\n/**\n * decorator of a watch function\n * @param path the path or the expression to observe\n * @param WatchOption\n * @return MethodDecorator\n */\nexport function Watch(path, options) {\n if (options === void 0) { options = {}; }\n var _a = options.deep, deep = _a === void 0 ? false : _a, _b = options.immediate, immediate = _b === void 0 ? false : _b;\n return createDecorator(function (componentOptions, handler) {\n if (typeof componentOptions.watch !== 'object') {\n componentOptions.watch = Object.create(null);\n }\n var watch = componentOptions.watch;\n if (typeof watch[path] === 'object' && !Array.isArray(watch[path])) {\n watch[path] = [watch[path]];\n }\n else if (typeof watch[path] === 'undefined') {\n watch[path] = [];\n }\n watch[path].push({ handler: handler, deep: deep, immediate: immediate });\n });\n}\n// Code copied from Vue/src/shared/util.js\nvar hyphenateRE = /\\B([A-Z])/g;\nvar hyphenate = function (str) { return str.replace(hyphenateRE, '-$1').toLowerCase(); };\n/**\n * decorator of an event-emitter function\n * @param event The name of the event\n * @return MethodDecorator\n */\nexport function Emit(event) {\n return function (_target, propertyKey, descriptor) {\n var key = hyphenate(propertyKey);\n var original = descriptor.value;\n descriptor.value = function emitter() {\n var _this = this;\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n var emit = function (returnValue) {\n var emitName = event || key;\n if (returnValue === undefined) {\n if (args.length === 0) {\n _this.$emit(emitName);\n }\n else if (args.length === 1) {\n _this.$emit(emitName, args[0]);\n }\n else {\n _this.$emit.apply(_this, [emitName].concat(args));\n }\n }\n else {\n if (args.length === 0) {\n _this.$emit(emitName, returnValue);\n }\n else if (args.length === 1) {\n _this.$emit(emitName, returnValue, args[0]);\n }\n else {\n _this.$emit.apply(_this, [emitName, returnValue].concat(args));\n }\n }\n };\n var returnValue = original.apply(this, args);\n if (isPromise(returnValue)) {\n returnValue.then(emit);\n }\n else {\n emit(returnValue);\n }\n return returnValue;\n };\n };\n}\n/**\n * decorator of a ref prop\n * @param refKey the ref key defined in template\n */\nexport function Ref(refKey) {\n return createDecorator(function (options, key) {\n options.computed = options.computed || {};\n options.computed[key] = {\n cache: false,\n get: function () {\n return this.$refs[refKey || key];\n },\n };\n });\n}\nfunction isPromise(obj) {\n return obj instanceof Promise || (obj && typeof obj.then === 'function');\n}\n","import 'reflect-metadata';\nimport { Vue, Component, Prop } from 'vue-property-decorator';\n\n/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation. All rights reserved.\r\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use\r\nthis file except in compliance with the License. You may obtain a copy of the\r\nLicense at http://www.apache.org/licenses/LICENSE-2.0\r\n\r\nTHIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\r\nKIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\r\nWARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\r\nMERCHANTABLITY OR NON-INFRINGEMENT.\r\n\r\nSee the Apache Version 2.0 License for specific language governing permissions\r\nand limitations under the License.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nfunction __extends(d, b) {\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nvar __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n };\r\n return __assign.apply(this, arguments);\r\n};\r\n\r\nfunction __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nfunction __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nfunction __values(o) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator], i = 0;\r\n if (m) return m.call(o);\r\n return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n}\r\n\r\nfunction __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\nfunction __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\n\n/**\r\n * This is the class of the global object that holds the state of the drag and drop during its progress. It emits events\r\n * reporting its state evolution during the progress of the drag and drop. Its data is reactive and listeners can be\r\n * attachted to it using the method on.\r\n */\r\nvar DnD = /** @class */ (function () {\r\n function DnD() {\r\n this.inProgress = false;\r\n this.type = null;\r\n this.data = null;\r\n this.source = null;\r\n this.top = null;\r\n this.position = null;\r\n this.eventBus = new Vue();\r\n this.sourceListeners = null;\r\n this.success = null;\r\n }\r\n DnD.prototype.startDrag = function (source, event, x, y, type, data) {\r\n this.type = type;\r\n this.data = data;\r\n this.source = source;\r\n this.position = { x: x, y: y };\r\n this.top = null;\r\n this.sourceListeners = source.$listeners;\r\n this.inProgress = true;\r\n this.emit(event, \"dragstart\");\r\n this.emit(event, \"dragtopchanged\", { previousTop: null });\r\n };\r\n DnD.prototype.resetVariables = function () {\r\n this.inProgress = false;\r\n this.data = null;\r\n this.source = null;\r\n this.position = null;\r\n this.success = null;\r\n };\r\n DnD.prototype.stopDrag = function (event) {\r\n this.success = this.top !== null && this.top['compatibleMode'] && this.top['dropAllowed'];\r\n if (this.top !== null) {\r\n this.emit(event, \"drop\");\r\n }\r\n this.emit(event, \"dragend\");\r\n this.resetVariables();\r\n };\r\n DnD.prototype.cancelDrag = function (event) {\r\n this.success = false;\r\n this.emit(event, \"dragend\");\r\n this.resetVariables();\r\n };\r\n DnD.prototype.mouseMove = function (event, comp) {\r\n if (this.inProgress) {\r\n var prevent = false;\r\n var previousTop = this.top;\r\n if (comp === null) {\r\n // The mouse move event reached the top of the document without hitting a drop component.\r\n this.top = null;\r\n prevent = true;\r\n }\r\n else if (comp['isDropMask']) {\r\n // The mouse move event bubbled until it reached a drop mask.\r\n this.top = null;\r\n prevent = true;\r\n }\r\n else if (comp['candidate'](this.type, this.data, this.source)) {\r\n // The mouse move event bubbled until it reached a drop component that participates in the current drag operation.\r\n this.top = comp;\r\n prevent = true;\r\n }\r\n if (prevent) {\r\n // We prevent the mouse move event from bubbling further up the tree because it reached the foremost drop component and that component is all that matters.\r\n event.stopPropagation();\r\n }\r\n if (this.top !== previousTop) {\r\n this.emit(event.detail.native, 'dragtopchanged', { previousTop: previousTop });\r\n }\r\n this.position = {\r\n x: event.detail.x,\r\n y: event.detail.y\r\n };\r\n this.emit(event.detail.native, 'dragpositionchanged');\r\n }\r\n };\r\n DnD.prototype.emit = function (native, event, data) {\r\n this.eventBus.$emit(event, __assign({ type: this.type, data: this.data, top: this.top, source: this.source, position: this.position, success: this.success, native: native }, data));\r\n };\r\n DnD.prototype.on = function (event, callback) {\r\n this.eventBus.$on(event, callback);\r\n };\r\n DnD.prototype.off = function (event, callback) {\r\n this.eventBus.$off(event, callback);\r\n };\r\n return DnD;\r\n}());\r\nvar dnd = new DnD();\r\ndnd = Vue.observable(dnd);\n\nvar DragAwareMixin = /** @class */ (function (_super) {\r\n __extends(DragAwareMixin, _super);\r\n function DragAwareMixin() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n Object.defineProperty(DragAwareMixin.prototype, \"dragInProgress\", {\r\n get: function () {\r\n return dnd.inProgress;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DragAwareMixin.prototype, \"dragData\", {\r\n get: function () {\r\n return dnd.data;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DragAwareMixin.prototype, \"dragType\", {\r\n get: function () {\r\n return dnd.type;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DragAwareMixin.prototype, \"dragPosition\", {\r\n get: function () {\r\n return dnd.position;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DragAwareMixin.prototype, \"dragSource\", {\r\n get: function () {\r\n return dnd.source;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DragAwareMixin.prototype, \"dragTop\", {\r\n get: function () {\r\n return dnd.top;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n DragAwareMixin = __decorate([\r\n Component({})\r\n ], DragAwareMixin);\r\n return DragAwareMixin;\r\n}(Vue));\n\n/**\r\n * This files contains the primitives required to create drag images from HTML elements that serve as models. A snapshot\r\n * of the computed styles of the model elements is taken when creating the drag image, so that it will look the same as\r\n * the model, no matter where the drag images is grafted into the DOM.\r\n */\r\n/**\r\n * Creates a drag image using the given element as model.\r\n */\r\nfunction createDragImage(el) {\r\n var clone = deepClone(el);\r\n clone.style.position = 'fixed';\r\n clone.style.margin = '0';\r\n clone.style[\"z-index\"] = '1000';\r\n clone.style.transition = 'opacity 0.2s';\r\n return clone;\r\n}\r\n/**\r\n * Clones the given element and all its descendants.\r\n */\r\nfunction deepClone(el) {\r\n var clone = el.cloneNode(true);\r\n copyStyle(el, clone);\r\n var vSrcElements = el.getElementsByTagName(\"*\");\r\n var vDstElements = clone.getElementsByTagName(\"*\");\r\n for (var i = vSrcElements.length; i--;) {\r\n var vSrcElement = vSrcElements[i];\r\n var vDstElement = vDstElements[i];\r\n copyStyle(vSrcElement, vDstElement);\r\n }\r\n return clone;\r\n}\r\n/**\r\n * Copy the computed styles from src to destination.\r\n */\r\nfunction copyStyle(src, destination) {\r\n var e_1, _a;\r\n var computedStyle = window.getComputedStyle(src);\r\n try {\r\n for (var computedStyle_1 = __values(computedStyle), computedStyle_1_1 = computedStyle_1.next(); !computedStyle_1_1.done; computedStyle_1_1 = computedStyle_1.next()) {\r\n var key = computedStyle_1_1.value;\r\n if (key === 'width') {\r\n // IE11\r\n var width = computedStyle.getPropertyValue(\"box-sizing\") === 'border-box' ?\r\n src.clientWidth :\r\n src.clientWidth - parseFloat(computedStyle.paddingLeft) - parseFloat(computedStyle.paddingRight);\r\n destination.style.setProperty(\"width\", width + \"px\");\r\n }\r\n else if (key === 'height') {\r\n // IE11\r\n var height = computedStyle.getPropertyValue(\"box-sizing\") === 'border-box' ?\r\n src.clientHeight :\r\n src.clientHeight - parseFloat(computedStyle.paddingTop) - parseFloat(computedStyle.paddingBottom);\r\n destination.style.setProperty(\"height\", height + \"px\");\r\n }\r\n else {\r\n destination.style.setProperty(key, computedStyle.getPropertyValue(key), computedStyle.getPropertyPriority(key));\r\n }\r\n }\r\n }\r\n catch (e_1_1) { e_1 = { error: e_1_1 }; }\r\n finally {\r\n try {\r\n if (computedStyle_1_1 && !computedStyle_1_1.done && (_a = computedStyle_1.return)) { _a.call(computedStyle_1); }\r\n }\r\n finally { if (e_1) { throw e_1.error; } }\r\n }\r\n destination.style.pointerEvents = 'none';\r\n}\n\n// Forked from https://gist.github.com/gre/296291b8ce0d8fe6e1c3ea4f1d1c5c3b\r\nvar regex = /(auto|scroll)/;\r\n\r\nvar style = function (node, prop) { return getComputedStyle(node, null).getPropertyValue(prop); };\r\n\r\nvar scroll = function (node) { return regex.test(\r\n style(node, \"overflow\") +\r\n style(node, \"overflow-y\") +\r\n style(node, \"overflow-x\")); };\r\n\r\nvar scrollparent = function (node) { return !node || node===document.body\r\n ? document.body\r\n : scroll(node)\r\n ? node\r\n : scrollparent(node.parentNode); };\n\n// Forked from https://github.com/bennadel/JavaScript-Demos/blob/master/demos/window-edge-scrolling/index.htm\r\n// Code was altered to work with scrollable containers\r\n\r\nvar timer = null;\r\n\r\nfunction cancelScrollAction () {\r\n clearTimeout(timer);\r\n}\r\n\r\nfunction performEdgeScroll(event, container, clientX, clientY, edgeSize) {\r\n if (!container || !edgeSize) {\r\n cancelScrollAction();\r\n return false;\r\n }\r\n \r\n // NOTE: Much of the information here, with regard to document dimensions,\r\n // viewport dimensions, and window scrolling is derived from JavaScript.info.\r\n // I am consuming it here primarily as NOTE TO SELF.\r\n // --\r\n // Read More: https://javascript.info/size-and-scroll-window\r\n // --\r\n // CAUTION: The viewport and document dimensions can all be CACHED and then\r\n // recalculated on window-resize events (for the most part). I am keeping it\r\n // all here in the mousemove event handler to remove as many of the moving\r\n // parts as possible and keep the demo as simple as possible.\r\n \r\n // Get the viewport-relative coordinates of the mousemove event.\r\n var rect = container.getBoundingClientRect();\r\n var isBody = container === document.body;\r\n \r\n var viewportX = clientX - rect.left;\r\n var viewportY = clientY - rect.top;\r\n if (isBody) {\r\n viewportX = clientX;\r\n viewportY = clientY;\r\n }\r\n \r\n // Get the viewport dimensions.\r\n var viewportWidth = rect.width;\r\n var viewportHeight = rect.height;\r\n if (isBody) {\r\n viewportWidth = document.documentElement.clientWidth;\r\n viewportHeight = document.documentElement.clientHeight;\r\n }\r\n \r\n // Next, we need to determine if the mouse is within the \"edge\" of the\r\n // viewport, which may require scrolling the window. To do this, we need to\r\n // calculate the boundaries of the edge in the viewport (these coordinates\r\n // are relative to the viewport grid system).\r\n var edgeTop = edgeSize;\r\n var edgeLeft = edgeSize;\r\n var edgeBottom = ( viewportHeight - edgeSize );\r\n var edgeRight = ( viewportWidth - edgeSize );\r\n \r\n var isInLeftEdge = ( viewportX < edgeLeft );\r\n var isInRightEdge = ( viewportX > edgeRight );\r\n var isInTopEdge = ( viewportY < edgeTop );\r\n var isInBottomEdge = ( viewportY > edgeBottom );\r\n \r\n // If the mouse is not in the viewport edge, there's no need to calculate\r\n // anything else.\r\n if (!(isInLeftEdge || isInRightEdge || isInTopEdge || isInBottomEdge)) {\r\n cancelScrollAction();\r\n return false;\r\n }\r\n \r\n // If we made it this far, the user's mouse is located within the edge of the\r\n // viewport. As such, we need to check to see if scrolling needs to be done.\r\n \r\n // Get the document dimensions.\r\n var documentWidth = Math.max(\r\n container.scrollWidth,\r\n container.offsetWidth,\r\n container.clientWidth\r\n );\r\n var documentHeight = Math.max(\r\n container.scrollHeight,\r\n container.offsetHeight,\r\n container.clientHeight\r\n );\r\n \r\n // Calculate the maximum scroll offset in each direction. Since you can only\r\n // scroll the overflow portion of the document, the maximum represents the\r\n // length of the document that is NOT in the viewport.\r\n var maxScrollX = (documentWidth - viewportWidth);\r\n var maxScrollY = (documentHeight - viewportHeight);\r\n \r\n // As we examine the mousemove event, we want to adjust the window scroll in\r\n // immediate response to the event; but, we also want to continue adjusting\r\n // the window scroll if the user rests their mouse in the edge boundary. To\r\n // do this, we'll invoke the adjustment logic immediately. Then, we'll setup\r\n // a timer that continues to invoke the adjustment logic while the window can\r\n // still be scrolled in a particular direction.\r\n (function checkForWindowScroll() {\r\n cancelScrollAction();\r\n \r\n if (adjustWindowScroll()) {\r\n timer = setTimeout( checkForWindowScroll, 30 );\r\n }\r\n })();\r\n \r\n // Adjust the window scroll based on the user's mouse position. Returns True\r\n // or False depending on whether or not the window scroll was changed.\r\n function adjustWindowScroll() {\r\n // Get the current scroll position of the document.\r\n var currentScrollX = container.scrollLeft;\r\n var currentScrollY = container.scrollTop;\r\n if (isBody) {\r\n currentScrollX = window.pageXOffset;\r\n currentScrollY = window.pageYOffset;\r\n }\r\n \r\n // Determine if the window can be scrolled in any particular direction.\r\n var canScrollUp = (currentScrollY > 0);\r\n var canScrollDown = (currentScrollY < maxScrollY);\r\n var canScrollLeft = (currentScrollX > 0);\r\n var canScrollRight = (currentScrollX < maxScrollX);\r\n \r\n // Since we can potentially scroll in two directions at the same time,\r\n // let's keep track of the next scroll, starting with the current scroll.\r\n // Each of these values can then be adjusted independently in the logic\r\n // below.\r\n var nextScrollX = currentScrollX;\r\n var nextScrollY = currentScrollY;\r\n \r\n // As we examine the mouse position within the edge, we want to make the\r\n // incremental scroll changes more \"intense\" the closer that the user\r\n // gets the viewport edge. As such, we'll calculate the percentage that\r\n // the user has made it \"through the edge\" when calculating the delta.\r\n // Then, that use that percentage to back-off from the \"max\" step value.\r\n var maxStep = 50;\r\n \r\n // Should we scroll left?\r\n if (isInLeftEdge && canScrollLeft) {\r\n var intensity = ((edgeLeft - viewportX) / edgeSize);\r\n nextScrollX = (nextScrollX - (maxStep * intensity));\r\n }\r\n // Should we scroll right?\r\n else if (isInRightEdge && canScrollRight) {\r\n var intensity = ((viewportX - edgeRight) / edgeSize);\r\n nextScrollX = (nextScrollX + (maxStep * intensity));\r\n }\r\n \r\n // Should we scroll up?\r\n if (isInTopEdge && canScrollUp) {\r\n var intensity = ((edgeTop - viewportY) / edgeSize);\r\n nextScrollY = (nextScrollY - (maxStep * intensity));\r\n }\r\n // Should we scroll down?\r\n else if (isInBottomEdge && canScrollDown) {\r\n var intensity = ((viewportY - edgeBottom) / edgeSize);\r\n nextScrollY = (nextScrollY + (maxStep * intensity));\r\n }\r\n \r\n // Sanitize invalid maximums. An invalid scroll offset won't break the\r\n // subsequent .scrollTo() call; however, it will make it harder to\r\n // determine if the .scrollTo() method should have been called in the\r\n // first place.\r\n nextScrollX = Math.max(0, Math.min(maxScrollX, nextScrollX));\r\n nextScrollY = Math.max(0, Math.min(maxScrollY, nextScrollY));\r\n \r\n if (\r\n (nextScrollX !== currentScrollX) ||\r\n (nextScrollY !== currentScrollY)\r\n ) {\r\n (isBody ? window : container).scrollTo(nextScrollX, nextScrollY);\r\n return true;\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n \r\n return true\r\n}\n\nvar DragMixin = /** @class */ (function (_super) {\r\n __extends(DragMixin, _super);\r\n function DragMixin() {\r\n var _this = _super !== null && _super.apply(this, arguments) || this;\r\n _this.dragInitialised = false;\r\n _this.dragStarted = false;\r\n _this.ignoreNextClick = false;\r\n _this.initialUserSelect = null;\r\n _this.downEvent = null;\r\n _this.startPosition = null;\r\n _this.delayTimer = null;\r\n _this.scrollContainer = null;\r\n return _this;\r\n }\r\n DragMixin.prototype.onSelectStart = function (e) {\r\n e.stopPropagation();\r\n e.preventDefault();\r\n };\r\n DragMixin.prototype.performVibration = function () {\r\n // If browser can perform vibration and user has defined a vibration, perform it\r\n if (this.vibration > 0 && window.navigator && window.navigator.vibrate) {\r\n window.navigator.vibrate(this.vibration);\r\n }\r\n };\r\n DragMixin.prototype.onMouseDown = function (e) {\r\n var _this = this;\r\n var target;\r\n var goodButton;\r\n if (e.type === 'mousedown') {\r\n var mouse = e;\r\n target = e.target;\r\n goodButton = mouse.buttons === 1;\r\n }\r\n else {\r\n var touch = e;\r\n target = touch.touches[0].target;\r\n goodButton = true;\r\n }\r\n if (this.disabled || this.downEvent !== null || !goodButton) {\r\n return;\r\n }\r\n // Check that the target element is eligible for starting a drag\r\n // Includes checking against the handle selector\r\n // or whether the element contains 'dnd-no-drag' class (which should disable dragging from that\r\n // sub-element of a draggable parent)\r\n var goodTarget = !target.matches('.dnd-no-drag, .dnd-no-drag *') &&\r\n (!this.handle ||\r\n target.matches(this.handle + ', ' + this.handle + ' *'));\r\n if (!goodTarget) {\r\n return;\r\n }\r\n this.scrollContainer = scrollparent(target);\r\n this.initialUserSelect = document.body.style.userSelect;\r\n document.documentElement.style.userSelect = 'none'; // Permet au drag de se poursuivre normalement même\r\n // quand on quitte un élémént avec overflow: hidden.\r\n this.dragStarted = false;\r\n this.downEvent = e;\r\n if (this.downEvent.type === 'mousedown') {\r\n var mouse = event;\r\n this.startPosition = {\r\n x: mouse.clientX,\r\n y: mouse.clientY\r\n };\r\n }\r\n else {\r\n var touch = event;\r\n this.startPosition = {\r\n x: touch.touches[0].clientX,\r\n y: touch.touches[0].clientY\r\n };\r\n }\r\n if (!!this.delay) {\r\n this.dragInitialised = false;\r\n clearTimeout(this.delayTimer);\r\n this.delayTimer = setTimeout(function () {\r\n _this.dragInitialised = true;\r\n _this.performVibration();\r\n }, this.delay);\r\n }\r\n else {\r\n this.dragInitialised = true;\r\n this.performVibration();\r\n }\r\n document.addEventListener('click', this.onMouseClick, true);\r\n document.addEventListener('mouseup', this.onMouseUp);\r\n document.addEventListener('touchend', this.onMouseUp);\r\n document.addEventListener('selectstart', this.onSelectStart);\r\n document.addEventListener('keyup', this.onKeyUp);\r\n setTimeout(function () {\r\n document.addEventListener('mousemove', _this.onMouseMove);\r\n document.addEventListener('touchmove', _this.onMouseMove, { passive: false });\r\n document.addEventListener('easy-dnd-move', _this.onEasyDnDMove);\r\n }, 0);\r\n // Prevents event from bubbling to ancestor drag components and initiate several drags at the same time\r\n e.stopPropagation();\r\n };\r\n // Prevent the user from accidentally causing a click event\r\n // if they have just attempted a drag event\r\n DragMixin.prototype.onMouseClick = function (e) {\r\n if (this.ignoreNextClick) {\r\n e.preventDefault();\r\n e.stopPropagation && e.stopPropagation();\r\n e.stopImmediatePropagation && e.stopImmediatePropagation();\r\n this.ignoreNextClick = false;\r\n return false;\r\n }\r\n };\r\n DragMixin.prototype.onMouseMove = function (e) {\r\n // We ignore the mousemove event that follows touchend :\r\n if (this.downEvent === null)\r\n { return; }\r\n // On touch devices, we ignore fake mouse events and deal with touch events only.\r\n if (this.downEvent.type === 'touchstart' && e.type === 'mousemove')\r\n { return; }\r\n // Find out event target and pointer position :\r\n var target;\r\n var x;\r\n var y;\r\n if (e.type === 'touchmove') {\r\n var touch = e;\r\n x = touch.touches[0].clientX;\r\n y = touch.touches[0].clientY;\r\n target = document.elementFromPoint(x, y);\r\n if (!target) {\r\n // Mouse going off screen. Ignore event.\r\n return;\r\n }\r\n }\r\n else {\r\n var mouse = e;\r\n x = mouse.clientX;\r\n y = mouse.clientY;\r\n target = mouse.target;\r\n }\r\n // Distance between current event and start position :\r\n var dist = Math.sqrt(Math.pow(this.startPosition.x - x, 2) + Math.pow(this.startPosition.y - y, 2));\r\n // If the drag has not begun yet and distance from initial point is greater than delta, we start the drag :\r\n if (!this.dragStarted && dist > this.delta) {\r\n // If they have dragged greater than the delta before the delay period has ended,\r\n // It means that they attempted to perform another action (such as scrolling) on the page\r\n if (!this.dragInitialised) {\r\n clearTimeout(this.delayTimer);\r\n }\r\n else {\r\n this.ignoreNextClick = true;\r\n this.dragStarted = true;\r\n dnd.startDrag(this, this.downEvent, this.startPosition.x, this.startPosition.y, this.type, this.data);\r\n document.documentElement.classList.add('drag-in-progress');\r\n }\r\n }\r\n // Dispatch custom easy-dnd-move event :\r\n if (this.dragStarted) {\r\n // If cursor/touch is at edge of container, perform scroll if available\r\n // If this.dragTop is defined, it means they are dragging on top of another DropList/EasyDnd component\r\n // if dropTop is a DropList, use the scrollingEdgeSize of that container if it exists, otherwise use the scrollingEdgeSize of the Drag component\r\n var currEdgeSize = this.dragTop && this.dragTop.$props.scrollingEdgeSize !== undefined ?\r\n this.dragTop.$props.scrollingEdgeSize :\r\n this.scrollingEdgeSize;\r\n if (!!currEdgeSize) {\r\n var currScrollContainer = this.dragTop ? scrollparent(this.dragTop.$el) : this.scrollContainer;\r\n performEdgeScroll(e, currScrollContainer, x, y, currEdgeSize);\r\n }\r\n else {\r\n cancelScrollAction();\r\n }\r\n var custom = new CustomEvent(\"easy-dnd-move\", {\r\n bubbles: true,\r\n cancelable: true,\r\n detail: {\r\n x: x,\r\n y: y,\r\n native: e\r\n }\r\n });\r\n target.dispatchEvent(custom);\r\n }\r\n // Prevent scroll on touch devices if they were performing a drag\r\n if (this.dragInitialised && e.cancelable) {\r\n e.preventDefault();\r\n }\r\n };\r\n DragMixin.prototype.onEasyDnDMove = function (e) {\r\n dnd.mouseMove(e, null);\r\n };\r\n DragMixin.prototype.onMouseUp = function (e) {\r\n var _this = this;\r\n // On touch devices, we ignore fake mouse events and deal with touch events only.\r\n if (this.downEvent.type === 'touchstart' && e.type === 'mouseup')\r\n { return; }\r\n // This delay makes sure that when the click event that results from the mouseup is produced, the drag is\r\n // still in progress. So by checking the flag dnd.inProgress, one can tell apart true clicks from drag and\r\n // drop artefacts.\r\n setTimeout(function () {\r\n _this.cancelDragActions();\r\n if (_this.dragStarted) {\r\n dnd.stopDrag(e);\r\n }\r\n _this.finishDrag();\r\n }, 0);\r\n };\r\n DragMixin.prototype.onKeyUp = function (e) {\r\n var _this = this;\r\n // If ESC is pressed, cancel the drag\r\n if (e.key === 'Escape') {\r\n this.cancelDragActions();\r\n setTimeout(function () {\r\n dnd.cancelDrag(e);\r\n _this.finishDrag();\r\n }, 0);\r\n }\r\n };\r\n DragMixin.prototype.cancelDragActions = function () {\r\n this.dragInitialised = false;\r\n clearTimeout(this.delayTimer);\r\n cancelScrollAction();\r\n };\r\n DragMixin.prototype.finishDrag = function () {\r\n this.downEvent = null;\r\n this.scrollContainer = null;\r\n if (this.dragStarted) {\r\n document.documentElement.classList.remove('drag-in-progress');\r\n }\r\n document.removeEventListener('click', this.onMouseClick, true);\r\n document.removeEventListener('mousemove', this.onMouseMove);\r\n document.removeEventListener('touchmove', this.onMouseMove);\r\n document.removeEventListener('easy-dnd-move', this.onEasyDnDMove);\r\n document.removeEventListener('mouseup', this.onMouseUp);\r\n document.removeEventListener('touchend', this.onMouseUp);\r\n document.removeEventListener('selectstart', this.onSelectStart);\r\n document.removeEventListener('keyup', this.onKeyUp);\r\n document.documentElement.style.userSelect = this.initialUserSelect;\r\n };\r\n DragMixin.prototype.dndDragStart = function (ev) {\r\n if (ev.source === this) {\r\n this.$emit('dragstart', ev);\r\n }\r\n };\r\n DragMixin.prototype.dndDragEnd = function (ev) {\r\n if (ev.source === this) {\r\n this.$emit('dragend', ev);\r\n }\r\n };\r\n DragMixin.prototype.created = function () {\r\n dnd.on('dragstart', this.dndDragStart);\r\n dnd.on('dragend', this.dndDragEnd);\r\n };\r\n DragMixin.prototype.mounted = function () {\r\n this.$el.addEventListener('mousedown', this.onMouseDown);\r\n this.$el.addEventListener('touchstart', this.onMouseDown);\r\n };\r\n DragMixin.prototype.beforeDestroy = function () {\r\n dnd.off('dragstart', this.dndDragStart);\r\n dnd.off('dragend', this.dndDragEnd);\r\n this.$el.removeEventListener('mousedown', this.onMouseDown);\r\n this.$el.removeEventListener('touchstart', this.onMouseDown);\r\n };\r\n Object.defineProperty(DragMixin.prototype, \"cssClasses\", {\r\n get: function () {\r\n var clazz = {\r\n 'dnd-drag': true\r\n };\r\n if (!this.disabled) {\r\n return __assign(__assign({}, clazz), { 'drag-source': this.dragInProgress && this.dragSource === this, 'drag-mode-copy': this.currentDropMode === 'copy', 'drag-mode-cut': this.currentDropMode === 'cut', 'drag-mode-reordering': this.currentDropMode === 'reordering', 'drag-no-handle': !this.handle });\r\n }\r\n else {\r\n return clazz;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DragMixin.prototype, \"currentDropMode\", {\r\n get: function () {\r\n if (this.dragInProgress && this.dragSource === this) {\r\n if (this.dragTop && this.dragTop['dropAllowed']) {\r\n if (this.dragTop['reordering'])\r\n { return 'reordering'; }\r\n else\r\n { return this.dragTop['mode']; }\r\n }\r\n else {\r\n return null;\r\n }\r\n }\r\n else {\r\n return null;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n DragMixin.prototype.createDragImage = function (selfTransform) {\r\n var image;\r\n if (this.$scopedSlots['drag-image']) {\r\n var el = this.$refs['drag-image'] || document.createElement('div');\r\n if (el.childElementCount !== 1) {\r\n image = createDragImage(el);\r\n }\r\n else {\r\n image = createDragImage(el.children.item(0));\r\n }\r\n }\r\n else {\r\n image = createDragImage(this.$el);\r\n image.style.transform = selfTransform;\r\n }\r\n if (this.dragClass) {\r\n image.classList.add(this.dragClass);\r\n }\r\n image.classList.add('dnd-ghost');\r\n image['__opacity'] = this.dragImageOpacity;\r\n return image;\r\n };\r\n __decorate([\r\n Prop({ default: null, type: null }),\r\n __metadata(\"design:type\", String)\r\n ], DragMixin.prototype, \"type\", void 0);\r\n __decorate([\r\n Prop({ default: null, type: null }),\r\n __metadata(\"design:type\", Object)\r\n ], DragMixin.prototype, \"data\", void 0);\r\n __decorate([\r\n Prop({ default: 0.7, type: Number }),\r\n __metadata(\"design:type\", Object)\r\n ], DragMixin.prototype, \"dragImageOpacity\", void 0);\r\n __decorate([\r\n Prop({ default: false, type: Boolean }),\r\n __metadata(\"design:type\", Boolean)\r\n ], DragMixin.prototype, \"disabled\", void 0);\r\n __decorate([\r\n Prop({ default: false, type: Boolean }),\r\n __metadata(\"design:type\", Boolean)\r\n ], DragMixin.prototype, \"goBack\", void 0);\r\n __decorate([\r\n Prop({ required: false, type: String }),\r\n __metadata(\"design:type\", String)\r\n ], DragMixin.prototype, \"handle\", void 0);\r\n __decorate([\r\n Prop({ type: Number, default: 3 }),\r\n __metadata(\"design:type\", Number)\r\n ], DragMixin.prototype, \"delta\", void 0);\r\n __decorate([\r\n Prop({ type: Number, default: 0 }),\r\n __metadata(\"design:type\", Number)\r\n ], DragMixin.prototype, \"delay\", void 0);\r\n __decorate([\r\n Prop({ type: String, default: null }),\r\n __metadata(\"design:type\", String)\r\n ], DragMixin.prototype, \"dragClass\", void 0);\r\n __decorate([\r\n Prop({ type: Number, default: 0 }),\r\n __metadata(\"design:type\", Number)\r\n ], DragMixin.prototype, \"vibration\", void 0);\r\n __decorate([\r\n Prop({ type: Number, default: 100 }),\r\n __metadata(\"design:type\", Number)\r\n ], DragMixin.prototype, \"scrollingEdgeSize\", void 0);\r\n DragMixin = __decorate([\r\n Component({})\r\n ], DragMixin);\r\n return DragMixin;\r\n}(DragAwareMixin));\n\nvar Drag = /** @class */ (function (_super) {\r\n __extends(Drag, _super);\r\n function Drag() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n __decorate([\r\n Prop({ default: 'div', type: [String, Object, Function] }),\r\n __metadata(\"design:type\", Object)\r\n ], Drag.prototype, \"tag\", void 0);\r\n Drag = __decorate([\r\n Component({})\r\n ], Drag);\r\n return Drag;\r\n}(DragMixin));\n\nfunction normalizeComponent(template, style, script, scopeId, isFunctionalTemplate, moduleIdentifier\n/* server only */\n, shadowMode, createInjector, createInjectorSSR, createInjectorShadow) {\n if (typeof shadowMode !== 'boolean') {\n createInjectorSSR = createInjector;\n createInjector = shadowMode;\n shadowMode = false;\n } // Vue.extend constructor export interop.\n\n\n var options = typeof script === 'function' ? script.options : script; // render functions\n\n if (template && template.render) {\n options.render = template.render;\n options.staticRenderFns = template.staticRenderFns;\n options._compiled = true; // functional template\n\n if (isFunctionalTemplate) {\n options.functional = true;\n }\n } // scopedId\n\n\n if (scopeId) {\n options._scopeId = scopeId;\n }\n\n var hook;\n\n if (moduleIdentifier) {\n // server build\n hook = function hook(context) {\n // 2.3 injection\n context = context || // cached call\n this.$vnode && this.$vnode.ssrContext || // stateful\n this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext; // functional\n // 2.2 with runInNewContext: true\n\n if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {\n context = __VUE_SSR_CONTEXT__;\n } // inject component styles\n\n\n if (style) {\n style.call(this, createInjectorSSR(context));\n } // register component module identifier for async chunk inference\n\n\n if (context && context._registeredComponents) {\n context._registeredComponents.add(moduleIdentifier);\n }\n }; // used by ssr in case component is cached and beforeCreate\n // never gets called\n\n\n options._ssrRegister = hook;\n } else if (style) {\n hook = shadowMode ? function () {\n style.call(this, createInjectorShadow(this.$root.$options.shadowRoot));\n } : function (context) {\n style.call(this, createInjector(context));\n };\n }\n\n if (hook) {\n if (options.functional) {\n // register for functional component in vue file\n var originalRender = options.render;\n\n options.render = function renderWithStyleInjection(h, context) {\n hook.call(context);\n return originalRender(h, context);\n };\n } else {\n // inject component registration as beforeCreate hook\n var existing = options.beforeCreate;\n options.beforeCreate = existing ? [].concat(existing, hook) : [hook];\n }\n }\n\n return script;\n}\n\nvar normalizeComponent_1 = normalizeComponent;\n\nvar isOldIE = typeof navigator !== 'undefined' && /msie [6-9]\\\\b/.test(navigator.userAgent.toLowerCase());\nfunction createInjector(context) {\n return function (id, style) {\n return addStyle(id, style);\n };\n}\nvar HEAD;\nvar styles = {};\n\nfunction addStyle(id, css) {\n var group = isOldIE ? css.media || 'default' : id;\n var style = styles[group] || (styles[group] = {\n ids: new Set(),\n styles: []\n });\n\n if (!style.ids.has(id)) {\n style.ids.add(id);\n var code = css.source;\n\n if (css.map) {\n // https://developer.chrome.com/devtools/docs/javascript-debugging\n // this makes source maps inside style tags work properly in Chrome\n code += '\\n/*# sourceURL=' + css.map.sources[0] + ' */'; // http://stackoverflow.com/a/26603875\n\n code += '\\n/*# sourceMappingURL=data:application/json;base64,' + btoa(unescape(encodeURIComponent(JSON.stringify(css.map)))) + ' */';\n }\n\n if (!style.element) {\n style.element = document.createElement('style');\n style.element.type = 'text/css';\n if (css.media) { style.element.setAttribute('media', css.media); }\n\n if (HEAD === undefined) {\n HEAD = document.head || document.getElementsByTagName('head')[0];\n }\n\n HEAD.appendChild(style.element);\n }\n\n if ('styleSheet' in style.element) {\n style.styles.push(code);\n style.element.styleSheet.cssText = style.styles.filter(Boolean).join('\\n');\n } else {\n var index = style.ids.size - 1;\n var textNode = document.createTextNode(code);\n var nodes = style.element.childNodes;\n if (nodes[index]) { style.element.removeChild(nodes[index]); }\n if (nodes.length) { style.element.insertBefore(textNode, nodes[index]); }else { style.element.appendChild(textNode); }\n }\n }\n}\n\nvar browser = createInjector;\n\n/* script */\nvar __vue_script__ = Drag;\n\n/* template */\nvar __vue_render__ = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c(_vm.tag,_vm._g(_vm._b({tag:\"component\",class:_vm.cssClasses,scopedSlots:_vm._u([_vm._l((_vm.$scopedSlots),function(_,slot){return {key:slot,fn:function(scope){return [_vm._t(slot,null,null,scope)]}}})],null,true)},'component',_vm.$attrs,false),_vm.$listeners),[_vm._t(\"default\"),_vm._v(\" \"),_vm._v(\" \"),(_vm.dragInitialised)?_c('div',{ref:\"drag-image\",staticClass:\"__drag-image\"},[_vm._t(\"drag-image\")],2):_vm._e()],2)};\nvar __vue_staticRenderFns__ = [];\n\n /* style */\n var __vue_inject_styles__ = function (inject) {\n if (!inject) { return }\n inject(\"data-v-fb811e22_0\", { source: \".drop-allowed.drop-in *{cursor:inherit!important}.drop-forbidden.drop-in,.drop-forbidden.drop-in *{cursor:no-drop!important}.drag-no-handle:hover{cursor:move;cursor:grab}\", map: undefined, media: undefined })\n,inject(\"data-v-fb811e22_1\", { source: \"html.drag-in-progress *{cursor:move!important;cursor:grabbing!important}\", map: undefined, media: undefined })\n,inject(\"data-v-fb811e22_2\", { source: \".__drag-image[data-v-fb811e22]{position:fixed;top:-10000px;left:-10000px;will-change:left,top}\", map: undefined, media: undefined });\n\n };\n /* scoped */\n var __vue_scope_id__ = \"data-v-fb811e22\";\n /* module identifier */\n var __vue_module_identifier__ = undefined;\n /* functional template */\n var __vue_is_functional_template__ = false;\n /* style inject SSR */\n \n\n \n var Drag$1 = normalizeComponent_1(\n { render: __vue_render__, staticRenderFns: __vue_staticRenderFns__ },\n __vue_inject_styles__,\n __vue_script__,\n __vue_scope_id__,\n __vue_is_functional_template__,\n __vue_module_identifier__,\n browser,\n undefined\n );\n\nvar DropMixin = /** @class */ (function (_super) {\r\n __extends(DropMixin, _super);\r\n function DropMixin() {\r\n var _this = _super.call(this) || this;\r\n _this.isDrop = true;\r\n return _this;\r\n }\r\n DropMixin.prototype.effectiveAcceptsType = function (type) {\r\n if (this.acceptsType === null)\r\n { return true; }\r\n else if (typeof (this.acceptsType) === 'string')\r\n { return this.acceptsType === type; }\r\n else if (typeof (this.acceptsType) === 'object' && Array.isArray(this.acceptsType)) {\r\n return this.acceptsType.includes(type);\r\n }\r\n else {\r\n return this.acceptsType(type);\r\n }\r\n };\r\n DropMixin.prototype.effectiveAcceptsData = function (data, type) {\r\n return this.acceptsData(data, type);\r\n };\r\n DropMixin.prototype.created = function () {\r\n dnd.on(\"dragpositionchanged\", this.onDragPositionChanged);\r\n dnd.on(\"dragtopchanged\", this.onDragTopChanged);\r\n dnd.on(\"drop\", this.onDrop);\r\n dnd.on(\"dragend\", this.onDragEnd);\r\n };\r\n DropMixin.prototype.beforeDestroy = function () {\r\n dnd.off(\"dragpositionchanged\", this.onDragPositionChanged);\r\n dnd.off(\"dragtopchanged\", this.onDragTopChanged);\r\n dnd.off(\"drop\", this.onDrop);\r\n dnd.off(\"dragend\", this.onDragEnd);\r\n };\r\n DropMixin.prototype.onDragPositionChanged = function (event) {\r\n if (this === event.top) {\r\n this.$emit(\"dragover\", event);\r\n }\r\n };\r\n DropMixin.prototype.onDragTopChanged = function (event) {\r\n if (this === event.top) {\r\n this.$emit(\"dragenter\", event);\r\n }\r\n if (this === event.previousTop) {\r\n this.$emit(\"dragleave\", event);\r\n }\r\n };\r\n DropMixin.prototype.onDragEnd = function (event) {\r\n if (this === event.top) {\r\n this.$emit('dragend', event);\r\n }\r\n };\r\n DropMixin.prototype.onDrop = function (event) {\r\n if (this.dropIn && this.compatibleMode && this.dropAllowed) {\r\n this.doDrop(event);\r\n }\r\n };\r\n DropMixin.prototype.doDrop = function (event) {\r\n this.$emit('drop', event);\r\n event.source.$emit(this.mode, event);\r\n };\r\n DropMixin.prototype.mounted = function () {\r\n var el = this.$el;\r\n var comp = this;\r\n el.addEventListener('easy-dnd-move', onMouseMove);\r\n function onMouseMove(e) {\r\n dnd.mouseMove(e, comp);\r\n }\r\n };\r\n Object.defineProperty(DropMixin.prototype, \"compatibleMode\", {\r\n get: function () {\r\n if (this.dragInProgress) {\r\n return this.mode === 'copy' || dnd.sourceListeners.hasOwnProperty(this.mode);\r\n }\r\n else {\r\n return null;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DropMixin.prototype, \"dropIn\", {\r\n get: function () {\r\n if (this.dragInProgress) {\r\n return this.dragTop === this;\r\n }\r\n else {\r\n return null;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DropMixin.prototype, \"typeAllowed\", {\r\n get: function () {\r\n if (this.dragInProgress) {\r\n return this.effectiveAcceptsType(this.dragType);\r\n }\r\n else {\r\n return null;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DropMixin.prototype, \"dropAllowed\", {\r\n get: function () {\r\n if (this.dragInProgress) {\r\n if (this.typeAllowed) {\r\n return this.compatibleMode && this.effectiveAcceptsData(this.dragData, this.dragType);\r\n }\r\n else {\r\n return null;\r\n }\r\n }\r\n else {\r\n return null;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DropMixin.prototype, \"cssClasses\", {\r\n get: function () {\r\n var clazz = {\r\n 'dnd-drop': true\r\n };\r\n if (this.dropIn !== null) {\r\n clazz['drop-in'] = this.dropIn;\r\n clazz['drop-out'] = !this.dropIn;\r\n }\r\n if (this.typeAllowed !== null) {\r\n clazz['type-allowed'] = this.typeAllowed;\r\n clazz['type-forbidden'] = !this.typeAllowed;\r\n }\r\n if (this.dropAllowed !== null) {\r\n clazz['drop-allowed'] = this.dropAllowed;\r\n clazz['drop-forbidden'] = !this.dropAllowed;\r\n }\r\n return clazz;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DropMixin.prototype, \"cssStyle\", {\r\n get: function () {\r\n return {};\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n /**\r\n * Returns true if the current drop area participates in the current drag operation.\r\n */\r\n DropMixin.prototype.candidate = function (type, data, source) {\r\n return this.effectiveAcceptsType(type);\r\n };\r\n DropMixin.prototype.createDragImage = function () {\r\n var image;\r\n if (this.$refs['drag-image']) {\r\n var el = this.$refs['drag-image'];\r\n if (el.childElementCount !== 1) {\r\n image = createDragImage(el);\r\n }\r\n else {\r\n image = createDragImage(el.children.item(0));\r\n }\r\n image['__opacity'] = this.dragImageOpacity;\r\n image.classList.add('dnd-ghost');\r\n }\r\n else {\r\n image = 'source';\r\n }\r\n return image;\r\n };\r\n __decorate([\r\n Prop({ default: function () { return function () { return true; }; }, type: [String, Array, Function] }),\r\n __metadata(\"design:type\", Object)\r\n ], DropMixin.prototype, \"acceptsType\", void 0);\r\n __decorate([\r\n Prop({ default: function () { return true; }, type: Function }),\r\n __metadata(\"design:type\", Object)\r\n ], DropMixin.prototype, \"acceptsData\", void 0);\r\n __decorate([\r\n Prop({ default: 'copy' }),\r\n __metadata(\"design:type\", String)\r\n ], DropMixin.prototype, \"mode\", void 0);\r\n __decorate([\r\n Prop({ default: 0.7, type: Number }),\r\n __metadata(\"design:type\", Object)\r\n ], DropMixin.prototype, \"dragImageOpacity\", void 0);\r\n DropMixin = __decorate([\r\n Component({}),\r\n __metadata(\"design:paramtypes\", [])\r\n ], DropMixin);\r\n return DropMixin;\r\n}(DragAwareMixin));\n\nvar Drop = /** @class */ (function (_super) {\r\n __extends(Drop, _super);\r\n function Drop() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n Object.defineProperty(Drop.prototype, \"showDragImage\", {\r\n get: function () {\r\n return this.dragInProgress && this.typeAllowed && this.$scopedSlots['drag-image'];\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n __decorate([\r\n Prop({ default: 'div', type: [String, Object, Function] }),\r\n __metadata(\"design:type\", Object)\r\n ], Drop.prototype, \"tag\", void 0);\r\n Drop = __decorate([\r\n Component({})\r\n ], Drop);\r\n return Drop;\r\n}(DropMixin));\n\n/* script */\nvar __vue_script__$1 = Drop;\n\n/* template */\nvar __vue_render__$1 = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c(_vm.tag,_vm._g(_vm._b({tag:\"component\",class:_vm.cssClasses,style:(_vm.cssStyle),scopedSlots:_vm._u([_vm._l((_vm.$scopedSlots),function(_,slot){return {key:slot,fn:function(scope){return [_vm._t(slot,null,null,scope)]}}})],null,true)},'component',_vm.$attrs,false),_vm.$listeners),[_vm._t(\"default\"),_vm._v(\" \"),_vm._v(\" \"),(_vm.showDragImage)?_c('div',{ref:\"drag-image\",staticClass:\"__drag-image\"},[_vm._t(\"drag-image\",null,{\"type\":_vm.dragType,\"data\":_vm.dragData})],2):_vm._e()],2)};\nvar __vue_staticRenderFns__$1 = [];\n\n /* style */\n var __vue_inject_styles__$1 = function (inject) {\n if (!inject) { return }\n inject(\"data-v-1d9169a9_0\", { source: \".drop-allowed.drop-in,.drop-allowed.drop-in *{cursor:pointer!important}.drop-forbidden.drop-in,.drop-forbidden.drop-in *{cursor:no-drop!important}\", map: undefined, media: undefined })\n,inject(\"data-v-1d9169a9_1\", { source: \".__drag-image[data-v-1d9169a9]{position:fixed;top:-10000px;left:-10000px;will-change:left,top}\", map: undefined, media: undefined });\n\n };\n /* scoped */\n var __vue_scope_id__$1 = \"data-v-1d9169a9\";\n /* module identifier */\n var __vue_module_identifier__$1 = undefined;\n /* functional template */\n var __vue_is_functional_template__$1 = false;\n /* style inject SSR */\n \n\n \n var Drop$1 = normalizeComponent_1(\n { render: __vue_render__$1, staticRenderFns: __vue_staticRenderFns__$1 },\n __vue_inject_styles__$1,\n __vue_script__$1,\n __vue_scope_id__$1,\n __vue_is_functional_template__$1,\n __vue_module_identifier__$1,\n browser,\n undefined\n );\n\nvar DropMask = /** @class */ (function (_super) {\r\n __extends(DropMask, _super);\r\n function DropMask() {\r\n var _this = _super !== null && _super.apply(this, arguments) || this;\r\n _this.isDropMask = true;\r\n return _this;\r\n }\r\n DropMask.prototype.mounted = function () {\r\n var el = this.$el;\r\n var comp = this;\r\n el.addEventListener('easy-dnd-move', onMouseMove);\r\n function onMouseMove(e) {\r\n dnd.mouseMove(e, comp);\r\n }\r\n };\r\n DropMask.prototype.createDragImage = function () {\r\n return 'source';\r\n };\r\n __decorate([\r\n Prop({ default: 'div', type: [String, Object, Function] }),\r\n __metadata(\"design:type\", Object)\r\n ], DropMask.prototype, \"tag\", void 0);\r\n DropMask = __decorate([\r\n Component({})\r\n ], DropMask);\r\n return DropMask;\r\n}(DragAwareMixin));\n\n/* script */\nvar __vue_script__$2 = DropMask;\n\n/* template */\nvar __vue_render__$2 = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c(_vm.tag,_vm._g(_vm._b({tag:\"component\",scopedSlots:_vm._u([_vm._l((_vm.$scopedSlots),function(_,slot){return {key:slot,fn:function(scope){return [_vm._t(slot,null,null,scope)]}}})],null,true)},'component',_vm.$attrs,false),_vm.$listeners),[_vm._t(\"default\")],2)};\nvar __vue_staticRenderFns__$2 = [];\n\n /* style */\n var __vue_inject_styles__$2 = undefined;\n /* scoped */\n var __vue_scope_id__$2 = undefined;\n /* module identifier */\n var __vue_module_identifier__$2 = undefined;\n /* functional template */\n var __vue_is_functional_template__$2 = false;\n /* style inject */\n \n /* style inject SSR */\n \n\n \n var DropMask$1 = normalizeComponent_1(\n { render: __vue_render__$2, staticRenderFns: __vue_staticRenderFns__$2 },\n __vue_inject_styles__$2,\n __vue_script__$2,\n __vue_scope_id__$2,\n __vue_is_functional_template__$2,\n __vue_module_identifier__$2,\n undefined,\n undefined\n );\n\n/**\r\n * This class reacts to drag events emitted by the dnd object to manage a sequence of drag images and fade from one to the\r\n * other as the drag progresses.\r\n */\r\nvar DragImagesManager = /** @class */ (function (_super) {\r\n __extends(DragImagesManager, _super);\r\n function DragImagesManager() {\r\n var _this = _super.call(this) || this;\r\n _this.selfTransform = null;\r\n _this.clones = null;\r\n _this.source = null;\r\n _this.sourcePos = null;\r\n _this.sourceClone = null;\r\n dnd.on('dragstart', _this.onDragStart);\r\n dnd.on('dragtopchanged', _this.onDragTopChanged);\r\n dnd.on('dragpositionchanged', _this.onDragPositionChanged);\r\n dnd.on('dragend', _this.onDragEnd);\r\n return _this;\r\n }\r\n DragImagesManager.prototype.onDragStart = function (event) {\r\n // If go-back=true and it is still animating while they attempt another drag,\r\n // it will bug out. Best to clean up any existing elements on the page before\r\n // attempting to start the next animation\r\n this.cleanUp();\r\n this.sourcePos = {\r\n x: event.source.$el.getBoundingClientRect().left,\r\n y: event.source.$el.getBoundingClientRect().top\r\n };\r\n this.selfTransform = \"translate(-\" + (event.position.x - this.sourcePos.x) + \"px, -\" + (event.position.y - this.sourcePos.y) + \"px)\";\r\n this.clones = new Map();\r\n this.source = event.source;\r\n };\r\n DragImagesManager.prototype.onDragEnd = function (event) {\r\n var _this = this;\r\n Vue.nextTick(function () {\r\n if (!event.success && _this.source && _this.source['goBack']) {\r\n // Restore the drag image that is active when hovering outside any drop zone :\r\n var img_1 = _this.switch(null);\r\n // Move it back to its original place :\r\n window.requestAnimationFrame(function () {\r\n img_1.style.transition = \"all 0.5s\";\r\n window.requestAnimationFrame(function () {\r\n img_1.style.left = _this.sourcePos.x + \"px\";\r\n img_1.style.top = _this.sourcePos.y + \"px\";\r\n img_1.style.transform = \"translate(0,0)\";\r\n var handler = function () {\r\n _this.cleanUp();\r\n img_1.removeEventListener(\"transitionend\", handler);\r\n };\r\n img_1.addEventListener(\"transitionend\", handler);\r\n });\r\n });\r\n }\r\n else {\r\n _this.cleanUp();\r\n }\r\n });\r\n };\r\n DragImagesManager.prototype.cleanUp = function () {\r\n if (this.clones) {\r\n this.clones.forEach(function (clone) {\r\n if (clone.parentNode === document.body) {\r\n document.body.removeChild(clone);\r\n }\r\n });\r\n }\r\n if (this.sourceClone !== null) {\r\n if (this.sourceClone.parentNode === document.body) {\r\n document.body.removeChild(this.sourceClone);\r\n }\r\n }\r\n this.selfTransform = null;\r\n this.clones = null;\r\n this.source = null;\r\n this.sourceClone = null;\r\n this.sourcePos = null;\r\n };\r\n DragImagesManager.prototype.onDragTopChanged = function (event) {\r\n this.switch(event.top);\r\n };\r\n DragImagesManager.prototype.switch = function (top) {\r\n this.clones.forEach(function (clone) {\r\n clone.style.opacity = \"0\";\r\n });\r\n if (this.sourceClone) {\r\n this.sourceClone.style.opacity = \"0\";\r\n }\r\n var activeClone;\r\n if (top === null) {\r\n activeClone = this.getSourceClone();\r\n }\r\n else {\r\n if (!this.clones.has(top)) {\r\n var clone = top['createDragImage'](this.selfTransform);\r\n if (clone === 'source') {\r\n clone = this.getSourceClone();\r\n }\r\n else if (clone !== null) {\r\n clone.style.opacity = '0';\r\n document.body.appendChild(clone);\r\n }\r\n this.clones.set(top, clone);\r\n }\r\n activeClone = this.clones.get(top);\r\n }\r\n if (activeClone !== null) {\r\n activeClone.offsetWidth; // Forces browser reflow\r\n activeClone.style.opacity = activeClone['__opacity'];\r\n activeClone.style.visibility = 'visible';\r\n }\r\n return activeClone;\r\n };\r\n DragImagesManager.prototype.getSourceClone = function () {\r\n if (this.sourceClone === null) {\r\n this.sourceClone = this.source['createDragImage'](this.selfTransform);\r\n this.sourceClone.style.opacity = '0';\r\n document.body.appendChild(this.sourceClone);\r\n }\r\n return this.sourceClone;\r\n };\r\n DragImagesManager.prototype.onDragPositionChanged = function (event) {\r\n this.clones.forEach(function (clone) {\r\n clone.style.left = dnd.position.x + \"px\";\r\n clone.style.top = dnd.position.y + \"px\";\r\n });\r\n if (this.sourceClone) {\r\n this.sourceClone.style.left = dnd.position.x + \"px\";\r\n this.sourceClone.style.top = dnd.position.y + \"px\";\r\n }\r\n };\r\n DragImagesManager = __decorate([\r\n Component({}) // Necessary to set proper \"this\" context in event listeners.\r\n ,\r\n __metadata(\"design:paramtypes\", [])\r\n ], DragImagesManager);\r\n return DragImagesManager;\r\n}(Vue));\r\nnew DragImagesManager();\n\nvar DragFeedback = /** @class */ (function (_super) {\r\n __extends(DragFeedback, _super);\r\n function DragFeedback() {\r\n return _super !== null && _super.apply(this, arguments) || this;\r\n }\r\n DragFeedback = __decorate([\r\n Component({})\r\n ], DragFeedback);\r\n return DragFeedback;\r\n}(Vue));\n\n/* script */\nvar __vue_script__$3 = DragFeedback;\n\n/* template */\nvar __vue_render__$3 = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:\"DragFeedback\"},[_vm._t(\"default\")],2)};\nvar __vue_staticRenderFns__$3 = [];\n\n /* style */\n var __vue_inject_styles__$3 = undefined;\n /* scoped */\n var __vue_scope_id__$3 = \"data-v-0589f3cb\";\n /* module identifier */\n var __vue_module_identifier__$3 = undefined;\n /* functional template */\n var __vue_is_functional_template__$3 = false;\n /* style inject */\n \n /* style inject SSR */\n \n\n \n var DragFeedback$1 = normalizeComponent_1(\n { render: __vue_render__$3, staticRenderFns: __vue_staticRenderFns__$3 },\n __vue_inject_styles__$3,\n __vue_script__$3,\n __vue_scope_id__$3,\n __vue_is_functional_template__$3,\n __vue_module_identifier__$3,\n undefined,\n undefined\n );\n\nvar Grid = /** @class */ (function () {\r\n function Grid(collection, upToIndex, row, fromIndex) {\r\n var e_1, _a;\r\n this.magnets = [];\r\n this.reference = collection.item(0).parentNode;\r\n this.referenceOriginalPosition = {\r\n x: this.reference.getBoundingClientRect().left - this.reference.scrollLeft,\r\n y: this.reference.getBoundingClientRect().top - this.reference.scrollTop,\r\n };\r\n var index = 0;\r\n try {\r\n for (var collection_1 = __values(collection), collection_1_1 = collection_1.next(); !collection_1_1.done; collection_1_1 = collection_1.next()) {\r\n var child = collection_1_1.value;\r\n if (index > upToIndex)\r\n { break; }\r\n var rect = child.getBoundingClientRect();\r\n var hasNestedDrop = child.classList.contains(\"dnd-drop\") || child.getElementsByClassName(\"dnd-drop\").length > 0;\r\n var horizontal = null;\r\n if (hasNestedDrop) {\r\n if (row === 'auto') {\r\n // Auto mode not supported for now. Row or column must be defined explicitly if there are nested drop lists.\r\n throw new Error(\"Easy-DnD error : a drop list is missing one of these attributes : 'row' or 'column'.\");\r\n }\r\n else {\r\n horizontal = row === 'row';\r\n }\r\n }\r\n if (fromIndex === null) {\r\n // Inserting mode.\r\n this.magnets.push(hasNestedDrop ? this.before(rect, horizontal) : this.center(rect));\r\n }\r\n else {\r\n // Reordering mode.\r\n this.magnets.push(hasNestedDrop ? (fromIndex < index ? this.after : this.before)(rect, horizontal) : this.center(rect));\r\n }\r\n // Debug : show magnets :\r\n //document.body.insertAdjacentHTML(\"beforeend\", \"
\")\r\n index++;\r\n }\r\n }\r\n catch (e_1_1) { e_1 = { error: e_1_1 }; }\r\n finally {\r\n try {\r\n if (collection_1_1 && !collection_1_1.done && (_a = collection_1.return)) { _a.call(collection_1); }\r\n }\r\n finally { if (e_1) { throw e_1.error; } }\r\n }\r\n }\r\n /**\r\n * Returns the center of the rectangle.\r\n */\r\n Grid.prototype.center = function (rect) {\r\n return {\r\n x: rect.left + rect.width / 2,\r\n y: rect.top + rect.height / 2\r\n };\r\n };\r\n /**\r\n * When horizontal is true / false, returns middle of the left / top side of the rectangle.\r\n */\r\n Grid.prototype.before = function (rect, horizontal) {\r\n return horizontal ? {\r\n x: rect.left,\r\n y: rect.top + rect.height / 2\r\n } : {\r\n x: rect.left + rect.width / 2,\r\n y: rect.top\r\n };\r\n };\r\n /**\r\n * When horizontal is true / false, returns middle of the right / bottom side of the rectangle.\r\n */\r\n Grid.prototype.after = function (rect, horizontal) {\r\n return horizontal ? {\r\n x: rect.left + rect.width,\r\n y: rect.top + rect.height / 2\r\n } : {\r\n x: rect.left + rect.width / 2,\r\n y: rect.top + rect.height\r\n };\r\n };\r\n /**\r\n * In case the user scrolls during the drag, the position of the magnets are not what they used to be when the drag\r\n * started. A correction must be applied that takes into account the amount of scroll. This correction is the\r\n * difference between the current position of the parent element and its position when the drag started.\r\n */\r\n Grid.prototype.correction = function () {\r\n return {\r\n x: this.reference.getBoundingClientRect().left - this.reference.scrollLeft - this.referenceOriginalPosition.x,\r\n y: this.reference.getBoundingClientRect().top - this.reference.scrollTop - this.referenceOriginalPosition.y,\r\n };\r\n };\r\n Grid.prototype.closestIndex = function (position) {\r\n var x = position.x - this.correction().x;\r\n var y = position.y - this.correction().y;\r\n var minDist = 999999;\r\n var index = -1;\r\n for (var i = 0; i < this.magnets.length; i++) {\r\n var magnet = this.magnets[i];\r\n var dist = Math.sqrt(Math.pow(magnet.x - x, 2) + Math.pow(magnet.y - y, 2));\r\n if (dist < minDist) {\r\n minDist = dist;\r\n index = i;\r\n }\r\n }\r\n return index;\r\n };\r\n return Grid;\r\n}());\n\nvar DnDEvent = /** @class */ (function () {\r\n function DnDEvent() {\r\n }\r\n return DnDEvent;\r\n}());\r\nvar ReorderEvent = /** @class */ (function () {\r\n function ReorderEvent(from, to) {\r\n this.from = from;\r\n this.to = to;\r\n }\r\n ReorderEvent.prototype.apply = function (array) {\r\n var tmp = array[this.from];\r\n array.splice(this.from, 1);\r\n array.splice(this.to, 0, tmp);\r\n };\r\n return ReorderEvent;\r\n}());\r\nvar InsertEvent = /** @class */ (function () {\r\n function InsertEvent(type, data, index) {\r\n this.type = type;\r\n this.data = data;\r\n this.index = index;\r\n }\r\n return InsertEvent;\r\n}());\n\nvar DropList = /** @class */ (function (_super) {\r\n __extends(DropList, _super);\r\n function DropList() {\r\n var _this = _super !== null && _super.apply(this, arguments) || this;\r\n _this.grid = null;\r\n _this.forbiddenKeys = [];\r\n _this.feedbackKey = null;\r\n _this.fromIndex = null;\r\n return _this;\r\n }\r\n Object.defineProperty(DropList.prototype, \"rootTag\", {\r\n get: function () {\r\n if (this.noAnimations) {\r\n return this.tag ? this.tag : 'div';\r\n }\r\n else {\r\n return \"transition-group\";\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DropList.prototype, \"rootProps\", {\r\n get: function () {\r\n if (this.noAnimations) {\r\n return this.$attrs;\r\n }\r\n else {\r\n return {\r\n tag: this.tag,\r\n duration: { enter: 0, leave: 0 },\r\n css: false\r\n };\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DropList.prototype, \"rootListeners\", {\r\n get: function () {\r\n if (this.noAnimations) {\r\n return this.$listeners;\r\n }\r\n else {\r\n return {};\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n DropList.prototype.created = function () {\r\n dnd.on(\"dragstart\", this.onDragStart);\r\n dnd.on(\"dragend\", this.onDragEnd);\r\n };\r\n Object.defineProperty(DropList.prototype, \"direction\", {\r\n get: function () {\r\n if (this.row)\r\n { return 'row'; }\r\n if (this.column)\r\n { return 'column'; }\r\n return 'auto';\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n DropList.prototype.beforeDestroy = function () {\r\n dnd.off(\"dragstart\", this.onDragStart);\r\n dnd.off(\"dragend\", this.onDragEnd);\r\n };\r\n // Presence of feedback node in the DOM and of keys in the virtual DOM required => delayed until what\r\n // depends on drag data has been processed.\r\n DropList.prototype.refresh = function () {\r\n var _this = this;\r\n this.$nextTick(function () {\r\n _this.grid = _this.computeInsertingGrid();\r\n _this.feedbackKey = _this.computeFeedbackKey();\r\n _this.forbiddenKeys = _this.computeForbiddenKeys();\r\n });\r\n };\r\n DropList.prototype.onDragStart = function (event) {\r\n if (this.candidate(dnd.type, dnd.data, dnd.source)) {\r\n if (this.reordering) {\r\n this.fromIndex = Array.prototype.indexOf.call(event.source.$el.parentElement.children, event.source.$el);\r\n this.grid = this.computeReorderingGrid();\r\n }\r\n else {\r\n this.refresh();\r\n }\r\n }\r\n };\r\n DropList.prototype.onDragEnd = function () {\r\n this.fromIndex = null;\r\n this.feedbackKey = null;\r\n this.forbiddenKeys = null;\r\n this.grid = null;\r\n };\r\n Object.defineProperty(DropList.prototype, \"reordering\", {\r\n get: function () {\r\n if (dnd.inProgress) {\r\n return dnd.source.$el.parentElement === this.$el && this.$listeners.hasOwnProperty('reorder');\r\n }\r\n else {\r\n return null;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DropList.prototype, \"closestIndex\", {\r\n get: function () {\r\n if (this.grid) {\r\n return this.grid.closestIndex(dnd.position);\r\n }\r\n else {\r\n return null;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DropList.prototype, \"dropAllowed\", {\r\n get: function () {\r\n if (this.dragInProgress) {\r\n if (this.reordering) {\r\n return this.items.length > 1;\r\n }\r\n else {\r\n var superDropAllowed = DropMixin['options'].computed.dropAllowed.get.call(this);\r\n if (!superDropAllowed) {\r\n return false;\r\n }\r\n else {\r\n if (this.forbiddenKeys !== null && this.feedbackKey !== null) {\r\n return !this.forbiddenKeys.includes(this.feedbackKey);\r\n }\r\n else {\r\n return null;\r\n }\r\n }\r\n }\r\n }\r\n else {\r\n return null;\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DropList.prototype, \"itemsBeforeFeedback\", {\r\n get: function () {\r\n if (this.closestIndex === 0) {\r\n return [];\r\n }\r\n else {\r\n return this.items.slice(0, this.closestIndex);\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DropList.prototype, \"itemsAfterFeedback\", {\r\n get: function () {\r\n if (this.closestIndex === this.items.length) {\r\n return [];\r\n }\r\n else {\r\n return this.items.slice(this.closestIndex);\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DropList.prototype, \"itemsBeforeReorderingFeedback\", {\r\n get: function () {\r\n if (this.closestIndex <= this.fromIndex) {\r\n return this.items.slice(0, this.closestIndex);\r\n }\r\n else {\r\n return this.items.slice(0, this.closestIndex + 1);\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DropList.prototype, \"itemsAfterReorderingFeedback\", {\r\n get: function () {\r\n if (this.closestIndex <= this.fromIndex) {\r\n return this.items.slice(this.closestIndex);\r\n }\r\n else {\r\n return this.items.slice(this.closestIndex + 1);\r\n }\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DropList.prototype, \"reorderedItems\", {\r\n get: function () {\r\n var toIndex = this.closestIndex;\r\n var reordered = __spread(this.items);\r\n var temp = reordered[this.fromIndex];\r\n reordered.splice(this.fromIndex, 1);\r\n reordered.splice(toIndex, 0, temp);\r\n return reordered;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DropList.prototype, \"clazz\", {\r\n get: function () {\r\n return __assign({ 'drop-list': true, 'reordering': this.reordering === true, 'inserting': this.reordering === false }, (this.reordering === false ? this.cssClasses : { 'dnd-drop': true }));\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DropList.prototype, \"style\", {\r\n get: function () {\r\n return __assign({}, (this.reordering === false ? this.cssStyle : {}));\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DropList.prototype, \"showDragFeedback\", {\r\n get: function () {\r\n return this.dragInProgress && this.typeAllowed && !this.reordering;\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DropList.prototype, \"showInsertingDragImage\", {\r\n get: function () {\r\n return this.dragInProgress && this.typeAllowed && !this.reordering && this.$scopedSlots.hasOwnProperty(\"drag-image\");\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n Object.defineProperty(DropList.prototype, \"showReorderingDragImage\", {\r\n get: function () {\r\n return this.dragInProgress && this.reordering && this.$scopedSlots.hasOwnProperty(\"reordering-drag-image\");\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n DropList.prototype.doDrop = function (event) {\r\n if (this.reordering) {\r\n if (this.fromIndex !== this.closestIndex) {\r\n this.$emit('reorder', new ReorderEvent(this.fromIndex, this.closestIndex));\r\n }\r\n }\r\n else {\r\n DropMixin['options'].methods.doDrop.call(this, event);\r\n this.$emit('insert', new InsertEvent(event.type, event.data, this.closestIndex));\r\n }\r\n };\r\n DropList.prototype.candidate = function (type, data, source) {\r\n var _a;\r\n var superCandidate = (_a = DropMixin['options'].methods.candidate).call.apply(_a, __spread([this], arguments));\r\n return (superCandidate && (this.$listeners.hasOwnProperty(\"insert\") || this.$listeners.hasOwnProperty(\"drop\"))) || this.reordering;\r\n };\r\n DropList.prototype.computeForbiddenKeys = function () {\r\n var vnodes = this.noAnimations ? [] : this.$children[0].$vnode.context.$children[0].$slots.default;\r\n return vnodes\r\n .map(function (vn) { return vn.key; })\r\n .filter(function (k) { return k !== undefined && k !== 'drag-image' && k !== 'drag-feedback'; });\r\n };\r\n DropList.prototype.computeFeedbackKey = function () {\r\n return this.$refs['feedback']['$slots']['default'][0]['key'];\r\n };\r\n Object.defineProperty(DropList.prototype, \"hasReorderingFeedback\", {\r\n get: function () {\r\n return this.$scopedSlots.hasOwnProperty(\"reordering-feedback\");\r\n },\r\n enumerable: true,\r\n configurable: true\r\n });\r\n DropList.prototype.computeInsertingGrid = function () {\r\n var feedbackParent = this.$refs['feedback']['$el'];\r\n var feedback = feedbackParent.children[0];\r\n var clone = feedback.cloneNode(true);\r\n var tg = this.$el;\r\n if (tg.children.length > this.items.length) {\r\n tg.insertBefore(clone, tg.children[this.items.length]);\r\n }\r\n else {\r\n tg.appendChild(clone);\r\n }\r\n var grid = new Grid(tg.children, this.items.length, this.direction, null);\r\n tg.removeChild(clone);\r\n return grid;\r\n };\r\n DropList.prototype.computeReorderingGrid = function () {\r\n var tg = this.$el;\r\n return new Grid(tg.children, this.items.length - 1, this.direction, this.fromIndex);\r\n };\r\n DropList.prototype.createDragImage = function () {\r\n var image;\r\n if (this.$refs['drag-image']) {\r\n var el = this.$refs['drag-image'];\r\n var model = void 0;\r\n if (el.childElementCount !== 1) {\r\n model = el;\r\n }\r\n else {\r\n model = el.children.item(0);\r\n }\r\n var clone = model.cloneNode(true);\r\n var tg = this.$el;\r\n tg.appendChild(clone);\r\n image = createDragImage(clone);\r\n tg.removeChild(clone);\r\n image['__opacity'] = this.dragImageOpacity;\r\n image.classList.add('dnd-ghost');\r\n }\r\n else {\r\n image = 'source';\r\n }\r\n return image;\r\n };\r\n __decorate([\r\n Prop({ default: 'div', type: [String, Object, Function] }),\r\n __metadata(\"design:type\", Object)\r\n ], DropList.prototype, \"tag\", void 0);\r\n __decorate([\r\n Prop(),\r\n __metadata(\"design:type\", Array)\r\n ], DropList.prototype, \"items\", void 0);\r\n __decorate([\r\n Prop({ default: null }),\r\n __metadata(\"design:type\", Boolean)\r\n ], DropList.prototype, \"row\", void 0);\r\n __decorate([\r\n Prop({ default: null, type: Boolean }),\r\n __metadata(\"design:type\", Boolean)\r\n ], DropList.prototype, \"column\", void 0);\r\n __decorate([\r\n Prop({ default: false, type: Boolean }),\r\n __metadata(\"design:type\", Boolean)\r\n ], DropList.prototype, \"noAnimations\", void 0);\r\n __decorate([\r\n Prop({ type: Number, default: undefined }),\r\n __metadata(\"design:type\", Number)\r\n ], DropList.prototype, \"scrollingEdgeSize\", void 0);\r\n DropList = __decorate([\r\n Component({\r\n components: { DragFeedback: DragFeedback$1 },\r\n inheritAttrs: false\r\n })\r\n ], DropList);\r\n return DropList;\r\n}(DropMixin));\n\n/* script */\nvar __vue_script__$4 = DropList;\n\n/* template */\nvar __vue_render__$4 = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c(_vm.rootTag,_vm._g(_vm._b({tag:\"component\",class:_vm.clazz,style:(_vm.style)},'component',_vm.rootProps,false),_vm.rootListeners),[(_vm.dropIn && _vm.dropAllowed)?[(_vm.reordering)?[(_vm.hasReorderingFeedback)?[_vm._l((_vm.itemsBeforeReorderingFeedback),function(item,index){return _vm._t(\"item\",null,{\"item\":item,\"index\":index})}),_vm._v(\" \"),_vm._t(\"reordering-feedback\",null,{\"item\":_vm.items[_vm.fromIndex]}),_vm._v(\" \"),_vm._l((_vm.itemsAfterReorderingFeedback),function(item,index){return _vm._t(\"item\",null,{\"item\":item,\"index\":_vm.itemsBeforeReorderingFeedback.length + index})})]:[_vm._l((_vm.reorderedItems),function(item,index){return _vm._t(\"item\",null,{\"item\":item,\"index\":index,\"reorder\":index === _vm.closestIndex})})]]:[_vm._l((_vm.itemsBeforeFeedback),function(item,index){return _vm._t(\"item\",null,{\"item\":item,\"reorder\":false,\"index\":index})}),_vm._v(\" \"),_vm._t(\"feedback\",null,{\"data\":_vm.dragData,\"type\":_vm.dragType}),_vm._v(\" \"),_vm._l((_vm.itemsAfterFeedback),function(item,index){return _vm._t(\"item\",null,{\"item\":item,\"reorder\":false,\"index\":_vm.itemsBeforeFeedback.length + index})})]]:[_vm._l((_vm.items),function(item,index){return _vm._t(\"item\",null,{\"item\":item,\"reorder\":false,\"index\":index})}),_vm._v(\" \"),(_vm.items.length < 1)?_vm._t(\"empty\"):_vm._e()],_vm._v(\" \"),(_vm.showDragFeedback)?_c('drag-feedback',{key:\"drag-feedback\",ref:\"feedback\",staticClass:\"__feedback\"},[_vm._t(\"feedback\",null,{\"data\":_vm.dragData,\"type\":_vm.dragType})],2):_vm._e(),_vm._v(\" \"),(_vm.showInsertingDragImage)?_c('div',{key:\"inserting-drag-image\",ref:\"drag-image\",staticClass:\"__drag-image\"},[_vm._t(\"drag-image\",null,{\"type\":_vm.dragType,\"data\":_vm.dragData})],2):_vm._e(),_vm._v(\" \"),(_vm.showReorderingDragImage)?_c('div',{key:\"reordering-drag-image\",ref:\"drag-image\",staticClass:\"__drag-image\"},[_vm._t(\"reordering-drag-image\",null,{\"item\":_vm.items[_vm.fromIndex]})],2):_vm._e(),_vm._v(\" \"),_vm._t(\"default\")],2)};\nvar __vue_staticRenderFns__$4 = [];\n\n /* style */\n var __vue_inject_styles__$4 = function (inject) {\n if (!inject) { return }\n inject(\"data-v-228404f8_0\", { source: \".drop-list[data-v-228404f8]>*{transition:transform .2s}.__feedback[data-v-228404f8]{display:none}.__drag-image[data-v-228404f8]{position:fixed;top:-10000px;left:-10000px;will-change:left,top}\", map: undefined, media: undefined })\n,inject(\"data-v-228404f8_1\", { source: \".drop-allowed.drop-in *{cursor:inherit!important}.drop-forbidden.drop-in,.drop-forbidden.drop-in *{cursor:no-drop!important}\", map: undefined, media: undefined });\n\n };\n /* scoped */\n var __vue_scope_id__$4 = \"data-v-228404f8\";\n /* module identifier */\n var __vue_module_identifier__$4 = undefined;\n /* functional template */\n var __vue_is_functional_template__$4 = false;\n /* style inject SSR */\n \n\n \n var DropList$1 = normalizeComponent_1(\n { render: __vue_render__$4, staticRenderFns: __vue_staticRenderFns__$4 },\n __vue_inject_styles__$4,\n __vue_script__$4,\n __vue_scope_id__$4,\n __vue_is_functional_template__$4,\n __vue_module_identifier__$4,\n browser,\n undefined\n );\n\nexport { DnDEvent, Drag$1 as Drag, DragAwareMixin, DragImagesManager, DragMixin, Drop$1 as Drop, DropList$1 as DropList, DropMask$1 as DropMask, DropMixin, InsertEvent, ReorderEvent, createDragImage, dnd };\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumDocumentFileType } from \"./enums/enumDocumentFileType.generated\";\nimport { EnumDocumentTagType } from \"./enums/enumDocumentTagType.generated\";\nimport { EnumDocumentType } from \"./enums/enumDocumentType.generated\";\n\n// Model Objects\n\nexport class DataTag extends ModelObject {\n\n public tagKey: string = \"\";\n public tagType: EnumDocumentTagType = EnumDocumentTagType.string;\n private _stringVal: string | null = null;\n public get stringVal(): string | null { return this._stringVal }\n public set stringVal(value: string | null) {\n this._stringVal = value === undefined ? null : value;\n }\n private _integerVal: number | null = null;\n public get integerVal(): number | null { return this._integerVal }\n public set integerVal(value: number | null) {\n this._integerVal = value === undefined ? null : value;\n }\n private _longVal: number | null = null;\n public get longVal(): number | null { return this._longVal }\n public set longVal(value: number | null) {\n this._longVal = value === undefined ? null : value;\n }\n private _doubleVal: number | null = null;\n public get doubleVal(): number | null { return this._doubleVal }\n public set doubleVal(value: number | null) {\n this._doubleVal = value === undefined ? null : value;\n }\n private _booleanVal: boolean | null = null;\n public get booleanVal(): boolean | null { return this._booleanVal }\n public set booleanVal(value: boolean | null) {\n this._booleanVal = value === undefined ? null : value;\n }\n private _dateVal: LocalDate | null = null;\n public get dateVal(): LocalDate | null { return this._dateVal }\n public set dateVal(value: LocalDate | null) {\n this._dateVal = value === undefined ? null : value;\n }\n private _timeVal: LocalTime | null = null;\n public get timeVal(): LocalTime | null { return this._timeVal }\n public set timeVal(value: LocalTime | null) {\n this._timeVal = value === undefined ? null : value;\n }\n private _timestampVal: Instant | null = null;\n public get timestampVal(): Instant | null { return this._timestampVal }\n public set timestampVal(value: Instant | null) {\n this._timestampVal = value === undefined ? null : value;\n }\n private _imageVal: Uint8Array | null = null;\n public get imageVal(): Uint8Array | null { return this._imageVal }\n public set imageVal(value: Uint8Array | null) {\n this._imageVal = value === undefined ? null : value;\n }\n public arrayVal: DataTagSet[] = [];\n private _objectVal: DataTagSet | null = null;\n public get objectVal(): DataTagSet | null { return this._objectVal }\n public set objectVal(value: DataTagSet | null) {\n this._objectVal = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tagKey = jsonSerializedObject.tagKey;\n this.tagType = EnumDocumentTagType.getByValue(jsonSerializedObject.tagType, this.tagType);\n this.stringVal = jsonSerializedObject.stringVal == null ? null : jsonSerializedObject.stringVal;\n this.integerVal = jsonSerializedObject.integerVal == null ? null : jsonSerializedObject.integerVal;\n this.longVal = jsonSerializedObject.longVal == null ? null : jsonSerializedObject.longVal;\n this.doubleVal = jsonSerializedObject.doubleVal == null ? null : jsonSerializedObject.doubleVal;\n this.booleanVal = jsonSerializedObject.booleanVal == null ? null : jsonSerializedObject.booleanVal;\n this.dateVal = jsonSerializedObject.dateVal == null ? null : LocalDate.parse(jsonSerializedObject.dateVal);\n this.timeVal = jsonSerializedObject.timeVal == null ? null : LocalTime.parse(jsonSerializedObject.timeVal);\n this.timestampVal = jsonSerializedObject.timestampVal == null ? null : Instant.parse(jsonSerializedObject.timestampVal);\n this.imageVal = converters.base64ToUint8Array(jsonSerializedObject.imageVal);\n this.arrayVal = jsonSerializedObject.arrayVal.map((v: any) => new DataTagSet(v));\n this.objectVal = jsonSerializedObject.objectVal == null ? null : new DataTagSet(jsonSerializedObject.objectVal);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tagKey = this.tagKey;\n toRet.tagType = this.tagType.value;\n toRet.stringVal = this.stringVal == null ? null : this.stringVal;\n toRet.integerVal = this.integerVal == null ? null : this.integerVal;\n toRet.longVal = this.longVal == null ? null : this.longVal;\n toRet.doubleVal = this.doubleVal == null ? null : this.doubleVal;\n toRet.booleanVal = this.booleanVal == null ? null : this.booleanVal;\n toRet.dateVal = this.dateVal == null ? null : this.dateVal.toString();\n toRet.timeVal = this.timeVal == null ? null : this.timeVal.toString();\n toRet.timestampVal = this.timestampVal == null ? null : this.timestampVal.toString();\n toRet.imageVal = converters.uint8ArrayToBase64(this.imageVal);\n toRet.arrayVal = this.arrayVal.map(v => v.toJsonSerializedObject());\n toRet.objectVal = this.objectVal == null ? null : this.objectVal?.toJsonSerializedObject() ?? null;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"integerVal\", rule: (v: any) => v == null || v >= -2147483648 || \"IntegerVal is not greater than minimum allowed value: -2147483648\"},\n {field: \"integerVal\", rule: (v: any) => v == null || v <= 2147483647 || \"IntegerVal is above maximum allowed value: 2147483647\"},\n {field: \"longVal\", rule: (v: any) => v == null || v >= -9223372036854775808 || \"LongVal is not greater than minimum allowed value: -9223372036854775808\"},\n {field: \"longVal\", rule: (v: any) => v == null || v <= 9223372036854775807 || \"LongVal is above maximum allowed value: 9223372036854775807\"},\n {field: \"arrayVal\", rule: (v: any) => !!v || \"arrayVal is required\"},\n {field: \"arrayVal\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as DataTagSet[]).reduce((acc: Array, curr: DataTagSet) => acc.concat(curr.validate()), new Array());\n }},\n {field: \"objectVal\", rule: (v: any) => (v === null) || v.validate()},\n ];\n}\n\n\nexport class DataTagSet extends ModelObject {\n\n public tags: DataTag[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tags = jsonSerializedObject.tags.map((v: any) => new DataTag(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tags = this.tags.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tags\", rule: (v: any) => !!v || \"tags is required\"},\n {field: \"tags\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as DataTag[]).reduce((acc: Array, curr: DataTag) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class DocumentPart extends ModelObject {\n\n private _documentTemplateId: Guid | null = null;\n /**\n * Optional document template, otherwise it will use default\n */\n public get documentTemplateId(): Guid | null { return this._documentTemplateId }\n public set documentTemplateId(value: Guid | null) {\n this._documentTemplateId = value === undefined ? null : value;\n }\n public documentType: EnumDocumentType = EnumDocumentType.none;\n public dataTags: DataTag[] = [];\n /**\n * Will insert copies of this document into the final document\n */\n public numberOfExtraCopies: number = 0;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.documentTemplateId = jsonSerializedObject.documentTemplateId == null ? null : Guid.fromString(jsonSerializedObject.documentTemplateId);\n this.documentType = EnumDocumentType.getByValue(jsonSerializedObject.documentType, this.documentType);\n this.dataTags = jsonSerializedObject.dataTags.map((v: any) => new DataTag(v));\n this.numberOfExtraCopies = jsonSerializedObject.numberOfExtraCopies;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.documentTemplateId = this.documentTemplateId == null ? null : this.documentTemplateId.toString();\n toRet.documentType = this.documentType.value;\n toRet.dataTags = this.dataTags.map(v => v.toJsonSerializedObject());\n toRet.numberOfExtraCopies = this.numberOfExtraCopies;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"documentTemplateId\", rule: (v: any) => v == null || !v.isEmpty() || \"DocumentPart.DocumentTemplateId cannot be empty\"},\n {field: \"dataTags\", rule: (v: any) => !!v || \"dataTags is required\"},\n {field: \"dataTags\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as DataTag[]).reduce((acc: Array, curr: DataTag) => acc.concat(curr.validate()), new Array());\n }},\n {field: \"numberOfExtraCopies\", rule: (v: any) => v == null || v >= -2147483648 || \"NumberOfExtraCopies is not greater than minimum allowed value: -2147483648\"},\n {field: \"numberOfExtraCopies\", rule: (v: any) => v == null || v <= 2147483647 || \"NumberOfExtraCopies is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class GridRowValue extends ModelObject {\n\n public cells: string[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.cells = jsonSerializedObject.cells.map((v: any) => v);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.cells = this.cells.map(v => v);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GridGroupValue extends ModelObject {\n\n public groupName: string = \"\";\n public cells: string[] = [];\n public subGroups: GridGroupValue[] = [];\n public rows: GridRowValue[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.groupName = jsonSerializedObject.groupName;\n this.cells = jsonSerializedObject.cells.map((v: any) => v);\n this.subGroups = jsonSerializedObject.subGroups.map((v: any) => new GridGroupValue(v));\n this.rows = jsonSerializedObject.rows.map((v: any) => new GridRowValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.groupName = this.groupName;\n toRet.cells = this.cells.map(v => v);\n toRet.subGroups = this.subGroups.map(v => v.toJsonSerializedObject());\n toRet.rows = this.rows.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"subGroups\", rule: (v: any) => !!v || \"subGroups is required\"},\n {field: \"subGroups\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as GridGroupValue[]).reduce((acc: Array, curr: GridGroupValue) => acc.concat(curr.validate()), new Array());\n }},\n {field: \"rows\", rule: (v: any) => !!v || \"rows is required\"},\n {field: \"rows\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as GridRowValue[]).reduce((acc: Array, curr: GridRowValue) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GridShape extends ModelObject {\n\n public title: string = \"\";\n public columns: string[] = [];\n public grid: GridGroupValue[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.title = jsonSerializedObject.title;\n this.columns = jsonSerializedObject.columns.map((v: any) => v);\n this.grid = jsonSerializedObject.grid.map((v: any) => new GridGroupValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.title = this.title;\n toRet.columns = this.columns.map(v => v);\n toRet.grid = this.grid.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"grid\", rule: (v: any) => !!v || \"grid is required\"},\n {field: \"grid\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as GridGroupValue[]).reduce((acc: Array, curr: GridGroupValue) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GenerateDocumentRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n private _documentTemplateId: Guid | null = null;\n /**\n * Optional document template, otherwise it will use default\n */\n public get documentTemplateId(): Guid | null { return this._documentTemplateId }\n public set documentTemplateId(value: Guid | null) {\n this._documentTemplateId = value === undefined ? null : value;\n }\n public documentType: EnumDocumentType = EnumDocumentType.none;\n public dataTags: readonly DataTag[] = [];\n public documentFormat: EnumDocumentFileType = EnumDocumentFileType.pdf;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.documentTemplateId = jsonSerializedObject.documentTemplateId == null ? null : Guid.fromString(jsonSerializedObject.documentTemplateId);\n this.documentType = EnumDocumentType.getByValue(jsonSerializedObject.documentType, this.documentType);\n this.dataTags = jsonSerializedObject.dataTags.map((v: any) => new DataTag(v));\n this.documentFormat = EnumDocumentFileType.getByValue(jsonSerializedObject.documentFormat, this.documentFormat);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.documentTemplateId = this.documentTemplateId == null ? null : this.documentTemplateId.toString();\n toRet.documentType = this.documentType.value;\n toRet.dataTags = this.dataTags.map(v => v.toJsonSerializedObject());\n toRet.documentFormat = this.documentFormat.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"documentTemplateId\", rule: (v: any) => v == null || !v.isEmpty() || \".DocumentTemplateId cannot be empty\"},\n {field: \"dataTags\", rule: (v: any) => !!v || \"dataTags is required\"},\n {field: \"dataTags\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as DataTag[]).reduce((acc: Array, curr: DataTag) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GenerateDocumentResponse extends ModelObject {\n\n public fileBytes: Uint8Array = new Uint8Array();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.fileBytes = converters.base64ToUint8Array(jsonSerializedObject.fileBytes);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.fileBytes = converters.uint8ArrayToBase64(this.fileBytes);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GenerateDocumentsRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public documentFormat: EnumDocumentFileType = EnumDocumentFileType.pdf;\n public documentParts: readonly DocumentPart[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.documentFormat = EnumDocumentFileType.getByValue(jsonSerializedObject.documentFormat, this.documentFormat);\n this.documentParts = jsonSerializedObject.documentParts.map((v: any) => new DocumentPart(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.documentFormat = this.documentFormat.value;\n toRet.documentParts = this.documentParts.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"documentParts\", rule: (v: any) => !!v || \"documentParts is required\"},\n {field: \"documentParts\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as DocumentPart[]).reduce((acc: Array, curr: DocumentPart) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GenerateDocumentsResponse extends ModelObject {\n\n public fileBytes: Uint8Array = new Uint8Array();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.fileBytes = converters.base64ToUint8Array(jsonSerializedObject.fileBytes);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.fileBytes = converters.uint8ArrayToBase64(this.fileBytes);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GenerateGridDocumentRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public documentFormat: EnumDocumentFileType = EnumDocumentFileType.pdf;\n public title: string = \"\";\n public columns: readonly string[] = [];\n public grid: readonly GridGroupValue[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.documentFormat = EnumDocumentFileType.getByValue(jsonSerializedObject.documentFormat, this.documentFormat);\n this.title = jsonSerializedObject.title;\n this.columns = jsonSerializedObject.columns.map((v: any) => v);\n this.grid = jsonSerializedObject.grid.map((v: any) => new GridGroupValue(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.documentFormat = this.documentFormat.value;\n toRet.title = this.title;\n toRet.columns = this.columns.map(v => v);\n toRet.grid = this.grid.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"grid\", rule: (v: any) => !!v || \"grid is required\"},\n {field: \"grid\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as GridGroupValue[]).reduce((acc: Array, curr: GridGroupValue) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GenerateGridDocumentResponse extends ModelObject {\n\n public fileBytes: Uint8Array = new Uint8Array();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.fileBytes = converters.base64ToUint8Array(jsonSerializedObject.fileBytes);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.fileBytes = converters.uint8ArrayToBase64(this.fileBytes);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GenerateCsvFileRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public documentType: EnumDocumentType = EnumDocumentType.none;\n public fileTemplateContents: string = \"\";\n public dataTags: readonly DataTag[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.documentType = EnumDocumentType.getByValue(jsonSerializedObject.documentType, this.documentType);\n this.fileTemplateContents = jsonSerializedObject.fileTemplateContents;\n this.dataTags = jsonSerializedObject.dataTags.map((v: any) => new DataTag(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.documentType = this.documentType.value;\n toRet.fileTemplateContents = this.fileTemplateContents;\n toRet.dataTags = this.dataTags.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"dataTags\", rule: (v: any) => !!v || \"dataTags is required\"},\n {field: \"dataTags\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as DataTag[]).reduce((acc: Array, curr: DataTag) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GenerateCsvFileResponse extends ModelObject {\n\n public fileBytes: Uint8Array = new Uint8Array();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.fileBytes = converters.base64ToUint8Array(jsonSerializedObject.fileBytes);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.fileBytes = converters.uint8ArrayToBase64(this.fileBytes);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class PerformStringTemplateReplacementRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public documentType: EnumDocumentType = EnumDocumentType.none;\n public templateString: string = \"\";\n public dataTags: readonly DataTag[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.documentType = EnumDocumentType.getByValue(jsonSerializedObject.documentType, this.documentType);\n this.templateString = jsonSerializedObject.templateString;\n this.dataTags = jsonSerializedObject.dataTags.map((v: any) => new DataTag(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.documentType = this.documentType.value;\n toRet.templateString = this.templateString;\n toRet.dataTags = this.dataTags.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"dataTags\", rule: (v: any) => !!v || \"dataTags is required\"},\n {field: \"dataTags\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as DataTag[]).reduce((acc: Array, curr: DataTag) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class PerformStringTemplateReplacementResponse extends ModelObject {\n\n public result: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.result = jsonSerializedObject.result;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.result = this.result;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GetAllDataTagsByDocumentTypeRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public documentType: EnumDocumentType = EnumDocumentType.none;\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.documentType = EnumDocumentType.getByValue(jsonSerializedObject.documentType, this.documentType);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.documentType = this.documentType.value;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetAllDataTagsByDocumentTypeResponse extends ModelObject {\n\n public dataTags: string[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.dataTags = jsonSerializedObject.dataTags.map((v: any) => v);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.dataTags = this.dataTags.map(v => v);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class GenerateMultipleGridsDocumentRequest extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public documentFormat: EnumDocumentFileType = EnumDocumentFileType.pdf;\n public gridShapes: readonly GridShape[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.documentFormat = EnumDocumentFileType.getByValue(jsonSerializedObject.documentFormat, this.documentFormat);\n this.gridShapes = jsonSerializedObject.gridShapes.map((v: any) => new GridShape(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.documentFormat = this.documentFormat.value;\n toRet.gridShapes = this.gridShapes.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"gridShapes\", rule: (v: any) => !!v || \"gridShapes is required\"},\n {field: \"gridShapes\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as GridShape[]).reduce((acc: Array, curr: GridShape) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class GenerateMultipleGridsDocumentResponse extends ModelObject {\n\n public fileBytes: Uint8Array = new Uint8Array();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.fileBytes = converters.base64ToUint8Array(jsonSerializedObject.fileBytes);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.fileBytes = converters.uint8ArrayToBase64(this.fileBytes);\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n ];\n}\n\n\nexport class DocumentGenerationService extends ServiceBase {\n\n public async generateDocument(tenantId: Guid, documentTemplateId: Guid | null, documentType: EnumDocumentType, dataTags: readonly DataTag[], documentFormat: EnumDocumentFileType, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GenerateDocumentRequest();\n req.tenantId = tenantId;\n req.documentTemplateId = documentTemplateId;\n req.documentType = documentType;\n req.dataTags = dataTags;\n req.documentFormat = documentFormat;\n const extractor = (response:any) => new GenerateDocumentResponse(response).fileBytes;\n return this.makeJsonRequest(\"documentGeneration/v1/generateDocument\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async generateDocuments(tenantId: Guid, documentFormat: EnumDocumentFileType, documentParts: readonly DocumentPart[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GenerateDocumentsRequest();\n req.tenantId = tenantId;\n req.documentFormat = documentFormat;\n req.documentParts = documentParts;\n const extractor = (response:any) => new GenerateDocumentsResponse(response).fileBytes;\n return this.makeJsonRequest(\"documentGeneration/v1/generateDocuments\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async generateGridDocument(tenantId: Guid, documentFormat: EnumDocumentFileType, title: string, columns: readonly string[], grid: readonly GridGroupValue[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GenerateGridDocumentRequest();\n req.tenantId = tenantId;\n req.documentFormat = documentFormat;\n req.title = title;\n req.columns = columns;\n req.grid = grid;\n const extractor = (response:any) => new GenerateGridDocumentResponse(response).fileBytes;\n return this.makeJsonRequest(\"documentGeneration/v1/generateGridDocument\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getAllDataTagsByDocumentType(tenantId: Guid, documentType: EnumDocumentType, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetAllDataTagsByDocumentTypeRequest();\n req.tenantId = tenantId;\n req.documentType = documentType;\n const extractor = (response:any) => new GetAllDataTagsByDocumentTypeResponse(response).dataTags;\n return this.makeJsonRequest(\"documentGeneration/v1/getAllDataTagsByDocumentType\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async generateMultipleGridsDocument(tenantId: Guid, documentFormat: EnumDocumentFileType, gridShapes: readonly GridShape[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GenerateMultipleGridsDocumentRequest();\n req.tenantId = tenantId;\n req.documentFormat = documentFormat;\n req.gridShapes = gridShapes;\n const extractor = (response:any) => new GenerateMultipleGridsDocumentResponse(response).fileBytes;\n return this.makeJsonRequest(\"documentGeneration/v1/generateMultipleGridsDocument\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const documentGenerationService = new DocumentGenerationService();","var __spreadArrays = (this && this.__spreadArrays) || function () {\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\n r[k] = a[j];\n return r;\n};\n// Code copied from Vue/src/shared/util.js\nvar hyphenateRE = /\\B([A-Z])/g;\nvar hyphenate = function (str) { return str.replace(hyphenateRE, '-$1').toLowerCase(); };\n/**\n * decorator of an event-emitter function\n * @param event The name of the event\n * @return MethodDecorator\n */\nexport function Emit(event) {\n return function (_target, propertyKey, descriptor) {\n var key = hyphenate(propertyKey);\n var original = descriptor.value;\n descriptor.value = function emitter() {\n var _this = this;\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n var emit = function (returnValue) {\n var emitName = event || key;\n if (returnValue === undefined) {\n if (args.length === 0) {\n _this.$emit(emitName);\n }\n else if (args.length === 1) {\n _this.$emit(emitName, args[0]);\n }\n else {\n _this.$emit.apply(_this, __spreadArrays([emitName], args));\n }\n }\n else {\n args.unshift(returnValue);\n _this.$emit.apply(_this, __spreadArrays([emitName], args));\n }\n };\n var returnValue = original.apply(this, args);\n if (isPromise(returnValue)) {\n returnValue.then(emit);\n }\n else {\n emit(returnValue);\n }\n return returnValue;\n };\n };\n}\nfunction isPromise(obj) {\n return obj instanceof Promise || (obj && typeof obj.then === 'function');\n}\n","/** @see {@link https://github.com/vuejs/vue-class-component/blob/master/src/reflect.ts} */\nvar reflectMetadataIsSupported = typeof Reflect !== 'undefined' && typeof Reflect.getMetadata !== 'undefined';\nexport function applyMetadata(options, target, key) {\n if (reflectMetadataIsSupported) {\n if (!Array.isArray(options) &&\n typeof options !== 'function' &&\n !options.hasOwnProperty('type') &&\n typeof options.type === 'undefined') {\n var type = Reflect.getMetadata('design:type', target, key);\n if (type !== Object) {\n options.type = type;\n }\n }\n }\n}\n","import { createDecorator } from 'vue-class-component';\nimport { applyMetadata } from '../helpers/metadata';\n/**\n * decorator of a prop\n * @param options the options for the prop\n * @return PropertyDecorator | void\n */\nexport function Prop(options) {\n if (options === void 0) { options = {}; }\n return function (target, key) {\n applyMetadata(options, target, key);\n createDecorator(function (componentOptions, k) {\n ;\n (componentOptions.props || (componentOptions.props = {}))[k] = options;\n })(target, key);\n };\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\n/**\n * If value is undefined, null or blank, returns null, otherwise returns the value\n * @param {T} value\n * @returns {T | null}\n */\nexport function makeNull(value) {\n if (value == null || value === '') {\n return null;\n }\n return value;\n}\nexport function exists(value, allowEmptyString) {\n if (allowEmptyString === void 0) { allowEmptyString = false; }\n return value != null && (value !== '' || allowEmptyString);\n}\nexport function missing(value) {\n return !exists(value);\n}\nexport function missingOrEmpty(value) {\n return value == null || value.length === 0;\n}\nexport function toStringOrNull(value) {\n return value != null && typeof value.toString === 'function' ? value.toString() : null;\n}\n// for parsing html attributes, where we want empty strings and missing attributes to be undefined\nexport function attrToNumber(value) {\n if (value === undefined) {\n // undefined or empty means ignore the value\n return;\n }\n if (value === null || value === '') {\n // null or blank means clear\n return null;\n }\n if (typeof value === 'number') {\n return isNaN(value) ? undefined : value;\n }\n var valueParsed = parseInt(value, 10);\n return isNaN(valueParsed) ? undefined : valueParsed;\n}\n// for parsing html attributes, where we want empty strings and missing attributes to be undefined\nexport function attrToBoolean(value) {\n if (value === undefined) {\n // undefined or empty means ignore the value\n return;\n }\n if (value === null || value === '') {\n // null means clear\n return false;\n }\n if (typeof value === 'boolean') {\n // if simple boolean, return the boolean\n return value;\n }\n // if equal to the string 'true' (ignoring case) then return true\n return (/true/i).test(value);\n}\n// for parsing html attributes, where we want empty strings and missing attributes to be undefined\nexport function attrToString(value) {\n if (value == null || value === '') {\n return;\n }\n return value;\n}\n/** @deprecated */\nexport function referenceCompare(left, right) {\n if (left == null && right == null) {\n return true;\n }\n if (left == null && right != null) {\n return false;\n }\n if (left != null && right == null) {\n return false;\n }\n return left === right;\n}\nexport function jsonEquals(val1, val2) {\n var val1Json = val1 ? JSON.stringify(val1) : null;\n var val2Json = val2 ? JSON.stringify(val2) : null;\n return val1Json === val2Json;\n}\nexport function defaultComparator(valueA, valueB, accentedCompare) {\n if (accentedCompare === void 0) { accentedCompare = false; }\n var valueAMissing = valueA == null;\n var valueBMissing = valueB == null;\n // this is for aggregations sum and avg, where the result can be a number that is wrapped.\n // if we didn't do this, then the toString() value would be used, which would result in\n // the strings getting used instead of the numbers.\n if (valueA && valueA.toNumber) {\n valueA = valueA.toNumber();\n }\n if (valueB && valueB.toNumber) {\n valueB = valueB.toNumber();\n }\n if (valueAMissing && valueBMissing) {\n return 0;\n }\n if (valueAMissing) {\n return -1;\n }\n if (valueBMissing) {\n return 1;\n }\n function doQuickCompare(a, b) {\n return (a > b ? 1 : (a < b ? -1 : 0));\n }\n if (typeof valueA !== 'string') {\n return doQuickCompare(valueA, valueB);\n }\n if (!accentedCompare) {\n return doQuickCompare(valueA, valueB);\n }\n try {\n // using local compare also allows chinese comparisons\n return valueA.localeCompare(valueB);\n }\n catch (e) {\n // if something wrong with localeCompare, eg not supported\n // by browser, then just continue with the quick one\n return doQuickCompare(valueA, valueB);\n }\n}\nexport function values(object) {\n if (object instanceof Set || object instanceof Map) {\n var arr_1 = [];\n object.forEach(function (value) { return arr_1.push(value); });\n return arr_1;\n }\n return Object.values(object);\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\n// class returns a unique id to use for the column. it checks the existing columns, and if the requested\n// id is already taken, it will start appending numbers until it gets a unique id.\n// eg, if the col field is 'name', it will try ids: {name, name_1, name_2...}\n// if no field or id provided in the col, it will try the ids of natural numbers\nimport { toStringOrNull } from \"../utils/generic\";\nvar ColumnKeyCreator = /** @class */ (function () {\n function ColumnKeyCreator() {\n this.existingKeys = {};\n }\n ColumnKeyCreator.prototype.addExistingKeys = function (keys) {\n for (var i = 0; i < keys.length; i++) {\n this.existingKeys[keys[i]] = true;\n }\n };\n ColumnKeyCreator.prototype.getUniqueKey = function (colId, colField) {\n // in case user passed in number for colId, convert to string\n colId = toStringOrNull(colId);\n var count = 0;\n while (true) {\n var idToTry = void 0;\n if (colId) {\n idToTry = colId;\n if (count !== 0) {\n idToTry += '_' + count;\n }\n }\n else if (colField) {\n idToTry = colField;\n if (count !== 0) {\n idToTry += '_' + count;\n }\n }\n else {\n idToTry = '' + count;\n }\n if (!this.existingKeys[idToTry]) {\n this.existingKeys[idToTry] = true;\n return idToTry;\n }\n count++;\n }\n };\n return ColumnKeyCreator;\n}());\nexport { ColumnKeyCreator };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nimport { missing, exists, values } from './generic';\nexport function iterateObject(object, callback) {\n if (object == null) {\n return;\n }\n if (Array.isArray(object)) {\n object.forEach(function (value, index) { return callback(\"\" + index, value); });\n }\n else {\n Object.keys(object).forEach(function (key) { return callback(key, object[key]); });\n }\n}\nexport function cloneObject(object) {\n var copy = {};\n var keys = Object.keys(object);\n for (var i = 0; i < keys.length; i++) {\n var key = keys[i];\n var value = object[key];\n copy[key] = value;\n }\n return copy;\n}\nexport function deepCloneObject(object) {\n return JSON.parse(JSON.stringify(object));\n}\n// returns copy of an object, doing a deep clone of any objects with that object.\n// this is used for eg creating copies of Column Definitions, where we want to\n// deep copy all objects, but do not want to deep copy functions (eg when user provides\n// a function or class for colDef.cellRenderer)\nexport function deepCloneDefinition(object, keysToSkip) {\n if (!object) {\n return;\n }\n var obj = object;\n var res = {};\n Object.keys(obj).forEach(function (key) {\n if (keysToSkip && keysToSkip.indexOf(key) >= 0) {\n return;\n }\n var value = obj[key];\n // 'simple object' means a bunch of key/value pairs, eg {filter: 'myFilter'}. it does\n // NOT include the following:\n // 1) arrays\n // 2) functions or classes (eg ColumnAPI instance)\n var sourceIsSimpleObject = isNonNullObject(value) && value.constructor === Object;\n if (sourceIsSimpleObject) {\n res[key] = deepCloneDefinition(value);\n }\n else {\n res[key] = value;\n }\n });\n return res;\n}\nexport function getProperty(object, key) {\n return object[key];\n}\nexport function setProperty(object, key, value) {\n object[key] = value;\n}\n/**\n * Will copy the specified properties from `source` into the equivalent properties on `target`, ignoring properties with\n * a value of `undefined`.\n */\nexport function copyPropertiesIfPresent(source, target) {\n var properties = [];\n for (var _i = 2; _i < arguments.length; _i++) {\n properties[_i - 2] = arguments[_i];\n }\n properties.forEach(function (p) { return copyPropertyIfPresent(source, target, p); });\n}\n/**\n * Will copy the specified property from `source` into the equivalent property on `target`, unless the property has a\n * value of `undefined`. If a transformation is provided, it will be applied to the value before being set on `target`.\n */\nexport function copyPropertyIfPresent(source, target, property, transform) {\n var value = getProperty(source, property);\n if (value !== undefined) {\n setProperty(target, property, transform ? transform(value) : value);\n }\n}\nexport function getAllKeysInObjects(objects) {\n var allValues = {};\n objects.filter(function (obj) { return obj != null; }).forEach(function (obj) {\n Object.keys(obj).forEach(function (key) { return allValues[key] = null; });\n });\n return Object.keys(allValues);\n}\nexport function getAllValuesInObject(obj) {\n if (!obj) {\n return [];\n }\n var anyObject = Object;\n if (typeof anyObject.values === 'function') {\n return anyObject.values(obj);\n }\n var ret = [];\n for (var key in obj) {\n if (obj.hasOwnProperty(key) && obj.propertyIsEnumerable(key)) {\n ret.push(obj[key]);\n }\n }\n return ret;\n}\nexport function mergeDeep(dest, source, copyUndefined, makeCopyOfSimpleObjects) {\n if (copyUndefined === void 0) { copyUndefined = true; }\n if (makeCopyOfSimpleObjects === void 0) { makeCopyOfSimpleObjects = false; }\n if (!exists(source)) {\n return;\n }\n iterateObject(source, function (key, sourceValue) {\n var destValue = dest[key];\n if (destValue === sourceValue) {\n return;\n }\n // when creating params, we don't want to just copy objects over. otherwise merging ColDefs (eg DefaultColDef\n // and Column Types) would result in params getting shared between objects.\n // by putting an empty value into destValue first, it means we end up copying over values from\n // the source object, rather than just copying in the source object in it's entirety.\n if (makeCopyOfSimpleObjects) {\n var objectIsDueToBeCopied = destValue == null && sourceValue != null;\n if (objectIsDueToBeCopied) {\n // 'simple object' means a bunch of key/value pairs, eg {filter: 'myFilter'}, as opposed\n // to a Class instance (such as ColumnAPI instance).\n var sourceIsSimpleObject = typeof sourceValue === 'object' && sourceValue.constructor === Object;\n var dontCopy = sourceIsSimpleObject;\n if (dontCopy) {\n destValue = {};\n dest[key] = destValue;\n }\n }\n }\n if (isNonNullObject(sourceValue) && isNonNullObject(destValue) && !Array.isArray(destValue)) {\n mergeDeep(destValue, sourceValue, copyUndefined, makeCopyOfSimpleObjects);\n }\n else if (copyUndefined || sourceValue !== undefined) {\n dest[key] = sourceValue;\n }\n });\n}\nexport function missingOrEmptyObject(value) {\n return missing(value) || Object.keys(value).length === 0;\n}\nexport function get(source, expression, defaultValue) {\n if (source == null) {\n return defaultValue;\n }\n var keys = expression.split('.');\n var objectToRead = source;\n while (keys.length > 1) {\n objectToRead = objectToRead[keys.shift()];\n if (objectToRead == null) {\n return defaultValue;\n }\n }\n var value = objectToRead[keys[0]];\n return value != null ? value : defaultValue;\n}\nexport function set(target, expression, value) {\n if (target == null) {\n return;\n }\n var keys = expression.split('.');\n var objectToUpdate = target;\n while (keys.length > 1) {\n objectToUpdate = objectToUpdate[keys.shift()];\n if (objectToUpdate == null) {\n return;\n }\n }\n objectToUpdate[keys[0]] = value;\n}\nexport function deepFreeze(object) {\n Object.freeze(object);\n values(object).forEach(function (v) {\n if (isNonNullObject(v) || typeof v === 'function') {\n deepFreeze(v);\n }\n });\n return object;\n}\nexport function getValueUsingField(data, field, fieldContainsDots) {\n if (!field || !data) {\n return;\n }\n // if no '.', then it's not a deep value\n if (!fieldContainsDots) {\n return data[field];\n }\n // otherwise it is a deep value, so need to dig for it\n var fields = field.split('.');\n var currentObject = data;\n for (var i = 0; i < fields.length; i++) {\n if (currentObject == null) {\n return undefined;\n }\n currentObject = currentObject[fields[i]];\n }\n return currentObject;\n}\n// used by ColumnAPI and GridAPI to remove all references, so keeping grid in memory resulting in a\n// memory leak if user is not disposing of the GridAPI or ColumnApi references\nexport function removeAllReferences(obj, objectName) {\n Object.keys(obj).forEach(function (key) {\n var value = obj[key];\n // we want to replace all the @autowired services, which are objects. any simple types (boolean, string etc)\n // we don't care about\n if (typeof value === 'object') {\n obj[key] = undefined;\n }\n });\n var proto = Object.getPrototypeOf(obj);\n var properties = {};\n Object.keys(proto).forEach(function (key) {\n var value = proto[key];\n // leave all basic types - this is needed for GridAPI to leave the \"destroyed: boolean\" attribute alone\n if (typeof value === 'function') {\n var func = function () {\n console.warn(\"AG Grid: \" + objectName + \" function \" + key + \"() cannot be called as the grid has been destroyed.\\n Please don't call grid API functions on destroyed grids - as a matter of fact you shouldn't\\n be keeping the API reference, your application has a memory leak! Remove the API reference\\n when the grid is destroyed.\");\n };\n properties[key] = { value: func, writable: true };\n }\n });\n Object.defineProperties(obj, properties);\n}\nexport function isNonNullObject(value) {\n return typeof value === 'object' && value !== null;\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar doOnceFlags = {};\n/**\n * If the key was passed before, then doesn't execute the func\n * @param {Function} func\n * @param {string} key\n */\nexport function doOnce(func, key) {\n if (doOnceFlags[key]) {\n return;\n }\n func();\n doOnceFlags[key] = true;\n}\nexport function getFunctionName(funcConstructor) {\n // for every other browser in the world\n if (funcConstructor.name) {\n return funcConstructor.name;\n }\n // for the pestilence that is ie11\n var matches = /function\\s+([^\\(]+)/.exec(funcConstructor.toString());\n return matches && matches.length === 2 ? matches[1].trim() : null;\n}\nexport function isFunction(val) {\n return !!(val && val.constructor && val.call && val.apply);\n}\nexport function executeInAWhile(funcs) {\n executeAfter(funcs, 400);\n}\nvar executeNextVMTurnFuncs = [];\nvar executeNextVMTurnPending = false;\nexport function executeNextVMTurn(func) {\n executeNextVMTurnFuncs.push(func);\n if (executeNextVMTurnPending) {\n return;\n }\n executeNextVMTurnPending = true;\n window.setTimeout(function () {\n var funcsCopy = executeNextVMTurnFuncs.slice();\n executeNextVMTurnFuncs.length = 0;\n executeNextVMTurnPending = false;\n funcsCopy.forEach(function (func) { return func(); });\n }, 0);\n}\nexport function executeAfter(funcs, milliseconds) {\n if (milliseconds === void 0) { milliseconds = 0; }\n if (funcs.length > 0) {\n window.setTimeout(function () { return funcs.forEach(function (func) { return func(); }); }, milliseconds);\n }\n}\n/**\n * from https://stackoverflow.com/questions/24004791/can-someone-explain-the-debounce-function-in-javascript\n * @param {Function} func The function to be debounced\n * @param {number} wait The time in ms to debounce\n * @param {boolean} immediate If it should run immediately or wait for the initial debounce delay\n * @return {Function} The debounced function\n */\nexport function debounce(func, wait, immediate) {\n if (immediate === void 0) { immediate = false; }\n // 'private' variable for instance\n // The returned function will be able to reference this due to closure.\n // Each call to the returned function will share this common timer.\n var timeout;\n // Calling debounce returns a new anonymous function\n return function () {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n // reference the context and args for the setTimeout function\n var context = this;\n // Should the function be called now? If immediate is true\n // and not already in a timeout then the answer is: Yes\n var callNow = immediate && !timeout;\n // This is the basic debounce behaviour where you can call this\n // function several times, but it will only execute once\n // [before or after imposing a delay].\n // Each time the returned function is called, the timer starts over.\n window.clearTimeout(timeout);\n // Set the new timeout\n timeout = window.setTimeout(function () {\n // Inside the timeout function, clear the timeout variable\n // which will let the next execution run when in 'immediate' mode\n timeout = null;\n // Check if the function already ran with the immediate flag\n if (!immediate) {\n // Call the original function with apply\n // apply lets you define the 'this' object as well as the arguments\n // (both captured before setTimeout)\n func.apply(context, args);\n }\n }, wait);\n // Immediate mode and no wait timer? Execute the function..\n if (callNow) {\n func.apply(context, args);\n }\n };\n}\n/**\n * @param {Function} func The function to be throttled\n * @param {number} wait The time in ms to throttle\n * @return {Function} The throttled function\n */\nexport function throttle(func, wait) {\n var previousCall = 0;\n return function () {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n var context = this;\n var currentCall = new Date().getTime();\n if (currentCall - previousCall < wait) {\n return;\n }\n previousCall = currentCall;\n func.apply(context, args);\n };\n}\nexport function waitUntil(condition, callback, timeout, timeoutMessage) {\n if (timeout === void 0) { timeout = 100; }\n var timeStamp = new Date().getTime();\n var interval = null;\n var executed = false;\n var internalCallback = function () {\n var reachedTimeout = ((new Date().getTime()) - timeStamp) > timeout;\n if (condition() || reachedTimeout) {\n callback();\n executed = true;\n if (interval != null) {\n window.clearInterval(interval);\n interval = null;\n }\n if (reachedTimeout && timeoutMessage) {\n console.warn(timeoutMessage);\n }\n }\n };\n internalCallback();\n if (!executed) {\n interval = window.setInterval(internalCallback, 10);\n }\n}\nexport function compose() {\n var fns = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n fns[_i] = arguments[_i];\n }\n return function (arg) { return fns.reduce(function (composed, f) { return f(composed); }, arg); };\n}\nexport function callIfPresent(func) {\n if (func) {\n func();\n }\n}\nexport var noop = function () { return; };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nimport { exists, values } from \"../utils/generic\";\nimport { iterateObject } from \"../utils/object\";\nimport { getFunctionName } from \"../utils/function\";\nvar Context = /** @class */ (function () {\n function Context(params, logger) {\n this.beanWrappers = {};\n this.destroyed = false;\n if (!params || !params.beanClasses) {\n return;\n }\n this.contextParams = params;\n this.logger = logger;\n this.logger.log(\">> creating ag-Application Context\");\n this.createBeans();\n var beanInstances = this.getBeanInstances();\n this.wireBeans(beanInstances);\n this.logger.log(\">> ag-Application Context ready - component is alive\");\n }\n Context.prototype.getBeanInstances = function () {\n return values(this.beanWrappers).map(function (beanEntry) { return beanEntry.beanInstance; });\n };\n Context.prototype.createBean = function (bean, afterPreCreateCallback) {\n if (!bean) {\n throw Error(\"Can't wire to bean since it is null\");\n }\n this.wireBeans([bean], afterPreCreateCallback);\n return bean;\n };\n Context.prototype.wireBeans = function (beanInstances, afterPreCreateCallback) {\n this.autoWireBeans(beanInstances);\n this.methodWireBeans(beanInstances);\n this.callLifeCycleMethods(beanInstances, 'preConstructMethods');\n // the callback sets the attributes, so the component has access to attributes\n // before postConstruct methods in the component are executed\n if (exists(afterPreCreateCallback)) {\n beanInstances.forEach(afterPreCreateCallback);\n }\n this.callLifeCycleMethods(beanInstances, 'postConstructMethods');\n };\n Context.prototype.createBeans = function () {\n var _this = this;\n // register all normal beans\n this.contextParams.beanClasses.forEach(this.createBeanWrapper.bind(this));\n // register override beans, these will overwrite beans above of same name\n // instantiate all beans - overridden beans will be left out\n iterateObject(this.beanWrappers, function (key, beanEntry) {\n var constructorParamsMeta;\n if (beanEntry.bean.__agBeanMetaData && beanEntry.bean.__agBeanMetaData.autowireMethods && beanEntry.bean.__agBeanMetaData.autowireMethods.agConstructor) {\n constructorParamsMeta = beanEntry.bean.__agBeanMetaData.autowireMethods.agConstructor;\n }\n var constructorParams = _this.getBeansForParameters(constructorParamsMeta, beanEntry.bean.name);\n var newInstance = applyToConstructor(beanEntry.bean, constructorParams);\n beanEntry.beanInstance = newInstance;\n });\n var createdBeanNames = Object.keys(this.beanWrappers).join(', ');\n this.logger.log(\"created beans: \" + createdBeanNames);\n };\n // tslint:disable-next-line\n Context.prototype.createBeanWrapper = function (BeanClass) {\n var metaData = BeanClass.__agBeanMetaData;\n if (!metaData) {\n var beanName = void 0;\n if (BeanClass.prototype.constructor) {\n beanName = getFunctionName(BeanClass.prototype.constructor);\n }\n else {\n beanName = \"\" + BeanClass;\n }\n console.error(\"Context item \" + beanName + \" is not a bean\");\n return;\n }\n var beanEntry = {\n bean: BeanClass,\n beanInstance: null,\n beanName: metaData.beanName\n };\n this.beanWrappers[metaData.beanName] = beanEntry;\n };\n Context.prototype.autoWireBeans = function (beanInstances) {\n var _this = this;\n beanInstances.forEach(function (beanInstance) {\n _this.forEachMetaDataInHierarchy(beanInstance, function (metaData, beanName) {\n var attributes = metaData.agClassAttributes;\n if (!attributes) {\n return;\n }\n attributes.forEach(function (attribute) {\n var otherBean = _this.lookupBeanInstance(beanName, attribute.beanName, attribute.optional);\n beanInstance[attribute.attributeName] = otherBean;\n });\n });\n });\n };\n Context.prototype.methodWireBeans = function (beanInstances) {\n var _this = this;\n beanInstances.forEach(function (beanInstance) {\n _this.forEachMetaDataInHierarchy(beanInstance, function (metaData, beanName) {\n iterateObject(metaData.autowireMethods, function (methodName, wireParams) {\n // skip constructor, as this is dealt with elsewhere\n if (methodName === \"agConstructor\") {\n return;\n }\n var initParams = _this.getBeansForParameters(wireParams, beanName);\n beanInstance[methodName].apply(beanInstance, initParams);\n });\n });\n });\n };\n Context.prototype.forEachMetaDataInHierarchy = function (beanInstance, callback) {\n var prototype = Object.getPrototypeOf(beanInstance);\n while (prototype != null) {\n var constructor = prototype.constructor;\n if (constructor.hasOwnProperty('__agBeanMetaData')) {\n var metaData = constructor.__agBeanMetaData;\n var beanName = this.getBeanName(constructor);\n callback(metaData, beanName);\n }\n prototype = Object.getPrototypeOf(prototype);\n }\n };\n Context.prototype.getBeanName = function (constructor) {\n if (constructor.__agBeanMetaData && constructor.__agBeanMetaData.beanName) {\n return constructor.__agBeanMetaData.beanName;\n }\n var constructorString = constructor.toString();\n var beanName = constructorString.substring(9, constructorString.indexOf(\"(\"));\n return beanName;\n };\n Context.prototype.getBeansForParameters = function (parameters, beanName) {\n var _this = this;\n var beansList = [];\n if (parameters) {\n iterateObject(parameters, function (paramIndex, otherBeanName) {\n var otherBean = _this.lookupBeanInstance(beanName, otherBeanName);\n beansList[Number(paramIndex)] = otherBean;\n });\n }\n return beansList;\n };\n Context.prototype.lookupBeanInstance = function (wiringBean, beanName, optional) {\n if (optional === void 0) { optional = false; }\n if (beanName === \"context\") {\n return this;\n }\n if (this.contextParams.providedBeanInstances && this.contextParams.providedBeanInstances.hasOwnProperty(beanName)) {\n return this.contextParams.providedBeanInstances[beanName];\n }\n var beanEntry = this.beanWrappers[beanName];\n if (beanEntry) {\n return beanEntry.beanInstance;\n }\n if (!optional) {\n console.error(\"AG Grid: unable to find bean reference \" + beanName + \" while initialising \" + wiringBean);\n }\n return null;\n };\n Context.prototype.callLifeCycleMethods = function (beanInstances, lifeCycleMethod) {\n var _this = this;\n beanInstances.forEach(function (beanInstance) { return _this.callLifeCycleMethodsOnBean(beanInstance, lifeCycleMethod); });\n };\n Context.prototype.callLifeCycleMethodsOnBean = function (beanInstance, lifeCycleMethod, methodToIgnore) {\n // putting all methods into a map removes duplicates\n var allMethods = {};\n // dump methods from each level of the metadata hierarchy\n this.forEachMetaDataInHierarchy(beanInstance, function (metaData) {\n var methods = metaData[lifeCycleMethod];\n if (methods) {\n methods.forEach(function (methodName) {\n if (methodName != methodToIgnore) {\n allMethods[methodName] = true;\n }\n });\n }\n });\n var allMethodsList = Object.keys(allMethods);\n allMethodsList.forEach(function (methodName) { return beanInstance[methodName](); });\n };\n Context.prototype.getBean = function (name) {\n return this.lookupBeanInstance(\"getBean\", name, true);\n };\n Context.prototype.destroy = function () {\n if (this.destroyed) {\n return;\n }\n this.logger.log(\">> Shutting down ag-Application Context\");\n var beanInstances = this.getBeanInstances();\n this.destroyBeans(beanInstances);\n this.contextParams.providedBeanInstances = null;\n this.destroyed = true;\n this.logger.log(\">> ag-Application Context shut down - component is dead\");\n };\n Context.prototype.destroyBean = function (bean) {\n if (!bean) {\n return;\n }\n this.destroyBeans([bean]);\n };\n Context.prototype.destroyBeans = function (beans) {\n var _this = this;\n if (!beans) {\n return [];\n }\n beans.forEach(function (bean) {\n _this.callLifeCycleMethodsOnBean(bean, 'preDestroyMethods', 'destroy');\n // call destroy() explicitly if it exists\n var beanAny = bean;\n if (typeof beanAny.destroy === 'function') {\n beanAny.destroy();\n }\n });\n return [];\n };\n return Context;\n}());\nexport { Context };\n// taken from: http://stackoverflow.com/questions/3362471/how-can-i-call-a-javascript-constructor-using-call-or-apply\n// allows calling 'apply' on a constructor\nfunction applyToConstructor(constructor, argArray) {\n var args = [null].concat(argArray);\n var factoryFunction = constructor.bind.apply(constructor, args);\n return new factoryFunction();\n}\nexport function PreConstruct(target, methodName, descriptor) {\n var props = getOrCreateProps(target.constructor);\n if (!props.preConstructMethods) {\n props.preConstructMethods = [];\n }\n props.preConstructMethods.push(methodName);\n}\nexport function PostConstruct(target, methodName, descriptor) {\n var props = getOrCreateProps(target.constructor);\n if (!props.postConstructMethods) {\n props.postConstructMethods = [];\n }\n props.postConstructMethods.push(methodName);\n}\nexport function PreDestroy(target, methodName, descriptor) {\n var props = getOrCreateProps(target.constructor);\n if (!props.preDestroyMethods) {\n props.preDestroyMethods = [];\n }\n props.preDestroyMethods.push(methodName);\n}\nexport function Bean(beanName) {\n return function (classConstructor) {\n var props = getOrCreateProps(classConstructor);\n props.beanName = beanName;\n };\n}\nexport function Autowired(name) {\n return function (target, propertyKey, descriptor) {\n autowiredFunc(target, name, false, target, propertyKey, null);\n };\n}\nexport function Optional(name) {\n return function (target, propertyKey, descriptor) {\n autowiredFunc(target, name, true, target, propertyKey, null);\n };\n}\nfunction autowiredFunc(target, name, optional, classPrototype, methodOrAttributeName, index) {\n if (name === null) {\n console.error(\"AG Grid: Autowired name should not be null\");\n return;\n }\n if (typeof index === \"number\") {\n console.error(\"AG Grid: Autowired should be on an attribute\");\n return;\n }\n // it's an attribute on the class\n var props = getOrCreateProps(target.constructor);\n if (!props.agClassAttributes) {\n props.agClassAttributes = [];\n }\n props.agClassAttributes.push({\n attributeName: methodOrAttributeName,\n beanName: name,\n optional: optional\n });\n}\nexport function Qualifier(name) {\n return function (classPrototype, methodOrAttributeName, index) {\n var constructor = typeof classPrototype == \"function\" ? classPrototype : classPrototype.constructor;\n var props;\n if (typeof index === \"number\") {\n // it's a parameter on a method\n var methodName = void 0;\n if (methodOrAttributeName) {\n props = getOrCreateProps(constructor);\n methodName = methodOrAttributeName;\n }\n else {\n props = getOrCreateProps(constructor);\n methodName = \"agConstructor\";\n }\n if (!props.autowireMethods) {\n props.autowireMethods = {};\n }\n if (!props.autowireMethods[methodName]) {\n props.autowireMethods[methodName] = {};\n }\n props.autowireMethods[methodName][index] = name;\n }\n };\n}\nfunction getOrCreateProps(target) {\n if (!target.hasOwnProperty(\"__agBeanMetaData\")) {\n target.__agBeanMetaData = {};\n }\n return target.__agBeanMetaData;\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n};\nimport { Bean, Qualifier } from \"./context/context\";\nvar EventService = /** @class */ (function () {\n function EventService() {\n this.allSyncListeners = new Map();\n this.allAsyncListeners = new Map();\n this.globalSyncListeners = new Set();\n this.globalAsyncListeners = new Set();\n this.asyncFunctionsQueue = [];\n this.scheduled = false;\n // using an object performs better than a Set for the number of different events we have\n this.firedEvents = {};\n }\n // because this class is used both inside the context and outside the context, we do not\n // use autowired attributes, as that would be confusing, as sometimes the attributes\n // would be wired, and sometimes not.\n //\n // the global event servers used by AG Grid is autowired by the context once, and this\n // setBeans method gets called once.\n //\n // the times when this class is used outside of the context (eg RowNode has an instance of this\n // class) then it is not a bean, and this setBeans method is not called.\n EventService.prototype.setBeans = function (loggerFactory, gridOptionsWrapper, frameworkOverrides, globalEventListener) {\n if (globalEventListener === void 0) { globalEventListener = null; }\n this.frameworkOverrides = frameworkOverrides;\n this.gridOptionsWrapper = gridOptionsWrapper;\n if (globalEventListener) {\n var async = gridOptionsWrapper.useAsyncEvents();\n this.addGlobalListener(globalEventListener, async);\n }\n };\n EventService.prototype.getListeners = function (eventType, async, autoCreateListenerCollection) {\n var listenerMap = async ? this.allAsyncListeners : this.allSyncListeners;\n var listeners = listenerMap.get(eventType);\n // Note: 'autoCreateListenerCollection' should only be 'true' if a listener is about to be added. For instance\n // getListeners() is also called during event dispatch even though no listeners are added. This measure protects\n // against 'memory bloat' as empty collections will prevent the RowNode's event service from being removed after\n // the RowComp is destroyed, see noRegisteredListenersExist() below.\n if (!listeners && autoCreateListenerCollection) {\n listeners = new Set();\n listenerMap.set(eventType, listeners);\n }\n return listeners;\n };\n EventService.prototype.noRegisteredListenersExist = function () {\n return this.allSyncListeners.size === 0 && this.allAsyncListeners.size === 0 &&\n this.globalSyncListeners.size === 0 && this.globalAsyncListeners.size === 0;\n };\n EventService.prototype.addEventListener = function (eventType, listener, async) {\n if (async === void 0) { async = false; }\n this.getListeners(eventType, async, true).add(listener);\n };\n EventService.prototype.removeEventListener = function (eventType, listener, async) {\n if (async === void 0) { async = false; }\n var listeners = this.getListeners(eventType, async, false);\n if (!listeners) {\n return;\n }\n listeners.delete(listener);\n if (listeners.size === 0) {\n var listenerMap = async ? this.allAsyncListeners : this.allSyncListeners;\n listenerMap.delete(eventType);\n }\n };\n EventService.prototype.addGlobalListener = function (listener, async) {\n if (async === void 0) { async = false; }\n (async ? this.globalAsyncListeners : this.globalSyncListeners).add(listener);\n };\n EventService.prototype.removeGlobalListener = function (listener, async) {\n if (async === void 0) { async = false; }\n (async ? this.globalAsyncListeners : this.globalSyncListeners).delete(listener);\n };\n EventService.prototype.dispatchEvent = function (event) {\n var agEvent = event;\n if (this.gridOptionsWrapper) {\n // Apply common properties to all dispatched events if this event service has had its beans set with gridOptionsWrapper.\n // Note there are multiple instances of EventService that are used local to components which do not set gridOptionsWrapper. \n agEvent = __assign(__assign({}, event), { api: this.gridOptionsWrapper.getApi(), columnApi: this.gridOptionsWrapper.getColumnApi(), context: this.gridOptionsWrapper.getContext() });\n }\n this.dispatchToListeners(agEvent, true);\n this.dispatchToListeners(agEvent, false);\n this.firedEvents[agEvent.type] = true;\n };\n EventService.prototype.dispatchEventOnce = function (event) {\n if (!this.firedEvents[event.type]) {\n this.dispatchEvent(event);\n }\n };\n EventService.prototype.dispatchToListeners = function (event, async) {\n var _this = this;\n var eventType = event.type;\n var processEventListeners = function (listeners) { return listeners.forEach(function (listener) {\n if (async) {\n _this.dispatchAsync(function () { return listener(event); });\n }\n else {\n listener(event);\n }\n }); };\n var listeners = this.getListeners(eventType, async, false);\n if (listeners) {\n processEventListeners(listeners);\n }\n var globalListeners = async ? this.globalAsyncListeners : this.globalSyncListeners;\n globalListeners.forEach(function (listener) {\n if (async) {\n _this.dispatchAsync(function () { return _this.frameworkOverrides.dispatchEvent(eventType, function () { return listener(eventType, event); }, true); });\n }\n else {\n _this.frameworkOverrides.dispatchEvent(eventType, function () { return listener(eventType, event); }, true);\n }\n });\n };\n // this gets called inside the grid's thread, for each event that it\n // wants to set async. the grid then batches the events into one setTimeout()\n // because setTimeout() is an expensive operation. ideally we would have\n // each event in it's own setTimeout(), but we batch for performance.\n EventService.prototype.dispatchAsync = function (func) {\n // add to the queue for executing later in the next VM turn\n this.asyncFunctionsQueue.push(func);\n // check if timeout is already scheduled. the first time the grid calls\n // this within it's thread turn, this should be false, so it will schedule\n // the 'flush queue' method the first time it comes here. then the flag is\n // set to 'true' so it will know it's already scheduled for subsequent calls.\n if (!this.scheduled) {\n // if not scheduled, schedule one\n window.setTimeout(this.flushAsyncQueue.bind(this), 0);\n // mark that it is scheduled\n this.scheduled = true;\n }\n };\n // this happens in the next VM turn only, and empties the queue of events\n EventService.prototype.flushAsyncQueue = function () {\n this.scheduled = false;\n // we take a copy, because the event listener could be using\n // the grid, which would cause more events, which would be potentially\n // added to the queue, so safe to take a copy, the new events will\n // get executed in a later VM turn rather than risk updating the\n // queue as we are flushing it.\n var queueCopy = this.asyncFunctionsQueue.slice();\n this.asyncFunctionsQueue = [];\n // execute the queue\n queueCopy.forEach(function (func) { return func(); });\n };\n __decorate([\n __param(0, Qualifier('loggerFactory')),\n __param(1, Qualifier('gridOptionsWrapper')),\n __param(2, Qualifier('frameworkOverrides')),\n __param(3, Qualifier('globalEventListener'))\n ], EventService.prototype, \"setBeans\", null);\n EventService = __decorate([\n Bean('eventService')\n ], EventService);\n return EventService;\n}());\nexport { EventService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar Constants = /** @class */ (function () {\n function Constants() {\n }\n Constants.ROW_BUFFER_SIZE = 10;\n Constants.LAYOUT_INTERVAL = 500;\n Constants.BATCH_WAIT_MILLIS = 50;\n Constants.EXPORT_TYPE_DRAG_COPY = 'dragCopy';\n Constants.EXPORT_TYPE_CLIPBOARD = 'clipboard';\n Constants.EXPORT_TYPE_EXCEL = 'excel';\n Constants.EXPORT_TYPE_CSV = 'csv';\n Constants.ROW_MODEL_TYPE_INFINITE = 'infinite';\n Constants.ROW_MODEL_TYPE_VIEWPORT = 'viewport';\n Constants.ROW_MODEL_TYPE_CLIENT_SIDE = 'clientSide';\n Constants.ROW_MODEL_TYPE_SERVER_SIDE = 'serverSide';\n Constants.ALWAYS = 'always';\n Constants.ONLY_WHEN_GROUPING = 'onlyWhenGrouping';\n Constants.PINNED_TOP = 'top';\n Constants.PINNED_BOTTOM = 'bottom';\n Constants.DOM_LAYOUT_NORMAL = 'normal';\n Constants.DOM_LAYOUT_PRINT = 'print';\n Constants.DOM_LAYOUT_AUTO_HEIGHT = 'autoHeight';\n Constants.GROUP_AUTO_COLUMN_ID = 'ag-Grid-AutoColumn';\n Constants.SOURCE_PASTE = 'paste';\n Constants.PINNED_RIGHT = 'right';\n Constants.PINNED_LEFT = 'left';\n Constants.SORT_ASC = 'asc';\n Constants.SORT_DESC = 'desc';\n Constants.INPUT_SELECTOR = 'input, select, button, textarea';\n Constants.FOCUSABLE_SELECTOR = '[tabindex], input, select, button, textarea';\n Constants.FOCUSABLE_EXCLUDE = '.ag-hidden, .ag-hidden *, [disabled], .ag-disabled, .ag-disabled *';\n return Constants;\n}());\nexport { Constants };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nexport var ModuleNames;\n(function (ModuleNames) {\n // when using modules, user references this\n ModuleNames[\"CommunityCoreModule\"] = \"@ag-grid-community/core\";\n // when not using modules, user references this\n ModuleNames[\"CommunityAllModules\"] = \"@ag-grid-community/all\";\n // community modules\n ModuleNames[\"InfiniteRowModelModule\"] = \"@ag-grid-community/infinite-row-model\";\n ModuleNames[\"ClientSideRowModelModule\"] = \"@ag-grid-community/client-side-row-model\";\n ModuleNames[\"CsvExportModule\"] = \"@ag-grid-community/csv-export\";\n // enterprise core - users never import on this, but other enterprise modules do\n ModuleNames[\"EnterpriseCoreModule\"] = \"@ag-grid-enterprise/core\";\n // when not using modules, user references this\n ModuleNames[\"EnterpriseAllModules\"] = \"@ag-grid-enterprise/all\";\n // enterprise modules\n ModuleNames[\"RowGroupingModule\"] = \"@ag-grid-enterprise/row-grouping\";\n ModuleNames[\"ColumnToolPanelModule\"] = \"@ag-grid-enterprise/column-tool-panel\";\n ModuleNames[\"FiltersToolPanelModule\"] = \"@ag-grid-enterprise/filter-tool-panel\";\n ModuleNames[\"MenuModule\"] = \"@ag-grid-enterprise/menu\";\n ModuleNames[\"SetFilterModule\"] = \"@ag-grid-enterprise/set-filter\";\n ModuleNames[\"MultiFilterModule\"] = \"@ag-grid-enterprise/multi-filter\";\n ModuleNames[\"StatusBarModule\"] = \"@ag-grid-enterprise/status-bar\";\n ModuleNames[\"SideBarModule\"] = \"@ag-grid-enterprise/side-bar\";\n ModuleNames[\"RangeSelectionModule\"] = \"@ag-grid-enterprise/range-selection\";\n ModuleNames[\"MasterDetailModule\"] = \"@ag-grid-enterprise/master-detail\";\n ModuleNames[\"RichSelectModule\"] = \"@ag-grid-enterprise/rich-select\";\n ModuleNames[\"GridChartsModule\"] = \"@ag-grid-enterprise/charts\";\n ModuleNames[\"ViewportRowModelModule\"] = \"@ag-grid-enterprise/viewport-row-model\";\n ModuleNames[\"ServerSideRowModelModule\"] = \"@ag-grid-enterprise/server-side-row-model\";\n ModuleNames[\"ExcelExportModule\"] = \"@ag-grid-enterprise/excel-export\";\n ModuleNames[\"ClipboardModule\"] = \"@ag-grid-enterprise/clipboard\";\n ModuleNames[\"SparklinesModule\"] = \"@ag-grid-enterprise/sparklines\";\n // framework wrappers currently don't provide beans, comps etc, so no need to be modules,\n // however i argue they should be as in theory they 'could' provide beans etc\n ModuleNames[\"AngularModule\"] = \"@ag-grid-community/angular\";\n ModuleNames[\"ReactModule\"] = \"@ag-grid-community/react\";\n ModuleNames[\"VueModule\"] = \"@ag-grid-community/vue\";\n ModuleNames[\"PolymerModule\"] = \"@ag-grid-community/polymer\";\n // and then this, which is definitely not a grid module, as it should not have any dependency\n // on the grid (ie shouldn't even reference the Module interface)\n // ChartsModule = \"@ag-grid-community/charts-core\",\n})(ModuleNames || (ModuleNames = {}));\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nimport { doOnce } from \"../utils/function\";\nimport { values } from \"../utils/generic\";\nvar ModuleRegistry = /** @class */ (function () {\n function ModuleRegistry() {\n }\n ModuleRegistry.register = function (module, moduleBased) {\n if (moduleBased === void 0) { moduleBased = true; }\n ModuleRegistry.modulesMap[module.moduleName] = module;\n if (ModuleRegistry.moduleBased === undefined) {\n ModuleRegistry.moduleBased = moduleBased;\n }\n else {\n if (ModuleRegistry.moduleBased !== moduleBased) {\n doOnce(function () {\n console.warn(\"AG Grid: You are mixing modules (i.e. @ag-grid-community/core) and packages (ag-grid-community) - you can only use one or the other of these mechanisms.\");\n console.warn('Please see https://www.ag-grid.com/javascript-grid/packages-modules/ for more information.');\n }, 'ModulePackageCheck');\n }\n }\n };\n // noinspection JSUnusedGlobalSymbols\n ModuleRegistry.registerModules = function (modules, moduleBased) {\n if (moduleBased === void 0) { moduleBased = true; }\n if (!modules) {\n return;\n }\n modules.forEach(function (module) { return ModuleRegistry.register(module, moduleBased); });\n };\n ModuleRegistry.assertRegistered = function (moduleName, reason) {\n if (this.isRegistered(moduleName)) {\n return true;\n }\n var warningKey = reason + moduleName;\n var warningMessage;\n if (ModuleRegistry.moduleBased) {\n warningMessage = \"AG Grid: unable to use \" + reason + \" as module \" + moduleName + \" is not present. Please see: https://www.ag-grid.com/javascript-grid/modules/\";\n }\n else {\n warningMessage = \"AG Grid: unable to use \" + reason + \" as package 'ag-grid-enterprise' is not present. Please see: https://www.ag-grid.com/javascript-grid/packages/\";\n }\n doOnce(function () {\n console.warn(warningMessage);\n }, warningKey);\n return false;\n };\n ModuleRegistry.isRegistered = function (moduleName) {\n return !!ModuleRegistry.modulesMap[moduleName];\n };\n ModuleRegistry.getRegisteredModules = function () {\n return values(ModuleRegistry.modulesMap);\n };\n ModuleRegistry.isPackageBased = function () {\n return !ModuleRegistry.moduleBased;\n };\n // having in a map a) removes duplicates and b) allows fast lookup\n ModuleRegistry.modulesMap = {};\n return ModuleRegistry;\n}());\nexport { ModuleRegistry };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { EventService } from \"../eventService\";\nimport { Autowired, PostConstruct } from \"../context/context\";\nimport { Constants } from \"../constants/constants\";\nimport { ModuleNames } from \"../modules/moduleNames\";\nimport { ModuleRegistry } from \"../modules/moduleRegistry\";\nimport { attrToNumber, attrToBoolean, exists, missing } from \"../utils/generic\";\nimport { doOnce } from \"../utils/function\";\nimport { mergeDeep } from \"../utils/object\";\nvar instanceIdSequence = 0;\n// Wrapper around a user provide column definition. The grid treats the column definition as ready only.\n// This class contains all the runtime information about a column, plus some logic (the definition has no logic).\n// This class implements both interfaces ColumnGroupChild and ProvidedColumnGroupChild as the class can\n// appear as a child of either the original tree or the displayed tree. However the relevant group classes\n// for each type only implements one, as each group can only appear in it's associated tree (eg ProvidedColumnGroup\n// can only appear in OriginalColumn tree).\nvar Column = /** @class */ (function () {\n function Column(colDef, userProvidedColDef, colId, primary) {\n // used by React (and possibly other frameworks) as key for rendering\n this.instanceId = instanceIdSequence++;\n // The measured height of this column's header when autoHeaderHeight is enabled\n this.autoHeaderHeight = null;\n this.moving = false;\n this.menuVisible = false;\n this.filterActive = false;\n this.eventService = new EventService();\n this.rowGroupActive = false;\n this.pivotActive = false;\n this.aggregationActive = false;\n this.colDef = colDef;\n this.userProvidedColDef = userProvidedColDef;\n this.colId = colId;\n this.primary = primary;\n this.setState(colDef);\n }\n Column.prototype.getInstanceId = function () {\n return this.instanceId;\n };\n Column.prototype.setState = function (colDef) {\n // sort\n if (colDef.sort !== undefined) {\n if (colDef.sort === Constants.SORT_ASC || colDef.sort === Constants.SORT_DESC) {\n this.sort = colDef.sort;\n }\n }\n else {\n if (colDef.initialSort === Constants.SORT_ASC || colDef.initialSort === Constants.SORT_DESC) {\n this.sort = colDef.initialSort;\n }\n }\n // sortIndex\n var sortIndex = attrToNumber(colDef.sortIndex);\n var initialSortIndex = attrToNumber(colDef.initialSortIndex);\n if (sortIndex !== undefined) {\n if (sortIndex !== null) {\n this.sortIndex = sortIndex;\n }\n }\n else {\n if (initialSortIndex !== null) {\n this.sortIndex = initialSortIndex;\n }\n }\n // hide\n var hide = attrToBoolean(colDef.hide);\n var initialHide = attrToBoolean(colDef.initialHide);\n if (hide !== undefined) {\n this.visible = !hide;\n }\n else {\n this.visible = !initialHide;\n }\n // pinned\n if (colDef.pinned !== undefined) {\n this.setPinned(colDef.pinned);\n }\n else {\n this.setPinned(colDef.initialPinned);\n }\n // flex\n var flex = attrToNumber(colDef.flex);\n var initialFlex = attrToNumber(colDef.initialFlex);\n if (flex !== undefined) {\n this.flex = flex;\n }\n else if (initialFlex !== undefined) {\n this.flex = initialFlex;\n }\n };\n // gets called when user provides an alternative colDef, eg\n Column.prototype.setColDef = function (colDef, userProvidedColDef) {\n this.colDef = colDef;\n this.userProvidedColDef = userProvidedColDef;\n this.initMinAndMaxWidths();\n this.initDotNotation();\n this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_COL_DEF_CHANGED, \"api\"));\n };\n /**\n * Returns the column definition provided by the application.\n * This may not be correct, as items can be superseded by default column options.\n * However it's useful for comparison, eg to know which application column definition matches that column.\n */\n Column.prototype.getUserProvidedColDef = function () {\n return this.userProvidedColDef;\n };\n Column.prototype.setParent = function (parent) {\n this.parent = parent;\n };\n /** Returns the parent column group, if column grouping is active. */\n Column.prototype.getParent = function () {\n return this.parent;\n };\n Column.prototype.setOriginalParent = function (originalParent) {\n this.originalParent = originalParent;\n };\n Column.prototype.getOriginalParent = function () {\n return this.originalParent;\n };\n // this is done after constructor as it uses gridOptionsWrapper\n Column.prototype.initialise = function () {\n this.initMinAndMaxWidths();\n this.resetActualWidth('gridInitializing');\n this.initDotNotation();\n this.validate();\n };\n Column.prototype.initDotNotation = function () {\n var suppressDotNotation = this.gridOptionsWrapper.isSuppressFieldDotNotation();\n this.fieldContainsDots = exists(this.colDef.field) && this.colDef.field.indexOf('.') >= 0 && !suppressDotNotation;\n this.tooltipFieldContainsDots = exists(this.colDef.tooltipField) && this.colDef.tooltipField.indexOf('.') >= 0 && !suppressDotNotation;\n };\n Column.prototype.initMinAndMaxWidths = function () {\n var colDef = this.colDef;\n this.minWidth = this.columnUtils.calculateColMinWidth(colDef);\n this.maxWidth = this.columnUtils.calculateColMaxWidth(colDef);\n };\n Column.prototype.resetActualWidth = function (source) {\n if (source === void 0) { source = 'api'; }\n var initialWidth = this.columnUtils.calculateColInitialWidth(this.colDef);\n this.setActualWidth(initialWidth, source, true);\n };\n Column.prototype.isEmptyGroup = function () {\n return false;\n };\n Column.prototype.isRowGroupDisplayed = function (colId) {\n if (missing(this.colDef) || missing(this.colDef.showRowGroup)) {\n return false;\n }\n var showingAllGroups = this.colDef.showRowGroup === true;\n var showingThisGroup = this.colDef.showRowGroup === colId;\n return showingAllGroups || showingThisGroup;\n };\n /** Returns `true` if column is a primary column, `false` if secondary. Secondary columns are used for pivoting. */\n Column.prototype.isPrimary = function () {\n return this.primary;\n };\n /** Returns `true` if column filtering is allowed. */\n Column.prototype.isFilterAllowed = function () {\n // filter defined means it's a string, class or true.\n // if its false, null or undefined then it's false.\n var filterDefined = !!this.colDef.filter || !!this.colDef.filterFramework;\n return filterDefined;\n };\n Column.prototype.isFieldContainsDots = function () {\n return this.fieldContainsDots;\n };\n Column.prototype.isTooltipFieldContainsDots = function () {\n return this.tooltipFieldContainsDots;\n };\n Column.prototype.validate = function () {\n var colDefAny = this.colDef;\n function warnOnce(msg, key, obj) {\n doOnce(function () {\n if (obj) {\n console.warn(msg, obj);\n }\n else {\n doOnce(function () { return console.warn(msg); }, key);\n }\n }, key);\n }\n var usingCSRM = this.gridOptionsWrapper.isRowModelDefault();\n if (usingCSRM && !ModuleRegistry.isRegistered(ModuleNames.RowGroupingModule)) {\n var rowGroupingItems = ['enableRowGroup', 'rowGroup', 'rowGroupIndex', 'enablePivot', 'enableValue', 'pivot', 'pivotIndex', 'aggFunc'];\n rowGroupingItems.forEach(function (item) {\n if (exists(colDefAny[item])) {\n if (ModuleRegistry.isPackageBased()) {\n warnOnce(\"AG Grid: \" + item + \" is only valid in ag-grid-enterprise, your column definition should not have \" + item, 'ColumnRowGroupingMissing' + item);\n }\n else {\n warnOnce(\"AG Grid: \" + item + \" is only valid with AG Grid Enterprise Module \" + ModuleNames.RowGroupingModule + \" - your column definition should not have \" + item, 'ColumnRowGroupingMissing' + item);\n }\n }\n });\n }\n if (!ModuleRegistry.isRegistered(ModuleNames.RichSelectModule)) {\n if (this.colDef.cellEditor === 'agRichSelect' || this.colDef.cellEditor === 'agRichSelectCellEditor') {\n if (ModuleRegistry.isPackageBased()) {\n warnOnce(\"AG Grid: \" + this.colDef.cellEditor + \" can only be used with ag-grid-enterprise\", 'ColumnRichSelectMissing');\n }\n else {\n warnOnce(\"AG Grid: \" + this.colDef.cellEditor + \" can only be used with AG Grid Enterprise Module \" + ModuleNames.RichSelectModule, 'ColumnRichSelectMissing');\n }\n }\n }\n if (this.gridOptionsWrapper.isTreeData()) {\n var itemsNotAllowedWithTreeData = ['rowGroup', 'rowGroupIndex', 'pivot', 'pivotIndex'];\n itemsNotAllowedWithTreeData.forEach(function (item) {\n if (exists(colDefAny[item])) {\n warnOnce(\"AG Grid: \" + item + \" is not possible when doing tree data, your column definition should not have \" + item, 'TreeDataCannotRowGroup');\n }\n });\n }\n if (exists(this.colDef.width) && typeof this.colDef.width !== 'number') {\n warnOnce('AG Grid: colDef.width should be a number, not ' + typeof this.colDef.width, 'ColumnCheck_asdfawef');\n }\n if (colDefAny.pinnedRowCellRenderer) {\n warnOnce('AG Grid: pinnedRowCellRenderer no longer exists, use cellRendererSelector if you want a different Cell Renderer for pinned rows. Check params.node.rowPinned. This was an unfortunate (but necessary) change we had to do to allow future plans we have of re-skinng the data grid in frameworks such as React, Angular and Vue. See https://www.ag-grid.com/javascript-grid/cell-rendering/#many-renderers-one-column', 'colDef.pinnedRowCellRenderer-deprecated');\n }\n if (colDefAny.pinnedRowCellRendererParams) {\n warnOnce('AG Grid: pinnedRowCellRenderer no longer exists, use cellRendererSelector if you want a different Cell Renderer for pinned rows. Check params.node.rowPinned. This was an unfortunate (but necessary) change we had to do to allow future plans we have of re-skinng the data grid in frameworks such as React, Angular and Vue. See https://www.ag-grid.com/javascript-grid/cell-rendering/#many-renderers-one-column', 'colDef.pinnedRowCellRenderer-deprecated');\n }\n if (colDefAny.pinnedRowCellRendererFramework) {\n warnOnce('AG Grid: pinnedRowCellRenderer no longer exists, use cellRendererSelector if you want a different Cell Renderer for pinned rows. Check params.node.rowPinned. This was an unfortunate (but necessary) change we had to do to allow future plans we have of re-skinng the data grid in frameworks such as React, Angular and Vue. See https://www.ag-grid.com/javascript-grid/cell-rendering/#many-renderers-one-column', 'colDef.pinnedRowCellRenderer-deprecated');\n }\n if (colDefAny.pinnedRowValueGetter) {\n warnOnce('AG Grid: pinnedRowCellRenderer is deprecated, use cellRendererSelector if you want a different Cell Renderer for pinned rows. Check params.node.rowPinned. This was an unfortunate (but necessary) change we had to do to allow future plans we have of re-skinng the data grid in frameworks such as React, Angular and Vue.', 'colDef.pinnedRowCellRenderer-deprecated');\n }\n };\n /** Add an event listener to the column. */\n Column.prototype.addEventListener = function (eventType, listener) {\n this.eventService.addEventListener(eventType, listener);\n };\n /** Remove event listener from the column. */\n Column.prototype.removeEventListener = function (eventType, listener) {\n this.eventService.removeEventListener(eventType, listener);\n };\n Column.prototype.createColumnFunctionCallbackParams = function (rowNode) {\n return {\n node: rowNode,\n data: rowNode.data,\n column: this,\n colDef: this.colDef,\n context: this.gridOptionsWrapper.getContext(),\n api: this.gridOptionsWrapper.getApi(),\n columnApi: this.gridOptionsWrapper.getColumnApi()\n };\n };\n Column.prototype.isSuppressNavigable = function (rowNode) {\n // if boolean set, then just use it\n if (typeof this.colDef.suppressNavigable === 'boolean') {\n return this.colDef.suppressNavigable;\n }\n // if function, then call the function to find out\n if (typeof this.colDef.suppressNavigable === 'function') {\n var params = this.createColumnFunctionCallbackParams(rowNode);\n var userFunc = this.colDef.suppressNavigable;\n return userFunc(params);\n }\n return false;\n };\n Column.prototype.isCellEditable = function (rowNode) {\n // only allow editing of groups if the user has this option enabled\n if (rowNode.group && !this.gridOptionsWrapper.isEnableGroupEdit()) {\n return false;\n }\n return this.isColumnFunc(rowNode, this.colDef.editable);\n };\n Column.prototype.isSuppressFillHandle = function () {\n return !!attrToBoolean(this.colDef.suppressFillHandle);\n };\n Column.prototype.isAutoHeight = function () {\n return !!attrToBoolean(this.colDef.autoHeight);\n };\n Column.prototype.isAutoHeaderHeight = function () {\n return !!attrToBoolean(this.colDef.autoHeaderHeight);\n };\n Column.prototype.isRowDrag = function (rowNode) {\n return this.isColumnFunc(rowNode, this.colDef.rowDrag);\n };\n Column.prototype.isDndSource = function (rowNode) {\n return this.isColumnFunc(rowNode, this.colDef.dndSource);\n };\n Column.prototype.isCellCheckboxSelection = function (rowNode) {\n return this.isColumnFunc(rowNode, this.colDef.checkboxSelection);\n };\n Column.prototype.isSuppressPaste = function (rowNode) {\n return this.isColumnFunc(rowNode, this.colDef ? this.colDef.suppressPaste : null);\n };\n Column.prototype.isResizable = function () {\n return !!attrToBoolean(this.colDef.resizable);\n };\n Column.prototype.isColumnFunc = function (rowNode, value) {\n // if boolean set, then just use it\n if (typeof value === 'boolean') {\n return value;\n }\n // if function, then call the function to find out\n if (typeof value === 'function') {\n var params = this.createColumnFunctionCallbackParams(rowNode);\n var editableFunc = value;\n return editableFunc(params);\n }\n return false;\n };\n Column.prototype.setMoving = function (moving, source) {\n if (source === void 0) { source = \"api\"; }\n this.moving = moving;\n this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_MOVING_CHANGED, source));\n };\n Column.prototype.createColumnEvent = function (type, source) {\n return {\n type: type,\n column: this,\n columns: [this],\n source: source,\n api: this.gridOptionsWrapper.getApi(),\n columnApi: this.gridOptionsWrapper.getColumnApi(),\n context: this.gridOptionsWrapper.getContext()\n };\n };\n Column.prototype.isMoving = function () {\n return this.moving;\n };\n /** If sorting is active, returns the sort direction e.g. `'asc'` or `'desc'`. */\n Column.prototype.getSort = function () {\n return this.sort;\n };\n Column.prototype.setSort = function (sort, source) {\n if (source === void 0) { source = \"api\"; }\n if (this.sort !== sort) {\n this.sort = sort;\n this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_SORT_CHANGED, source));\n }\n };\n Column.prototype.setMenuVisible = function (visible, source) {\n if (source === void 0) { source = \"api\"; }\n if (this.menuVisible !== visible) {\n this.menuVisible = visible;\n this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_MENU_VISIBLE_CHANGED, source));\n }\n };\n Column.prototype.isMenuVisible = function () {\n return this.menuVisible;\n };\n Column.prototype.isSortAscending = function () {\n return this.sort === Constants.SORT_ASC;\n };\n Column.prototype.isSortDescending = function () {\n return this.sort === Constants.SORT_DESC;\n };\n Column.prototype.isSortNone = function () {\n return missing(this.sort);\n };\n Column.prototype.isSorting = function () {\n return exists(this.sort);\n };\n Column.prototype.getSortIndex = function () {\n return this.sortIndex;\n };\n Column.prototype.setSortIndex = function (sortOrder) {\n this.sortIndex = sortOrder;\n };\n Column.prototype.setAggFunc = function (aggFunc) {\n this.aggFunc = aggFunc;\n };\n /** If aggregation is set for the column, returns the aggregation function. */\n Column.prototype.getAggFunc = function () {\n return this.aggFunc;\n };\n Column.prototype.getLeft = function () {\n return this.left;\n };\n Column.prototype.getOldLeft = function () {\n return this.oldLeft;\n };\n Column.prototype.getRight = function () {\n return this.left + this.actualWidth;\n };\n Column.prototype.setLeft = function (left, source) {\n if (source === void 0) { source = \"api\"; }\n this.oldLeft = this.left;\n if (this.left !== left) {\n this.left = left;\n this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_LEFT_CHANGED, source));\n }\n };\n /** Returns `true` if filter is active on the column. */\n Column.prototype.isFilterActive = function () {\n return this.filterActive;\n };\n // additionalEventAttributes is used by provided simple floating filter, so it can add 'floatingFilter=true' to the event\n Column.prototype.setFilterActive = function (active, source, additionalEventAttributes) {\n if (source === void 0) { source = \"api\"; }\n if (this.filterActive !== active) {\n this.filterActive = active;\n this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_FILTER_ACTIVE_CHANGED, source));\n }\n var filterChangedEvent = this.createColumnEvent(Column.EVENT_FILTER_CHANGED, source);\n if (additionalEventAttributes) {\n mergeDeep(filterChangedEvent, additionalEventAttributes);\n }\n this.eventService.dispatchEvent(filterChangedEvent);\n };\n Column.prototype.setPinned = function (pinned) {\n if (pinned === true || pinned === Constants.PINNED_LEFT) {\n this.pinned = Constants.PINNED_LEFT;\n }\n else if (pinned === Constants.PINNED_RIGHT) {\n this.pinned = Constants.PINNED_RIGHT;\n }\n else {\n this.pinned = null;\n }\n };\n Column.prototype.setFirstRightPinned = function (firstRightPinned, source) {\n if (source === void 0) { source = \"api\"; }\n if (this.firstRightPinned !== firstRightPinned) {\n this.firstRightPinned = firstRightPinned;\n this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_FIRST_RIGHT_PINNED_CHANGED, source));\n }\n };\n Column.prototype.setLastLeftPinned = function (lastLeftPinned, source) {\n if (source === void 0) { source = \"api\"; }\n if (this.lastLeftPinned !== lastLeftPinned) {\n this.lastLeftPinned = lastLeftPinned;\n this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_LAST_LEFT_PINNED_CHANGED, source));\n }\n };\n Column.prototype.isFirstRightPinned = function () {\n return this.firstRightPinned;\n };\n Column.prototype.isLastLeftPinned = function () {\n return this.lastLeftPinned;\n };\n Column.prototype.isPinned = function () {\n return this.pinned === Constants.PINNED_LEFT || this.pinned === Constants.PINNED_RIGHT;\n };\n Column.prototype.isPinnedLeft = function () {\n return this.pinned === Constants.PINNED_LEFT;\n };\n Column.prototype.isPinnedRight = function () {\n return this.pinned === Constants.PINNED_RIGHT;\n };\n Column.prototype.getPinned = function () {\n return this.pinned;\n };\n Column.prototype.setVisible = function (visible, source) {\n if (source === void 0) { source = \"api\"; }\n var newValue = visible === true;\n if (this.visible !== newValue) {\n this.visible = newValue;\n this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_VISIBLE_CHANGED, source));\n }\n };\n Column.prototype.isVisible = function () {\n return this.visible;\n };\n /** Returns the column definition for this column.\n * The column definition will be the result of merging the application provided column definition with any provided defaults\n * (e.g. `defaultColDef` grid option, or column types.\n *\n * Equivalent: `getDefinition` */\n Column.prototype.getColDef = function () {\n return this.colDef;\n };\n Column.prototype.getColumnGroupShow = function () {\n return this.colDef.columnGroupShow;\n };\n /**\n * Returns the unique ID for the column.\n *\n * Equivalent: `getId`, `getUniqueId` */\n Column.prototype.getColId = function () {\n return this.colId;\n };\n /**\n * Returns the unique ID for the column.\n *\n * Equivalent: `getColId`, `getUniqueId` */\n Column.prototype.getId = function () {\n return this.getColId();\n };\n /**\n * Returns the unique ID for the column.\n *\n * Equivalent: `getColId`, `getId` */\n Column.prototype.getUniqueId = function () {\n return this.getId();\n };\n Column.prototype.getDefinition = function () {\n return this.colDef;\n };\n /** Returns the current width of the column. If the column is resized, the actual width is the new size. */\n Column.prototype.getActualWidth = function () {\n return this.actualWidth;\n };\n Column.prototype.getAutoHeaderHeight = function () {\n return this.autoHeaderHeight;\n };\n /** Returns true if the header height has changed */\n Column.prototype.setAutoHeaderHeight = function (height) {\n var changed = height !== this.autoHeaderHeight;\n this.autoHeaderHeight = height;\n return changed;\n };\n Column.prototype.createBaseColDefParams = function (rowNode) {\n var params = {\n node: rowNode,\n data: rowNode.data,\n colDef: this.colDef,\n column: this,\n api: this.gridOptionsWrapper.getApi(),\n columnApi: this.gridOptionsWrapper.getColumnApi(),\n context: this.gridOptionsWrapper.getContext()\n };\n return params;\n };\n Column.prototype.getColSpan = function (rowNode) {\n if (missing(this.colDef.colSpan)) {\n return 1;\n }\n var params = this.createBaseColDefParams(rowNode);\n var colSpan = this.colDef.colSpan(params);\n // colSpan must be number equal to or greater than 1\n return Math.max(colSpan, 1);\n };\n Column.prototype.getRowSpan = function (rowNode) {\n if (missing(this.colDef.rowSpan)) {\n return 1;\n }\n var params = this.createBaseColDefParams(rowNode);\n var rowSpan = this.colDef.rowSpan(params);\n // rowSpan must be number equal to or greater than 1\n return Math.max(rowSpan, 1);\n };\n Column.prototype.setActualWidth = function (actualWidth, source, silent) {\n if (source === void 0) { source = \"api\"; }\n if (silent === void 0) { silent = false; }\n if (this.minWidth != null) {\n actualWidth = Math.max(actualWidth, this.minWidth);\n }\n if (this.maxWidth != null) {\n actualWidth = Math.min(actualWidth, this.maxWidth);\n }\n if (this.actualWidth !== actualWidth) {\n // disable flex for this column if it was manually resized.\n this.actualWidth = actualWidth;\n if (this.flex && source !== 'flex' && source !== 'gridInitializing') {\n this.flex = null;\n }\n if (!silent) {\n this.fireColumnWidthChangedEvent(source);\n }\n }\n };\n Column.prototype.fireColumnWidthChangedEvent = function (source) {\n this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_WIDTH_CHANGED, source));\n };\n Column.prototype.isGreaterThanMax = function (width) {\n if (this.maxWidth != null) {\n return width > this.maxWidth;\n }\n return false;\n };\n Column.prototype.getMinWidth = function () {\n return this.minWidth;\n };\n Column.prototype.getMaxWidth = function () {\n return this.maxWidth;\n };\n Column.prototype.getFlex = function () {\n return this.flex || 0;\n };\n // this method should only be used by the columnModel to\n // change flex when required by the setColumnState method.\n Column.prototype.setFlex = function (flex) {\n if (this.flex !== flex) {\n this.flex = flex;\n }\n };\n Column.prototype.setMinimum = function (source) {\n if (source === void 0) { source = \"api\"; }\n if (exists(this.minWidth)) {\n this.setActualWidth(this.minWidth, source);\n }\n };\n Column.prototype.setRowGroupActive = function (rowGroup, source) {\n if (source === void 0) { source = \"api\"; }\n if (this.rowGroupActive !== rowGroup) {\n this.rowGroupActive = rowGroup;\n this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_ROW_GROUP_CHANGED, source));\n }\n };\n /** Returns `true` if row group is currently active for this column. */\n Column.prototype.isRowGroupActive = function () {\n return this.rowGroupActive;\n };\n Column.prototype.setPivotActive = function (pivot, source) {\n if (source === void 0) { source = \"api\"; }\n if (this.pivotActive !== pivot) {\n this.pivotActive = pivot;\n this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_PIVOT_CHANGED, source));\n }\n };\n /** Returns `true` if pivot is currently active for this column. */\n Column.prototype.isPivotActive = function () {\n return this.pivotActive;\n };\n Column.prototype.isAnyFunctionActive = function () {\n return this.isPivotActive() || this.isRowGroupActive() || this.isValueActive();\n };\n Column.prototype.isAnyFunctionAllowed = function () {\n return this.isAllowPivot() || this.isAllowRowGroup() || this.isAllowValue();\n };\n Column.prototype.setValueActive = function (value, source) {\n if (source === void 0) { source = \"api\"; }\n if (this.aggregationActive !== value) {\n this.aggregationActive = value;\n this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_VALUE_CHANGED, source));\n }\n };\n /** Returns `true` if value (aggregation) is currently active for this column. */\n Column.prototype.isValueActive = function () {\n return this.aggregationActive;\n };\n Column.prototype.isAllowPivot = function () {\n return this.colDef.enablePivot === true;\n };\n Column.prototype.isAllowValue = function () {\n return this.colDef.enableValue === true;\n };\n Column.prototype.isAllowRowGroup = function () {\n return this.colDef.enableRowGroup === true;\n };\n Column.prototype.getMenuTabs = function (defaultValues) {\n var menuTabs = this.getColDef().menuTabs;\n if (menuTabs == null) {\n menuTabs = defaultValues;\n }\n return menuTabs;\n };\n // this used to be needed, as previous version of ag-grid had lockPosition as column state,\n // so couldn't depend on colDef version.\n Column.prototype.isLockPosition = function () {\n console.warn('AG Grid: since v21, col.isLockPosition() should not be used, please use col.getColDef().lockPosition instead.');\n return this.colDef ? !!this.colDef.lockPosition : false;\n };\n // this used to be needed, as previous version of ag-grid had lockVisible as column state,\n // so couldn't depend on colDef version.\n Column.prototype.isLockVisible = function () {\n console.warn('AG Grid: since v21, col.isLockVisible() should not be used, please use col.getColDef().lockVisible instead.');\n return this.colDef ? !!this.colDef.lockVisible : false;\n };\n // this used to be needed, as previous version of ag-grid had lockPinned as column state,\n // so couldn't depend on colDef version.\n Column.prototype.isLockPinned = function () {\n console.warn('AG Grid: since v21, col.isLockPinned() should not be used, please use col.getColDef().lockPinned instead.');\n return this.colDef ? !!this.colDef.lockPinned : false;\n };\n // + renderedHeaderCell - for making header cell transparent when moving\n Column.EVENT_MOVING_CHANGED = 'movingChanged';\n // + renderedCell - changing left position\n Column.EVENT_LEFT_CHANGED = 'leftChanged';\n // + renderedCell - changing width\n Column.EVENT_WIDTH_CHANGED = 'widthChanged';\n // + renderedCell - for changing pinned classes\n Column.EVENT_LAST_LEFT_PINNED_CHANGED = 'lastLeftPinnedChanged';\n Column.EVENT_FIRST_RIGHT_PINNED_CHANGED = 'firstRightPinnedChanged';\n // + renderedColumn - for changing visibility icon\n Column.EVENT_VISIBLE_CHANGED = 'visibleChanged';\n // + every time the filter changes, used in the floating filters\n Column.EVENT_FILTER_CHANGED = 'filterChanged';\n // + renderedHeaderCell - marks the header with filter icon\n Column.EVENT_FILTER_ACTIVE_CHANGED = 'filterActiveChanged';\n // + renderedHeaderCell - marks the header with sort icon\n Column.EVENT_SORT_CHANGED = 'sortChanged';\n // + renderedHeaderCell - marks the header with sort icon\n Column.EVENT_COL_DEF_CHANGED = 'colDefChanged';\n Column.EVENT_MENU_VISIBLE_CHANGED = 'menuVisibleChanged';\n // + toolpanel, for gui updates\n Column.EVENT_ROW_GROUP_CHANGED = 'columnRowGroupChanged';\n // + toolpanel, for gui updates\n Column.EVENT_PIVOT_CHANGED = 'columnPivotChanged';\n // + toolpanel, for gui updates\n Column.EVENT_VALUE_CHANGED = 'columnValueChanged';\n __decorate([\n Autowired('gridOptionsWrapper')\n ], Column.prototype, \"gridOptionsWrapper\", void 0);\n __decorate([\n Autowired('columnUtils')\n ], Column.prototype, \"columnUtils\", void 0);\n __decorate([\n PostConstruct\n ], Column.prototype, \"initialise\", null);\n return Column;\n}());\nexport { Column };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nimport { exists, toStringOrNull } from './generic';\nexport function firstExistingValue() {\n var values = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n values[_i] = arguments[_i];\n }\n for (var i = 0; i < values.length; i++) {\n var value = values[i];\n if (exists(value)) {\n return value;\n }\n }\n return null;\n}\nexport function existsAndNotEmpty(value) {\n return value != null && value.length > 0;\n}\nexport function last(arr) {\n if (!arr || !arr.length) {\n return;\n }\n return arr[arr.length - 1];\n}\nexport function areEqual(a, b, comparator) {\n if (a == null && b == null) {\n return true;\n }\n return a != null &&\n b != null &&\n a.length === b.length &&\n a.every(function (value, index) { return comparator ? comparator(value, b[index]) : b[index] === value; });\n}\n/** @deprecated */\nexport function compareArrays(array1, array2) {\n return areEqual(array1, array2);\n}\n/** @deprecated */\nexport function shallowCompare(arr1, arr2) {\n return areEqual(arr1, arr2);\n}\nexport function sortNumerically(array) {\n return array.sort(function (a, b) { return a - b; });\n}\nexport function removeRepeatsFromArray(array, object) {\n if (!array) {\n return;\n }\n for (var index = array.length - 2; index >= 0; index--) {\n var thisOneMatches = array[index] === object;\n var nextOneMatches = array[index + 1] === object;\n if (thisOneMatches && nextOneMatches) {\n array.splice(index + 1, 1);\n }\n }\n}\nexport function removeFromArray(array, object) {\n var index = array.indexOf(object);\n if (index >= 0) {\n array.splice(index, 1);\n }\n}\nexport function removeAllFromArray(array, toRemove) {\n toRemove.forEach(function (item) { return removeFromArray(array, item); });\n}\nexport function insertIntoArray(array, object, toIndex) {\n array.splice(toIndex, 0, object);\n}\nexport function insertArrayIntoArray(dest, src, toIndex) {\n if (dest == null || src == null) {\n return;\n }\n // put items in backwards, otherwise inserted items end up in reverse order\n for (var i = src.length - 1; i >= 0; i--) {\n var item = src[i];\n insertIntoArray(dest, item, toIndex);\n }\n}\nexport function moveInArray(array, objectsToMove, toIndex) {\n // first take out items from the array\n removeAllFromArray(array, objectsToMove);\n // now add the objects, in same order as provided to us, that means we start at the end\n // as the objects will be pushed to the right as they are inserted\n objectsToMove.slice().reverse().forEach(function (obj) { return insertIntoArray(array, obj, toIndex); });\n}\nexport function includes(array, value) {\n return array.indexOf(value) > -1;\n}\nexport function flatten(arrayOfArrays) {\n return [].concat.apply([], arrayOfArrays);\n}\nexport function pushAll(target, source) {\n if (source == null || target == null) {\n return;\n }\n source.forEach(function (value) { return target.push(value); });\n}\nexport function toStrings(array) {\n return array.map(toStringOrNull);\n}\nexport function forEachReverse(list, action) {\n if (list == null) {\n return;\n }\n for (var i = list.length - 1; i >= 0; i--) {\n action(list[i], i);\n }\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Column } from \"./column\";\nimport { EventService } from \"../eventService\";\nimport { Autowired } from \"../context/context\";\nimport { last } from \"../utils/array\";\nvar ColumnGroup = /** @class */ (function () {\n function ColumnGroup(providedColumnGroup, groupId, instanceId, pinned) {\n // depends on the open/closed state of the group, only displaying columns are stored here\n this.displayedChildren = [];\n this.localEventService = new EventService();\n this.groupId = groupId;\n this.instanceId = instanceId;\n this.providedColumnGroup = providedColumnGroup;\n this.pinned = pinned;\n }\n // this is static, a it is used outside of this class\n ColumnGroup.createUniqueId = function (groupId, instanceId) {\n return groupId + '_' + instanceId;\n };\n // as the user is adding and removing columns, the groups are recalculated.\n // this reset clears out all children, ready for children to be added again\n ColumnGroup.prototype.reset = function () {\n this.parent = null;\n this.children = null;\n this.displayedChildren = null;\n };\n ColumnGroup.prototype.getParent = function () {\n return this.parent;\n };\n ColumnGroup.prototype.setParent = function (parent) {\n this.parent = parent;\n };\n ColumnGroup.prototype.getUniqueId = function () {\n return ColumnGroup.createUniqueId(this.groupId, this.instanceId);\n };\n ColumnGroup.prototype.isEmptyGroup = function () {\n return this.displayedChildren.length === 0;\n };\n ColumnGroup.prototype.isMoving = function () {\n var allLeafColumns = this.getProvidedColumnGroup().getLeafColumns();\n if (!allLeafColumns || allLeafColumns.length === 0) {\n return false;\n }\n return allLeafColumns.every(function (col) { return col.isMoving(); });\n };\n ColumnGroup.prototype.checkLeft = function () {\n // first get all children to setLeft, as it impacts our decision below\n this.displayedChildren.forEach(function (child) {\n if (child instanceof ColumnGroup) {\n child.checkLeft();\n }\n });\n // set our left based on first displayed column\n if (this.displayedChildren.length > 0) {\n if (this.gridOptionsWrapper.isEnableRtl()) {\n var lastChild = last(this.displayedChildren);\n var lastChildLeft = lastChild.getLeft();\n this.setLeft(lastChildLeft);\n }\n else {\n var firstChildLeft = this.displayedChildren[0].getLeft();\n this.setLeft(firstChildLeft);\n }\n }\n else {\n // this should never happen, as if we have no displayed columns, then\n // this groups should not even exist.\n this.setLeft(null);\n }\n };\n ColumnGroup.prototype.getLeft = function () {\n return this.left;\n };\n ColumnGroup.prototype.getOldLeft = function () {\n return this.oldLeft;\n };\n ColumnGroup.prototype.setLeft = function (left) {\n this.oldLeft = left;\n if (this.left !== left) {\n this.left = left;\n this.localEventService.dispatchEvent(this.createAgEvent(ColumnGroup.EVENT_LEFT_CHANGED));\n }\n };\n ColumnGroup.prototype.getPinned = function () {\n return this.pinned;\n };\n ColumnGroup.prototype.createAgEvent = function (type) {\n return { type: type };\n };\n ColumnGroup.prototype.addEventListener = function (eventType, listener) {\n this.localEventService.addEventListener(eventType, listener);\n };\n ColumnGroup.prototype.removeEventListener = function (eventType, listener) {\n this.localEventService.removeEventListener(eventType, listener);\n };\n ColumnGroup.prototype.getGroupId = function () {\n return this.groupId;\n };\n ColumnGroup.prototype.getInstanceId = function () {\n return this.instanceId;\n };\n ColumnGroup.prototype.isChildInThisGroupDeepSearch = function (wantedChild) {\n var result = false;\n this.children.forEach(function (foundChild) {\n if (wantedChild === foundChild) {\n result = true;\n }\n if (foundChild instanceof ColumnGroup) {\n if (foundChild.isChildInThisGroupDeepSearch(wantedChild)) {\n result = true;\n }\n }\n });\n return result;\n };\n ColumnGroup.prototype.getActualWidth = function () {\n var groupActualWidth = 0;\n if (this.displayedChildren) {\n this.displayedChildren.forEach(function (child) {\n groupActualWidth += child.getActualWidth();\n });\n }\n return groupActualWidth;\n };\n ColumnGroup.prototype.isResizable = function () {\n if (!this.displayedChildren) {\n return false;\n }\n // if at least one child is resizable, then the group is resizable\n var result = false;\n this.displayedChildren.forEach(function (child) {\n if (child.isResizable()) {\n result = true;\n }\n });\n return result;\n };\n ColumnGroup.prototype.getMinWidth = function () {\n var result = 0;\n this.displayedChildren.forEach(function (groupChild) {\n result += groupChild.getMinWidth() || 0;\n });\n return result;\n };\n ColumnGroup.prototype.addChild = function (child) {\n if (!this.children) {\n this.children = [];\n }\n this.children.push(child);\n };\n ColumnGroup.prototype.getDisplayedChildren = function () {\n return this.displayedChildren;\n };\n ColumnGroup.prototype.getLeafColumns = function () {\n var result = [];\n this.addLeafColumns(result);\n return result;\n };\n ColumnGroup.prototype.getDisplayedLeafColumns = function () {\n var result = [];\n this.addDisplayedLeafColumns(result);\n return result;\n };\n // why two methods here doing the same thing?\n ColumnGroup.prototype.getDefinition = function () {\n return this.providedColumnGroup.getColGroupDef();\n };\n ColumnGroup.prototype.getColGroupDef = function () {\n return this.providedColumnGroup.getColGroupDef();\n };\n ColumnGroup.prototype.isPadding = function () {\n return this.providedColumnGroup.isPadding();\n };\n ColumnGroup.prototype.isExpandable = function () {\n return this.providedColumnGroup.isExpandable();\n };\n ColumnGroup.prototype.isExpanded = function () {\n return this.providedColumnGroup.isExpanded();\n };\n ColumnGroup.prototype.setExpanded = function (expanded) {\n this.providedColumnGroup.setExpanded(expanded);\n };\n ColumnGroup.prototype.addDisplayedLeafColumns = function (leafColumns) {\n this.displayedChildren.forEach(function (child) {\n if (child instanceof Column) {\n leafColumns.push(child);\n }\n else if (child instanceof ColumnGroup) {\n child.addDisplayedLeafColumns(leafColumns);\n }\n });\n };\n ColumnGroup.prototype.addLeafColumns = function (leafColumns) {\n this.children.forEach(function (child) {\n if (child instanceof Column) {\n leafColumns.push(child);\n }\n else if (child instanceof ColumnGroup) {\n child.addLeafColumns(leafColumns);\n }\n });\n };\n ColumnGroup.prototype.getChildren = function () {\n return this.children;\n };\n ColumnGroup.prototype.getColumnGroupShow = function () {\n return this.providedColumnGroup.getColumnGroupShow();\n };\n ColumnGroup.prototype.getProvidedColumnGroup = function () {\n return this.providedColumnGroup;\n };\n /** @deprecated getOriginalColumnGroup is deprecated, use getOriginalColumnGroup. */\n ColumnGroup.prototype.getOriginalColumnGroup = function () {\n console.warn('AG Grid: columnGroup.getOriginalColumnGroup() is deprecated due to a method rename, use columnGroup.getProvidedColumnGroup() instead');\n return this.getProvidedColumnGroup();\n };\n ColumnGroup.prototype.getPaddingLevel = function () {\n var parent = this.getParent();\n if (!this.isPadding() || !parent || !parent.isPadding()) {\n return 0;\n }\n return 1 + parent.getPaddingLevel();\n };\n ColumnGroup.prototype.calculateDisplayedColumns = function () {\n var _this = this;\n // clear out last time we calculated\n this.displayedChildren = [];\n // find the column group that is controlling expandable. this is relevant when we have padding (empty)\n // groups, where the expandable is actually the first parent that is not a padding group.\n var parentWithExpansion = this;\n while (parentWithExpansion != null && parentWithExpansion.isPadding()) {\n parentWithExpansion = parentWithExpansion.getParent();\n }\n var isExpandable = parentWithExpansion ? parentWithExpansion.providedColumnGroup.isExpandable() : false;\n // it not expandable, everything is visible\n if (!isExpandable) {\n this.displayedChildren = this.children;\n this.localEventService.dispatchEvent(this.createAgEvent(ColumnGroup.EVENT_DISPLAYED_CHILDREN_CHANGED));\n return;\n }\n // Add cols based on columnGroupShow\n // Note - the below also adds padding groups, these are always added because they never have\n // colDef.columnGroupShow set.\n this.children.forEach(function (child) {\n // never add empty groups\n var emptyGroup = child instanceof ColumnGroup && (!child.displayedChildren || !child.displayedChildren.length);\n if (emptyGroup) {\n return;\n }\n var headerGroupShow = child.getColumnGroupShow();\n switch (headerGroupShow) {\n case ColumnGroup.HEADER_GROUP_SHOW_OPEN:\n // when set to open, only show col if group is open\n if (parentWithExpansion.providedColumnGroup.isExpanded()) {\n _this.displayedChildren.push(child);\n }\n break;\n case ColumnGroup.HEADER_GROUP_SHOW_CLOSED:\n // when set to open, only show col if group is open\n if (!parentWithExpansion.providedColumnGroup.isExpanded()) {\n _this.displayedChildren.push(child);\n }\n break;\n default:\n _this.displayedChildren.push(child);\n break;\n }\n });\n this.localEventService.dispatchEvent(this.createAgEvent(ColumnGroup.EVENT_DISPLAYED_CHILDREN_CHANGED));\n };\n ColumnGroup.HEADER_GROUP_SHOW_OPEN = 'open';\n ColumnGroup.HEADER_GROUP_SHOW_CLOSED = 'closed';\n ColumnGroup.EVENT_LEFT_CHANGED = 'leftChanged';\n ColumnGroup.EVENT_DISPLAYED_CHILDREN_CHANGED = 'displayedChildrenChanged';\n __decorate([\n Autowired('gridOptionsWrapper')\n ], ColumnGroup.prototype, \"gridOptionsWrapper\", void 0);\n return ColumnGroup;\n}());\nexport { ColumnGroup };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nimport { ColumnGroup } from \"./columnGroup\";\nimport { Column } from \"./column\";\nimport { EventService } from \"../eventService\";\nvar ProvidedColumnGroup = /** @class */ (function () {\n function ProvidedColumnGroup(colGroupDef, groupId, padding, level) {\n this.localEventService = new EventService();\n this.expandable = false;\n this.colGroupDef = colGroupDef;\n this.groupId = groupId;\n this.expanded = !!colGroupDef && !!colGroupDef.openByDefault;\n this.padding = padding;\n this.level = level;\n }\n ProvidedColumnGroup.prototype.setOriginalParent = function (originalParent) {\n this.originalParent = originalParent;\n };\n ProvidedColumnGroup.prototype.getOriginalParent = function () {\n return this.originalParent;\n };\n ProvidedColumnGroup.prototype.getLevel = function () {\n return this.level;\n };\n ProvidedColumnGroup.prototype.isVisible = function () {\n // return true if at least one child is visible\n if (this.children) {\n return this.children.some(function (child) { return child.isVisible(); });\n }\n return false;\n };\n ProvidedColumnGroup.prototype.isPadding = function () {\n return this.padding;\n };\n ProvidedColumnGroup.prototype.setExpanded = function (expanded) {\n this.expanded = expanded === undefined ? false : expanded;\n var event = {\n type: ProvidedColumnGroup.EVENT_EXPANDED_CHANGED\n };\n this.localEventService.dispatchEvent(event);\n };\n ProvidedColumnGroup.prototype.isExpandable = function () {\n return this.expandable;\n };\n ProvidedColumnGroup.prototype.isExpanded = function () {\n return this.expanded;\n };\n ProvidedColumnGroup.prototype.getGroupId = function () {\n return this.groupId;\n };\n ProvidedColumnGroup.prototype.getId = function () {\n return this.getGroupId();\n };\n ProvidedColumnGroup.prototype.setChildren = function (children) {\n this.children = children;\n };\n ProvidedColumnGroup.prototype.getChildren = function () {\n return this.children;\n };\n ProvidedColumnGroup.prototype.getColGroupDef = function () {\n return this.colGroupDef;\n };\n ProvidedColumnGroup.prototype.getLeafColumns = function () {\n var result = [];\n this.addLeafColumns(result);\n return result;\n };\n ProvidedColumnGroup.prototype.addLeafColumns = function (leafColumns) {\n if (!this.children) {\n return;\n }\n this.children.forEach(function (child) {\n if (child instanceof Column) {\n leafColumns.push(child);\n }\n else if (child instanceof ProvidedColumnGroup) {\n child.addLeafColumns(leafColumns);\n }\n });\n };\n ProvidedColumnGroup.prototype.getColumnGroupShow = function () {\n var colGroupDef = this.colGroupDef;\n if (!colGroupDef) {\n return;\n }\n return colGroupDef.columnGroupShow;\n };\n // need to check that this group has at least one col showing when both expanded and contracted.\n // if not, then we don't allow expanding and contracting on this group\n ProvidedColumnGroup.prototype.setupExpandable = function () {\n var _this = this;\n this.setExpandable();\n // note - we should be removing this event listener\n this.getLeafColumns().forEach(function (col) { return col.addEventListener(Column.EVENT_VISIBLE_CHANGED, _this.onColumnVisibilityChanged.bind(_this)); });\n };\n ProvidedColumnGroup.prototype.setExpandable = function () {\n if (this.isPadding()) {\n return;\n }\n // want to make sure the group doesn't disappear when it's open\n var atLeastOneShowingWhenOpen = false;\n // want to make sure the group doesn't disappear when it's closed\n var atLeastOneShowingWhenClosed = false;\n // want to make sure the group has something to show / hide\n var atLeastOneChangeable = false;\n var children = this.findChildrenRemovingPadding();\n for (var i = 0, j = children.length; i < j; i++) {\n var abstractColumn = children[i];\n if (!abstractColumn.isVisible()) {\n continue;\n }\n // if the abstractColumn is a grid generated group, there will be no colDef\n var headerGroupShow = abstractColumn.getColumnGroupShow();\n if (headerGroupShow === ColumnGroup.HEADER_GROUP_SHOW_OPEN) {\n atLeastOneShowingWhenOpen = true;\n atLeastOneChangeable = true;\n }\n else if (headerGroupShow === ColumnGroup.HEADER_GROUP_SHOW_CLOSED) {\n atLeastOneShowingWhenClosed = true;\n atLeastOneChangeable = true;\n }\n else {\n atLeastOneShowingWhenOpen = true;\n atLeastOneShowingWhenClosed = true;\n }\n }\n var expandable = atLeastOneShowingWhenOpen && atLeastOneShowingWhenClosed && atLeastOneChangeable;\n if (this.expandable !== expandable) {\n this.expandable = expandable;\n var event_1 = {\n type: ProvidedColumnGroup.EVENT_EXPANDABLE_CHANGED\n };\n this.localEventService.dispatchEvent(event_1);\n }\n };\n ProvidedColumnGroup.prototype.findChildrenRemovingPadding = function () {\n var res = [];\n var process = function (items) {\n items.forEach(function (item) {\n // if padding, we add this children instead of the padding\n var skipBecausePadding = item instanceof ProvidedColumnGroup && item.isPadding();\n if (skipBecausePadding) {\n process(item.children);\n }\n else {\n res.push(item);\n }\n });\n };\n process(this.children);\n return res;\n };\n ProvidedColumnGroup.prototype.onColumnVisibilityChanged = function () {\n this.setExpandable();\n };\n ProvidedColumnGroup.prototype.addEventListener = function (eventType, listener) {\n this.localEventService.addEventListener(eventType, listener);\n };\n ProvidedColumnGroup.prototype.removeEventListener = function (eventType, listener) {\n this.localEventService.removeEventListener(eventType, listener);\n };\n ProvidedColumnGroup.EVENT_EXPANDED_CHANGED = 'expandedChanged';\n ProvidedColumnGroup.EVENT_EXPANDABLE_CHANGED = 'expandableChanged';\n return ProvidedColumnGroup;\n}());\nexport { ProvidedColumnGroup };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nexport var DefaultColumnTypes = {\n numericColumn: {\n headerClass: 'ag-right-aligned-header',\n cellClass: 'ag-right-aligned-cell'\n },\n rightAligned: {\n headerClass: 'ag-right-aligned-header',\n cellClass: 'ag-right-aligned-cell'\n }\n};\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nimport { includes } from './array';\nvar AG_GRID_STOP_PROPAGATION = '__ag_Grid_Stop_Propagation';\nvar PASSIVE_EVENTS = ['touchstart', 'touchend', 'touchmove', 'touchcancel'];\nvar supports = {};\n/**\n * a user once raised an issue - they said that when you opened a popup (eg context menu)\n * and then clicked on a selection checkbox, the popup wasn't closed. this is because the\n * popup listens for clicks on the body, however ag-grid WAS stopping propagation on the\n * checkbox clicks (so the rows didn't pick them up as row selection selection clicks).\n * to get around this, we have a pattern to stop propagation for the purposes of AG Grid,\n * but we still let the event pass back to the body.\n * @param {Event} event\n */\nexport function stopPropagationForAgGrid(event) {\n event[AG_GRID_STOP_PROPAGATION] = true;\n}\nexport function isStopPropagationForAgGrid(event) {\n return event[AG_GRID_STOP_PROPAGATION] === true;\n}\nexport var isEventSupported = (function () {\n var tags = {\n select: 'input',\n change: 'input',\n submit: 'form',\n reset: 'form',\n error: 'img',\n load: 'img',\n abort: 'img'\n };\n var eventChecker = function (eventName) {\n if (typeof supports[eventName] === 'boolean') {\n return supports[eventName];\n }\n var el = document.createElement(tags[eventName] || 'div');\n eventName = 'on' + eventName;\n return supports[eventName] = (eventName in el);\n };\n return eventChecker;\n})();\nexport function getCtrlForEvent(gridOptionsWrapper, event, type) {\n var sourceElement = event.target;\n while (sourceElement) {\n var renderedComp = gridOptionsWrapper.getDomData(sourceElement, type);\n if (renderedComp) {\n return renderedComp;\n }\n sourceElement = sourceElement.parentElement;\n }\n return null;\n}\n/**\n * @deprecated\n * Adds all type of change listeners to an element, intended to be a text field\n * @param {HTMLElement} element\n * @param {EventListener} listener\n */\nexport function addChangeListener(element, listener) {\n element.addEventListener('changed', listener);\n element.addEventListener('paste', listener);\n element.addEventListener('input', listener);\n}\nexport function isElementInEventPath(element, event) {\n if (!event || !element) {\n return false;\n }\n return getEventPath(event).indexOf(element) >= 0;\n}\nexport function createEventPath(event) {\n var res = [];\n var pointer = event.target;\n while (pointer) {\n res.push(pointer);\n pointer = pointer.parentElement;\n }\n return res;\n}\n/**\n * firefox doesn't have event.path set, or any alternative to it, so we hack\n * it in. this is needed as it's to late to work out the path when the item is\n * removed from the dom. used by MouseEventService, where it works out if a click\n * was from the current grid, or a detail grid (master / detail).\n * @param {Event} event\n */\nexport function addAgGridEventPath(event) {\n event.__agGridEventPath = getEventPath(event);\n}\n/**\n * Gets the path for an Event.\n * https://stackoverflow.com/questions/39245488/event-path-undefined-with-firefox-and-vue-js\n * https://developer.mozilla.org/en-US/docs/Web/API/Event\n * @param {Event} event\n * @returns {EventTarget[]}\n */\nexport function getEventPath(event) {\n var eventNoType = event;\n if (eventNoType.path) {\n // Chrome supports path\n return eventNoType.path;\n }\n if (eventNoType.composedPath) {\n // Firefox supports composePath\n return eventNoType.composedPath();\n }\n if (eventNoType.__agGridEventPath) {\n // Firefox supports composePath\n return eventNoType.__agGridEventPath;\n }\n // and finally, if none of the above worked,\n // we create the path ourselves\n return createEventPath(event);\n}\nexport function addSafePassiveEventListener(frameworkOverrides, eElement, event, listener) {\n var isPassive = includes(PASSIVE_EVENTS, event);\n var options = isPassive ? { passive: true } : undefined;\n // this check is here for certain scenarios where I believe the user must be destroying\n // the grid somehow but continuing for it to be used\n if (frameworkOverrides && frameworkOverrides.addEventListener) {\n frameworkOverrides.addEventListener(eElement, event, listener, options);\n }\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { EventService } from \"../eventService\";\nimport { Autowired, PreDestroy } from \"./context\";\nimport { addSafePassiveEventListener } from \"../utils/event\";\nvar BeanStub = /** @class */ (function () {\n function BeanStub() {\n var _this = this;\n this.destroyFunctions = [];\n this.destroyed = false;\n // for vue 3 - prevents Vue from trying to make this (and obviously any sub classes) from being reactive\n // prevents vue from creating proxies for created objects and prevents identity related issues\n this.__v_skip = true;\n this.isAlive = function () { return !_this.destroyed; };\n }\n // this was a test constructor niall built, when active, it prints after 5 seconds all beans/components that are\n // not destroyed. to use, create a new grid, then api.destroy() before 5 seconds. then anything that gets printed\n // points to a bean or component that was not properly disposed of.\n // constructor() {\n // setTimeout(()=> {\n // if (this.isAlive()) {\n // let prototype: any = Object.getPrototypeOf(this);\n // const constructor: any = prototype.constructor;\n // const constructorString = constructor.toString();\n // const beanName = constructorString.substring(9, constructorString.indexOf(\"(\"));\n // console.log('is alive ' + beanName);\n // }\n // }, 5000);\n // }\n // CellComp and GridComp and override this because they get the FrameworkOverrides from the Beans bean\n BeanStub.prototype.getFrameworkOverrides = function () {\n return this.frameworkOverrides;\n };\n BeanStub.prototype.getContext = function () {\n return this.context;\n };\n BeanStub.prototype.destroy = function () {\n // let prototype: any = Object.getPrototypeOf(this);\n // const constructor: any = prototype.constructor;\n // const constructorString = constructor.toString();\n // const beanName = constructorString.substring(9, constructorString.indexOf(\"(\"));\n this.destroyFunctions.forEach(function (func) { return func(); });\n this.destroyFunctions.length = 0;\n this.destroyed = true;\n this.dispatchEvent({ type: BeanStub.EVENT_DESTROYED });\n };\n BeanStub.prototype.addEventListener = function (eventType, listener) {\n if (!this.localEventService) {\n this.localEventService = new EventService();\n }\n this.localEventService.addEventListener(eventType, listener);\n };\n BeanStub.prototype.removeEventListener = function (eventType, listener) {\n if (this.localEventService) {\n this.localEventService.removeEventListener(eventType, listener);\n }\n };\n BeanStub.prototype.dispatchEventAsync = function (event) {\n var _this = this;\n window.setTimeout(function () { return _this.dispatchEvent(event); }, 0);\n };\n BeanStub.prototype.dispatchEvent = function (event) {\n if (this.localEventService) {\n this.localEventService.dispatchEvent(event);\n }\n };\n BeanStub.prototype.addManagedListener = function (object, event, listener) {\n var _this = this;\n if (this.destroyed) {\n return;\n }\n if (object instanceof HTMLElement) {\n addSafePassiveEventListener(this.getFrameworkOverrides(), object, event, listener);\n }\n else {\n object.addEventListener(event, listener);\n }\n var destroyFunc = function () {\n object.removeEventListener(event, listener);\n _this.destroyFunctions = _this.destroyFunctions.filter(function (fn) { return fn !== destroyFunc; });\n return null;\n };\n this.destroyFunctions.push(destroyFunc);\n return destroyFunc;\n };\n BeanStub.prototype.addDestroyFunc = function (func) {\n // if we are already destroyed, we execute the func now\n if (this.isAlive()) {\n this.destroyFunctions.push(func);\n }\n else {\n func();\n }\n };\n BeanStub.prototype.createManagedBean = function (bean, context) {\n var res = this.createBean(bean, context);\n this.addDestroyFunc(this.destroyBean.bind(this, bean, context));\n return res;\n };\n BeanStub.prototype.createBean = function (bean, context, afterPreCreateCallback) {\n return (context || this.getContext()).createBean(bean, afterPreCreateCallback);\n };\n BeanStub.prototype.destroyBean = function (bean, context) {\n return (context || this.getContext()).destroyBean(bean);\n };\n BeanStub.prototype.destroyBeans = function (beans, context) {\n var _this = this;\n if (beans) {\n beans.forEach(function (bean) { return _this.destroyBean(bean, context); });\n }\n return [];\n };\n BeanStub.EVENT_DESTROYED = 'destroyed';\n __decorate([\n Autowired('frameworkOverrides')\n ], BeanStub.prototype, \"frameworkOverrides\", void 0);\n __decorate([\n Autowired('context')\n ], BeanStub.prototype, \"context\", void 0);\n __decorate([\n Autowired('eventService')\n ], BeanStub.prototype, \"eventService\", void 0);\n __decorate([\n Autowired('gridOptionsWrapper')\n ], BeanStub.prototype, \"gridOptionsWrapper\", void 0);\n __decorate([\n PreDestroy\n ], BeanStub.prototype, \"destroy\", null);\n return BeanStub;\n}());\nexport { BeanStub };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n};\nimport { ColumnKeyCreator } from \"./columnKeyCreator\";\nimport { ProvidedColumnGroup } from \"../entities/providedColumnGroup\";\nimport { Column } from \"../entities/column\";\nimport { Autowired, Bean, Qualifier } from \"../context/context\";\nimport { DefaultColumnTypes } from \"../entities/defaultColumnTypes\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { Constants } from \"../constants/constants\";\nimport { iterateObject, mergeDeep } from '../utils/object';\nimport { attrToNumber, attrToBoolean } from '../utils/generic';\nimport { removeFromArray } from '../utils/array';\n// takes ColDefs and ColGroupDefs and turns them into Columns and OriginalGroups\nvar ColumnFactory = /** @class */ (function (_super) {\n __extends(ColumnFactory, _super);\n function ColumnFactory() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n ColumnFactory.prototype.setBeans = function (loggerFactory) {\n this.logger = loggerFactory.create('ColumnFactory');\n };\n ColumnFactory.prototype.createColumnTree = function (defs, primaryColumns, existingTree) {\n // column key creator dishes out unique column id's in a deterministic way,\n // so if we have two grids (that could be master/slave) with same column definitions,\n // then this ensures the two grids use identical id's.\n var columnKeyCreator = new ColumnKeyCreator();\n var _a = this.extractExistingTreeData(existingTree), existingCols = _a.existingCols, existingGroups = _a.existingGroups, existingColKeys = _a.existingColKeys;\n columnKeyCreator.addExistingKeys(existingColKeys);\n // create am unbalanced tree that maps the provided definitions\n var unbalancedTree = this.recursivelyCreateColumns(defs, 0, primaryColumns, existingCols, columnKeyCreator, existingGroups);\n var treeDept = this.findMaxDept(unbalancedTree, 0);\n this.logger.log('Number of levels for grouped columns is ' + treeDept);\n var columnTree = this.balanceColumnTree(unbalancedTree, 0, treeDept, columnKeyCreator);\n var deptFirstCallback = function (child, parent) {\n if (child instanceof ProvidedColumnGroup) {\n child.setupExpandable();\n }\n // we set the original parents at the end, rather than when we go along, as balancing the tree\n // adds extra levels into the tree. so we can only set parents when balancing is done.\n child.setOriginalParent(parent);\n };\n this.columnUtils.depthFirstOriginalTreeSearch(null, columnTree, deptFirstCallback);\n return {\n columnTree: columnTree,\n treeDept: treeDept\n };\n };\n ColumnFactory.prototype.extractExistingTreeData = function (existingTree) {\n var existingCols = [];\n var existingGroups = [];\n var existingColKeys = [];\n if (existingTree) {\n this.columnUtils.depthFirstOriginalTreeSearch(null, existingTree, function (item) {\n if (item instanceof ProvidedColumnGroup) {\n var group = item;\n existingGroups.push(group);\n }\n else {\n var col = item;\n existingColKeys.push(col.getId());\n existingCols.push(col);\n }\n });\n }\n return { existingCols: existingCols, existingGroups: existingGroups, existingColKeys: existingColKeys };\n };\n ColumnFactory.prototype.createForAutoGroups = function (autoGroupCols, gridBalancedTree) {\n var _this = this;\n return autoGroupCols.map(function (col) { return _this.createAutoGroupTreeItem(gridBalancedTree, col); });\n };\n ColumnFactory.prototype.createAutoGroupTreeItem = function (balancedColumnTree, column) {\n var dept = this.findDepth(balancedColumnTree);\n // at the end, this will be the top of the tree item.\n var nextChild = column;\n for (var i = dept - 1; i >= 0; i--) {\n var autoGroup = new ProvidedColumnGroup(null, \"FAKE_PATH_\" + column.getId() + \"}_\" + i, true, i);\n this.context.createBean(autoGroup);\n autoGroup.setChildren([nextChild]);\n nextChild.setOriginalParent(autoGroup);\n nextChild = autoGroup;\n }\n // at this point, the nextChild is the top most item in the tree\n return nextChild;\n };\n ColumnFactory.prototype.findDepth = function (balancedColumnTree) {\n var dept = 0;\n var pointer = balancedColumnTree;\n while (pointer && pointer[0] && pointer[0] instanceof ProvidedColumnGroup) {\n dept++;\n pointer = pointer[0].getChildren();\n }\n return dept;\n };\n ColumnFactory.prototype.balanceColumnTree = function (unbalancedTree, currentDept, columnDept, columnKeyCreator) {\n var result = [];\n // go through each child, for groups, recurse a level deeper,\n // for columns we need to pad\n for (var i = 0; i < unbalancedTree.length; i++) {\n var child = unbalancedTree[i];\n if (child instanceof ProvidedColumnGroup) {\n // child is a group, all we do is go to the next level of recursion\n var originalGroup = child;\n var newChildren = this.balanceColumnTree(originalGroup.getChildren(), currentDept + 1, columnDept, columnKeyCreator);\n originalGroup.setChildren(newChildren);\n result.push(originalGroup);\n }\n else {\n // child is a column - so here we add in the padded column groups if needed\n var firstPaddedGroup = void 0;\n var currentPaddedGroup = void 0;\n // this for loop will NOT run any loops if no padded column groups are needed\n for (var j = columnDept - 1; j >= currentDept; j--) {\n var newColId = columnKeyCreator.getUniqueKey(null, null);\n var colGroupDefMerged = this.createMergedColGroupDef(null);\n var paddedGroup = new ProvidedColumnGroup(colGroupDefMerged, newColId, true, currentDept);\n this.context.createBean(paddedGroup);\n if (currentPaddedGroup) {\n currentPaddedGroup.setChildren([paddedGroup]);\n }\n currentPaddedGroup = paddedGroup;\n if (!firstPaddedGroup) {\n firstPaddedGroup = currentPaddedGroup;\n }\n }\n // likewise this if statement will not run if no padded groups\n if (firstPaddedGroup && currentPaddedGroup) {\n result.push(firstPaddedGroup);\n var hasGroups = unbalancedTree.some(function (leaf) { return leaf instanceof ProvidedColumnGroup; });\n if (hasGroups) {\n currentPaddedGroup.setChildren([child]);\n continue;\n }\n else {\n currentPaddedGroup.setChildren(unbalancedTree);\n break;\n }\n }\n result.push(child);\n }\n }\n return result;\n };\n ColumnFactory.prototype.findMaxDept = function (treeChildren, dept) {\n var maxDeptThisLevel = dept;\n for (var i = 0; i < treeChildren.length; i++) {\n var abstractColumn = treeChildren[i];\n if (abstractColumn instanceof ProvidedColumnGroup) {\n var originalGroup = abstractColumn;\n var newDept = this.findMaxDept(originalGroup.getChildren(), dept + 1);\n if (maxDeptThisLevel < newDept) {\n maxDeptThisLevel = newDept;\n }\n }\n }\n return maxDeptThisLevel;\n };\n ColumnFactory.prototype.recursivelyCreateColumns = function (defs, level, primaryColumns, existingColsCopy, columnKeyCreator, existingGroups) {\n var _this = this;\n return (defs || []).map(function (def) {\n if (_this.isColumnGroup(def)) {\n return _this.createColumnGroup(primaryColumns, def, level, existingColsCopy, columnKeyCreator, existingGroups);\n }\n else {\n return _this.createColumn(primaryColumns, def, existingColsCopy, columnKeyCreator);\n }\n });\n };\n ColumnFactory.prototype.createColumnGroup = function (primaryColumns, colGroupDef, level, existingColumns, columnKeyCreator, existingGroups) {\n var colGroupDefMerged = this.createMergedColGroupDef(colGroupDef);\n var groupId = columnKeyCreator.getUniqueKey(colGroupDefMerged.groupId || null, null);\n var providedGroup = new ProvidedColumnGroup(colGroupDefMerged, groupId, false, level);\n this.context.createBean(providedGroup);\n var existingGroup = this.findExistingGroup(colGroupDef, existingGroups);\n // make sure we remove, so if user provided duplicate id, then we don't have more than\n // one column instance for colDef with common id\n if (existingGroup) {\n removeFromArray(existingGroups, existingGroup);\n }\n if (existingGroup && existingGroup.isExpanded()) {\n providedGroup.setExpanded(true);\n }\n var children = this.recursivelyCreateColumns(colGroupDefMerged.children, level + 1, primaryColumns, existingColumns, columnKeyCreator, existingGroups);\n providedGroup.setChildren(children);\n return providedGroup;\n };\n ColumnFactory.prototype.createMergedColGroupDef = function (colGroupDef) {\n var colGroupDefMerged = {};\n Object.assign(colGroupDefMerged, this.gridOptionsWrapper.getDefaultColGroupDef());\n Object.assign(colGroupDefMerged, colGroupDef);\n this.checkForDeprecatedItems(colGroupDefMerged);\n return colGroupDefMerged;\n };\n ColumnFactory.prototype.createColumn = function (primaryColumns, colDef, existingColsCopy, columnKeyCreator) {\n var colDefMerged = this.mergeColDefs(colDef);\n this.checkForDeprecatedItems(colDefMerged);\n // see if column already exists\n var column = this.findExistingColumn(colDef, existingColsCopy);\n // make sure we remove, so if user provided duplicate id, then we don't have more than\n // one column instance for colDef with common id\n if (existingColsCopy && column) {\n removeFromArray(existingColsCopy, column);\n }\n if (!column) {\n // no existing column, need to create one\n var colId = columnKeyCreator.getUniqueKey(colDefMerged.colId, colDefMerged.field);\n column = new Column(colDefMerged, colDef, colId, primaryColumns);\n this.context.createBean(column);\n }\n else {\n column.setColDef(colDefMerged, colDef);\n this.applyColumnState(column, colDefMerged);\n }\n return column;\n };\n ColumnFactory.prototype.applyColumnState = function (column, colDef) {\n // flex\n var flex = attrToNumber(colDef.flex);\n if (flex !== undefined) {\n column.setFlex(flex);\n }\n // width - we only set width if column is not flexing\n var noFlexThisCol = column.getFlex() <= 0;\n if (noFlexThisCol) {\n // both null and undefined means we skip, as it's not possible to 'clear' width (a column must have a width)\n var width = attrToNumber(colDef.width);\n if (width != null) {\n column.setActualWidth(width);\n }\n else {\n // otherwise set the width again, in case min or max width has changed,\n // and width needs to be adjusted.\n var widthBeforeUpdate = column.getActualWidth();\n column.setActualWidth(widthBeforeUpdate);\n }\n }\n // sort - anything but undefined will set sort, thus null or empty string will clear the sort\n if (colDef.sort !== undefined) {\n if (colDef.sort == Constants.SORT_ASC || colDef.sort == Constants.SORT_DESC) {\n column.setSort(colDef.sort);\n }\n else {\n column.setSort(undefined);\n }\n }\n // sorted at - anything but undefined, thus null will clear the sortIndex\n var sortIndex = attrToNumber(colDef.sortIndex);\n if (sortIndex !== undefined) {\n column.setSortIndex(sortIndex);\n }\n // hide - anything but undefined, thus null will clear the hide\n var hide = attrToBoolean(colDef.hide);\n if (hide !== undefined) {\n column.setVisible(!hide);\n }\n // pinned - anything but undefined, thus null or empty string will remove pinned\n if (colDef.pinned !== undefined) {\n column.setPinned(colDef.pinned);\n }\n };\n ColumnFactory.prototype.findExistingColumn = function (newColDef, existingColsCopy) {\n return (existingColsCopy || []).find(function (existingCol) {\n var existingColDef = existingCol.getUserProvidedColDef();\n if (!existingColDef) {\n return false;\n }\n var newHasId = newColDef.colId != null;\n var newHasField = newColDef.field != null;\n if (newHasId) {\n return existingCol.getId() === newColDef.colId;\n }\n if (newHasField) {\n return existingColDef.field === newColDef.field;\n }\n // if no id or field present, then try object equivalence.\n if (existingColDef === newColDef) {\n return true;\n }\n return false;\n });\n };\n ColumnFactory.prototype.findExistingGroup = function (newGroupDef, existingGroups) {\n return existingGroups.find(function (existingGroup) {\n var existingDef = existingGroup.getColGroupDef();\n if (!existingDef) {\n return false;\n }\n var newHasId = newGroupDef.groupId != null;\n if (newHasId) {\n return existingGroup.getId() === newGroupDef.groupId;\n }\n return false;\n });\n };\n ColumnFactory.prototype.mergeColDefs = function (colDef) {\n // start with empty merged definition\n var colDefMerged = {};\n // merge properties from default column definitions\n var defaultColDef = this.gridOptionsWrapper.getDefaultColDef();\n mergeDeep(colDefMerged, defaultColDef, false, true);\n // merge properties from column type properties\n var columnType = colDef.type;\n if (!columnType) {\n columnType = defaultColDef && defaultColDef.type;\n }\n // if type of both colDef and defaultColDef, then colDef gets preference\n if (columnType) {\n this.assignColumnTypes(columnType, colDefMerged);\n }\n // merge properties from column definitions\n mergeDeep(colDefMerged, colDef, false, true);\n var autoGroupColDef = this.gridOptionsWrapper.getAutoGroupColumnDef();\n var isSortingCoupled = this.gridOptionsWrapper.isColumnsSortingCoupledToGroup();\n if (colDef.rowGroup && autoGroupColDef && isSortingCoupled) {\n // override the sort for row group columns where the autoGroupColDef defines these values.\n mergeDeep(colDefMerged, { sort: autoGroupColDef.sort, initialSort: autoGroupColDef.initialSort }, false, true);\n }\n return colDefMerged;\n };\n ColumnFactory.prototype.assignColumnTypes = function (type, colDefMerged) {\n var typeKeys = [];\n if (type instanceof Array) {\n var invalidArray = type.some(function (a) { return typeof a !== 'string'; });\n if (invalidArray) {\n console.warn(\"AG Grid: if colDef.type is supplied an array it should be of type 'string[]'\");\n }\n else {\n typeKeys = type;\n }\n }\n else if (typeof type === 'string') {\n typeKeys = type.split(',');\n }\n else {\n console.warn(\"AG Grid: colDef.type should be of type 'string' | 'string[]'\");\n return;\n }\n // merge user defined with default column types\n var allColumnTypes = Object.assign({}, DefaultColumnTypes);\n var userTypes = this.gridOptionsWrapper.getColumnTypes() || {};\n iterateObject(userTypes, function (key, value) {\n if (key in allColumnTypes) {\n console.warn(\"AG Grid: the column type '\" + key + \"' is a default column type and cannot be overridden.\");\n }\n else {\n allColumnTypes[key] = value;\n }\n });\n typeKeys.forEach(function (t) {\n var typeColDef = allColumnTypes[t.trim()];\n if (typeColDef) {\n mergeDeep(colDefMerged, typeColDef, false, true);\n }\n else {\n console.warn(\"AG Grid: colDef.type '\" + t + \"' does not correspond to defined gridOptions.columnTypes\");\n }\n });\n };\n ColumnFactory.prototype.checkForDeprecatedItems = function (colDef) {\n if (colDef) {\n var colDefNoType = colDef; // take out the type, so we can access attributes not defined in the type\n if (colDefNoType.group !== undefined) {\n console.warn('AG Grid: colDef.group is invalid, please check documentation on how to do grouping as it changed in version 3');\n }\n if (colDefNoType.headerGroup !== undefined) {\n console.warn('AG Grid: colDef.headerGroup is invalid, please check documentation on how to do grouping as it changed in version 3');\n }\n if (colDefNoType.headerGroupShow !== undefined) {\n console.warn('AG Grid: colDef.headerGroupShow is invalid, should be columnGroupShow, please check documentation on how to do grouping as it changed in version 3');\n }\n if (colDefNoType.suppressRowGroup !== undefined) {\n console.warn('AG Grid: colDef.suppressRowGroup is deprecated, please use colDef.type instead');\n }\n if (colDefNoType.suppressAggregation !== undefined) {\n console.warn('AG Grid: colDef.suppressAggregation is deprecated, please use colDef.type instead');\n }\n if (colDefNoType.suppressRowGroup || colDefNoType.suppressAggregation) {\n console.warn('AG Grid: colDef.suppressAggregation and colDef.suppressRowGroup are deprecated, use allowRowGroup, allowPivot and allowValue instead');\n }\n if (colDefNoType.displayName) {\n console.warn(\"AG Grid: Found displayName \" + colDefNoType.displayName + \", please use headerName instead, displayName is deprecated.\");\n colDefNoType.headerName = colDefNoType.displayName;\n }\n }\n };\n // if object has children, we assume it's a group\n ColumnFactory.prototype.isColumnGroup = function (abstractColDef) {\n return abstractColDef.children !== undefined;\n };\n __decorate([\n Autowired('columnUtils')\n ], ColumnFactory.prototype, \"columnUtils\", void 0);\n __decorate([\n __param(0, Qualifier('loggerFactory'))\n ], ColumnFactory.prototype, \"setBeans\", null);\n ColumnFactory = __decorate([\n Bean('columnFactory')\n ], ColumnFactory);\n return ColumnFactory;\n}(BeanStub));\nexport { ColumnFactory };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar Events = /** @class */ (function () {\n function Events() {\n }\n /** Everything has changed with the columns. Either complete new set of columns set, or user called setState() */\n /** @deprecated - grid no longer uses this, and setSate() also fires individual events */\n Events.EVENT_COLUMN_EVERYTHING_CHANGED = 'columnEverythingChanged';\n /** User has set in new columns. */\n Events.EVENT_NEW_COLUMNS_LOADED = 'newColumnsLoaded';\n /** The pivot mode flag was changed */\n Events.EVENT_COLUMN_PIVOT_MODE_CHANGED = 'columnPivotModeChanged';\n /** A row group column was added, removed or order changed. */\n Events.EVENT_COLUMN_ROW_GROUP_CHANGED = 'columnRowGroupChanged';\n /** expandAll / collapseAll was called from the api. */\n Events.EVENT_EXPAND_COLLAPSE_ALL = 'expandOrCollapseAll';\n /** A pivot column was added, removed or order changed. */\n Events.EVENT_COLUMN_PIVOT_CHANGED = 'columnPivotChanged';\n /** The list of grid columns has changed. */\n Events.EVENT_GRID_COLUMNS_CHANGED = 'gridColumnsChanged';\n /** A value column was added, removed or agg function was changed. */\n Events.EVENT_COLUMN_VALUE_CHANGED = 'columnValueChanged';\n /** A column was moved */\n Events.EVENT_COLUMN_MOVED = 'columnMoved';\n /** One or more columns was shown / hidden */\n Events.EVENT_COLUMN_VISIBLE = 'columnVisible';\n /** One or more columns was pinned / unpinned*/\n Events.EVENT_COLUMN_PINNED = 'columnPinned';\n /** A column group was opened / closed */\n Events.EVENT_COLUMN_GROUP_OPENED = 'columnGroupOpened';\n /** One or more columns was resized. If just one, the column in the event is set. */\n Events.EVENT_COLUMN_RESIZED = 'columnResized';\n /** The list of displayed columns has changed, can result from columns open / close, column move, pivot, group, etc */\n Events.EVENT_DISPLAYED_COLUMNS_CHANGED = 'displayedColumnsChanged';\n /** The list of virtual columns has changed, results from viewport changing */\n Events.EVENT_VIRTUAL_COLUMNS_CHANGED = 'virtualColumnsChanged';\n /** Async Transactions Executed */\n Events.EVENT_ASYNC_TRANSACTIONS_FLUSHED = 'asyncTransactionsFlushed';\n /** A row group was opened / closed */\n Events.EVENT_ROW_GROUP_OPENED = 'rowGroupOpened';\n /** @deprecated use EVENT_ROW_DATA_UPDATED instead */\n Events.EVENT_ROW_DATA_CHANGED = 'rowDataChanged';\n /** The client has updated data for the grid */\n Events.EVENT_ROW_DATA_UPDATED = 'rowDataUpdated';\n /** The client has set new floating data into the grid */\n Events.EVENT_PINNED_ROW_DATA_CHANGED = 'pinnedRowDataChanged';\n /** Range selection has changed */\n Events.EVENT_RANGE_SELECTION_CHANGED = 'rangeSelectionChanged';\n /** Chart was created */\n Events.EVENT_CHART_CREATED = 'chartCreated';\n /** Chart Range selection has changed */\n Events.EVENT_CHART_RANGE_SELECTION_CHANGED = 'chartRangeSelectionChanged';\n /** Chart Options have changed */\n Events.EVENT_CHART_OPTIONS_CHANGED = 'chartOptionsChanged';\n /** Chart was destroyed */\n Events.EVENT_CHART_DESTROYED = 'chartDestroyed';\n /** For when the tool panel is shown / hidden */\n Events.EVENT_TOOL_PANEL_VISIBLE_CHANGED = 'toolPanelVisibleChanged';\n Events.EVENT_COLUMN_PANEL_ITEM_DRAG_START = 'columnPanelItemDragStart';\n Events.EVENT_COLUMN_PANEL_ITEM_DRAG_END = 'columnPanelItemDragEnd';\n /** Model was updated - grid updates the drawn rows when this happens */\n Events.EVENT_MODEL_UPDATED = 'modelUpdated';\n Events.EVENT_PASTE_START = 'pasteStart';\n Events.EVENT_PASTE_END = 'pasteEnd';\n Events.EVENT_FILL_START = 'fillStart';\n Events.EVENT_FILL_END = 'fillEnd';\n Events.EVENT_CELL_CLICKED = 'cellClicked';\n Events.EVENT_CELL_DOUBLE_CLICKED = 'cellDoubleClicked';\n Events.EVENT_CELL_MOUSE_DOWN = 'cellMouseDown';\n Events.EVENT_CELL_CONTEXT_MENU = 'cellContextMenu';\n Events.EVENT_CELL_VALUE_CHANGED = 'cellValueChanged';\n Events.EVENT_CELL_EDIT_REQUEST = 'cellEditRequest';\n Events.EVENT_ROW_VALUE_CHANGED = 'rowValueChanged';\n Events.EVENT_CELL_FOCUSED = 'cellFocused';\n Events.EVENT_FULL_WIDTH_ROW_FOCUSED = 'fullWidthRowFocused';\n Events.EVENT_ROW_SELECTED = 'rowSelected';\n Events.EVENT_SELECTION_CHANGED = 'selectionChanged';\n Events.EVENT_CELL_KEY_DOWN = 'cellKeyDown';\n Events.EVENT_CELL_KEY_PRESS = 'cellKeyPress';\n Events.EVENT_CELL_MOUSE_OVER = 'cellMouseOver';\n Events.EVENT_CELL_MOUSE_OUT = 'cellMouseOut';\n /** 2 events for filtering. The grid LISTENS for filterChanged and afterFilterChanged */\n Events.EVENT_FILTER_CHANGED = 'filterChanged';\n /** Filter was change but not applied. Only useful if apply buttons are used in filters. */\n Events.EVENT_FILTER_MODIFIED = 'filterModified';\n Events.EVENT_FILTER_OPENED = 'filterOpened';\n Events.EVENT_SORT_CHANGED = 'sortChanged';\n /** A row was removed from the dom, for any reason. Use to clean up resources (if any) used by the row. */\n Events.EVENT_VIRTUAL_ROW_REMOVED = 'virtualRowRemoved';\n Events.EVENT_ROW_CLICKED = 'rowClicked';\n Events.EVENT_ROW_DOUBLE_CLICKED = 'rowDoubleClicked';\n /** Gets called once after the grid has finished initialising. */\n Events.EVENT_GRID_READY = 'gridReady';\n /** Width of height of the main grid div has changed. Grid listens for this and does layout of grid if it's\n * changed, so always filling the space it was given. */\n Events.EVENT_GRID_SIZE_CHANGED = 'gridSizeChanged';\n /** The indexes of the rows rendered has changed, eg user has scrolled to a new vertical position. */\n Events.EVENT_VIEWPORT_CHANGED = 'viewportChanged';\n /* The width of the scrollbar has been calculated */\n Events.EVENT_SCROLLBAR_WIDTH_CHANGED = 'scrollbarWidthChanged';\n /** Rows were rendered for the first time (ie on async data load). */\n Events.EVENT_FIRST_DATA_RENDERED = 'firstDataRendered';\n /** A column drag has started, either resizing a column or moving a column. */\n Events.EVENT_DRAG_STARTED = 'dragStarted';\n /** A column drag has stopped */\n Events.EVENT_DRAG_STOPPED = 'dragStopped';\n Events.EVENT_CHECKBOX_CHANGED = 'checkboxChanged';\n Events.EVENT_ROW_EDITING_STARTED = 'rowEditingStarted';\n Events.EVENT_ROW_EDITING_STOPPED = 'rowEditingStopped';\n Events.EVENT_CELL_EDITING_STARTED = 'cellEditingStarted';\n Events.EVENT_CELL_EDITING_STOPPED = 'cellEditingStopped';\n /** Main body of grid has scrolled, either horizontally or vertically */\n Events.EVENT_BODY_SCROLL = 'bodyScroll';\n /** Main body of the grid has stopped scrolling, either horizontally or vertically */\n Events.EVENT_BODY_SCROLL_END = 'bodyScrollEnd';\n Events.EVENT_HEIGHT_SCALE_CHANGED = 'heightScaleChanged';\n /** The displayed page for pagination has changed. For example the data was filtered or sorted,\n * or the user has moved to a different page. */\n Events.EVENT_PAGINATION_CHANGED = 'paginationChanged';\n /** Only used by React, Angular, Web Components and VueJS AG Grid components\n * (not used if doing plain JavaScript). If the grid receives changes due\n * to bound properties, this event fires after the grid has finished processing the change. */\n Events.EVENT_COMPONENT_STATE_CHANGED = 'componentStateChanged';\n /***************************** INTERNAL EVENTS: START ******************************************* */\n /** Please remember to add to ComponentUtil.EXCLUDED_INTERNAL_EVENTS to not have these events exposed to framework components. */\n /** All items from here down are used internally by the grid, not intended for external use. */\n // not documented, either experimental, or we just don't want users using an depending on them\n Events.EVENT_BODY_HEIGHT_CHANGED = 'bodyHeightChanged';\n Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED = 'displayedColumnsWidthChanged';\n Events.EVENT_SCROLL_VISIBILITY_CHANGED = 'scrollVisibilityChanged';\n Events.EVENT_COLUMN_HOVER_CHANGED = 'columnHoverChanged';\n Events.EVENT_FLASH_CELLS = 'flashCells';\n Events.EVENT_PAGINATION_PIXEL_OFFSET_CHANGED = 'paginationPixelOffsetChanged';\n Events.EVENT_DISPLAYED_ROWS_CHANGED = 'displayedRowsChanged';\n Events.EVENT_LEFT_PINNED_WIDTH_CHANGED = 'leftPinnedWidthChanged';\n Events.EVENT_RIGHT_PINNED_WIDTH_CHANGED = 'rightPinnedWidthChanged';\n Events.EVENT_ROW_CONTAINER_HEIGHT_CHANGED = 'rowContainerHeightChanged';\n Events.EVENT_HEADER_HEIGHT_CHANGED = 'headerHeightChanged';\n Events.EVENT_COLUMN_HEADER_HEIGHT_CHANGED = 'columnHeaderHeightChanged';\n Events.EVENT_ROW_DRAG_ENTER = 'rowDragEnter';\n Events.EVENT_ROW_DRAG_MOVE = 'rowDragMove';\n Events.EVENT_ROW_DRAG_LEAVE = 'rowDragLeave';\n Events.EVENT_ROW_DRAG_END = 'rowDragEnd';\n // primarily for charts\n Events.EVENT_POPUP_TO_FRONT = 'popupToFront';\n // these are used for server side group and agg - only used by CS with Viewport Row Model - intention is\n // to design these better around server side functions and then release to general public when fully working with\n // all the row models.\n Events.EVENT_COLUMN_ROW_GROUP_CHANGE_REQUEST = 'columnRowGroupChangeRequest';\n Events.EVENT_COLUMN_PIVOT_CHANGE_REQUEST = 'columnPivotChangeRequest';\n Events.EVENT_COLUMN_VALUE_CHANGE_REQUEST = 'columnValueChangeRequest';\n Events.EVENT_COLUMN_AGG_FUNC_CHANGE_REQUEST = 'columnAggFuncChangeRequest';\n Events.EVENT_KEYBOARD_FOCUS = 'keyboardFocus';\n Events.EVENT_MOUSE_FOCUS = 'mouseFocus';\n Events.EVENT_STORE_UPDATED = 'storeUpdated';\n return Events;\n}());\nexport { Events };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\n// class returns unique instance id's for columns.\n// eg, the following calls (in this order) will result in:\n//\n// getInstanceIdForKey('country') => 0\n// getInstanceIdForKey('country') => 1\n// getInstanceIdForKey('country') => 2\n// getInstanceIdForKey('country') => 3\n// getInstanceIdForKey('age') => 0\n// getInstanceIdForKey('age') => 1\n// getInstanceIdForKey('country') => 4\nvar GroupInstanceIdCreator = /** @class */ (function () {\n function GroupInstanceIdCreator() {\n // this map contains keys to numbers, so we remember what the last call was\n this.existingIds = {};\n }\n GroupInstanceIdCreator.prototype.getInstanceIdForKey = function (key) {\n var lastResult = this.existingIds[key];\n var result;\n if (typeof lastResult !== 'number') {\n // first time this key\n result = 0;\n }\n else {\n result = lastResult + 1;\n }\n this.existingIds[key] = result;\n return result;\n };\n return GroupInstanceIdCreator;\n}());\nexport { GroupInstanceIdCreator };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar reUnescapedHtml = /[&<>\"']/g;\n/**\n * HTML Escapes.\n */\nvar HTML_ESCAPES = {\n '&': '&',\n '<': '<',\n '>': '>',\n '\"': '"',\n \"'\": '''\n};\n/**\n * It encodes any string in UTF-8 format\n * taken from https://github.com/mathiasbynens/utf8.js\n * @param {string} s\n * @returns {string}\n */\nexport function utf8_encode(s) {\n var stringFromCharCode = String.fromCharCode;\n function ucs2decode(string) {\n var output = [];\n if (!string) {\n return [];\n }\n var len = string.length;\n var counter = 0;\n var value;\n var extra;\n while (counter < len) {\n value = string.charCodeAt(counter++);\n if (value >= 0xD800 && value <= 0xDBFF && counter < len) {\n // high surrogate, and there is a next character\n extra = string.charCodeAt(counter++);\n if ((extra & 0xFC00) == 0xDC00) { // low surrogate\n output.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000);\n }\n else {\n // unmatched surrogate; only append this code unit, in case the next\n // code unit is the high surrogate of a surrogate pair\n output.push(value);\n counter--;\n }\n }\n else {\n output.push(value);\n }\n }\n return output;\n }\n function checkScalarValue(point) {\n if (point >= 0xD800 && point <= 0xDFFF) {\n throw Error('Lone surrogate U+' + point.toString(16).toUpperCase() +\n ' is not a scalar value');\n }\n }\n function createByte(point, shift) {\n return stringFromCharCode(((point >> shift) & 0x3F) | 0x80);\n }\n function encodeCodePoint(point) {\n if ((point >= 0 && point <= 31 && point !== 10)) {\n var convertedCode = point.toString(16).toUpperCase();\n var paddedCode = convertedCode.padStart(4, '0');\n return \"_x\" + paddedCode + \"_\";\n }\n if ((point & 0xFFFFFF80) == 0) { // 1-byte sequence\n return stringFromCharCode(point);\n }\n var symbol = '';\n if ((point & 0xFFFFF800) == 0) { // 2-byte sequence\n symbol = stringFromCharCode(((point >> 6) & 0x1F) | 0xC0);\n }\n else if ((point & 0xFFFF0000) == 0) { // 3-byte sequence\n checkScalarValue(point);\n symbol = stringFromCharCode(((point >> 12) & 0x0F) | 0xE0);\n symbol += createByte(point, 6);\n }\n else if ((point & 0xFFE00000) == 0) { // 4-byte sequence\n symbol = stringFromCharCode(((point >> 18) & 0x07) | 0xF0);\n symbol += createByte(point, 12);\n symbol += createByte(point, 6);\n }\n symbol += stringFromCharCode((point & 0x3F) | 0x80);\n return symbol;\n }\n var codePoints = ucs2decode(s);\n var length = codePoints.length;\n var index = -1;\n var codePoint;\n var byteString = '';\n while (++index < length) {\n codePoint = codePoints[index];\n byteString += encodeCodePoint(codePoint);\n }\n return byteString;\n}\n/**\n * Converts a camelCase string into hyphenated string\n * from https://gist.github.com/youssman/745578062609e8acac9f\n * @param {string} str\n * @return {string}\n */\nexport function camelCaseToHyphen(str) {\n if (str === null || str === undefined) {\n return null;\n }\n return str.replace(/([A-Z])/g, function (g) { return '-' + g[0].toLowerCase(); });\n}\n/**\n * Converts a hyphenated string into camelCase string\n * from https://stackoverflow.com/questions/6660977/convert-hyphens-to-camel-case-camelcase\n * @param {string} str\n * @return {string}\n */\nexport function hyphenToCamelCase(str) {\n if (str === null || str === undefined) {\n return null;\n }\n return str.replace(/-([a-z])/g, function (g) { return g[1].toUpperCase(); });\n}\nexport function capitalise(str) {\n return str[0].toUpperCase() + str.substr(1).toLowerCase();\n}\nexport function escapeString(toEscape) {\n // we call toString() twice, in case value is an object, where user provides\n // a toString() method, and first call to toString() returns back something other\n // than a string (eg a number to render)\n return toEscape == null ? null : toEscape.toString().toString().replace(reUnescapedHtml, function (chr) { return HTML_ESCAPES[chr]; });\n}\n/**\n * Converts a camelCase string into regular text\n * from: https://stackoverflow.com/questions/15369566/putting-space-in-camel-case-string-using-regular-expression\n * @param {string} camelCase\n * @return {string}\n */\nexport function camelCaseToHumanText(camelCase) {\n if (!camelCase || camelCase == null) {\n return null;\n }\n var rex = /([A-Z])([A-Z])([a-z])|([a-z])([A-Z])/g;\n var words = camelCase.replace(rex, '$1$4 $2$3$5').replace('.', ' ').split(' ');\n return words.map(function (word) { return word.substring(0, 1).toUpperCase() + ((word.length > 1) ? word.substring(1, word.length) : ''); }).join(' ');\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nexport function convertToMap(arr) {\n var map = new Map();\n arr.forEach(function (pair) { return map.set(pair[0], pair[1]); });\n return map;\n}\n// handy for organising a list into a map, where each item is mapped by an attribute, eg mapping Columns by ID\nexport function mapById(arr, callback) {\n var map = new Map();\n arr.forEach(function (item) { return map.set(callback(item), item); });\n return map;\n}\nexport function keys(map) {\n var arr = [];\n map.forEach(function (_, key) { return arr.push(key); });\n return arr;\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nvar ColDefUtil = /** @class */ (function () {\n function ColDefUtil() {\n }\n ColDefUtil.STRING_PROPERTIES = [\n 'headerName',\n 'columnGroupShow',\n 'headerClass',\n 'toolPanelClass',\n 'headerValueGetter',\n 'pivotKeys',\n 'groupId',\n 'colId',\n 'sort',\n 'initialSort',\n 'field',\n 'type',\n 'tooltipComponent',\n 'tooltipField',\n 'headerTooltip',\n 'cellClass',\n 'showRowGroup',\n 'filter',\n 'initialAggFunc',\n 'defaultAggFunc',\n 'aggFunc',\n 'pinned',\n 'initialPinned',\n 'chartDataType',\n 'cellEditorPopupPosition'\n ];\n ColDefUtil.OBJECT_PROPERTIES = [\n 'headerGroupComponent',\n 'headerGroupComponentFramework',\n 'headerGroupComponentParams',\n 'cellStyle',\n 'cellRenderer',\n 'cellRendererParams',\n 'cellRendererFramework',\n 'cellEditor',\n 'cellEditorFramework',\n 'cellEditorParams',\n 'pinnedRowCellRendererFramework',\n 'pinnedRowCellRendererParams',\n 'filterFramework',\n 'filterParams',\n 'pivotValueColumn',\n 'headerComponent',\n 'headerComponentFramework',\n 'headerComponentParams',\n 'floatingFilterComponent',\n 'floatingFilterComponentParams',\n 'floatingFilterComponentFramework',\n 'floatingFilterFramework',\n 'tooltipComponent',\n 'tooltipComponentParams',\n 'tooltipComponentFramework',\n 'refData',\n 'columnsMenuParams'\n ];\n ColDefUtil.ARRAY_PROPERTIES = [\n 'children',\n 'sortingOrder',\n 'allowedAggFuncs',\n 'menuTabs',\n 'pivotTotalColumnIds',\n 'cellClassRules',\n 'icons'\n ];\n ColDefUtil.NUMBER_PROPERTIES = [\n 'sortedAt',\n 'sortIndex',\n 'initialSortIndex',\n 'flex',\n 'initialFlex',\n 'width',\n 'initialWidth',\n 'minWidth',\n 'maxWidth',\n 'rowGroupIndex',\n 'initialRowGroupIndex',\n 'pivotIndex',\n 'initialPivotIndex'\n ];\n ColDefUtil.BOOLEAN_PROPERTIES = [\n 'suppressCellFlash',\n 'suppressColumnsToolPanel',\n 'suppressFiltersToolPanel',\n 'openByDefault',\n 'marryChildren',\n 'hide',\n 'initialHide',\n 'rowGroup',\n 'initialRowGroup',\n 'pivot',\n 'initialPivot',\n 'checkboxSelection',\n 'showDisabledCheckboxes',\n 'headerCheckboxSelection',\n 'headerCheckboxSelectionFilteredOnly',\n 'suppressMenu',\n 'suppressMovable',\n 'lockPosition',\n 'lockVisible',\n 'lockPinned',\n 'unSortIcon',\n 'suppressSizeToFit',\n 'suppressAutoSize',\n 'enableRowGroup',\n 'enablePivot',\n 'enableValue',\n 'editable',\n 'suppressPaste',\n 'suppressNavigable',\n 'enableCellChangeFlash',\n 'rowDrag',\n 'dndSource',\n 'autoHeight',\n 'wrapText',\n 'sortable',\n 'resizable',\n 'singleClickEdit',\n 'floatingFilter',\n 'cellEditorPopup',\n 'suppressFillHandle',\n 'wrapHeaderText',\n 'autoHeaderHeight'\n ];\n ColDefUtil.FUNCTION_PROPERTIES = [\n 'dndSourceOnRowDrag',\n 'valueGetter',\n 'valueSetter',\n 'filterValueGetter',\n 'keyCreator',\n 'pinnedRowCellRenderer',\n 'valueFormatter',\n 'pinnedRowValueFormatter',\n 'valueParser',\n 'comparator',\n 'equals',\n 'pivotComparator',\n 'suppressKeyboardEvent',\n 'suppressHeaderKeyboardEvent',\n 'colSpan',\n 'rowSpan',\n 'getQuickFilterText',\n 'newValueHandler',\n 'onCellValueChanged',\n 'onCellClicked',\n 'onCellDoubleClicked',\n 'onCellContextMenu',\n 'rowDragText',\n 'tooltipValueGetter',\n 'tooltipComponent',\n 'tooltipComponentFramework',\n 'cellRendererSelector',\n 'cellEditorSelector'\n ];\n ColDefUtil.ALL_PROPERTIES = __spread(ColDefUtil.ARRAY_PROPERTIES, ColDefUtil.OBJECT_PROPERTIES, ColDefUtil.STRING_PROPERTIES, ColDefUtil.NUMBER_PROPERTIES, ColDefUtil.FUNCTION_PROPERTIES, ColDefUtil.BOOLEAN_PROPERTIES);\n // used when doing property checks - this causes noise when using frameworks which can add their own fw specific\n // properties to colDefs, gridOptions etc\n ColDefUtil.FRAMEWORK_PROPERTIES = [\n '__ob__',\n '__v_skip',\n '__metadata__',\n 'mappedColumnProperties',\n 'hasChildColumns',\n 'toColDef',\n 'createColDefFromGridColumn'\n ];\n return ColDefUtil;\n}());\nexport { ColDefUtil };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\n/**\n * These keys are used for validating properties supplied on a gridOptions object, and for code generation.\n * If you change the properties on the gridOptions interface, you *must* update this file as well to be consistent.\n */\nvar PropertyKeys = /** @class */ (function () {\n function PropertyKeys() {\n }\n PropertyKeys.STRING_PROPERTIES = [\n 'sortingOrder', 'rowClass', 'rowSelection', 'overlayLoadingTemplate', 'overlayNoRowsTemplate',\n 'quickFilterText', 'rowModelType', 'editType', 'domLayout', 'clipboardDelimiter', 'rowGroupPanelShow',\n 'multiSortKey', 'pivotColumnGroupTotals', 'pivotRowTotals', 'pivotPanelShow', 'fillHandleDirection',\n 'serverSideStoreType', 'groupDisplayType', 'treeDataDisplayType'\n ];\n PropertyKeys.OBJECT_PROPERTIES = [\n 'components', 'frameworkComponents', 'rowStyle', 'context', 'autoGroupColumnDef', 'localeText', 'icons',\n 'datasource', 'serverSideDatasource', 'viewportDatasource', 'groupRowRendererParams', 'aggFuncs', 'fullWidthCellRendererParams',\n 'defaultColGroupDef', 'defaultColDef', 'defaultExportParams', 'defaultCsvExportParams', 'defaultExcelExportParams', 'columnTypes',\n 'rowClassRules', 'detailCellRendererParams', 'loadingCellRendererParams', 'loadingOverlayComponentParams',\n 'noRowsOverlayComponentParams', 'popupParent', 'colResizeDefault', 'statusBar', 'sideBar', 'chartThemeOverrides',\n 'customChartThemes'\n ];\n PropertyKeys.ARRAY_PROPERTIES = [\n 'alignedGrids', 'rowData', 'columnDefs', 'excelStyles', 'pinnedTopRowData', 'pinnedBottomRowData', 'chartThemes'\n ];\n PropertyKeys.NUMBER_PROPERTIES = [\n 'rowHeight', 'detailRowHeight', 'rowBuffer', 'colWidth', 'headerHeight', 'groupHeaderHeight', 'floatingFiltersHeight',\n 'pivotHeaderHeight', 'pivotGroupHeaderHeight', 'groupDefaultExpanded', 'minColWidth', 'maxColWidth', 'viewportRowModelPageSize',\n 'viewportRowModelBufferSize', 'autoSizePadding', 'maxBlocksInCache', 'maxConcurrentDatasourceRequests', 'tooltipShowDelay',\n 'tooltipHideDelay', 'cacheOverflowSize', 'paginationPageSize', 'cacheBlockSize', 'infiniteInitialRowCount', 'serverSideInitialRowCount', 'scrollbarWidth',\n 'batchUpdateWaitMillis', 'asyncTransactionWaitMillis', 'blockLoadDebounceMillis', 'keepDetailRowsCount',\n 'undoRedoCellEditingLimit', 'cellFlashDelay', 'cellFadeDelay', 'tabIndex'\n ];\n PropertyKeys.BOOLEAN_PROPERTIES = [\n 'suppressMakeColumnVisibleAfterUnGroup', 'suppressRowClickSelection', 'suppressCellSelection', 'suppressCellFocus', 'suppressHorizontalScroll',\n 'alwaysShowHorizontalScroll', 'alwaysShowVerticalScroll', 'debug', 'enableBrowserTooltips', 'enableCellExpressions',\n 'angularCompileRows', 'angularCompileFilters', 'groupSuppressAutoColumn', 'groupSelectsChildren', 'groupIncludeFooter',\n 'groupIncludeTotalFooter', 'groupUseEntireRow', 'groupSuppressBlankHeader', 'suppressMenuHide', 'suppressRowDeselection',\n 'unSortIcon', 'suppressMultiSort', 'alwaysMultiSort', 'singleClickEdit', 'suppressLoadingOverlay', 'suppressNoRowsOverlay', 'suppressAutoSize',\n 'skipHeaderOnAutoSize', 'suppressParentsInRowNodes', 'suppressColumnMoveAnimation', 'suppressMovableColumns',\n 'suppressFieldDotNotation', 'enableRangeSelection', 'enableRangeHandle', 'enableFillHandle', 'suppressClearOnFillReduction',\n 'deltaSort', 'suppressTouch', 'suppressAsyncEvents', 'allowContextMenuWithControlKey', 'suppressContextMenu',\n 'rememberGroupStateWhenNewData', 'enableCellChangeFlash', 'suppressDragLeaveHidesColumns', 'suppressRowGroupHidesColumns', 'suppressMiddleClickScrolls',\n 'suppressPreventDefaultOnMouseWheel', 'suppressCopyRowsToClipboard', 'copyHeadersToClipboard', 'copyGroupHeadersToClipboard',\n 'pivotMode', 'suppressAggFuncInHeader', 'suppressColumnVirtualisation', 'suppressAggAtRootLevel', 'suppressFocusAfterRefresh',\n 'functionsPassive', 'functionsReadOnly', 'animateRows', 'groupSelectsFiltered', 'groupRemoveSingleChildren',\n 'groupRemoveLowestSingleChildren', 'enableRtl', 'suppressClickEdit', 'rowDragEntireRow', 'rowDragManaged', 'suppressRowDrag',\n 'suppressMoveWhenRowDragging', 'rowDragMultiRow', 'enableGroupEdit', 'embedFullWidthRows', 'deprecatedEmbedFullWidthRows',\n 'suppressPaginationPanel', 'groupHideOpenParents', 'groupMultiAutoColumn', 'pagination',\n 'stopEditingWhenGridLosesFocus', 'paginationAutoPageSize', 'suppressScrollOnNewData', 'suppressScrollWhenPopupsAreOpen',\n 'purgeClosedRowNodes', 'cacheQuickFilter', 'deltaRowDataMode', 'ensureDomOrder', 'accentedSort', 'suppressChangeDetection',\n 'valueCache', 'valueCacheNeverExpires', 'aggregateOnlyChangedColumns', 'suppressAnimationFrame', 'suppressExcelExport',\n 'suppressCsvExport', 'treeData', 'masterDetail', 'suppressMultiRangeSelection', 'enterMovesDownAfterEdit', 'enterMovesDown',\n 'suppressPropertyNamesCheck', 'rowMultiSelectWithClick', 'suppressEnterpriseResetOnNewColumns',\n 'suppressRowHoverHighlight', 'suppressRowTransform', 'suppressClipboardPaste', 'suppressLastEmptyLineOnPaste',\n 'suppressSetColumnStateEvents', 'suppressColumnStateEvents', 'enableCharts', 'deltaColumnMode',\n 'suppressMaintainUnsortedOrder', 'enableCellTextSelection', 'suppressBrowserResizeObserver', 'suppressMaxRenderedRowRestriction',\n 'excludeChildrenWhenTreeDataFiltering', 'tooltipMouseTrack', 'keepDetailRows', 'paginateChildRows', 'preventDefaultOnContextMenu',\n 'undoRedoCellEditing', 'allowDragFromColumnsToolPanel', 'immutableData', 'immutableColumns', 'pivotSuppressAutoColumn',\n 'suppressExpandablePivotGroups', 'applyColumnDefOrder', 'debounceVerticalScrollbar', 'detailRowAutoHeight',\n 'serverSideFilteringAlwaysResets', 'serverSideSortingAlwaysResets', 'serverSideSortAllLevels', 'serverSideFilterAllLevels',\n 'serverSideSortOnServer', 'serverSideFilterOnServer', 'suppressAggFilteredOnly', 'showOpenedGroup', 'suppressClipboardApi',\n 'suppressModelUpdateAfterUpdateTransaction', 'stopEditingWhenCellsLoseFocus', 'maintainColumnOrder', 'groupMaintainOrder',\n 'columnHoverHighlight', 'reactUi', 'suppressReactUi', 'readOnlyEdit', 'suppressRowVirtualisation',\n 'resetRowDataOnUpdate', 'removePivotHeaderRowWhenSingleValueColumn', 'suppressCopySingleCellRanges',\n 'groupRowsSticky', 'serverSideInfiniteScroll'\n ];\n /** You do not need to include event callbacks in this list, as they are generated automatically. */\n PropertyKeys.FUNCTION_PROPERTIES = [\n 'localeTextFunc', 'getLocaleText', 'groupRowInnerRenderer', 'groupRowInnerRendererFramework',\n 'groupRowRenderer', 'groupRowRendererFramework', 'isExternalFilterPresent', 'getRowHeight', 'doesExternalFilterPass',\n 'getRowClass', 'getRowStyle', 'getContextMenuItems', 'getMainMenuItems', 'processRowPostCreate', 'processCellForClipboard',\n 'groupRowAggNodes', 'getGroupRowAgg', 'getRowNodeId', 'isFullWidthCell', 'isFullWidthRow', 'fullWidthCellRenderer', 'fullWidthCellRendererFramework',\n 'processSecondaryColDef', 'processSecondaryColGroupDef', 'processPivotResultColDef', 'processPivotResultColGroupDef',\n 'getBusinessKeyForNode', 'sendToClipboard', 'navigateToNextHeader',\n 'tabToNextHeader', 'navigateToNextCell', 'tabToNextCell', 'processCellFromClipboard', 'getDocument', 'postProcessPopup',\n 'getChildCount', 'getDataPath', 'loadingCellRenderer', 'loadingCellRendererFramework', 'loadingOverlayComponent',\n 'loadingOverlayComponentFramework', 'noRowsOverlayComponent', 'noRowsOverlayComponentFramework', 'detailCellRenderer',\n 'detailCellRendererFramework', 'isRowMaster', 'isRowSelectable', 'postSort', 'postSortRows', 'processHeaderForClipboard', 'processGroupHeaderForClipboard',\n 'paginationNumberFormatter', 'processDataFromClipboard', 'getServerSideGroupKey', 'isServerSideGroup', 'suppressKeyboardEvent',\n 'createChartContainer', 'getChartToolbarItems', 'fillOperation', 'isApplyServerSideTransaction', 'getServerSideStoreParams',\n 'getServerSideGroupLevelParams',\n 'isServerSideGroupOpenByDefault', 'isGroupOpenByDefault', 'defaultGroupSortComparator', 'defaultGroupOrderComparator', 'initialGroupOrderComparator',\n 'loadingCellRendererSelector', 'getRowId', 'groupAggFiltering'\n ];\n PropertyKeys.ALL_PROPERTIES = __spread(PropertyKeys.ARRAY_PROPERTIES, PropertyKeys.OBJECT_PROPERTIES, PropertyKeys.STRING_PROPERTIES, PropertyKeys.NUMBER_PROPERTIES, PropertyKeys.FUNCTION_PROPERTIES, PropertyKeys.BOOLEAN_PROPERTIES);\n /**\n * Used when performing property checks. This avoids noise caused when using frameworks, which can add their own\n * framework-specific properties to colDefs, gridOptions etc.\n */\n PropertyKeys.FRAMEWORK_PROPERTIES = [\n '__ob__', '__v_skip', '__metadata__', 'mappedColumnProperties', 'hasChildColumns', 'toColDef', 'createColDefFromGridColumn'\n ];\n return PropertyKeys;\n}());\nexport { PropertyKeys };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nimport { Events } from '../events';\nimport { PropertyKeys } from '../propertyKeys';\nimport { iterateObject } from '../utils/object';\nimport { includes } from '../utils/array';\nimport { values } from '../utils/generic';\nvar ComponentUtil = /** @class */ (function () {\n function ComponentUtil() {\n }\n ComponentUtil.getEventCallbacks = function () {\n if (!ComponentUtil.EVENT_CALLBACKS) {\n ComponentUtil.EVENT_CALLBACKS = ComponentUtil.EVENTS.map(function (event) { return ComponentUtil.getCallbackForEvent(event); });\n }\n return ComponentUtil.EVENT_CALLBACKS;\n };\n ComponentUtil.copyAttributesToGridOptions = function (gridOptions, component, skipEventDeprecationCheck) {\n if (skipEventDeprecationCheck === void 0) { skipEventDeprecationCheck = false; }\n // create empty grid options if none were passed\n if (typeof gridOptions !== 'object') {\n gridOptions = {};\n }\n // to allow array style lookup in TypeScript, take type away from 'this' and 'gridOptions'\n var pGridOptions = gridOptions;\n var keyExists = function (key) { return typeof component[key] !== 'undefined'; };\n // if groupAggFiltering exists and isn't a function, handle as a boolean.\n if (keyExists('groupAggFiltering') && typeof component.groupAggFiltering !== 'function') {\n pGridOptions.groupAggFiltering = ComponentUtil.toBoolean(component.groupAggFiltering);\n delete component.groupAggFiltering;\n }\n // add in all the simple properties\n __spread(ComponentUtil.ARRAY_PROPERTIES, ComponentUtil.STRING_PROPERTIES, ComponentUtil.OBJECT_PROPERTIES, ComponentUtil.FUNCTION_PROPERTIES, ComponentUtil.getEventCallbacks()).filter(keyExists)\n .forEach(function (key) { return pGridOptions[key] = component[key]; });\n ComponentUtil.BOOLEAN_PROPERTIES\n .filter(keyExists)\n .forEach(function (key) { return pGridOptions[key] = ComponentUtil.toBoolean(component[key]); });\n ComponentUtil.NUMBER_PROPERTIES\n .filter(keyExists)\n .forEach(function (key) { return pGridOptions[key] = ComponentUtil.toNumber(component[key]); });\n return gridOptions;\n };\n ComponentUtil.getCallbackForEvent = function (eventName) {\n if (!eventName || eventName.length < 2) {\n return eventName;\n }\n return 'on' + eventName[0].toUpperCase() + eventName.substr(1);\n };\n ComponentUtil.processOnChange = function (changes, gridOptions, api, columnApi) {\n if (!changes) {\n return;\n }\n var changesToApply = __assign({}, changes);\n // to allow array style lookup in TypeScript, take type away from 'this' and 'gridOptions'\n var pGridOptions = gridOptions;\n var keyExists = function (key) { return changesToApply[key]; };\n // if groupAggFiltering exists and isn't a function, handle as a boolean.\n if (keyExists('groupAggFiltering')) {\n if (typeof changesToApply.groupAggFiltering === 'function') {\n pGridOptions.groupAggFiltering = changesToApply.groupAggFiltering;\n }\n else {\n pGridOptions.groupAggFiltering = ComponentUtil.toBoolean(changesToApply.groupAggFiltering);\n }\n delete changesToApply.groupAggFiltering;\n }\n if (keyExists('groupDisplayType')) {\n if (typeof changesToApply.groupDisplayType.currentValue === 'string') {\n api.setGroupDisplayType(changesToApply.groupDisplayType.currentValue);\n delete changesToApply.groupDisplayType;\n }\n }\n // we need to do this before the generic handling, otherwise value gets set before we\n // try to set it, and the grid then doesn't refresh the rows as it doesn't see any change.\n // also it's possible we use the generic code setXXX below and put it up there instead,\n // cover all cases.\n if (changesToApply.rowClass) {\n api.setRowClass(changesToApply.rowClass.currentValue);\n delete changesToApply.rowClass;\n }\n // check if any change for the simple types, and if so, then just copy in the new value\n __spread(ComponentUtil.ARRAY_PROPERTIES, ComponentUtil.OBJECT_PROPERTIES, ComponentUtil.STRING_PROPERTIES, ComponentUtil.getEventCallbacks()).filter(keyExists)\n .forEach(function (key) { return pGridOptions[key] = changesToApply[key].currentValue; });\n ComponentUtil.BOOLEAN_PROPERTIES\n .filter(keyExists)\n .forEach(function (key) { return pGridOptions[key] = ComponentUtil.toBoolean(changesToApply[key].currentValue); });\n ComponentUtil.NUMBER_PROPERTIES\n .filter(keyExists)\n .forEach(function (key) { return pGridOptions[key] = ComponentUtil.toNumber(changesToApply[key].currentValue); });\n if (changesToApply.enableCellTextSelection) {\n api.setEnableCellTextSelection(ComponentUtil.toBoolean(changesToApply.enableCellTextSelection.currentValue));\n delete changesToApply.enableCellTextSelection;\n }\n if (changesToApply.quickFilterText) {\n api.setQuickFilter(changesToApply.quickFilterText.currentValue);\n delete changesToApply.quickFilterText;\n }\n if (changesToApply.autoGroupColumnDef) {\n api.setAutoGroupColumnDef(changesToApply.autoGroupColumnDef.currentValue, \"gridOptionsChanged\");\n delete changesToApply.autoGroupColumnDef;\n }\n if (changesToApply.columnDefs) {\n api.setColumnDefs(changesToApply.columnDefs.currentValue, \"gridOptionsChanged\");\n delete changesToApply.columnDefs;\n }\n if (changesToApply.defaultColDef) {\n api.setDefaultColDef(changesToApply.defaultColDef.currentValue, \"gridOptionsChanged\");\n delete changesToApply.defaultColDef;\n }\n if (changesToApply.paginationPageSize) {\n api.paginationSetPageSize(ComponentUtil.toNumber(changesToApply.paginationPageSize.currentValue));\n delete changesToApply.paginationPageSize;\n }\n if (changesToApply.pivotMode) {\n columnApi.setPivotMode(ComponentUtil.toBoolean(changesToApply.pivotMode.currentValue));\n delete changesToApply.pivotMode;\n }\n if (changesToApply.groupRemoveSingleChildren) {\n api.setGroupRemoveSingleChildren(ComponentUtil.toBoolean(changesToApply.groupRemoveSingleChildren.currentValue));\n delete changesToApply.groupRemoveSingleChildren;\n }\n if (changesToApply.suppressRowDrag) {\n api.setSuppressRowDrag(ComponentUtil.toBoolean(changesToApply.suppressRowDrag.currentValue));\n delete changesToApply.suppressRowDrag;\n }\n if (changesToApply.suppressMoveWhenRowDragging) {\n api.setSuppressMoveWhenRowDragging(ComponentUtil.toBoolean(changesToApply.suppressMoveWhenRowDragging.currentValue));\n delete changesToApply.suppressMoveWhenRowDragging;\n }\n if (changesToApply.suppressRowClickSelection) {\n api.setSuppressRowClickSelection(ComponentUtil.toBoolean(changesToApply.suppressRowClickSelection.currentValue));\n delete changesToApply.suppressRowClickSelection;\n }\n if (changesToApply.suppressClipboardPaste) {\n api.setSuppressClipboardPaste(ComponentUtil.toBoolean(changesToApply.suppressClipboardPaste.currentValue));\n delete changesToApply.suppressClipboardPaste;\n }\n if (changesToApply.headerHeight) {\n api.setHeaderHeight(ComponentUtil.toNumber(changesToApply.headerHeight.currentValue));\n delete changesToApply.headerHeight;\n }\n // any remaining properties can be set in a generic way\n // ie the setter takes the form of setXXX and the argument requires no formatting/translation first\n var dynamicApi = api;\n Object.keys(changesToApply)\n .forEach(function (property) {\n var setterName = \"set\" + property.charAt(0).toUpperCase() + property.substring(1);\n if (dynamicApi[setterName]) {\n dynamicApi[setterName](changes[property].currentValue);\n }\n });\n // copy changes into an event for dispatch\n var event = {\n type: Events.EVENT_COMPONENT_STATE_CHANGED\n };\n iterateObject(changes, function (key, value) {\n event[key] = value;\n });\n api.dispatchEvent(event);\n };\n ComponentUtil.toBoolean = function (value) {\n if (typeof value === 'boolean') {\n return value;\n }\n if (typeof value === 'string') {\n // for boolean, compare to empty String to allow attributes appearing with\n // no value to be treated as 'true'\n return value.toUpperCase() === 'TRUE' || value == '';\n }\n return false;\n };\n ComponentUtil.toNumber = function (value) {\n if (typeof value === 'number') {\n return value;\n }\n if (typeof value === 'string') {\n return Number(value);\n }\n };\n // all the events are populated in here AFTER this class (at the bottom of the file).\n ComponentUtil.EVENTS = [];\n // events that are available for use by users of AG Grid and so should be documented\n ComponentUtil.PUBLIC_EVENTS = [];\n // events that are internal to AG Grid and should not be exposed to users via documentation or generated framework components\n ComponentUtil.EXCLUDED_INTERNAL_EVENTS = [];\n ComponentUtil.STRING_PROPERTIES = PropertyKeys.STRING_PROPERTIES;\n ComponentUtil.OBJECT_PROPERTIES = PropertyKeys.OBJECT_PROPERTIES;\n ComponentUtil.ARRAY_PROPERTIES = PropertyKeys.ARRAY_PROPERTIES;\n ComponentUtil.NUMBER_PROPERTIES = PropertyKeys.NUMBER_PROPERTIES;\n ComponentUtil.BOOLEAN_PROPERTIES = PropertyKeys.BOOLEAN_PROPERTIES;\n ComponentUtil.FUNCTION_PROPERTIES = PropertyKeys.FUNCTION_PROPERTIES;\n ComponentUtil.ALL_PROPERTIES = PropertyKeys.ALL_PROPERTIES;\n return ComponentUtil;\n}());\nexport { ComponentUtil };\nComponentUtil.EVENTS = values(Events);\n/** Exclude the following internal events from code generation to prevent exposing these events via framework components */\nComponentUtil.EXCLUDED_INTERNAL_EVENTS = [\n Events.EVENT_SCROLLBAR_WIDTH_CHANGED,\n Events.EVENT_CHECKBOX_CHANGED,\n Events.EVENT_HEIGHT_SCALE_CHANGED,\n Events.EVENT_BODY_HEIGHT_CHANGED,\n Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED,\n Events.EVENT_SCROLL_VISIBILITY_CHANGED,\n Events.EVENT_COLUMN_HOVER_CHANGED,\n Events.EVENT_FLASH_CELLS,\n Events.EVENT_PAGINATION_PIXEL_OFFSET_CHANGED,\n Events.EVENT_DISPLAYED_ROWS_CHANGED,\n Events.EVENT_LEFT_PINNED_WIDTH_CHANGED,\n Events.EVENT_RIGHT_PINNED_WIDTH_CHANGED,\n Events.EVENT_ROW_CONTAINER_HEIGHT_CHANGED,\n Events.EVENT_POPUP_TO_FRONT,\n Events.EVENT_KEYBOARD_FOCUS,\n Events.EVENT_MOUSE_FOCUS,\n Events.EVENT_STORE_UPDATED,\n Events.EVENT_COLUMN_PANEL_ITEM_DRAG_START,\n Events.EVENT_COLUMN_PANEL_ITEM_DRAG_END,\n Events.EVENT_FILL_START,\n Events.EVENT_FILL_END,\n Events.EVENT_FULL_WIDTH_ROW_FOCUSED,\n Events.EVENT_HEADER_HEIGHT_CHANGED,\n Events.EVENT_COLUMN_HEADER_HEIGHT_CHANGED\n];\n/** EVENTS that should be exposed via code generation for the framework components. */\nComponentUtil.PUBLIC_EVENTS = ComponentUtil.EVENTS.filter(function (e) { return !includes(ComponentUtil.EXCLUDED_INTERNAL_EVENTS, e); });\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar SideBarDefParser = /** @class */ (function () {\n function SideBarDefParser() {\n }\n SideBarDefParser.parse = function (toParse) {\n if (!toParse) {\n return null;\n }\n if (toParse === true) {\n return {\n toolPanels: [\n SideBarDefParser.DEFAULT_COLUMN_COMP,\n SideBarDefParser.DEFAULT_FILTER_COMP,\n ],\n defaultToolPanel: 'columns'\n };\n }\n if (typeof toParse === 'string') {\n return SideBarDefParser.parse([toParse]);\n }\n if (Array.isArray(toParse)) {\n var comps_1 = [];\n toParse.forEach(function (key) {\n var lookupResult = SideBarDefParser.DEFAULT_BY_KEY[key];\n if (!lookupResult) {\n console.warn(\"AG Grid: the key \" + key + \" is not a valid key for specifying a tool panel, valid keys are: \" + Object.keys(SideBarDefParser.DEFAULT_BY_KEY).join(','));\n return;\n }\n comps_1.push(lookupResult);\n });\n if (comps_1.length === 0) {\n return null;\n }\n return {\n toolPanels: comps_1,\n defaultToolPanel: comps_1[0].id\n };\n }\n var result = {\n toolPanels: SideBarDefParser.parseComponents(toParse.toolPanels),\n defaultToolPanel: toParse.defaultToolPanel,\n hiddenByDefault: toParse.hiddenByDefault,\n position: toParse.position\n };\n return result;\n };\n SideBarDefParser.parseComponents = function (from) {\n var result = [];\n if (!from) {\n return result;\n }\n from.forEach(function (it) {\n var toAdd = null;\n if (typeof it === 'string') {\n var lookupResult = SideBarDefParser.DEFAULT_BY_KEY[it];\n if (!lookupResult) {\n console.warn(\"AG Grid: the key \" + it + \" is not a valid key for specifying a tool panel, valid keys are: \" + Object.keys(SideBarDefParser.DEFAULT_BY_KEY).join(','));\n return;\n }\n toAdd = lookupResult;\n }\n else {\n toAdd = it;\n }\n result.push(toAdd);\n });\n return result;\n };\n SideBarDefParser.DEFAULT_COLUMN_COMP = {\n id: 'columns',\n labelDefault: 'Columns',\n labelKey: 'columns',\n iconKey: 'columns',\n toolPanel: 'agColumnsToolPanel',\n };\n SideBarDefParser.DEFAULT_FILTER_COMP = {\n id: 'filters',\n labelDefault: 'Filters',\n labelKey: 'filters',\n iconKey: 'filter',\n toolPanel: 'agFiltersToolPanel',\n };\n SideBarDefParser.DEFAULT_BY_KEY = {\n columns: SideBarDefParser.DEFAULT_COLUMN_COMP,\n filters: SideBarDefParser.DEFAULT_FILTER_COMP\n };\n return SideBarDefParser;\n}());\nexport { SideBarDefParser };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __values = (this && this.__values) || function(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\n/**\n * These variables are lazy loaded, as otherwise they try and get initialised when we are loading\n * unit tests and we don't have references to window or document in the unit tests\n * from http://stackoverflow.com/questions/9847580/how-to-detect-safari-chrome-ie-firefox-and-opera-browser\n */\nvar isSafari;\nvar isIE;\nvar isEdge;\nvar isChrome;\nvar isFirefox;\nvar isMacOs;\nvar isIOS;\nvar invisibleScrollbar;\nvar browserScrollbarWidth;\nvar browserInfo;\n/**\n * from https://stackoverflow.com/a/16938481/1388233\n */\nexport function getBrowserInfo() {\n if (browserInfo) {\n return browserInfo;\n }\n var userAgent = navigator.userAgent;\n var match = userAgent.match(/(opera|chrome|safari|firefox|msie|trident(?=\\/))\\/?\\s*(\\d+)/i) || [];\n var tem;\n var version;\n if (/trident/i.test(match[1])) {\n tem = /\\brv[ :]+(\\d+)/g.exec(userAgent) || [];\n version = tem[1] != null ? parseFloat(tem[1]) : 0;\n return {\n name: 'IE',\n version: version\n };\n }\n if (match[1] === 'Chrome') {\n tem = userAgent.match(/\\bOPR|Edge\\/(\\d+)/);\n if (tem != null) {\n version = tem[1] != null ? parseFloat(tem[1]) : 0;\n return {\n name: 'Opera',\n version: version\n };\n }\n }\n match = match[2] ? [match[1], match[2]] : [navigator.appName, navigator.appVersion, '-?'];\n tem = userAgent.match(/version\\/(\\d+)/i);\n if (tem != null) {\n match.splice(1, 1, tem[1]);\n }\n var name = match[0];\n version = match[1] != null ? parseFloat(match[1]) : 0;\n browserInfo = { name: name, version: version };\n return browserInfo;\n}\nfunction isBrowserIE() {\n if (isIE === undefined) {\n isIE = /*@cc_on!@*/ false || !!document.documentMode; // At least IE6\n }\n return isIE;\n}\nexport function isBrowserEdge() {\n if (isEdge === undefined) {\n isEdge = !isBrowserIE() && !!window.StyleMedia;\n }\n return isEdge;\n}\nexport function isBrowserSafari() {\n if (isSafari === undefined) {\n // taken from https://stackoverflow.com/a/23522755/1388233\n isSafari = /^((?!chrome|android).)*safari/i.test(navigator.userAgent);\n }\n return isSafari;\n}\nexport function isBrowserChrome() {\n if (isChrome === undefined) {\n var win = window;\n isChrome = (!!win.chrome && (!!win.chrome.webstore || !!win.chrome.runtime)) ||\n (/Chrome/.test(navigator.userAgent) && /Google Inc/.test(navigator.vendor));\n }\n return isChrome;\n}\nexport function isBrowserFirefox() {\n if (isFirefox === undefined) {\n var win = window;\n isFirefox = typeof win.InstallTrigger !== 'undefined';\n }\n return isFirefox;\n}\nexport function isMacOsUserAgent() {\n if (isMacOs === undefined) {\n isMacOs = /(Mac|iPhone|iPod|iPad)/i.test(navigator.platform);\n }\n return isMacOs;\n}\nexport function isIOSUserAgent() {\n if (isIOS === undefined) {\n // taken from https://stackoverflow.com/a/58064481/1388233\n isIOS = (/iPad|iPhone|iPod/.test(navigator.platform) ||\n // eslint-disable-next-line\n (navigator.platform === 'MacIntel' && navigator.maxTouchPoints > 1)) &&\n // @ts-ignore\n !window.MSStream;\n }\n return isIOS;\n}\nexport function browserSupportsPreventScroll() {\n // all browsers except safari support focus({ preventScroll: true }).\n // this feature was added on Safari 15+\n return !isBrowserSafari() || getBrowserInfo().version >= 15;\n}\nexport function getTabIndex(el) {\n if (!el) {\n return null;\n }\n var numberTabIndex = el.tabIndex;\n var tabIndex = el.getAttribute('tabIndex');\n if (numberTabIndex === -1 && (tabIndex === null || (tabIndex === '' && !isBrowserFirefox()))) {\n return null;\n }\n return numberTabIndex.toString();\n}\nexport function getMaxDivHeight() {\n if (!document.body) {\n return -1;\n }\n var res = 1000000;\n // FF reports the height back but still renders blank after ~6M px\n var testUpTo = navigator.userAgent.toLowerCase().match(/firefox/) ? 6000000 : 1000000000;\n var div = document.createElement('div');\n document.body.appendChild(div);\n while (true) {\n var test = res * 2;\n div.style.height = test + 'px';\n if (test > testUpTo || div.clientHeight !== test) {\n break;\n }\n else {\n res = test;\n }\n }\n document.body.removeChild(div);\n return res;\n}\nexport function getScrollbarWidth() {\n if (browserScrollbarWidth == null) {\n initScrollbarWidthAndVisibility();\n }\n return browserScrollbarWidth;\n}\nfunction initScrollbarWidthAndVisibility() {\n var body = document.body;\n var div = document.createElement('div');\n div.style.width = div.style.height = '100px';\n div.style.opacity = '0';\n div.style.overflow = 'scroll';\n div.style.msOverflowStyle = 'scrollbar'; // needed for WinJS apps\n div.style.position = 'absolute';\n body.appendChild(div);\n var width = div.offsetWidth - div.clientWidth;\n // if width is 0 and client width is 0, means the DOM isn't ready\n if (width === 0 && div.clientWidth === 0) {\n width = null;\n }\n // remove div\n if (div.parentNode) {\n div.parentNode.removeChild(div);\n }\n if (width != null) {\n browserScrollbarWidth = width;\n invisibleScrollbar = width === 0;\n }\n}\nexport function isInvisibleScrollbar() {\n if (invisibleScrollbar == null) {\n initScrollbarWidthAndVisibility();\n }\n return invisibleScrollbar;\n}\n/** @deprecated */\nexport function hasOverflowScrolling() {\n var e_1, _a;\n var prefixes = ['webkit', 'moz', 'o', 'ms'];\n var div = document.createElement('div');\n var body = document.getElementsByTagName('body')[0];\n var found = false;\n var p;\n body.appendChild(div);\n div.setAttribute('style', prefixes.map(function (prefix) { return \"-\" + prefix + \"-overflow-scrolling: touch\"; }).concat('overflow-scrolling: touch').join(';'));\n var computedStyle = window.getComputedStyle(div);\n if (computedStyle.overflowScrolling === 'touch') {\n found = true;\n }\n if (!found) {\n try {\n for (var prefixes_1 = __values(prefixes), prefixes_1_1 = prefixes_1.next(); !prefixes_1_1.done; prefixes_1_1 = prefixes_1.next()) {\n p = prefixes_1_1.value;\n if (computedStyle[p + \"OverflowScrolling\"] === 'touch') {\n found = true;\n break;\n }\n }\n }\n catch (e_1_1) { e_1 = { error: e_1_1 }; }\n finally {\n try {\n if (prefixes_1_1 && !prefixes_1_1.done && (_a = prefixes_1.return)) _a.call(prefixes_1);\n }\n finally { if (e_1) throw e_1.error; }\n }\n }\n if (div.parentNode) {\n div.parentNode.removeChild(div);\n }\n return found;\n}\n/**\n * Gets the document body width\n * from: http://stackoverflow.com/questions/1038727/how-to-get-browser-width-using-javascript-code\n * @returns {number}\n */\nexport function getBodyWidth() {\n if (document.body) {\n return document.body.clientWidth;\n }\n if (window.innerHeight) {\n return window.innerWidth;\n }\n if (document.documentElement && document.documentElement.clientWidth) {\n return document.documentElement.clientWidth;\n }\n return -1;\n}\n/**\n * Gets the body height\n * from: http://stackoverflow.com/questions/1038727/how-to-get-browser-width-using-javascript-code\n * @returns {number}\n */\nexport function getBodyHeight() {\n if (document.body) {\n return document.body.clientHeight;\n }\n if (window.innerHeight) {\n return window.innerHeight;\n }\n if (document.documentElement && document.documentElement.clientHeight) {\n return document.documentElement.clientHeight;\n }\n return -1;\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nexport function fuzzyCheckStrings(inputValues, validValues, allSuggestions) {\n var fuzzyMatches = {};\n var invalidInputs = inputValues.filter(function (inputValue) {\n return !validValues.some(function (validValue) { return validValue === inputValue; });\n });\n if (invalidInputs.length > 0) {\n invalidInputs.forEach(function (invalidInput) {\n return fuzzyMatches[invalidInput] = fuzzySuggestions(invalidInput, allSuggestions);\n });\n }\n return fuzzyMatches;\n}\n/**\n *\n * @param {String} inputValue The value to be compared against a list of strings\n * @param allSuggestions The list of strings to be compared against\n * @param hideIrrelevant By default, fuzzy suggestions will just sort the allSuggestions list, set this to true\n * to filter out the irrelevant values\n * @param weighted Set this to true, to make letters matched in the order they were typed have priority in the results.\n */\nexport function fuzzySuggestions(inputValue, allSuggestions, hideIrrelevant, weighted) {\n var search = weighted ? string_weighted_distances : string_distances;\n var thisSuggestions = allSuggestions.map(function (text) { return ({\n value: text,\n relevance: search(inputValue.toLowerCase(), text.toLocaleLowerCase())\n }); });\n thisSuggestions.sort(function (a, b) { return b.relevance - a.relevance; });\n if (hideIrrelevant) {\n thisSuggestions = thisSuggestions.filter(function (suggestion) { return suggestion.relevance !== 0; });\n }\n return thisSuggestions.map(function (suggestion) { return suggestion.value; });\n}\n/**\n * Algorithm to do fuzzy search\n * from https://stackoverflow.com/questions/23305000/javascript-fuzzy-search-that-makes-sense\n * @param {string} from\n * @return {[]}\n */\nexport function get_bigrams(from) {\n var s = from.toLowerCase();\n var v = new Array(s.length - 1);\n var i;\n var j;\n var ref;\n for (i = j = 0, ref = v.length; j <= ref; i = j += 1) {\n v[i] = s.slice(i, i + 2);\n }\n return v;\n}\nexport function string_distances(str1, str2) {\n if (str1.length === 0 && str2.length === 0) {\n return 0;\n }\n var pairs1 = get_bigrams(str1);\n var pairs2 = get_bigrams(str2);\n var union = pairs1.length + pairs2.length;\n var hit_count = 0;\n var j;\n var len;\n for (j = 0, len = pairs1.length; j < len; j++) {\n var x = pairs1[j];\n var k = void 0;\n var len1 = void 0;\n for (k = 0, len1 = pairs2.length; k < len1; k++) {\n var y = pairs2[k];\n if (x === y) {\n hit_count++;\n }\n }\n }\n return hit_count > 0 ? (2 * hit_count) / union : 0;\n}\nexport function string_weighted_distances(str1, str2) {\n var a = str1.replace(/\\s/g, '');\n var b = str2.replace(/\\s/g, '');\n var weight = 0;\n var lastIndex = 0;\n for (var i = 0; i < a.length; i++) {\n var idx = b.indexOf(a[i], lastIndex);\n if (idx === -1) {\n continue;\n }\n lastIndex = idx;\n weight += (100 - (lastIndex * 100 / 10000) * 100);\n }\n return weight;\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nexport function padStartWidthZeros(value, totalStringSize) {\n return value.toString().padStart(totalStringSize, '0');\n}\nexport function createArrayOfNumbers(first, last) {\n var result = [];\n for (var i = first; i <= last; i++) {\n result.push(i);\n }\n return result;\n}\n/**\n * Check if a value is numeric\n * from http://stackoverflow.com/questions/9716468/is-there-any-function-like-isnumeric-in-javascript-to-validate-numbers\n * @param {any} value\n * @return {boolean}\n */\nexport function isNumeric(value) {\n return value !== '' && !isNaN(parseFloat(value)) && isFinite(value);\n}\nexport function cleanNumber(value) {\n if (typeof value === 'string') {\n value = parseInt(value, 10);\n }\n if (typeof value === 'number') {\n return Math.floor(value);\n }\n return null;\n}\nexport function decToHex(number, bytes) {\n var hex = '';\n for (var i = 0; i < bytes; i++) {\n hex += String.fromCharCode(number & 0xff);\n number >>>= 8;\n }\n return hex;\n}\nexport function formatNumberTwoDecimalPlacesAndCommas(value, thousandSeparator, decimalSeparator) {\n if (typeof value !== 'number') {\n return '';\n }\n return formatNumberCommas(Math.round(value * 100) / 100, thousandSeparator, decimalSeparator);\n}\n/**\n * the native method number.toLocaleString(undefined, {minimumFractionDigits: 0})\n * puts in decimal places in IE, so we use this method instead\n * from: http://blog.tompawlak.org/number-currency-formatting-javascript\n * @param {number} value\n * @returns {string}\n */\nexport function formatNumberCommas(value, thousandSeparator, decimalSeparator) {\n if (typeof value !== 'number') {\n return '';\n }\n return value.toString().replace('.', decimalSeparator).replace(/(\\d)(?=(\\d{3})+(?!\\d))/g, \"$1\" + thousandSeparator);\n}\nexport function sum(values) {\n return values == null ? null : values.reduce(function (total, value) { return total + value; }, 0);\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nimport { ColDefUtil } from './components/colDefUtil';\nimport { ComponentUtil } from './components/componentUtil';\nimport { Constants } from './constants/constants';\nimport { Autowired, Bean, PostConstruct, PreDestroy, Qualifier } from './context/context';\nimport { SideBarDefParser } from './entities/sideBar';\nimport { Events } from './eventKeys';\nimport { EventService } from './eventService';\nimport { ModuleNames } from './modules/moduleNames';\nimport { ModuleRegistry } from './modules/moduleRegistry';\nimport { PropertyKeys } from './propertyKeys';\nimport { getScrollbarWidth } from './utils/browser';\nimport { doOnce } from './utils/function';\nimport { fuzzyCheckStrings } from './utils/fuzzyMatch';\nimport { exists, missing, values } from './utils/generic';\nimport { isNumeric } from './utils/number';\nimport { iterateObject } from './utils/object';\nimport { capitalise } from './utils/string';\nvar DEFAULT_ROW_HEIGHT = 25;\nvar DEFAULT_DETAIL_ROW_HEIGHT = 300;\nvar DEFAULT_VIEWPORT_ROW_MODEL_PAGE_SIZE = 5;\nvar DEFAULT_VIEWPORT_ROW_MODEL_BUFFER_SIZE = 5;\nvar DEFAULT_KEEP_DETAIL_ROW_COUNT = 10;\nfunction isTrue(value) {\n return value === true || value === 'true';\n}\nfunction toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (typeof value == 'string') {\n return parseInt(value, 10);\n }\n}\nfunction zeroOrGreater(value, defaultValue) {\n if (value >= 0) {\n return value;\n }\n // zero gets returned if number is missing or the wrong type\n return defaultValue;\n}\nfunction oneOrGreater(value, defaultValue) {\n var valueNumber = parseInt(value, 10);\n if (isNumeric(valueNumber) && valueNumber > 0) {\n return valueNumber;\n }\n return defaultValue;\n}\nvar GridOptionsWrapper = /** @class */ (function () {\n function GridOptionsWrapper() {\n this.propertyEventService = new EventService();\n this.domDataKey = '__AG_' + Math.random().toString();\n this.destroyed = false;\n }\n GridOptionsWrapper_1 = GridOptionsWrapper;\n GridOptionsWrapper.prototype.agWire = function (gridApi, columnApi) {\n this.gridOptions.api = gridApi;\n this.gridOptions.columnApi = columnApi;\n this.checkForDeprecated();\n this.checkForViolations();\n };\n GridOptionsWrapper.prototype.destroy = function () {\n // need to remove these, as we don't own the lifecycle of the gridOptions, we need to\n // remove the references in case the user keeps the grid options, we want the rest\n // of the grid to be picked up by the garbage collector\n this.gridOptions.api = null;\n this.gridOptions.columnApi = null;\n this.destroyed = true;\n };\n GridOptionsWrapper.prototype.init = function () {\n var _this = this;\n if (this.gridOptions.suppressPropertyNamesCheck !== true) {\n this.checkGridOptionsProperties();\n this.checkColumnDefProperties();\n }\n // parse side bar options into correct format\n if (this.gridOptions.sideBar != null) {\n this.gridOptions.sideBar = SideBarDefParser.parse(this.gridOptions.sideBar);\n }\n var async = this.useAsyncEvents();\n this.eventService.addGlobalListener(this.globalEventHandler.bind(this), async);\n if (this.isGroupSelectsChildren() && this.isSuppressParentsInRowNodes()) {\n console.warn(\"AG Grid: 'groupSelectsChildren' does not work with 'suppressParentsInRowNodes', this selection method needs the part in rowNode to work\");\n }\n if (this.isGroupSelectsChildren()) {\n if (!this.isRowSelectionMulti()) {\n console.warn(\"AG Grid: rowSelection must be 'multiple' for groupSelectsChildren to make sense\");\n }\n if (this.isRowModelServerSide()) {\n console.warn('AG Grid: group selects children is NOT support for Server Side Row Model. ' +\n 'This is because the rows are lazy loaded, so selecting a group is not possible as' +\n 'the grid has no way of knowing what the children are.');\n }\n }\n if (this.isGroupRemoveSingleChildren() && this.isGroupHideOpenParents()) {\n console.warn(\"AG Grid: groupRemoveSingleChildren and groupHideOpenParents do not work with each other, you need to pick one. And don't ask us how to use these together on our support forum either, you will get the same answer!\");\n }\n if (this.isRowModelServerSide()) {\n var msg = function (prop) { return \"AG Grid: '\" + prop + \"' is not supported on the Server-Side Row Model\"; };\n if (exists(this.gridOptions.groupDefaultExpanded)) {\n console.warn(msg('groupDefaultExpanded'));\n }\n if (exists(this.gridOptions.groupDefaultExpanded)) {\n console.warn(msg('groupIncludeFooter'));\n }\n if (exists(this.gridOptions.groupDefaultExpanded)) {\n console.warn(msg('groupIncludeTotalFooter'));\n }\n }\n if (isTrue(this.gridOptions.enableRangeSelection)) {\n ModuleRegistry.assertRegistered(ModuleNames.RangeSelectionModule, 'enableRangeSelection');\n }\n else if (this.isEnableRangeHandle() || this.isEnableFillHandle()) {\n console.warn(\"AG Grid: 'enableRangeHandle' or 'enableFillHandle' will not work unless 'enableRangeSelection' is set to true\");\n }\n if (this.isGroupRowsSticky()) {\n if (this.isGroupHideOpenParents()) {\n console.warn(\"AG Grid: groupRowsSticky and groupHideOpenParents do not work with each other, you need to pick one.\");\n }\n if (this.isMasterDetail()) {\n console.warn(\"AG Grid: groupRowsSticky and masterDetail do not work with each other, you need to pick one.\");\n }\n if (this.isPagination()) {\n console.warn(\"AG Grid: groupRowsSticky and pagination do not work with each other, you need to pick one.\");\n }\n }\n var warnOfDeprecaredIcon = function (name) {\n if (_this.gridOptions.icons && _this.gridOptions.icons[name]) {\n console.warn(\"gridOptions.icons.\" + name + \" is no longer supported. For information on how to style checkboxes and radio buttons, see https://www.ag-grid.com/javascript-grid-icons/\");\n }\n };\n warnOfDeprecaredIcon('radioButtonOff');\n warnOfDeprecaredIcon('radioButtonOn');\n warnOfDeprecaredIcon('checkboxChecked');\n warnOfDeprecaredIcon('checkboxUnchecked');\n warnOfDeprecaredIcon('checkboxIndeterminate');\n // sets an initial calculation for the scrollbar width\n this.getScrollbarWidth();\n };\n GridOptionsWrapper.prototype.checkColumnDefProperties = function () {\n var _this = this;\n if (this.gridOptions.columnDefs == null) {\n return;\n }\n this.gridOptions.columnDefs.forEach(function (colDef) {\n var userProperties = Object.getOwnPropertyNames(colDef);\n var validProperties = __spread(ColDefUtil.ALL_PROPERTIES, ColDefUtil.FRAMEWORK_PROPERTIES);\n _this.checkProperties(userProperties, validProperties, validProperties, 'colDef', 'https://www.ag-grid.com/javascript-grid-column-properties/');\n });\n };\n GridOptionsWrapper.prototype.checkGridOptionsProperties = function () {\n var userProperties = Object.getOwnPropertyNames(this.gridOptions);\n var validProperties = __spread(PropertyKeys.ALL_PROPERTIES, PropertyKeys.FRAMEWORK_PROPERTIES, values(Events).map(function (event) { return ComponentUtil.getCallbackForEvent(event); }));\n var validPropertiesAndExceptions = __spread(validProperties, ['api', 'columnApi']);\n this.checkProperties(userProperties, validPropertiesAndExceptions, validProperties, 'gridOptions', 'https://www.ag-grid.com/javascript-data-grid/grid-options/');\n };\n GridOptionsWrapper.prototype.checkProperties = function (userProperties, validPropertiesAndExceptions, validProperties, containerName, docsUrl) {\n var invalidProperties = fuzzyCheckStrings(userProperties, validPropertiesAndExceptions, validProperties);\n iterateObject(invalidProperties, function (key, value) {\n console.warn(\"ag-grid: invalid \" + containerName + \" property '\" + key + \"' did you mean any of these: \" + value.slice(0, 8).join(\", \"));\n });\n if (Object.keys(invalidProperties).length > 0) {\n console.warn(\"ag-grid: to see all the valid \" + containerName + \" properties please check: \" + docsUrl);\n }\n };\n /**\n * Wrap the user callback and attach the api, columnApi and context to the params object on the way through.\n * @param callback User provided callback\n * @returns Wrapped callback where the params object not require api, columnApi and context\n */\n GridOptionsWrapper.prototype.mergeGridCommonParams = function (callback) {\n var _this = this;\n if (callback) {\n var wrapped = function (callbackParams) {\n var mergedParams = __assign(__assign({}, callbackParams), { api: _this.getApi(), columnApi: _this.getColumnApi(), context: _this.getContext() });\n return callback(mergedParams);\n };\n return wrapped;\n }\n return callback;\n };\n GridOptionsWrapper.prototype.getDomDataKey = function () {\n return this.domDataKey;\n };\n // returns the dom data, or undefined if not found\n GridOptionsWrapper.prototype.getDomData = function (element, key) {\n var domData = element[this.getDomDataKey()];\n return domData ? domData[key] : undefined;\n };\n GridOptionsWrapper.prototype.setDomData = function (element, key, value) {\n var domDataKey = this.getDomDataKey();\n var domData = element[domDataKey];\n if (missing(domData)) {\n domData = {};\n element[domDataKey] = domData;\n }\n domData[key] = value;\n };\n GridOptionsWrapper.prototype.isRowSelection = function () {\n return this.gridOptions.rowSelection === 'single' || this.gridOptions.rowSelection === 'multiple';\n };\n GridOptionsWrapper.prototype.isSuppressRowDeselection = function () {\n return isTrue(this.gridOptions.suppressRowDeselection);\n };\n GridOptionsWrapper.prototype.isRowSelectionMulti = function () {\n return this.gridOptions.rowSelection === 'multiple';\n };\n GridOptionsWrapper.prototype.isRowMultiSelectWithClick = function () {\n return isTrue(this.gridOptions.rowMultiSelectWithClick);\n };\n GridOptionsWrapper.prototype.getContext = function () {\n return this.gridOptions.context;\n };\n GridOptionsWrapper.prototype.isPivotMode = function () {\n return isTrue(this.gridOptions.pivotMode);\n };\n GridOptionsWrapper.prototype.isSuppressExpandablePivotGroups = function () {\n return isTrue(this.gridOptions.suppressExpandablePivotGroups);\n };\n GridOptionsWrapper.prototype.getPivotColumnGroupTotals = function () {\n return this.gridOptions.pivotColumnGroupTotals;\n };\n GridOptionsWrapper.prototype.getPivotRowTotals = function () {\n return this.gridOptions.pivotRowTotals;\n };\n GridOptionsWrapper.prototype.isRowModelInfinite = function () {\n return this.gridOptions.rowModelType === Constants.ROW_MODEL_TYPE_INFINITE;\n };\n GridOptionsWrapper.prototype.isRowModelViewport = function () {\n return this.gridOptions.rowModelType === Constants.ROW_MODEL_TYPE_VIEWPORT;\n };\n GridOptionsWrapper.prototype.isRowModelServerSide = function () {\n return this.gridOptions.rowModelType === Constants.ROW_MODEL_TYPE_SERVER_SIDE;\n };\n GridOptionsWrapper.prototype.isRowModelDefault = function () {\n return (missing(this.gridOptions.rowModelType) ||\n this.gridOptions.rowModelType === Constants.ROW_MODEL_TYPE_CLIENT_SIDE);\n };\n GridOptionsWrapper.prototype.isFullRowEdit = function () {\n return this.gridOptions.editType === 'fullRow';\n };\n GridOptionsWrapper.prototype.isSuppressFocusAfterRefresh = function () {\n return isTrue(this.gridOptions.suppressFocusAfterRefresh);\n };\n GridOptionsWrapper.prototype.isSuppressBrowserResizeObserver = function () {\n return isTrue(this.gridOptions.suppressBrowserResizeObserver);\n };\n GridOptionsWrapper.prototype.isSuppressMaintainUnsortedOrder = function () {\n return isTrue(this.gridOptions.suppressMaintainUnsortedOrder);\n };\n GridOptionsWrapper.prototype.isSuppressClearOnFillReduction = function () {\n return isTrue(this.gridOptions.suppressClearOnFillReduction);\n };\n GridOptionsWrapper.prototype.isShowToolPanel = function () {\n return isTrue(this.gridOptions.sideBar && Array.isArray(this.getSideBar().toolPanels));\n };\n GridOptionsWrapper.prototype.getSideBar = function () {\n return this.gridOptions.sideBar;\n };\n GridOptionsWrapper.prototype.isSuppressTouch = function () {\n return isTrue(this.gridOptions.suppressTouch);\n };\n GridOptionsWrapper.prototype.isMaintainColumnOrder = function () {\n return isTrue(this.gridOptions.maintainColumnOrder);\n };\n GridOptionsWrapper.prototype.isSuppressRowTransform = function () {\n return isTrue(this.gridOptions.suppressRowTransform);\n };\n GridOptionsWrapper.prototype.isSuppressColumnStateEvents = function () {\n return isTrue(this.gridOptions.suppressColumnStateEvents);\n };\n GridOptionsWrapper.prototype.isAllowDragFromColumnsToolPanel = function () {\n return isTrue(this.gridOptions.allowDragFromColumnsToolPanel);\n };\n GridOptionsWrapper.prototype.useAsyncEvents = function () {\n return !isTrue(this.gridOptions.suppressAsyncEvents);\n };\n GridOptionsWrapper.prototype.isEnableCellChangeFlash = function () {\n return isTrue(this.gridOptions.enableCellChangeFlash);\n };\n GridOptionsWrapper.prototype.getCellFlashDelay = function () {\n return this.gridOptions.cellFlashDelay || 500;\n };\n GridOptionsWrapper.prototype.getCellFadeDelay = function () {\n return this.gridOptions.cellFadeDelay || 1000;\n };\n GridOptionsWrapper.prototype.isGroupSelectsChildren = function () {\n return isTrue(this.gridOptions.groupSelectsChildren);\n };\n GridOptionsWrapper.prototype.isSuppressRowHoverHighlight = function () {\n return isTrue(this.gridOptions.suppressRowHoverHighlight);\n };\n GridOptionsWrapper.prototype.isColumnHoverHighlight = function () {\n return isTrue(this.gridOptions.columnHoverHighlight);\n };\n GridOptionsWrapper.prototype.isGroupSelectsFiltered = function () {\n return isTrue(this.gridOptions.groupSelectsFiltered);\n };\n GridOptionsWrapper.prototype.isGroupHideOpenParents = function () {\n return isTrue(this.gridOptions.groupHideOpenParents);\n };\n GridOptionsWrapper.prototype.isGroupMaintainOrder = function () {\n return isTrue(this.gridOptions.groupMaintainOrder);\n };\n GridOptionsWrapper.prototype.getAutoGroupColumnDef = function () {\n return this.gridOptions.autoGroupColumnDef;\n };\n GridOptionsWrapper.prototype.isColumnsSortingCoupledToGroup = function () {\n var _a;\n var autoGroupColumnDef = this.getAutoGroupColumnDef();\n var isClientSideRowModel = this.isRowModelDefault();\n return isClientSideRowModel && !((_a = autoGroupColumnDef) === null || _a === void 0 ? void 0 : _a.comparator);\n };\n GridOptionsWrapper.prototype.isGroupMultiAutoColumn = function () {\n if (this.gridOptions.groupDisplayType) {\n return this.matchesGroupDisplayType('multipleColumns', this.gridOptions.groupDisplayType);\n }\n // if we are doing hideOpenParents we also show multiple columns, otherwise hideOpenParents would not work\n return isTrue(this.gridOptions.groupHideOpenParents);\n };\n GridOptionsWrapper.prototype.isGroupUseEntireRow = function (pivotMode) {\n // we never allow groupUseEntireRow if in pivot mode, otherwise we won't see the pivot values.\n if (pivotMode) {\n return false;\n }\n return this.gridOptions.groupDisplayType ?\n this.matchesGroupDisplayType('groupRows', this.gridOptions.groupDisplayType) : false;\n };\n GridOptionsWrapper.prototype.isGroupRowsSticky = function () {\n return isTrue(this.gridOptions.groupRowsSticky);\n };\n GridOptionsWrapper.prototype.isGroupSuppressAutoColumn = function () {\n var isCustomRowGroups = this.gridOptions.groupDisplayType ?\n this.matchesGroupDisplayType('custom', this.gridOptions.groupDisplayType) : false;\n if (isCustomRowGroups) {\n return true;\n }\n return this.gridOptions.treeDataDisplayType ?\n this.matchesTreeDataDisplayType('custom', this.gridOptions.treeDataDisplayType) : false;\n };\n GridOptionsWrapper.prototype.isGroupRemoveSingleChildren = function () {\n return isTrue(this.gridOptions.groupRemoveSingleChildren);\n };\n GridOptionsWrapper.prototype.isGroupRemoveLowestSingleChildren = function () {\n return isTrue(this.gridOptions.groupRemoveLowestSingleChildren);\n };\n GridOptionsWrapper.prototype.isGroupIncludeFooter = function () {\n return isTrue(this.gridOptions.groupIncludeFooter);\n };\n GridOptionsWrapper.prototype.isGroupIncludeTotalFooter = function () {\n return isTrue(this.gridOptions.groupIncludeTotalFooter);\n };\n GridOptionsWrapper.prototype.isGroupSuppressBlankHeader = function () {\n return isTrue(this.gridOptions.groupSuppressBlankHeader);\n };\n GridOptionsWrapper.prototype.isSuppressRowClickSelection = function () {\n return isTrue(this.gridOptions.suppressRowClickSelection);\n };\n GridOptionsWrapper.prototype.isSuppressCellFocus = function () {\n return isTrue(this.gridOptions.suppressCellFocus);\n };\n GridOptionsWrapper.prototype.isSuppressMultiSort = function () {\n return isTrue(this.gridOptions.suppressMultiSort);\n };\n GridOptionsWrapper.prototype.isAlwaysMultiSort = function () {\n return isTrue(this.gridOptions.alwaysMultiSort);\n };\n GridOptionsWrapper.prototype.isMultiSortKeyCtrl = function () {\n return this.gridOptions.multiSortKey === 'ctrl';\n };\n GridOptionsWrapper.prototype.isPivotSuppressAutoColumn = function () {\n return isTrue(this.gridOptions.pivotSuppressAutoColumn);\n };\n GridOptionsWrapper.prototype.isSuppressDragLeaveHidesColumns = function () {\n return isTrue(this.gridOptions.suppressDragLeaveHidesColumns);\n };\n GridOptionsWrapper.prototype.isSuppressRowGroupHidesColumns = function () {\n return isTrue(this.gridOptions.suppressRowGroupHidesColumns);\n };\n GridOptionsWrapper.prototype.isSuppressScrollOnNewData = function () {\n return isTrue(this.gridOptions.suppressScrollOnNewData);\n };\n GridOptionsWrapper.prototype.isSuppressScrollWhenPopupsAreOpen = function () {\n return isTrue(this.gridOptions.suppressScrollWhenPopupsAreOpen);\n };\n GridOptionsWrapper.prototype.isRowDragEntireRow = function () {\n return isTrue(this.gridOptions.rowDragEntireRow);\n };\n GridOptionsWrapper.prototype.isSuppressRowDrag = function () {\n return isTrue(this.gridOptions.suppressRowDrag);\n };\n GridOptionsWrapper.prototype.isRowDragManaged = function () {\n return isTrue(this.gridOptions.rowDragManaged);\n };\n GridOptionsWrapper.prototype.isSuppressMoveWhenRowDragging = function () {\n return isTrue(this.gridOptions.suppressMoveWhenRowDragging);\n };\n GridOptionsWrapper.prototype.isRowDragMultiRow = function () {\n return isTrue(this.gridOptions.rowDragMultiRow);\n };\n // returns either 'print', 'autoHeight' or 'normal' (normal is the default)\n GridOptionsWrapper.prototype.getDomLayout = function () {\n var domLayout = this.gridOptions.domLayout || Constants.DOM_LAYOUT_NORMAL;\n var validLayouts = [\n Constants.DOM_LAYOUT_PRINT,\n Constants.DOM_LAYOUT_AUTO_HEIGHT,\n Constants.DOM_LAYOUT_NORMAL\n ];\n if (validLayouts.indexOf(domLayout) === -1) {\n doOnce(function () {\n return console.warn(\"AG Grid: \" + domLayout + \" is not valid for DOM Layout, valid values are \" + Constants.DOM_LAYOUT_NORMAL + \", \" + Constants.DOM_LAYOUT_AUTO_HEIGHT + \" and \" + Constants.DOM_LAYOUT_PRINT);\n }, 'warn about dom layout values');\n return Constants.DOM_LAYOUT_NORMAL;\n }\n return domLayout;\n };\n GridOptionsWrapper.prototype.isSuppressHorizontalScroll = function () {\n return isTrue(this.gridOptions.suppressHorizontalScroll);\n };\n GridOptionsWrapper.prototype.isSuppressMaxRenderedRowRestriction = function () {\n return isTrue(this.gridOptions.suppressMaxRenderedRowRestriction);\n };\n GridOptionsWrapper.prototype.isExcludeChildrenWhenTreeDataFiltering = function () {\n return isTrue(this.gridOptions.excludeChildrenWhenTreeDataFiltering);\n };\n GridOptionsWrapper.prototype.isAlwaysShowHorizontalScroll = function () {\n return isTrue(this.gridOptions.alwaysShowHorizontalScroll);\n };\n GridOptionsWrapper.prototype.isAlwaysShowVerticalScroll = function () {\n return isTrue(this.gridOptions.alwaysShowVerticalScroll);\n };\n GridOptionsWrapper.prototype.isDebounceVerticalScrollbar = function () {\n return isTrue(this.gridOptions.debounceVerticalScrollbar);\n };\n GridOptionsWrapper.prototype.isSuppressLoadingOverlay = function () {\n return isTrue(this.gridOptions.suppressLoadingOverlay);\n };\n GridOptionsWrapper.prototype.isSuppressNoRowsOverlay = function () {\n return isTrue(this.gridOptions.suppressNoRowsOverlay);\n };\n GridOptionsWrapper.prototype.isSuppressFieldDotNotation = function () {\n return isTrue(this.gridOptions.suppressFieldDotNotation);\n };\n GridOptionsWrapper.prototype.getPinnedTopRowData = function () {\n return this.gridOptions.pinnedTopRowData;\n };\n GridOptionsWrapper.prototype.getPinnedBottomRowData = function () {\n return this.gridOptions.pinnedBottomRowData;\n };\n GridOptionsWrapper.prototype.isFunctionsPassive = function () {\n return isTrue(this.gridOptions.functionsPassive);\n };\n GridOptionsWrapper.prototype.isSuppressChangeDetection = function () {\n return isTrue(this.gridOptions.suppressChangeDetection);\n };\n GridOptionsWrapper.prototype.isSuppressAnimationFrame = function () {\n return isTrue(this.gridOptions.suppressAnimationFrame);\n };\n GridOptionsWrapper.prototype.getQuickFilterText = function () {\n return this.gridOptions.quickFilterText;\n };\n GridOptionsWrapper.prototype.isCacheQuickFilter = function () {\n return isTrue(this.gridOptions.cacheQuickFilter);\n };\n GridOptionsWrapper.prototype.isUnSortIcon = function () {\n return isTrue(this.gridOptions.unSortIcon);\n };\n GridOptionsWrapper.prototype.isSuppressMenuHide = function () {\n return isTrue(this.gridOptions.suppressMenuHide);\n };\n GridOptionsWrapper.prototype.isEnterMovesDownAfterEdit = function () {\n return isTrue(this.gridOptions.enterMovesDownAfterEdit);\n };\n GridOptionsWrapper.prototype.isEnterMovesDown = function () {\n return isTrue(this.gridOptions.enterMovesDown);\n };\n GridOptionsWrapper.prototype.isUndoRedoCellEditing = function () {\n return isTrue(this.gridOptions.undoRedoCellEditing);\n };\n GridOptionsWrapper.prototype.getUndoRedoCellEditingLimit = function () {\n return toNumber(this.gridOptions.undoRedoCellEditingLimit);\n };\n GridOptionsWrapper.prototype.getRowStyle = function () {\n return this.gridOptions.rowStyle;\n };\n GridOptionsWrapper.prototype.getRowClass = function () {\n return this.gridOptions.rowClass;\n };\n GridOptionsWrapper.prototype.getRowStyleFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.getRowStyle);\n };\n GridOptionsWrapper.prototype.getRowClassFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.getRowClass);\n };\n GridOptionsWrapper.prototype.rowClassRules = function () {\n return this.gridOptions.rowClassRules;\n };\n GridOptionsWrapper.prototype.isServerSideInfiniteScroll = function () {\n return isTrue(this.gridOptions.serverSideInfiniteScroll);\n };\n GridOptionsWrapper.prototype.getServerSideGroupLevelParamsFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.getServerSideGroupLevelParams);\n };\n GridOptionsWrapper.prototype.getCreateChartContainerFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.createChartContainer);\n };\n GridOptionsWrapper.prototype.getPopupParent = function () {\n return this.gridOptions.popupParent;\n };\n GridOptionsWrapper.prototype.getBlockLoadDebounceMillis = function () {\n return this.gridOptions.blockLoadDebounceMillis;\n };\n GridOptionsWrapper.prototype.getPostProcessPopupFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.postProcessPopup);\n };\n GridOptionsWrapper.prototype.getPaginationNumberFormatterFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.paginationNumberFormatter);\n };\n GridOptionsWrapper.prototype.getChildCountFunc = function () {\n return this.gridOptions.getChildCount;\n };\n GridOptionsWrapper.prototype.getIsApplyServerSideTransactionFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.isApplyServerSideTransaction);\n };\n GridOptionsWrapper.prototype.getInitialGroupOrderComparator = function () {\n var _a = this.gridOptions, initialGroupOrderComparator = _a.initialGroupOrderComparator, defaultGroupOrderComparator = _a.defaultGroupOrderComparator;\n if (initialGroupOrderComparator) {\n return this.mergeGridCommonParams(initialGroupOrderComparator);\n }\n // this is the deprecated way, so provide a proxy to make it compatible\n if (defaultGroupOrderComparator) {\n return function (params) { return defaultGroupOrderComparator(params.nodeA, params.nodeB); };\n }\n };\n GridOptionsWrapper.prototype.getIsFullWidthCellFunc = function () {\n var _a = this.gridOptions, isFullWidthRow = _a.isFullWidthRow, isFullWidthCell = _a.isFullWidthCell;\n if (isFullWidthRow) {\n return this.mergeGridCommonParams(isFullWidthRow);\n }\n // this is the deprecated way, so provide a proxy to make it compatible\n if (isFullWidthCell) {\n return function (params) { return isFullWidthCell(params.rowNode); };\n }\n };\n GridOptionsWrapper.prototype.getFullWidthCellRendererParams = function () {\n return this.gridOptions.fullWidthCellRendererParams;\n };\n GridOptionsWrapper.prototype.isEmbedFullWidthRows = function () {\n return isTrue(this.gridOptions.embedFullWidthRows) || isTrue(this.gridOptions.deprecatedEmbedFullWidthRows);\n };\n GridOptionsWrapper.prototype.isDetailRowAutoHeight = function () {\n return isTrue(this.gridOptions.detailRowAutoHeight);\n };\n GridOptionsWrapper.prototype.getSuppressKeyboardEventFunc = function () {\n return this.gridOptions.suppressKeyboardEvent;\n };\n GridOptionsWrapper.prototype.getBusinessKeyForNodeFunc = function () {\n return this.gridOptions.getBusinessKeyForNode;\n };\n GridOptionsWrapper.prototype.getApi = function () {\n return this.gridOptions.api;\n };\n GridOptionsWrapper.prototype.getColumnApi = function () {\n return this.gridOptions.columnApi;\n };\n GridOptionsWrapper.prototype.isReadOnlyEdit = function () {\n return isTrue(this.gridOptions.readOnlyEdit);\n };\n GridOptionsWrapper.prototype.isImmutableData = function () {\n // we used to have a property immutableData for this. however this was deprecated\n // in favour of having Immutable Data on by default when getRowId is provided\n var getRowIdProvided = this.gridOptions.getRowId != null;\n var immutableData = isTrue(this.gridOptions.immutableData);\n // this property is a backwards compatibility property, for those who want\n // the old behaviour of Row ID's but NOT Immutable Data.\n var resetRowDataOnUpdate = isTrue(this.gridOptions.resetRowDataOnUpdate);\n if (resetRowDataOnUpdate) {\n return false;\n }\n return getRowIdProvided || immutableData;\n };\n GridOptionsWrapper.prototype.isEnsureDomOrder = function () {\n return isTrue(this.gridOptions.ensureDomOrder);\n };\n GridOptionsWrapper.prototype.isEnableCharts = function () {\n if (isTrue(this.gridOptions.enableCharts)) {\n return ModuleRegistry.assertRegistered(ModuleNames.GridChartsModule, 'enableCharts');\n }\n return false;\n };\n GridOptionsWrapper.prototype.getColResizeDefault = function () {\n return this.gridOptions.colResizeDefault;\n };\n GridOptionsWrapper.prototype.isSingleClickEdit = function () {\n return isTrue(this.gridOptions.singleClickEdit);\n };\n GridOptionsWrapper.prototype.isSuppressClickEdit = function () {\n return isTrue(this.gridOptions.suppressClickEdit);\n };\n GridOptionsWrapper.prototype.isStopEditingWhenCellsLoseFocus = function () {\n return isTrue(this.gridOptions.stopEditingWhenCellsLoseFocus);\n };\n GridOptionsWrapper.prototype.getGroupDefaultExpanded = function () {\n return this.gridOptions.groupDefaultExpanded;\n };\n GridOptionsWrapper.prototype.getMaxConcurrentDatasourceRequests = function () {\n var res = toNumber(this.gridOptions.maxConcurrentDatasourceRequests);\n if (res == null) {\n return 2;\n } // 2 is the default\n if (res <= 0) {\n return;\n } // negative number, eg -1, means no max restriction\n return res;\n };\n GridOptionsWrapper.prototype.getMaxBlocksInCache = function () {\n return this.gridOptions.maxBlocksInCache;\n };\n GridOptionsWrapper.prototype.getCacheOverflowSize = function () {\n return this.gridOptions.cacheOverflowSize;\n };\n GridOptionsWrapper.prototype.getPaginationPageSize = function () {\n return toNumber(this.gridOptions.paginationPageSize);\n };\n GridOptionsWrapper.prototype.isPaginateChildRows = function () {\n var shouldPaginate = this.isGroupRemoveSingleChildren() || this.isGroupRemoveLowestSingleChildren();\n if (shouldPaginate) {\n return true;\n }\n return isTrue(this.gridOptions.paginateChildRows);\n };\n GridOptionsWrapper.prototype.getCacheBlockSize = function () {\n return oneOrGreater(this.gridOptions.cacheBlockSize);\n };\n GridOptionsWrapper.prototype.getInfiniteInitialRowCount = function () {\n return this.gridOptions.infiniteInitialRowCount;\n };\n GridOptionsWrapper.prototype.getServerSideInitialRowCount = function () {\n var rowCount = this.gridOptions.serverSideInitialRowCount;\n if (typeof rowCount === 'number' && rowCount > 0) {\n return rowCount;\n }\n return 1;\n };\n GridOptionsWrapper.prototype.isPurgeClosedRowNodes = function () {\n return isTrue(this.gridOptions.purgeClosedRowNodes);\n };\n GridOptionsWrapper.prototype.isSuppressPaginationPanel = function () {\n return isTrue(this.gridOptions.suppressPaginationPanel);\n };\n GridOptionsWrapper.prototype.getRowData = function () {\n return this.gridOptions.rowData;\n };\n GridOptionsWrapper.prototype.isEnableRtl = function () {\n return isTrue(this.gridOptions.enableRtl);\n };\n GridOptionsWrapper.prototype.getRowGroupPanelShow = function () {\n return this.gridOptions.rowGroupPanelShow;\n };\n GridOptionsWrapper.prototype.getPivotPanelShow = function () {\n return this.gridOptions.pivotPanelShow;\n };\n GridOptionsWrapper.prototype.isAngularCompileRows = function () {\n return isTrue(this.gridOptions.angularCompileRows);\n };\n GridOptionsWrapper.prototype.isAngularCompileFilters = function () {\n return isTrue(this.gridOptions.angularCompileFilters);\n };\n GridOptionsWrapper.prototype.isDebug = function () {\n return isTrue(this.gridOptions.debug);\n };\n GridOptionsWrapper.prototype.getColumnDefs = function () {\n return this.gridOptions.columnDefs;\n };\n GridOptionsWrapper.prototype.getColumnTypes = function () {\n return this.gridOptions.columnTypes;\n };\n GridOptionsWrapper.prototype.getDatasource = function () {\n return this.gridOptions.datasource;\n };\n GridOptionsWrapper.prototype.getViewportDatasource = function () {\n return this.gridOptions.viewportDatasource;\n };\n GridOptionsWrapper.prototype.getServerSideDatasource = function () {\n return this.gridOptions.serverSideDatasource;\n };\n GridOptionsWrapper.prototype.isAccentedSort = function () {\n return isTrue(this.gridOptions.accentedSort);\n };\n GridOptionsWrapper.prototype.isEnableBrowserTooltips = function () {\n return isTrue(this.gridOptions.enableBrowserTooltips);\n };\n GridOptionsWrapper.prototype.isEnableCellExpressions = function () {\n return isTrue(this.gridOptions.enableCellExpressions);\n };\n GridOptionsWrapper.prototype.isEnableGroupEdit = function () {\n return isTrue(this.gridOptions.enableGroupEdit);\n };\n GridOptionsWrapper.prototype.isSuppressMiddleClickScrolls = function () {\n return isTrue(this.gridOptions.suppressMiddleClickScrolls);\n };\n GridOptionsWrapper.prototype.isPreventDefaultOnContextMenu = function () {\n return isTrue(this.gridOptions.preventDefaultOnContextMenu);\n };\n GridOptionsWrapper.prototype.isSuppressPreventDefaultOnMouseWheel = function () {\n return isTrue(this.gridOptions.suppressPreventDefaultOnMouseWheel);\n };\n GridOptionsWrapper.prototype.isSuppressColumnVirtualisation = function () {\n return isTrue(this.gridOptions.suppressColumnVirtualisation);\n };\n GridOptionsWrapper.prototype.isSuppressRowVirtualisation = function () {\n return isTrue(this.gridOptions.suppressRowVirtualisation);\n };\n GridOptionsWrapper.prototype.isSuppressContextMenu = function () {\n return isTrue(this.gridOptions.suppressContextMenu);\n };\n GridOptionsWrapper.prototype.isAllowContextMenuWithControlKey = function () {\n return isTrue(this.gridOptions.allowContextMenuWithControlKey);\n };\n GridOptionsWrapper.prototype.isSuppressCopyRowsToClipboard = function () {\n return isTrue(this.gridOptions.suppressCopyRowsToClipboard);\n };\n GridOptionsWrapper.prototype.isSuppressCopySingleCellRanges = function () {\n return isTrue(this.gridOptions.suppressCopySingleCellRanges);\n };\n GridOptionsWrapper.prototype.isCopyHeadersToClipboard = function () {\n return isTrue(this.gridOptions.copyHeadersToClipboard);\n };\n GridOptionsWrapper.prototype.isCopyGroupHeadersToClipboard = function () {\n return isTrue(this.gridOptions.copyGroupHeadersToClipboard);\n };\n GridOptionsWrapper.prototype.isSuppressClipboardPaste = function () {\n return isTrue(this.gridOptions.suppressClipboardPaste);\n };\n GridOptionsWrapper.prototype.isSuppressLastEmptyLineOnPaste = function () {\n return isTrue(this.gridOptions.suppressLastEmptyLineOnPaste);\n };\n GridOptionsWrapper.prototype.isPagination = function () {\n return isTrue(this.gridOptions.pagination);\n };\n GridOptionsWrapper.prototype.isSuppressEnterpriseResetOnNewColumns = function () {\n return isTrue(this.gridOptions.suppressEnterpriseResetOnNewColumns);\n };\n GridOptionsWrapper.prototype.getProcessDataFromClipboardFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.processDataFromClipboard);\n };\n GridOptionsWrapper.prototype.getAsyncTransactionWaitMillis = function () {\n return exists(this.gridOptions.asyncTransactionWaitMillis) ? this.gridOptions.asyncTransactionWaitMillis : Constants.BATCH_WAIT_MILLIS;\n };\n GridOptionsWrapper.prototype.isSuppressMovableColumns = function () {\n return isTrue(this.gridOptions.suppressMovableColumns);\n };\n GridOptionsWrapper.prototype.isAnimateRows = function () {\n // never allow animating if enforcing the row order\n if (this.isEnsureDomOrder()) {\n return false;\n }\n return isTrue(this.gridOptions.animateRows);\n };\n GridOptionsWrapper.prototype.isSuppressColumnMoveAnimation = function () {\n return isTrue(this.gridOptions.suppressColumnMoveAnimation);\n };\n GridOptionsWrapper.prototype.isSuppressAggFuncInHeader = function () {\n return isTrue(this.gridOptions.suppressAggFuncInHeader);\n };\n GridOptionsWrapper.prototype.isSuppressAggAtRootLevel = function () {\n return isTrue(this.gridOptions.suppressAggAtRootLevel);\n };\n GridOptionsWrapper.prototype.isSuppressAggFilteredOnly = function () {\n var isGroupAggFiltering = this.getGroupAggFiltering() !== undefined;\n return isGroupAggFiltering || isTrue(this.gridOptions.suppressAggFilteredOnly);\n };\n GridOptionsWrapper.prototype.isRemovePivotHeaderRowWhenSingleValueColumn = function () {\n return isTrue(this.gridOptions.removePivotHeaderRowWhenSingleValueColumn);\n };\n GridOptionsWrapper.prototype.isShowOpenedGroup = function () {\n return isTrue(this.gridOptions.showOpenedGroup);\n };\n GridOptionsWrapper.prototype.isReactUi = function () {\n return isTrue(this.gridOptions.reactUi);\n };\n GridOptionsWrapper.prototype.isSuppressReactUi = function () {\n return isTrue(this.gridOptions.suppressReactUi);\n };\n GridOptionsWrapper.prototype.isEnableRangeSelection = function () {\n return ModuleRegistry.isRegistered(ModuleNames.RangeSelectionModule) && isTrue(this.gridOptions.enableRangeSelection);\n };\n GridOptionsWrapper.prototype.isEnableRangeHandle = function () {\n return isTrue(this.gridOptions.enableRangeHandle);\n };\n GridOptionsWrapper.prototype.isEnableFillHandle = function () {\n return isTrue(this.gridOptions.enableFillHandle);\n };\n GridOptionsWrapper.prototype.getFillHandleDirection = function () {\n var direction = this.gridOptions.fillHandleDirection;\n if (!direction) {\n return 'xy';\n }\n if (direction !== 'x' && direction !== 'y' && direction !== 'xy') {\n doOnce(function () { return console.warn(\"AG Grid: valid values for fillHandleDirection are 'x', 'y' and 'xy'. Default to 'xy'.\"); }, 'warn invalid fill direction');\n return 'xy';\n }\n return direction;\n };\n GridOptionsWrapper.prototype.getFillOperation = function () {\n return this.mergeGridCommonParams(this.gridOptions.fillOperation);\n };\n GridOptionsWrapper.prototype.isSuppressMultiRangeSelection = function () {\n return isTrue(this.gridOptions.suppressMultiRangeSelection);\n };\n GridOptionsWrapper.prototype.isPaginationAutoPageSize = function () {\n return isTrue(this.gridOptions.paginationAutoPageSize);\n };\n GridOptionsWrapper.prototype.isRememberGroupStateWhenNewData = function () {\n return isTrue(this.gridOptions.rememberGroupStateWhenNewData);\n };\n GridOptionsWrapper.prototype.getIcons = function () {\n return this.gridOptions.icons;\n };\n GridOptionsWrapper.prototype.getGroupAggFiltering = function () {\n var userValue = this.gridOptions.groupAggFiltering;\n if (typeof userValue === 'function') {\n return this.mergeGridCommonParams(userValue);\n }\n if (isTrue(userValue)) {\n return function () { return true; };\n }\n return undefined;\n };\n GridOptionsWrapper.prototype.getAggFuncs = function () {\n return this.gridOptions.aggFuncs;\n };\n GridOptionsWrapper.prototype.getSortingOrder = function () {\n return this.gridOptions.sortingOrder;\n };\n GridOptionsWrapper.prototype.getAlignedGrids = function () {\n return this.gridOptions.alignedGrids;\n };\n GridOptionsWrapper.prototype.isMasterDetail = function () {\n var masterDetail = isTrue(this.gridOptions.masterDetail);\n if (masterDetail) {\n return ModuleRegistry.assertRegistered(ModuleNames.MasterDetailModule, 'masterDetail');\n }\n else {\n return false;\n }\n };\n GridOptionsWrapper.prototype.isKeepDetailRows = function () {\n return isTrue(this.gridOptions.keepDetailRows);\n };\n GridOptionsWrapper.prototype.getKeepDetailRowsCount = function () {\n var keepDetailRowsCount = this.gridOptions.keepDetailRowsCount;\n if (exists(keepDetailRowsCount) && keepDetailRowsCount > 0) {\n return this.gridOptions.keepDetailRowsCount;\n }\n return DEFAULT_KEEP_DETAIL_ROW_COUNT;\n };\n GridOptionsWrapper.prototype.getIsRowMasterFunc = function () {\n return this.gridOptions.isRowMaster;\n };\n GridOptionsWrapper.prototype.getIsRowSelectableFunc = function () {\n return this.gridOptions.isRowSelectable;\n };\n GridOptionsWrapper.prototype.getGroupRowRendererParams = function () {\n return this.gridOptions.groupRowRendererParams;\n };\n GridOptionsWrapper.prototype.getOverlayLoadingTemplate = function () {\n return this.gridOptions.overlayLoadingTemplate;\n };\n GridOptionsWrapper.prototype.getOverlayNoRowsTemplate = function () {\n return this.gridOptions.overlayNoRowsTemplate;\n };\n GridOptionsWrapper.prototype.isSuppressAutoSize = function () {\n return isTrue(this.gridOptions.suppressAutoSize);\n };\n GridOptionsWrapper.prototype.isEnableCellTextSelection = function () {\n return isTrue(this.gridOptions.enableCellTextSelection);\n };\n GridOptionsWrapper.prototype.isSuppressParentsInRowNodes = function () {\n return isTrue(this.gridOptions.suppressParentsInRowNodes);\n };\n GridOptionsWrapper.prototype.isSuppressClipboardApi = function () {\n return isTrue(this.gridOptions.suppressClipboardApi);\n };\n GridOptionsWrapper.prototype.isFunctionsReadOnly = function () {\n return isTrue(this.gridOptions.functionsReadOnly);\n };\n GridOptionsWrapper.prototype.isEnableCellTextSelect = function () {\n return isTrue(this.gridOptions.enableCellTextSelection);\n };\n GridOptionsWrapper.prototype.getDefaultColDef = function () {\n return this.gridOptions.defaultColDef;\n };\n GridOptionsWrapper.prototype.getDefaultColGroupDef = function () {\n return this.gridOptions.defaultColGroupDef;\n };\n GridOptionsWrapper.prototype.getDefaultExportParams = function (type) {\n if (this.gridOptions.defaultExportParams) {\n console.warn(\"AG Grid: Since v25.2 `defaultExportParams` has been replaced by `default\" + capitalise(type) + \"ExportParams`'\");\n if (type === 'csv') {\n return this.gridOptions.defaultExportParams;\n }\n return this.gridOptions.defaultExportParams;\n }\n if (type === 'csv' && this.gridOptions.defaultCsvExportParams) {\n return this.gridOptions.defaultCsvExportParams;\n }\n if (type === 'excel' && this.gridOptions.defaultExcelExportParams) {\n return this.gridOptions.defaultExcelExportParams;\n }\n };\n GridOptionsWrapper.prototype.isSuppressCsvExport = function () {\n return isTrue(this.gridOptions.suppressCsvExport);\n };\n GridOptionsWrapper.prototype.isAllowShowChangeAfterFilter = function () {\n return isTrue(this.gridOptions.allowShowChangeAfterFilter);\n };\n GridOptionsWrapper.prototype.isSuppressExcelExport = function () {\n return isTrue(this.gridOptions.suppressExcelExport);\n };\n GridOptionsWrapper.prototype.isSuppressMakeColumnVisibleAfterUnGroup = function () {\n return isTrue(this.gridOptions.suppressMakeColumnVisibleAfterUnGroup);\n };\n GridOptionsWrapper.prototype.getDataPathFunc = function () {\n return this.gridOptions.getDataPath;\n };\n GridOptionsWrapper.prototype.getIsServerSideGroupFunc = function () {\n return this.gridOptions.isServerSideGroup;\n };\n GridOptionsWrapper.prototype.getIsServerSideGroupOpenByDefaultFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.isServerSideGroupOpenByDefault);\n };\n GridOptionsWrapper.prototype.getIsGroupOpenByDefaultFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.isGroupOpenByDefault);\n };\n GridOptionsWrapper.prototype.getServerSideGroupKeyFunc = function () {\n return this.gridOptions.getServerSideGroupKey;\n };\n GridOptionsWrapper.prototype.getGroupRowAggFunc = function () {\n var _a = this.gridOptions, getGroupRowAgg = _a.getGroupRowAgg, groupRowAggNodes = _a.groupRowAggNodes;\n if (getGroupRowAgg) {\n return this.mergeGridCommonParams(getGroupRowAgg);\n }\n // this is the deprecated way, so provide a proxy to make it compatible\n if (groupRowAggNodes) {\n return function (params) { return groupRowAggNodes(params.nodes); };\n }\n };\n GridOptionsWrapper.prototype.getContextMenuItemsFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.getContextMenuItems);\n };\n GridOptionsWrapper.prototype.getMainMenuItemsFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.getMainMenuItems);\n };\n GridOptionsWrapper.prototype.getRowIdFunc = function () {\n var _a = this.gridOptions, getRowId = _a.getRowId, getRowNodeId = _a.getRowNodeId;\n if (getRowId) {\n return this.mergeGridCommonParams(getRowId);\n }\n // this is the deprecated way, so provide a proxy to make it compatible\n if (getRowNodeId) {\n return function (params) { return getRowNodeId(params.data); };\n }\n };\n GridOptionsWrapper.prototype.getNavigateToNextHeaderFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.navigateToNextHeader);\n };\n GridOptionsWrapper.prototype.getTabToNextHeaderFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.tabToNextHeader);\n };\n GridOptionsWrapper.prototype.getNavigateToNextCellFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.navigateToNextCell);\n };\n GridOptionsWrapper.prototype.getTabToNextCellFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.tabToNextCell);\n };\n GridOptionsWrapper.prototype.getGridTabIndex = function () {\n return (this.gridOptions.tabIndex || 0).toString();\n };\n GridOptionsWrapper.prototype.isTreeData = function () {\n var usingTreeData = isTrue(this.gridOptions.treeData);\n if (usingTreeData) {\n return ModuleRegistry.assertRegistered(ModuleNames.RowGroupingModule, 'Tree Data');\n }\n return false;\n };\n GridOptionsWrapper.prototype.isValueCache = function () {\n return isTrue(this.gridOptions.valueCache);\n };\n GridOptionsWrapper.prototype.isValueCacheNeverExpires = function () {\n return isTrue(this.gridOptions.valueCacheNeverExpires);\n };\n GridOptionsWrapper.prototype.isDeltaSort = function () {\n return isTrue(this.gridOptions.deltaSort);\n };\n GridOptionsWrapper.prototype.isAggregateOnlyChangedColumns = function () {\n return isTrue(this.gridOptions.aggregateOnlyChangedColumns);\n };\n GridOptionsWrapper.prototype.getProcessPivotResultColDefFunc = function () {\n return this.gridOptions.processPivotResultColDef || this.gridOptions.processSecondaryColDef;\n };\n GridOptionsWrapper.prototype.getProcessPivotResultColGroupDefFunc = function () {\n return this.gridOptions.processPivotResultColGroupDef || this.gridOptions.processSecondaryColGroupDef;\n };\n GridOptionsWrapper.prototype.getSendToClipboardFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.sendToClipboard);\n };\n GridOptionsWrapper.prototype.getProcessRowPostCreateFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.processRowPostCreate);\n };\n GridOptionsWrapper.prototype.getProcessCellForClipboardFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.processCellForClipboard);\n };\n GridOptionsWrapper.prototype.getProcessHeaderForClipboardFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.processHeaderForClipboard);\n };\n GridOptionsWrapper.prototype.getProcessGroupHeaderForClipboardFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.processGroupHeaderForClipboard);\n };\n GridOptionsWrapper.prototype.getProcessCellFromClipboardFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.processCellFromClipboard);\n };\n GridOptionsWrapper.prototype.getViewportRowModelPageSize = function () {\n return oneOrGreater(this.gridOptions.viewportRowModelPageSize, DEFAULT_VIEWPORT_ROW_MODEL_PAGE_SIZE);\n };\n GridOptionsWrapper.prototype.getViewportRowModelBufferSize = function () {\n return zeroOrGreater(this.gridOptions.viewportRowModelBufferSize, DEFAULT_VIEWPORT_ROW_MODEL_BUFFER_SIZE);\n };\n GridOptionsWrapper.prototype.isServerSideSortAllLevels = function () {\n var isEnabled = isTrue(this.gridOptions.serverSideSortAllLevels);\n if (!this.isRowModelServerSide() && isEnabled) {\n doOnce(function () { return console.warn('AG Grid: The `serverSideSortAllLevels` property can only be used with the server side row model.'); }, 'serverSideSortAllLevels');\n return false;\n }\n return isEnabled;\n };\n GridOptionsWrapper.prototype.isServerSideFilterAllLevels = function () {\n var isEnabled = isTrue(this.gridOptions.serverSideFilterAllLevels);\n if (!this.isRowModelServerSide() && isEnabled) {\n doOnce(function () { return console.warn('AG Grid: The `serverSideFilterAllLevels` property can only be used with the server side row model.'); }, 'serverSideFilterAllLevels');\n return false;\n }\n return isEnabled;\n };\n GridOptionsWrapper.prototype.isServerSideSortOnServer = function () {\n var isEnabled = isTrue(this.gridOptions.serverSideSortOnServer);\n if (!this.isRowModelServerSide() && isEnabled) {\n doOnce(function () { return console.warn('AG Grid: The `serverSideSortOnServer` property can only be used with the server side row model.'); }, 'serverSideSortOnServerRowModel');\n return false;\n }\n if (this.isTreeData() && isEnabled) {\n doOnce(function () { return console.warn('AG Grid: The `serverSideSortOnServer` property cannot be used while using tree data.'); }, 'serverSideSortOnServerTreeData');\n return false;\n }\n return isEnabled;\n };\n GridOptionsWrapper.prototype.isServerSideFilterOnServer = function () {\n var isEnabled = isTrue(this.gridOptions.serverSideFilterOnServer);\n if (!this.isRowModelServerSide() && isEnabled) {\n doOnce(function () { return console.warn('AG Grid: The `serverSideFilterOnServer` property can only be used with the server side row model.'); }, 'serverSideFilterOnServerRowModel');\n return false;\n }\n if (this.isTreeData() && isEnabled) {\n doOnce(function () { return console.warn('AG Grid: The `serverSideFilterOnServer` property cannot be used while using tree data.'); }, 'serverSideFilterOnServerTreeData');\n return false;\n }\n return isEnabled;\n };\n GridOptionsWrapper.prototype.getPostSortFunc = function () {\n var _a = this.gridOptions, postSortRows = _a.postSortRows, postSort = _a.postSort;\n if (postSortRows) {\n return this.mergeGridCommonParams(postSortRows);\n }\n // this is the deprecated way, so provide a proxy to make it compatible\n if (postSort) {\n return function (params) { return postSort(params.nodes); };\n }\n };\n GridOptionsWrapper.prototype.getChartToolbarItemsFunc = function () {\n return this.mergeGridCommonParams(this.gridOptions.getChartToolbarItems);\n };\n GridOptionsWrapper.prototype.getChartThemeOverrides = function () {\n return this.gridOptions.chartThemeOverrides;\n };\n GridOptionsWrapper.prototype.getCustomChartThemes = function () {\n return this.gridOptions.customChartThemes;\n };\n GridOptionsWrapper.prototype.getChartThemes = function () {\n // return default themes if user hasn't supplied any\n return this.gridOptions.chartThemes || ['ag-default', 'ag-material', 'ag-pastel', 'ag-vivid', 'ag-solar'];\n };\n GridOptionsWrapper.prototype.getClipboardDelimiter = function () {\n return exists(this.gridOptions.clipboardDelimiter) ? this.gridOptions.clipboardDelimiter : '\\t';\n };\n GridOptionsWrapper.prototype.setProperty = function (key, value, force) {\n if (force === void 0) { force = false; }\n var previousValue = this.gridOptions[key];\n if (force || previousValue !== value) {\n this.gridOptions[key] = value;\n var event_1 = {\n type: key,\n currentValue: value,\n previousValue: previousValue\n };\n this.propertyEventService.dispatchEvent(event_1);\n }\n };\n GridOptionsWrapper.prototype.addEventListener = function (key, listener) {\n this.propertyEventService.addEventListener(key, listener);\n };\n GridOptionsWrapper.prototype.removeEventListener = function (key, listener) {\n this.propertyEventService.removeEventListener(key, listener);\n };\n GridOptionsWrapper.prototype.isSkipHeaderOnAutoSize = function () {\n return !!this.gridOptions.skipHeaderOnAutoSize;\n };\n GridOptionsWrapper.prototype.getAutoSizePadding = function () {\n var value = this.gridOptions.autoSizePadding;\n return value != null && value >= 0 ? value : 20;\n };\n // properties\n GridOptionsWrapper.prototype.getHeaderHeight = function () {\n if (typeof this.gridOptions.headerHeight === 'number') {\n return this.gridOptions.headerHeight;\n }\n return this.getFromTheme(25, 'headerHeight');\n };\n GridOptionsWrapper.prototype.getFloatingFiltersHeight = function () {\n if (typeof this.gridOptions.floatingFiltersHeight === 'number') {\n return this.gridOptions.floatingFiltersHeight;\n }\n return this.getFromTheme(25, 'headerHeight');\n };\n GridOptionsWrapper.prototype.getGroupHeaderHeight = function () {\n if (typeof this.gridOptions.groupHeaderHeight === 'number') {\n return this.gridOptions.groupHeaderHeight;\n }\n return this.getHeaderHeight();\n };\n GridOptionsWrapper.prototype.getPivotHeaderHeight = function () {\n if (typeof this.gridOptions.pivotHeaderHeight === 'number') {\n return this.gridOptions.pivotHeaderHeight;\n }\n return this.getHeaderHeight();\n };\n GridOptionsWrapper.prototype.getPivotGroupHeaderHeight = function () {\n if (typeof this.gridOptions.pivotGroupHeaderHeight === 'number') {\n return this.gridOptions.pivotGroupHeaderHeight;\n }\n return this.getGroupHeaderHeight();\n };\n GridOptionsWrapper.prototype.isExternalFilterPresent = function () {\n if (typeof this.gridOptions.isExternalFilterPresent === 'function') {\n return this.gridOptions.isExternalFilterPresent({ api: this.getApi(), columnApi: this.getColumnApi(), context: this.getContext() });\n }\n return false;\n };\n GridOptionsWrapper.prototype.doesExternalFilterPass = function (node) {\n if (typeof this.gridOptions.doesExternalFilterPass === 'function') {\n return this.gridOptions.doesExternalFilterPass(node);\n }\n return false;\n };\n GridOptionsWrapper.prototype.getTooltipDelay = function (type) {\n var _a = this.gridOptions, tooltipShowDelay = _a.tooltipShowDelay, tooltipHideDelay = _a.tooltipHideDelay;\n var delay = type === 'show' ? tooltipShowDelay : tooltipHideDelay;\n var capitalisedType = capitalise(type);\n if (exists(delay)) {\n if (delay < 0) {\n doOnce(function () { return console.warn(\"ag-grid: tooltip\" + capitalisedType + \"Delay should not be lower than 0\"); }, \"tooltip\" + capitalisedType + \"DelayWarn\");\n }\n return Math.max(200, delay);\n }\n return null;\n };\n GridOptionsWrapper.prototype.isTooltipMouseTrack = function () {\n return isTrue(this.gridOptions.tooltipMouseTrack);\n };\n GridOptionsWrapper.prototype.isSuppressModelUpdateAfterUpdateTransaction = function () {\n return isTrue(this.gridOptions.suppressModelUpdateAfterUpdateTransaction);\n };\n GridOptionsWrapper.prototype.getDocument = function () {\n // if user is providing document, we use the users one,\n // otherwise we use the document on the global namespace.\n var result = null;\n if (this.gridOptions.getDocument && exists(this.gridOptions.getDocument)) {\n result = this.gridOptions.getDocument();\n }\n else if (this.eGridDiv) {\n result = this.eGridDiv.ownerDocument;\n }\n if (result && exists(result)) {\n return result;\n }\n return document;\n };\n GridOptionsWrapper.prototype.getMinColWidth = function () {\n var minColWidth = this.gridOptions.minColWidth;\n if (exists(minColWidth) && minColWidth > GridOptionsWrapper_1.MIN_COL_WIDTH) {\n return this.gridOptions.minColWidth;\n }\n var measuredMin = this.getFromTheme(null, 'headerCellMinWidth');\n return exists(measuredMin) ? Math.max(measuredMin, GridOptionsWrapper_1.MIN_COL_WIDTH) : GridOptionsWrapper_1.MIN_COL_WIDTH;\n };\n GridOptionsWrapper.prototype.getMaxColWidth = function () {\n if (this.gridOptions.maxColWidth && this.gridOptions.maxColWidth > GridOptionsWrapper_1.MIN_COL_WIDTH) {\n return this.gridOptions.maxColWidth;\n }\n return null;\n };\n GridOptionsWrapper.prototype.getColWidth = function () {\n if (typeof this.gridOptions.colWidth !== 'number' || this.gridOptions.colWidth < GridOptionsWrapper_1.MIN_COL_WIDTH) {\n return 200;\n }\n return this.gridOptions.colWidth;\n };\n GridOptionsWrapper.prototype.getRowBuffer = function () {\n var rowBuffer = this.gridOptions.rowBuffer;\n if (typeof rowBuffer === 'number') {\n if (rowBuffer < 0) {\n doOnce(function () { return console.warn(\"AG Grid: rowBuffer should not be negative\"); }, 'warn rowBuffer negative');\n this.gridOptions.rowBuffer = rowBuffer = 0;\n }\n }\n else {\n rowBuffer = Constants.ROW_BUFFER_SIZE;\n }\n return rowBuffer;\n };\n GridOptionsWrapper.prototype.getRowBufferInPixels = function () {\n var rowsToBuffer = this.getRowBuffer();\n var defaultRowHeight = this.getRowHeightAsNumber();\n return rowsToBuffer * defaultRowHeight;\n };\n // the user might be using some non-standard scrollbar, eg a scrollbar that has zero\n // width and overlays (like the Safari scrollbar, but presented in Chrome). so we\n // allow the user to provide the scroll width before we work it out.\n GridOptionsWrapper.prototype.getScrollbarWidth = function () {\n if (this.scrollbarWidth == null) {\n var useGridOptions = typeof this.gridOptions.scrollbarWidth === 'number' && this.gridOptions.scrollbarWidth >= 0;\n var scrollbarWidth = useGridOptions ? this.gridOptions.scrollbarWidth : getScrollbarWidth();\n if (scrollbarWidth != null) {\n this.scrollbarWidth = scrollbarWidth;\n this.eventService.dispatchEvent({\n type: Events.EVENT_SCROLLBAR_WIDTH_CHANGED\n });\n }\n }\n return this.scrollbarWidth;\n };\n GridOptionsWrapper.prototype.checkForDeprecated = function () {\n // casting to generic object, so typescript compiles even though\n // we are looking for attributes that don't exist\n var options = this.gridOptions;\n if (options.deprecatedEmbedFullWidthRows) {\n console.warn(\"AG Grid: since v21.2, deprecatedEmbedFullWidthRows has been replaced with embedFullWidthRows.\");\n }\n if (options.rowDeselection) {\n console.warn('AG Grid: since v24.x, rowDeselection is deprecated and the behaviour is true by default. Please use `suppressRowDeselection` to prevent rows from being deselected.');\n }\n if (options.enableMultiRowDragging) {\n options.rowDragMultiRow = true;\n delete options.enableMultiRowDragging;\n console.warn('AG Grid: since v26.1, `enableMultiRowDragging` is deprecated. Please use `rowDragMultiRow`.');\n }\n var checkRenamedProperty = function (oldProp, newProp, version) {\n if (options[oldProp] != null) {\n console.warn(\"AG Grid: since version \" + version + \", '\" + oldProp + \"' is deprecated / renamed, please use the new property name '\" + newProp + \"' instead.\");\n if (options[newProp] == null) {\n options[newProp] = options[oldProp];\n }\n }\n };\n checkRenamedProperty('batchUpdateWaitMillis', 'asyncTransactionWaitMillis', '23.1.x');\n checkRenamedProperty('deltaRowDataMode', 'immutableData', '23.1.x');\n checkRenamedProperty('serverSideFilteringAlwaysResets', 'serverSideFilterAllLevels', '28.0.0');\n checkRenamedProperty('serverSideSortingAlwaysResets', 'serverSideSortAllLevels', '28.0.0');\n if (options.immutableColumns || options.deltaColumnMode) {\n console.warn('AG Grid: since v24.0, immutableColumns and deltaColumnMode properties are gone. The grid now works like this as default. To keep column order maintained, set grid property applyColumnDefOrder=true');\n }\n checkRenamedProperty('suppressSetColumnStateEvents', 'suppressColumnStateEvents', '24.0.x');\n if (options.groupRowInnerRenderer || options.groupRowInnerRendererParams || options.groupRowInnerRendererFramework) {\n console.warn('AG Grid: since v24.0, grid properties groupRowInnerRenderer, groupRowInnerRendererFramework and groupRowInnerRendererParams are no longer used.');\n console.warn(' Instead use the grid properties groupRowRendererParams.innerRenderer, groupRowRendererParams.innerRendererFramework and groupRowRendererParams.innerRendererParams.');\n console.warn(' For example instead of this:');\n console.warn(' groupRowInnerRenderer: \"myRenderer\"');\n console.warn(' groupRowInnerRendererParams: {x: a}');\n console.warn(' Replace with this:');\n console.warn(' groupRowRendererParams: {');\n console.warn(' innerRenderer: \"myRenderer\",');\n console.warn(' innerRendererParams: {x: a}');\n console.warn(' }');\n console.warn(' We have copied the properties over for you. However to stop this error message, please change your application code.');\n if (!options.groupRowRendererParams) {\n options.groupRowRendererParams = {};\n }\n var params = options.groupRowRendererParams;\n if (options.groupRowInnerRenderer) {\n params.innerRenderer = options.groupRowInnerRenderer;\n }\n if (options.groupRowInnerRendererParams) {\n params.innerRendererParams = options.groupRowInnerRendererParams;\n }\n if (options.groupRowInnerRendererFramework) {\n params.innerRendererFramework = options.groupRowInnerRendererFramework;\n }\n }\n if (options.rememberGroupStateWhenNewData) {\n console.warn('AG Grid: since v24.0, grid property rememberGroupStateWhenNewData is deprecated. This feature was provided before Transaction Updates worked (which keep group state). Now that transaction updates are possible and they keep group state, this feature is no longer needed.');\n }\n if (options.detailCellRendererParams && options.detailCellRendererParams.autoHeight) {\n console.warn('AG Grid: since v24.1, grid property detailCellRendererParams.autoHeight is replaced with grid property detailRowAutoHeight. This allows this feature to work when you provide a custom DetailCellRenderer');\n options.detailRowAutoHeight = true;\n }\n if (options.suppressKeyboardEvent) {\n console.warn(\"AG Grid: since v24.1 suppressKeyboardEvent in the gridOptions has been deprecated and will be removed in\\n future versions of AG Grid. If you need this to be set for every column use the defaultColDef property.\");\n }\n if (options.suppressEnterpriseResetOnNewColumns) {\n console.warn('AG Grid: since v25, grid property suppressEnterpriseResetOnNewColumns is deprecated. This was a temporary property to allow changing columns in Server Side Row Model without triggering a reload. Now that it is possible to dynamically change columns in the grid, this is no longer needed.');\n }\n if (options.suppressColumnStateEvents) {\n console.warn('AG Grid: since v25, grid property suppressColumnStateEvents no longer works due to a refactor that we did. It should be possible to achieve similar using event.source, which would be \"api\" if the event was due to setting column state via the API');\n }\n if (options.defaultExportParams) {\n console.warn('AG Grid: since v25.2, the grid property `defaultExportParams` has been replaced by `defaultCsvExportParams` and `defaultExcelExportParams`.');\n }\n if (options.stopEditingWhenGridLosesFocus) {\n console.warn('AG Grid: since v25.2.2, the grid property `stopEditingWhenGridLosesFocus` has been replaced by `stopEditingWhenCellsLoseFocus`.');\n options.stopEditingWhenCellsLoseFocus = true;\n }\n if (options.applyColumnDefOrder) {\n console.warn('AG Grid: since v26.0, the grid property `applyColumnDefOrder` is no longer needed, as this is the default behaviour. To turn this behaviour off, set maintainColumnOrder=true');\n }\n if (options.groupMultiAutoColumn) {\n console.warn(\"AG Grid: since v26.0, the grid property `groupMultiAutoColumn` has been replaced by `groupDisplayType = 'multipleColumns'`\");\n options.groupDisplayType = 'multipleColumns';\n }\n if (options.groupUseEntireRow) {\n console.warn(\"AG Grid: since v26.0, the grid property `groupUseEntireRow` has been replaced by `groupDisplayType = 'groupRows'`\");\n options.groupDisplayType = 'groupRows';\n }\n if (options.groupSuppressAutoColumn) {\n var propName = options.treeData ? 'treeDataDisplayType' : 'groupDisplayType';\n console.warn(\"AG Grid: since v26.0, the grid property `groupSuppressAutoColumn` has been replaced by `\" + propName + \" = 'custom'`\");\n options.groupDisplayType = 'custom';\n }\n if (options.defaultGroupOrderComparator) {\n console.warn(\"AG Grid: since v27.2, the grid property `defaultGroupOrderComparator` is deprecated and has been replaced by `initialGroupOrderComparator` and now receives a single params object.\");\n }\n if (options.defaultGroupSortComparator) {\n console.warn(\"AG Grid: since v26.0, the grid property `defaultGroupSortComparator` has been replaced by `initialGroupOrderComparator`\");\n options.defaultGroupOrderComparator = options.defaultGroupSortComparator;\n }\n if (options.groupRowAggNodes) {\n console.warn(\"AG Grid: since v27.2, the grid property `groupRowAggNodes` is deprecated and has been replaced by `getGroupRowAgg` and now receives a single params object.\");\n }\n if (options.postSort) {\n console.warn(\"AG Grid: since v27.2, the grid property `postSort` is deprecated and has been replaced by `postSortRows` and now receives a single params object.\");\n }\n if (options.isFullWidthCell) {\n console.warn(\"AG Grid: since v27.2, the grid property `isFullWidthCell` is deprecated and has been replaced by `isFullWidthRow` and now receives a single params object.\");\n }\n if (options.localeTextFunc) {\n console.warn(\"AG Grid: since v27.2, the grid property `localeTextFunc` is deprecated and has been replaced by `getLocaleText` and now receives a single params object.\");\n }\n if (options.colWidth) {\n console.warn('AG Grid: since v26.1, the grid property `colWidth` is deprecated and should be set via `defaultColDef.width`.');\n }\n if (options.minColWidth) {\n console.warn('AG Grid: since v26.1, the grid property `minColWidth` is deprecated and should be set via `defaultColDef.minWidth`.');\n }\n if (options.maxColWidth) {\n console.warn('AG Grid: since v26.1, the grid property `maxColWidth` is deprecated and should be set via `defaultColDef.maxWidth`.');\n }\n if (options.reactUi) {\n console.warn('AG Grid: since v27.0, React UI is on by default, so no need for reactUi=true. To turn it off, set suppressReactUi=true.');\n }\n if (options.suppressReactUi) {\n console.warn('AG Grid: The legacy React rendering engine is deprecated and will be removed in the next major version of the grid.');\n }\n if (options.suppressCellSelection) {\n console.warn('AG Grid: since v27.0, `suppressCellSelection` has been replaced by `suppressCellFocus`.');\n options.suppressCellFocus = options.suppressCellSelection;\n }\n if (options.getRowNodeId) {\n console.warn('AG Grid: since v27.1, `getRowNodeId` is deprecated and has been replaced by `getRowId`. The difference: if getRowId() is implemented then immutable data is enabled by default.');\n }\n if (options.immutableData) {\n if (options.getRowId) {\n console.warn('AG Grid: since v27.1, `immutableData` is deprecated. With the `getRowId` callback implemented, immutable data is enabled by default so you can remove `immutableData=true`.');\n }\n else {\n console.warn('AG Grid: since v27.1, `immutableData` is deprecated. To enable immutable data you must implement the `getRowId()` callback.');\n }\n }\n if (options.clipboardDeliminator) {\n console.warn('AG Grid: since v27.1, `clipboardDeliminator` has been replaced by `clipboardDelimiter`.');\n options.clipboardDelimiter = options.clipboardDeliminator;\n }\n checkRenamedProperty('processSecondaryColDef', 'processPivotResultColDef', '28.0.x');\n checkRenamedProperty('processSecondaryColGroupDef', 'processPivotResultColGroupDef', '28.0.x');\n if (options.serverSideStoreType) {\n console.warn('AG Grid: since v28.0, `serverSideStoreType` has been replaced by `serverSideInfiniteScroll`. Set to true to use Partial Store, and false to use Full Store.');\n options.serverSideInfiniteScroll = options.serverSideStoreType === 'partial';\n }\n checkRenamedProperty('getServerSideStoreParams', 'getServerSideGroupLevelParams', '28.0.x');\n };\n GridOptionsWrapper.prototype.checkForViolations = function () {\n if (this.isTreeData()) {\n this.treeDataViolations();\n }\n };\n GridOptionsWrapper.prototype.treeDataViolations = function () {\n if (this.isRowModelDefault()) {\n if (missing(this.getDataPathFunc())) {\n console.warn('AG Grid: property usingTreeData=true with rowModel=clientSide, but you did not ' +\n 'provide getDataPath function, please provide getDataPath function if using tree data.');\n }\n }\n if (this.isRowModelServerSide()) {\n if (missing(this.getIsServerSideGroupFunc())) {\n console.warn('AG Grid: property usingTreeData=true with rowModel=serverSide, but you did not ' +\n 'provide isServerSideGroup function, please provide isServerSideGroup function if using tree data.');\n }\n if (missing(this.getServerSideGroupKeyFunc())) {\n console.warn('AG Grid: property usingTreeData=true with rowModel=serverSide, but you did not ' +\n 'provide getServerSideGroupKey function, please provide getServerSideGroupKey function if using tree data.');\n }\n }\n };\n GridOptionsWrapper.prototype.getLocaleTextFunc = function () {\n var _this = this;\n var _a = this.gridOptions, localeText = _a.localeText, getLocaleText = _a.getLocaleText, localeTextFunc = _a.localeTextFunc;\n if (getLocaleText) {\n //key: string, defaultValue: string, variableValues?: string[]\n return function (key, defaultValue, variableValues) {\n var params = {\n key: key,\n defaultValue: defaultValue,\n variableValues: variableValues,\n api: _this.getApi(),\n columnApi: _this.getColumnApi(),\n context: _this.getContext()\n };\n return getLocaleText(params);\n };\n }\n if (localeTextFunc) {\n return localeTextFunc;\n }\n return function (key, defaultValue, variableValues) {\n var localisedText = localeText && localeText[key];\n if (localisedText && variableValues && variableValues.length) {\n var found = 0;\n while (true) {\n if (found >= variableValues.length) {\n break;\n }\n var idx = localisedText.indexOf('${variable}');\n if (idx === -1) {\n break;\n }\n localisedText = localisedText.replace('${variable}', variableValues[found++]);\n }\n }\n return (localisedText !== null && localisedText !== void 0 ? localisedText : defaultValue);\n };\n };\n // responsible for calling the onXXX functions on gridOptions\n GridOptionsWrapper.prototype.globalEventHandler = function (eventName, event) {\n // prevent events from being fired _after_ the grid has been destroyed\n if (this.destroyed) {\n return;\n }\n var callbackMethodName = ComponentUtil.getCallbackForEvent(eventName);\n if (typeof this.gridOptions[callbackMethodName] === 'function') {\n this.gridOptions[callbackMethodName](event);\n }\n };\n GridOptionsWrapper.prototype.setRowHeightVariable = function (height) {\n var oldRowHeight = this.eGridDiv.style.getPropertyValue('--ag-line-height').trim();\n var newRowHeight = height + \"px\";\n if (oldRowHeight != newRowHeight) {\n this.eGridDiv.style.setProperty('--ag-line-height', newRowHeight);\n }\n };\n // we don't allow dynamic row height for virtual paging\n GridOptionsWrapper.prototype.getRowHeightAsNumber = function () {\n if (!this.gridOptions.rowHeight || missing(this.gridOptions.rowHeight)) {\n return this.getDefaultRowHeight();\n }\n var rowHeight = this.gridOptions.rowHeight;\n if (rowHeight && this.isNumeric(rowHeight)) {\n this.setRowHeightVariable(rowHeight);\n return rowHeight;\n }\n console.warn('AG Grid row height must be a number if not using standard row model');\n return this.getDefaultRowHeight();\n };\n GridOptionsWrapper.prototype.isGetRowHeightFunction = function () {\n return typeof this.gridOptions.getRowHeight === 'function';\n };\n GridOptionsWrapper.prototype.getRowHeightForNode = function (rowNode, allowEstimate, defaultRowHeight) {\n if (allowEstimate === void 0) { allowEstimate = false; }\n if (defaultRowHeight == null) {\n defaultRowHeight = this.getDefaultRowHeight();\n }\n // check the function first, in case use set both function and\n // number, when using virtual pagination then function can be\n // used for pinned rows and the number for the body rows.\n if (this.isGetRowHeightFunction()) {\n if (allowEstimate) {\n return { height: defaultRowHeight, estimated: true };\n }\n var params = {\n node: rowNode,\n data: rowNode.data\n };\n var height = this.mergeGridCommonParams(this.gridOptions.getRowHeight)(params);\n if (this.isNumeric(height)) {\n if (height === 0) {\n doOnce(function () { return console.warn('AG Grid: The return of `getRowHeight` cannot be zero. If the intention is to hide rows, use a filter instead.'); }, 'invalidRowHeight');\n }\n return { height: Math.max(1, height), estimated: false };\n }\n }\n if (rowNode.detail && this.isMasterDetail()) {\n // if autoHeight, we want the height to grow to the new height starting at 1, as otherwise a flicker would happen,\n // as the detail goes to the default (eg 200px) and then immediately shrink up/down to the new measured height\n // (due to auto height) which looks bad, especially if doing row animation.\n if (this.isDetailRowAutoHeight()) {\n return { height: 1, estimated: false };\n }\n if (this.isNumeric(this.gridOptions.detailRowHeight)) {\n return { height: this.gridOptions.detailRowHeight, estimated: false };\n }\n return { height: DEFAULT_DETAIL_ROW_HEIGHT, estimated: false };\n }\n var rowHeight = this.gridOptions.rowHeight && this.isNumeric(this.gridOptions.rowHeight) ? this.gridOptions.rowHeight : defaultRowHeight;\n return { height: rowHeight, estimated: false };\n };\n GridOptionsWrapper.prototype.isDynamicRowHeight = function () {\n return typeof this.gridOptions.getRowHeight === 'function';\n };\n GridOptionsWrapper.prototype.getListItemHeight = function () {\n return this.getFromTheme(20, 'listItemHeight');\n };\n GridOptionsWrapper.prototype.chartMenuPanelWidth = function () {\n return this.environment.chartMenuPanelWidth();\n };\n GridOptionsWrapper.prototype.isNumeric = function (value) {\n return !isNaN(value) && typeof value === 'number' && isFinite(value);\n };\n GridOptionsWrapper.prototype.getFromTheme = function (defaultValue, sassVariableName) {\n var theme = this.environment.getTheme().theme;\n if (theme && theme.indexOf('ag-theme') === 0) {\n return this.environment.getSassVariable(theme, sassVariableName);\n }\n return defaultValue;\n };\n GridOptionsWrapper.prototype.getDefaultRowHeight = function () {\n return this.getFromTheme(DEFAULT_ROW_HEIGHT, 'rowHeight');\n };\n GridOptionsWrapper.prototype.matchesGroupDisplayType = function (toMatch, supplied) {\n var groupDisplayTypeValues = ['groupRows', 'multipleColumns', 'custom', 'singleColumn'];\n if (groupDisplayTypeValues.indexOf(supplied) < 0) {\n console.warn(\"AG Grid: '\" + supplied + \"' is not a valid groupDisplayType value - possible values are: '\" + groupDisplayTypeValues.join(\"', '\") + \"'\");\n return false;\n }\n return supplied === toMatch;\n };\n GridOptionsWrapper.prototype.matchesTreeDataDisplayType = function (toMatch, supplied) {\n var treeDataDisplayTypeValues = ['auto', 'custom'];\n if (treeDataDisplayTypeValues.indexOf(supplied) < 0) {\n console.warn(\"AG Grid: '\" + supplied + \"' is not a valid treeDataDisplayType value - possible values are: '\" + treeDataDisplayTypeValues.join(\"', '\") + \"'\");\n return false;\n }\n return supplied === toMatch;\n };\n var GridOptionsWrapper_1;\n GridOptionsWrapper.MIN_COL_WIDTH = 10;\n GridOptionsWrapper.PROP_HEADER_HEIGHT = 'headerHeight';\n GridOptionsWrapper.PROP_GROUP_REMOVE_SINGLE_CHILDREN = 'groupRemoveSingleChildren';\n GridOptionsWrapper.PROP_GROUP_REMOVE_LOWEST_SINGLE_CHILDREN = 'groupRemoveLowestSingleChildren';\n GridOptionsWrapper.PROP_GROUP_DISPLAY_TYPE = 'groupDisplayType';\n GridOptionsWrapper.PROP_PIVOT_HEADER_HEIGHT = 'pivotHeaderHeight';\n GridOptionsWrapper.PROP_SUPPRESS_CLIPBOARD_PASTE = 'suppressClipboardPaste';\n GridOptionsWrapper.PROP_GROUP_HEADER_HEIGHT = 'groupHeaderHeight';\n GridOptionsWrapper.PROP_PIVOT_GROUP_HEADER_HEIGHT = 'pivotGroupHeaderHeight';\n GridOptionsWrapper.PROP_NAVIGATE_TO_NEXT_CELL = 'navigateToNextCell';\n GridOptionsWrapper.PROP_TAB_TO_NEXT_CELL = 'tabToNextCell';\n GridOptionsWrapper.PROP_NAVIGATE_TO_NEXT_HEADER = 'navigateToNextHeader';\n GridOptionsWrapper.PROP_TAB_TO_NEXT_HEADER = 'tabToNextHeader';\n GridOptionsWrapper.PROP_IS_EXTERNAL_FILTER_PRESENT = 'isExternalFilterPresent';\n GridOptionsWrapper.PROP_DOES_EXTERNAL_FILTER_PASS = 'doesExternalFilterPass';\n GridOptionsWrapper.PROP_FLOATING_FILTERS_HEIGHT = 'floatingFiltersHeight';\n GridOptionsWrapper.PROP_SUPPRESS_ROW_CLICK_SELECTION = 'suppressRowClickSelection';\n GridOptionsWrapper.PROP_SUPPRESS_ROW_DRAG = 'suppressRowDrag';\n GridOptionsWrapper.PROP_SUPPRESS_MOVE_WHEN_ROW_DRAG = 'suppressMoveWhenRowDragging';\n GridOptionsWrapper.PROP_GET_ROW_CLASS = 'getRowClass';\n GridOptionsWrapper.PROP_GET_ROW_STYLE = 'getRowStyle';\n GridOptionsWrapper.PROP_GET_ROW_HEIGHT = 'getRowHeight';\n GridOptionsWrapper.PROP_POPUP_PARENT = 'popupParent';\n GridOptionsWrapper.PROP_DOM_LAYOUT = 'domLayout';\n GridOptionsWrapper.PROP_ROW_CLASS = 'rowClass';\n GridOptionsWrapper.PROP_FILL_HANDLE_DIRECTION = 'fillHandleDirection';\n GridOptionsWrapper.PROP_GROUP_ROW_AGG_NODES = 'groupRowAggNodes';\n GridOptionsWrapper.PROP_GET_GROUP_ROW_AGG = 'getGroupRowAgg';\n GridOptionsWrapper.PROP_GET_BUSINESS_KEY_FOR_NODE = 'getBusinessKeyForNode';\n GridOptionsWrapper.PROP_GET_CHILD_COUNT = 'getChildCount';\n GridOptionsWrapper.PROP_PROCESS_ROW_POST_CREATE = 'processRowPostCreate';\n GridOptionsWrapper.PROP_GET_ROW_NODE_ID = 'getRowNodeId';\n GridOptionsWrapper.PROP_GET_ROW_ID = 'getRowId';\n GridOptionsWrapper.PROP_IS_FULL_WIDTH_CELL = 'isFullWidthCell';\n GridOptionsWrapper.PROP_IS_FULL_WIDTH_ROW = 'isFullWidthRow';\n GridOptionsWrapper.PROP_IS_ROW_SELECTABLE = 'isRowSelectable';\n GridOptionsWrapper.PROP_IS_ROW_MASTER = 'isRowMaster';\n GridOptionsWrapper.PROP_POST_SORT = 'postSort';\n GridOptionsWrapper.PROP_POST_SORT_ROWS = 'postSortRows';\n GridOptionsWrapper.PROP_GET_DOCUMENT = 'getDocument';\n GridOptionsWrapper.PROP_POST_PROCESS_POPUP = 'postProcessPopup';\n GridOptionsWrapper.PROP_DEFAULT_GROUP_ORDER_COMPARATOR = 'defaultGroupOrderComparator';\n GridOptionsWrapper.PROP_INITIAL_GROUP_ORDER_COMPARATOR = 'initialGroupOrderComparator';\n GridOptionsWrapper.PROP_PAGINATION_NUMBER_FORMATTER = 'paginationNumberFormatter';\n GridOptionsWrapper.PROP_GET_CONTEXT_MENU_ITEMS = 'getContextMenuItems';\n GridOptionsWrapper.PROP_GET_MAIN_MENU_ITEMS = 'getMainMenuItems';\n GridOptionsWrapper.PROP_PROCESS_CELL_FOR_CLIPBOARD = 'processCellForClipboard';\n GridOptionsWrapper.PROP_PROCESS_CELL_FROM_CLIPBOARD = 'processCellFromClipboard';\n GridOptionsWrapper.PROP_SEND_TO_CLIPBOARD = 'sendToClipboard';\n GridOptionsWrapper.PROP_PROCESS_PIVOT_RESULT_COL_DEF = 'processPivotResultColDef';\n GridOptionsWrapper.PROP_PROCESS_PIVOT_RESULT_COL_GROUP_DEF = 'processPivotResultColGroupDef';\n GridOptionsWrapper.PROP_GET_CHART_TOOLBAR_ITEMS = 'getChartToolbarItems';\n GridOptionsWrapper.PROP_GET_SERVER_SIDE_GROUP_PARAMS = 'getServerSideGroupLevelParams';\n GridOptionsWrapper.PROP_IS_SERVER_SIDE_GROUPS_OPEN_BY_DEFAULT = 'isServerSideGroupOpenByDefault';\n GridOptionsWrapper.PROP_IS_APPLY_SERVER_SIDE_TRANSACTION = 'isApplyServerSideTransaction';\n GridOptionsWrapper.PROP_IS_SERVER_SIDE_GROUP = 'isServerSideGroup';\n GridOptionsWrapper.PROP_GET_SERVER_SIDE_GROUP_KEY = 'getServerSideGroupKey';\n GridOptionsWrapper.PROP_AUTO_GROUP_COLUMN_DEF = 'autoGroupColumnDef';\n GridOptionsWrapper.PROP_DEFAULT_COL_DEF = 'defaultColDef';\n __decorate([\n Autowired('gridOptions')\n ], GridOptionsWrapper.prototype, \"gridOptions\", void 0);\n __decorate([\n Autowired('eventService')\n ], GridOptionsWrapper.prototype, \"eventService\", void 0);\n __decorate([\n Autowired('environment')\n ], GridOptionsWrapper.prototype, \"environment\", void 0);\n __decorate([\n Autowired('eGridDiv')\n ], GridOptionsWrapper.prototype, \"eGridDiv\", void 0);\n __decorate([\n __param(0, Qualifier('gridApi')), __param(1, Qualifier('columnApi'))\n ], GridOptionsWrapper.prototype, \"agWire\", null);\n __decorate([\n PreDestroy\n ], GridOptionsWrapper.prototype, \"destroy\", null);\n __decorate([\n PostConstruct\n ], GridOptionsWrapper.prototype, \"init\", null);\n GridOptionsWrapper = GridOptionsWrapper_1 = __decorate([\n Bean('gridOptionsWrapper')\n ], GridOptionsWrapper);\n return GridOptionsWrapper;\n}());\nexport { GridOptionsWrapper };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n};\nvar __rest = (this && this.__rest) || function (s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n t[p[i]] = s[p[i]];\n }\n return t;\n};\nvar __values = (this && this.__values) || function(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nimport { ColumnGroup } from '../entities/columnGroup';\nimport { Column } from '../entities/column';\nimport { Events } from '../events';\nimport { BeanStub } from \"../context/beanStub\";\nimport { ProvidedColumnGroup } from '../entities/providedColumnGroup';\nimport { GroupInstanceIdCreator } from './groupInstanceIdCreator';\nimport { Autowired, Bean, Optional, PostConstruct, Qualifier } from '../context/context';\nimport { Constants } from '../constants/constants';\nimport { areEqual, last, removeFromArray, moveInArray, includes, insertIntoArray, removeAllFromArray } from '../utils/array';\nimport { missingOrEmpty, exists, missing, attrToBoolean, attrToNumber } from '../utils/generic';\nimport { camelCaseToHumanText } from '../utils/string';\nimport { convertToMap } from '../utils/map';\nimport { doOnce } from '../utils/function';\nimport { GridOptionsWrapper } from '../gridOptionsWrapper';\nvar ColumnModel = /** @class */ (function (_super) {\n __extends(ColumnModel, _super);\n function ColumnModel() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n // header row count, based on user provided columns\n _this.primaryHeaderRowCount = 0;\n _this.secondaryHeaderRowCount = 0;\n // header row count, either above, or based on pivoting if we are pivoting\n _this.gridHeaderRowCount = 0;\n // leave level columns of the displayed trees\n _this.displayedColumnsLeft = [];\n _this.displayedColumnsRight = [];\n _this.displayedColumnsCenter = [];\n // all three lists above combined\n _this.displayedColumns = [];\n // for fast lookup, to see if a column or group is still displayed\n _this.displayedColumnsAndGroupsMap = {};\n // all columns to be rendered\n _this.viewportColumns = [];\n // same as viewportColumns, except we always include columns with headerAutoHeight\n _this.headerViewportColumns = [];\n // all columns to be rendered in the centre\n _this.viewportColumnsCenter = [];\n // same as viewportColumnsCenter, except we always include columns with headerAutoHeight\n _this.headerViewportColumnsCenter = [];\n _this.autoHeightActiveAtLeastOnce = false;\n _this.rowGroupColumns = [];\n _this.valueColumns = [];\n _this.pivotColumns = [];\n _this.ready = false;\n _this.autoGroupsNeedBuilding = false;\n _this.forceRecreateAutoGroups = false;\n _this.pivotMode = false;\n _this.bodyWidth = 0;\n _this.leftWidth = 0;\n _this.rightWidth = 0;\n _this.bodyWidthDirty = true;\n _this.flexColsCalculatedAtLestOnce = false;\n return _this;\n }\n ColumnModel.prototype.init = function () {\n var _this = this;\n this.suppressColumnVirtualisation = this.gridOptionsWrapper.isSuppressColumnVirtualisation();\n var pivotMode = this.gridOptionsWrapper.isPivotMode();\n if (this.isPivotSettingAllowed(pivotMode)) {\n this.pivotMode = pivotMode;\n }\n this.usingTreeData = this.gridOptionsWrapper.isTreeData();\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_GROUP_DISPLAY_TYPE, function () { return _this.onAutoGroupColumnDefChanged(); });\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_AUTO_GROUP_COLUMN_DEF, function () { return _this.onAutoGroupColumnDefChanged(); });\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_DEFAULT_COL_DEF, function () { return _this.onDefaultColDefChanged(); });\n };\n ColumnModel.prototype.onAutoGroupColumnDefChanged = function () {\n this.autoGroupsNeedBuilding = true;\n this.forceRecreateAutoGroups = true;\n this.updateGridColumns();\n this.updateDisplayedColumns('gridOptionsChanged');\n };\n ColumnModel.prototype.onDefaultColDefChanged = function () {\n // likewise for autoGroupCol, the default col def impacts this\n this.forceRecreateAutoGroups = true;\n this.createColumnsFromColumnDefs(true);\n };\n ColumnModel.prototype.setColumnDefs = function (columnDefs, source) {\n if (source === void 0) { source = 'api'; }\n var colsPreviouslyExisted = !!this.columnDefs;\n this.columnDefs = columnDefs;\n this.createColumnsFromColumnDefs(colsPreviouslyExisted, source);\n };\n ColumnModel.prototype.createColumnsFromColumnDefs = function (colsPreviouslyExisted, source) {\n var _this = this;\n if (source === void 0) { source = 'api'; }\n // only need to raise before/after events if updating columns, never if setting columns for first time\n var raiseEventsFunc = colsPreviouslyExisted ? this.compareColumnStatesAndRaiseEvents(source) : undefined;\n // always invalidate cache on changing columns, as the column id's for the new columns\n // could overlap with the old id's, so the cache would return old values for new columns.\n this.valueCache.expire();\n // NOTE ==================\n // we should be destroying the existing columns and groups if they exist, for example, the original column\n // group adds a listener to the columns, it should be also removing the listeners\n this.autoGroupsNeedBuilding = true;\n var oldPrimaryColumns = this.primaryColumns;\n var oldPrimaryTree = this.primaryColumnTree;\n var balancedTreeResult = this.columnFactory.createColumnTree(this.columnDefs, true, oldPrimaryTree);\n this.primaryColumnTree = balancedTreeResult.columnTree;\n this.primaryHeaderRowCount = balancedTreeResult.treeDept + 1;\n this.primaryColumns = this.getColumnsFromTree(this.primaryColumnTree);\n this.primaryColumnsMap = {};\n this.primaryColumns.forEach(function (col) { return _this.primaryColumnsMap[col.getId()] = col; });\n this.extractRowGroupColumns(source, oldPrimaryColumns);\n this.extractPivotColumns(source, oldPrimaryColumns);\n this.extractValueColumns(source, oldPrimaryColumns);\n this.ready = true;\n // if we are showing secondary columns, then no need to update grid columns\n // at this point, as it's the pivot service responsibility to change these\n // if we are no longer pivoting (ie and need to revert back to primary, otherwise\n // we shouldn't be touching the primary).\n var gridColsNotProcessed = this.gridColsArePrimary === undefined;\n var processGridCols = this.gridColsArePrimary || gridColsNotProcessed;\n if (processGridCols) {\n this.updateGridColumns();\n if (colsPreviouslyExisted && !this.gridOptionsWrapper.isMaintainColumnOrder()) {\n this.orderGridColumnsLikePrimary();\n }\n this.updateDisplayedColumns(source);\n this.checkViewportColumns();\n }\n // this event is not used by AG Grid, but left here for backwards compatibility,\n // in case applications use it\n this.dispatchEverythingChanged(source);\n if (raiseEventsFunc) {\n raiseEventsFunc();\n }\n this.dispatchNewColumnsLoaded();\n };\n ColumnModel.prototype.dispatchNewColumnsLoaded = function () {\n var newColumnsLoadedEvent = {\n type: Events.EVENT_NEW_COLUMNS_LOADED\n };\n this.eventService.dispatchEvent(newColumnsLoadedEvent);\n };\n // this event is legacy, no grid code listens to it. instead the grid listens to New Columns Loaded\n ColumnModel.prototype.dispatchEverythingChanged = function (source) {\n if (source === void 0) { source = 'api'; }\n var eventEverythingChanged = {\n type: Events.EVENT_COLUMN_EVERYTHING_CHANGED,\n source: source\n };\n this.eventService.dispatchEvent(eventEverythingChanged);\n };\n ColumnModel.prototype.orderGridColumnsLikePrimary = function () {\n var _this = this;\n var primaryColumns = this.primaryColumns;\n if (!primaryColumns) {\n return;\n }\n this.gridColumns.sort(function (colA, colB) {\n var primaryIndexA = primaryColumns.indexOf(colA);\n var primaryIndexB = primaryColumns.indexOf(colB);\n // if both cols are present in primary, then we just return the position,\n // so position is maintained.\n var indexAPresent = primaryIndexA >= 0;\n var indexBPresent = primaryIndexB >= 0;\n if (indexAPresent && indexBPresent) {\n return primaryIndexA - primaryIndexB;\n }\n if (indexAPresent) {\n // B is auto group column, so put B first\n return 1;\n }\n if (indexBPresent) {\n // A is auto group column, so put A first\n return -1;\n }\n // otherwise both A and B are auto-group columns. so we just keep the order\n // as they were already in.\n var gridIndexA = _this.gridColumns.indexOf(colA);\n var gridIndexB = _this.gridColumns.indexOf(colB);\n return gridIndexA - gridIndexB;\n });\n this.gridColumns = this.placeLockedColumns(this.gridColumns);\n };\n ColumnModel.prototype.getAllDisplayedAutoHeightCols = function () {\n return this.displayedAutoHeightCols;\n };\n ColumnModel.prototype.setViewport = function () {\n if (this.gridOptionsWrapper.isEnableRtl()) {\n this.viewportLeft = this.bodyWidth - this.scrollPosition - this.scrollWidth;\n this.viewportRight = this.bodyWidth - this.scrollPosition;\n }\n else {\n this.viewportLeft = this.scrollPosition;\n this.viewportRight = this.scrollWidth + this.scrollPosition;\n }\n };\n // used by clipboard service, to know what columns to paste into\n ColumnModel.prototype.getDisplayedColumnsStartingAt = function (column) {\n var currentColumn = column;\n var columns = [];\n while (currentColumn != null) {\n columns.push(currentColumn);\n currentColumn = this.getDisplayedColAfter(currentColumn);\n }\n return columns;\n };\n // checks what columns are currently displayed due to column virtualisation. fires an event\n // if the list of columns has changed.\n // + setColumnWidth(), setViewportPosition(), setColumnDefs(), sizeColumnsToFit()\n ColumnModel.prototype.checkViewportColumns = function () {\n // check displayCenterColumnTree exists first, as it won't exist when grid is initialising\n if (this.displayedColumnsCenter == null) {\n return;\n }\n var viewportColumnsChanged = this.extractViewport();\n if (!viewportColumnsChanged) {\n return;\n }\n var event = {\n type: Events.EVENT_VIRTUAL_COLUMNS_CHANGED\n };\n this.eventService.dispatchEvent(event);\n };\n ColumnModel.prototype.setViewportPosition = function (scrollWidth, scrollPosition) {\n if (scrollWidth !== this.scrollWidth || scrollPosition !== this.scrollPosition || this.bodyWidthDirty) {\n this.scrollWidth = scrollWidth;\n this.scrollPosition = scrollPosition;\n // we need to call setVirtualViewportLeftAndRight() at least once after the body width changes,\n // as the viewport can stay the same, but in RTL, if body width changes, we need to work out the\n // virtual columns again\n this.bodyWidthDirty = true;\n this.setViewport();\n if (this.ready) {\n this.checkViewportColumns();\n }\n }\n };\n ColumnModel.prototype.isPivotMode = function () {\n return this.pivotMode;\n };\n ColumnModel.prototype.isPivotSettingAllowed = function (pivot) {\n if (pivot && this.gridOptionsWrapper.isTreeData()) {\n console.warn(\"AG Grid: Pivot mode not available in conjunction Tree Data i.e. 'gridOptions.treeData: true'\");\n return false;\n }\n return true;\n };\n ColumnModel.prototype.setPivotMode = function (pivotMode, source) {\n if (source === void 0) { source = 'api'; }\n if (pivotMode === this.pivotMode || !this.isPivotSettingAllowed(this.pivotMode)) {\n return;\n }\n this.pivotMode = pivotMode;\n // we need to update grid columns to cover the scenario where user has groupSuppressAutoColumn=true, as\n // this means we don't use auto group column UNLESS we are in pivot mode (it's mandatory in pivot mode),\n // so need to updateGridColumn() to check it autoGroupCol needs to be added / removed\n this.autoGroupsNeedBuilding = true;\n this.updateGridColumns();\n this.updateDisplayedColumns(source);\n var event = {\n type: Events.EVENT_COLUMN_PIVOT_MODE_CHANGED\n };\n this.eventService.dispatchEvent(event);\n };\n ColumnModel.prototype.getSecondaryPivotColumn = function (pivotKeys, valueColKey) {\n if (missing(this.secondaryColumns)) {\n return null;\n }\n var valueColumnToFind = this.getPrimaryColumn(valueColKey);\n var foundColumn = null;\n this.secondaryColumns.forEach(function (column) {\n var thisPivotKeys = column.getColDef().pivotKeys;\n var pivotValueColumn = column.getColDef().pivotValueColumn;\n var pivotKeyMatches = areEqual(thisPivotKeys, pivotKeys);\n var pivotValueMatches = pivotValueColumn === valueColumnToFind;\n if (pivotKeyMatches && pivotValueMatches) {\n foundColumn = column;\n }\n });\n return foundColumn;\n };\n ColumnModel.prototype.setBeans = function (loggerFactory) {\n this.logger = loggerFactory.create('columnModel');\n };\n ColumnModel.prototype.setFirstRightAndLastLeftPinned = function (source) {\n var lastLeft;\n var firstRight;\n if (this.gridOptionsWrapper.isEnableRtl()) {\n lastLeft = this.displayedColumnsLeft ? this.displayedColumnsLeft[0] : null;\n firstRight = this.displayedColumnsRight ? last(this.displayedColumnsRight) : null;\n }\n else {\n lastLeft = this.displayedColumnsLeft ? last(this.displayedColumnsLeft) : null;\n firstRight = this.displayedColumnsRight ? this.displayedColumnsRight[0] : null;\n }\n this.gridColumns.forEach(function (column) {\n column.setLastLeftPinned(column === lastLeft, source);\n column.setFirstRightPinned(column === firstRight, source);\n });\n };\n ColumnModel.prototype.autoSizeColumns = function (params) {\n var _this = this;\n var columns = params.columns, skipHeader = params.skipHeader, skipHeaderGroups = params.skipHeaderGroups, stopAtGroup = params.stopAtGroup, _a = params.source, source = _a === void 0 ? 'api' : _a;\n // because of column virtualisation, we can only do this function on columns that are\n // actually rendered, as non-rendered columns (outside the viewport and not rendered\n // due to column virtualisation) are not present. this can result in all rendered columns\n // getting narrowed, which in turn introduces more rendered columns on the RHS which\n // did not get autosized in the original run, leaving the visible grid with columns on\n // the LHS sized, but RHS no. so we keep looping through the visible columns until\n // no more cols are available (rendered) to be resized\n // we autosize after animation frames finish in case any cell renderers need to complete first. this can\n // happen eg if client code is calling api.autoSizeAllColumns() straight after grid is initialised, but grid\n // hasn't fully drawn out all the cells yet (due to cell renderers in animation frames).\n this.animationFrameService.flushAllFrames();\n // keep track of which cols we have resized in here\n var columnsAutosized = [];\n // initialise with anything except 0 so that while loop executes at least once\n var changesThisTimeAround = -1;\n var shouldSkipHeader = skipHeader != null ? skipHeader : this.gridOptionsWrapper.isSkipHeaderOnAutoSize();\n var shouldSkipHeaderGroups = skipHeaderGroups != null ? skipHeaderGroups : shouldSkipHeader;\n while (changesThisTimeAround !== 0) {\n changesThisTimeAround = 0;\n this.actionOnGridColumns(columns, function (column) {\n // if already autosized, skip it\n if (columnsAutosized.indexOf(column) >= 0) {\n return false;\n }\n // get how wide this col should be\n var preferredWidth = _this.autoWidthCalculator.getPreferredWidthForColumn(column, shouldSkipHeader);\n // preferredWidth = -1 if this col is not on the screen\n if (preferredWidth > 0) {\n var newWidth = _this.normaliseColumnWidth(column, preferredWidth);\n column.setActualWidth(newWidth, source);\n columnsAutosized.push(column);\n changesThisTimeAround++;\n }\n return true;\n }, source);\n }\n if (!shouldSkipHeaderGroups) {\n this.autoSizeColumnGroupsByColumns(columns, stopAtGroup);\n }\n this.fireColumnResizedEvent(columnsAutosized, true, 'autosizeColumns');\n };\n ColumnModel.prototype.fireColumnResizedEvent = function (columns, finished, source, flexColumns) {\n if (flexColumns === void 0) { flexColumns = null; }\n if (columns && columns.length) {\n var event_1 = {\n type: Events.EVENT_COLUMN_RESIZED,\n columns: columns,\n column: columns.length === 1 ? columns[0] : null,\n flexColumns: flexColumns,\n finished: finished,\n source: source\n };\n this.eventService.dispatchEvent(event_1);\n }\n };\n ColumnModel.prototype.autoSizeColumn = function (key, skipHeader, source) {\n if (source === void 0) { source = \"api\"; }\n if (key) {\n this.autoSizeColumns({ columns: [key], skipHeader: skipHeader, skipHeaderGroups: true, source: source });\n }\n };\n ColumnModel.prototype.autoSizeColumnGroupsByColumns = function (keys, stopAtGroup) {\n var e_1, _a, e_2, _b;\n var columnGroups = new Set();\n var columns = this.getGridColumns(keys);\n columns.forEach(function (col) {\n var parent = col.getParent();\n while (parent && parent != stopAtGroup) {\n if (!parent.isPadding()) {\n columnGroups.add(parent);\n }\n parent = parent.getParent();\n }\n });\n var headerGroupCtrl;\n var resizedColumns = [];\n try {\n for (var columnGroups_1 = __values(columnGroups), columnGroups_1_1 = columnGroups_1.next(); !columnGroups_1_1.done; columnGroups_1_1 = columnGroups_1.next()) {\n var columnGroup = columnGroups_1_1.value;\n try {\n for (var _c = (e_2 = void 0, __values(this.ctrlsService.getHeaderRowContainerCtrls())), _d = _c.next(); !_d.done; _d = _c.next()) {\n var headerContainerCtrl = _d.value;\n headerGroupCtrl = headerContainerCtrl.getHeaderCtrlForColumn(columnGroup);\n if (headerGroupCtrl) {\n break;\n }\n }\n }\n catch (e_2_1) { e_2 = { error: e_2_1 }; }\n finally {\n try {\n if (_d && !_d.done && (_b = _c.return)) _b.call(_c);\n }\n finally { if (e_2) throw e_2.error; }\n }\n if (headerGroupCtrl) {\n headerGroupCtrl.resizeLeafColumnsToFit();\n }\n }\n }\n catch (e_1_1) { e_1 = { error: e_1_1 }; }\n finally {\n try {\n if (columnGroups_1_1 && !columnGroups_1_1.done && (_a = columnGroups_1.return)) _a.call(columnGroups_1);\n }\n finally { if (e_1) throw e_1.error; }\n }\n return resizedColumns;\n };\n ColumnModel.prototype.autoSizeAllColumns = function (skipHeader, source) {\n if (source === void 0) { source = \"api\"; }\n var allDisplayedColumns = this.getAllDisplayedColumns();\n this.autoSizeColumns({ columns: allDisplayedColumns, skipHeader: skipHeader, source: source });\n };\n // Possible candidate for reuse (alot of recursive traversal duplication)\n ColumnModel.prototype.getColumnsFromTree = function (rootColumns) {\n var result = [];\n var recursiveFindColumns = function (childColumns) {\n for (var i = 0; i < childColumns.length; i++) {\n var child = childColumns[i];\n if (child instanceof Column) {\n result.push(child);\n }\n else if (child instanceof ProvidedColumnGroup) {\n recursiveFindColumns(child.getChildren());\n }\n }\n };\n recursiveFindColumns(rootColumns);\n return result;\n };\n ColumnModel.prototype.getAllDisplayedTrees = function () {\n if (this.displayedTreeLeft && this.displayedTreeRight && this.displayedTreeCentre) {\n return this.displayedTreeLeft\n .concat(this.displayedTreeCentre)\n .concat(this.displayedTreeRight);\n }\n return null;\n };\n // + columnSelectPanel\n ColumnModel.prototype.getPrimaryColumnTree = function () {\n return this.primaryColumnTree;\n };\n // + gridPanel -> for resizing the body and setting top margin\n ColumnModel.prototype.getHeaderRowCount = function () {\n return this.gridHeaderRowCount;\n };\n // + headerRenderer -> setting pinned body width\n ColumnModel.prototype.getDisplayedTreeLeft = function () {\n return this.displayedTreeLeft;\n };\n // + headerRenderer -> setting pinned body width\n ColumnModel.prototype.getDisplayedTreeRight = function () {\n return this.displayedTreeRight;\n };\n // + headerRenderer -> setting pinned body width\n ColumnModel.prototype.getDisplayedTreeCentre = function () {\n return this.displayedTreeCentre;\n };\n // gridPanel -> ensureColumnVisible\n ColumnModel.prototype.isColumnDisplayed = function (column) {\n return this.getAllDisplayedColumns().indexOf(column) >= 0;\n };\n // + csvCreator\n ColumnModel.prototype.getAllDisplayedColumns = function () {\n return this.displayedColumns;\n };\n ColumnModel.prototype.getViewportColumns = function () {\n return this.viewportColumns;\n };\n ColumnModel.prototype.getDisplayedLeftColumnsForRow = function (rowNode) {\n if (!this.colSpanActive) {\n return this.displayedColumnsLeft;\n }\n return this.getDisplayedColumnsForRow(rowNode, this.displayedColumnsLeft);\n };\n ColumnModel.prototype.getDisplayedRightColumnsForRow = function (rowNode) {\n if (!this.colSpanActive) {\n return this.displayedColumnsRight;\n }\n return this.getDisplayedColumnsForRow(rowNode, this.displayedColumnsRight);\n };\n ColumnModel.prototype.getDisplayedColumnsForRow = function (rowNode, displayedColumns, filterCallback, emptySpaceBeforeColumn) {\n var result = [];\n var lastConsideredCol = null;\n var _loop_1 = function (i) {\n var col = displayedColumns[i];\n var maxAllowedColSpan = displayedColumns.length - i;\n var colSpan = Math.min(col.getColSpan(rowNode), maxAllowedColSpan);\n var columnsToCheckFilter = [col];\n if (colSpan > 1) {\n var colsToRemove = colSpan - 1;\n for (var j = 1; j <= colsToRemove; j++) {\n columnsToCheckFilter.push(displayedColumns[i + j]);\n }\n i += colsToRemove;\n }\n // see which cols we should take out for column virtualisation\n var filterPasses;\n if (filterCallback) {\n // if user provided a callback, means some columns may not be in the viewport.\n // the user will NOT provide a callback if we are talking about pinned areas,\n // as pinned areas have no horizontal scroll and do not virtualise the columns.\n // if lots of columns, that means column spanning, and we set filterPasses = true\n // if one or more of the columns spanned pass the filter.\n filterPasses = false;\n columnsToCheckFilter.forEach(function (colForFilter) {\n if (filterCallback(colForFilter)) {\n filterPasses = true;\n }\n });\n }\n else {\n filterPasses = true;\n }\n if (filterPasses) {\n if (result.length === 0 && lastConsideredCol) {\n var gapBeforeColumn = emptySpaceBeforeColumn ? emptySpaceBeforeColumn(col) : false;\n if (gapBeforeColumn) {\n result.push(lastConsideredCol);\n }\n }\n result.push(col);\n }\n lastConsideredCol = col;\n out_i_1 = i;\n };\n var out_i_1;\n for (var i = 0; i < displayedColumns.length; i++) {\n _loop_1(i);\n i = out_i_1;\n }\n return result;\n };\n // + rowRenderer\n // if we are not column spanning, this just returns back the virtual centre columns,\n // however if we are column spanning, then different rows can have different virtual\n // columns, so we have to work out the list for each individual row.\n ColumnModel.prototype.getViewportCenterColumnsForRow = function (rowNode) {\n var _this = this;\n if (!this.colSpanActive) {\n return this.viewportColumnsCenter;\n }\n var emptySpaceBeforeColumn = function (col) {\n var left = col.getLeft();\n return exists(left) && left > _this.viewportLeft;\n };\n // if doing column virtualisation, then we filter based on the viewport.\n var filterCallback = this.suppressColumnVirtualisation ? null : this.isColumnInRowViewport.bind(this);\n return this.getDisplayedColumnsForRow(rowNode, this.displayedColumnsCenter, filterCallback, emptySpaceBeforeColumn);\n };\n ColumnModel.prototype.getAriaColumnIndex = function (col) {\n return this.getAllGridColumns().indexOf(col) + 1;\n };\n ColumnModel.prototype.isColumnInHeaderViewport = function (col) {\n // for headers, we never filter out autoHeaderHeight columns, if calculating \n if (col.isAutoHeaderHeight()) {\n return true;\n }\n return this.isColumnInRowViewport(col);\n };\n ColumnModel.prototype.isColumnInRowViewport = function (col) {\n // we never filter out autoHeight columns, as we need them in the DOM for calculating Auto Height\n if (col.isAutoHeight()) {\n return true;\n }\n var columnLeft = col.getLeft() || 0;\n var columnRight = columnLeft + col.getActualWidth();\n // adding 200 for buffer size, so some cols off viewport are rendered.\n // this helps horizontal scrolling so user rarely sees white space (unless\n // they scroll horizontally fast). however we are conservative, as the more\n // buffer the slower the vertical redraw speed\n var leftBounds = this.viewportLeft - 200;\n var rightBounds = this.viewportRight + 200;\n var columnToMuchLeft = columnLeft < leftBounds && columnRight < leftBounds;\n var columnToMuchRight = columnLeft > rightBounds && columnRight > rightBounds;\n return !columnToMuchLeft && !columnToMuchRight;\n };\n // used by:\n // + angularGrid -> setting pinned body width\n // note: this should be cached\n ColumnModel.prototype.getDisplayedColumnsLeftWidth = function () {\n return this.getWidthOfColsInList(this.displayedColumnsLeft);\n };\n // note: this should be cached\n ColumnModel.prototype.getDisplayedColumnsRightWidth = function () {\n return this.getWidthOfColsInList(this.displayedColumnsRight);\n };\n ColumnModel.prototype.updatePrimaryColumnList = function (keys, masterList, actionIsAdd, columnCallback, eventType, source) {\n var _this = this;\n if (source === void 0) { source = \"api\"; }\n if (!keys || missingOrEmpty(keys)) {\n return;\n }\n var atLeastOne = false;\n keys.forEach(function (key) {\n var columnToAdd = _this.getPrimaryColumn(key);\n if (!columnToAdd) {\n return;\n }\n if (actionIsAdd) {\n if (masterList.indexOf(columnToAdd) >= 0) {\n return;\n }\n masterList.push(columnToAdd);\n }\n else {\n if (masterList.indexOf(columnToAdd) < 0) {\n return;\n }\n removeFromArray(masterList, columnToAdd);\n }\n columnCallback(columnToAdd);\n atLeastOne = true;\n });\n if (!atLeastOne) {\n return;\n }\n if (this.autoGroupsNeedBuilding) {\n this.updateGridColumns();\n }\n this.updateDisplayedColumns(source);\n var event = {\n type: eventType,\n columns: masterList,\n column: masterList.length === 1 ? masterList[0] : null,\n source: source\n };\n this.eventService.dispatchEvent(event);\n };\n ColumnModel.prototype.setRowGroupColumns = function (colKeys, source) {\n if (source === void 0) { source = \"api\"; }\n this.autoGroupsNeedBuilding = true;\n this.setPrimaryColumnList(colKeys, this.rowGroupColumns, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, this.setRowGroupActive.bind(this), source);\n };\n ColumnModel.prototype.setRowGroupActive = function (active, column, source) {\n if (active === column.isRowGroupActive()) {\n return;\n }\n column.setRowGroupActive(active, source);\n if (active && !this.gridOptionsWrapper.isSuppressRowGroupHidesColumns()) {\n this.setColumnVisible(column, false, source);\n }\n if (!active && !this.gridOptionsWrapper.isSuppressMakeColumnVisibleAfterUnGroup()) {\n this.setColumnVisible(column, true, source);\n }\n };\n ColumnModel.prototype.addRowGroupColumn = function (key, source) {\n if (source === void 0) { source = \"api\"; }\n if (key) {\n this.addRowGroupColumns([key], source);\n }\n };\n ColumnModel.prototype.addRowGroupColumns = function (keys, source) {\n if (source === void 0) { source = \"api\"; }\n this.autoGroupsNeedBuilding = true;\n this.updatePrimaryColumnList(keys, this.rowGroupColumns, true, this.setRowGroupActive.bind(this, true), Events.EVENT_COLUMN_ROW_GROUP_CHANGED, source);\n };\n ColumnModel.prototype.removeRowGroupColumns = function (keys, source) {\n if (source === void 0) { source = \"api\"; }\n this.autoGroupsNeedBuilding = true;\n this.updatePrimaryColumnList(keys, this.rowGroupColumns, false, this.setRowGroupActive.bind(this, false), Events.EVENT_COLUMN_ROW_GROUP_CHANGED, source);\n };\n ColumnModel.prototype.removeRowGroupColumn = function (key, source) {\n if (source === void 0) { source = \"api\"; }\n if (key) {\n this.removeRowGroupColumns([key], source);\n }\n };\n ColumnModel.prototype.addPivotColumns = function (keys, source) {\n if (source === void 0) { source = \"api\"; }\n this.updatePrimaryColumnList(keys, this.pivotColumns, true, function (column) { return column.setPivotActive(true, source); }, Events.EVENT_COLUMN_PIVOT_CHANGED, source);\n };\n ColumnModel.prototype.setPivotColumns = function (colKeys, source) {\n if (source === void 0) { source = \"api\"; }\n this.setPrimaryColumnList(colKeys, this.pivotColumns, Events.EVENT_COLUMN_PIVOT_CHANGED, function (added, column) {\n column.setPivotActive(added, source);\n }, source);\n };\n ColumnModel.prototype.addPivotColumn = function (key, source) {\n if (source === void 0) { source = \"api\"; }\n this.addPivotColumns([key], source);\n };\n ColumnModel.prototype.removePivotColumns = function (keys, source) {\n if (source === void 0) { source = \"api\"; }\n this.updatePrimaryColumnList(keys, this.pivotColumns, false, function (column) { return column.setPivotActive(false, source); }, Events.EVENT_COLUMN_PIVOT_CHANGED, source);\n };\n ColumnModel.prototype.removePivotColumn = function (key, source) {\n if (source === void 0) { source = \"api\"; }\n this.removePivotColumns([key], source);\n };\n ColumnModel.prototype.setPrimaryColumnList = function (colKeys, masterList, eventName, columnCallback, source) {\n var _this = this;\n masterList.length = 0;\n if (exists(colKeys)) {\n colKeys.forEach(function (key) {\n var column = _this.getPrimaryColumn(key);\n if (column) {\n masterList.push(column);\n }\n });\n }\n (this.primaryColumns || []).forEach(function (column) {\n var added = masterList.indexOf(column) >= 0;\n columnCallback(added, column);\n });\n if (this.autoGroupsNeedBuilding) {\n this.updateGridColumns();\n }\n this.updateDisplayedColumns(source);\n this.fireColumnEvent(eventName, masterList, source);\n };\n ColumnModel.prototype.setValueColumns = function (colKeys, source) {\n if (source === void 0) { source = \"api\"; }\n this.setPrimaryColumnList(colKeys, this.valueColumns, Events.EVENT_COLUMN_VALUE_CHANGED, this.setValueActive.bind(this), source);\n };\n ColumnModel.prototype.setValueActive = function (active, column, source) {\n if (active === column.isValueActive()) {\n return;\n }\n column.setValueActive(active, source);\n if (active && !column.getAggFunc()) {\n var initialAggFunc = this.aggFuncService.getDefaultAggFunc(column);\n column.setAggFunc(initialAggFunc);\n }\n };\n ColumnModel.prototype.addValueColumns = function (keys, source) {\n if (source === void 0) { source = \"api\"; }\n this.updatePrimaryColumnList(keys, this.valueColumns, true, this.setValueActive.bind(this, true), Events.EVENT_COLUMN_VALUE_CHANGED, source);\n };\n ColumnModel.prototype.addValueColumn = function (colKey, source) {\n if (source === void 0) { source = \"api\"; }\n if (colKey) {\n this.addValueColumns([colKey], source);\n }\n };\n ColumnModel.prototype.removeValueColumn = function (colKey, source) {\n if (source === void 0) { source = \"api\"; }\n this.removeValueColumns([colKey], source);\n };\n ColumnModel.prototype.removeValueColumns = function (keys, source) {\n if (source === void 0) { source = \"api\"; }\n this.updatePrimaryColumnList(keys, this.valueColumns, false, this.setValueActive.bind(this, false), Events.EVENT_COLUMN_VALUE_CHANGED, source);\n };\n // returns the width we can set to this col, taking into consideration min and max widths\n ColumnModel.prototype.normaliseColumnWidth = function (column, newWidth) {\n var minWidth = column.getMinWidth();\n if (exists(minWidth) && newWidth < minWidth) {\n newWidth = minWidth;\n }\n var maxWidth = column.getMaxWidth();\n if (exists(maxWidth) && column.isGreaterThanMax(newWidth)) {\n newWidth = maxWidth;\n }\n return newWidth;\n };\n ColumnModel.prototype.getPrimaryOrGridColumn = function (key) {\n var column = this.getPrimaryColumn(key);\n return column || this.getGridColumn(key);\n };\n ColumnModel.prototype.setColumnWidths = function (columnWidths, shiftKey, // @takeFromAdjacent - if user has 'shift' pressed, then pixels are taken from adjacent column\n finished, // @finished - ends up in the event, tells the user if more events are to come\n source) {\n var _this = this;\n if (source === void 0) { source = \"api\"; }\n var sets = [];\n columnWidths.forEach(function (columnWidth) {\n var col = _this.getPrimaryOrGridColumn(columnWidth.key);\n if (!col) {\n return;\n }\n sets.push({\n width: columnWidth.newWidth,\n ratios: [1],\n columns: [col]\n });\n // if user wants to do shift resize by default, then we invert the shift operation\n var defaultIsShift = _this.gridOptionsWrapper.getColResizeDefault() === 'shift';\n if (defaultIsShift) {\n shiftKey = !shiftKey;\n }\n if (shiftKey) {\n var otherCol = _this.getDisplayedColAfter(col);\n if (!otherCol) {\n return;\n }\n var widthDiff = col.getActualWidth() - columnWidth.newWidth;\n var otherColWidth = otherCol.getActualWidth() + widthDiff;\n sets.push({\n width: otherColWidth,\n ratios: [1],\n columns: [otherCol]\n });\n }\n });\n if (sets.length === 0) {\n return;\n }\n this.resizeColumnSets({\n resizeSets: sets,\n finished: finished,\n source: source\n });\n };\n ColumnModel.prototype.checkMinAndMaxWidthsForSet = function (columnResizeSet) {\n var columns = columnResizeSet.columns, width = columnResizeSet.width;\n // every col has a min width, so sum them all up and see if we have enough room\n // for all the min widths\n var minWidthAccumulated = 0;\n var maxWidthAccumulated = 0;\n var maxWidthActive = true;\n columns.forEach(function (col) {\n var minWidth = col.getMinWidth();\n minWidthAccumulated += minWidth || 0;\n var maxWidth = col.getMaxWidth();\n if (exists(maxWidth) && maxWidth > 0) {\n maxWidthAccumulated += maxWidth;\n }\n else {\n // if at least one columns has no max width, it means the group of columns\n // then has no max width, as at least one column can take as much width as possible\n maxWidthActive = false;\n }\n });\n var minWidthPasses = width >= minWidthAccumulated;\n var maxWidthPasses = !maxWidthActive || (width <= maxWidthAccumulated);\n return minWidthPasses && maxWidthPasses;\n };\n // method takes sets of columns and resizes them. either all sets will be resized, or nothing\n // be resized. this is used for example when user tries to resize a group and holds shift key,\n // then both the current group (grows), and the adjacent group (shrinks), will get resized,\n // so that's two sets for this method.\n ColumnModel.prototype.resizeColumnSets = function (params) {\n var _this = this;\n var resizeSets = params.resizeSets, finished = params.finished, source = params.source;\n var passMinMaxCheck = !resizeSets || resizeSets.every(function (columnResizeSet) { return _this.checkMinAndMaxWidthsForSet(columnResizeSet); });\n if (!passMinMaxCheck) {\n // even though we are not going to resize beyond min/max size, we still need to raise event when finished\n if (finished) {\n var columns = resizeSets && resizeSets.length > 0 ? resizeSets[0].columns : null;\n this.fireColumnResizedEvent(columns, finished, source);\n }\n return; // don't resize!\n }\n var changedCols = [];\n var allResizedCols = [];\n resizeSets.forEach(function (set) {\n var width = set.width, columns = set.columns, ratios = set.ratios;\n // keep track of pixels used, and last column gets the remaining,\n // to cater for rounding errors, and min width adjustments\n var newWidths = {};\n var finishedCols = {};\n columns.forEach(function (col) { return allResizedCols.push(col); });\n // the loop below goes through each col. if a col exceeds it's min/max width,\n // it then gets set to its min/max width and the column is removed marked as 'finished'\n // and the calculation is done again leaving this column out. take for example columns\n // {A, width: 50, maxWidth: 100}\n // {B, width: 50}\n // {C, width: 50}\n // and then the set is set to width 600 - on the first pass the grid tries to set each column\n // to 200. it checks A and sees 200 > 100 and so sets the width to 100. col A is then marked\n // as 'finished' and the calculation is done again with the remaining cols B and C, which end up\n // splitting the remaining 500 pixels.\n var finishedColsGrew = true;\n var loopCount = 0;\n var _loop_2 = function () {\n loopCount++;\n if (loopCount > 1000) {\n // this should never happen, but in the future, someone might introduce a bug here,\n // so we stop the browser from hanging and report bug properly\n console.error('AG Grid: infinite loop in resizeColumnSets');\n return \"break\";\n }\n finishedColsGrew = false;\n var subsetCols = [];\n var subsetRatioTotal = 0;\n var pixelsToDistribute = width;\n columns.forEach(function (col, index) {\n var thisColFinished = finishedCols[col.getId()];\n if (thisColFinished) {\n pixelsToDistribute -= newWidths[col.getId()];\n }\n else {\n subsetCols.push(col);\n var ratioThisCol = ratios[index];\n subsetRatioTotal += ratioThisCol;\n }\n });\n // because we are not using all of the ratios (cols can be missing),\n // we scale the ratio. if all columns are included, then subsetRatioTotal=1,\n // and so the ratioScale will be 1.\n var ratioScale = 1 / subsetRatioTotal;\n subsetCols.forEach(function (col, index) {\n var lastCol = index === (subsetCols.length - 1);\n var colNewWidth;\n if (lastCol) {\n colNewWidth = pixelsToDistribute;\n }\n else {\n colNewWidth = Math.round(ratios[index] * width * ratioScale);\n pixelsToDistribute -= colNewWidth;\n }\n var minWidth = col.getMinWidth();\n var maxWidth = col.getMaxWidth();\n if (exists(minWidth) && colNewWidth < minWidth) {\n colNewWidth = minWidth;\n finishedCols[col.getId()] = true;\n finishedColsGrew = true;\n }\n else if (exists(maxWidth) && maxWidth > 0 && colNewWidth > maxWidth) {\n colNewWidth = maxWidth;\n finishedCols[col.getId()] = true;\n finishedColsGrew = true;\n }\n newWidths[col.getId()] = colNewWidth;\n });\n };\n while (finishedColsGrew) {\n var state_1 = _loop_2();\n if (state_1 === \"break\")\n break;\n }\n columns.forEach(function (col) {\n var newWidth = newWidths[col.getId()];\n var actualWidth = col.getActualWidth();\n if (actualWidth !== newWidth) {\n col.setActualWidth(newWidth, source);\n changedCols.push(col);\n }\n });\n });\n // if no cols changed, then no need to update more or send event.\n var atLeastOneColChanged = changedCols.length > 0;\n var flexedCols = [];\n if (atLeastOneColChanged) {\n flexedCols = this.refreshFlexedColumns({ resizingCols: allResizedCols, skipSetLeft: true });\n this.setLeftValues(source);\n this.updateBodyWidths();\n this.checkViewportColumns();\n }\n // check for change first, to avoid unnecessary firing of events\n // however we always fire 'finished' events. this is important\n // when groups are resized, as if the group is changing slowly,\n // eg 1 pixel at a time, then each change will fire change events\n // in all the columns in the group, but only one with get the pixel.\n var colsForEvent = allResizedCols.concat(flexedCols);\n if (atLeastOneColChanged || finished) {\n this.fireColumnResizedEvent(colsForEvent, finished, source, flexedCols);\n }\n };\n ColumnModel.prototype.setColumnAggFunc = function (key, aggFunc, source) {\n if (source === void 0) { source = \"api\"; }\n if (!key) {\n return;\n }\n var column = this.getPrimaryColumn(key);\n if (!column) {\n return;\n }\n column.setAggFunc(aggFunc);\n this.fireColumnEvent(Events.EVENT_COLUMN_VALUE_CHANGED, [column], source);\n };\n ColumnModel.prototype.fireColumnEvent = function (type, columns, source) {\n var event = {\n type: type,\n columns: columns,\n column: (columns && columns.length == 1) ? columns[0] : null,\n source: source\n };\n this.eventService.dispatchEvent(event);\n };\n ColumnModel.prototype.moveRowGroupColumn = function (fromIndex, toIndex, source) {\n if (source === void 0) { source = \"api\"; }\n var column = this.rowGroupColumns[fromIndex];\n this.rowGroupColumns.splice(fromIndex, 1);\n this.rowGroupColumns.splice(toIndex, 0, column);\n var event = {\n type: Events.EVENT_COLUMN_ROW_GROUP_CHANGED,\n columns: this.rowGroupColumns,\n column: this.rowGroupColumns.length === 1 ? this.rowGroupColumns[0] : null,\n source: source\n };\n this.eventService.dispatchEvent(event);\n };\n ColumnModel.prototype.moveColumns = function (columnsToMoveKeys, toIndex, source) {\n if (source === void 0) { source = \"api\"; }\n this.columnAnimationService.start();\n if (toIndex > this.gridColumns.length - columnsToMoveKeys.length) {\n console.warn('AG Grid: tried to insert columns in invalid location, toIndex = ' + toIndex);\n console.warn('AG Grid: remember that you should not count the moving columns when calculating the new index');\n return;\n }\n // we want to pull all the columns out first and put them into an ordered list\n var columnsToMove = this.getGridColumns(columnsToMoveKeys);\n var failedRules = !this.doesMovePassRules(columnsToMove, toIndex);\n if (failedRules) {\n return;\n }\n moveInArray(this.gridColumns, columnsToMove, toIndex);\n this.updateDisplayedColumns(source);\n var event = {\n type: Events.EVENT_COLUMN_MOVED,\n columns: columnsToMove,\n column: columnsToMove.length === 1 ? columnsToMove[0] : null,\n toIndex: toIndex,\n source: source\n };\n this.eventService.dispatchEvent(event);\n this.columnAnimationService.finish();\n };\n ColumnModel.prototype.doesMovePassRules = function (columnsToMove, toIndex) {\n // make a copy of what the grid columns would look like after the move\n var proposedColumnOrder = this.getProposedColumnOrder(columnsToMove, toIndex);\n return this.doesOrderPassRules(proposedColumnOrder);\n };\n ColumnModel.prototype.doesOrderPassRules = function (gridOrder) {\n if (!this.doesMovePassMarryChildren(gridOrder)) {\n return false;\n }\n if (!this.doesMovePassLockedPositions(gridOrder)) {\n return false;\n }\n return true;\n };\n ColumnModel.prototype.getProposedColumnOrder = function (columnsToMove, toIndex) {\n var proposedColumnOrder = this.gridColumns.slice();\n moveInArray(proposedColumnOrder, columnsToMove, toIndex);\n return proposedColumnOrder;\n };\n // returns the provided cols sorted in same order as they appear in grid columns. eg if grid columns\n // contains [a,b,c,d,e] and col passed is [e,a] then the passed cols are sorted into [a,e]\n ColumnModel.prototype.sortColumnsLikeGridColumns = function (cols) {\n var _this = this;\n if (!cols || cols.length <= 1) {\n return;\n }\n var notAllColsInGridColumns = cols.filter(function (c) { return _this.gridColumns.indexOf(c) < 0; }).length > 0;\n if (notAllColsInGridColumns) {\n return;\n }\n cols.sort(function (a, b) {\n var indexA = _this.gridColumns.indexOf(a);\n var indexB = _this.gridColumns.indexOf(b);\n return indexA - indexB;\n });\n };\n ColumnModel.prototype.doesMovePassLockedPositions = function (proposedColumnOrder) {\n // Placement is a number indicating 'left' 'center' or 'right' as 0 1 2\n var lastPlacement = 0;\n var rulePassed = true;\n var lockPositionToPlacement = function (position) {\n if (!position) { // false or undefined\n return 1;\n }\n if (position === true) {\n return 0;\n }\n return position === 'left' ? 0 : 2; // Otherwise 'right'\n };\n proposedColumnOrder.forEach(function (col) {\n var placement = lockPositionToPlacement(col.getColDef().lockPosition);\n if (placement < lastPlacement) { // If placement goes down, we're not in the correct order\n rulePassed = false;\n }\n lastPlacement = placement;\n });\n return rulePassed;\n };\n ColumnModel.prototype.doesMovePassMarryChildren = function (allColumnsCopy) {\n var rulePassed = true;\n this.columnUtils.depthFirstOriginalTreeSearch(null, this.gridBalancedTree, function (child) {\n if (!(child instanceof ProvidedColumnGroup)) {\n return;\n }\n var columnGroup = child;\n var colGroupDef = columnGroup.getColGroupDef();\n var marryChildren = colGroupDef && colGroupDef.marryChildren;\n if (!marryChildren) {\n return;\n }\n var newIndexes = [];\n columnGroup.getLeafColumns().forEach(function (col) {\n var newColIndex = allColumnsCopy.indexOf(col);\n newIndexes.push(newColIndex);\n });\n var maxIndex = Math.max.apply(Math, newIndexes);\n var minIndex = Math.min.apply(Math, newIndexes);\n // spread is how far the first column in this group is away from the last column\n var spread = maxIndex - minIndex;\n var maxSpread = columnGroup.getLeafColumns().length - 1;\n // if the columns\n if (spread > maxSpread) {\n rulePassed = false;\n }\n // console.log(`maxIndex = ${maxIndex}, minIndex = ${minIndex}, spread = ${spread}, maxSpread = ${maxSpread}, fail = ${spread > (count-1)}`)\n // console.log(allColumnsCopy.map( col => col.getColDef().field).join(','));\n });\n return rulePassed;\n };\n ColumnModel.prototype.moveColumn = function (key, toIndex, source) {\n if (source === void 0) { source = \"api\"; }\n this.moveColumns([key], toIndex, source);\n };\n ColumnModel.prototype.moveColumnByIndex = function (fromIndex, toIndex, source) {\n if (source === void 0) { source = \"api\"; }\n var column = this.gridColumns[fromIndex];\n this.moveColumn(column, toIndex, source);\n };\n ColumnModel.prototype.getColumnDefs = function () {\n var _this = this;\n if (!this.primaryColumns) {\n return;\n }\n var cols = this.primaryColumns.slice();\n if (this.gridColsArePrimary) {\n cols.sort(function (a, b) { return _this.gridColumns.indexOf(a) - _this.gridColumns.indexOf(b); });\n }\n else if (this.lastPrimaryOrder) {\n cols.sort(function (a, b) { return _this.lastPrimaryOrder.indexOf(a) - _this.lastPrimaryOrder.indexOf(b); });\n }\n return this.columnDefFactory.buildColumnDefs(cols, this.rowGroupColumns, this.pivotColumns);\n };\n // used by:\n // + angularGrid -> for setting body width\n // + rowController -> setting main row widths (when inserting and resizing)\n // need to cache this\n ColumnModel.prototype.getBodyContainerWidth = function () {\n return this.bodyWidth;\n };\n ColumnModel.prototype.getContainerWidth = function (pinned) {\n switch (pinned) {\n case Constants.PINNED_LEFT:\n return this.leftWidth;\n case Constants.PINNED_RIGHT:\n return this.rightWidth;\n default:\n return this.bodyWidth;\n }\n };\n // after setColumnWidth or updateGroupsAndDisplayedColumns\n ColumnModel.prototype.updateBodyWidths = function () {\n var newBodyWidth = this.getWidthOfColsInList(this.displayedColumnsCenter);\n var newLeftWidth = this.getWidthOfColsInList(this.displayedColumnsLeft);\n var newRightWidth = this.getWidthOfColsInList(this.displayedColumnsRight);\n // this is used by virtual col calculation, for RTL only, as a change to body width can impact displayed\n // columns, due to RTL inverting the y coordinates\n this.bodyWidthDirty = this.bodyWidth !== newBodyWidth;\n var atLeastOneChanged = this.bodyWidth !== newBodyWidth || this.leftWidth !== newLeftWidth || this.rightWidth !== newRightWidth;\n if (atLeastOneChanged) {\n this.bodyWidth = newBodyWidth;\n this.leftWidth = newLeftWidth;\n this.rightWidth = newRightWidth;\n // when this fires, it is picked up by the gridPanel, which ends up in\n // gridPanel calling setWidthAndScrollPosition(), which in turn calls setViewportPosition()\n var event_2 = {\n type: Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED,\n };\n this.eventService.dispatchEvent(event_2);\n }\n };\n // + rowController\n ColumnModel.prototype.getValueColumns = function () {\n return this.valueColumns ? this.valueColumns : [];\n };\n // + rowController\n ColumnModel.prototype.getPivotColumns = function () {\n return this.pivotColumns ? this.pivotColumns : [];\n };\n // + clientSideRowModel\n ColumnModel.prototype.isPivotActive = function () {\n return this.pivotColumns && this.pivotColumns.length > 0 && this.pivotMode;\n };\n // + toolPanel\n ColumnModel.prototype.getRowGroupColumns = function () {\n return this.rowGroupColumns ? this.rowGroupColumns : [];\n };\n // + rowController -> while inserting rows\n ColumnModel.prototype.getDisplayedCenterColumns = function () {\n return this.displayedColumnsCenter;\n };\n // + rowController -> while inserting rows\n ColumnModel.prototype.getDisplayedLeftColumns = function () {\n return this.displayedColumnsLeft;\n };\n ColumnModel.prototype.getDisplayedRightColumns = function () {\n return this.displayedColumnsRight;\n };\n ColumnModel.prototype.getDisplayedColumns = function (type) {\n switch (type) {\n case Constants.PINNED_LEFT:\n return this.getDisplayedLeftColumns();\n case Constants.PINNED_RIGHT:\n return this.getDisplayedRightColumns();\n default:\n return this.getDisplayedCenterColumns();\n }\n };\n // used by:\n // + clientSideRowController -> sorting, building quick filter text\n // + headerRenderer -> sorting (clearing icon)\n ColumnModel.prototype.getAllPrimaryColumns = function () {\n return this.primaryColumns ? this.primaryColumns.slice() : null;\n };\n ColumnModel.prototype.getSecondaryColumns = function () {\n return this.secondaryColumns ? this.secondaryColumns.slice() : null;\n };\n ColumnModel.prototype.getAllColumnsForQuickFilter = function () {\n return this.columnsForQuickFilter;\n };\n // + moveColumnController\n ColumnModel.prototype.getAllGridColumns = function () {\n return this.gridColumns;\n };\n ColumnModel.prototype.isEmpty = function () {\n return missingOrEmpty(this.gridColumns);\n };\n ColumnModel.prototype.isRowGroupEmpty = function () {\n return missingOrEmpty(this.rowGroupColumns);\n };\n ColumnModel.prototype.setColumnVisible = function (key, visible, source) {\n if (source === void 0) { source = \"api\"; }\n this.setColumnsVisible([key], visible, source);\n };\n ColumnModel.prototype.setColumnsVisible = function (keys, visible, source) {\n if (visible === void 0) { visible = false; }\n if (source === void 0) { source = \"api\"; }\n this.applyColumnState({\n state: keys.map(function (key) { return ({\n colId: typeof key === 'string' ? key : key.getColId(),\n hide: !visible,\n }); }),\n });\n };\n ColumnModel.prototype.setColumnPinned = function (key, pinned, source) {\n if (source === void 0) { source = \"api\"; }\n if (key) {\n this.setColumnsPinned([key], pinned, source);\n }\n };\n ColumnModel.prototype.setColumnsPinned = function (keys, pinned, source) {\n if (source === void 0) { source = \"api\"; }\n if (this.gridOptionsWrapper.getDomLayout() === 'print') {\n console.warn(\"Changing the column pinning status is not allowed with domLayout='print'\");\n return;\n }\n this.columnAnimationService.start();\n var actualPinned;\n if (pinned === true || pinned === Constants.PINNED_LEFT) {\n actualPinned = Constants.PINNED_LEFT;\n }\n else if (pinned === Constants.PINNED_RIGHT) {\n actualPinned = Constants.PINNED_RIGHT;\n }\n else {\n actualPinned = null;\n }\n this.actionOnGridColumns(keys, function (col) {\n if (col.getPinned() !== actualPinned) {\n col.setPinned(actualPinned);\n return true;\n }\n return false;\n }, source, function () {\n var event = {\n type: Events.EVENT_COLUMN_PINNED,\n pinned: actualPinned,\n column: null,\n columns: null,\n source: source\n };\n return event;\n });\n this.columnAnimationService.finish();\n };\n // does an action on a set of columns. provides common functionality for looking up the\n // columns based on key, getting a list of effected columns, and then updated the event\n // with either one column (if it was just one col) or a list of columns\n // used by: autoResize, setVisible, setPinned\n ColumnModel.prototype.actionOnGridColumns = function (// the column keys this action will be on\n keys, \n // the action to do - if this returns false, the column was skipped\n // and won't be included in the event\n action, \n // should return back a column event of the right type\n source, createEvent) {\n var _this = this;\n if (missingOrEmpty(keys)) {\n return;\n }\n var updatedColumns = [];\n keys.forEach(function (key) {\n var column = _this.getGridColumn(key);\n if (!column) {\n return;\n }\n // need to check for false with type (ie !== instead of !=)\n // as not returning anything (undefined) would also be false\n var resultOfAction = action(column);\n if (resultOfAction !== false) {\n updatedColumns.push(column);\n }\n });\n if (!updatedColumns.length) {\n return;\n }\n this.updateDisplayedColumns(source);\n if (exists(createEvent) && createEvent) {\n var event_3 = createEvent();\n event_3.columns = updatedColumns;\n event_3.column = updatedColumns.length === 1 ? updatedColumns[0] : null;\n this.eventService.dispatchEvent(event_3);\n }\n };\n ColumnModel.prototype.getDisplayedColBefore = function (col) {\n var allDisplayedColumns = this.getAllDisplayedColumns();\n var oldIndex = allDisplayedColumns.indexOf(col);\n if (oldIndex > 0) {\n return allDisplayedColumns[oldIndex - 1];\n }\n return null;\n };\n // used by:\n // + rowRenderer -> for navigation\n ColumnModel.prototype.getDisplayedColAfter = function (col) {\n var allDisplayedColumns = this.getAllDisplayedColumns();\n var oldIndex = allDisplayedColumns.indexOf(col);\n if (oldIndex < (allDisplayedColumns.length - 1)) {\n return allDisplayedColumns[oldIndex + 1];\n }\n return null;\n };\n ColumnModel.prototype.getDisplayedGroupAfter = function (columnGroup) {\n return this.getDisplayedGroupAtDirection(columnGroup, 'After');\n };\n ColumnModel.prototype.getDisplayedGroupBefore = function (columnGroup) {\n return this.getDisplayedGroupAtDirection(columnGroup, 'Before');\n };\n ColumnModel.prototype.getDisplayedGroupAtDirection = function (columnGroup, direction) {\n // pick the last displayed column in this group\n var requiredLevel = columnGroup.getProvidedColumnGroup().getLevel() + columnGroup.getPaddingLevel();\n var colGroupLeafColumns = columnGroup.getDisplayedLeafColumns();\n var col = direction === 'After' ? last(colGroupLeafColumns) : colGroupLeafColumns[0];\n var getDisplayColMethod = \"getDisplayedCol\" + direction;\n while (true) {\n // keep moving to the next col, until we get to another group\n var column = this[getDisplayColMethod](col);\n if (!column) {\n return null;\n }\n var groupPointer = this.getColumnGroupAtLevel(column, requiredLevel);\n if (groupPointer !== columnGroup) {\n return groupPointer;\n }\n }\n };\n ColumnModel.prototype.getColumnGroupAtLevel = function (column, level) {\n // get group at same level as the one we are looking for\n var groupPointer = column.getParent();\n var originalGroupLevel;\n var groupPointerLevel;\n while (true) {\n var groupPointerProvidedColumnGroup = groupPointer.getProvidedColumnGroup();\n originalGroupLevel = groupPointerProvidedColumnGroup.getLevel();\n groupPointerLevel = groupPointer.getPaddingLevel();\n if (originalGroupLevel + groupPointerLevel <= level) {\n break;\n }\n groupPointer = groupPointer.getParent();\n }\n return groupPointer;\n };\n ColumnModel.prototype.isPinningLeft = function () {\n return this.displayedColumnsLeft.length > 0;\n };\n ColumnModel.prototype.isPinningRight = function () {\n return this.displayedColumnsRight.length > 0;\n };\n ColumnModel.prototype.getPrimaryAndSecondaryAndAutoColumns = function () {\n var _a;\n return (_a = []).concat.apply(_a, __spread([\n this.primaryColumns || [],\n this.groupAutoColumns || [],\n this.secondaryColumns || [],\n ]));\n };\n ColumnModel.prototype.getPrimaryAndAutoGroupCols = function () {\n var _a;\n return (_a = []).concat.apply(_a, __spread([\n this.primaryColumns || [],\n this.groupAutoColumns || [],\n ]));\n };\n ColumnModel.prototype.getPrimaryAndSecondaryColumns = function () {\n var _a;\n return (_a = []).concat.apply(_a, __spread([\n this.primaryColumns || [],\n this.secondaryColumns || [],\n ]));\n };\n ColumnModel.prototype.createStateItemFromColumn = function (column) {\n var rowGroupIndex = column.isRowGroupActive() ? this.rowGroupColumns.indexOf(column) : null;\n var pivotIndex = column.isPivotActive() ? this.pivotColumns.indexOf(column) : null;\n var aggFunc = column.isValueActive() ? column.getAggFunc() : null;\n var sort = column.getSort() != null ? column.getSort() : null;\n var sortIndex = column.getSortIndex() != null ? column.getSortIndex() : null;\n var flex = column.getFlex() != null && column.getFlex() > 0 ? column.getFlex() : null;\n var res = {\n colId: column.getColId(),\n width: column.getActualWidth(),\n hide: !column.isVisible(),\n pinned: column.getPinned(),\n sort: sort,\n sortIndex: sortIndex,\n aggFunc: aggFunc,\n rowGroup: column.isRowGroupActive(),\n rowGroupIndex: rowGroupIndex,\n pivot: column.isPivotActive(),\n pivotIndex: pivotIndex,\n flex: flex\n };\n return res;\n };\n ColumnModel.prototype.getColumnState = function () {\n if (missing(this.primaryColumns) || !this.isAlive()) {\n return [];\n }\n var colsForState = this.getPrimaryAndSecondaryAndAutoColumns();\n var res = colsForState.map(this.createStateItemFromColumn.bind(this));\n this.orderColumnStateList(res);\n return res;\n };\n ColumnModel.prototype.orderColumnStateList = function (columnStateList) {\n // for fast looking, store the index of each column\n var colIdToGridIndexMap = convertToMap(this.gridColumns.map(function (col, index) { return [col.getColId(), index]; }));\n columnStateList.sort(function (itemA, itemB) {\n var posA = colIdToGridIndexMap.has(itemA.colId) ? colIdToGridIndexMap.get(itemA.colId) : -1;\n var posB = colIdToGridIndexMap.has(itemB.colId) ? colIdToGridIndexMap.get(itemB.colId) : -1;\n return posA - posB;\n });\n };\n ColumnModel.prototype.resetColumnState = function (source) {\n // NOTE = there is one bug here that no customer has noticed - if a column has colDef.lockPosition,\n // this is ignored below when ordering the cols. to work, we should always put lockPosition cols first.\n // As a work around, developers should just put lockPosition columns first in their colDef list.\n if (source === void 0) { source = \"api\"; }\n // we can't use 'allColumns' as the order might of messed up, so get the primary ordered list\n var primaryColumns = this.getColumnsFromTree(this.primaryColumnTree);\n var columnStates = [];\n // we start at 1000, so if user has mix of rowGroup and group specified, it will work with both.\n // eg IF user has ColA.rowGroupIndex=0, ColB.rowGroupIndex=1, ColC.rowGroup=true,\n // THEN result will be ColA.rowGroupIndex=0, ColB.rowGroupIndex=1, ColC.rowGroup=1000\n var letRowGroupIndex = 1000;\n var letPivotIndex = 1000;\n var colsToProcess = [];\n if (this.groupAutoColumns) {\n colsToProcess = colsToProcess.concat(this.groupAutoColumns);\n }\n if (primaryColumns) {\n colsToProcess = colsToProcess.concat(primaryColumns);\n }\n colsToProcess.forEach(function (column) {\n var getValueOrNull = function (a, b) { return a != null ? a : b != null ? b : null; };\n var colDef = column.getColDef();\n var sort = getValueOrNull(colDef.sort, colDef.initialSort);\n var sortIndex = getValueOrNull(colDef.sortIndex, colDef.initialSortIndex);\n var hide = getValueOrNull(colDef.hide, colDef.initialHide);\n var pinned = getValueOrNull(colDef.pinned, colDef.initialPinned);\n var width = getValueOrNull(colDef.width, colDef.initialWidth);\n var flex = getValueOrNull(colDef.flex, colDef.initialFlex);\n var rowGroupIndex = getValueOrNull(colDef.rowGroupIndex, colDef.initialRowGroupIndex);\n var rowGroup = getValueOrNull(colDef.rowGroup, colDef.initialRowGroup);\n if (rowGroupIndex == null && (rowGroup == null || rowGroup == false)) {\n rowGroupIndex = null;\n rowGroup = null;\n }\n var pivotIndex = getValueOrNull(colDef.pivotIndex, colDef.initialPivotIndex);\n var pivot = getValueOrNull(colDef.pivot, colDef.initialPivot);\n if (pivotIndex == null && (pivot == null || pivot == false)) {\n pivotIndex = null;\n pivot = null;\n }\n var aggFunc = getValueOrNull(colDef.aggFunc, colDef.initialAggFunc);\n var stateItem = {\n colId: column.getColId(),\n sort: sort,\n sortIndex: sortIndex,\n hide: hide,\n pinned: pinned,\n width: width,\n flex: flex,\n rowGroup: rowGroup,\n rowGroupIndex: rowGroupIndex,\n pivot: pivot,\n pivotIndex: pivotIndex,\n aggFunc: aggFunc,\n };\n if (missing(rowGroupIndex) && rowGroup) {\n stateItem.rowGroupIndex = letRowGroupIndex++;\n }\n if (missing(pivotIndex) && pivot) {\n stateItem.pivotIndex = letPivotIndex++;\n }\n columnStates.push(stateItem);\n });\n this.applyColumnState({ state: columnStates, applyOrder: true }, source);\n };\n ColumnModel.prototype.applyColumnState = function (params, source) {\n var _this = this;\n if (source === void 0) { source = \"api\"; }\n if (missingOrEmpty(this.primaryColumns)) {\n return false;\n }\n if (params && params.state && !params.state.forEach) {\n console.warn('AG Grid: applyColumnState() - the state attribute should be an array, however an array was not found. Please provide an array of items (one for each col you want to change) for state.');\n return false;\n }\n var applyStates = function (states, existingColumns, getById) {\n var raiseEventsFunc = _this.compareColumnStatesAndRaiseEvents(source);\n _this.autoGroupsNeedBuilding = true;\n // at the end below, this list will have all columns we got no state for\n var columnsWithNoState = existingColumns.slice();\n var rowGroupIndexes = {};\n var pivotIndexes = {};\n var autoGroupColumnStates = [];\n // If pivoting is modified, these are the states we try to reapply after\n // the secondary columns are re-generated\n var unmatchedAndAutoStates = [];\n var unmatchedCount = 0;\n var previousRowGroupCols = _this.rowGroupColumns.slice();\n var previousPivotCols = _this.pivotColumns.slice();\n states.forEach(function (state) {\n var colId = state.colId || '';\n // auto group columns are re-created so deferring syncing with ColumnState\n var isAutoGroupColumn = colId.startsWith(Constants.GROUP_AUTO_COLUMN_ID);\n if (isAutoGroupColumn) {\n autoGroupColumnStates.push(state);\n unmatchedAndAutoStates.push(state);\n return;\n }\n var column = getById(colId);\n if (!column) {\n unmatchedAndAutoStates.push(state);\n unmatchedCount += 1;\n }\n else {\n _this.syncColumnWithStateItem(column, state, params.defaultState, rowGroupIndexes, pivotIndexes, false, source);\n removeFromArray(columnsWithNoState, column);\n }\n });\n // anything left over, we got no data for, so add in the column as non-value, non-rowGroup and hidden\n var applyDefaultsFunc = function (col) {\n return _this.syncColumnWithStateItem(col, null, params.defaultState, rowGroupIndexes, pivotIndexes, false, source);\n };\n columnsWithNoState.forEach(applyDefaultsFunc);\n // sort the lists according to the indexes that were provided\n var comparator = function (indexes, oldList, colA, colB) {\n var indexA = indexes[colA.getId()];\n var indexB = indexes[colB.getId()];\n var aHasIndex = indexA != null;\n var bHasIndex = indexB != null;\n if (aHasIndex && bHasIndex) {\n // both a and b are new cols with index, so sort on index\n return indexA - indexB;\n }\n if (aHasIndex) {\n // a has an index, so it should be before a\n return -1;\n }\n if (bHasIndex) {\n // b has an index, so it should be before a\n return 1;\n }\n var oldIndexA = oldList.indexOf(colA);\n var oldIndexB = oldList.indexOf(colB);\n var aHasOldIndex = oldIndexA >= 0;\n var bHasOldIndex = oldIndexB >= 0;\n if (aHasOldIndex && bHasOldIndex) {\n // both a and b are old cols, so sort based on last order\n return oldIndexA - oldIndexB;\n }\n if (aHasOldIndex) {\n // a is old, b is new, so b is first\n return -1;\n }\n // this bit does matter, means both are new cols\n // but without index or that b is old and a is new\n return 1;\n };\n _this.rowGroupColumns.sort(comparator.bind(_this, rowGroupIndexes, previousRowGroupCols));\n _this.pivotColumns.sort(comparator.bind(_this, pivotIndexes, previousPivotCols));\n _this.updateGridColumns();\n // sync newly created auto group columns with ColumnState\n var autoGroupColsCopy = _this.groupAutoColumns ? _this.groupAutoColumns.slice() : [];\n autoGroupColumnStates.forEach(function (stateItem) {\n var autoCol = _this.getAutoColumn(stateItem.colId);\n removeFromArray(autoGroupColsCopy, autoCol);\n _this.syncColumnWithStateItem(autoCol, stateItem, params.defaultState, null, null, true, source);\n });\n // autogroup cols with nothing else, apply the default\n autoGroupColsCopy.forEach(applyDefaultsFunc);\n _this.applyOrderAfterApplyState(params);\n _this.updateDisplayedColumns(source);\n _this.dispatchEverythingChanged(source);\n raiseEventsFunc(); // Will trigger secondary column changes if pivoting modified\n return { unmatchedAndAutoStates: unmatchedAndAutoStates, unmatchedCount: unmatchedCount };\n };\n this.columnAnimationService.start();\n var _a = applyStates(params.state || [], this.primaryColumns || [], function (id) { return _this.getPrimaryColumn(id); }), unmatchedAndAutoStates = _a.unmatchedAndAutoStates, unmatchedCount = _a.unmatchedCount;\n // If there are still states left over, see if we can apply them to newly generated\n // secondary or auto columns. Also if defaults exist, ensure they are applied to secondary cols\n if (unmatchedAndAutoStates.length > 0 || exists(params.defaultState)) {\n unmatchedCount = applyStates(unmatchedAndAutoStates, this.secondaryColumns || [], function (id) { return _this.getSecondaryColumn(id); }).unmatchedCount;\n }\n this.columnAnimationService.finish();\n return unmatchedCount === 0; // Successful if no states unaccounted for\n };\n ColumnModel.prototype.applyOrderAfterApplyState = function (params) {\n var _this = this;\n if (!params.applyOrder || !params.state) {\n return;\n }\n var newOrder = [];\n var processedColIds = {};\n params.state.forEach(function (item) {\n if (!item.colId || processedColIds[item.colId]) {\n return;\n }\n var col = _this.gridColumnsMap[item.colId];\n if (col) {\n newOrder.push(col);\n processedColIds[item.colId] = true;\n }\n });\n // add in all other columns\n var autoGroupInsertIndex = 0;\n this.gridColumns.forEach(function (col) {\n var colId = col.getColId();\n var alreadyProcessed = processedColIds[colId] != null;\n if (alreadyProcessed) {\n return;\n }\n var isAutoGroupCol = colId.startsWith(Constants.GROUP_AUTO_COLUMN_ID);\n if (isAutoGroupCol) {\n // auto group columns, if missing from state list, are added to the start.\n // it's common to have autoGroup missing, as grouping could be on by default\n // on a column, but the user could of since removed the grouping via the UI.\n // if we don't inc the insert index, autoGroups will be inserted in reverse order\n insertIntoArray(newOrder, col, autoGroupInsertIndex++);\n }\n else {\n // normal columns, if missing from state list, are added at the end\n newOrder.push(col);\n }\n });\n // this is already done in updateGridColumns, however we changed the order above (to match the order of the state\n // columns) so we need to do it again. we could of put logic into the order above to take into account fixed\n // columns, however if we did then we would have logic for updating fixed columns twice. reusing the logic here\n // is less sexy for the code here, but it keeps consistency.\n newOrder = this.placeLockedColumns(newOrder);\n if (!this.doesMovePassMarryChildren(newOrder)) {\n console.warn('AG Grid: Applying column order broke a group where columns should be married together. Applying new order has been discarded.');\n return;\n }\n this.gridColumns = newOrder;\n };\n ColumnModel.prototype.compareColumnStatesAndRaiseEvents = function (source) {\n var _this = this;\n var startState = {\n rowGroupColumns: this.rowGroupColumns.slice(),\n pivotColumns: this.pivotColumns.slice(),\n valueColumns: this.valueColumns.slice()\n };\n var columnStateBefore = this.getColumnState();\n var columnStateBeforeMap = {};\n columnStateBefore.forEach(function (col) {\n columnStateBeforeMap[col.colId] = col;\n });\n return function () {\n if (_this.gridOptionsWrapper.isSuppressColumnStateEvents()) {\n return;\n }\n var colsForState = _this.getPrimaryAndSecondaryAndAutoColumns();\n // raises generic ColumnEvents where all columns are returned rather than what has changed\n var raiseWhenListsDifferent = function (eventType, colsBefore, colsAfter, idMapper) {\n var beforeList = colsBefore.map(idMapper);\n var afterList = colsAfter.map(idMapper);\n var unchanged = areEqual(beforeList, afterList);\n if (unchanged) {\n return;\n }\n // returning all columns rather than what has changed!\n var event = {\n type: eventType,\n columns: colsAfter,\n column: colsAfter.length === 1 ? colsAfter[0] : null,\n source: source\n };\n _this.eventService.dispatchEvent(event);\n };\n // determines which columns have changed according to supplied predicate\n var getChangedColumns = function (changedPredicate) {\n var changedColumns = [];\n colsForState.forEach(function (column) {\n var colStateBefore = columnStateBeforeMap[column.getColId()];\n if (colStateBefore && changedPredicate(colStateBefore, column)) {\n changedColumns.push(column);\n }\n });\n return changedColumns;\n };\n var columnIdMapper = function (c) { return c.getColId(); };\n raiseWhenListsDifferent(Events.EVENT_COLUMN_ROW_GROUP_CHANGED, startState.rowGroupColumns, _this.rowGroupColumns, columnIdMapper);\n raiseWhenListsDifferent(Events.EVENT_COLUMN_PIVOT_CHANGED, startState.pivotColumns, _this.pivotColumns, columnIdMapper);\n var valueChangePredicate = function (cs, c) {\n var oldActive = cs.aggFunc != null;\n var activeChanged = oldActive != c.isValueActive();\n // we only check aggFunc if the agg is active\n var aggFuncChanged = oldActive && cs.aggFunc != c.getAggFunc();\n return activeChanged || aggFuncChanged;\n };\n var changedValues = getChangedColumns(valueChangePredicate);\n if (changedValues.length > 0) {\n // we pass all value columns, now the ones that changed. this is the same\n // as pivot and rowGroup cols, but different to all other properties below.\n // this is more for backwards compatibility, as it's always been this way.\n // really it should be the other way, as the order of the cols makes no difference\n // for valueColumns (apart from displaying them in the tool panel).\n _this.fireColumnEvent(Events.EVENT_COLUMN_VALUE_CHANGED, _this.valueColumns, source);\n }\n var resizeChangePredicate = function (cs, c) { return cs.width != c.getActualWidth(); };\n _this.fireColumnResizedEvent(getChangedColumns(resizeChangePredicate), true, source);\n var pinnedChangePredicate = function (cs, c) { return cs.pinned != c.getPinned(); };\n _this.raiseColumnPinnedEvent(getChangedColumns(pinnedChangePredicate), source);\n var visibilityChangePredicate = function (cs, c) { return cs.hide == c.isVisible(); };\n _this.raiseColumnVisibleEvent(getChangedColumns(visibilityChangePredicate), source);\n var sortChangePredicate = function (cs, c) { return cs.sort != c.getSort() || cs.sortIndex != c.getSortIndex(); };\n if (getChangedColumns(sortChangePredicate).length > 0) {\n _this.sortController.dispatchSortChangedEvents(source);\n }\n // special handling for moved column events\n _this.raiseColumnMovedEvent(columnStateBefore, source);\n };\n };\n ColumnModel.prototype.raiseColumnPinnedEvent = function (changedColumns, source) {\n if (!changedColumns.length) {\n return;\n }\n // if just one column, we use this, otherwise we don't include the col\n var column = changedColumns.length === 1 ? changedColumns[0] : null;\n // only include visible if it's common in all columns\n var pinned = this.getCommonValue(changedColumns, function (col) { return col.getPinned(); });\n var event = {\n type: Events.EVENT_COLUMN_PINNED,\n // mistake in typing, 'undefined' should be allowed, as 'null' means 'not pinned'\n pinned: pinned != null ? pinned : null,\n columns: changedColumns,\n column: column,\n source: source\n };\n this.eventService.dispatchEvent(event);\n };\n ColumnModel.prototype.getCommonValue = function (cols, valueGetter) {\n if (!cols || cols.length == 0) {\n return undefined;\n }\n // compare each value to the first value. if nothing differs, then value is common so return it.\n var firstValue = valueGetter(cols[0]);\n for (var i = 1; i < cols.length; i++) {\n if (firstValue !== valueGetter(cols[i])) {\n // values differ, no common value\n return undefined;\n }\n }\n return firstValue;\n };\n ColumnModel.prototype.raiseColumnVisibleEvent = function (changedColumns, source) {\n if (!changedColumns.length) {\n return;\n }\n // if just one column, we use this, otherwise we don't include the col\n var column = changedColumns.length === 1 ? changedColumns[0] : null;\n // only include visible if it's common in all columns\n var visible = this.getCommonValue(changedColumns, function (col) { return col.isVisible(); });\n var event = {\n type: Events.EVENT_COLUMN_VISIBLE,\n visible: visible,\n columns: changedColumns,\n column: column,\n source: source\n };\n this.eventService.dispatchEvent(event);\n };\n ColumnModel.prototype.raiseColumnMovedEvent = function (colStateBefore, source) {\n // we are only interested in columns that were both present and visible before and after\n var _this = this;\n var colStateAfter = this.getColumnState();\n var colStateAfterMapped = {};\n colStateAfter.forEach(function (s) { return colStateAfterMapped[s.colId] = s; });\n // get id's of cols in both before and after lists\n var colsIntersectIds = {};\n colStateBefore.forEach(function (s) {\n if (colStateAfterMapped[s.colId]) {\n colsIntersectIds[s.colId] = true;\n }\n });\n // filter state lists, so we only have cols that were present before and after\n var beforeFiltered = colStateBefore.filter(function (c) { return colsIntersectIds[c.colId]; });\n var afterFiltered = colStateAfter.filter(function (c) { return colsIntersectIds[c.colId]; });\n // see if any cols are in a different location\n var movedColumns = [];\n afterFiltered.forEach(function (csAfter, index) {\n var csBefore = beforeFiltered && beforeFiltered[index];\n if (csBefore && csBefore.colId !== csAfter.colId) {\n var gridCol = _this.getGridColumn(csBefore.colId);\n if (gridCol) {\n movedColumns.push(gridCol);\n }\n }\n });\n if (!movedColumns.length) {\n return;\n }\n var event = {\n type: Events.EVENT_COLUMN_MOVED,\n columns: movedColumns,\n column: null,\n source: source\n };\n this.eventService.dispatchEvent(event);\n };\n ColumnModel.prototype.syncColumnWithStateItem = function (column, stateItem, defaultState, rowGroupIndexes, pivotIndexes, autoCol, source) {\n if (!column) {\n return;\n }\n var getValue = function (key1, key2) {\n var obj = { value1: undefined, value2: undefined };\n var calculated = false;\n if (stateItem) {\n if (stateItem[key1] !== undefined) {\n obj.value1 = stateItem[key1];\n calculated = true;\n }\n if (exists(key2) && stateItem[key2] !== undefined) {\n obj.value2 = stateItem[key2];\n calculated = true;\n }\n }\n if (!calculated && defaultState) {\n if (defaultState[key1] !== undefined) {\n obj.value1 = defaultState[key1];\n }\n if (exists(key2) && defaultState[key2] !== undefined) {\n obj.value2 = defaultState[key2];\n }\n }\n return obj;\n };\n // following ensures we are left with boolean true or false, eg converts (null, undefined, 0) all to true\n var hide = getValue('hide').value1;\n if (hide !== undefined) {\n column.setVisible(!hide, source);\n }\n // sets pinned to 'left' or 'right'\n var pinned = getValue('pinned').value1;\n if (pinned !== undefined) {\n column.setPinned(pinned);\n }\n // if width provided and valid, use it, otherwise stick with the old width\n var minColWidth = this.columnUtils.calculateColMinWidth(column.getColDef());\n // flex\n var flex = getValue('flex').value1;\n if (flex !== undefined) {\n column.setFlex(flex);\n }\n // width - we only set width if column is not flexing\n var noFlexThisCol = column.getFlex() <= 0;\n if (noFlexThisCol) {\n // both null and undefined means we skip, as it's not possible to 'clear' width (a column must have a width)\n var width = getValue('width').value1;\n if (width != null) {\n if (minColWidth != null && width >= minColWidth) {\n column.setActualWidth(width, source);\n }\n }\n }\n var sort = getValue('sort').value1;\n if (sort !== undefined) {\n if (sort === Constants.SORT_DESC || sort === Constants.SORT_ASC) {\n column.setSort(sort, source);\n }\n else {\n column.setSort(undefined, source);\n }\n }\n var sortIndex = getValue('sortIndex').value1;\n if (sortIndex !== undefined) {\n column.setSortIndex(sortIndex);\n }\n // we do not do aggFunc, rowGroup or pivot for auto cols or secondary cols\n if (autoCol || !column.isPrimary()) {\n return;\n }\n var aggFunc = getValue('aggFunc').value1;\n if (aggFunc !== undefined) {\n if (typeof aggFunc === 'string') {\n column.setAggFunc(aggFunc);\n if (!column.isValueActive()) {\n column.setValueActive(true, source);\n this.valueColumns.push(column);\n }\n }\n else {\n if (exists(aggFunc)) {\n console.warn('AG Grid: stateItem.aggFunc must be a string. if using your own aggregation ' +\n 'functions, register the functions first before using them in get/set state. This is because it is ' +\n 'intended for the column state to be stored and retrieved as simple JSON.');\n }\n // Note: we do not call column.setAggFunc(null), so that next time we aggregate\n // by this column (eg drag the column to the agg section int he toolpanel) it will\n // default to the last aggregation function.\n if (column.isValueActive()) {\n column.setValueActive(false, source);\n removeFromArray(this.valueColumns, column);\n }\n }\n }\n var _a = getValue('rowGroup', 'rowGroupIndex'), rowGroup = _a.value1, rowGroupIndex = _a.value2;\n if (rowGroup !== undefined || rowGroupIndex !== undefined) {\n if (typeof rowGroupIndex === 'number' || rowGroup) {\n if (!column.isRowGroupActive()) {\n column.setRowGroupActive(true, source);\n this.rowGroupColumns.push(column);\n }\n if (rowGroupIndexes && typeof rowGroupIndex === 'number') {\n rowGroupIndexes[column.getId()] = rowGroupIndex;\n }\n }\n else {\n if (column.isRowGroupActive()) {\n column.setRowGroupActive(false, source);\n removeFromArray(this.rowGroupColumns, column);\n }\n }\n }\n var _b = getValue('pivot', 'pivotIndex'), pivot = _b.value1, pivotIndex = _b.value2;\n if (pivot !== undefined || pivotIndex !== undefined) {\n if (typeof pivotIndex === 'number' || pivot) {\n if (!column.isPivotActive()) {\n column.setPivotActive(true, source);\n this.pivotColumns.push(column);\n }\n if (pivotIndexes && typeof pivotIndex === 'number') {\n pivotIndexes[column.getId()] = pivotIndex;\n }\n }\n else {\n if (column.isPivotActive()) {\n column.setPivotActive(false, source);\n removeFromArray(this.pivotColumns, column);\n }\n }\n }\n };\n ColumnModel.prototype.getGridColumns = function (keys) {\n return this.getColumns(keys, this.getGridColumn.bind(this));\n };\n ColumnModel.prototype.getColumns = function (keys, columnLookupCallback) {\n var foundColumns = [];\n if (keys) {\n keys.forEach(function (key) {\n var column = columnLookupCallback(key);\n if (column) {\n foundColumns.push(column);\n }\n });\n }\n return foundColumns;\n };\n // used by growGroupPanel\n ColumnModel.prototype.getColumnWithValidation = function (key) {\n if (key == null) {\n return null;\n }\n var column = this.getGridColumn(key);\n if (!column) {\n console.warn('AG Grid: could not find column ' + key);\n }\n return column;\n };\n ColumnModel.prototype.getPrimaryColumn = function (key) {\n if (!this.primaryColumns) {\n return null;\n }\n return this.getColumn(key, this.primaryColumns, this.primaryColumnsMap);\n };\n ColumnModel.prototype.getGridColumn = function (key) {\n return this.getColumn(key, this.gridColumns, this.gridColumnsMap);\n };\n ColumnModel.prototype.getSecondaryColumn = function (key) {\n if (!this.secondaryColumns) {\n return null;\n }\n return this.getColumn(key, this.secondaryColumns, this.secondaryColumnsMap);\n };\n ColumnModel.prototype.getColumn = function (key, columnList, columnMap) {\n if (!key) {\n return null;\n }\n // most of the time this method gets called the key is a string, so we put this shortcut in\n // for performance reasons, to see if we can match for ID (it doesn't do auto columns, that's done below)\n if (typeof key == 'string' && columnMap[key]) {\n return columnMap[key];\n }\n for (var i = 0; i < columnList.length; i++) {\n if (this.columnsMatch(columnList[i], key)) {\n return columnList[i];\n }\n }\n return this.getAutoColumn(key);\n };\n ColumnModel.prototype.getSourceColumnsForGroupColumn = function (groupCol) {\n var sourceColumnId = groupCol.getColDef().showRowGroup;\n if (!sourceColumnId) {\n return null;\n }\n if (sourceColumnId === true) {\n return this.rowGroupColumns.slice(0);\n }\n var column = this.getPrimaryColumn(sourceColumnId);\n return column ? [column] : null;\n };\n ColumnModel.prototype.getAutoColumn = function (key) {\n var _this = this;\n if (!this.groupAutoColumns ||\n !exists(this.groupAutoColumns) ||\n missing(this.groupAutoColumns)) {\n return null;\n }\n return this.groupAutoColumns.find(function (groupCol) { return _this.columnsMatch(groupCol, key); }) || null;\n };\n ColumnModel.prototype.columnsMatch = function (column, key) {\n var columnMatches = column === key;\n var colDefMatches = column.getColDef() === key;\n var idMatches = column.getColId() == key;\n return columnMatches || colDefMatches || idMatches;\n };\n ColumnModel.prototype.getDisplayNameForColumn = function (column, location, includeAggFunc) {\n if (includeAggFunc === void 0) { includeAggFunc = false; }\n if (!column) {\n return null;\n }\n var headerName = this.getHeaderName(column.getColDef(), column, null, null, location);\n if (includeAggFunc) {\n return this.wrapHeaderNameWithAggFunc(column, headerName);\n }\n return headerName;\n };\n ColumnModel.prototype.getDisplayNameForProvidedColumnGroup = function (columnGroup, providedColumnGroup, location) {\n var colGroupDef = providedColumnGroup ? providedColumnGroup.getColGroupDef() : null;\n if (colGroupDef) {\n return this.getHeaderName(colGroupDef, null, columnGroup, providedColumnGroup, location);\n }\n return null;\n };\n ColumnModel.prototype.getDisplayNameForColumnGroup = function (columnGroup, location) {\n return this.getDisplayNameForProvidedColumnGroup(columnGroup, columnGroup.getProvidedColumnGroup(), location);\n };\n // location is where the column is going to appear, ie who is calling us\n ColumnModel.prototype.getHeaderName = function (colDef, column, columnGroup, providedColumnGroup, location) {\n var headerValueGetter = colDef.headerValueGetter;\n if (headerValueGetter) {\n var params = {\n colDef: colDef,\n column: column,\n columnGroup: columnGroup,\n providedColumnGroup: providedColumnGroup,\n location: location,\n api: this.gridOptionsWrapper.getApi(),\n columnApi: this.gridOptionsWrapper.getColumnApi(),\n context: this.gridOptionsWrapper.getContext()\n };\n if (typeof headerValueGetter === 'function') {\n // valueGetter is a function, so just call it\n return headerValueGetter(params);\n }\n else if (typeof headerValueGetter === 'string') {\n // valueGetter is an expression, so execute the expression\n return this.expressionService.evaluate(headerValueGetter, params);\n }\n console.warn('ag-grid: headerValueGetter must be a function or a string');\n return '';\n }\n else if (colDef.headerName != null) {\n return colDef.headerName;\n }\n else if (colDef.field) {\n return camelCaseToHumanText(colDef.field);\n }\n return '';\n };\n ColumnModel.prototype.wrapHeaderNameWithAggFunc = function (column, headerName) {\n if (this.gridOptionsWrapper.isSuppressAggFuncInHeader()) {\n return headerName;\n }\n // only columns with aggregation active can have aggregations\n var pivotValueColumn = column.getColDef().pivotValueColumn;\n var pivotActiveOnThisColumn = exists(pivotValueColumn);\n var aggFunc = null;\n var aggFuncFound;\n // otherwise we have a measure that is active, and we are doing aggregation on it\n if (pivotActiveOnThisColumn) {\n var isCollapsedHeaderEnabled = this.gridOptionsWrapper.isRemovePivotHeaderRowWhenSingleValueColumn() && this.valueColumns.length === 1;\n var isTotalColumn = column.getColDef().pivotTotalColumnIds !== undefined;\n if (isCollapsedHeaderEnabled && !isTotalColumn) {\n return headerName; // Skip decorating the header - in this case the label is the pivot key, not the value col\n }\n aggFunc = pivotValueColumn ? pivotValueColumn.getAggFunc() : null;\n aggFuncFound = true;\n }\n else {\n var measureActive = column.isValueActive();\n var aggregationPresent = this.pivotMode || !this.isRowGroupEmpty();\n if (measureActive && aggregationPresent) {\n aggFunc = column.getAggFunc();\n aggFuncFound = true;\n }\n else {\n aggFuncFound = false;\n }\n }\n if (aggFuncFound) {\n var aggFuncString = (typeof aggFunc === 'string') ? aggFunc : 'func';\n var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();\n var aggFuncStringTranslated = localeTextFunc(aggFuncString, aggFuncString);\n return aggFuncStringTranslated + \"(\" + headerName + \")\";\n }\n return headerName;\n };\n // returns the group with matching colId and instanceId. If instanceId is missing,\n // matches only on the colId.\n ColumnModel.prototype.getColumnGroup = function (colId, instanceId) {\n if (!colId) {\n return null;\n }\n if (colId instanceof ColumnGroup) {\n return colId;\n }\n var allColumnGroups = this.getAllDisplayedTrees();\n var checkInstanceId = typeof instanceId === 'number';\n var result = null;\n this.columnUtils.depthFirstAllColumnTreeSearch(allColumnGroups, function (child) {\n if (child instanceof ColumnGroup) {\n var columnGroup = child;\n var matched = void 0;\n if (checkInstanceId) {\n matched = colId === columnGroup.getGroupId() && instanceId === columnGroup.getInstanceId();\n }\n else {\n matched = colId === columnGroup.getGroupId();\n }\n if (matched) {\n result = columnGroup;\n }\n }\n });\n return result;\n };\n ColumnModel.prototype.isReady = function () {\n return this.ready;\n };\n ColumnModel.prototype.extractValueColumns = function (source, oldPrimaryColumns) {\n this.valueColumns = this.extractColumns(oldPrimaryColumns, this.valueColumns, function (col, flag) { return col.setValueActive(flag, source); }, \n // aggFunc doesn't have index variant, cos order of value cols doesn't matter, so always return null\n function () { return undefined; }, function () { return undefined; }, \n // aggFunc is a string, so return it's existence\n function (colDef) {\n var aggFunc = colDef.aggFunc;\n // null or empty string means clear\n if (aggFunc === null || aggFunc === '') {\n return null;\n }\n if (aggFunc === undefined) {\n return;\n }\n return !!aggFunc;\n }, function (colDef) {\n // return false if any of the following: null, undefined, empty string\n return colDef.initialAggFunc != null && colDef.initialAggFunc != '';\n });\n // all new columns added will have aggFunc missing, so set it to what is in the colDef\n this.valueColumns.forEach(function (col) {\n var colDef = col.getColDef();\n // if aggFunc provided, we always override, as reactive property\n if (colDef.aggFunc != null && colDef.aggFunc != '') {\n col.setAggFunc(colDef.aggFunc);\n }\n else {\n // otherwise we use initialAggFunc only if no agg func set - which happens when new column only\n if (!col.getAggFunc()) {\n col.setAggFunc(colDef.initialAggFunc);\n }\n }\n });\n };\n ColumnModel.prototype.extractRowGroupColumns = function (source, oldPrimaryColumns) {\n this.rowGroupColumns = this.extractColumns(oldPrimaryColumns, this.rowGroupColumns, function (col, flag) { return col.setRowGroupActive(flag, source); }, function (colDef) { return colDef.rowGroupIndex; }, function (colDef) { return colDef.initialRowGroupIndex; }, function (colDef) { return colDef.rowGroup; }, function (colDef) { return colDef.initialRowGroup; });\n };\n ColumnModel.prototype.extractColumns = function (oldPrimaryColumns, previousCols, setFlagFunc, getIndexFunc, getInitialIndexFunc, getValueFunc, getInitialValueFunc) {\n if (oldPrimaryColumns === void 0) { oldPrimaryColumns = []; }\n if (previousCols === void 0) { previousCols = []; }\n var colsWithIndex = [];\n var colsWithValue = [];\n // go though all cols.\n // if value, change\n // if default only, change only if new\n (this.primaryColumns || []).forEach(function (col) {\n var colIsNew = oldPrimaryColumns.indexOf(col) < 0;\n var colDef = col.getColDef();\n var value = attrToBoolean(getValueFunc(colDef));\n var initialValue = attrToBoolean(getInitialValueFunc(colDef));\n var index = attrToNumber(getIndexFunc(colDef));\n var initialIndex = attrToNumber(getInitialIndexFunc(colDef));\n var include;\n var valuePresent = value !== undefined;\n var indexPresent = index !== undefined;\n var initialValuePresent = initialValue !== undefined;\n var initialIndexPresent = initialIndex !== undefined;\n if (valuePresent) {\n include = value; // boolean value is guaranteed as attrToBoolean() is used above\n }\n else if (indexPresent) {\n if (index === null) {\n // if col is new we don't want to use the default / initial if index is set to null. Similarly,\n // we don't want to include the property for existing columns, i.e. we want to 'clear' it.\n include = false;\n }\n else {\n // note that 'null >= 0' evaluates to true which means 'rowGroupIndex = null' would enable row\n // grouping if the null check didn't exist above.\n include = index >= 0;\n }\n }\n else {\n if (colIsNew) {\n // as no value or index is 'present' we use the default / initial when col is new\n if (initialValuePresent) {\n include = initialValue;\n }\n else if (initialIndexPresent) {\n include = initialIndex != null && initialIndex >= 0;\n }\n else {\n include = false;\n }\n }\n else {\n // otherwise include it if included last time, e.g. if we are extracting row group cols and this col\n // is an existing row group col (i.e. it exists in 'previousCols') then we should include it.\n include = previousCols.indexOf(col) >= 0;\n }\n }\n if (include) {\n var useIndex = colIsNew ? (index != null || initialIndex != null) : index != null;\n useIndex ? colsWithIndex.push(col) : colsWithValue.push(col);\n }\n });\n var getIndexForCol = function (col) {\n var index = getIndexFunc(col.getColDef());\n var defaultIndex = getInitialIndexFunc(col.getColDef());\n return index != null ? index : defaultIndex;\n };\n // sort cols with index, and add these first\n colsWithIndex.sort(function (colA, colB) {\n var indexA = getIndexForCol(colA);\n var indexB = getIndexForCol(colB);\n if (indexA === indexB) {\n return 0;\n }\n if (indexA < indexB) {\n return -1;\n }\n return 1;\n });\n var res = [].concat(colsWithIndex);\n // second add columns that were there before and in the same order as they were before,\n // so we are preserving order of current grouping of columns that simply have rowGroup=true\n previousCols.forEach(function (col) {\n if (colsWithValue.indexOf(col) >= 0) {\n res.push(col);\n }\n });\n // lastly put in all remaining cols\n colsWithValue.forEach(function (col) {\n if (res.indexOf(col) < 0) {\n res.push(col);\n }\n });\n // set flag=false for removed cols\n previousCols.forEach(function (col) {\n if (res.indexOf(col) < 0) {\n setFlagFunc(col, false);\n }\n });\n // set flag=true for newly added cols\n res.forEach(function (col) {\n if (previousCols.indexOf(col) < 0) {\n setFlagFunc(col, true);\n }\n });\n return res;\n };\n ColumnModel.prototype.extractPivotColumns = function (source, oldPrimaryColumns) {\n this.pivotColumns = this.extractColumns(oldPrimaryColumns, this.pivotColumns, function (col, flag) { return col.setPivotActive(flag, source); }, function (colDef) { return colDef.pivotIndex; }, function (colDef) { return colDef.initialPivotIndex; }, function (colDef) { return colDef.pivot; }, function (colDef) { return colDef.initialPivot; });\n };\n ColumnModel.prototype.resetColumnGroupState = function (source) {\n if (source === void 0) { source = \"api\"; }\n var stateItems = [];\n this.columnUtils.depthFirstOriginalTreeSearch(null, this.primaryColumnTree, function (child) {\n if (child instanceof ProvidedColumnGroup) {\n var colGroupDef = child.getColGroupDef();\n var groupState = {\n groupId: child.getGroupId(),\n open: !colGroupDef ? undefined : colGroupDef.openByDefault\n };\n stateItems.push(groupState);\n }\n });\n this.setColumnGroupState(stateItems, source);\n };\n ColumnModel.prototype.getColumnGroupState = function () {\n var columnGroupState = [];\n this.columnUtils.depthFirstOriginalTreeSearch(null, this.gridBalancedTree, function (node) {\n if (node instanceof ProvidedColumnGroup) {\n columnGroupState.push({\n groupId: node.getGroupId(),\n open: node.isExpanded()\n });\n }\n });\n return columnGroupState;\n };\n ColumnModel.prototype.setColumnGroupState = function (stateItems, source) {\n var _this = this;\n if (source === void 0) { source = \"api\"; }\n this.columnAnimationService.start();\n var impactedGroups = [];\n stateItems.forEach(function (stateItem) {\n var groupKey = stateItem.groupId;\n var newValue = stateItem.open;\n var providedColumnGroup = _this.getProvidedColumnGroup(groupKey);\n if (!providedColumnGroup) {\n return;\n }\n if (providedColumnGroup.isExpanded() === newValue) {\n return;\n }\n _this.logger.log('columnGroupOpened(' + providedColumnGroup.getGroupId() + ',' + newValue + ')');\n providedColumnGroup.setExpanded(newValue);\n impactedGroups.push(providedColumnGroup);\n });\n this.updateGroupsAndDisplayedColumns(source);\n this.setFirstRightAndLastLeftPinned(source);\n impactedGroups.forEach(function (providedColumnGroup) {\n var event = {\n type: Events.EVENT_COLUMN_GROUP_OPENED,\n columnGroup: providedColumnGroup\n };\n _this.eventService.dispatchEvent(event);\n });\n this.columnAnimationService.finish();\n };\n // called by headerRenderer - when a header is opened or closed\n ColumnModel.prototype.setColumnGroupOpened = function (key, newValue, source) {\n if (source === void 0) { source = \"api\"; }\n var keyAsString;\n if (key instanceof ProvidedColumnGroup) {\n keyAsString = key.getId();\n }\n else {\n keyAsString = key || '';\n }\n this.setColumnGroupState([{ groupId: keyAsString, open: newValue }], source);\n };\n ColumnModel.prototype.getProvidedColumnGroup = function (key) {\n // if (key instanceof ProvidedColumnGroup) { return key; }\n if (typeof key !== 'string') {\n console.error('AG Grid: group key must be a string');\n }\n // otherwise, search for the column group by id\n var res = null;\n this.columnUtils.depthFirstOriginalTreeSearch(null, this.gridBalancedTree, function (node) {\n if (node instanceof ProvidedColumnGroup) {\n if (node.getId() === key) {\n res = node;\n }\n }\n });\n return res;\n };\n ColumnModel.prototype.calculateColumnsForDisplay = function () {\n var _this = this;\n var columnsForDisplay;\n if (this.pivotMode && missing(this.secondaryColumns)) {\n // pivot mode is on, but we are not pivoting, so we only\n // show columns we are aggregating on\n columnsForDisplay = this.gridColumns.filter(function (column) {\n var isAutoGroupCol = _this.groupAutoColumns && includes(_this.groupAutoColumns, column);\n var isValueCol = _this.valueColumns && includes(_this.valueColumns, column);\n return isAutoGroupCol || isValueCol;\n });\n }\n else {\n // otherwise continue as normal. this can be working on the primary\n // or secondary columns, whatever the gridColumns are set to\n columnsForDisplay = this.gridColumns.filter(function (column) {\n // keep col if a) it's auto-group or b) it's visible\n var isAutoGroupCol = _this.groupAutoColumns && includes(_this.groupAutoColumns, column);\n return isAutoGroupCol || column.isVisible();\n });\n }\n return columnsForDisplay;\n };\n ColumnModel.prototype.checkColSpanActiveInCols = function (columns) {\n var result = false;\n columns.forEach(function (col) {\n if (exists(col.getColDef().colSpan)) {\n result = true;\n }\n });\n return result;\n };\n ColumnModel.prototype.calculateColumnsForGroupDisplay = function () {\n var _this = this;\n this.groupDisplayColumns = [];\n this.groupDisplayColumnsMap = {};\n var checkFunc = function (col) {\n var colDef = col.getColDef();\n var underlyingColumn = colDef.showRowGroup;\n if (colDef && exists(underlyingColumn)) {\n _this.groupDisplayColumns.push(col);\n if (typeof underlyingColumn === 'string') {\n _this.groupDisplayColumnsMap[underlyingColumn] = col;\n }\n else if (underlyingColumn === true) {\n _this.getRowGroupColumns().forEach(function (rowGroupCol) {\n _this.groupDisplayColumnsMap[rowGroupCol.getId()] = col;\n });\n }\n }\n };\n this.gridColumns.forEach(checkFunc);\n if (this.groupAutoColumns) {\n this.groupAutoColumns.forEach(checkFunc);\n }\n };\n ColumnModel.prototype.getGroupDisplayColumns = function () {\n return this.groupDisplayColumns;\n };\n ColumnModel.prototype.getGroupDisplayColumnForGroup = function (rowGroupColumnId) {\n return this.groupDisplayColumnsMap[rowGroupColumnId];\n };\n ColumnModel.prototype.updateDisplayedColumns = function (source) {\n var columnsForDisplay = this.calculateColumnsForDisplay();\n this.buildDisplayedTrees(columnsForDisplay);\n this.calculateColumnsForGroupDisplay();\n // also called when group opened/closed\n this.updateGroupsAndDisplayedColumns(source);\n // also called when group opened/closed\n this.setFirstRightAndLastLeftPinned(source);\n };\n ColumnModel.prototype.isSecondaryColumnsPresent = function () {\n return exists(this.secondaryColumns);\n };\n ColumnModel.prototype.setSecondaryColumns = function (colDefs, source) {\n var _this = this;\n if (source === void 0) { source = \"api\"; }\n var newColsPresent = colDefs && colDefs.length > 0;\n // if not cols passed, and we had no cols anyway, then do nothing\n if (!newColsPresent && missing(this.secondaryColumns)) {\n return;\n }\n if (newColsPresent) {\n this.processSecondaryColumnDefinitions(colDefs);\n var balancedTreeResult = this.columnFactory.createColumnTree(colDefs, false, this.secondaryBalancedTree || this.previousSecondaryColumns || undefined);\n this.secondaryBalancedTree = balancedTreeResult.columnTree;\n this.secondaryHeaderRowCount = balancedTreeResult.treeDept + 1;\n this.secondaryColumns = this.getColumnsFromTree(this.secondaryBalancedTree);\n this.secondaryColumnsMap = {};\n this.secondaryColumns.forEach(function (col) { return _this.secondaryColumnsMap[col.getId()] = col; });\n this.previousSecondaryColumns = null;\n }\n else {\n this.previousSecondaryColumns = this.secondaryBalancedTree;\n this.secondaryBalancedTree = null;\n this.secondaryHeaderRowCount = -1;\n this.secondaryColumns = null;\n this.secondaryColumnsMap = {};\n }\n this.updateGridColumns();\n this.updateDisplayedColumns(source);\n };\n ColumnModel.prototype.processSecondaryColumnDefinitions = function (colDefs) {\n var columnCallback = this.gridOptionsWrapper.getProcessPivotResultColDefFunc();\n var groupCallback = this.gridOptionsWrapper.getProcessPivotResultColGroupDefFunc();\n if (!columnCallback && !groupCallback) {\n return undefined;\n }\n var searchForColDefs = function (colDefs2) {\n colDefs2.forEach(function (abstractColDef) {\n var isGroup = exists(abstractColDef.children);\n if (isGroup) {\n var colGroupDef = abstractColDef;\n if (groupCallback) {\n groupCallback(colGroupDef);\n }\n searchForColDefs(colGroupDef.children);\n }\n else {\n var colDef = abstractColDef;\n if (columnCallback) {\n columnCallback(colDef);\n }\n }\n });\n };\n if (colDefs) {\n searchForColDefs(colDefs);\n }\n };\n // called from: setColumnState, setColumnDefs, setSecondaryColumns\n ColumnModel.prototype.updateGridColumns = function () {\n var _this = this;\n var prevGridCols = this.gridBalancedTree;\n if (this.gridColsArePrimary) {\n this.lastPrimaryOrder = this.gridColumns;\n }\n else {\n this.lastSecondaryOrder = this.gridColumns;\n }\n if (this.secondaryColumns && this.secondaryBalancedTree) {\n var hasSameColumns = this.secondaryColumns.every(function (col) {\n return _this.gridColumnsMap[col.getColId()] !== undefined;\n });\n this.gridBalancedTree = this.secondaryBalancedTree.slice();\n this.gridHeaderRowCount = this.secondaryHeaderRowCount;\n this.gridColumns = this.secondaryColumns.slice();\n this.gridColsArePrimary = false;\n // If the current columns are the same or a subset of the previous\n // we keep the previous order, otherwise we go back to the order the pivot\n // cols are generated in\n if (hasSameColumns) {\n this.orderGridColsLike(this.lastSecondaryOrder);\n }\n }\n else if (this.primaryColumns) {\n this.gridBalancedTree = this.primaryColumnTree.slice();\n this.gridHeaderRowCount = this.primaryHeaderRowCount;\n this.gridColumns = this.primaryColumns.slice();\n this.gridColsArePrimary = true;\n // updateGridColumns gets called after user adds a row group. we want to maintain the order of the columns\n // when this happens (eg if user moved a column) rather than revert back to the original column order.\n // likewise if changing in/out of pivot mode, we want to maintain the order of the cols\n this.orderGridColsLike(this.lastPrimaryOrder);\n }\n this.addAutoGroupToGridColumns();\n this.gridColumns = this.placeLockedColumns(this.gridColumns);\n this.setupQuickFilterColumns();\n this.clearDisplayedAndViewportColumns();\n this.colSpanActive = this.checkColSpanActiveInCols(this.gridColumns);\n this.gridColumnsMap = {};\n this.gridColumns.forEach(function (col) { return _this.gridColumnsMap[col.getId()] = col; });\n this.setAutoHeightActive();\n if (!areEqual(prevGridCols, this.gridBalancedTree)) {\n var event_4 = {\n type: Events.EVENT_GRID_COLUMNS_CHANGED\n };\n this.eventService.dispatchEvent(event_4);\n }\n };\n ColumnModel.prototype.setAutoHeightActive = function () {\n this.autoHeightActive = this.gridColumns.filter(function (col) { return col.isAutoHeight(); }).length > 0;\n if (this.autoHeightActive) {\n this.autoHeightActiveAtLeastOnce = true;\n var rowModelType = this.rowModel.getType();\n var supportedRowModel = rowModelType === Constants.ROW_MODEL_TYPE_CLIENT_SIDE || rowModelType === Constants.ROW_MODEL_TYPE_SERVER_SIDE;\n if (!supportedRowModel) {\n var message_1 = 'AG Grid - autoHeight columns only work with Client Side Row Model and Server Side Row Model.';\n doOnce(function () { return console.warn(message_1); }, 'autoHeightActive.wrongRowModel');\n }\n }\n };\n ColumnModel.prototype.orderGridColsLike = function (colsOrder) {\n if (missing(colsOrder)) {\n return;\n }\n var lastOrderMapped = convertToMap(colsOrder.map(function (col, index) { return [col, index]; }));\n // only do the sort if at least one column is accounted for. columns will be not accounted for\n // if changing from secondary to primary columns\n var noColsFound = true;\n this.gridColumns.forEach(function (col) {\n if (lastOrderMapped.has(col)) {\n noColsFound = false;\n }\n });\n if (noColsFound) {\n return;\n }\n // order cols in the same order as before. we need to make sure that all\n // cols still exists, so filter out any that no longer exist.\n var gridColsMap = convertToMap(this.gridColumns.map(function (col) { return [col, true]; }));\n var oldColsOrdered = colsOrder.filter(function (col) { return gridColsMap.has(col); });\n var oldColsMap = convertToMap(oldColsOrdered.map(function (col) { return [col, true]; }));\n var newColsOrdered = this.gridColumns.filter(function (col) { return !oldColsMap.has(col); });\n // add in the new columns, at the end (if no group), or at the end of the group (if a group)\n var newGridColumns = oldColsOrdered.slice();\n newColsOrdered.forEach(function (newCol) {\n var parent = newCol.getOriginalParent();\n // if no parent, means we are not grouping, so just add the column to the end\n if (!parent) {\n newGridColumns.push(newCol);\n return;\n }\n // find the group the column belongs to. if no siblings at the current level (eg col in group on it's\n // own) then go up one level and look for siblings there.\n var siblings = [];\n while (!siblings.length && parent) {\n var leafCols = parent.getLeafColumns();\n leafCols.forEach(function (leafCol) {\n var presentInNewGriColumns = newGridColumns.indexOf(leafCol) >= 0;\n var noYetInSiblings = siblings.indexOf(leafCol) < 0;\n if (presentInNewGriColumns && noYetInSiblings) {\n siblings.push(leafCol);\n }\n });\n parent = parent.getOriginalParent();\n }\n // if no siblings exist at any level, this means the col is in a group (or parent groups) on it's own\n if (!siblings.length) {\n newGridColumns.push(newCol);\n return;\n }\n // find index of last column in the group\n var indexes = siblings.map(function (col) { return newGridColumns.indexOf(col); });\n var lastIndex = Math.max.apply(Math, __spread(indexes));\n insertIntoArray(newGridColumns, newCol, lastIndex + 1);\n });\n this.gridColumns = newGridColumns;\n };\n ColumnModel.prototype.isPrimaryColumnGroupsPresent = function () {\n return this.primaryHeaderRowCount > 1;\n };\n // if we are using autoGroupCols, then they should be included for quick filter. this covers the\n // following scenarios:\n // a) user provides 'field' into autoGroupCol of normal grid, so now because a valid col to filter leafs on\n // b) using tree data and user depends on autoGroupCol for first col, and we also want to filter on this\n // (tree data is a bit different, as parent rows can be filtered on, unlike row grouping)\n ColumnModel.prototype.setupQuickFilterColumns = function () {\n if (this.groupAutoColumns) {\n this.columnsForQuickFilter = (this.primaryColumns || []).concat(this.groupAutoColumns);\n }\n else if (this.primaryColumns) {\n this.columnsForQuickFilter = this.primaryColumns;\n }\n };\n ColumnModel.prototype.placeLockedColumns = function (cols) {\n var left = [];\n var normal = [];\n var right = [];\n cols.forEach(function (col) {\n var position = col.getColDef().lockPosition;\n if (position === 'right') {\n right.push(col);\n }\n else if (position === 'left' || position === true) {\n left.push(col);\n }\n else {\n normal.push(col);\n }\n });\n return __spread(left, normal, right);\n };\n ColumnModel.prototype.addAutoGroupToGridColumns = function () {\n // add in auto-group here\n this.createGroupAutoColumnsIfNeeded();\n if (missing(this.groupAutoColumns)) {\n return;\n }\n this.gridColumns = this.groupAutoColumns ? this.groupAutoColumns.concat(this.gridColumns) : this.gridColumns;\n var autoColBalancedTree = this.columnFactory.createForAutoGroups(this.groupAutoColumns, this.gridBalancedTree);\n this.gridBalancedTree = autoColBalancedTree.concat(this.gridBalancedTree);\n };\n // gets called after we copy down grid columns, to make sure any part of the gui\n // that tries to draw, eg the header, it will get empty lists of columns rather\n // than stale columns. for example, the header will received gridColumnsChanged\n // event, so will try and draw, but it will draw successfully when it acts on the\n // virtualColumnsChanged event\n ColumnModel.prototype.clearDisplayedAndViewportColumns = function () {\n this.displayedTreeLeft = [];\n this.displayedTreeRight = [];\n this.displayedTreeCentre = [];\n this.viewportRowLeft = {};\n this.viewportRowRight = {};\n this.viewportRowCenter = {};\n this.displayedColumnsLeft = [];\n this.displayedColumnsRight = [];\n this.displayedColumnsCenter = [];\n this.displayedColumns = [];\n this.viewportColumns = [];\n this.headerViewportColumns = [];\n };\n ColumnModel.prototype.updateGroupsAndDisplayedColumns = function (source) {\n this.updateOpenClosedVisibilityInColumnGroups();\n this.deriveDisplayedColumns(source);\n this.refreshFlexedColumns();\n this.extractViewport();\n this.updateBodyWidths();\n // this event is picked up by the gui, headerRenderer and rowRenderer, to recalculate what columns to display\n var event = {\n type: Events.EVENT_DISPLAYED_COLUMNS_CHANGED\n };\n this.eventService.dispatchEvent(event);\n };\n ColumnModel.prototype.deriveDisplayedColumns = function (source) {\n this.derivedDisplayedColumnsFromDisplayedTree(this.displayedTreeLeft, this.displayedColumnsLeft);\n this.derivedDisplayedColumnsFromDisplayedTree(this.displayedTreeCentre, this.displayedColumnsCenter);\n this.derivedDisplayedColumnsFromDisplayedTree(this.displayedTreeRight, this.displayedColumnsRight);\n this.joinDisplayedColumns();\n this.setLeftValues(source);\n this.displayedAutoHeightCols = this.displayedColumns.filter(function (col) { return col.isAutoHeight(); });\n };\n ColumnModel.prototype.isAutoRowHeightActive = function () {\n return this.autoHeightActive;\n };\n ColumnModel.prototype.wasAutoRowHeightEverActive = function () {\n return this.autoHeightActiveAtLeastOnce;\n };\n ColumnModel.prototype.joinDisplayedColumns = function () {\n if (this.gridOptionsWrapper.isEnableRtl()) {\n this.displayedColumns = this.displayedColumnsRight\n .concat(this.displayedColumnsCenter)\n .concat(this.displayedColumnsLeft);\n }\n else {\n this.displayedColumns = this.displayedColumnsLeft\n .concat(this.displayedColumnsCenter)\n .concat(this.displayedColumnsRight);\n }\n };\n // sets the left pixel position of each column\n ColumnModel.prototype.setLeftValues = function (source) {\n this.setLeftValuesOfColumns(source);\n this.setLeftValuesOfGroups();\n };\n ColumnModel.prototype.setLeftValuesOfColumns = function (source) {\n var _this = this;\n if (!this.primaryColumns) {\n return;\n }\n // go through each list of displayed columns\n var allColumns = this.primaryColumns.slice(0);\n // let totalColumnWidth = this.getWidthOfColsInList()\n var doingRtl = this.gridOptionsWrapper.isEnableRtl();\n [\n this.displayedColumnsLeft,\n this.displayedColumnsRight,\n this.displayedColumnsCenter\n ].forEach(function (columns) {\n if (doingRtl) {\n // when doing RTL, we start at the top most pixel (ie RHS) and work backwards\n var left_1 = _this.getWidthOfColsInList(columns);\n columns.forEach(function (column) {\n left_1 -= column.getActualWidth();\n column.setLeft(left_1, source);\n });\n }\n else {\n // otherwise normal LTR, we start at zero\n var left_2 = 0;\n columns.forEach(function (column) {\n column.setLeft(left_2, source);\n left_2 += column.getActualWidth();\n });\n }\n removeAllFromArray(allColumns, columns);\n });\n // items left in allColumns are columns not displayed, so remove the left position. this is\n // important for the rows, as if a col is made visible, then taken out, then made visible again,\n // we don't want the animation of the cell floating in from the old position, whatever that was.\n allColumns.forEach(function (column) {\n column.setLeft(null, source);\n });\n };\n ColumnModel.prototype.setLeftValuesOfGroups = function () {\n // a groups left value is the lest left value of it's children\n [\n this.displayedTreeLeft,\n this.displayedTreeRight,\n this.displayedTreeCentre\n ].forEach(function (columns) {\n columns.forEach(function (column) {\n if (column instanceof ColumnGroup) {\n var columnGroup = column;\n columnGroup.checkLeft();\n }\n });\n });\n };\n ColumnModel.prototype.derivedDisplayedColumnsFromDisplayedTree = function (tree, columns) {\n columns.length = 0;\n this.columnUtils.depthFirstDisplayedColumnTreeSearch(tree, function (child) {\n if (child instanceof Column) {\n columns.push(child);\n }\n });\n };\n ColumnModel.prototype.extractViewportColumns = function () {\n if (this.suppressColumnVirtualisation) {\n // no virtualisation, so don't filter\n this.viewportColumnsCenter = this.displayedColumnsCenter;\n this.headerViewportColumnsCenter = this.displayedColumnsCenter;\n }\n else {\n // filter out what should be visible\n this.viewportColumnsCenter = this.displayedColumnsCenter.filter(this.isColumnInRowViewport.bind(this));\n this.headerViewportColumnsCenter = this.displayedColumnsCenter.filter(this.isColumnInHeaderViewport.bind(this));\n }\n this.viewportColumns = this.viewportColumnsCenter\n .concat(this.displayedColumnsLeft)\n .concat(this.displayedColumnsRight);\n this.headerViewportColumns = this.headerViewportColumnsCenter\n .concat(this.displayedColumnsLeft)\n .concat(this.displayedColumnsRight);\n };\n ColumnModel.prototype.getVirtualHeaderGroupRow = function (type, dept) {\n var result;\n switch (type) {\n case Constants.PINNED_LEFT:\n result = this.viewportRowLeft[dept];\n break;\n case Constants.PINNED_RIGHT:\n result = this.viewportRowRight[dept];\n break;\n default:\n result = this.viewportRowCenter[dept];\n break;\n }\n if (missing(result)) {\n result = [];\n }\n return result;\n };\n ColumnModel.prototype.calculateHeaderRows = function () {\n // go through each group, see if any of it's cols are displayed, and if yes,\n // then this group is included\n this.viewportRowLeft = {};\n this.viewportRowRight = {};\n this.viewportRowCenter = {};\n // for easy lookup when building the groups.\n var virtualColIds = {};\n this.headerViewportColumns.forEach(function (col) { return virtualColIds[col.getId()] = true; });\n var testGroup = function (children, result, dept) {\n var returnValue = false;\n for (var i = 0; i < children.length; i++) {\n // see if this item is within viewport\n var child = children[i];\n var addThisItem = false;\n if (child instanceof Column) {\n // for column, test if column is included\n addThisItem = virtualColIds[child.getId()] === true;\n }\n else {\n // if group, base decision on children\n var columnGroup = child;\n var displayedChildren = columnGroup.getDisplayedChildren();\n if (displayedChildren) {\n addThisItem = testGroup(displayedChildren, result, dept + 1);\n }\n }\n if (addThisItem) {\n returnValue = true;\n if (!result[dept]) {\n result[dept] = [];\n }\n result[dept].push(child);\n }\n }\n return returnValue;\n };\n testGroup(this.displayedTreeLeft, this.viewportRowLeft, 0);\n testGroup(this.displayedTreeRight, this.viewportRowRight, 0);\n testGroup(this.displayedTreeCentre, this.viewportRowCenter, 0);\n };\n ColumnModel.prototype.extractViewport = function () {\n var hashBefore = this.viewportColumns.map(function (column) { return column.getId(); }).join('#');\n this.extractViewportColumns();\n var hashAfter = this.viewportColumns.map(function (column) { return column.getId(); }).join('#');\n var changed = hashBefore !== hashAfter;\n if (changed) {\n this.calculateHeaderRows();\n }\n return changed;\n };\n ColumnModel.prototype.refreshFlexedColumns = function (params) {\n var _this = this;\n if (params === void 0) { params = {}; }\n var source = params.source ? params.source : 'flex';\n if (params.viewportWidth != null) {\n this.flexViewportWidth = params.viewportWidth;\n }\n if (!this.flexViewportWidth) {\n return [];\n }\n // If the grid has left-over space, divide it between flexing columns in proportion to their flex value.\n // A \"flexing column\" is one that has a 'flex' value set and is not currently being constrained by its\n // minWidth or maxWidth rules.\n var flexAfterDisplayIndex = -1;\n if (params.resizingCols) {\n params.resizingCols.forEach(function (col) {\n var indexOfCol = _this.displayedColumnsCenter.indexOf(col);\n if (flexAfterDisplayIndex < indexOfCol) {\n flexAfterDisplayIndex = indexOfCol;\n }\n });\n }\n var isColFlex = function (col) {\n var afterResizingCols = _this.displayedColumnsCenter.indexOf(col) > flexAfterDisplayIndex;\n return col.getFlex() && afterResizingCols;\n };\n var knownWidthColumns = this.displayedColumnsCenter.filter(function (col) { return !isColFlex(col); });\n var flexingColumns = this.displayedColumnsCenter.filter(function (col) { return isColFlex(col); });\n var changedColumns = [];\n if (!flexingColumns.length) {\n return [];\n }\n var flexingColumnSizes = [];\n var spaceForFlexingColumns;\n outer: while (true) {\n var totalFlex = flexingColumns.reduce(function (count, col) { return count + col.getFlex(); }, 0);\n spaceForFlexingColumns = this.flexViewportWidth - this.getWidthOfColsInList(knownWidthColumns);\n for (var i = 0; i < flexingColumns.length; i++) {\n var col = flexingColumns[i];\n var widthByFlexRule = spaceForFlexingColumns * col.getFlex() / totalFlex;\n var constrainedWidth = 0;\n var minWidth = col.getMinWidth();\n var maxWidth = col.getMaxWidth();\n if (exists(minWidth) && widthByFlexRule < minWidth) {\n constrainedWidth = minWidth;\n }\n else if (exists(maxWidth) && widthByFlexRule > maxWidth) {\n constrainedWidth = maxWidth;\n }\n if (constrainedWidth) {\n // This column is not in fact flexing as it is being constrained to a specific size\n // so remove it from the list of flexing columns and start again\n col.setActualWidth(constrainedWidth, source);\n removeFromArray(flexingColumns, col);\n changedColumns.push(col);\n knownWidthColumns.push(col);\n continue outer;\n }\n flexingColumnSizes[i] = Math.round(widthByFlexRule);\n }\n break;\n }\n var remainingSpace = spaceForFlexingColumns;\n flexingColumns.forEach(function (col, i) {\n col.setActualWidth(Math.min(flexingColumnSizes[i], remainingSpace), source);\n changedColumns.push(col);\n remainingSpace -= flexingColumnSizes[i];\n });\n if (!params.skipSetLeft) {\n this.setLeftValues(source);\n }\n if (params.updateBodyWidths) {\n this.updateBodyWidths();\n }\n if (params.fireResizedEvent) {\n this.fireColumnResizedEvent(changedColumns, true, source, flexingColumns);\n }\n // if the user sets rowData directly into GridOptions, then the row data is set before\n // grid is attached to the DOM. this means the columns are not flexed, and then the rows\n // have the wrong height (as they depend on column widths). so once the columns have\n // been flexed for the first time (only happens once grid is attached to DOM, as dependency\n // on getting the grid width, which only happens after attached after ResizeObserver fires)\n // we get get rows to re-calc their heights.\n if (!this.flexColsCalculatedAtLestOnce) {\n if (this.gridOptionsWrapper.isRowModelDefault()) {\n this.rowModel.resetRowHeights();\n }\n this.flexColsCalculatedAtLestOnce = true;\n }\n return flexingColumns;\n };\n // called from api\n ColumnModel.prototype.sizeColumnsToFit = function (gridWidth, source, silent, params) {\n if (source === void 0) { source = \"sizeColumnsToFit\"; }\n var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l;\n var limitsMap = {};\n if (params) {\n (_b = (_a = params) === null || _a === void 0 ? void 0 : _a.columnLimits) === null || _b === void 0 ? void 0 : _b.forEach(function (_a) {\n var key = _a.key, dimensions = __rest(_a, [\"key\"]);\n limitsMap[typeof key === 'string' ? key : key.getColId()] = dimensions;\n });\n }\n // avoid divide by zero\n var allDisplayedColumns = this.getAllDisplayedColumns();\n var doColumnsAlreadyFit = gridWidth === this.getWidthOfColsInList(allDisplayedColumns);\n if (gridWidth <= 0 || !allDisplayedColumns.length || doColumnsAlreadyFit) {\n return;\n }\n var colsToSpread = [];\n var colsToNotSpread = [];\n allDisplayedColumns.forEach(function (column) {\n if (column.getColDef().suppressSizeToFit === true) {\n colsToNotSpread.push(column);\n }\n else {\n colsToSpread.push(column);\n }\n });\n // make a copy of the cols that are going to be resized\n var colsToFireEventFor = colsToSpread.slice(0);\n var finishedResizing = false;\n var moveToNotSpread = function (column) {\n removeFromArray(colsToSpread, column);\n colsToNotSpread.push(column);\n };\n // resetting cols to their original width makes the sizeColumnsToFit more deterministic,\n // rather than depending on the current size of the columns. most users call sizeColumnsToFit\n // immediately after grid is created, so will make no difference. however if application is calling\n // sizeColumnsToFit repeatedly (eg after column group is opened / closed repeatedly) we don't want\n // the columns to start shrinking / growing over time.\n //\n // NOTE: the process below will assign values to `this.actualWidth` of each column without firing events\n // for this reason we need to manually fire resize events after the resize has been done for each column.\n colsToSpread.forEach(function (column) { return column.resetActualWidth(source); });\n while (!finishedResizing) {\n finishedResizing = true;\n var availablePixels = gridWidth - this.getWidthOfColsInList(colsToNotSpread);\n if (availablePixels <= 0) {\n // no width, set everything to minimum\n colsToSpread.forEach(function (column) {\n var _a, _b, _c, _d;\n var widthOverride = (_c = (_b = (_a = limitsMap) === null || _a === void 0 ? void 0 : _a[column.getId()]) === null || _b === void 0 ? void 0 : _b.minWidth, (_c !== null && _c !== void 0 ? _c : (_d = params) === null || _d === void 0 ? void 0 : _d.defaultMinWidth));\n if (typeof widthOverride === 'number') {\n column.setActualWidth(widthOverride);\n return;\n }\n column.setMinimum(source);\n });\n }\n else {\n var scale = availablePixels / this.getWidthOfColsInList(colsToSpread);\n // we set the pixels for the last col based on what's left, as otherwise\n // we could be a pixel or two short or extra because of rounding errors.\n var pixelsForLastCol = availablePixels;\n // backwards through loop, as we are removing items as we go\n for (var i = colsToSpread.length - 1; i >= 0; i--) {\n var column = colsToSpread[i];\n var widthOverride = (_c = limitsMap) === null || _c === void 0 ? void 0 : _c[column.getId()];\n var minOverride = (_e = (_d = widthOverride) === null || _d === void 0 ? void 0 : _d.minWidth, (_e !== null && _e !== void 0 ? _e : (_f = params) === null || _f === void 0 ? void 0 : _f.defaultMinWidth));\n var maxOverride = (_h = (_g = widthOverride) === null || _g === void 0 ? void 0 : _g.maxWidth, (_h !== null && _h !== void 0 ? _h : (_j = params) === null || _j === void 0 ? void 0 : _j.defaultMaxWidth));\n var colMinWidth = (_k = column.getMinWidth(), (_k !== null && _k !== void 0 ? _k : 0));\n var colMaxWidth = (_l = column.getMaxWidth(), (_l !== null && _l !== void 0 ? _l : Number.MAX_VALUE));\n var minWidth = typeof minOverride === 'number' && minOverride > colMinWidth ? minOverride : column.getMinWidth();\n var maxWidth = typeof maxOverride === 'number' && maxOverride < colMaxWidth ? maxOverride : column.getMaxWidth();\n var newWidth = Math.round(column.getActualWidth() * scale);\n if (exists(minWidth) && newWidth < minWidth) {\n newWidth = minWidth;\n moveToNotSpread(column);\n finishedResizing = false;\n }\n else if (exists(maxWidth) && newWidth > maxWidth) {\n newWidth = maxWidth;\n moveToNotSpread(column);\n finishedResizing = false;\n }\n else if (i === 0) { // if this is the last column\n newWidth = pixelsForLastCol;\n }\n column.setActualWidth(newWidth, source, true);\n pixelsForLastCol -= newWidth;\n }\n }\n }\n // see notes above\n colsToFireEventFor.forEach(function (col) {\n col.fireColumnWidthChangedEvent(source);\n });\n this.setLeftValues(source);\n this.updateBodyWidths();\n if (silent) {\n return;\n }\n this.fireColumnResizedEvent(colsToFireEventFor, true, source);\n };\n ColumnModel.prototype.buildDisplayedTrees = function (visibleColumns) {\n var leftVisibleColumns = [];\n var rightVisibleColumns = [];\n var centerVisibleColumns = [];\n visibleColumns.forEach(function (column) {\n switch (column.getPinned()) {\n case \"left\":\n leftVisibleColumns.push(column);\n break;\n case \"right\":\n rightVisibleColumns.push(column);\n break;\n default:\n centerVisibleColumns.push(column);\n break;\n }\n });\n var groupInstanceIdCreator = new GroupInstanceIdCreator();\n this.displayedTreeLeft = this.displayedGroupCreator.createDisplayedGroups(leftVisibleColumns, this.gridBalancedTree, groupInstanceIdCreator, Constants.PINNED_LEFT, this.displayedTreeLeft);\n this.displayedTreeRight = this.displayedGroupCreator.createDisplayedGroups(rightVisibleColumns, this.gridBalancedTree, groupInstanceIdCreator, Constants.PINNED_RIGHT, this.displayedTreeRight);\n this.displayedTreeCentre = this.displayedGroupCreator.createDisplayedGroups(centerVisibleColumns, this.gridBalancedTree, groupInstanceIdCreator, null, this.displayedTreeCentre);\n this.updateDisplayedMap();\n };\n ColumnModel.prototype.updateDisplayedMap = function () {\n var _this = this;\n this.displayedColumnsAndGroupsMap = {};\n var func = function (child) {\n _this.displayedColumnsAndGroupsMap[child.getUniqueId()] = child;\n };\n this.columnUtils.depthFirstAllColumnTreeSearch(this.displayedTreeCentre, func);\n this.columnUtils.depthFirstAllColumnTreeSearch(this.displayedTreeLeft, func);\n this.columnUtils.depthFirstAllColumnTreeSearch(this.displayedTreeRight, func);\n };\n ColumnModel.prototype.isDisplayed = function (item) {\n var fromMap = this.displayedColumnsAndGroupsMap[item.getUniqueId()];\n // check for reference, in case new column / group with same id is now present\n return fromMap === item;\n };\n ColumnModel.prototype.updateOpenClosedVisibilityInColumnGroups = function () {\n var allColumnGroups = this.getAllDisplayedTrees();\n this.columnUtils.depthFirstAllColumnTreeSearch(allColumnGroups, function (child) {\n if (child instanceof ColumnGroup) {\n var columnGroup = child;\n columnGroup.calculateDisplayedColumns();\n }\n });\n };\n ColumnModel.prototype.getGroupAutoColumns = function () {\n return this.groupAutoColumns;\n };\n ColumnModel.prototype.createGroupAutoColumnsIfNeeded = function () {\n if (!this.autoGroupsNeedBuilding) {\n return;\n }\n this.autoGroupsNeedBuilding = false;\n var groupFullWidthRow = this.gridOptionsWrapper.isGroupUseEntireRow(this.pivotMode);\n // we need to allow suppressing auto-column separately for group and pivot as the normal situation\n // is CSRM and user provides group column themselves for normal view, but when they go into pivot the\n // columns are generated by the grid so no opportunity for user to provide group column. so need a way\n // to suppress auto-col for grouping only, and not pivot.\n // however if using Viewport RM or SSRM and user is providing the columns, the user may wish full control\n // of the group column in this instance.\n var suppressAutoColumn = this.pivotMode ?\n this.gridOptionsWrapper.isPivotSuppressAutoColumn() : this.gridOptionsWrapper.isGroupSuppressAutoColumn();\n var groupingActive = this.rowGroupColumns.length > 0 || this.usingTreeData;\n var needAutoColumns = groupingActive && !suppressAutoColumn && !groupFullWidthRow;\n if (needAutoColumns) {\n var existingCols = this.groupAutoColumns || [];\n var newAutoGroupCols = this.autoGroupColService.createAutoGroupColumns(existingCols, this.rowGroupColumns);\n var autoColsDifferent = !this.autoColsEqual(newAutoGroupCols, this.groupAutoColumns);\n // we force recreate when suppressColumnStateEvents changes, so new group cols pick up the new\n // definitions. otherwise we could ignore the new cols because they appear to be the same.\n if (autoColsDifferent || this.forceRecreateAutoGroups) {\n this.groupAutoColumns = newAutoGroupCols;\n }\n }\n else {\n this.groupAutoColumns = null;\n }\n };\n ColumnModel.prototype.autoColsEqual = function (colsA, colsB) {\n return areEqual(colsA, colsB, function (a, b) { return a.getColId() === b.getColId(); });\n };\n ColumnModel.prototype.getWidthOfColsInList = function (columnList) {\n return columnList.reduce(function (width, col) { return width + col.getActualWidth(); }, 0);\n };\n ColumnModel.prototype.getGridBalancedTree = function () {\n return this.gridBalancedTree;\n };\n ColumnModel.prototype.hasFloatingFilters = function () {\n if (!this.gridColumns) {\n return false;\n }\n var res = this.gridColumns.some(function (col) { return col.getColDef().floatingFilter; });\n return res;\n };\n ColumnModel.prototype.getFirstDisplayedColumn = function () {\n var isRtl = this.gridOptionsWrapper.isEnableRtl();\n var queryOrder = [\n 'getDisplayedLeftColumns',\n 'getDisplayedCenterColumns',\n 'getDisplayedRightColumns'\n ];\n if (isRtl) {\n queryOrder.reverse();\n }\n for (var i = 0; i < queryOrder.length; i++) {\n var container = this[queryOrder[i]]();\n if (container.length) {\n return isRtl ? last(container) : container[0];\n }\n }\n return null;\n };\n ColumnModel.prototype.setColumnHeaderHeight = function (col, height) {\n var changed = col.setAutoHeaderHeight(height);\n if (changed) {\n var event_5 = {\n type: Events.EVENT_COLUMN_HEADER_HEIGHT_CHANGED,\n column: col,\n columns: [col],\n source: 'autosizeColumnHeaderHeight',\n };\n this.eventService.dispatchEvent(event_5);\n }\n };\n ColumnModel.prototype.getColumnGroupHeaderRowHeight = function () {\n if (this.isPivotMode()) {\n return this.gridOptionsWrapper.getPivotGroupHeaderHeight();\n }\n else {\n return this.gridOptionsWrapper.getGroupHeaderHeight();\n }\n };\n ColumnModel.prototype.getColumnHeaderRowHeight = function () {\n var defaultHeight = (this.isPivotMode() ?\n this.gridOptionsWrapper.getPivotHeaderHeight() :\n this.gridOptionsWrapper.getHeaderHeight());\n var displayedHeights = this.getAllDisplayedColumns()\n .filter(function (col) { return col.isAutoHeaderHeight(); })\n .map(function (col) { return col.getAutoHeaderHeight() || 0; });\n return Math.max.apply(Math, __spread([defaultHeight], displayedHeights));\n };\n __decorate([\n Autowired('expressionService')\n ], ColumnModel.prototype, \"expressionService\", void 0);\n __decorate([\n Autowired('columnFactory')\n ], ColumnModel.prototype, \"columnFactory\", void 0);\n __decorate([\n Autowired('displayedGroupCreator')\n ], ColumnModel.prototype, \"displayedGroupCreator\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], ColumnModel.prototype, \"ctrlsService\", void 0);\n __decorate([\n Autowired('autoWidthCalculator')\n ], ColumnModel.prototype, \"autoWidthCalculator\", void 0);\n __decorate([\n Autowired('columnUtils')\n ], ColumnModel.prototype, \"columnUtils\", void 0);\n __decorate([\n Autowired('columnAnimationService')\n ], ColumnModel.prototype, \"columnAnimationService\", void 0);\n __decorate([\n Autowired('autoGroupColService')\n ], ColumnModel.prototype, \"autoGroupColService\", void 0);\n __decorate([\n Optional('aggFuncService')\n ], ColumnModel.prototype, \"aggFuncService\", void 0);\n __decorate([\n Optional('valueCache')\n ], ColumnModel.prototype, \"valueCache\", void 0);\n __decorate([\n Optional('animationFrameService')\n ], ColumnModel.prototype, \"animationFrameService\", void 0);\n __decorate([\n Autowired('rowModel')\n ], ColumnModel.prototype, \"rowModel\", void 0);\n __decorate([\n Autowired('sortController')\n ], ColumnModel.prototype, \"sortController\", void 0);\n __decorate([\n Autowired('columnDefFactory')\n ], ColumnModel.prototype, \"columnDefFactory\", void 0);\n __decorate([\n PostConstruct\n ], ColumnModel.prototype, \"init\", null);\n __decorate([\n __param(0, Qualifier('loggerFactory'))\n ], ColumnModel.prototype, \"setBeans\", null);\n ColumnModel = __decorate([\n Bean('columnModel')\n ], ColumnModel);\n return ColumnModel;\n}(BeanStub));\nexport { ColumnModel };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { ColumnGroup } from \"../entities/columnGroup\";\nimport { ProvidedColumnGroup } from \"../entities/providedColumnGroup\";\nimport { Bean } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { attrToNumber } from \"../utils/generic\";\n// takes in a list of columns, as specified by the column definitions, and returns column groups\nvar ColumnUtils = /** @class */ (function (_super) {\n __extends(ColumnUtils, _super);\n function ColumnUtils() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n ColumnUtils.prototype.calculateColMinWidth = function (colDef) {\n return colDef.minWidth != null ? colDef.minWidth : this.gridOptionsWrapper.getMinColWidth();\n };\n ColumnUtils.prototype.calculateColMaxWidth = function (colDef) {\n return colDef.maxWidth != null ? colDef.maxWidth : (this.gridOptionsWrapper.getMaxColWidth() || Number.MAX_SAFE_INTEGER);\n };\n ColumnUtils.prototype.calculateColInitialWidth = function (colDef) {\n var minColWidth = this.calculateColMinWidth(colDef);\n var maxColWidth = this.calculateColMaxWidth(colDef);\n var width;\n var colDefWidth = attrToNumber(colDef.width);\n var colDefInitialWidth = attrToNumber(colDef.initialWidth);\n if (colDefWidth != null) {\n width = colDefWidth;\n }\n else if (colDefInitialWidth != null) {\n width = colDefInitialWidth;\n }\n else {\n width = this.gridOptionsWrapper.getColWidth();\n }\n return Math.max(Math.min(width, maxColWidth), minColWidth);\n };\n ColumnUtils.prototype.getOriginalPathForColumn = function (column, originalBalancedTree) {\n var result = [];\n var found = false;\n var recursePath = function (balancedColumnTree, dept) {\n for (var i = 0; i < balancedColumnTree.length; i++) {\n if (found) {\n return;\n }\n // quit the search, so 'result' is kept with the found result\n var node = balancedColumnTree[i];\n if (node instanceof ProvidedColumnGroup) {\n var nextNode = node;\n recursePath(nextNode.getChildren(), dept + 1);\n result[dept] = node;\n }\n else if (node === column) {\n found = true;\n }\n }\n };\n recursePath(originalBalancedTree, 0);\n // we should always find the path, but in case there is a bug somewhere, returning null\n // will make it fail rather than provide a 'hard to track down' bug\n return found ? result : null;\n };\n ColumnUtils.prototype.depthFirstOriginalTreeSearch = function (parent, tree, callback) {\n var _this = this;\n if (!tree) {\n return;\n }\n tree.forEach(function (child) {\n if (child instanceof ProvidedColumnGroup) {\n _this.depthFirstOriginalTreeSearch(child, child.getChildren(), callback);\n }\n callback(child, parent);\n });\n };\n ColumnUtils.prototype.depthFirstAllColumnTreeSearch = function (tree, callback) {\n var _this = this;\n if (!tree) {\n return;\n }\n tree.forEach(function (child) {\n if (child instanceof ColumnGroup) {\n _this.depthFirstAllColumnTreeSearch(child.getChildren(), callback);\n }\n callback(child);\n });\n };\n ColumnUtils.prototype.depthFirstDisplayedColumnTreeSearch = function (tree, callback) {\n var _this = this;\n if (!tree) {\n return;\n }\n tree.forEach(function (child) {\n if (child instanceof ColumnGroup) {\n _this.depthFirstDisplayedColumnTreeSearch(child.getDisplayedChildren(), callback);\n }\n callback(child);\n });\n };\n ColumnUtils = __decorate([\n Bean('columnUtils')\n ], ColumnUtils);\n return ColumnUtils;\n}(BeanStub));\nexport { ColumnUtils };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { ColumnGroup } from \"../entities/columnGroup\";\nimport { ProvidedColumnGroup } from \"../entities/providedColumnGroup\";\nimport { Bean } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { last } from \"../utils/array\";\nimport { exists } from \"../utils/generic\";\n// takes in a list of columns, as specified by the column definitions, and returns column groups\nvar DisplayedGroupCreator = /** @class */ (function (_super) {\n __extends(DisplayedGroupCreator, _super);\n function DisplayedGroupCreator() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n DisplayedGroupCreator.prototype.createDisplayedGroups = function (\n // all displayed columns sorted - this is the columns the grid should show\n sortedVisibleColumns, \n // the tree of columns, as provided by the users, used to know what groups columns roll up into\n balancedColumnTree, \n // creates unique id's for the group\n groupInstanceIdCreator, \n // whether it's left, right or center col\n pinned, \n // we try to reuse old groups if we can, to allow gui to do animation\n oldDisplayedGroups) {\n var _this = this;\n var result = [];\n var previousRealPath;\n var previousOriginalPath;\n var oldColumnsMapped = this.mapOldGroupsById(oldDisplayedGroups);\n // go through each column, then do a bottom up comparison to the previous column, and start\n // to share groups if they converge at any point.\n sortedVisibleColumns.forEach(function (currentColumn) {\n var currentOriginalPath = _this.getOriginalPathForColumn(balancedColumnTree, currentColumn);\n var currentRealPath = [];\n var firstColumn = !previousOriginalPath;\n for (var i = 0; i < currentOriginalPath.length; i++) {\n if (firstColumn || currentOriginalPath[i] !== previousOriginalPath[i]) {\n // new group needed\n var newGroup = _this.createColumnGroup(currentOriginalPath[i], groupInstanceIdCreator, oldColumnsMapped, pinned);\n currentRealPath[i] = newGroup;\n // if top level, add to result, otherwise add to parent\n if (i == 0) {\n result.push(newGroup);\n }\n else {\n currentRealPath[i - 1].addChild(newGroup);\n }\n }\n else {\n // reuse old group\n currentRealPath[i] = previousRealPath[i];\n }\n }\n var noColumnGroups = currentRealPath.length === 0;\n if (noColumnGroups) {\n // if we are not grouping, then the result of the above is an empty\n // path (no groups), and we just add the column to the root list.\n result.push(currentColumn);\n }\n else {\n var leafGroup = last(currentRealPath);\n leafGroup.addChild(currentColumn);\n }\n previousRealPath = currentRealPath;\n previousOriginalPath = currentOriginalPath;\n });\n this.setupParentsIntoColumns(result, null);\n return result;\n };\n DisplayedGroupCreator.prototype.createColumnGroup = function (providedGroup, groupInstanceIdCreator, oldColumnsMapped, pinned) {\n var groupId = providedGroup.getGroupId();\n var instanceId = groupInstanceIdCreator.getInstanceIdForKey(groupId);\n var uniqueId = ColumnGroup.createUniqueId(groupId, instanceId);\n var columnGroup = oldColumnsMapped[uniqueId];\n // if the user is setting new colDefs, it is possible that the id's overlap, and we\n // would have a false match from above. so we double check we are talking about the\n // same original column group.\n if (columnGroup && columnGroup.getProvidedColumnGroup() !== providedGroup) {\n columnGroup = null;\n }\n if (exists(columnGroup)) {\n // clean out the old column group here, as we will be adding children into it again\n columnGroup.reset();\n }\n else {\n columnGroup = new ColumnGroup(providedGroup, groupId, instanceId, pinned);\n this.context.createBean(columnGroup);\n }\n return columnGroup;\n };\n // returns back a 2d map of ColumnGroup as follows: groupId -> instanceId -> ColumnGroup\n DisplayedGroupCreator.prototype.mapOldGroupsById = function (displayedGroups) {\n var result = {};\n var recursive = function (columnsOrGroups) {\n columnsOrGroups.forEach(function (columnOrGroup) {\n if (columnOrGroup instanceof ColumnGroup) {\n var columnGroup = columnOrGroup;\n result[columnOrGroup.getUniqueId()] = columnGroup;\n recursive(columnGroup.getChildren());\n }\n });\n };\n if (displayedGroups) {\n recursive(displayedGroups);\n }\n return result;\n };\n DisplayedGroupCreator.prototype.setupParentsIntoColumns = function (columnsOrGroups, parent) {\n var _this = this;\n columnsOrGroups.forEach(function (columnsOrGroup) {\n columnsOrGroup.setParent(parent);\n if (columnsOrGroup instanceof ColumnGroup) {\n var columnGroup = columnsOrGroup;\n _this.setupParentsIntoColumns(columnGroup.getChildren(), columnGroup);\n }\n });\n };\n DisplayedGroupCreator.prototype.getOriginalPathForColumn = function (balancedColumnTree, column) {\n var result = [];\n var found = false;\n var recursePath = function (columnTree, dept) {\n for (var i = 0; i < columnTree.length; i++) {\n // quit the search, so 'result' is kept with the found result\n if (found) {\n return;\n }\n var node = columnTree[i];\n if (node instanceof ProvidedColumnGroup) {\n recursePath(node.getChildren(), dept + 1);\n result[dept] = node;\n }\n else if (node === column) {\n found = true;\n }\n }\n };\n recursePath(balancedColumnTree, 0);\n // it's possible we didn't find a path. this happens if the column is generated\n // by the grid (auto-group), in that the definition didn't come from the client. in this case,\n // we create a fake original path.\n if (found) {\n return result;\n }\n console.warn('AG Grid: could not get path');\n return null;\n };\n DisplayedGroupCreator = __decorate([\n Bean('displayedGroupCreator')\n ], DisplayedGroupCreator);\n return DisplayedGroupCreator;\n}(BeanStub));\nexport { DisplayedGroupCreator };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nvar AgStackComponentsRegistry = /** @class */ (function (_super) {\n __extends(AgStackComponentsRegistry, _super);\n function AgStackComponentsRegistry() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.componentsMappedByName = {};\n return _this;\n }\n AgStackComponentsRegistry.prototype.setupComponents = function (components) {\n var _this = this;\n if (components) {\n components.forEach(function (componentMeta) { return _this.addComponent(componentMeta); });\n }\n };\n AgStackComponentsRegistry.prototype.addComponent = function (componentMeta) {\n // get name of the class as a string\n // let className = getNameOfClass(ComponentClass);\n // insert a dash after every capital letter\n // let classEscaped = className.replace(/([A-Z])/g, \"-$1\").toLowerCase();\n var classEscaped = componentMeta.componentName.replace(/([a-z])([A-Z])/g, \"$1-$2\").toLowerCase();\n // put all to upper case\n var classUpperCase = classEscaped.toUpperCase();\n // finally store\n this.componentsMappedByName[classUpperCase] = componentMeta.componentClass;\n };\n AgStackComponentsRegistry.prototype.getComponentClass = function (htmlTag) {\n return this.componentsMappedByName[htmlTag];\n };\n AgStackComponentsRegistry = __decorate([\n Bean('agStackComponentsRegistry')\n ], AgStackComponentsRegistry);\n return AgStackComponentsRegistry;\n}(BeanStub));\nexport { AgStackComponentsRegistry };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar Color = /** @class */ (function () {\n /**\n * Every color component should be in the [0, 1] range.\n * Some easing functions (such as elastic easing) can overshoot the target value by some amount.\n * So, when animating colors, if the source or target color components are already near\n * or at the edge of the allowed [0, 1] range, it is possible for the intermediate color\n * component value to end up outside of that range mid-animation. For this reason the constructor\n * performs range checking/constraining.\n * @param r Red component.\n * @param g Green component.\n * @param b Blue component.\n * @param a Alpha (opacity) component.\n */\n function Color(r, g, b, a) {\n if (a === void 0) { a = 1; }\n // NaN is treated as 0.\n this.r = Math.min(1, Math.max(0, r || 0));\n this.g = Math.min(1, Math.max(0, g || 0));\n this.b = Math.min(1, Math.max(0, b || 0));\n this.a = Math.min(1, Math.max(0, a || 0));\n }\n /**\n * The given string can be in one of the following formats:\n * - #rgb\n * - #rrggbb\n * - rgb(r, g, b)\n * - rgba(r, g, b, a)\n * - CSS color name such as 'white', 'orange', 'cyan', etc.\n * @param str\n */\n Color.fromString = function (str) {\n // hexadecimal notation\n if (str.indexOf('#') >= 0) { // there can be some leading whitespace\n return Color.fromHexString(str);\n }\n // color name\n var hex = Color.nameToHex[str];\n if (hex) {\n return Color.fromHexString(hex);\n }\n // rgb(a) notation\n if (str.indexOf('rgb') >= 0) {\n return Color.fromRgbaString(str);\n }\n throw new Error(\"Invalid color string: '\" + str + \"'\");\n };\n // See https://drafts.csswg.org/css-color/#hex-notation\n Color.parseHex = function (input) {\n input = input.replace(/ /g, '').slice(1);\n var parts;\n switch (input.length) {\n case 6:\n case 8:\n parts = [];\n for (var i = 0; i < input.length; i += 2) {\n parts.push(parseInt(\"\" + input[i] + input[i + 1], 16));\n }\n break;\n case 3:\n case 4:\n parts = input.split('').map(function (p) { return parseInt(p, 16); }).map(function (p) { return p + p * 16; });\n break;\n }\n if (parts.length >= 3) {\n if (parts.every(function (p) { return p >= 0; })) {\n if (parts.length === 3) {\n parts.push(255);\n }\n return parts;\n }\n }\n };\n Color.fromHexString = function (str) {\n var values = Color.parseHex(str);\n if (values) {\n var _a = __read(values, 4), r = _a[0], g = _a[1], b = _a[2], a = _a[3];\n return new Color(r / 255, g / 255, b / 255, a / 255);\n }\n throw new Error(\"Malformed hexadecimal color string: '\" + str + \"'\");\n };\n Color.stringToRgba = function (str) {\n // Find positions of opening and closing parentheses.\n var _a = __read([NaN, NaN], 2), po = _a[0], pc = _a[1];\n for (var i = 0; i < str.length; i++) {\n var c = str[i];\n if (!po && c === '(') {\n po = i;\n }\n else if (c === ')') {\n pc = i;\n break;\n }\n }\n var contents = po && pc && str.substring(po + 1, pc);\n if (!contents) {\n return;\n }\n var parts = contents.split(',');\n var rgba = [];\n for (var i = 0; i < parts.length; i++) {\n var part = parts[i];\n var value = parseFloat(part);\n if (isNaN(value)) {\n return;\n }\n if (part.indexOf('%') >= 0) { // percentage r, g, or b value\n value = Math.max(0, Math.min(100, value));\n value /= 100;\n }\n else {\n if (i === 3) { // alpha component\n value = Math.max(0, Math.min(1, value));\n }\n else { // absolute r, g, or b value\n value = Math.max(0, Math.min(255, value));\n value /= 255;\n }\n }\n rgba.push(value);\n }\n return rgba;\n };\n Color.fromRgbaString = function (str) {\n var rgba = Color.stringToRgba(str);\n if (rgba) {\n if (rgba.length === 3) {\n return new Color(rgba[0], rgba[1], rgba[2]);\n }\n else if (rgba.length === 4) {\n return new Color(rgba[0], rgba[1], rgba[2], rgba[3]);\n }\n }\n throw new Error(\"Malformed rgb/rgba color string: '\" + str + \"'\");\n };\n Color.fromArray = function (arr) {\n if (arr.length === 4) {\n return new Color(arr[0], arr[1], arr[2], arr[3]);\n }\n if (arr.length === 3) {\n return new Color(arr[0], arr[1], arr[2]);\n }\n throw new Error('The given array should contain 3 or 4 color components (numbers).');\n };\n Color.fromHSB = function (h, s, b, alpha) {\n if (alpha === void 0) { alpha = 1; }\n var rgb = Color.HSBtoRGB(h, s, b);\n return new Color(rgb[0], rgb[1], rgb[2], alpha);\n };\n Color.padHex = function (str) {\n // Can't use `padStart(2, '0')` here because of IE.\n return str.length === 1 ? '0' + str : str;\n };\n Color.prototype.toHexString = function () {\n var hex = '#'\n + Color.padHex(Math.round(this.r * 255).toString(16))\n + Color.padHex(Math.round(this.g * 255).toString(16))\n + Color.padHex(Math.round(this.b * 255).toString(16));\n if (this.a < 1) {\n hex += Color.padHex(Math.round(this.a * 255).toString(16));\n }\n return hex;\n };\n Color.prototype.toRgbaString = function (fractionDigits) {\n if (fractionDigits === void 0) { fractionDigits = 3; }\n var components = [\n Math.round(this.r * 255),\n Math.round(this.g * 255),\n Math.round(this.b * 255)\n ];\n var k = Math.pow(10, fractionDigits);\n if (this.a !== 1) {\n components.push(Math.round(this.a * k) / k);\n return \"rgba(\" + components.join(', ') + \")\";\n }\n return \"rgb(\" + components.join(', ') + \")\";\n };\n Color.prototype.toString = function () {\n if (this.a === 1) {\n return this.toHexString();\n }\n return this.toRgbaString();\n };\n Color.prototype.toHSB = function () {\n return Color.RGBtoHSB(this.r, this.g, this.b);\n };\n /**\n * Converts the given RGB triple to an array of HSB (HSV) components.\n * The hue component will be `NaN` for achromatic colors.\n */\n Color.RGBtoHSB = function (r, g, b) {\n var min = Math.min(r, g, b);\n var max = Math.max(r, g, b);\n var S = max !== 0 ? (max - min) / max : 0;\n var H = NaN;\n // min == max, means all components are the same\n // and the color is a shade of gray with no hue (H is NaN)\n if (min !== max) {\n var delta = max - min;\n var rc = (max - r) / delta;\n var gc = (max - g) / delta;\n var bc = (max - b) / delta;\n if (r === max) {\n H = bc - gc;\n }\n else if (g === max) {\n H = 2.0 + rc - bc;\n }\n else {\n H = 4.0 + gc - rc;\n }\n H /= 6.0;\n if (H < 0) {\n H = H + 1.0;\n }\n }\n return [H * 360, S, max];\n };\n /**\n * Converts the given HSB (HSV) triple to an array of RGB components.\n */\n Color.HSBtoRGB = function (H, S, B) {\n if (isNaN(H)) {\n H = 0;\n }\n H = (((H % 360) + 360) % 360) / 360; // normalize hue to [0, 360] interval, then scale to [0, 1]\n var r = 0;\n var g = 0;\n var b = 0;\n if (S === 0) {\n r = g = b = B;\n }\n else {\n var h = (H - Math.floor(H)) * 6;\n var f = h - Math.floor(h);\n var p = B * (1 - S);\n var q = B * (1 - S * f);\n var t = B * (1 - (S * (1 - f)));\n switch (h >> 0) { // discard the floating point part of the number\n case 0:\n r = B;\n g = t;\n b = p;\n break;\n case 1:\n r = q;\n g = B;\n b = p;\n break;\n case 2:\n r = p;\n g = B;\n b = t;\n break;\n case 3:\n r = p;\n g = q;\n b = B;\n break;\n case 4:\n r = t;\n g = p;\n b = B;\n break;\n case 5:\n r = B;\n g = p;\n b = q;\n break;\n }\n }\n return [r, g, b];\n };\n Color.prototype.derive = function (hueShift, saturationFactor, brightnessFactor, opacityFactor) {\n var hsb = Color.RGBtoHSB(this.r, this.g, this.b);\n var b = hsb[2];\n if (b == 0 && brightnessFactor > 1.0) {\n b = 0.05;\n }\n var h = (((hsb[0] + hueShift) % 360) + 360) % 360;\n var s = Math.max(Math.min(hsb[1] * saturationFactor, 1.0), 0.0);\n b = Math.max(Math.min(b * brightnessFactor, 1.0), 0.0);\n var a = Math.max(Math.min(this.a * opacityFactor, 1.0), 0.0);\n var rgba = Color.HSBtoRGB(h, s, b);\n rgba.push(a);\n return Color.fromArray(rgba);\n };\n Color.prototype.brighter = function () {\n return this.derive(0, 1.0, 1.0 / 0.7, 1.0);\n };\n Color.prototype.darker = function () {\n return this.derive(0, 1.0, 0.7, 1.0);\n };\n /**\n * CSS Color Module Level 4:\n * https://drafts.csswg.org/css-color/#named-colors\n */\n Color.nameToHex = Object.freeze({\n aliceblue: '#F0F8FF',\n antiquewhite: '#FAEBD7',\n aqua: '#00FFFF',\n aquamarine: '#7FFFD4',\n azure: '#F0FFFF',\n beige: '#F5F5DC',\n bisque: '#FFE4C4',\n black: '#000000',\n blanchedalmond: '#FFEBCD',\n blue: '#0000FF',\n blueviolet: '#8A2BE2',\n brown: '#A52A2A',\n burlywood: '#DEB887',\n cadetblue: '#5F9EA0',\n chartreuse: '#7FFF00',\n chocolate: '#D2691E',\n coral: '#FF7F50',\n cornflowerblue: '#6495ED',\n cornsilk: '#FFF8DC',\n crimson: '#DC143C',\n cyan: '#00FFFF',\n darkblue: '#00008B',\n darkcyan: '#008B8B',\n darkgoldenrod: '#B8860B',\n darkgray: '#A9A9A9',\n darkgreen: '#006400',\n darkgrey: '#A9A9A9',\n darkkhaki: '#BDB76B',\n darkmagenta: '#8B008B',\n darkolivegreen: '#556B2F',\n darkorange: '#FF8C00',\n darkorchid: '#9932CC',\n darkred: '#8B0000',\n darksalmon: '#E9967A',\n darkseagreen: '#8FBC8F',\n darkslateblue: '#483D8B',\n darkslategray: '#2F4F4F',\n darkslategrey: '#2F4F4F',\n darkturquoise: '#00CED1',\n darkviolet: '#9400D3',\n deeppink: '#FF1493',\n deepskyblue: '#00BFFF',\n dimgray: '#696969',\n dimgrey: '#696969',\n dodgerblue: '#1E90FF',\n firebrick: '#B22222',\n floralwhite: '#FFFAF0',\n forestgreen: '#228B22',\n fuchsia: '#FF00FF',\n gainsboro: '#DCDCDC',\n ghostwhite: '#F8F8FF',\n gold: '#FFD700',\n goldenrod: '#DAA520',\n gray: '#808080',\n green: '#008000',\n greenyellow: '#ADFF2F',\n grey: '#808080',\n honeydew: '#F0FFF0',\n hotpink: '#FF69B4',\n indianred: '#CD5C5C',\n indigo: '#4B0082',\n ivory: '#FFFFF0',\n khaki: '#F0E68C',\n lavender: '#E6E6FA',\n lavenderblush: '#FFF0F5',\n lawngreen: '#7CFC00',\n lemonchiffon: '#FFFACD',\n lightblue: '#ADD8E6',\n lightcoral: '#F08080',\n lightcyan: '#E0FFFF',\n lightgoldenrodyellow: '#FAFAD2',\n lightgray: '#D3D3D3',\n lightgreen: '#90EE90',\n lightgrey: '#D3D3D3',\n lightpink: '#FFB6C1',\n lightsalmon: '#FFA07A',\n lightseagreen: '#20B2AA',\n lightskyblue: '#87CEFA',\n lightslategray: '#778899',\n lightslategrey: '#778899',\n lightsteelblue: '#B0C4DE',\n lightyellow: '#FFFFE0',\n lime: '#00FF00',\n limegreen: '#32CD32',\n linen: '#FAF0E6',\n magenta: '#FF00FF',\n maroon: '#800000',\n mediumaquamarine: '#66CDAA',\n mediumblue: '#0000CD',\n mediumorchid: '#BA55D3',\n mediumpurple: '#9370DB',\n mediumseagreen: '#3CB371',\n mediumslateblue: '#7B68EE',\n mediumspringgreen: '#00FA9A',\n mediumturquoise: '#48D1CC',\n mediumvioletred: '#C71585',\n midnightblue: '#191970',\n mintcream: '#F5FFFA',\n mistyrose: '#FFE4E1',\n moccasin: '#FFE4B5',\n navajowhite: '#FFDEAD',\n navy: '#000080',\n oldlace: '#FDF5E6',\n olive: '#808000',\n olivedrab: '#6B8E23',\n orange: '#FFA500',\n orangered: '#FF4500',\n orchid: '#DA70D6',\n palegoldenrod: '#EEE8AA',\n palegreen: '#98FB98',\n paleturquoise: '#AFEEEE',\n palevioletred: '#DB7093',\n papayawhip: '#FFEFD5',\n peachpuff: '#FFDAB9',\n peru: '#CD853F',\n pink: '#FFC0CB',\n plum: '#DDA0DD',\n powderblue: '#B0E0E6',\n purple: '#800080',\n rebeccapurple: '#663399',\n red: '#FF0000',\n rosybrown: '#BC8F8F',\n royalblue: '#4169E1',\n saddlebrown: '#8B4513',\n salmon: '#FA8072',\n sandybrown: '#F4A460',\n seagreen: '#2E8B57',\n seashell: '#FFF5EE',\n sienna: '#A0522D',\n silver: '#C0C0C0',\n skyblue: '#87CEEB',\n slateblue: '#6A5ACD',\n slategray: '#708090',\n slategrey: '#708090',\n snow: '#FFFAFA',\n springgreen: '#00FF7F',\n steelblue: '#4682B4',\n tan: '#D2B48C',\n teal: '#008080',\n thistle: '#D8BFD8',\n tomato: '#FF6347',\n turquoise: '#40E0D0',\n violet: '#EE82EE',\n wheat: '#F5DEB3',\n white: '#FFFFFF',\n whitesmoke: '#F5F5F5',\n yellow: '#FFFF00',\n yellowgreen: '#9ACD32'\n });\n return Color;\n}());\nexport { Color };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\n// Based on https://stackoverflow.com/a/14991797\n// This will parse a delimited string into an array of arrays.\nexport function stringToArray(strData, delimiter) {\n if (delimiter === void 0) { delimiter = ','; }\n var data = [];\n var isNewline = function (char) { return char === '\\r' || char === '\\n'; };\n var insideQuotedField = false;\n if (strData === '') {\n return [['']];\n }\n var _loop_1 = function (row, column, position) {\n var previousChar = strData[position - 1];\n var currentChar = strData[position];\n var nextChar = strData[position + 1];\n var ensureDataExists = function () {\n if (!data[row]) {\n // create row if it doesn't exist\n data[row] = [];\n }\n if (!data[row][column]) {\n // create column if it doesn't exist\n data[row][column] = '';\n }\n };\n ensureDataExists();\n if (currentChar === '\"') {\n if (insideQuotedField) {\n if (nextChar === '\"') {\n // unescape double quote\n data[row][column] += '\"';\n position++;\n }\n else {\n // exit quoted field\n insideQuotedField = false;\n }\n return out_row_1 = row, out_column_1 = column, out_position_1 = position, \"continue\";\n }\n else if (previousChar === undefined || previousChar === delimiter || isNewline(previousChar)) {\n // enter quoted field\n insideQuotedField = true;\n return out_row_1 = row, out_column_1 = column, out_position_1 = position, \"continue\";\n }\n }\n if (!insideQuotedField) {\n if (currentChar === delimiter) {\n // move to next column\n column++;\n ensureDataExists();\n return out_row_1 = row, out_column_1 = column, out_position_1 = position, \"continue\";\n }\n else if (isNewline(currentChar)) {\n // move to next row\n column = 0;\n row++;\n ensureDataExists();\n if (currentChar === '\\r' && nextChar === '\\n') {\n // skip over second newline character if it exists\n position++;\n }\n return out_row_1 = row, out_column_1 = column, out_position_1 = position, \"continue\";\n }\n }\n // add current character to current column\n data[row][column] += currentChar;\n out_row_1 = row;\n out_column_1 = column;\n out_position_1 = position;\n };\n var out_row_1, out_column_1, out_position_1;\n // iterate over each character, keep track of current row and column (of the returned array)\n for (var row = 0, column = 0, position = 0; position < strData.length; position++) {\n _loop_1(row, column, position);\n row = out_row_1;\n column = out_column_1;\n position = out_position_1;\n }\n return data;\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nimport { browserSupportsPreventScroll, isBrowserChrome, isBrowserSafari } from './browser';\nimport { exists } from './generic';\nimport { isNonNullObject } from './object';\nimport { hyphenToCamelCase } from './string';\nimport { Constants } from '../constants/constants';\nvar rtlNegativeScroll;\n/**\n * This method adds a class to an element and remove that class from all siblings.\n * Useful for toggling state.\n * @param {HTMLElement} element The element to receive the class\n * @param {string} elementClass The class to be assigned to the element\n * @param {boolean} otherElementClass The class to be assigned to siblings of the element, but not the element itself\n */\nexport function radioCssClass(element, elementClass, otherElementClass) {\n var parent = element.parentElement;\n var sibling = parent && parent.firstChild;\n while (sibling) {\n if (elementClass) {\n sibling.classList.toggle(elementClass, sibling === element);\n }\n if (otherElementClass) {\n sibling.classList.toggle(otherElementClass, sibling !== element);\n }\n sibling = sibling.nextSibling;\n }\n}\nexport function isFocusableFormField(element) {\n var matches = Element.prototype.matches || Element.prototype.msMatchesSelector;\n var isFocusable = matches.call(element, Constants.INPUT_SELECTOR);\n var isNotFocusable = matches.call(element, Constants.FOCUSABLE_EXCLUDE);\n var isElementVisible = isVisible(element);\n var focusable = isFocusable && !isNotFocusable && isElementVisible;\n return focusable;\n}\nexport function setDisplayed(element, displayed) {\n element.classList.toggle('ag-hidden', !displayed);\n}\nexport function setVisible(element, visible) {\n element.classList.toggle('ag-invisible', !visible);\n}\nexport function setDisabled(element, disabled) {\n var attributeName = 'disabled';\n var addOrRemoveDisabledAttribute = disabled ?\n function (e) { return e.setAttribute(attributeName, ''); } :\n function (e) { return e.removeAttribute(attributeName); };\n addOrRemoveDisabledAttribute(element);\n nodeListForEach(element.querySelectorAll('input'), function (input) { return addOrRemoveDisabledAttribute(input); });\n}\nexport function isElementChildOfClass(element, cls, maxNest) {\n var counter = 0;\n while (element) {\n if (element.classList.contains(cls)) {\n return true;\n }\n element = element.parentElement;\n if (typeof maxNest == 'number') {\n if (++counter > maxNest) {\n break;\n }\n }\n else if (element === maxNest) {\n break;\n }\n }\n return false;\n}\n// returns back sizes as doubles instead of strings. similar to\n// getBoundingClientRect, however getBoundingClientRect does not:\n// a) work with fractions (eg browser is zooming)\n// b) has CSS transitions applied (eg CSS scale, browser zoom), which we don't want, we want the un-transitioned values\nexport function getElementSize(el) {\n var _a = window.getComputedStyle(el), height = _a.height, width = _a.width, paddingTop = _a.paddingTop, paddingRight = _a.paddingRight, paddingBottom = _a.paddingBottom, paddingLeft = _a.paddingLeft, marginTop = _a.marginTop, marginRight = _a.marginRight, marginBottom = _a.marginBottom, marginLeft = _a.marginLeft, boxSizing = _a.boxSizing;\n return {\n height: parseFloat(height),\n width: parseFloat(width),\n paddingTop: parseFloat(paddingTop),\n paddingRight: parseFloat(paddingRight),\n paddingBottom: parseFloat(paddingBottom),\n paddingLeft: parseFloat(paddingLeft),\n marginTop: parseFloat(marginTop),\n marginRight: parseFloat(marginRight),\n marginBottom: parseFloat(marginBottom),\n marginLeft: parseFloat(marginLeft),\n boxSizing: boxSizing\n };\n}\nexport function getInnerHeight(el) {\n var size = getElementSize(el);\n if (size.boxSizing === 'border-box') {\n return size.height - size.paddingTop - size.paddingBottom;\n }\n return size.height;\n}\nexport function getInnerWidth(el) {\n var size = getElementSize(el);\n if (size.boxSizing === 'border-box') {\n return size.width - size.paddingLeft - size.paddingRight;\n }\n return size.width;\n}\nexport function getAbsoluteHeight(el) {\n var size = getElementSize(el);\n var marginRight = size.marginBottom + size.marginTop;\n return Math.ceil(el.offsetHeight + marginRight);\n}\nexport function getAbsoluteWidth(el) {\n var size = getElementSize(el);\n var marginWidth = size.marginLeft + size.marginRight;\n return Math.ceil(el.offsetWidth + marginWidth);\n}\nexport function isRtlNegativeScroll() {\n if (typeof rtlNegativeScroll === \"boolean\") {\n return rtlNegativeScroll;\n }\n var template = document.createElement('div');\n template.style.direction = 'rtl';\n template.style.width = '1px';\n template.style.height = '1px';\n template.style.position = 'fixed';\n template.style.top = '0px';\n template.style.overflow = 'hidden';\n template.dir = 'rtl';\n template.innerHTML = /* html */\n \"
\\n \\n \\n
\";\n document.body.appendChild(template);\n template.scrollLeft = 1;\n rtlNegativeScroll = Math.floor(template.scrollLeft) === 0;\n document.body.removeChild(template);\n return rtlNegativeScroll;\n}\nexport function getScrollLeft(element, rtl) {\n var scrollLeft = element.scrollLeft;\n if (rtl) {\n // Absolute value - for FF that reports RTL scrolls in negative numbers\n scrollLeft = Math.abs(scrollLeft);\n if (isBrowserChrome() && !isRtlNegativeScroll()) {\n scrollLeft = element.scrollWidth - element.clientWidth - scrollLeft;\n }\n }\n return scrollLeft;\n}\nexport function setScrollLeft(element, value, rtl) {\n if (rtl) {\n // Chrome and Safari when doing RTL have the END position of the scroll as zero, not the start\n if (isRtlNegativeScroll()) {\n value *= -1;\n }\n else if (isBrowserSafari() || isBrowserChrome()) {\n value = element.scrollWidth - element.clientWidth - value;\n }\n }\n element.scrollLeft = value;\n}\nexport function clearElement(el) {\n while (el && el.firstChild) {\n el.removeChild(el.firstChild);\n }\n}\n/** @deprecated */\nexport function removeElement(parent, cssSelector) {\n removeFromParent(parent.querySelector(cssSelector));\n}\nexport function removeFromParent(node) {\n if (node && node.parentNode) {\n node.parentNode.removeChild(node);\n }\n}\nexport function isVisible(element) {\n return element.offsetParent !== null;\n}\n/**\n * Loads the template and returns it as an element. makes up for no simple way in\n * the dom api to load html directly, eg we cannot do this: document.createElement(template)\n * @param {string} template\n * @returns {HTMLElement}\n */\nexport function loadTemplate(template) {\n var tempDiv = document.createElement('div');\n tempDiv.innerHTML = (template || '').trim();\n return tempDiv.firstChild;\n}\nexport function appendHtml(eContainer, htmlTemplate) {\n if (eContainer.lastChild) {\n // https://developer.mozilla.org/en-US/docs/Web/API/Element/insertAdjacentHTML\n // we put the items at the start, so new items appear underneath old items,\n // so when expanding/collapsing groups, the new rows don't go on top of the\n // rows below that are moving our of the way\n eContainer.insertAdjacentHTML('afterbegin', htmlTemplate);\n }\n else {\n eContainer.innerHTML = htmlTemplate;\n }\n}\n/** @deprecated */\nexport function getElementAttribute(element, attributeName) {\n if (element.attributes && element.attributes[attributeName]) {\n var attribute = element.attributes[attributeName];\n return attribute.value;\n }\n return null;\n}\nexport function offsetHeight(element) {\n return element && element.clientHeight ? element.clientHeight : 0;\n}\nexport function offsetWidth(element) {\n return element && element.clientWidth ? element.clientWidth : 0;\n}\nexport function ensureDomOrder(eContainer, eChild, eChildBefore) {\n // if already in right order, do nothing\n if (eChildBefore && eChildBefore.nextSibling === eChild) {\n return;\n }\n var focusedEl = document.activeElement;\n var eChildHasFocus = eChild.contains(focusedEl);\n if (eChildBefore) {\n if (eChildBefore.nextSibling) {\n // insert between the eRowBefore and the row after it\n eContainer.insertBefore(eChild, eChildBefore.nextSibling);\n }\n else {\n // if nextSibling is missing, means other row is at end, so just append new row at the end\n eContainer.appendChild(eChild);\n }\n }\n else {\n // otherwise put at start\n if (eContainer.firstChild && eContainer.firstChild !== eChild) {\n // insert it at the first location\n eContainer.insertAdjacentElement('afterbegin', eChild);\n }\n }\n if (eChildHasFocus && focusedEl && browserSupportsPreventScroll()) {\n focusedEl.focus({ preventScroll: true });\n }\n}\nexport function setDomChildOrder(eContainer, orderedChildren) {\n for (var i = 0; i < orderedChildren.length; i++) {\n var correctCellAtIndex = orderedChildren[i];\n var actualCellAtIndex = eContainer.children[i];\n if (actualCellAtIndex !== correctCellAtIndex) {\n eContainer.insertBefore(correctCellAtIndex, actualCellAtIndex);\n }\n }\n}\nexport function insertWithDomOrder(eContainer, eToInsert, eChildBefore) {\n if (eChildBefore) {\n // if previous element exists, just slot in after the previous element\n eChildBefore.insertAdjacentElement('afterend', eToInsert);\n }\n else {\n if (eContainer.firstChild) {\n // insert it at the first location\n eContainer.insertAdjacentElement('afterbegin', eToInsert);\n }\n else {\n // otherwise eContainer is empty, so just append it\n eContainer.appendChild(eToInsert);\n }\n }\n}\n/** @deprecated */\nexport function prependDC(parent, documentFragment) {\n if (exists(parent.firstChild)) {\n parent.insertBefore(documentFragment, parent.firstChild);\n }\n else {\n parent.appendChild(documentFragment);\n }\n}\nexport function addStylesToElement(eElement, styles) {\n if (!styles) {\n return;\n }\n Object.keys(styles).forEach(function (key) {\n var keyCamelCase = hyphenToCamelCase(key);\n if (keyCamelCase) {\n eElement.style[keyCamelCase] = styles[key];\n }\n });\n}\nexport function isHorizontalScrollShowing(element) {\n return element.clientWidth < element.scrollWidth;\n}\nexport function isVerticalScrollShowing(element) {\n return element.clientHeight < element.scrollHeight;\n}\nexport function setElementWidth(element, width) {\n if (width === 'flex') {\n element.style.removeProperty('width');\n element.style.removeProperty('minWidth');\n element.style.removeProperty('maxWidth');\n element.style.flex = '1 1 auto';\n }\n else {\n setFixedWidth(element, width);\n }\n}\nexport function setFixedWidth(element, width) {\n width = formatSize(width);\n element.style.width = width.toString();\n element.style.maxWidth = width.toString();\n element.style.minWidth = width.toString();\n}\nexport function setElementHeight(element, height) {\n if (height === 'flex') {\n element.style.removeProperty('height');\n element.style.removeProperty('minHeight');\n element.style.removeProperty('maxHeight');\n element.style.flex = '1 1 auto';\n }\n else {\n setFixedHeight(element, height);\n }\n}\nexport function setFixedHeight(element, height) {\n height = formatSize(height);\n element.style.height = height.toString();\n element.style.maxHeight = height.toString();\n element.style.minHeight = height.toString();\n}\nexport function formatSize(size) {\n if (typeof size === 'number') {\n return size + \"px\";\n }\n return size;\n}\n/**\n * Returns true if it is a DOM node\n * taken from: http://stackoverflow.com/questions/384286/javascript-isdom-how-do-you-check-if-a-javascript-object-is-a-dom-object\n * @param {any} o\n * @return {boolean}\n */\nexport function isNode(o) {\n return (typeof Node === 'function'\n ? o instanceof Node\n : o && typeof o === 'object' && typeof o.nodeType === 'number' && typeof o.nodeName === 'string');\n}\n//\n/**\n * Returns true if it is a DOM element\n * taken from: http://stackoverflow.com/questions/384286/javascript-isdom-how-do-you-check-if-a-javascript-object-is-a-dom-object\n * @param {any} o\n * @returns {boolean}\n */\nexport function isElement(o) {\n return (typeof HTMLElement === 'function'\n ? o instanceof HTMLElement //DOM2\n : o && isNonNullObject(o) && o.nodeType === 1 && typeof o.nodeName === 'string');\n}\nexport function isNodeOrElement(o) {\n return isNode(o) || isElement(o);\n}\n/**\n * Makes a copy of a node list into a list\n * @param {NodeList} nodeList\n * @returns {Node[]}\n */\nexport function copyNodeList(nodeList) {\n if (nodeList == null) {\n return [];\n }\n var result = [];\n nodeListForEach(nodeList, function (node) { return result.push(node); });\n return result;\n}\nexport function iterateNamedNodeMap(map, callback) {\n if (!map) {\n return;\n }\n for (var i = 0; i < map.length; i++) {\n var attr = map[i];\n callback(attr.name, attr.value);\n }\n}\n/** @deprecated */\nexport function setCheckboxState(eCheckbox, state) {\n if (typeof state === 'boolean') {\n eCheckbox.checked = state;\n eCheckbox.indeterminate = false;\n }\n else {\n // isNodeSelected returns back undefined if it's a group and the children\n // are a mix of selected and unselected\n eCheckbox.indeterminate = true;\n }\n}\nexport function addOrRemoveAttribute(element, name, value) {\n if (value == null) {\n element.removeAttribute(name);\n }\n else {\n element.setAttribute(name, value.toString());\n }\n}\nexport function nodeListForEach(nodeList, action) {\n if (nodeList == null) {\n return;\n }\n for (var i = 0; i < nodeList.length; i++) {\n action(nodeList[i]);\n }\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nimport { loadTemplate } from './dom';\nimport { camelCaseToHyphen } from './string';\nimport { iterateObject } from './object';\n/** @deprecated */\nexport function getNameOfClass(theClass) {\n var funcNameRegex = /function (.{1,})\\(/;\n var funcAsString = theClass.toString();\n var results = funcNameRegex.exec(funcAsString);\n return results && results.length > 1 ? results[1] : \"\";\n}\nexport function findLineByLeastSquares(values) {\n var len = values.length;\n var maxDecimals = 0;\n if (len <= 1) {\n return values;\n }\n for (var i = 0; i < values.length; i++) {\n var value = values[i];\n var splitExponent = value.toString().split('e-');\n if (splitExponent.length > 1) {\n maxDecimals = Math.max(maxDecimals, parseInt(splitExponent[1], 10));\n continue;\n }\n if (Math.floor(value) === value) {\n continue;\n }\n maxDecimals = Math.max(maxDecimals, value.toString().split('.')[1].length);\n }\n var sum_x = 0;\n var sum_y = 0;\n var sum_xy = 0;\n var sum_xx = 0;\n var y = 0;\n for (var x = 0; x < len; x++) {\n y = values[x];\n sum_x += x;\n sum_y += y;\n sum_xx += x * x;\n sum_xy += x * y;\n }\n var m = (len * sum_xy - sum_x * sum_y) / (len * sum_xx - sum_x * sum_x);\n var b = (sum_y / len) - (m * sum_x) / len;\n var result = [];\n for (var x = 0; x <= len; x++) {\n result.push(parseFloat((x * m + b).toFixed(maxDecimals)));\n }\n return result;\n}\n/**\n * Converts a CSS object into string\n * @param {Object} stylesToUse an object eg: {color: 'black', top: '25px'}\n * @return {string} A string like \"color: black; top: 25px;\" for html\n */\nexport function cssStyleObjectToMarkup(stylesToUse) {\n if (!stylesToUse) {\n return '';\n }\n var resParts = [];\n iterateObject(stylesToUse, function (styleKey, styleValue) {\n var styleKeyDashed = camelCaseToHyphen(styleKey);\n resParts.push(styleKeyDashed + \": \" + styleValue + \";\");\n });\n return resParts.join(' ');\n}\n/**\n * Displays a message to the browser. this is useful in iPad, where you can't easily see the console.\n * so the javascript code can use this to give feedback. this is NOT intended to be called in production.\n * it is intended the AG Grid developer calls this to troubleshoot, but then takes out the calls before\n * checking in.\n * @param {string} msg\n */\nexport function message(msg) {\n var eMessage = document.createElement('div');\n var eBox = document.querySelector('#__ag__message');\n eMessage.innerHTML = msg;\n if (!eBox) {\n var template = \"
\";\n eBox = loadTemplate(template);\n if (document.body) {\n document.body.appendChild(eBox);\n }\n }\n eBox.insertBefore(eMessage, eBox.children[0]);\n}\n/**\n * cell renderers are used in a few places. they bind to dom slightly differently to other cell renderes as they\n * can return back strings (instead of html elemnt) in the getGui() method. common code placed here to handle that.\n * @param {AgPromise} cellRendererPromise\n * @param {HTMLElement} eTarget\n */\nexport function bindCellRendererToHtmlElement(cellRendererPromise, eTarget) {\n cellRendererPromise.then(function (cellRenderer) {\n var gui = cellRenderer.getGui();\n if (gui != null) {\n if (typeof gui === 'object') {\n eTarget.appendChild(gui);\n }\n else {\n eTarget.innerHTML = gui;\n }\n }\n });\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\n// ARIA HELPER FUNCTIONS\nfunction setAriaAttribute(element, attribute, value) {\n element.setAttribute(ariaAttributeName(attribute), value.toString());\n}\nfunction removeAriaAttribute(element, attribute) {\n element.removeAttribute(ariaAttributeName(attribute));\n}\nfunction ariaAttributeName(attribute) {\n return \"aria-\" + attribute;\n}\nexport function setAriaRole(element, role) {\n if (role) {\n element.setAttribute('role', role);\n }\n else {\n element.removeAttribute('role');\n }\n}\nexport function getAriaSortState(column) {\n var sort;\n if (column.isSortAscending()) {\n sort = 'ascending';\n }\n else if (column.isSortDescending()) {\n sort = 'descending';\n }\n else {\n sort = 'none';\n }\n return sort;\n}\n// ARIA ATTRIBUTE GETTERS\nexport function getAriaLevel(element) {\n return parseInt(element.getAttribute('aria-level'), 10);\n}\nexport function getAriaPosInSet(element) {\n return parseInt(element.getAttribute('aria-posinset'), 10);\n}\nexport function getAriaDescribedBy(element) {\n return element.getAttribute('aria-describedby') || '';\n}\n// ARIA ATTRIBUTE SETTERS\nexport function setAriaLabel(element, label) {\n var key = 'label';\n if (label) {\n setAriaAttribute(element, key, label);\n }\n else {\n removeAriaAttribute(element, key);\n }\n}\nexport function setAriaLabelledBy(element, labelledBy) {\n var key = 'labelledby';\n if (labelledBy) {\n setAriaAttribute(element, key, labelledBy);\n }\n else {\n removeAriaAttribute(element, key);\n }\n}\nexport function setAriaDescription(element, description) {\n var key = 'description';\n if (description) {\n setAriaAttribute(element, key, description);\n }\n else {\n removeAriaAttribute(element, key);\n }\n}\nexport function setAriaDescribedBy(element, describedby) {\n var key = 'describedby';\n if (describedby) {\n setAriaAttribute(element, key, describedby);\n }\n else {\n removeAriaAttribute(element, key);\n }\n}\nexport function setAriaLevel(element, level) {\n setAriaAttribute(element, 'level', level);\n}\nexport function setAriaDisabled(element, disabled) {\n setAriaAttribute(element, 'disabled', disabled);\n}\nexport function setAriaExpanded(element, expanded) {\n setAriaAttribute(element, 'expanded', expanded);\n}\nexport function removeAriaExpanded(element) {\n removeAriaAttribute(element, 'expanded');\n}\nexport function setAriaSetSize(element, setsize) {\n setAriaAttribute(element, 'setsize', setsize);\n}\nexport function setAriaPosInSet(element, position) {\n setAriaAttribute(element, 'posinset', position);\n}\nexport function setAriaMultiSelectable(element, multiSelectable) {\n setAriaAttribute(element, 'multiselectable', multiSelectable);\n}\nexport function setAriaRowCount(element, rowCount) {\n setAriaAttribute(element, 'rowcount', rowCount);\n}\nexport function setAriaRowIndex(element, rowIndex) {\n setAriaAttribute(element, 'rowindex', rowIndex);\n}\nexport function setAriaColCount(element, colCount) {\n setAriaAttribute(element, 'colcount', colCount);\n}\nexport function setAriaColIndex(element, colIndex) {\n setAriaAttribute(element, 'colindex', colIndex);\n}\nexport function setAriaColSpan(element, colSpan) {\n setAriaAttribute(element, 'colspan', colSpan);\n}\nexport function setAriaSort(element, sort) {\n setAriaAttribute(element, 'sort', sort);\n}\nexport function removeAriaSort(element) {\n removeAriaAttribute(element, 'sort');\n}\nexport function setAriaSelected(element, selected) {\n var attributeName = 'selected';\n if (selected) {\n setAriaAttribute(element, attributeName, selected);\n }\n else {\n removeAriaAttribute(element, attributeName);\n }\n}\nexport function setAriaChecked(element, checked) {\n setAriaAttribute(element, 'checked', checked === undefined ? 'mixed' : checked);\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nimport { padStartWidthZeros } from './number';\n/**\n * Serialises a Date to a string of format `yyyy-MM-dd HH:mm:ss`.\n * An alternative separator can be provided to be used instead of hyphens.\n * @param date The date to serialise\n * @param includeTime Whether to include the time in the serialised string\n * @param separator The separator to use between date parts\n */\nexport function serialiseDate(date, includeTime, separator) {\n if (includeTime === void 0) { includeTime = true; }\n if (separator === void 0) { separator = '-'; }\n if (!date) {\n return null;\n }\n var serialised = [date.getFullYear(), date.getMonth() + 1, date.getDate()].map(function (part) { return padStartWidthZeros(part, 2); }).join(separator);\n if (includeTime) {\n serialised += ' ' + [date.getHours(), date.getMinutes(), date.getSeconds()].map(function (part) { return padStartWidthZeros(part, 2); }).join(':');\n }\n return serialised;\n}\nvar calculateOrdinal = function (value) {\n if (value > 3 && value < 21) {\n return 'th';\n }\n var remainder = value % 10;\n switch (remainder) {\n case 1: return \"st\";\n case 2: return \"nd\";\n case 3: return \"rd\";\n }\n return 'th';\n};\n/**\n * Serialises a Date to a string of format the defined format, does not include time.\n * @param date The date to serialise\n * @param format The string to format the date to, defaults to YYYY-MM-DD\n */\nexport function dateToFormattedString(date, format) {\n if (format === void 0) { format = 'YYYY-MM-DD'; }\n var fullYear = padStartWidthZeros(date.getFullYear(), 4);\n var months = [\n 'January', 'February', 'March', 'April', 'May', 'June',\n 'July', 'August', 'September', 'October', 'November', 'December',\n ];\n var days = [\n 'Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday',\n ];\n var replace = {\n YYYY: function () { return fullYear.slice(fullYear.length - 4, fullYear.length); },\n YY: function () { return fullYear.slice(fullYear.length - 2, fullYear.length); },\n Y: function () { return \"\" + date.getFullYear(); },\n MMMM: function () { return months[date.getMonth()]; },\n MMM: function () { return months[date.getMonth()].slice(0, 3); },\n MM: function () { return padStartWidthZeros(date.getMonth() + 1, 2); },\n Mo: function () { return \"\" + (date.getMonth() + 1) + calculateOrdinal(date.getMonth() + 1); },\n M: function () { return \"\" + (date.getMonth() + 1); },\n Do: function () { return \"\" + date.getDate() + calculateOrdinal(date.getDate()); },\n DD: function () { return padStartWidthZeros(date.getDate(), 2); },\n D: function () { return \"\" + date.getDate(); },\n dddd: function () { return days[date.getDay()]; },\n ddd: function () { return days[date.getDay()].slice(0, 3); },\n dd: function () { return days[date.getDay()].slice(0, 2); },\n do: function () { return \"\" + date.getDay() + calculateOrdinal(date.getDay()); },\n d: function () { return \"\" + date.getDay(); },\n };\n var regexp = new RegExp(Object.keys(replace).join('|'), 'g');\n return format.replace(regexp, function (match) {\n if (match in replace) {\n return replace[match]();\n }\n return match;\n });\n}\n/**\n * Parses a date and time from a string in the format `yyyy-MM-dd HH:mm:ss`\n */\nexport function parseDateTimeFromString(value) {\n if (!value) {\n return null;\n }\n var _a = __read(value.split(' '), 2), dateStr = _a[0], timeStr = _a[1];\n if (!dateStr) {\n return null;\n }\n var fields = dateStr.split('-').map(function (f) { return parseInt(f, 10); });\n if (fields.filter(function (f) { return !isNaN(f); }).length !== 3) {\n return null;\n }\n var _b = __read(fields, 3), year = _b[0], month = _b[1], day = _b[2];\n var date = new Date(year, month - 1, day);\n if (date.getFullYear() !== year ||\n date.getMonth() !== month - 1 ||\n date.getDate() !== day) {\n // date was not parsed as expected so must have been invalid\n return null;\n }\n if (!timeStr || timeStr === '00:00:00') {\n return date;\n }\n var _c = __read(timeStr.split(':').map(function (part) { return parseInt(part, 10); }), 3), hours = _c[0], minutes = _c[1], seconds = _c[2];\n if (hours >= 0 && hours < 24) {\n date.setHours(hours);\n }\n if (minutes >= 0 && minutes < 60) {\n date.setMinutes(minutes);\n }\n if (seconds >= 0 && seconds < 60) {\n date.setSeconds(seconds);\n }\n return date;\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nimport { loadTemplate, isNodeOrElement } from './dom';\nimport { setAriaRole } from './aria';\n//\n// IMPORTANT NOTE!\n//\n// If you change the list below, copy/paste the new content into the docs page javascript-grid-icons\n//\nexport var iconNameClassMap = {\n // header column group shown when expanded (click to contract)\n columnGroupOpened: 'expanded',\n // header column group shown when contracted (click to expand)\n columnGroupClosed: 'contracted',\n // tool panel column group contracted (click to expand)\n columnSelectClosed: 'tree-closed',\n // tool panel column group expanded (click to contract)\n columnSelectOpen: 'tree-open',\n // column tool panel header expand/collapse all button, shown when some children are expanded and\n // others are collapsed\n columnSelectIndeterminate: 'tree-indeterminate',\n // shown on ghost icon while dragging column to the side of the grid to pin\n columnMovePin: 'pin',\n // shown on ghost icon while dragging over part of the page that is not a drop zone\n columnMoveHide: 'eye-slash',\n // shown on ghost icon while dragging columns to reorder\n columnMoveMove: 'arrows',\n // animating icon shown when dragging a column to the right of the grid causes horizontal scrolling\n columnMoveLeft: 'left',\n // animating icon shown when dragging a column to the left of the grid causes horizontal scrolling\n columnMoveRight: 'right',\n // shown on ghost icon while dragging over Row Groups drop zone\n columnMoveGroup: 'group',\n // shown on ghost icon while dragging over Values drop zone\n columnMoveValue: 'aggregation',\n // shown on ghost icon while dragging over pivot drop zone\n columnMovePivot: 'pivot',\n // shown on ghost icon while dragging over drop zone that doesn't support it, e.g.\n // string column over aggregation drop zone\n dropNotAllowed: 'not-allowed',\n // shown on row group when contracted (click to expand)\n groupContracted: 'tree-closed',\n // shown on row group when expanded (click to contract)\n groupExpanded: 'tree-open',\n // context menu chart item\n chart: 'chart',\n // chart window title bar\n close: 'cross',\n // X (remove) on column 'pill' after adding it to a drop zone list\n cancel: 'cancel',\n // indicates the currently active pin state in the \"Pin column\" sub-menu of the column menu\n check: 'tick',\n // \"go to first\" button in pagination controls\n first: 'first',\n // \"go to previous\" button in pagination controls\n previous: 'previous',\n // \"go to next\" button in pagination controls\n next: 'next',\n // \"go to last\" button in pagination controls\n last: 'last',\n // shown on top right of chart when chart is linked to range data (click to unlink)\n linked: 'linked',\n // shown on top right of chart when chart is not linked to range data (click to link)\n unlinked: 'unlinked',\n // \"Choose colour\" button on chart settings tab\n colorPicker: 'color-picker',\n // rotating spinner shown by the loading cell renderer\n groupLoading: 'loading',\n // button to launch enterprise column menu\n menu: 'menu',\n // filter tool panel tab\n filter: 'filter',\n // column tool panel tab\n columns: 'columns',\n // button in chart regular size window title bar (click to maximise)\n maximize: 'maximize',\n // button in chart maximised window title bar (click to make regular size)\n minimize: 'minimize',\n // \"Pin column\" item in column header menu\n menuPin: 'pin',\n // \"Value aggregation\" column menu item (shown on numeric columns when grouping is active)\"\n menuValue: 'aggregation',\n // \"Group by {column-name}\" item in column header menu\n menuAddRowGroup: 'group',\n // \"Un-Group by {column-name}\" item in column header menu\n menuRemoveRowGroup: 'group',\n // context menu copy item\n clipboardCopy: 'copy',\n // context menu paste item\n clipboardPaste: 'paste',\n // identifies the pivot drop zone\n pivotPanel: 'pivot',\n // \"Row groups\" drop zone in column tool panel\n rowGroupPanel: 'group',\n // columns tool panel Values drop zone\n valuePanel: 'aggregation',\n // drag handle used to pick up draggable columns\n columnDrag: 'grip',\n // drag handle used to pick up draggable rows\n rowDrag: 'grip',\n // context menu export item\n save: 'save',\n // csv export\n csvExport: 'csv',\n // excel export,\n excelExport: 'excel',\n // icon on dropdown editors\n smallDown: 'small-down',\n // version of small-right used in RTL mode\n smallLeft: 'small-left',\n // separater between column 'pills' when you add multiple columns to the header drop zone\n smallRight: 'small-right',\n smallUp: 'small-up',\n // show on column header when column is sorted ascending\n sortAscending: 'asc',\n // show on column header when column is sorted descending\n sortDescending: 'desc',\n // show on column header when column has no sort, only when enabled with gridOptions.unSortIcon=true\n sortUnSort: 'none'\n};\n/**\n * If icon provided, use this (either a string, or a function callback).\n * if not, then use the default icon from the theme\n * @param {string} iconName\n * @param {GridOptionsWrapper} gridOptionsWrapper\n * @param {Column | null} [column]\n * @returns {HTMLElement}\n */\nexport function createIcon(iconName, gridOptionsWrapper, column) {\n var iconContents = createIconNoSpan(iconName, gridOptionsWrapper, column);\n if (iconContents && iconContents.className.indexOf('ag-icon') > -1) {\n return iconContents;\n }\n var eResult = document.createElement('span');\n eResult.appendChild(iconContents);\n return eResult;\n}\nexport function createIconNoSpan(iconName, gridOptionsWrapper, column, forceCreate) {\n var userProvidedIcon = null;\n // check col for icon first\n var icons = column && column.getColDef().icons;\n if (icons) {\n userProvidedIcon = icons[iconName];\n }\n // if not in col, try grid options\n if (gridOptionsWrapper && !userProvidedIcon) {\n var optionsIcons = gridOptionsWrapper.getIcons();\n if (optionsIcons) {\n userProvidedIcon = optionsIcons[iconName];\n }\n }\n // now if user provided, use it\n if (userProvidedIcon) {\n var rendererResult = void 0;\n if (typeof userProvidedIcon === 'function') {\n rendererResult = userProvidedIcon();\n }\n else if (typeof userProvidedIcon === 'string') {\n rendererResult = userProvidedIcon;\n }\n else {\n throw new Error('icon from grid options needs to be a string or a function');\n }\n if (typeof rendererResult === 'string') {\n return loadTemplate(rendererResult);\n }\n if (isNodeOrElement(rendererResult)) {\n return rendererResult;\n }\n console.warn('AG Grid: iconRenderer should return back a string or a dom object');\n }\n else {\n var span = document.createElement('span');\n var cssClass = iconNameClassMap[iconName];\n if (!cssClass) {\n if (!forceCreate) {\n console.warn(\"AG Grid: Did not find icon \" + iconName);\n cssClass = '';\n }\n else {\n cssClass = iconName;\n }\n }\n span.setAttribute('class', \"ag-icon ag-icon-\" + cssClass);\n span.setAttribute('unselectable', 'on');\n setAriaRole(span, 'presentation');\n return span;\n }\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar KeyCode = /** @class */ (function () {\n function KeyCode() {\n }\n KeyCode.BACKSPACE = 'Backspace';\n KeyCode.TAB = 'Tab';\n KeyCode.ENTER = 'Enter';\n KeyCode.ESCAPE = 'Escape';\n KeyCode.SPACE = ' ';\n KeyCode.LEFT = 'ArrowLeft';\n KeyCode.UP = 'ArrowUp';\n KeyCode.RIGHT = 'ArrowRight';\n KeyCode.DOWN = 'ArrowDown';\n KeyCode.DELETE = 'Delete';\n KeyCode.F2 = 'F2';\n KeyCode.PAGE_UP = 'PageUp';\n KeyCode.PAGE_DOWN = 'PageDown';\n KeyCode.PAGE_HOME = 'Home';\n KeyCode.PAGE_END = 'End';\n // these should be used with `event.code` instead of `event.key`\n // as `event.key` changes when non-latin keyboards are used\n KeyCode.A = 'KeyA';\n KeyCode.C = 'KeyC';\n KeyCode.V = 'KeyV';\n KeyCode.D = 'KeyD';\n KeyCode.Z = 'KeyZ';\n KeyCode.Y = 'KeyY';\n return KeyCode;\n}());\nexport { KeyCode };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nimport { isBrowserEdge } from './browser';\nimport { exists } from './generic';\nimport { KeyCode } from '../constants/keyCode';\nvar NUMPAD_DEL_NUMLOCK_ON_KEY = 'Del';\n// Using legacy values to match AZERTY keyboards\nvar NUMPAD_DEL_NUMLOCK_ON_KEYCODE = 46;\nvar A_KEYCODE = 65;\nvar C_KEYCODE = 67;\nvar V_KEYCODE = 86;\nvar D_KEYCODE = 68;\nvar Z_KEYCODE = 90;\nvar Y_KEYCODE = 89;\nexport function isEventFromPrintableCharacter(event) {\n // no allowed printable chars have alt or ctrl key combinations\n if (event.altKey || event.ctrlKey || event.metaKey) {\n return false;\n }\n // if key is length 1, eg if it is 'a' for the a key, or '2' for the '2' key.\n // non-printable characters have names, eg 'Enter' or 'Backspace'.\n var printableCharacter = event.key.length === 1;\n // IE11 & Edge treat the numpad del key differently - with numlock on we get \"Del\" for key,\n // so this addition checks if its IE11/Edge and handles that specific case the same was as all other browsers\n var numpadDelWithNumlockOnForEdgeOrIe = isNumpadDelWithNumLockOnForEdge(event);\n return printableCharacter || numpadDelWithNumlockOnForEdgeOrIe;\n}\n/**\n * Allows user to tell the grid to skip specific keyboard events\n * @param {GridOptionsWrapper} gridOptionsWrapper\n * @param {KeyboardEvent} keyboardEvent\n * @param {RowNode} rowNode\n * @param {Column} column\n * @param {boolean} editing\n * @returns {boolean}\n */\nexport function isUserSuppressingKeyboardEvent(gridOptionsWrapper, keyboardEvent, rowNode, column, editing) {\n var gridOptionsFunc = gridOptionsWrapper.getSuppressKeyboardEventFunc();\n var colDefFunc = column ? column.getColDef().suppressKeyboardEvent : undefined;\n // if no callbacks provided by user, then do nothing\n if (!gridOptionsFunc && !colDefFunc) {\n return false;\n }\n var params = {\n event: keyboardEvent,\n editing: editing,\n column: column,\n api: gridOptionsWrapper.getApi(),\n node: rowNode,\n data: rowNode.data,\n colDef: column.getColDef(),\n context: gridOptionsWrapper.getContext(),\n columnApi: gridOptionsWrapper.getColumnApi()\n };\n // colDef get first preference on suppressing events\n if (colDefFunc) {\n var colDefFuncResult = colDefFunc(params);\n // if colDef func suppressed, then return now, no need to call gridOption func\n if (colDefFuncResult) {\n return true;\n }\n }\n if (gridOptionsFunc) {\n // if gridOption func, return the result\n return gridOptionsFunc(params);\n }\n // otherwise return false, don't suppress, as colDef didn't suppress and no func on gridOptions\n return false;\n}\nexport function isUserSuppressingHeaderKeyboardEvent(gridOptionsWrapper, keyboardEvent, headerRowIndex, column) {\n var colDef = column.getDefinition();\n var colDefFunc = colDef && colDef.suppressHeaderKeyboardEvent;\n if (!exists(colDefFunc)) {\n return false;\n }\n var params = {\n api: gridOptionsWrapper.getApi(),\n columnApi: gridOptionsWrapper.getColumnApi(),\n context: gridOptionsWrapper.getContext(),\n colDef: colDef,\n column: column,\n headerRowIndex: headerRowIndex,\n event: keyboardEvent\n };\n return !!colDefFunc(params);\n}\nfunction isNumpadDelWithNumLockOnForEdge(event) {\n return (isBrowserEdge()) &&\n event.key === NUMPAD_DEL_NUMLOCK_ON_KEY &&\n event.charCode === NUMPAD_DEL_NUMLOCK_ON_KEYCODE;\n}\nexport function normaliseQwertyAzerty(keyboardEvent) {\n var keyCode = keyboardEvent.keyCode;\n var code;\n switch (keyCode) {\n case A_KEYCODE:\n code = KeyCode.A;\n break;\n case C_KEYCODE:\n code = KeyCode.C;\n break;\n case V_KEYCODE:\n code = KeyCode.V;\n break;\n case D_KEYCODE:\n code = KeyCode.D;\n break;\n case Z_KEYCODE:\n code = KeyCode.Z;\n break;\n case Y_KEYCODE:\n code = KeyCode.Y;\n break;\n default:\n code = keyboardEvent.code;\n }\n return code;\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\n/**\n * `True` if the event is close to the original event by X pixels either vertically or horizontally.\n * we only start dragging after X pixels so this allows us to know if we should start dragging yet.\n * @param {MouseEvent | TouchEvent} e1\n * @param {MouseEvent | TouchEvent} e2\n * @param {number} pixelCount\n * @returns {boolean}\n */\nexport function areEventsNear(e1, e2, pixelCount) {\n // by default, we wait 4 pixels before starting the drag\n if (pixelCount === 0) {\n return false;\n }\n var diffX = Math.abs(e1.clientX - e2.clientX);\n var diffY = Math.abs(e1.clientY - e2.clientY);\n return Math.max(diffX, diffY) <= pixelCount;\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\n/**\n * Gets called by: a) ClientSideNodeManager and b) GroupStage to do sorting.\n * when in ClientSideNodeManager we always have indexes (as this sorts the items the\n * user provided) but when in GroupStage, the nodes can contain filler nodes that\n * don't have order id's\n * @param {RowNode[]} rowNodes\n * @param {Object} rowNodeOrder\n */\nexport function sortRowNodesByOrder(rowNodes, rowNodeOrder) {\n if (!rowNodes) {\n return;\n }\n var comparator = function (nodeA, nodeB) {\n var positionA = rowNodeOrder[nodeA.id];\n var positionB = rowNodeOrder[nodeB.id];\n var aHasIndex = positionA !== undefined;\n var bHasIndex = positionB !== undefined;\n var bothNodesAreUserNodes = aHasIndex && bHasIndex;\n var bothNodesAreFillerNodes = !aHasIndex && !bHasIndex;\n if (bothNodesAreUserNodes) {\n // when comparing two nodes the user has provided, they always\n // have indexes\n return positionA - positionB;\n }\n if (bothNodesAreFillerNodes) {\n // when comparing two filler nodes, we have no index to compare them\n // against, however we want this sorting to be deterministic, so that\n // the rows don't jump around as the user does delta updates. so we\n // want the same sort result. so we use the __objectId - which doesn't make sense\n // from a sorting point of view, but does give consistent behaviour between\n // calls. otherwise groups jump around as delta updates are done.\n // note: previously here we used nodeId, however this gave a strange order\n // as string ordering of numbers is wrong, so using id based on creation order\n // as least gives better looking order.\n return nodeA.__objectId - nodeB.__objectId;\n }\n if (aHasIndex) {\n return 1;\n }\n return -1;\n };\n // check if the list first needs sorting\n var rowNodeA;\n var rowNodeB;\n var atLeastOneOutOfOrder = false;\n for (var i = 0; i < rowNodes.length - 1; i++) {\n rowNodeA = rowNodes[i];\n rowNodeB = rowNodes[i + 1];\n if (comparator(rowNodeA, rowNodeB) > 0) {\n atLeastOneOutOfOrder = true;\n break;\n }\n }\n if (atLeastOneOutOfOrder) {\n rowNodes.sort(comparator);\n }\n}\nexport function traverseNodesWithKey(nodes, callback) {\n var keyParts = [];\n recursiveSearchNodes(nodes);\n function recursiveSearchNodes(currentNodes) {\n if (!currentNodes) {\n return;\n }\n currentNodes.forEach(function (node) {\n // also checking for children for tree data\n if (node.group || node.hasChildren()) {\n keyParts.push(node.key);\n var key = keyParts.join('|');\n callback(node, key);\n recursiveSearchNodes(node.childrenAfterGroup);\n keyParts.pop();\n }\n });\n }\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nexport function convertToSet(list) {\n var set = new Set();\n list.forEach(function (x) { return set.add(x); });\n return set;\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nimport * as GeneralUtils from './general';\nimport * as AriaUtils from './aria';\nimport * as ArrayUtils from './array';\nimport * as BrowserUtils from './browser';\nimport * as CsvUtils from './csv';\nimport * as DateUtils from './date';\nimport * as DomUtils from './dom';\nimport * as EventUtils from './event';\nimport * as FunctionUtils from './function';\nimport * as FuzzyMatchUtils from './fuzzyMatch';\nimport * as GenericUtils from './generic';\nimport * as IconUtils from './icon';\nimport * as KeyboardUtils from './keyboard';\nimport * as MapUtils from './map';\nimport * as MouseUtils from './mouse';\nimport * as NumberUtils from './number';\nimport * as ObjectUtils from './object';\nimport * as RowNodeUtils from './rowNode';\nimport * as SetUtils from './set';\nimport * as StringUtils from './string';\nvar utils = __assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign({}, GeneralUtils), AriaUtils), ArrayUtils), BrowserUtils), CsvUtils), DateUtils), DomUtils), EventUtils), FunctionUtils), FuzzyMatchUtils), GenericUtils), IconUtils), KeyboardUtils), MapUtils), MouseUtils), NumberUtils), ObjectUtils), RowNodeUtils), SetUtils), StringUtils);\nexport var _ = utils;\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar NumberSequence = /** @class */ (function () {\n function NumberSequence(initValue, step) {\n if (initValue === void 0) { initValue = 0; }\n if (step === void 0) { step = 1; }\n this.nextValue = initValue;\n this.step = step;\n }\n NumberSequence.prototype.next = function () {\n var valToReturn = this.nextValue;\n this.nextValue += this.step;\n return valToReturn;\n };\n NumberSequence.prototype.peek = function () {\n return this.nextValue;\n };\n NumberSequence.prototype.skip = function (count) {\n this.nextValue += count;\n };\n return NumberSequence;\n}());\nexport { NumberSequence };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nexport var AgPromiseStatus;\n(function (AgPromiseStatus) {\n AgPromiseStatus[AgPromiseStatus[\"IN_PROGRESS\"] = 0] = \"IN_PROGRESS\";\n AgPromiseStatus[AgPromiseStatus[\"RESOLVED\"] = 1] = \"RESOLVED\";\n})(AgPromiseStatus || (AgPromiseStatus = {}));\nvar AgPromise = /** @class */ (function () {\n function AgPromise(callback) {\n var _this = this;\n this.status = AgPromiseStatus.IN_PROGRESS;\n this.resolution = null;\n this.waiters = [];\n callback(function (value) { return _this.onDone(value); }, function (params) { return _this.onReject(params); });\n }\n AgPromise.all = function (promises) {\n return new AgPromise(function (resolve) {\n var remainingToResolve = promises.length;\n var combinedValues = new Array(remainingToResolve);\n promises.forEach(function (promise, index) {\n promise.then(function (value) {\n combinedValues[index] = value;\n remainingToResolve--;\n if (remainingToResolve === 0) {\n resolve(combinedValues);\n }\n });\n });\n });\n };\n AgPromise.resolve = function (value) {\n if (value === void 0) { value = null; }\n return new AgPromise(function (resolve) { return resolve(value); });\n };\n AgPromise.prototype.then = function (func) {\n var _this = this;\n return new AgPromise(function (resolve) {\n if (_this.status === AgPromiseStatus.RESOLVED) {\n resolve(func(_this.resolution));\n }\n else {\n _this.waiters.push(function (value) { return resolve(func(value)); });\n }\n });\n };\n AgPromise.prototype.resolveNow = function (ifNotResolvedValue, ifResolved) {\n return this.status === AgPromiseStatus.RESOLVED ? ifResolved(this.resolution) : ifNotResolvedValue;\n };\n AgPromise.prototype.onDone = function (value) {\n this.status = AgPromiseStatus.RESOLVED;\n this.resolution = value;\n this.waiters.forEach(function (waiter) { return waiter(value); });\n };\n AgPromise.prototype.onReject = function (params) {\n console.warn('TBI');\n };\n return AgPromise;\n}());\nexport { AgPromise };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { exists } from \"../utils/generic\";\nimport { isIOSUserAgent } from \"../utils/browser\";\nvar TooltipStates;\n(function (TooltipStates) {\n TooltipStates[TooltipStates[\"NOTHING\"] = 0] = \"NOTHING\";\n TooltipStates[TooltipStates[\"WAITING_TO_SHOW\"] = 1] = \"WAITING_TO_SHOW\";\n TooltipStates[TooltipStates[\"SHOWING\"] = 2] = \"SHOWING\";\n})(TooltipStates || (TooltipStates = {}));\nvar CustomTooltipFeature = /** @class */ (function (_super) {\n __extends(CustomTooltipFeature, _super);\n function CustomTooltipFeature(parentComp) {\n var _this = _super.call(this) || this;\n _this.DEFAULT_SHOW_TOOLTIP_DELAY = 2000;\n _this.DEFAULT_HIDE_TOOLTIP_DELAY = 10000;\n _this.SHOW_QUICK_TOOLTIP_DIFF = 1000;\n _this.FADE_OUT_TOOLTIP_TIMEOUT = 1000;\n _this.state = TooltipStates.NOTHING;\n // when showing the tooltip, we need to make sure it's the most recent instance we request, as due to\n // async we could request two tooltips before the first instance returns, in which case we should\n // disregard the second instance.\n _this.tooltipInstanceCount = 0;\n _this.tooltipMouseTrack = false;\n _this.parentComp = parentComp;\n return _this;\n }\n CustomTooltipFeature.prototype.postConstruct = function () {\n this.tooltipShowDelay = this.gridOptionsWrapper.getTooltipDelay('show') || this.DEFAULT_SHOW_TOOLTIP_DELAY;\n this.tooltipHideDelay = this.gridOptionsWrapper.getTooltipDelay('hide') || this.DEFAULT_HIDE_TOOLTIP_DELAY;\n this.tooltipMouseTrack = this.gridOptionsWrapper.isTooltipMouseTrack();\n var el = this.parentComp.getGui();\n this.addManagedListener(el, 'mouseenter', this.onMouseEnter.bind(this));\n this.addManagedListener(el, 'mouseleave', this.onMouseLeave.bind(this));\n this.addManagedListener(el, 'mousemove', this.onMouseMove.bind(this));\n this.addManagedListener(el, 'mousedown', this.onMouseDown.bind(this));\n this.addManagedListener(el, 'keydown', this.onKeyDown.bind(this));\n };\n CustomTooltipFeature.prototype.destroy = function () {\n // if this component gets destroyed while tooltip is showing, need to make sure\n // we don't end with no mouseLeave event resulting in zombie tooltip\n this.setToDoNothing();\n _super.prototype.destroy.call(this);\n };\n CustomTooltipFeature.prototype.onMouseEnter = function (e) {\n if (isIOSUserAgent()) {\n return;\n }\n // every mouseenter should be following by a mouseleave, however for some unkonwn, it's possible for\n // mouseenter to be called twice in a row, which can happen if editing the cell. this was reported\n // in https://ag-grid.atlassian.net/browse/AG-4422. to get around this, we check the state, and if\n // state is !=nothing, then we know mouseenter was already received.\n if (this.state != TooltipStates.NOTHING) {\n return;\n }\n // if another tooltip was hidden very recently, we only wait 200ms to show, not the normal waiting time\n var delay = this.isLastTooltipHiddenRecently() ? 200 : this.tooltipShowDelay;\n this.showTooltipTimeoutId = window.setTimeout(this.showTooltip.bind(this), delay);\n this.lastMouseEvent = e;\n this.state = TooltipStates.WAITING_TO_SHOW;\n };\n CustomTooltipFeature.prototype.onMouseLeave = function () {\n this.setToDoNothing();\n };\n CustomTooltipFeature.prototype.onKeyDown = function () {\n this.setToDoNothing();\n };\n CustomTooltipFeature.prototype.setToDoNothing = function () {\n if (this.state === TooltipStates.SHOWING) {\n this.hideTooltip();\n }\n this.clearTimeouts();\n this.state = TooltipStates.NOTHING;\n };\n CustomTooltipFeature.prototype.onMouseMove = function (e) {\n // there is a delay from the time we mouseOver a component and the time the\n // tooltip is displayed, so we need to track mousemove to be able to correctly\n // position the tooltip when showTooltip is called.\n this.lastMouseEvent = e;\n if (this.tooltipMouseTrack &&\n this.state === TooltipStates.SHOWING &&\n this.tooltipComp) {\n this.positionTooltipUnderLastMouseEvent();\n }\n };\n CustomTooltipFeature.prototype.onMouseDown = function () {\n this.setToDoNothing();\n };\n CustomTooltipFeature.prototype.hideTooltip = function () {\n // check if comp exists - due to async, although we asked for\n // one, the instance may not be back yet\n if (this.tooltipComp) {\n this.destroyTooltipComp();\n CustomTooltipFeature.lastTooltipHideTime = new Date().getTime();\n }\n this.state = TooltipStates.NOTHING;\n };\n CustomTooltipFeature.prototype.destroyTooltipComp = function () {\n var _this = this;\n // add class to fade out the tooltip\n this.tooltipComp.getGui().classList.add('ag-tooltip-hiding');\n // make local copies of these variables, as we use them in the async function below,\n // and we clear then to 'undefined' later, so need to take a copy before they are undefined.\n var tooltipPopupDestroyFunc = this.tooltipPopupDestroyFunc;\n var tooltipComp = this.tooltipComp;\n window.setTimeout(function () {\n tooltipPopupDestroyFunc();\n _this.getContext().destroyBean(tooltipComp);\n }, this.FADE_OUT_TOOLTIP_TIMEOUT);\n this.tooltipPopupDestroyFunc = undefined;\n this.tooltipComp = undefined;\n };\n CustomTooltipFeature.prototype.isLastTooltipHiddenRecently = function () {\n // return true if <1000ms since last time we hid a tooltip\n var now = new Date().getTime();\n var then = CustomTooltipFeature.lastTooltipHideTime;\n return (now - then) < this.SHOW_QUICK_TOOLTIP_DIFF;\n };\n CustomTooltipFeature.prototype.showTooltip = function () {\n var params = __assign({}, this.parentComp.getTooltipParams());\n if (!exists(params.value)) {\n this.setToDoNothing();\n return;\n }\n this.state = TooltipStates.SHOWING;\n this.tooltipInstanceCount++;\n // we pass in tooltipInstanceCount so the callback knows what the count was when\n // we requested the tooltip, so if another tooltip was requested in the mean time\n // we disregard it\n var callback = this.newTooltipComponentCallback.bind(this, this.tooltipInstanceCount);\n var userDetails = this.userComponentFactory.getTooltipCompDetails(params);\n userDetails.newAgStackInstance().then(callback);\n };\n CustomTooltipFeature.prototype.newTooltipComponentCallback = function (tooltipInstanceCopy, tooltipComp) {\n var compNoLongerNeeded = this.state !== TooltipStates.SHOWING || this.tooltipInstanceCount !== tooltipInstanceCopy;\n if (compNoLongerNeeded) {\n this.getContext().destroyBean(tooltipComp);\n return;\n }\n var eGui = tooltipComp.getGui();\n this.tooltipComp = tooltipComp;\n if (!eGui.classList.contains('ag-tooltip')) {\n eGui.classList.add('ag-tooltip-custom');\n }\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n var addPopupRes = this.popupService.addPopup({\n eChild: eGui,\n ariaLabel: translate('ariaLabelTooltip', 'Tooltip')\n });\n if (addPopupRes) {\n this.tooltipPopupDestroyFunc = addPopupRes.hideFunc;\n }\n // this.tooltipPopupDestroyFunc = this.popupService.addPopup(false, eGui, false);\n this.positionTooltipUnderLastMouseEvent();\n this.hideTooltipTimeoutId = window.setTimeout(this.hideTooltip.bind(this), this.tooltipHideDelay);\n };\n CustomTooltipFeature.prototype.positionTooltipUnderLastMouseEvent = function () {\n this.popupService.positionPopupUnderMouseEvent({\n type: 'tooltip',\n mouseEvent: this.lastMouseEvent,\n ePopup: this.tooltipComp.getGui(),\n nudgeY: 18\n });\n };\n CustomTooltipFeature.prototype.clearTimeouts = function () {\n if (this.showTooltipTimeoutId) {\n window.clearTimeout(this.showTooltipTimeoutId);\n this.showTooltipTimeoutId = undefined;\n }\n if (this.hideTooltipTimeoutId) {\n window.clearTimeout(this.hideTooltipTimeoutId);\n this.hideTooltipTimeoutId = undefined;\n }\n };\n __decorate([\n Autowired('popupService')\n ], CustomTooltipFeature.prototype, \"popupService\", void 0);\n __decorate([\n Autowired('userComponentFactory')\n ], CustomTooltipFeature.prototype, \"userComponentFactory\", void 0);\n __decorate([\n Autowired('columnApi')\n ], CustomTooltipFeature.prototype, \"columnApi\", void 0);\n __decorate([\n Autowired('gridApi')\n ], CustomTooltipFeature.prototype, \"gridApi\", void 0);\n __decorate([\n PostConstruct\n ], CustomTooltipFeature.prototype, \"postConstruct\", null);\n return CustomTooltipFeature;\n}(BeanStub));\nexport { CustomTooltipFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar CssClassManager = /** @class */ (function () {\n function CssClassManager(getGui) {\n // to minimise DOM hits, we only apply CSS classes if they have changed. as adding a CSS class that is already\n // there, or removing one that wasn't present, all takes CPU.\n this.cssClassStates = {};\n this.getGui = getGui;\n }\n CssClassManager.prototype.addCssClass = function (className) {\n var _this = this;\n var list = (className || '').split(' ');\n if (list.length > 1) {\n list.forEach(function (cls) { return _this.addCssClass(cls); });\n return;\n }\n var updateNeeded = this.cssClassStates[className] !== true;\n if (updateNeeded && className.length) {\n this.getGui().classList.add(className);\n this.cssClassStates[className] = true;\n }\n };\n CssClassManager.prototype.removeCssClass = function (className) {\n var _this = this;\n var list = (className || '').split(' ');\n if (list.length > 1) {\n list.forEach(function (cls) { return _this.removeCssClass(cls); });\n return;\n }\n var updateNeeded = this.cssClassStates[className] !== false;\n if (updateNeeded && className.length) {\n this.getGui().classList.remove(className);\n this.cssClassStates[className] = false;\n }\n };\n CssClassManager.prototype.containsCssClass = function (className) {\n return this.getGui().classList.contains(className);\n };\n CssClassManager.prototype.addOrRemoveCssClass = function (className, addOrRemove) {\n var _this = this;\n if (!className) {\n return;\n }\n // we check for spaces before doing the split, as doing the split\n // created a performance problem (on windows only, see AG-6765)\n if (className.indexOf(' ') >= 0) {\n var list = (className || '').split(' ');\n if (list.length > 1) {\n list.forEach(function (cls) { return _this.addOrRemoveCssClass(cls, addOrRemove); });\n return;\n }\n }\n var updateNeeded = this.cssClassStates[className] !== addOrRemove;\n if (updateNeeded && className.length) {\n this.getGui().classList.toggle(className, addOrRemove);\n this.cssClassStates[className] = addOrRemove;\n }\n };\n return CssClassManager;\n}());\nexport { CssClassManager };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PreConstruct } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { NumberSequence } from \"../utils\";\nimport { isNodeOrElement, copyNodeList, iterateNamedNodeMap, loadTemplate, setVisible, setDisplayed } from '../utils/dom';\nimport { getFunctionName } from '../utils/function';\nimport { CustomTooltipFeature } from \"./customTooltipFeature\";\nimport { CssClassManager } from \"../rendering/cssClassManager\";\nvar compIdSequence = new NumberSequence();\nvar Component = /** @class */ (function (_super) {\n __extends(Component, _super);\n function Component(template) {\n var _this = _super.call(this) || this;\n // if false, then CSS class \"ag-hidden\" is applied, which sets \"display: none\"\n _this.displayed = true;\n // if false, then CSS class \"ag-invisible\" is applied, which sets \"visibility: hidden\"\n _this.visible = true;\n // unique id for this row component. this is used for getting a reference to the HTML dom.\n // we cannot use the RowNode id as this is not unique (due to animation, old rows can be lying\n // around as we create a new rowComp instance for the same row node).\n _this.compId = compIdSequence.next();\n _this.cssClassManager = new CssClassManager(function () { return _this.eGui; });\n if (template) {\n _this.setTemplate(template);\n }\n return _this;\n }\n Component.prototype.preConstructOnComponent = function () {\n this.usingBrowserTooltips = this.gridOptionsWrapper.isEnableBrowserTooltips();\n };\n Component.prototype.getCompId = function () {\n return this.compId;\n };\n Component.prototype.getTooltipParams = function () {\n return {\n value: this.tooltipText,\n location: 'UNKNOWN'\n };\n };\n Component.prototype.setTooltip = function (newTooltipText) {\n var _this = this;\n var removeTooltip = function () {\n if (_this.usingBrowserTooltips) {\n _this.getGui().removeAttribute('title');\n }\n else {\n _this.tooltipFeature = _this.destroyBean(_this.tooltipFeature);\n }\n };\n var addTooltip = function () {\n if (_this.usingBrowserTooltips) {\n _this.getGui().setAttribute('title', _this.tooltipText);\n }\n else {\n _this.tooltipFeature = _this.createBean(new CustomTooltipFeature(_this));\n }\n };\n if (this.tooltipText != newTooltipText) {\n if (this.tooltipText) {\n removeTooltip();\n }\n if (newTooltipText != null) {\n this.tooltipText = newTooltipText;\n if (this.tooltipText) {\n addTooltip();\n }\n }\n }\n };\n // for registered components only, eg creates AgCheckbox instance from ag-checkbox HTML tag\n Component.prototype.createChildComponentsFromTags = function (parentNode, paramsMap) {\n var _this = this;\n // we MUST take a copy of the list first, as the 'swapComponentForNode' adds comments into the DOM\n // which messes up the traversal order of the children.\n var childNodeList = copyNodeList(parentNode.childNodes);\n childNodeList.forEach(function (childNode) {\n if (!(childNode instanceof HTMLElement)) {\n return;\n }\n var childComp = _this.createComponentFromElement(childNode, function (childComp) {\n // copy over all attributes, including css classes, so any attributes user put on the tag\n // wll be carried across\n var childGui = childComp.getGui();\n if (childGui) {\n _this.copyAttributesFromNode(childNode, childComp.getGui());\n }\n }, paramsMap);\n if (childComp) {\n if (childComp.addItems && childNode.children.length) {\n _this.createChildComponentsFromTags(childNode, paramsMap);\n // converting from HTMLCollection to Array\n var items = Array.prototype.slice.call(childNode.children);\n childComp.addItems(items);\n }\n // replace the tag (eg ag-checkbox) with the proper HTMLElement (eg 'div') in the dom\n _this.swapComponentForNode(childComp, parentNode, childNode);\n }\n else if (childNode.childNodes) {\n _this.createChildComponentsFromTags(childNode, paramsMap);\n }\n });\n };\n Component.prototype.createComponentFromElement = function (element, afterPreCreateCallback, paramsMap) {\n var key = element.nodeName;\n var componentParams = paramsMap ? paramsMap[element.getAttribute('ref')] : undefined;\n var ComponentClass = this.agStackComponentsRegistry.getComponentClass(key);\n if (ComponentClass) {\n Component.elementGettingCreated = element;\n var newComponent = new ComponentClass(componentParams);\n newComponent.setParentComponent(this);\n this.createBean(newComponent, null, afterPreCreateCallback);\n return newComponent;\n }\n return null;\n };\n Component.prototype.copyAttributesFromNode = function (source, dest) {\n iterateNamedNodeMap(source.attributes, function (name, value) { return dest.setAttribute(name, value); });\n };\n Component.prototype.swapComponentForNode = function (newComponent, parentNode, childNode) {\n var eComponent = newComponent.getGui();\n parentNode.replaceChild(eComponent, childNode);\n parentNode.insertBefore(document.createComment(childNode.nodeName), eComponent);\n this.addDestroyFunc(this.destroyBean.bind(this, newComponent));\n this.swapInComponentForQuerySelectors(newComponent, childNode);\n };\n Component.prototype.swapInComponentForQuerySelectors = function (newComponent, childNode) {\n var thisNoType = this;\n this.iterateOverQuerySelectors(function (querySelector) {\n if (thisNoType[querySelector.attributeName] === childNode) {\n thisNoType[querySelector.attributeName] = newComponent;\n }\n });\n };\n Component.prototype.iterateOverQuerySelectors = function (action) {\n var thisPrototype = Object.getPrototypeOf(this);\n while (thisPrototype != null) {\n var metaData = thisPrototype.__agComponentMetaData;\n var currentProtoName = getFunctionName(thisPrototype.constructor);\n if (metaData && metaData[currentProtoName] && metaData[currentProtoName].querySelectors) {\n metaData[currentProtoName].querySelectors.forEach(function (querySelector) { return action(querySelector); });\n }\n thisPrototype = Object.getPrototypeOf(thisPrototype);\n }\n };\n Component.prototype.setTemplate = function (template, paramsMap) {\n var eGui = loadTemplate(template);\n this.setTemplateFromElement(eGui, paramsMap);\n };\n Component.prototype.setTemplateFromElement = function (element, paramsMap) {\n this.eGui = element;\n this.eGui.__agComponent = this;\n this.wireQuerySelectors();\n // context will not be available when user sets template in constructor\n if (!!this.getContext()) {\n this.createChildComponentsFromTags(this.getGui(), paramsMap);\n }\n };\n Component.prototype.createChildComponentsPreConstruct = function () {\n // ui exists if user sets template in constructor. when this happens, we have to wait for the context\n // to be autoWired first before we can create child components.\n if (!!this.getGui()) {\n this.createChildComponentsFromTags(this.getGui());\n }\n };\n Component.prototype.wireQuerySelectors = function () {\n var _this = this;\n if (!this.eGui) {\n return;\n }\n var thisNoType = this;\n this.iterateOverQuerySelectors(function (querySelector) {\n var setResult = function (result) { return thisNoType[querySelector.attributeName] = result; };\n // if it's a ref selector, and match is on top level component, we return\n // the element. otherwise no way of components putting ref=xxx on the top\n // level element as querySelector only looks at children.\n var topLevelRefMatch = querySelector.refSelector\n && _this.eGui.getAttribute('ref') === querySelector.refSelector;\n if (topLevelRefMatch) {\n setResult(_this.eGui);\n }\n else {\n // otherwise use querySelector, which looks at children\n var resultOfQuery = _this.eGui.querySelector(querySelector.querySelector);\n if (resultOfQuery) {\n setResult(resultOfQuery.__agComponent || resultOfQuery);\n }\n }\n });\n };\n Component.prototype.getGui = function () {\n return this.eGui;\n };\n Component.prototype.getFocusableElement = function () {\n return this.eGui;\n };\n Component.prototype.setParentComponent = function (component) {\n this.parentComponent = component;\n };\n Component.prototype.getParentComponent = function () {\n return this.parentComponent;\n };\n // this method is for older code, that wants to provide the gui element,\n // it is not intended for this to be in ag-Stack\n Component.prototype.setGui = function (eGui) {\n this.eGui = eGui;\n };\n Component.prototype.queryForHtmlElement = function (cssSelector) {\n return this.eGui.querySelector(cssSelector);\n };\n Component.prototype.queryForHtmlInputElement = function (cssSelector) {\n return this.eGui.querySelector(cssSelector);\n };\n Component.prototype.appendChild = function (newChild, container) {\n if (newChild == null) {\n return;\n }\n if (!container) {\n container = this.eGui;\n }\n if (isNodeOrElement(newChild)) {\n container.appendChild(newChild);\n }\n else {\n var childComponent = newChild;\n container.appendChild(childComponent.getGui());\n }\n };\n Component.prototype.isDisplayed = function () {\n return this.displayed;\n };\n Component.prototype.setVisible = function (visible) {\n if (visible !== this.visible) {\n this.visible = visible;\n setVisible(this.eGui, visible);\n }\n };\n Component.prototype.setDisplayed = function (displayed) {\n if (displayed !== this.displayed) {\n this.displayed = displayed;\n setDisplayed(this.eGui, displayed);\n var event_1 = {\n type: Component.EVENT_DISPLAYED_CHANGED,\n visible: this.displayed\n };\n this.dispatchEvent(event_1);\n }\n };\n Component.prototype.destroy = function () {\n if (this.tooltipFeature) {\n this.tooltipFeature = this.destroyBean(this.tooltipFeature);\n }\n _super.prototype.destroy.call(this);\n };\n Component.prototype.addGuiEventListener = function (event, listener) {\n var _this = this;\n this.eGui.addEventListener(event, listener);\n this.addDestroyFunc(function () { return _this.eGui.removeEventListener(event, listener); });\n };\n Component.prototype.addCssClass = function (className) {\n this.cssClassManager.addCssClass(className);\n };\n Component.prototype.removeCssClass = function (className) {\n this.cssClassManager.removeCssClass(className);\n };\n Component.prototype.containsCssClass = function (className) {\n return this.cssClassManager.containsCssClass(className);\n };\n Component.prototype.addOrRemoveCssClass = function (className, addOrRemove) {\n this.cssClassManager.addOrRemoveCssClass(className, addOrRemove);\n };\n Component.prototype.getAttribute = function (key) {\n var eGui = this.eGui;\n return eGui ? eGui.getAttribute(key) : null;\n };\n Component.prototype.getRefElement = function (refName) {\n return this.queryForHtmlElement(\"[ref=\\\"\" + refName + \"\\\"]\");\n };\n Component.EVENT_DISPLAYED_CHANGED = 'displayedChanged';\n __decorate([\n Autowired('agStackComponentsRegistry')\n ], Component.prototype, \"agStackComponentsRegistry\", void 0);\n __decorate([\n PreConstruct\n ], Component.prototype, \"preConstructOnComponent\", null);\n __decorate([\n PreConstruct\n ], Component.prototype, \"createChildComponentsPreConstruct\", null);\n return Component;\n}(BeanStub));\nexport { Component };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nimport { getFunctionName } from '../utils/function';\nexport function QuerySelector(selector) {\n return querySelectorFunc.bind(this, selector, undefined);\n}\nexport function RefSelector(ref) {\n return querySelectorFunc.bind(this, \"[ref=\" + ref + \"]\", ref);\n}\nfunction querySelectorFunc(selector, refSelector, classPrototype, methodOrAttributeName, index) {\n if (selector === null) {\n console.error('AG Grid: QuerySelector selector should not be null');\n return;\n }\n if (typeof index === 'number') {\n console.error('AG Grid: QuerySelector should be on an attribute');\n return;\n }\n addToObjectProps(classPrototype, 'querySelectors', {\n attributeName: methodOrAttributeName,\n querySelector: selector,\n refSelector: refSelector\n });\n}\n// // think we should take this out, put property bindings on the\n// export function Method(eventName?: string): Function {\n// return methodFunc.bind(this, eventName);\n// }\n//\n// function methodFunc(alias: string, target: Object, methodName: string) {\n// if (alias === null) {\n// console.error(\"AG Grid: EventListener eventName should not be null\");\n// return;\n// }\n//\n// addToObjectProps(target, 'methods', {\n// methodName: methodName,\n// alias: alias\n// });\n// }\nfunction addToObjectProps(target, key, value) {\n // it's an attribute on the class\n var props = getOrCreateProps(target, getFunctionName(target.constructor));\n if (!props[key]) {\n props[key] = [];\n }\n props[key].push(value);\n}\nfunction getOrCreateProps(target, instanceName) {\n if (!target.__agComponentMetaData) {\n target.__agComponentMetaData = {};\n }\n if (!target.__agComponentMetaData[instanceName]) {\n target.__agComponentMetaData[instanceName] = {};\n }\n return target.__agComponentMetaData[instanceName];\n}\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from '../../../widgets/component';\nimport { RefSelector } from '../../../widgets/componentAnnotations';\nimport { Autowired } from '../../../context/context';\n// optional floating filter for user provided filters - instead of providing a floating filter,\n// they can provide a getModelAsString() method on the filter instead. this class just displays\n// the string returned from getModelAsString()\nvar ReadOnlyFloatingFilter = /** @class */ (function (_super) {\n __extends(ReadOnlyFloatingFilter, _super);\n function ReadOnlyFloatingFilter() {\n return _super.call(this, /* html */ \"\\n
\\n \\n
\") || this;\n }\n // this is a user component, and IComponent has \"public destroy()\" as part of the interface.\n // so we need to override destroy() just to make the method public.\n ReadOnlyFloatingFilter.prototype.destroy = function () {\n _super.prototype.destroy.call(this);\n };\n ReadOnlyFloatingFilter.prototype.init = function (params) {\n this.params = params;\n var displayName = this.columnModel.getDisplayNameForColumn(params.column, 'header', true);\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n this.eFloatingFilterText\n .setDisabled(true)\n .setInputAriaLabel(displayName + \" \" + translate('ariaFilterInput', 'Filter Input'));\n };\n ReadOnlyFloatingFilter.prototype.onParentModelChanged = function (parentModel) {\n var _this = this;\n if (!parentModel) {\n this.eFloatingFilterText.setValue('');\n return;\n }\n this.params.parentFilterInstance(function (filterInstance) {\n // it would be nice to check if getModelAsString was present before creating this component,\n // however that is not possible, as React Hooks and VueJS don't attached the methods to the Filter until\n // AFTER the filter is created, not allowing inspection before this (we create floating filters as columns\n // are drawn, but the parent filters are only created when needed).\n if (filterInstance.getModelAsString) {\n var modelAsString = filterInstance.getModelAsString(parentModel);\n _this.eFloatingFilterText.setValue(modelAsString);\n }\n });\n };\n __decorate([\n RefSelector('eFloatingFilterText')\n ], ReadOnlyFloatingFilter.prototype, \"eFloatingFilterText\", void 0);\n __decorate([\n Autowired('columnModel')\n ], ReadOnlyFloatingFilter.prototype, \"columnModel\", void 0);\n return ReadOnlyFloatingFilter;\n}(Component));\nexport { ReadOnlyFloatingFilter };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nimport { setDisplayed } from '../../../utils/dom';\n/** Provides sync access to async component. Date component can be lazy created - this class encapsulates\n * this by keeping value locally until DateComp has loaded, then passing DateComp the value. */\nvar DateCompWrapper = /** @class */ (function () {\n function DateCompWrapper(context, userComponentFactory, dateComponentParams, eParent) {\n var _this = this;\n this.alive = true;\n this.context = context;\n this.eParent = eParent;\n var compDetails = userComponentFactory.getDateCompDetails(dateComponentParams);\n var promise = compDetails.newAgStackInstance();\n promise.then(function (dateComp) {\n // because async, check the filter still exists after component comes back\n if (!_this.alive) {\n context.destroyBean(dateComp);\n return;\n }\n _this.dateComp = dateComp;\n if (!dateComp) {\n return;\n }\n eParent.appendChild(dateComp.getGui());\n if (dateComp.afterGuiAttached) {\n dateComp.afterGuiAttached();\n }\n if (_this.tempValue) {\n dateComp.setDate(_this.tempValue);\n }\n if (_this.disabled != null) {\n _this.setDateCompDisabled(_this.disabled);\n }\n });\n }\n DateCompWrapper.prototype.destroy = function () {\n this.alive = false;\n this.dateComp = this.context.destroyBean(this.dateComp);\n };\n DateCompWrapper.prototype.getDate = function () {\n return this.dateComp ? this.dateComp.getDate() : this.tempValue;\n };\n DateCompWrapper.prototype.setDate = function (value) {\n if (this.dateComp) {\n this.dateComp.setDate(value);\n }\n else {\n this.tempValue = value;\n }\n };\n DateCompWrapper.prototype.setDisabled = function (disabled) {\n if (this.dateComp) {\n this.setDateCompDisabled(disabled);\n }\n else {\n this.disabled = disabled;\n }\n };\n DateCompWrapper.prototype.setDisplayed = function (displayed) {\n setDisplayed(this.eParent, displayed);\n };\n DateCompWrapper.prototype.setInputPlaceholder = function (placeholder) {\n if (this.dateComp && this.dateComp.setInputPlaceholder) {\n this.dateComp.setInputPlaceholder(placeholder);\n }\n };\n DateCompWrapper.prototype.setInputAriaLabel = function (label) {\n if (this.dateComp && this.dateComp.setInputAriaLabel) {\n this.dateComp.setInputAriaLabel(label);\n }\n };\n DateCompWrapper.prototype.afterGuiAttached = function (params) {\n if (this.dateComp && typeof this.dateComp.afterGuiAttached === 'function') {\n this.dateComp.afterGuiAttached(params);\n }\n };\n DateCompWrapper.prototype.setDateCompDisabled = function (disabled) {\n if (this.dateComp == null) {\n return;\n }\n if (this.dateComp.setDisabled == null) {\n return;\n }\n this.dateComp.setDisabled(disabled);\n };\n return DateCompWrapper;\n}());\nexport { DateCompWrapper };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\n/* Common logic for options, used by both filters and floating filters. */\nvar OptionsFactory = /** @class */ (function () {\n function OptionsFactory() {\n this.customFilterOptions = {};\n }\n OptionsFactory.prototype.init = function (params, defaultOptions) {\n this.filterOptions = params.filterOptions || defaultOptions;\n this.mapCustomOptions();\n this.selectDefaultItem(params);\n this.checkForDeprecatedParams();\n };\n OptionsFactory.prototype.checkForDeprecatedParams = function () {\n if (this.filterOptions.some(function (opt) { return typeof opt != 'string' && opt.test != null; })) {\n console.warn(\"AG Grid: [IFilterOptionDef] since v26.2.0, test() has been replaced with predicate().\");\n }\n if (this.filterOptions.some(function (opt) { return typeof opt != 'string' && opt.hideFilterInput != null; })) {\n console.warn(\"AG Grid: [IFilterOptionDef] since v26.2.0, useOfHideFilterInput has been replaced with numberOfInputs.\");\n }\n };\n OptionsFactory.prototype.getFilterOptions = function () {\n return this.filterOptions;\n };\n OptionsFactory.prototype.mapCustomOptions = function () {\n var _this = this;\n if (!this.filterOptions) {\n return;\n }\n this.filterOptions.forEach(function (filterOption) {\n if (typeof filterOption === 'string') {\n return;\n }\n var requiredProperties = [['displayKey'], ['displayName'], ['predicate', 'test']];\n var propertyCheck = function (keys) {\n if (!keys.some(function (key) { return filterOption[key] != null; })) {\n console.warn(\"AG Grid: ignoring FilterOptionDef as it doesn't contain one of '\" + keys + \"'\");\n return false;\n }\n return true;\n };\n if (!requiredProperties.every(propertyCheck)) {\n _this.filterOptions = _this.filterOptions.filter(function (v) { return v === filterOption; }) || [];\n return;\n }\n var test = filterOption.test;\n var mutatedFilterOptions = __assign({}, filterOption);\n if (test != null && filterOption.predicate == null) {\n mutatedFilterOptions.predicate = function (v, cv) { return test(v[0], cv); };\n delete mutatedFilterOptions.test;\n }\n if (mutatedFilterOptions.hideFilterInput && mutatedFilterOptions.numberOfInputs == null) {\n mutatedFilterOptions.numberOfInputs = 0;\n delete mutatedFilterOptions.hideFilterInput;\n }\n _this.customFilterOptions[filterOption.displayKey] = mutatedFilterOptions;\n });\n };\n OptionsFactory.prototype.selectDefaultItem = function (params) {\n if (params.defaultOption) {\n this.defaultOption = params.defaultOption;\n }\n else if (this.filterOptions.length >= 1) {\n var firstFilterOption = this.filterOptions[0];\n if (typeof firstFilterOption === 'string') {\n this.defaultOption = firstFilterOption;\n }\n else if (firstFilterOption.displayKey) {\n this.defaultOption = firstFilterOption.displayKey;\n }\n else {\n console.warn(\"AG Grid: invalid FilterOptionDef supplied as it doesn't contain a 'displayKey'\");\n }\n }\n else {\n console.warn('AG Grid: no filter options for filter');\n }\n };\n OptionsFactory.prototype.getDefaultOption = function () {\n return this.defaultOption;\n };\n OptionsFactory.prototype.getCustomOption = function (name) {\n return this.customFilterOptions[name];\n };\n return OptionsFactory;\n}());\nexport { OptionsFactory };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nexport var DEFAULT_FILTER_LOCALE_TEXT = {\n applyFilter: 'Apply',\n clearFilter: 'Clear',\n resetFilter: 'Reset',\n cancelFilter: 'Cancel',\n textFilter: 'Text Filter',\n numberFilter: 'Number Filter',\n dateFilter: 'Date Filter',\n setFilter: 'Set Filter',\n filterOoo: 'Filter...',\n empty: 'Choose One',\n equals: 'Equals',\n notEqual: 'Not equal',\n lessThan: 'Less than',\n greaterThan: 'Greater than',\n inRange: 'In range',\n inRangeStart: 'From',\n inRangeEnd: 'To',\n lessThanOrEqual: 'Less than or equals',\n greaterThanOrEqual: 'Greater than or equals',\n contains: 'Contains',\n notContains: 'Not contains',\n startsWith: 'Starts with',\n endsWith: 'Ends with',\n blank: 'Blank',\n notBlank: 'Not blank',\n andCondition: 'AND',\n orCondition: 'OR',\n dateFormatOoo: 'yyyy-mm-dd',\n};\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PostConstruct, Autowired } from '../context/context';\nimport { KeyCode } from '../constants/keyCode';\nimport { isStopPropagationForAgGrid, stopPropagationForAgGrid } from '../utils/event';\nimport { BeanStub } from '../context/beanStub';\nvar ManagedFocusFeature = /** @class */ (function (_super) {\n __extends(ManagedFocusFeature, _super);\n function ManagedFocusFeature(eFocusableElement, callbacks) {\n if (callbacks === void 0) { callbacks = {}; }\n var _this = _super.call(this) || this;\n _this.eFocusableElement = eFocusableElement;\n _this.callbacks = callbacks;\n _this.callbacks = __assign({ shouldStopEventPropagation: function () { return false; }, onTabKeyDown: function (e) {\n if (e.defaultPrevented) {\n return;\n }\n var nextRoot = _this.focusService.findNextFocusableElement(_this.eFocusableElement, false, e.shiftKey);\n if (!nextRoot) {\n return;\n }\n nextRoot.focus();\n e.preventDefault();\n } }, callbacks);\n return _this;\n }\n ManagedFocusFeature.prototype.postConstruct = function () {\n this.eFocusableElement.classList.add(ManagedFocusFeature.FOCUS_MANAGED_CLASS);\n this.addKeyDownListeners(this.eFocusableElement);\n if (this.callbacks.onFocusIn) {\n this.addManagedListener(this.eFocusableElement, 'focusin', this.callbacks.onFocusIn);\n }\n if (this.callbacks.onFocusOut) {\n this.addManagedListener(this.eFocusableElement, 'focusout', this.callbacks.onFocusOut);\n }\n };\n ManagedFocusFeature.prototype.addKeyDownListeners = function (eGui) {\n var _this = this;\n this.addManagedListener(eGui, 'keydown', function (e) {\n if (e.defaultPrevented || isStopPropagationForAgGrid(e)) {\n return;\n }\n if (_this.callbacks.shouldStopEventPropagation(e)) {\n stopPropagationForAgGrid(e);\n return;\n }\n if (e.key === KeyCode.TAB) {\n _this.callbacks.onTabKeyDown(e);\n }\n else if (_this.callbacks.handleKeyDown) {\n _this.callbacks.handleKeyDown(e);\n }\n });\n };\n ManagedFocusFeature.FOCUS_MANAGED_CLASS = 'ag-focus-managed';\n __decorate([\n Autowired('focusService')\n ], ManagedFocusFeature.prototype, \"focusService\", void 0);\n __decorate([\n PostConstruct\n ], ManagedFocusFeature.prototype, \"postConstruct\", null);\n return ManagedFocusFeature;\n}(BeanStub));\nexport { ManagedFocusFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from '../../context/context';\nimport { loadTemplate, setDisabled } from '../../utils/dom';\nimport { debounce } from '../../utils/function';\nimport { DEFAULT_FILTER_LOCALE_TEXT } from '../filterLocaleText';\nimport { ManagedFocusFeature } from '../../widgets/managedFocusFeature';\nimport { convertToSet } from '../../utils/set';\nimport { Component } from '../../widgets/component';\n/**\n * Contains common logic to all provided filters (apply button, clear button, etc).\n * All the filters that come with AG Grid extend this class. User filters do not\n * extend this class.\n *\n * @param M type of filter-model managed by the concrete sub-class that extends this type\n * @param V type of value managed by the concrete sub-class that extends this type\n */\nvar ProvidedFilter = /** @class */ (function (_super) {\n __extends(ProvidedFilter, _super);\n function ProvidedFilter(filterNameKey) {\n var _this = _super.call(this) || this;\n _this.filterNameKey = filterNameKey;\n _this.applyActive = false;\n _this.hidePopup = null;\n // after the user hits 'apply' the model gets copied to here. this is then the model that we use for\n // all filtering. so if user changes UI but doesn't hit apply, then the UI will be out of sync with this model.\n // this is what we want, as the UI should only become the 'active' filter once it's applied. when apply is\n // inactive, this model will be in sync (following the debounce ms). if the UI is not a valid filter\n // (eg the value is missing so nothing to filter on, or for set filter all checkboxes are checked so filter\n // not active) then this appliedModel will be null/undefined.\n _this.appliedModel = null;\n return _this;\n }\n ProvidedFilter.prototype.postConstruct = function () {\n this.resetTemplate(); // do this first to create the DOM\n this.createManagedBean(new ManagedFocusFeature(this.getFocusableElement(), {\n handleKeyDown: this.handleKeyDown.bind(this)\n }));\n };\n // override\n ProvidedFilter.prototype.handleKeyDown = function (e) { };\n ProvidedFilter.prototype.getFilterTitle = function () {\n return this.translate(this.filterNameKey);\n };\n ProvidedFilter.prototype.isFilterActive = function () {\n // filter is active if we have a valid applied model\n return !!this.appliedModel;\n };\n ProvidedFilter.prototype.resetTemplate = function (paramsMap) {\n var templateString = /* html */ \"\\n
\\n
\\n \" + this.createBodyTemplate() + \"\\n
\\n
\";\n this.setTemplate(templateString, paramsMap);\n };\n ProvidedFilter.prototype.isReadOnly = function () {\n return !!this.providedFilterParams.readOnly;\n };\n ProvidedFilter.prototype.init = function (params) {\n var _this = this;\n this.setParams(params);\n this.resetUiToDefaults(true).then(function () {\n _this.updateUiVisibility();\n _this.setupOnBtApplyDebounce();\n });\n };\n ProvidedFilter.prototype.setParams = function (params) {\n this.providedFilterParams = params;\n this.applyActive = ProvidedFilter.isUseApplyButton(params);\n this.createButtonPanel();\n };\n ProvidedFilter.prototype.createButtonPanel = function () {\n var _this = this;\n var buttons = this.providedFilterParams.buttons;\n if (!buttons || buttons.length < 1 || this.isReadOnly()) {\n return;\n }\n var eButtonsPanel = document.createElement('div');\n eButtonsPanel.classList.add('ag-filter-apply-panel');\n var addButton = function (type) {\n var text;\n var clickListener;\n switch (type) {\n case 'apply':\n text = _this.translate('applyFilter');\n clickListener = function (e) { return _this.onBtApply(false, false, e); };\n break;\n case 'clear':\n text = _this.translate('clearFilter');\n clickListener = function () { return _this.onBtClear(); };\n break;\n case 'reset':\n text = _this.translate('resetFilter');\n clickListener = function () { return _this.onBtReset(); };\n break;\n case 'cancel':\n text = _this.translate('cancelFilter');\n clickListener = function (e) { _this.onBtCancel(e); };\n break;\n default:\n console.warn('AG Grid: Unknown button type specified');\n return;\n }\n var button = loadTemplate(\n /* html */\n \"\" + text + \"\\n \");\n eButtonsPanel.appendChild(button);\n _this.addManagedListener(button, 'click', clickListener);\n };\n convertToSet(buttons).forEach(function (type) { return addButton(type); });\n this.getGui().appendChild(eButtonsPanel);\n };\n // subclasses can override this to provide alternative debounce defaults\n ProvidedFilter.prototype.getDefaultDebounceMs = function () {\n return 0;\n };\n ProvidedFilter.prototype.setupOnBtApplyDebounce = function () {\n var debounceMs = ProvidedFilter.getDebounceMs(this.providedFilterParams, this.getDefaultDebounceMs());\n this.onBtApplyDebounce = debounce(this.onBtApply.bind(this), debounceMs);\n };\n ProvidedFilter.prototype.getModel = function () {\n return this.appliedModel ? this.appliedModel : null;\n };\n ProvidedFilter.prototype.setModel = function (model) {\n var _this = this;\n var promise = model != null ? this.setModelIntoUi(model) : this.resetUiToDefaults();\n return promise.then(function () {\n _this.updateUiVisibility();\n // we set the model from the GUI, rather than the provided model,\n // so the model is consistent, e.g. handling of null/undefined will be the same,\n // or if model is case insensitive, then casing is removed.\n _this.applyModel();\n });\n };\n ProvidedFilter.prototype.onBtCancel = function (e) {\n var _this = this;\n var currentModel = this.getModel();\n var afterAppliedFunc = function () {\n _this.onUiChanged(false, 'prevent');\n if (_this.providedFilterParams.closeOnApply) {\n _this.close(e);\n }\n };\n if (currentModel != null) {\n this.setModelIntoUi(currentModel).then(afterAppliedFunc);\n }\n else {\n this.resetUiToDefaults().then(afterAppliedFunc);\n }\n };\n ProvidedFilter.prototype.onBtClear = function () {\n var _this = this;\n this.resetUiToDefaults().then(function () { return _this.onUiChanged(); });\n };\n ProvidedFilter.prototype.onBtReset = function () {\n this.onBtClear();\n this.onBtApply();\n };\n /**\n * Applies changes made in the UI to the filter, and returns true if the model has changed.\n */\n ProvidedFilter.prototype.applyModel = function () {\n var newModel = this.getModelFromUi();\n if (!this.isModelValid(newModel)) {\n return false;\n }\n var previousModel = this.appliedModel;\n this.appliedModel = newModel;\n // models can be same if user pasted same content into text field, or maybe just changed the case\n // and it's a case insensitive filter\n return !this.areModelsEqual(previousModel, newModel);\n };\n ProvidedFilter.prototype.isModelValid = function (model) {\n return true;\n };\n ProvidedFilter.prototype.onBtApply = function (afterFloatingFilter, afterDataChange, e) {\n if (afterFloatingFilter === void 0) { afterFloatingFilter = false; }\n if (afterDataChange === void 0) { afterDataChange = false; }\n if (this.applyModel()) {\n // the floating filter uses 'afterFloatingFilter' info, so it doesn't refresh after filter changed if change\n // came from floating filter\n this.providedFilterParams.filterChangedCallback({ afterFloatingFilter: afterFloatingFilter, afterDataChange: afterDataChange });\n }\n var closeOnApply = this.providedFilterParams.closeOnApply;\n // only close if an apply button is visible, otherwise we'd be closing every time a change was made!\n if (closeOnApply && this.applyActive && !afterFloatingFilter && !afterDataChange) {\n this.close(e);\n }\n };\n ProvidedFilter.prototype.onNewRowsLoaded = function () {\n };\n ProvidedFilter.prototype.close = function (e) {\n if (!this.hidePopup) {\n return;\n }\n var keyboardEvent = e;\n var key = keyboardEvent && keyboardEvent.key;\n var params;\n if (key === 'Enter' || key === 'Space') {\n params = { keyboardEvent: keyboardEvent };\n }\n this.hidePopup(params);\n this.hidePopup = null;\n };\n /**\n * By default, if the change came from a floating filter it will be applied immediately, otherwise if there is no\n * apply button it will be applied after a debounce, otherwise it will not be applied at all. This behaviour can\n * be adjusted by using the apply parameter.\n */\n ProvidedFilter.prototype.onUiChanged = function (fromFloatingFilter, apply) {\n if (fromFloatingFilter === void 0) { fromFloatingFilter = false; }\n this.updateUiVisibility();\n this.providedFilterParams.filterModifiedCallback();\n if (this.applyActive && !this.isReadOnly) {\n var isValid = this.isModelValid(this.getModelFromUi());\n setDisabled(this.getRefElement('applyFilterButton'), !isValid);\n }\n if ((fromFloatingFilter && !apply) || apply === 'immediately') {\n this.onBtApply(fromFloatingFilter);\n }\n else if ((!this.applyActive && !apply) || apply === 'debounce') {\n this.onBtApplyDebounce();\n }\n };\n ProvidedFilter.prototype.afterGuiAttached = function (params) {\n if (params == null) {\n return;\n }\n this.hidePopup = params.hidePopup;\n };\n // static, as used by floating filter also\n ProvidedFilter.getDebounceMs = function (params, debounceDefault) {\n if (ProvidedFilter.isUseApplyButton(params)) {\n if (params.debounceMs != null) {\n console.warn('AG Grid: debounceMs is ignored when apply button is present');\n }\n return 0;\n }\n return params.debounceMs != null ? params.debounceMs : debounceDefault;\n };\n // static, as used by floating filter also\n ProvidedFilter.isUseApplyButton = function (params) {\n return !!params.buttons && params.buttons.indexOf('apply') >= 0;\n };\n ProvidedFilter.prototype.destroy = function () {\n this.hidePopup = null;\n _super.prototype.destroy.call(this);\n };\n ProvidedFilter.prototype.translate = function (key) {\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n return translate(key, DEFAULT_FILTER_LOCALE_TEXT[key]);\n };\n ProvidedFilter.prototype.getCellValue = function (rowNode) {\n var _a = this.providedFilterParams, api = _a.api, colDef = _a.colDef, column = _a.column, columnApi = _a.columnApi, context = _a.context;\n return this.providedFilterParams.valueGetter({\n api: api,\n colDef: colDef,\n column: column,\n columnApi: columnApi,\n context: context,\n data: rowNode.data,\n getValue: function (field) { return rowNode.data[field]; },\n node: rowNode,\n });\n };\n __decorate([\n Autowired('rowModel')\n ], ProvidedFilter.prototype, \"rowModel\", void 0);\n __decorate([\n Autowired('valueService')\n ], ProvidedFilter.prototype, \"valueService\", void 0);\n __decorate([\n PostConstruct\n ], ProvidedFilter.prototype, \"postConstruct\", null);\n return ProvidedFilter;\n}(Component));\nexport { ProvidedFilter };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from \"./component\";\nimport { PostConstruct } from \"../context/context\";\nimport { clearElement, setDisabled, setElementWidth } from \"../utils/dom\";\nimport { setAriaRole } from \"../utils/aria\";\nvar AgAbstractLabel = /** @class */ (function (_super) {\n __extends(AgAbstractLabel, _super);\n function AgAbstractLabel(config, template) {\n var _this = _super.call(this, template) || this;\n _this.labelSeparator = '';\n _this.labelAlignment = 'left';\n _this.disabled = false;\n _this.label = '';\n _this.config = config || {};\n return _this;\n }\n AgAbstractLabel.prototype.postConstruct = function () {\n this.addCssClass('ag-labeled');\n this.eLabel.classList.add('ag-label');\n var _a = this.config, labelSeparator = _a.labelSeparator, label = _a.label, labelWidth = _a.labelWidth, labelAlignment = _a.labelAlignment;\n if (labelSeparator != null) {\n this.setLabelSeparator(labelSeparator);\n }\n if (label != null) {\n this.setLabel(label);\n }\n if (labelWidth != null) {\n this.setLabelWidth(labelWidth);\n }\n this.setLabelAlignment(labelAlignment || this.labelAlignment);\n this.refreshLabel();\n };\n AgAbstractLabel.prototype.refreshLabel = function () {\n clearElement(this.eLabel);\n if (typeof this.label === 'string') {\n this.eLabel.innerText = this.label + this.labelSeparator;\n }\n else if (this.label) {\n this.eLabel.appendChild(this.label);\n }\n if (this.label === '') {\n this.eLabel.classList.add('ag-hidden');\n setAriaRole(this.eLabel, 'presentation');\n }\n else {\n this.eLabel.classList.remove('ag-hidden');\n setAriaRole(this.eLabel, null);\n }\n };\n AgAbstractLabel.prototype.setLabelSeparator = function (labelSeparator) {\n if (this.labelSeparator === labelSeparator) {\n return this;\n }\n this.labelSeparator = labelSeparator;\n if (this.label != null) {\n this.refreshLabel();\n }\n return this;\n };\n AgAbstractLabel.prototype.getLabelId = function () {\n this.eLabel.id = this.eLabel.id || \"ag-\" + this.getCompId() + \"-label\";\n return this.eLabel.id;\n };\n AgAbstractLabel.prototype.getLabel = function () {\n return this.label;\n };\n AgAbstractLabel.prototype.setLabel = function (label) {\n if (this.label === label) {\n return this;\n }\n this.label = label;\n this.refreshLabel();\n return this;\n };\n AgAbstractLabel.prototype.setLabelAlignment = function (alignment) {\n var eGui = this.getGui();\n var eGuiClassList = eGui.classList;\n eGuiClassList.toggle('ag-label-align-left', alignment === 'left');\n eGuiClassList.toggle('ag-label-align-right', alignment === 'right');\n eGuiClassList.toggle('ag-label-align-top', alignment === 'top');\n return this;\n };\n AgAbstractLabel.prototype.setLabelWidth = function (width) {\n if (this.label == null) {\n return this;\n }\n setElementWidth(this.eLabel, width);\n return this;\n };\n AgAbstractLabel.prototype.setDisabled = function (disabled) {\n disabled = !!disabled;\n var element = this.getGui();\n setDisabled(element, disabled);\n element.classList.toggle('ag-disabled', disabled);\n this.disabled = disabled;\n return this;\n };\n AgAbstractLabel.prototype.isDisabled = function () {\n return !!this.disabled;\n };\n __decorate([\n PostConstruct\n ], AgAbstractLabel.prototype, \"postConstruct\", null);\n return AgAbstractLabel;\n}(Component));\nexport { AgAbstractLabel };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { AgAbstractLabel } from './agAbstractLabel';\nimport { setFixedWidth } from '../utils/dom';\nvar AgAbstractField = /** @class */ (function (_super) {\n __extends(AgAbstractField, _super);\n function AgAbstractField(config, template, className) {\n var _this = _super.call(this, config, template) || this;\n _this.className = className;\n return _this;\n }\n AgAbstractField.prototype.postConstruct = function () {\n _super.prototype.postConstruct.call(this);\n if (this.className) {\n this.addCssClass(this.className);\n }\n };\n AgAbstractField.prototype.onValueChange = function (callbackFn) {\n var _this = this;\n this.addManagedListener(this, AgAbstractField.EVENT_CHANGED, function () { return callbackFn(_this.getValue()); });\n return this;\n };\n AgAbstractField.prototype.getWidth = function () {\n return this.getGui().clientWidth;\n };\n AgAbstractField.prototype.setWidth = function (width) {\n setFixedWidth(this.getGui(), width);\n return this;\n };\n AgAbstractField.prototype.getPreviousValue = function () {\n return this.previousValue;\n };\n AgAbstractField.prototype.getValue = function () {\n return this.value;\n };\n AgAbstractField.prototype.setValue = function (value, silent) {\n if (this.value === value) {\n return this;\n }\n this.previousValue = this.value;\n this.value = value;\n if (!silent) {\n this.dispatchEvent({ type: AgAbstractField.EVENT_CHANGED });\n }\n return this;\n };\n AgAbstractField.EVENT_CHANGED = 'valueChange';\n return AgAbstractField;\n}(AgAbstractLabel));\nexport { AgAbstractField };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { AgAbstractField } from \"./agAbstractField\";\nimport { RefSelector } from \"./componentAnnotations\";\nimport { setAriaLabelledBy, setAriaLabel, setAriaDescribedBy } from \"../utils/aria\";\nimport { createIconNoSpan } from \"../utils/icon\";\nimport { exists } from \"../utils/generic\";\nimport { setElementWidth, isVisible } from \"../utils/dom\";\nimport { KeyCode } from '../constants/keyCode';\nvar AgPickerField = /** @class */ (function (_super) {\n __extends(AgPickerField, _super);\n function AgPickerField(config, className, pickerIcon, ariaRole) {\n var _this = _super.call(this, config, \n /* html */ \"
\\n
\\n
\\n
\\n
\\n
\\n
\", className) || this;\n _this.pickerIcon = pickerIcon;\n _this.isPickerDisplayed = false;\n _this.isDestroyingPicker = false;\n _this.skipClick = false;\n return _this;\n }\n AgPickerField.prototype.postConstruct = function () {\n var _this = this;\n _super.prototype.postConstruct.call(this);\n var displayId = this.getCompId() + \"-display\";\n this.eDisplayField.setAttribute('id', displayId);\n setAriaDescribedBy(this.eWrapper, displayId);\n var clickHandler = function () {\n if (_this.skipClick) {\n _this.skipClick = false;\n return;\n }\n if (_this.isDisabled()) {\n return;\n }\n _this.pickerComponent = _this.showPicker();\n };\n var eGui = this.getGui();\n this.addManagedListener(eGui, 'mousedown', function (e) {\n if (!_this.skipClick &&\n _this.pickerComponent &&\n _this.pickerComponent.isAlive() &&\n isVisible(_this.pickerComponent.getGui()) &&\n eGui.contains(e.target)) {\n _this.skipClick = true;\n }\n });\n this.addManagedListener(eGui, 'keydown', function (e) {\n switch (e.key) {\n case KeyCode.UP:\n case KeyCode.DOWN:\n case KeyCode.ENTER:\n case KeyCode.SPACE:\n clickHandler();\n case KeyCode.ESCAPE:\n if (_this.isPickerDisplayed) {\n e.preventDefault();\n }\n break;\n }\n });\n this.addManagedListener(this.eWrapper, 'click', clickHandler);\n this.addManagedListener(this.eLabel, 'click', clickHandler);\n if (this.pickerIcon) {\n var icon = createIconNoSpan(this.pickerIcon, this.gridOptionsWrapper);\n if (icon) {\n this.eIcon.appendChild(icon);\n }\n }\n };\n AgPickerField.prototype.refreshLabel = function () {\n if (exists(this.getLabel())) {\n setAriaLabelledBy(this.eWrapper, this.getLabelId());\n }\n else {\n this.eWrapper.removeAttribute('aria-labelledby');\n }\n _super.prototype.refreshLabel.call(this);\n };\n AgPickerField.prototype.setAriaLabel = function (label) {\n setAriaLabel(this.eWrapper, label);\n return this;\n };\n AgPickerField.prototype.setInputWidth = function (width) {\n setElementWidth(this.eWrapper, width);\n return this;\n };\n AgPickerField.prototype.getFocusableElement = function () {\n return this.eWrapper;\n };\n __decorate([\n RefSelector('eLabel')\n ], AgPickerField.prototype, \"eLabel\", void 0);\n __decorate([\n RefSelector('eWrapper')\n ], AgPickerField.prototype, \"eWrapper\", void 0);\n __decorate([\n RefSelector('eDisplayField')\n ], AgPickerField.prototype, \"eDisplayField\", void 0);\n __decorate([\n RefSelector('eIcon')\n ], AgPickerField.prototype, \"eIcon\", void 0);\n return AgPickerField;\n}(AgAbstractField));\nexport { AgPickerField };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { AgAbstractField } from \"./agAbstractField\";\nimport { Component } from \"./component\";\nimport { PostConstruct } from \"../context/context\";\nimport { escapeString } from \"../utils/string\";\nimport { KeyCode } from '../constants/keyCode';\nimport { setAriaPosInSet, setAriaRole, setAriaSelected, setAriaSetSize } from '../utils/aria';\nvar AgList = /** @class */ (function (_super) {\n __extends(AgList, _super);\n function AgList(cssIdentifier) {\n if (cssIdentifier === void 0) { cssIdentifier = 'default'; }\n var _this = _super.call(this, /* html */ \"
\") || this;\n _this.cssIdentifier = cssIdentifier;\n _this.options = [];\n _this.itemEls = [];\n return _this;\n }\n AgList.prototype.init = function () {\n this.addManagedListener(this.getGui(), 'keydown', this.handleKeyDown.bind(this));\n };\n AgList.prototype.handleKeyDown = function (e) {\n var key = e.key;\n switch (key) {\n case KeyCode.ENTER:\n if (!this.highlightedEl) {\n this.setValue(this.getValue());\n }\n else {\n var pos = this.itemEls.indexOf(this.highlightedEl);\n this.setValueByIndex(pos);\n }\n break;\n case KeyCode.DOWN:\n case KeyCode.UP:\n var isDown = key === KeyCode.DOWN;\n var itemToHighlight = void 0;\n e.preventDefault();\n if (!this.highlightedEl) {\n itemToHighlight = this.itemEls[isDown ? 0 : this.itemEls.length - 1];\n }\n else {\n var currentIdx = this.itemEls.indexOf(this.highlightedEl);\n var nextPos = currentIdx + (isDown ? 1 : -1);\n nextPos = Math.min(Math.max(nextPos, 0), this.itemEls.length - 1);\n itemToHighlight = this.itemEls[nextPos];\n }\n this.highlightItem(itemToHighlight);\n break;\n }\n };\n AgList.prototype.addOptions = function (listOptions) {\n var _this = this;\n listOptions.forEach(function (listOption) { return _this.addOption(listOption); });\n return this;\n };\n AgList.prototype.addOption = function (listOption) {\n var value = listOption.value, text = listOption.text;\n var sanitisedText = escapeString(text || value);\n this.options.push({ value: value, text: sanitisedText });\n this.renderOption(value, sanitisedText);\n this.updateIndices();\n return this;\n };\n AgList.prototype.updateIndices = function () {\n var options = this.getGui().querySelectorAll('.ag-list-item');\n options.forEach(function (option, idx) {\n setAriaPosInSet(option, idx + 1);\n setAriaSetSize(option, options.length);\n });\n };\n AgList.prototype.renderOption = function (value, text) {\n var _this = this;\n var itemEl = document.createElement('div');\n setAriaRole(itemEl, 'option');\n itemEl.classList.add('ag-list-item', \"ag-\" + this.cssIdentifier + \"-list-item\");\n itemEl.innerHTML = \"\" + text + \"\";\n itemEl.tabIndex = -1;\n this.itemEls.push(itemEl);\n this.addManagedListener(itemEl, 'mouseover', function () { return _this.highlightItem(itemEl); });\n this.addManagedListener(itemEl, 'mouseleave', function () { return _this.clearHighlighted(); });\n this.addManagedListener(itemEl, 'click', function () { return _this.setValue(value); });\n this.getGui().appendChild(itemEl);\n };\n AgList.prototype.setValue = function (value, silent) {\n if (this.value === value) {\n this.fireItemSelected();\n return this;\n }\n if (value == null) {\n this.reset();\n return this;\n }\n var idx = this.options.findIndex(function (option) { return option.value === value; });\n if (idx !== -1) {\n var option = this.options[idx];\n this.value = option.value;\n this.displayValue = option.text != null ? option.text : option.value;\n this.highlightItem(this.itemEls[idx]);\n if (!silent) {\n this.fireChangeEvent();\n }\n }\n return this;\n };\n AgList.prototype.setValueByIndex = function (idx) {\n return this.setValue(this.options[idx].value);\n };\n AgList.prototype.getValue = function () {\n return this.value;\n };\n AgList.prototype.getDisplayValue = function () {\n return this.displayValue;\n };\n AgList.prototype.refreshHighlighted = function () {\n var _this = this;\n this.clearHighlighted();\n var idx = this.options.findIndex(function (option) { return option.value === _this.value; });\n if (idx !== -1) {\n this.highlightItem(this.itemEls[idx]);\n }\n };\n AgList.prototype.reset = function () {\n this.value = null;\n this.displayValue = null;\n this.clearHighlighted();\n this.fireChangeEvent();\n };\n AgList.prototype.highlightItem = function (el) {\n if (!el.offsetParent) {\n return;\n }\n this.clearHighlighted();\n this.highlightedEl = el;\n this.highlightedEl.classList.add(AgList.ACTIVE_CLASS);\n setAriaSelected(this.highlightedEl, true);\n this.highlightedEl.focus();\n };\n AgList.prototype.clearHighlighted = function () {\n if (!this.highlightedEl || !this.highlightedEl.offsetParent) {\n return;\n }\n this.highlightedEl.classList.remove(AgList.ACTIVE_CLASS);\n setAriaSelected(this.highlightedEl, false);\n this.highlightedEl = null;\n };\n AgList.prototype.fireChangeEvent = function () {\n this.dispatchEvent({ type: AgAbstractField.EVENT_CHANGED });\n this.fireItemSelected();\n };\n AgList.prototype.fireItemSelected = function () {\n this.dispatchEvent({ type: AgList.EVENT_ITEM_SELECTED });\n };\n AgList.EVENT_ITEM_SELECTED = 'selectedItem';\n AgList.ACTIVE_CLASS = 'ag-active-item';\n __decorate([\n PostConstruct\n ], AgList.prototype, \"init\", null);\n return AgList;\n}(Component));\nexport { AgList };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { AgAbstractField } from \"./agAbstractField\";\nimport { AgPickerField } from \"./agPickerField\";\nimport { AgList } from \"./agList\";\nimport { Autowired, PostConstruct } from \"../context/context\";\nimport { setElementWidth, getAbsoluteWidth, getInnerHeight } from \"../utils/dom\";\nimport { setAriaExpanded } from \"../utils/aria\";\nvar AgSelect = /** @class */ (function (_super) {\n __extends(AgSelect, _super);\n function AgSelect(config) {\n return _super.call(this, config, 'ag-select', 'smallDown', 'listbox') || this;\n }\n AgSelect.prototype.init = function () {\n var _this = this;\n this.listComponent = this.createBean(new AgList('select'));\n this.listComponent.setParentComponent(this);\n this.eWrapper.tabIndex = 0;\n this.listComponent.addManagedListener(this.listComponent, AgList.EVENT_ITEM_SELECTED, function () { if (_this.hideList) {\n _this.hideList();\n } });\n this.listComponent.addManagedListener(this.listComponent, AgAbstractField.EVENT_CHANGED, function () {\n _this.setValue(_this.listComponent.getValue(), false, true);\n if (_this.hideList) {\n _this.hideList();\n }\n });\n };\n AgSelect.prototype.showPicker = function () {\n var _this = this;\n var listGui = this.listComponent.getGui();\n var eDocument = this.gridOptionsWrapper.getDocument();\n var destroyMouseWheelFunc = this.addManagedListener(eDocument.body, 'wheel', function (e) {\n if (!listGui.contains(e.target) && _this.hideList) {\n _this.hideList();\n }\n });\n var destroyFocusOutFunc = this.addManagedListener(listGui, 'focusout', function (e) {\n if (!listGui.contains(e.relatedTarget) && _this.hideList) {\n _this.hideList();\n }\n });\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n var addPopupRes = this.popupService.addPopup({\n modal: true,\n eChild: listGui,\n closeOnEsc: true,\n closedCallback: function () {\n _this.hideList = null;\n _this.isPickerDisplayed = false;\n destroyFocusOutFunc();\n destroyMouseWheelFunc();\n if (_this.isAlive()) {\n setAriaExpanded(_this.eWrapper, false);\n _this.getFocusableElement().focus();\n }\n },\n ariaLabel: translate('ariaLabelSelectField', 'Select Field')\n });\n if (addPopupRes) {\n this.hideList = addPopupRes.hideFunc;\n }\n this.isPickerDisplayed = true;\n setElementWidth(listGui, getAbsoluteWidth(this.eWrapper));\n setAriaExpanded(this.eWrapper, true);\n listGui.style.maxHeight = getInnerHeight(this.popupService.getPopupParent()) + 'px';\n listGui.style.position = 'absolute';\n this.popupService.positionPopupUnderComponent({\n type: 'ag-list',\n eventSource: this.eWrapper,\n ePopup: listGui,\n keepWithinBounds: true\n });\n this.listComponent.refreshHighlighted();\n return this.listComponent;\n };\n AgSelect.prototype.addOptions = function (options) {\n var _this = this;\n options.forEach(function (option) { return _this.addOption(option); });\n return this;\n };\n AgSelect.prototype.addOption = function (option) {\n this.listComponent.addOption(option);\n return this;\n };\n AgSelect.prototype.setValue = function (value, silent, fromPicker) {\n if (this.value === value) {\n return this;\n }\n if (!fromPicker) {\n this.listComponent.setValue(value, true);\n }\n var newValue = this.listComponent.getValue();\n if (newValue === this.getValue()) {\n return this;\n }\n this.eDisplayField.innerHTML = this.listComponent.getDisplayValue();\n return _super.prototype.setValue.call(this, value, silent);\n };\n AgSelect.prototype.destroy = function () {\n if (this.hideList) {\n this.hideList();\n }\n this.destroyBean(this.listComponent);\n _super.prototype.destroy.call(this);\n };\n __decorate([\n Autowired('popupService')\n ], AgSelect.prototype, \"popupService\", void 0);\n __decorate([\n PostConstruct\n ], AgSelect.prototype, \"init\", null);\n return AgSelect;\n}(AgPickerField));\nexport { AgSelect };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { RefSelector } from './componentAnnotations';\nimport { AgAbstractField } from './agAbstractField';\nimport { setDisabled, setElementWidth, addOrRemoveAttribute } from '../utils/dom';\nimport { setAriaLabelledBy, setAriaLabel } from '../utils/aria';\nimport { exists } from '../utils/generic';\nvar AgAbstractInputField = /** @class */ (function (_super) {\n __extends(AgAbstractInputField, _super);\n function AgAbstractInputField(config, className, inputType, displayFieldTag) {\n if (inputType === void 0) { inputType = 'text'; }\n if (displayFieldTag === void 0) { displayFieldTag = 'input'; }\n var _this = _super.call(this, config, /* html */ \"\\n
\\n
\\n
\\n <\" + displayFieldTag + \" ref=\\\"eInput\\\" class=\\\"ag-input-field-input\\\">\\n
\\n
\", className) || this;\n _this.inputType = inputType;\n _this.displayFieldTag = displayFieldTag;\n return _this;\n }\n AgAbstractInputField.prototype.postConstruct = function () {\n _super.prototype.postConstruct.call(this);\n this.setInputType();\n this.eLabel.classList.add(this.className + \"-label\");\n this.eWrapper.classList.add(this.className + \"-input-wrapper\");\n this.eInput.classList.add(this.className + \"-input\");\n this.addCssClass('ag-input-field');\n this.eInput.id = this.eInput.id || \"ag-\" + this.getCompId() + \"-input\";\n var _a = this.config, width = _a.width, value = _a.value;\n if (width != null) {\n this.setWidth(width);\n }\n if (value != null) {\n this.setValue(value);\n }\n this.addInputListeners();\n };\n AgAbstractInputField.prototype.refreshLabel = function () {\n if (exists(this.getLabel())) {\n setAriaLabelledBy(this.eInput, this.getLabelId());\n }\n else {\n this.eInput.removeAttribute('aria-labelledby');\n }\n _super.prototype.refreshLabel.call(this);\n };\n AgAbstractInputField.prototype.addInputListeners = function () {\n var _this = this;\n this.addManagedListener(this.eInput, 'input', function (e) { return _this.setValue(e.target.value); });\n };\n AgAbstractInputField.prototype.setInputType = function () {\n if (this.displayFieldTag === 'input') {\n this.eInput.setAttribute('type', this.inputType);\n }\n };\n AgAbstractInputField.prototype.getInputElement = function () {\n return this.eInput;\n };\n AgAbstractInputField.prototype.setInputWidth = function (width) {\n setElementWidth(this.eWrapper, width);\n return this;\n };\n AgAbstractInputField.prototype.setInputName = function (name) {\n this.getInputElement().setAttribute('name', name);\n return this;\n };\n AgAbstractInputField.prototype.getFocusableElement = function () {\n return this.eInput;\n };\n AgAbstractInputField.prototype.setMaxLength = function (length) {\n var eInput = this.eInput;\n eInput.maxLength = length;\n return this;\n };\n AgAbstractInputField.prototype.setInputPlaceholder = function (placeholder) {\n addOrRemoveAttribute(this.eInput, 'placeholder', placeholder);\n return this;\n };\n AgAbstractInputField.prototype.setInputAriaLabel = function (label) {\n setAriaLabel(this.eInput, label);\n return this;\n };\n AgAbstractInputField.prototype.setDisabled = function (disabled) {\n setDisabled(this.eInput, disabled);\n return _super.prototype.setDisabled.call(this, disabled);\n };\n __decorate([\n RefSelector('eLabel')\n ], AgAbstractInputField.prototype, \"eLabel\", void 0);\n __decorate([\n RefSelector('eWrapper')\n ], AgAbstractInputField.prototype, \"eWrapper\", void 0);\n __decorate([\n RefSelector('eInput')\n ], AgAbstractInputField.prototype, \"eInput\", void 0);\n return AgAbstractInputField;\n}(AgAbstractField));\nexport { AgAbstractInputField };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { RefSelector } from '../../widgets/componentAnnotations';\nimport { OptionsFactory } from './optionsFactory';\nimport { ProvidedFilter } from './providedFilter';\nimport { AgPromise } from '../../utils';\nimport { AgSelect } from '../../widgets/agSelect';\nimport { includes } from '../../utils/array';\nimport { setDisplayed, setDisabled } from '../../utils/dom';\nimport { Component } from '../../widgets/component';\nimport { AgAbstractInputField } from '../../widgets/agAbstractInputField';\nexport var ConditionPosition;\n(function (ConditionPosition) {\n ConditionPosition[ConditionPosition[\"One\"] = 0] = \"One\";\n ConditionPosition[ConditionPosition[\"Two\"] = 1] = \"Two\";\n})(ConditionPosition || (ConditionPosition = {}));\n/**\n * Every filter with a dropdown where the user can specify a comparing type against the filter values.\n *\n * @param M type of filter-model managed by the concrete sub-class that extends this type\n * @param V type of value managed by the concrete sub-class that extends this type\n * @param E type of UI element used for collecting user-input\n */\nvar SimpleFilter = /** @class */ (function (_super) {\n __extends(SimpleFilter, _super);\n function SimpleFilter() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n SimpleFilter.prototype.getNumberOfInputs = function (type) {\n var customOpts = this.optionsFactory.getCustomOption(type);\n if (customOpts) {\n var numberOfInputs = customOpts.numberOfInputs;\n return numberOfInputs != null ? numberOfInputs : 1;\n }\n var zeroInputTypes = [\n SimpleFilter.EMPTY, SimpleFilter.NOT_BLANK, SimpleFilter.BLANK,\n ];\n if (type && zeroInputTypes.indexOf(type) >= 0) {\n return 0;\n }\n else if (type === SimpleFilter.IN_RANGE) {\n return 2;\n }\n return 1;\n };\n // floating filter calls this when user applies filter from floating filter\n SimpleFilter.prototype.onFloatingFilterChanged = function (type, value) {\n this.setTypeFromFloatingFilter(type);\n this.setValueFromFloatingFilter(value);\n this.onUiChanged(true);\n };\n SimpleFilter.prototype.setTypeFromFloatingFilter = function (type) {\n this.eType1.setValue(type);\n this.eType2.setValue(this.optionsFactory.getDefaultOption());\n (this.isDefaultOperator('AND') ? this.eJoinOperatorAnd : this.eJoinOperatorOr).setValue(true);\n };\n SimpleFilter.prototype.getModelFromUi = function () {\n if (!this.isConditionUiComplete(ConditionPosition.One)) {\n return null;\n }\n if (this.isAllowTwoConditions() && this.isConditionUiComplete(ConditionPosition.Two)) {\n return {\n filterType: this.getFilterType(),\n operator: this.getJoinOperator(),\n condition1: this.createCondition(ConditionPosition.One),\n condition2: this.createCondition(ConditionPosition.Two)\n };\n }\n return this.createCondition(ConditionPosition.One);\n };\n SimpleFilter.prototype.getConditionTypes = function () {\n return [\n this.eType1.getValue(),\n this.eType2.getValue(),\n ];\n };\n SimpleFilter.prototype.getJoinOperator = function () {\n return this.eJoinOperatorOr.getValue() === true ? 'OR' : 'AND';\n };\n SimpleFilter.prototype.areModelsEqual = function (a, b) {\n // both are missing\n if (!a && !b) {\n return true;\n }\n // one is missing, other present\n if ((!a && b) || (a && !b)) {\n return false;\n }\n // one is combined, the other is not\n var aIsSimple = !a.operator;\n var bIsSimple = !b.operator;\n var oneSimpleOneCombined = (!aIsSimple && bIsSimple) || (aIsSimple && !bIsSimple);\n if (oneSimpleOneCombined) {\n return false;\n }\n var res;\n // otherwise both present, so compare\n if (aIsSimple) {\n var aSimple = a;\n var bSimple = b;\n res = this.areSimpleModelsEqual(aSimple, bSimple);\n }\n else {\n var aCombined = a;\n var bCombined = b;\n res = aCombined.operator === bCombined.operator\n && this.areSimpleModelsEqual(aCombined.condition1, bCombined.condition1)\n && this.areSimpleModelsEqual(aCombined.condition2, bCombined.condition2);\n }\n return res;\n };\n SimpleFilter.prototype.setModelIntoUi = function (model) {\n var isCombined = model.operator;\n if (isCombined) {\n var combinedModel = model;\n var orChecked = combinedModel.operator === 'OR';\n this.eJoinOperatorAnd.setValue(!orChecked);\n this.eJoinOperatorOr.setValue(orChecked);\n this.eType1.setValue(combinedModel.condition1.type);\n this.eType2.setValue(combinedModel.condition2.type);\n this.setConditionIntoUi(combinedModel.condition1, ConditionPosition.One);\n this.setConditionIntoUi(combinedModel.condition2, ConditionPosition.Two);\n }\n else {\n var simpleModel = model;\n this.eJoinOperatorAnd.setValue(this.isDefaultOperator('AND'));\n this.eJoinOperatorOr.setValue(this.isDefaultOperator('OR'));\n this.eType1.setValue(simpleModel.type);\n this.eType2.setValue(this.optionsFactory.getDefaultOption());\n this.setConditionIntoUi(simpleModel, ConditionPosition.One);\n this.setConditionIntoUi(null, ConditionPosition.Two);\n }\n return AgPromise.resolve();\n };\n SimpleFilter.prototype.doesFilterPass = function (params) {\n var _this = this;\n var model = this.getModel();\n if (model == null) {\n return true;\n }\n var operator = model.operator;\n var models = [];\n if (operator) {\n var combinedModel = model;\n models.push(combinedModel.condition1, combinedModel.condition2);\n }\n else {\n models.push(model);\n }\n var combineFunction = operator && operator === 'OR' ? 'some' : 'every';\n return models[combineFunction](function (m) { return _this.individualConditionPasses(params, m); });\n };\n SimpleFilter.prototype.setParams = function (params) {\n _super.prototype.setParams.call(this, params);\n this.optionsFactory = new OptionsFactory();\n this.optionsFactory.init(params, this.getDefaultFilterOptions());\n this.allowTwoConditions = !params.suppressAndOrCondition;\n this.alwaysShowBothConditions = !!params.alwaysShowBothConditions;\n this.defaultJoinOperator = this.getDefaultJoinOperator(params.defaultJoinOperator);\n this.putOptionsIntoDropdown();\n this.addChangedListeners();\n };\n SimpleFilter.prototype.getDefaultJoinOperator = function (defaultJoinOperator) {\n return includes(['AND', 'OR'], defaultJoinOperator) ? defaultJoinOperator : 'AND';\n };\n SimpleFilter.prototype.putOptionsIntoDropdown = function () {\n var _this = this;\n var filterOptions = this.optionsFactory.getFilterOptions();\n var eTypes = [this.eType1, this.eType2];\n // Add specified options to all condition drop-downs.\n filterOptions.forEach(function (option) {\n var listOption = typeof option === 'string' ?\n _this.createBoilerplateListOption(option) :\n _this.createCustomListOption(option);\n eTypes.forEach(function (eType) { return eType.addOption(listOption); });\n });\n // Make drop-downs read-only if there is only one option.\n eTypes.forEach(function (eType) { return eType.setDisabled(filterOptions.length <= 1); });\n };\n SimpleFilter.prototype.createBoilerplateListOption = function (option) {\n return { value: option, text: this.translate(option) };\n };\n SimpleFilter.prototype.createCustomListOption = function (option) {\n var displayKey = option.displayKey;\n var customOption = this.optionsFactory.getCustomOption(option.displayKey);\n return {\n value: displayKey,\n text: customOption ?\n this.gridOptionsWrapper.getLocaleTextFunc()(customOption.displayKey, customOption.displayName) :\n this.translate(displayKey),\n };\n };\n SimpleFilter.prototype.isAllowTwoConditions = function () {\n return this.allowTwoConditions;\n };\n SimpleFilter.prototype.createBodyTemplate = function () {\n return /* html */ \"\\n \\n \" + this.createValueTemplate(ConditionPosition.One) + \"\\n
\\n \\n \\n
\\n \\n \" + this.createValueTemplate(ConditionPosition.Two);\n };\n SimpleFilter.prototype.getCssIdentifier = function () {\n return 'simple-filter';\n };\n SimpleFilter.prototype.updateUiVisibility = function () {\n var _this = this;\n var elementConditionGroups = [\n [this.eType1],\n [this.eType2, this.eJoinOperatorPanel, this.eJoinOperatorAnd, this.eJoinOperatorOr],\n ];\n var elementBodies = [this.eCondition1Body, this.eCondition2Body];\n elementConditionGroups.forEach(function (group, position) {\n var visible = _this.isConditionVisible(position);\n var disabled = _this.isConditionDisabled(position);\n group.forEach(function (element) {\n if (element instanceof AgAbstractInputField || element instanceof AgSelect) {\n element.setDisabled(disabled);\n element.setDisplayed(visible);\n }\n else {\n setDisabled(element, disabled);\n setDisplayed(element, visible);\n }\n });\n });\n elementBodies.forEach(function (element, index) {\n setDisplayed(element, _this.isConditionBodyVisible(index));\n });\n this.forEachInput(function (element, index, position, numberOfInputs) {\n _this.setElementDisplayed(element, index < numberOfInputs);\n _this.setElementDisabled(element, _this.isConditionDisabled(position));\n });\n this.resetPlaceholder();\n };\n SimpleFilter.prototype.afterGuiAttached = function (params) {\n _super.prototype.afterGuiAttached.call(this, params);\n this.resetPlaceholder();\n if (!params || (!params.suppressFocus && !this.isReadOnly())) {\n var firstInput = this.getInputs()[0][0];\n if (!firstInput) {\n return;\n }\n if (firstInput instanceof AgAbstractInputField) {\n firstInput.getInputElement().focus();\n }\n }\n };\n // allow sub-classes to reset HTML placeholders after UI update.\n SimpleFilter.prototype.resetPlaceholder = function () {\n var _this = this;\n var globalTranslate = this.gridOptionsWrapper.getLocaleTextFunc();\n this.forEachInput(function (element, index, _, numberOfInputs) {\n if (!(element instanceof AgAbstractInputField)) {\n return;\n }\n var placeholder = index === 0 && numberOfInputs > 1 ? 'inRangeStart' :\n index === 0 ? 'filterOoo' :\n 'inRangeEnd';\n var ariaLabel = index === 0 && numberOfInputs > 1 ? globalTranslate('ariaFilterFromValue', 'Filter from value') :\n index === 0 ? globalTranslate('ariaFilterValue', 'Filter Value') :\n globalTranslate('ariaFilterToValue', 'Filter to Value');\n element.setInputPlaceholder(_this.translate(placeholder));\n element.setInputAriaLabel(ariaLabel);\n });\n };\n SimpleFilter.prototype.setElementValue = function (element, value, silent) {\n if (element instanceof AgAbstractInputField) {\n element.setValue(value != null ? String(value) : null, silent);\n }\n };\n SimpleFilter.prototype.setElementDisplayed = function (element, displayed) {\n if (element instanceof Component) {\n setDisplayed(element.getGui(), displayed);\n }\n };\n SimpleFilter.prototype.setElementDisabled = function (element, disabled) {\n if (element instanceof Component) {\n setDisabled(element.getGui(), disabled);\n }\n };\n SimpleFilter.prototype.attachElementOnChange = function (element, listener) {\n if (element instanceof AgAbstractInputField) {\n element.onValueChange(listener);\n }\n };\n SimpleFilter.prototype.forEachInput = function (cb) {\n var _this = this;\n var inputs = this.getInputs();\n this.getConditionTypes().forEach(function (type, position) {\n var numberOfInputs = _this.getNumberOfInputs(type);\n for (var index = 0; index < inputs[position].length; index++) {\n var input = inputs[position][index];\n if (input != null) {\n cb(input, index, position, numberOfInputs);\n }\n }\n });\n };\n SimpleFilter.prototype.isConditionVisible = function (position) {\n if (position === 0) {\n return true;\n } // Position 0 should always be visible.\n if (!this.allowTwoConditions) {\n return false;\n } // Short-circuit if no tail conditions.\n if (this.isReadOnly()) {\n // Only display a condition when read-only if the condition is complete.\n return this.isConditionUiComplete(position);\n }\n if (this.alwaysShowBothConditions) {\n return true;\n }\n // Only display a 2nd or later condition when the previous condition is complete.\n return this.isConditionUiComplete(position - 1);\n };\n SimpleFilter.prototype.isConditionDisabled = function (position) {\n if (this.isReadOnly()) {\n return true;\n } // Read-only mode trumps everything.\n if (!this.isConditionVisible(position)) {\n return true;\n } // Invisible implies disabled.\n if (position === 0) {\n return false;\n } // Position 0 should typically be editable.\n // Only allow editing of a 2nd or later condition if the previous condition is complete.\n return !this.isConditionUiComplete(position - 1);\n };\n SimpleFilter.prototype.isConditionBodyVisible = function (position) {\n if (!this.isConditionVisible(position)) {\n return false;\n }\n // Check that the condition needs inputs.\n var type = this.getConditionTypes()[position];\n var numberOfInputs = this.getNumberOfInputs(type);\n return numberOfInputs > 0;\n };\n // returns true if the UI represents a working filter, eg all parts are filled out.\n // eg if text filter and textfield blank then returns false.\n SimpleFilter.prototype.isConditionUiComplete = function (position) {\n var type = this.getConditionTypes()[position];\n if (type === SimpleFilter.EMPTY) {\n return false;\n }\n if (this.getValues(position).some(function (v) { return v == null; })) {\n return false;\n }\n return true;\n };\n SimpleFilter.prototype.resetUiToDefaults = function (silent) {\n var _this = this;\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n var filteringLabel = translate('ariaFilteringOperator', 'Filtering operator');\n var uniqueGroupId = 'ag-simple-filter-and-or-' + this.getCompId();\n var defaultOption = this.optionsFactory.getDefaultOption();\n this.eType1\n .setValue(defaultOption, silent)\n .setAriaLabel(filteringLabel)\n .setDisabled(this.isReadOnly());\n this.eType2\n .setValue(this.optionsFactory.getDefaultOption(), silent)\n .setAriaLabel(filteringLabel)\n .setDisabled(this.isReadOnly());\n this.eJoinOperatorAnd\n .setValue(this.isDefaultOperator('AND'), silent)\n .setName(uniqueGroupId)\n .setLabel(this.translate('andCondition'))\n .setDisabled(this.isReadOnly());\n this.eJoinOperatorOr\n .setValue(this.isDefaultOperator('OR'), silent)\n .setName(uniqueGroupId)\n .setLabel(this.translate('orCondition'))\n .setDisabled(this.isReadOnly());\n this.forEachInput(function (element) {\n _this.setElementValue(element, null, silent);\n _this.setElementDisabled(element, _this.isReadOnly());\n });\n this.resetPlaceholder();\n return AgPromise.resolve();\n };\n // puts model values into the UI\n SimpleFilter.prototype.setConditionIntoUi = function (model, position) {\n var _this = this;\n var values = this.mapValuesFromModel(model);\n this.forEachInput(function (element, index, elPosition, _) {\n if (elPosition !== position) {\n return;\n }\n _this.setElementValue(element, values[index] != null ? values[index] : null);\n });\n };\n // after floating filter changes, this sets the 'value' section. this is implemented by the base class\n // (as that's where value is controlled), the 'type' part from the floating filter is dealt with in this class.\n SimpleFilter.prototype.setValueFromFloatingFilter = function (value) {\n var _this = this;\n this.forEachInput(function (element, index, position, _) {\n _this.setElementValue(element, index === 0 && position === 0 ? value : null);\n });\n };\n SimpleFilter.prototype.isDefaultOperator = function (operator) {\n return operator === this.defaultJoinOperator;\n };\n SimpleFilter.prototype.addChangedListeners = function () {\n var _this = this;\n if (this.isReadOnly()) {\n return;\n }\n var listener = function () { return _this.onUiChanged(); };\n this.eType1.onValueChange(listener);\n this.eType2.onValueChange(listener);\n this.eJoinOperatorOr.onValueChange(listener);\n this.eJoinOperatorAnd.onValueChange(listener);\n this.forEachInput(function (element) {\n _this.attachElementOnChange(element, listener);\n });\n };\n /** returns true if the row passes the said condition */\n SimpleFilter.prototype.individualConditionPasses = function (params, filterModel) {\n var cellValue = this.getCellValue(params.node);\n var values = this.mapValuesFromModel(filterModel);\n var customFilterOption = this.optionsFactory.getCustomOption(filterModel.type);\n var customFilterResult = this.evaluateCustomFilter(customFilterOption, values, cellValue);\n if (customFilterResult != null) {\n return customFilterResult;\n }\n if (cellValue == null) {\n return this.evaluateNullValue(filterModel.type);\n }\n return this.evaluateNonNullValue(values, cellValue, filterModel, params);\n };\n SimpleFilter.prototype.evaluateCustomFilter = function (customFilterOption, values, cellValue) {\n if (customFilterOption == null) {\n return;\n }\n var predicate = customFilterOption.predicate;\n // only execute the custom filter if a value exists or a value isn't required, i.e. input is hidden\n if (predicate != null && !values.some(function (v) { return v == null; })) {\n return predicate(values, cellValue);\n }\n // No custom filter invocation, indicate that to the caller.\n return;\n };\n SimpleFilter.prototype.isBlank = function (cellValue) {\n return cellValue == null ||\n (typeof cellValue === 'string' && cellValue.trim().length === 0);\n };\n SimpleFilter.EMPTY = 'empty';\n SimpleFilter.BLANK = 'blank';\n SimpleFilter.NOT_BLANK = 'notBlank';\n SimpleFilter.EQUALS = 'equals';\n SimpleFilter.NOT_EQUAL = 'notEqual';\n SimpleFilter.LESS_THAN = 'lessThan';\n SimpleFilter.LESS_THAN_OR_EQUAL = 'lessThanOrEqual';\n SimpleFilter.GREATER_THAN = 'greaterThan';\n SimpleFilter.GREATER_THAN_OR_EQUAL = 'greaterThanOrEqual';\n SimpleFilter.IN_RANGE = 'inRange';\n SimpleFilter.CONTAINS = 'contains';\n SimpleFilter.NOT_CONTAINS = 'notContains';\n SimpleFilter.STARTS_WITH = 'startsWith';\n SimpleFilter.ENDS_WITH = 'endsWith';\n __decorate([\n RefSelector('eOptions1')\n ], SimpleFilter.prototype, \"eType1\", void 0);\n __decorate([\n RefSelector('eOptions2')\n ], SimpleFilter.prototype, \"eType2\", void 0);\n __decorate([\n RefSelector('eJoinOperatorPanel')\n ], SimpleFilter.prototype, \"eJoinOperatorPanel\", void 0);\n __decorate([\n RefSelector('eJoinOperatorAnd')\n ], SimpleFilter.prototype, \"eJoinOperatorAnd\", void 0);\n __decorate([\n RefSelector('eJoinOperatorOr')\n ], SimpleFilter.prototype, \"eJoinOperatorOr\", void 0);\n __decorate([\n RefSelector('eCondition1Body')\n ], SimpleFilter.prototype, \"eCondition1Body\", void 0);\n __decorate([\n RefSelector('eCondition2Body')\n ], SimpleFilter.prototype, \"eCondition2Body\", void 0);\n return SimpleFilter;\n}(ProvidedFilter));\nexport { SimpleFilter };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { SimpleFilter } from \"./simpleFilter\";\nvar ScalarFilter = /** @class */ (function (_super) {\n __extends(ScalarFilter, _super);\n function ScalarFilter() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n ScalarFilter.prototype.setParams = function (params) {\n _super.prototype.setParams.call(this, params);\n this.scalarFilterParams = params;\n };\n ScalarFilter.prototype.evaluateNullValue = function (filterType) {\n switch (filterType) {\n case ScalarFilter.EQUALS:\n case ScalarFilter.NOT_EQUAL:\n if (this.scalarFilterParams.includeBlanksInEquals) {\n return true;\n }\n break;\n case ScalarFilter.GREATER_THAN:\n case ScalarFilter.GREATER_THAN_OR_EQUAL:\n if (this.scalarFilterParams.includeBlanksInGreaterThan) {\n return true;\n }\n break;\n case ScalarFilter.LESS_THAN:\n case ScalarFilter.LESS_THAN_OR_EQUAL:\n if (this.scalarFilterParams.includeBlanksInLessThan) {\n return true;\n }\n break;\n case ScalarFilter.IN_RANGE:\n if (this.scalarFilterParams.includeBlanksInRange) {\n return true;\n }\n break;\n case ScalarFilter.BLANK:\n return true;\n case ScalarFilter.NOT_BLANK:\n return false;\n }\n return false;\n };\n ScalarFilter.prototype.evaluateNonNullValue = function (values, cellValue, filterModel) {\n var comparator = this.comparator();\n var compareResult = values[0] != null ? comparator(values[0], cellValue) : 0;\n switch (filterModel.type) {\n case ScalarFilter.EQUALS:\n return compareResult === 0;\n case ScalarFilter.NOT_EQUAL:\n return compareResult !== 0;\n case ScalarFilter.GREATER_THAN:\n return compareResult > 0;\n case ScalarFilter.GREATER_THAN_OR_EQUAL:\n return compareResult >= 0;\n case ScalarFilter.LESS_THAN:\n return compareResult < 0;\n case ScalarFilter.LESS_THAN_OR_EQUAL:\n return compareResult <= 0;\n case ScalarFilter.IN_RANGE: {\n var compareToResult = comparator(values[1], cellValue);\n return this.scalarFilterParams.inRangeInclusive ?\n compareResult >= 0 && compareToResult <= 0 :\n compareResult > 0 && compareToResult < 0;\n }\n case ScalarFilter.BLANK:\n return this.isBlank(cellValue);\n case ScalarFilter.NOT_BLANK:\n return !this.isBlank(cellValue);\n default:\n console.warn('AG Grid: Unexpected type of filter \"' + filterModel.type + '\", it looks like the filter was configured with incorrect Filter Options');\n return true;\n }\n };\n return ScalarFilter;\n}(SimpleFilter));\nexport { ScalarFilter };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { RefSelector } from '../../../widgets/componentAnnotations';\nimport { Autowired } from '../../../context/context';\nimport { DateCompWrapper } from './dateCompWrapper';\nimport { ConditionPosition } from '../simpleFilter';\nimport { ScalarFilter } from '../scalarFilter';\nimport { serialiseDate, parseDateTimeFromString } from '../../../utils/date';\nvar DEFAULT_MIN_YEAR = 1000;\nvar DEFAULT_MAX_YEAR = Infinity;\nvar DateFilter = /** @class */ (function (_super) {\n __extends(DateFilter, _super);\n function DateFilter() {\n var _this = _super.call(this, 'dateFilter') || this;\n _this.minValidYear = DEFAULT_MIN_YEAR;\n _this.maxValidYear = DEFAULT_MAX_YEAR;\n return _this;\n }\n DateFilter.prototype.afterGuiAttached = function (params) {\n _super.prototype.afterGuiAttached.call(this, params);\n this.dateCondition1FromComp.afterGuiAttached(params);\n };\n DateFilter.prototype.mapValuesFromModel = function (filterModel) {\n // unlike the other filters, we do two things here:\n // 1) allow for different attribute names (same as done for other filters) (eg the 'from' and 'to'\n // are in different locations in Date and Number filter models)\n // 2) convert the type (because Date filter uses Dates, however model is 'string')\n //\n // NOTE: The conversion of string to date also removes the timezone - i.e. when user picks\n // a date from the UI, it will have timezone info in it. This is lost when creating\n // the model. When we recreate the date again here, it's without a timezone.\n var _a = filterModel || {}, dateFrom = _a.dateFrom, dateTo = _a.dateTo, type = _a.type;\n return [\n dateFrom && parseDateTimeFromString(dateFrom) || null,\n dateTo && parseDateTimeFromString(dateTo) || null,\n ].slice(0, this.getNumberOfInputs(type));\n };\n DateFilter.prototype.comparator = function () {\n return this.dateFilterParams.comparator ? this.dateFilterParams.comparator : this.defaultComparator.bind(this);\n };\n DateFilter.prototype.defaultComparator = function (filterDate, cellValue) {\n // The default comparator assumes that the cellValue is a date\n var cellAsDate = cellValue;\n if (cellValue == null || cellAsDate < filterDate) {\n return -1;\n }\n if (cellAsDate > filterDate) {\n return 1;\n }\n return 0;\n };\n DateFilter.prototype.setParams = function (params) {\n _super.prototype.setParams.call(this, params);\n this.dateFilterParams = params;\n var yearParser = function (param, fallback) {\n if (params[param] != null) {\n if (!isNaN(params[param])) {\n return params[param] == null ? fallback : Number(params[param]);\n }\n else {\n console.warn(\"AG Grid: DateFilter \" + param + \" is not a number\");\n }\n }\n return fallback;\n };\n this.minValidYear = yearParser('minValidYear', DEFAULT_MIN_YEAR);\n this.maxValidYear = yearParser('maxValidYear', DEFAULT_MAX_YEAR);\n if (this.minValidYear > this.maxValidYear) {\n console.warn(\"AG Grid: DateFilter minValidYear should be <= maxValidYear\");\n }\n this.createDateComponents();\n };\n DateFilter.prototype.createDateComponents = function () {\n var _this = this;\n var createDateCompWrapper = function (element) {\n return new DateCompWrapper(_this.getContext(), _this.userComponentFactory, {\n onDateChanged: function () { return _this.onUiChanged(); },\n filterParams: _this.dateFilterParams\n }, element);\n };\n this.dateCondition1FromComp = createDateCompWrapper(this.eCondition1PanelFrom);\n this.dateCondition1ToComp = createDateCompWrapper(this.eCondition1PanelTo);\n this.dateCondition2FromComp = createDateCompWrapper(this.eCondition2PanelFrom);\n this.dateCondition2ToComp = createDateCompWrapper(this.eCondition2PanelTo);\n this.addDestroyFunc(function () {\n _this.forEachInput(function (element) { return element.destroy(); });\n });\n };\n DateFilter.prototype.setElementValue = function (element, value, silent) {\n element.setDate(value);\n };\n DateFilter.prototype.setElementDisplayed = function (element, displayed) {\n element.setDisplayed(displayed);\n };\n DateFilter.prototype.setElementDisabled = function (element, disabled) {\n element.setDisabled(disabled);\n };\n DateFilter.prototype.getDefaultFilterOptions = function () {\n return DateFilter.DEFAULT_FILTER_OPTIONS;\n };\n DateFilter.prototype.createValueTemplate = function (position) {\n var pos = position === ConditionPosition.One ? '1' : '2';\n return /* html */ \"\\n
\\n
\\n
\\n
\";\n };\n DateFilter.prototype.isConditionUiComplete = function (position) {\n var _this = this;\n if (!_super.prototype.isConditionUiComplete.call(this, position)) {\n return false;\n }\n var isValidDate = function (value) { return value != null\n && value.getUTCFullYear() >= _this.minValidYear\n && value.getUTCFullYear() <= _this.maxValidYear; };\n var valid = true;\n this.forEachInput(function (element, index, elPosition, numberOfInputs) {\n if (elPosition !== position || !valid || index >= numberOfInputs) {\n return;\n }\n valid = valid && isValidDate(element.getDate());\n });\n return valid;\n };\n DateFilter.prototype.areSimpleModelsEqual = function (aSimple, bSimple) {\n return aSimple.dateFrom === bSimple.dateFrom\n && aSimple.dateTo === bSimple.dateTo\n && aSimple.type === bSimple.type;\n };\n DateFilter.prototype.getFilterType = function () {\n return 'date';\n };\n DateFilter.prototype.createCondition = function (position) {\n var type = this.getConditionTypes()[position];\n var model = {};\n var values = this.getValues(position);\n if (values.length > 0) {\n model.dateFrom = serialiseDate(values[0]);\n }\n if (values.length > 1) {\n model.dateTo = serialiseDate(values[1]);\n }\n return __assign({ dateFrom: null, dateTo: null, filterType: this.getFilterType(), type: type }, model);\n };\n DateFilter.prototype.resetPlaceholder = function () {\n var globalTranslate = this.gridOptionsWrapper.getLocaleTextFunc();\n var placeholder = this.translate('dateFormatOoo');\n var ariaLabel = globalTranslate('ariaFilterValue', 'Filter Value');\n this.forEachInput(function (element) {\n element.setInputPlaceholder(placeholder);\n element.setInputAriaLabel(ariaLabel);\n });\n };\n DateFilter.prototype.getInputs = function () {\n return [\n [this.dateCondition1FromComp, this.dateCondition1ToComp],\n [this.dateCondition2FromComp, this.dateCondition2ToComp],\n ];\n };\n DateFilter.prototype.getValues = function (position) {\n var result = [];\n this.forEachInput(function (element, index, elPosition, numberOfInputs) {\n if (position === elPosition && index < numberOfInputs) {\n result.push(element.getDate());\n }\n });\n return result;\n };\n DateFilter.DEFAULT_FILTER_OPTIONS = [\n ScalarFilter.EQUALS,\n ScalarFilter.GREATER_THAN,\n ScalarFilter.LESS_THAN,\n ScalarFilter.NOT_EQUAL,\n ScalarFilter.IN_RANGE,\n ScalarFilter.BLANK,\n ScalarFilter.NOT_BLANK,\n ];\n __decorate([\n RefSelector('eCondition1PanelFrom')\n ], DateFilter.prototype, \"eCondition1PanelFrom\", void 0);\n __decorate([\n RefSelector('eCondition1PanelTo')\n ], DateFilter.prototype, \"eCondition1PanelTo\", void 0);\n __decorate([\n RefSelector('eCondition2PanelFrom')\n ], DateFilter.prototype, \"eCondition2PanelFrom\", void 0);\n __decorate([\n RefSelector('eCondition2PanelTo')\n ], DateFilter.prototype, \"eCondition2PanelTo\", void 0);\n __decorate([\n Autowired('userComponentFactory')\n ], DateFilter.prototype, \"userComponentFactory\", void 0);\n return DateFilter;\n}(ScalarFilter));\nexport { DateFilter };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { Component } from '../../../widgets/component';\nimport { SimpleFilter } from '../../provided/simpleFilter';\nimport { OptionsFactory } from '../../provided/optionsFactory';\nvar SimpleFloatingFilter = /** @class */ (function (_super) {\n __extends(SimpleFloatingFilter, _super);\n function SimpleFloatingFilter() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n SimpleFloatingFilter.prototype.getDefaultDebounceMs = function () {\n return 0;\n };\n // this is a user component, and IComponent has \"public destroy()\" as part of the interface.\n // so we need to override destroy() just to make the method public.\n SimpleFloatingFilter.prototype.destroy = function () {\n _super.prototype.destroy.call(this);\n };\n // used by:\n // 1) NumberFloatingFilter & TextFloatingFilter: Always, for both when editable and read only.\n // 2) DateFloatingFilter: Only when read only (as we show text rather than a date picker when read only)\n SimpleFloatingFilter.prototype.getTextFromModel = function (model) {\n if (!model) {\n return null;\n }\n var isCombined = model.operator != null;\n if (isCombined) {\n var combinedModel = model;\n var _a = combinedModel || {}, condition1 = _a.condition1, condition2 = _a.condition2;\n var customOption1 = this.optionsFactory.getCustomOption(condition1.type);\n var customOption2 = this.optionsFactory.getCustomOption(condition2.type);\n return [\n this.conditionToString(condition1, customOption1),\n combinedModel.operator,\n this.conditionToString(condition2, customOption2),\n ].join(' ');\n }\n else {\n var condition = model;\n var customOption = this.optionsFactory.getCustomOption(condition.type);\n // For custom filter options we display the Name of the filter instead\n // of displaying the `from` value, as it wouldn't be relevant\n var _b = customOption || {}, displayKey = _b.displayKey, displayName = _b.displayName, numberOfInputs = _b.numberOfInputs;\n if (displayKey && displayName && numberOfInputs === 0) {\n this.gridOptionsWrapper.getLocaleTextFunc()(displayKey, displayName);\n return displayName;\n }\n return this.conditionToString(condition, customOption);\n }\n };\n SimpleFloatingFilter.prototype.isEventFromFloatingFilter = function (event) {\n return event && event.afterFloatingFilter;\n };\n SimpleFloatingFilter.prototype.getLastType = function () {\n return this.lastType;\n };\n SimpleFloatingFilter.prototype.isReadOnly = function () {\n return this.readOnly;\n };\n SimpleFloatingFilter.prototype.setLastTypeFromModel = function (model) {\n // if no model provided by the parent filter use default\n if (!model) {\n this.lastType = this.optionsFactory.getDefaultOption();\n return;\n }\n var isCombined = model.operator;\n var condition;\n if (isCombined) {\n var combinedModel = model;\n condition = combinedModel.condition1;\n }\n else {\n condition = model;\n }\n this.lastType = condition.type;\n };\n SimpleFloatingFilter.prototype.canWeEditAfterModelFromParentFilter = function (model) {\n if (!model) {\n // if no model, then we can edit as long as the lastType is something we can edit, as this\n // is the type we will provide to the parent filter if the user decides to use the floating filter.\n return this.isTypeEditable(this.lastType);\n }\n // never allow editing if the filter is combined (ie has two parts)\n var isCombined = model.operator;\n if (isCombined) {\n return false;\n }\n var simpleModel = model;\n return this.isTypeEditable(simpleModel.type);\n };\n SimpleFloatingFilter.prototype.init = function (params) {\n this.optionsFactory = new OptionsFactory();\n this.optionsFactory.init(params.filterParams, this.getDefaultFilterOptions());\n this.lastType = this.optionsFactory.getDefaultOption();\n // readOnly is a property of IProvidedFilterParams - we need to find a better (type-safe)\n // way to support reading this in the future.\n this.readOnly = !!params.filterParams.readOnly;\n // we are editable if:\n // 1) there is a type (user has configured filter wrong if not type)\n // AND\n // 2) the default type is not 'in range'\n var editable = this.isTypeEditable(this.lastType);\n this.setEditable(editable);\n };\n SimpleFloatingFilter.prototype.doesFilterHaveSingleInput = function (filterType) {\n var customFilterOption = this.optionsFactory.getCustomOption(filterType);\n var numberOfInputs = (customFilterOption || {}).numberOfInputs;\n return numberOfInputs == null || numberOfInputs == 1;\n };\n SimpleFloatingFilter.prototype.isTypeEditable = function (type) {\n var uneditableTypes = [\n SimpleFilter.IN_RANGE, SimpleFilter.EMPTY, SimpleFilter.BLANK, SimpleFilter.NOT_BLANK,\n ];\n return !!type &&\n !this.isReadOnly() &&\n this.doesFilterHaveSingleInput(type) &&\n uneditableTypes.indexOf(type) < 0;\n };\n return SimpleFloatingFilter;\n}(Component));\nexport { SimpleFloatingFilter };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { DateFilter } from './dateFilter';\nimport { Autowired } from '../../../context/context';\nimport { DateCompWrapper } from './dateCompWrapper';\nimport { RefSelector } from '../../../widgets/componentAnnotations';\nimport { SimpleFilter } from '../simpleFilter';\nimport { SimpleFloatingFilter } from '../../floating/provided/simpleFloatingFilter';\nimport { ProvidedFilter } from '../providedFilter';\nimport { setDisplayed } from '../../../utils/dom';\nimport { dateToFormattedString, parseDateTimeFromString, serialiseDate } from '../../../utils/date';\nimport { debounce } from '../../../utils/function';\nvar DateFloatingFilter = /** @class */ (function (_super) {\n __extends(DateFloatingFilter, _super);\n function DateFloatingFilter() {\n return _super.call(this, /* html */ \"\\n
\\n \\n
\\n
\") || this;\n }\n DateFloatingFilter.prototype.getDefaultFilterOptions = function () {\n return DateFilter.DEFAULT_FILTER_OPTIONS;\n };\n DateFloatingFilter.prototype.conditionToString = function (condition, options) {\n var type = condition.type;\n var numberOfInputs = (options || {}).numberOfInputs;\n var isRange = type == SimpleFilter.IN_RANGE || numberOfInputs === 2;\n var dateFrom = parseDateTimeFromString(condition.dateFrom);\n var dateTo = parseDateTimeFromString(condition.dateTo);\n var format = this.filterParams.inRangeFloatingFilterDateFormat;\n if (isRange) {\n var formattedFrom = dateFrom !== null ? dateToFormattedString(dateFrom, format) : 'null';\n var formattedTo = dateTo !== null ? dateToFormattedString(dateTo, format) : 'null';\n return formattedFrom + \"-\" + formattedTo;\n }\n if (dateFrom != null) {\n return dateToFormattedString(dateFrom, format);\n }\n // cater for when the type doesn't need a value\n return \"\" + type;\n };\n DateFloatingFilter.prototype.init = function (params) {\n _super.prototype.init.call(this, params);\n this.params = params;\n this.filterParams = params.filterParams;\n this.createDateComponent();\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n this.eReadOnlyText\n .setDisabled(true)\n .setInputAriaLabel(translate('ariaDateFilterInput', 'Date Filter Input'));\n };\n DateFloatingFilter.prototype.setEditable = function (editable) {\n setDisplayed(this.eDateWrapper, editable);\n setDisplayed(this.eReadOnlyText.getGui(), !editable);\n };\n DateFloatingFilter.prototype.onParentModelChanged = function (model, event) {\n // We don't want to update the floating filter if the floating filter caused the change,\n // because the UI is already in sync. if we didn't do this, the UI would behave strangely\n // as it would be updating as the user is typing\n if (this.isEventFromFloatingFilter(event)) {\n return;\n }\n _super.prototype.setLastTypeFromModel.call(this, model);\n var allowEditing = !this.isReadOnly() &&\n this.canWeEditAfterModelFromParentFilter(model);\n this.setEditable(allowEditing);\n if (allowEditing) {\n if (model) {\n var dateModel = model;\n this.dateComp.setDate(parseDateTimeFromString(dateModel.dateFrom));\n }\n else {\n this.dateComp.setDate(null);\n }\n this.eReadOnlyText.setValue('');\n }\n else {\n this.eReadOnlyText.setValue(this.getTextFromModel(model));\n this.dateComp.setDate(null);\n }\n };\n DateFloatingFilter.prototype.onDateChanged = function () {\n var _this = this;\n var filterValueDate = this.dateComp.getDate();\n var filterValueText = serialiseDate(filterValueDate);\n this.params.parentFilterInstance(function (filterInstance) {\n if (filterInstance) {\n var date = parseDateTimeFromString(filterValueText);\n filterInstance.onFloatingFilterChanged(_this.getLastType() || null, date);\n }\n });\n };\n DateFloatingFilter.prototype.createDateComponent = function () {\n var _this = this;\n var debounceMs = ProvidedFilter.getDebounceMs(this.params.filterParams, this.getDefaultDebounceMs());\n var dateComponentParams = {\n onDateChanged: debounce(this.onDateChanged.bind(this), debounceMs),\n filterParams: this.params.column.getColDef().filterParams\n };\n this.dateComp = new DateCompWrapper(this.getContext(), this.userComponentFactory, dateComponentParams, this.eDateWrapper);\n this.addDestroyFunc(function () { return _this.dateComp.destroy(); });\n };\n __decorate([\n Autowired('userComponentFactory')\n ], DateFloatingFilter.prototype, \"userComponentFactory\", void 0);\n __decorate([\n RefSelector('eReadOnlyText')\n ], DateFloatingFilter.prototype, \"eReadOnlyText\", void 0);\n __decorate([\n RefSelector('eDateWrapper')\n ], DateFloatingFilter.prototype, \"eDateWrapper\", void 0);\n return DateFloatingFilter;\n}(SimpleFloatingFilter));\nexport { DateFloatingFilter };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from '../../../widgets/component';\nimport { RefSelector } from '../../../widgets/componentAnnotations';\nimport { serialiseDate, parseDateTimeFromString } from '../../../utils/date';\nimport { isBrowserChrome, isBrowserFirefox } from '../../../utils/browser';\nvar DefaultDateComponent = /** @class */ (function (_super) {\n __extends(DefaultDateComponent, _super);\n function DefaultDateComponent() {\n return _super.call(this, /* html */ \"\\n
\\n \\n
\") || this;\n }\n // this is a user component, and IComponent has \"public destroy()\" as part of the interface.\n // so we need to override destroy() just to make the method public.\n DefaultDateComponent.prototype.destroy = function () {\n _super.prototype.destroy.call(this);\n };\n DefaultDateComponent.prototype.init = function (params) {\n var _this = this;\n var eDocument = this.gridOptionsWrapper.getDocument();\n var inputElement = this.eDateInput.getInputElement();\n if (this.shouldUseBrowserDatePicker(params)) {\n inputElement.type = 'date';\n }\n // ensures that the input element is focussed when a clear button is clicked\n this.addManagedListener(inputElement, 'mousedown', function () {\n if (_this.eDateInput.isDisabled()) {\n return;\n }\n inputElement.focus();\n });\n this.addManagedListener(inputElement, 'input', function (e) {\n if (e.target !== eDocument.activeElement) {\n return;\n }\n if (_this.eDateInput.isDisabled()) {\n return;\n }\n params.onDateChanged();\n });\n var _a = params.filterParams || {}, minValidYear = _a.minValidYear, maxValidYear = _a.maxValidYear;\n if (minValidYear) {\n inputElement.min = minValidYear + \"-01-01\";\n }\n if (maxValidYear) {\n inputElement.max = maxValidYear + \"-12-31\";\n }\n };\n DefaultDateComponent.prototype.getDate = function () {\n return parseDateTimeFromString(this.eDateInput.getValue());\n };\n DefaultDateComponent.prototype.setDate = function (date) {\n this.eDateInput.setValue(serialiseDate(date, false));\n };\n DefaultDateComponent.prototype.setInputPlaceholder = function (placeholder) {\n this.eDateInput.setInputPlaceholder(placeholder);\n };\n DefaultDateComponent.prototype.setDisabled = function (disabled) {\n this.eDateInput.setDisabled(disabled);\n };\n DefaultDateComponent.prototype.afterGuiAttached = function (params) {\n if (!params || !params.suppressFocus) {\n this.eDateInput.getInputElement().focus();\n }\n };\n DefaultDateComponent.prototype.shouldUseBrowserDatePicker = function (params) {\n if (params.filterParams && params.filterParams.browserDatePicker != null) {\n return params.filterParams.browserDatePicker;\n }\n return isBrowserChrome() || isBrowserFirefox();\n };\n __decorate([\n RefSelector('eDateInput')\n ], DefaultDateComponent.prototype, \"eDateInput\", void 0);\n return DefaultDateComponent;\n}(Component));\nexport { DefaultDateComponent };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { RefSelector } from '../../../widgets/componentAnnotations';\nimport { ConditionPosition } from '../simpleFilter';\nimport { ScalarFilter } from '../scalarFilter';\nimport { makeNull } from '../../../utils/generic';\nimport { isBrowserChrome, isBrowserEdge } from '../../../utils/browser';\nvar NumberFilter = /** @class */ (function (_super) {\n __extends(NumberFilter, _super);\n function NumberFilter() {\n return _super.call(this, 'numberFilter') || this;\n }\n NumberFilter.prototype.mapValuesFromModel = function (filterModel) {\n var _a = filterModel || {}, filter = _a.filter, filterTo = _a.filterTo, type = _a.type;\n return [\n filter == null ? null : filter,\n filterTo == null ? null : filterTo,\n ].slice(0, this.getNumberOfInputs(type));\n };\n NumberFilter.prototype.getDefaultDebounceMs = function () {\n return 500;\n };\n NumberFilter.prototype.comparator = function () {\n return function (left, right) {\n if (left === right) {\n return 0;\n }\n return left < right ? 1 : -1;\n };\n };\n NumberFilter.prototype.setParams = function (params) {\n this.numberFilterParams = params;\n var allowedCharPattern = this.getAllowedCharPattern();\n if (allowedCharPattern) {\n var config = { allowedCharPattern: allowedCharPattern };\n this.resetTemplate({\n 'eValue-index0-1': config,\n 'eValue-index1-1': config,\n 'eValue-index0-2': config,\n 'eValue-index1-2': config,\n });\n }\n _super.prototype.setParams.call(this, params);\n };\n NumberFilter.prototype.getDefaultFilterOptions = function () {\n return NumberFilter.DEFAULT_FILTER_OPTIONS;\n };\n NumberFilter.prototype.createValueTemplate = function (position) {\n var pos = position === ConditionPosition.One ? '1' : '2';\n var allowedCharPattern = this.getAllowedCharPattern();\n var agElementTag = allowedCharPattern ? 'ag-input-text-field' : 'ag-input-number-field';\n return /* html */ \"\\n
\\n <\" + agElementTag + \" class=\\\"ag-filter-from ag-filter-filter\\\" ref=\\\"eValue-index0-\" + pos + \"\\\">\\n <\" + agElementTag + \" class=\\\"ag-filter-to ag-filter-filter\\\" ref=\\\"eValue-index1-\" + pos + \"\\\">\\n
\";\n };\n NumberFilter.prototype.getValues = function (position) {\n var _this = this;\n var result = [];\n this.forEachInput(function (element, index, elPosition, numberOfInputs) {\n if (position === elPosition && index < numberOfInputs) {\n result.push(_this.stringToFloat(element.getValue()));\n }\n });\n return result;\n };\n NumberFilter.prototype.areSimpleModelsEqual = function (aSimple, bSimple) {\n return aSimple.filter === bSimple.filter\n && aSimple.filterTo === bSimple.filterTo\n && aSimple.type === bSimple.type;\n };\n NumberFilter.prototype.getFilterType = function () {\n return 'number';\n };\n NumberFilter.prototype.stringToFloat = function (value) {\n if (typeof value === 'number') {\n return value;\n }\n var filterText = makeNull(value);\n if (filterText != null && filterText.trim() === '') {\n filterText = null;\n }\n if (this.numberFilterParams.numberParser) {\n return this.numberFilterParams.numberParser(filterText);\n }\n return filterText == null || filterText.trim() === '-' ? null : parseFloat(filterText);\n };\n NumberFilter.prototype.createCondition = function (position) {\n var type = this.getConditionTypes()[position];\n var model = {\n filterType: this.getFilterType(),\n type: type\n };\n var values = this.getValues(position);\n if (values.length > 0) {\n model.filter = values[0];\n }\n if (values.length > 1) {\n model.filterTo = values[1];\n }\n return model;\n };\n NumberFilter.prototype.getInputs = function () {\n return [\n [this.eValueFrom1, this.eValueTo1],\n [this.eValueFrom2, this.eValueTo2],\n ];\n };\n NumberFilter.prototype.getAllowedCharPattern = function () {\n var allowedCharPattern = (this.numberFilterParams || {}).allowedCharPattern;\n if (allowedCharPattern) {\n return allowedCharPattern;\n }\n if (!isBrowserChrome() && !isBrowserEdge()) {\n // only Chrome and Edge support the HTML5 number field, so for other browsers we provide an equivalent\n // constraint instead\n return '\\\\d\\\\-\\\\.';\n }\n return null;\n };\n NumberFilter.DEFAULT_FILTER_OPTIONS = [\n ScalarFilter.EQUALS,\n ScalarFilter.NOT_EQUAL,\n ScalarFilter.LESS_THAN,\n ScalarFilter.LESS_THAN_OR_EQUAL,\n ScalarFilter.GREATER_THAN,\n ScalarFilter.GREATER_THAN_OR_EQUAL,\n ScalarFilter.IN_RANGE,\n ScalarFilter.BLANK,\n ScalarFilter.NOT_BLANK,\n ];\n __decorate([\n RefSelector('eValue-index0-1')\n ], NumberFilter.prototype, \"eValueFrom1\", void 0);\n __decorate([\n RefSelector('eValue-index1-1')\n ], NumberFilter.prototype, \"eValueTo1\", void 0);\n __decorate([\n RefSelector('eValue-index0-2')\n ], NumberFilter.prototype, \"eValueFrom2\", void 0);\n __decorate([\n RefSelector('eValue-index1-2')\n ], NumberFilter.prototype, \"eValueTo2\", void 0);\n return NumberFilter;\n}(ScalarFilter));\nexport { NumberFilter };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { RefSelector } from '../../../widgets/componentAnnotations';\nimport { SimpleFilter, ConditionPosition } from '../simpleFilter';\nimport { makeNull } from '../../../utils/generic';\nimport { _ } from '../../../utils';\nvar TextFilter = /** @class */ (function (_super) {\n __extends(TextFilter, _super);\n function TextFilter() {\n return _super.call(this, 'textFilter') || this;\n }\n TextFilter.trimInput = function (value) {\n var trimmedInput = value && value.trim();\n // trim the input, unless it is all whitespace (this is consistent with Excel behaviour)\n return trimmedInput === '' ? value : trimmedInput;\n };\n TextFilter.prototype.getDefaultDebounceMs = function () {\n return 500;\n };\n TextFilter.prototype.setParams = function (params) {\n _super.prototype.setParams.call(this, params);\n this.textFilterParams = params;\n this.matcher = this.getTextMatcher();\n this.formatter = this.textFilterParams.textFormatter ||\n (this.textFilterParams.caseSensitive ? TextFilter.DEFAULT_FORMATTER : TextFilter.DEFAULT_LOWERCASE_FORMATTER);\n };\n TextFilter.prototype.getTextMatcher = function () {\n var legacyComparator = this.textFilterParams.textCustomComparator;\n if (legacyComparator) {\n _.doOnce(function () { return console.warn('AG Grid - textCustomComparator is deprecated, use textMatcher instead.'); }, 'textCustomComparator.deprecated');\n return function (_a) {\n var filterOption = _a.filterOption, value = _a.value, filterText = _a.filterText;\n return legacyComparator(filterOption, value, filterText);\n };\n }\n return this.textFilterParams.textMatcher || TextFilter.DEFAULT_MATCHER;\n };\n TextFilter.prototype.createCondition = function (position) {\n var type = this.getConditionTypes()[position];\n var model = {\n filterType: this.getFilterType(),\n type: type,\n };\n var values = this.getValues(position);\n if (values.length > 0) {\n model.filter = values[0];\n }\n if (values.length > 1) {\n model.filterTo = values[1];\n }\n return model;\n };\n TextFilter.prototype.getFilterType = function () {\n return 'text';\n };\n TextFilter.prototype.areSimpleModelsEqual = function (aSimple, bSimple) {\n return aSimple.filter === bSimple.filter &&\n aSimple.filterTo === bSimple.filterTo &&\n aSimple.type === bSimple.type;\n };\n TextFilter.prototype.getInputs = function () {\n return [\n [this.eValueFrom1, this.eValueTo1],\n [this.eValueFrom2, this.eValueTo2],\n ];\n };\n TextFilter.prototype.getValues = function (position) {\n var _this = this;\n var result = [];\n this.forEachInput(function (element, index, elPosition, numberOfInputs) {\n if (position === elPosition && index < numberOfInputs) {\n var value = makeNull(element.getValue());\n var cleanValue = (_this.textFilterParams.trimInput ? TextFilter.trimInput(value) : value) || null;\n result.push(cleanValue);\n element.setValue(cleanValue, true); // ensure clean value is visible\n }\n });\n return result;\n };\n TextFilter.prototype.getDefaultFilterOptions = function () {\n return TextFilter.DEFAULT_FILTER_OPTIONS;\n };\n TextFilter.prototype.createValueTemplate = function (position) {\n var pos = position === ConditionPosition.One ? '1' : '2';\n return /* html */ \"\\n
\\n \\n \\n
\";\n };\n TextFilter.prototype.mapValuesFromModel = function (filterModel) {\n var _a = filterModel || {}, filter = _a.filter, filterTo = _a.filterTo, type = _a.type;\n return [\n filter || null,\n filterTo || null,\n ].slice(0, this.getNumberOfInputs(type));\n };\n TextFilter.prototype.evaluateNullValue = function (filterType) {\n var filterTypesAllowNulls = [\n SimpleFilter.NOT_EQUAL, SimpleFilter.NOT_CONTAINS, SimpleFilter.BLANK,\n ];\n return filterType ? filterTypesAllowNulls.indexOf(filterType) >= 0 : false;\n };\n TextFilter.prototype.evaluateNonNullValue = function (values, cellValue, filterModel, params) {\n var _this = this;\n var formattedValues = values.map(function (v) { return _this.formatter(v); }) || [];\n var cellValueFormatted = this.formatter(cellValue);\n var _a = this.textFilterParams, api = _a.api, colDef = _a.colDef, column = _a.column, columnApi = _a.columnApi, context = _a.context, textFormatter = _a.textFormatter;\n if (filterModel.type === SimpleFilter.BLANK) {\n return this.isBlank(cellValue);\n }\n else if (filterModel.type === SimpleFilter.NOT_BLANK) {\n return !this.isBlank(cellValue);\n }\n var matcherParams = {\n api: api,\n colDef: colDef,\n column: column,\n columnApi: columnApi,\n context: context,\n node: params.node,\n data: params.data,\n filterOption: filterModel.type,\n value: cellValueFormatted,\n textFormatter: textFormatter,\n };\n return formattedValues.some(function (v) { return _this.matcher(__assign(__assign({}, matcherParams), { filterText: v })); });\n };\n TextFilter.DEFAULT_FILTER_OPTIONS = [\n SimpleFilter.CONTAINS,\n SimpleFilter.NOT_CONTAINS,\n SimpleFilter.EQUALS,\n SimpleFilter.NOT_EQUAL,\n SimpleFilter.STARTS_WITH,\n SimpleFilter.ENDS_WITH,\n SimpleFilter.BLANK,\n SimpleFilter.NOT_BLANK,\n ];\n TextFilter.DEFAULT_FORMATTER = function (from) { return from; };\n TextFilter.DEFAULT_LOWERCASE_FORMATTER = function (from) { return from == null ? null : from.toString().toLowerCase(); };\n TextFilter.DEFAULT_MATCHER = function (_a) {\n var filterOption = _a.filterOption, value = _a.value, filterText = _a.filterText;\n if (filterText == null) {\n return false;\n }\n switch (filterOption) {\n case TextFilter.CONTAINS:\n return value.indexOf(filterText) >= 0;\n case TextFilter.NOT_CONTAINS:\n return value.indexOf(filterText) < 0;\n case TextFilter.EQUALS:\n return value === filterText;\n case TextFilter.NOT_EQUAL:\n return value != filterText;\n case TextFilter.STARTS_WITH:\n return value.indexOf(filterText) === 0;\n case TextFilter.ENDS_WITH:\n var index = value.lastIndexOf(filterText);\n return index >= 0 && index === (value.length - filterText.length);\n default:\n return false;\n }\n };\n __decorate([\n RefSelector('eValue-index0-1')\n ], TextFilter.prototype, \"eValueFrom1\", void 0);\n __decorate([\n RefSelector('eValue-index1-1')\n ], TextFilter.prototype, \"eValueTo1\", void 0);\n __decorate([\n RefSelector('eValue-index0-2')\n ], TextFilter.prototype, \"eValueFrom2\", void 0);\n __decorate([\n RefSelector('eValue-index1-2')\n ], TextFilter.prototype, \"eValueTo2\", void 0);\n return TextFilter;\n}(SimpleFilter));\nexport { TextFilter };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { RefSelector } from '../../../widgets/componentAnnotations';\nimport { debounce } from '../../../utils/function';\nimport { ProvidedFilter } from '../../provided/providedFilter';\nimport { PostConstruct, Autowired } from '../../../context/context';\nimport { SimpleFloatingFilter } from './simpleFloatingFilter';\nimport { SimpleFilter } from '../../provided/simpleFilter';\nimport { KeyCode } from '../../../constants/keyCode';\nimport { TextFilter } from '../../provided/text/textFilter';\nvar TextInputFloatingFilter = /** @class */ (function (_super) {\n __extends(TextInputFloatingFilter, _super);\n function TextInputFloatingFilter() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n TextInputFloatingFilter.prototype.postConstruct = function () {\n this.resetTemplate();\n };\n TextInputFloatingFilter.prototype.resetTemplate = function (paramsMap) {\n this.setTemplate(/* html */ \"\\n
\\n \\n
\\n \", paramsMap);\n };\n TextInputFloatingFilter.prototype.getDefaultDebounceMs = function () {\n return 500;\n };\n TextInputFloatingFilter.prototype.onParentModelChanged = function (model, event) {\n if (this.isEventFromFloatingFilter(event)) {\n // if the floating filter triggered the change, it is already in sync\n return;\n }\n this.setLastTypeFromModel(model);\n this.eFloatingFilterInput.setValue(this.getTextFromModel(model));\n this.setEditable(this.canWeEditAfterModelFromParentFilter(model));\n };\n TextInputFloatingFilter.prototype.init = function (params) {\n _super.prototype.init.call(this, params);\n this.params = params;\n this.applyActive = ProvidedFilter.isUseApplyButton(this.params.filterParams);\n var allowedCharPattern = this.params.filterParams.allowedCharPattern;\n if (allowedCharPattern != null) {\n this.resetTemplate({ eFloatingFilterInput: { allowedCharPattern: allowedCharPattern } });\n }\n if (!this.isReadOnly()) {\n var debounceMs = ProvidedFilter.getDebounceMs(this.params.filterParams, this.getDefaultDebounceMs());\n var toDebounce = debounce(this.syncUpWithParentFilter.bind(this), debounceMs);\n var filterGui = this.eFloatingFilterInput.getGui();\n this.addManagedListener(filterGui, 'input', toDebounce);\n this.addManagedListener(filterGui, 'keypress', toDebounce);\n this.addManagedListener(filterGui, 'keydown', toDebounce);\n }\n var columnDef = params.column.getDefinition();\n if (this.isReadOnly() || (columnDef.filterParams &&\n columnDef.filterParams.filterOptions &&\n columnDef.filterParams.filterOptions.length === 1 &&\n columnDef.filterParams.filterOptions[0] === 'inRange')) {\n this.eFloatingFilterInput.setDisabled(true);\n }\n var displayName = this.columnModel.getDisplayNameForColumn(params.column, 'header', true);\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n this.eFloatingFilterInput.setInputAriaLabel(displayName + \" \" + translate('ariaFilterInput', 'Filter Input'));\n };\n TextInputFloatingFilter.prototype.syncUpWithParentFilter = function (e) {\n var _this = this;\n var enterKeyPressed = e.key === KeyCode.ENTER;\n if (this.applyActive && !enterKeyPressed) {\n return;\n }\n var value = this.eFloatingFilterInput.getValue();\n if (this.params.filterParams.trimInput) {\n value = TextFilter.trimInput(value);\n this.eFloatingFilterInput.setValue(value, true); // ensure visible value is trimmed\n }\n this.params.parentFilterInstance(function (filterInstance) {\n if (filterInstance) {\n filterInstance.onFloatingFilterChanged(_this.getLastType() || null, value || null);\n }\n });\n };\n TextInputFloatingFilter.prototype.conditionToString = function (condition, options) {\n var numberOfInputs = (options || {}).numberOfInputs;\n var isRange = condition.type == SimpleFilter.IN_RANGE || numberOfInputs === 2;\n if (isRange) {\n return condition.filter + \"-\" + condition.filterTo;\n }\n // cater for when the type doesn't need a value\n if (condition.filter != null) {\n return \"\" + condition.filter;\n }\n return \"\" + condition.type;\n };\n TextInputFloatingFilter.prototype.setEditable = function (editable) {\n this.eFloatingFilterInput.setDisabled(!editable);\n };\n __decorate([\n Autowired('columnModel')\n ], TextInputFloatingFilter.prototype, \"columnModel\", void 0);\n __decorate([\n RefSelector('eFloatingFilterInput')\n ], TextInputFloatingFilter.prototype, \"eFloatingFilterInput\", void 0);\n __decorate([\n PostConstruct\n ], TextInputFloatingFilter.prototype, \"postConstruct\", null);\n return TextInputFloatingFilter;\n}(SimpleFloatingFilter));\nexport { TextInputFloatingFilter };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { NumberFilter } from './numberFilter';\nimport { TextInputFloatingFilter } from '../../floating/provided/textInputFloatingFilter';\nvar NumberFloatingFilter = /** @class */ (function (_super) {\n __extends(NumberFloatingFilter, _super);\n function NumberFloatingFilter() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n NumberFloatingFilter.prototype.getDefaultFilterOptions = function () {\n return NumberFilter.DEFAULT_FILTER_OPTIONS;\n };\n return NumberFloatingFilter;\n}(TextInputFloatingFilter));\nexport { NumberFloatingFilter };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { TextFilter } from './textFilter';\nimport { TextInputFloatingFilter } from '../../floating/provided/textInputFloatingFilter';\nvar TextFloatingFilter = /** @class */ (function (_super) {\n __extends(TextFloatingFilter, _super);\n function TextFloatingFilter() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n TextFloatingFilter.prototype.getDefaultFilterOptions = function () {\n return TextFilter.DEFAULT_FILTER_OPTIONS;\n };\n return TextFloatingFilter;\n}(TextInputFloatingFilter));\nexport { TextFloatingFilter };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nimport { EventService } from \"../eventService\";\nimport { areEventsNear } from \"../utils/mouse\";\nvar TouchListener = /** @class */ (function () {\n function TouchListener(eElement, preventMouseClick) {\n var _this = this;\n if (preventMouseClick === void 0) { preventMouseClick = false; }\n this.destroyFuncs = [];\n this.touching = false;\n this.eventService = new EventService();\n this.eElement = eElement;\n this.preventMouseClick = preventMouseClick;\n var startListener = this.onTouchStart.bind(this);\n var moveListener = this.onTouchMove.bind(this);\n var endListener = this.onTouchEnd.bind(this);\n this.eElement.addEventListener(\"touchstart\", startListener, { passive: true });\n this.eElement.addEventListener(\"touchmove\", moveListener, { passive: true });\n // we set passive=false, as we want to prevent default on this event\n this.eElement.addEventListener(\"touchend\", endListener, { passive: false });\n this.destroyFuncs.push(function () {\n _this.eElement.removeEventListener(\"touchstart\", startListener, { passive: true });\n _this.eElement.removeEventListener(\"touchmove\", moveListener, { passive: true });\n _this.eElement.removeEventListener(\"touchend\", endListener, { passive: false });\n });\n }\n TouchListener.prototype.getActiveTouch = function (touchList) {\n for (var i = 0; i < touchList.length; i++) {\n var matches = touchList[i].identifier === this.touchStart.identifier;\n if (matches) {\n return touchList[i];\n }\n }\n return null;\n };\n TouchListener.prototype.addEventListener = function (eventType, listener) {\n this.eventService.addEventListener(eventType, listener);\n };\n TouchListener.prototype.removeEventListener = function (eventType, listener) {\n this.eventService.removeEventListener(eventType, listener);\n };\n TouchListener.prototype.onTouchStart = function (touchEvent) {\n var _this = this;\n // only looking at one touch point at any time\n if (this.touching) {\n return;\n }\n this.touchStart = touchEvent.touches[0];\n this.touching = true;\n this.moved = false;\n var touchStartCopy = this.touchStart;\n window.setTimeout(function () {\n var touchesMatch = _this.touchStart === touchStartCopy;\n if (_this.touching && touchesMatch && !_this.moved) {\n _this.moved = true;\n var event_1 = {\n type: TouchListener.EVENT_LONG_TAP,\n touchStart: _this.touchStart,\n touchEvent: touchEvent\n };\n _this.eventService.dispatchEvent(event_1);\n }\n }, 500);\n };\n TouchListener.prototype.onTouchMove = function (touchEvent) {\n if (!this.touching) {\n return;\n }\n var touch = this.getActiveTouch(touchEvent.touches);\n if (!touch) {\n return;\n }\n var eventIsFarAway = !areEventsNear(touch, this.touchStart, 4);\n if (eventIsFarAway) {\n this.moved = true;\n }\n };\n TouchListener.prototype.onTouchEnd = function (touchEvent) {\n if (!this.touching) {\n return;\n }\n if (!this.moved) {\n var event_2 = {\n type: TouchListener.EVENT_TAP,\n touchStart: this.touchStart\n };\n this.eventService.dispatchEvent(event_2);\n this.checkForDoubleTap();\n }\n // stops the tap from also been processed as a mouse click\n if (this.preventMouseClick && touchEvent.cancelable) {\n touchEvent.preventDefault();\n }\n this.touching = false;\n };\n TouchListener.prototype.checkForDoubleTap = function () {\n var now = new Date().getTime();\n if (this.lastTapTime && this.lastTapTime > 0) {\n // if previous tap, see if duration is short enough to be considered double tap\n var interval = now - this.lastTapTime;\n if (interval > TouchListener.DOUBLE_TAP_MILLIS) {\n // dispatch double tap event\n var event_3 = {\n type: TouchListener.EVENT_DOUBLE_TAP,\n touchStart: this.touchStart\n };\n this.eventService.dispatchEvent(event_3);\n // this stops a tripple tap ending up as two double taps\n this.lastTapTime = null;\n }\n else {\n this.lastTapTime = now;\n }\n }\n else {\n this.lastTapTime = now;\n }\n };\n TouchListener.prototype.destroy = function () {\n this.destroyFuncs.forEach(function (func) { return func(); });\n };\n TouchListener.EVENT_TAP = \"tap\";\n TouchListener.EVENT_DOUBLE_TAP = \"doubleTap\";\n TouchListener.EVENT_LONG_TAP = \"longTap\";\n TouchListener.DOUBLE_TAP_MILLIS = 500;\n return TouchListener;\n}());\nexport { TouchListener };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Events } from \"../../../eventKeys\";\nimport { setDisplayed, clearElement } from \"../../../utils/dom\";\nimport { Autowired } from \"../../../context/context\";\nimport { RefSelector } from \"../../../widgets/componentAnnotations\";\nimport { Component } from \"../../../widgets/component\";\nimport { createIconNoSpan } from \"../../../utils/icon\";\nvar SortIndicatorComp = /** @class */ (function (_super) {\n __extends(SortIndicatorComp, _super);\n function SortIndicatorComp(skipTemplate) {\n var _this = _super.call(this) || this;\n if (!skipTemplate) {\n _this.setTemplate(SortIndicatorComp.TEMPLATE);\n }\n return _this;\n }\n SortIndicatorComp.prototype.attachCustomElements = function (eSortOrder, eSortAsc, eSortDesc, eSortMixed, eSortNone) {\n this.eSortOrder = eSortOrder;\n this.eSortAsc = eSortAsc;\n this.eSortDesc = eSortDesc;\n this.eSortMixed = eSortMixed;\n this.eSortNone = eSortNone;\n };\n SortIndicatorComp.prototype.setupSort = function (column, suppressOrder) {\n var _this = this;\n if (suppressOrder === void 0) { suppressOrder = false; }\n this.column = column;\n this.suppressOrder = suppressOrder;\n this.setupMultiSortIndicator();\n var canSort = !!this.column.getColDef().sortable;\n if (!canSort) {\n return;\n }\n this.addInIcon('sortAscending', this.eSortAsc, column);\n this.addInIcon('sortDescending', this.eSortDesc, column);\n this.addInIcon('sortUnSort', this.eSortNone, column);\n // Watch global events, as row group columns can effect their display column.\n this.addManagedListener(this.eventService, Events.EVENT_SORT_CHANGED, function () { return _this.onSortChanged(); });\n // when grouping changes so can sort indexes and icons\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, function () { return _this.onSortChanged(); });\n this.onSortChanged();\n };\n SortIndicatorComp.prototype.addInIcon = function (iconName, eParent, column) {\n if (eParent == null) {\n return;\n }\n var eIcon = createIconNoSpan(iconName, this.gridOptionsWrapper, column);\n if (eIcon) {\n eParent.appendChild(eIcon);\n }\n };\n SortIndicatorComp.prototype.onSortChanged = function () {\n this.updateIcons();\n if (!this.suppressOrder) {\n this.updateSortOrder();\n }\n };\n SortIndicatorComp.prototype.updateIcons = function () {\n var sortDirection = this.sortController.getDisplaySortForColumn(this.column);\n if (this.eSortAsc) {\n var isAscending = sortDirection === 'asc';\n this.eSortAsc.classList.toggle('ag-hidden', !isAscending);\n }\n if (this.eSortDesc) {\n var isDescending = sortDirection === 'desc';\n this.eSortDesc.classList.toggle('ag-hidden', !isDescending);\n }\n if (this.eSortNone) {\n var alwaysHideNoSort = !this.column.getColDef().unSortIcon && !this.gridOptionsWrapper.isUnSortIcon();\n var isNone = sortDirection === null || sortDirection === undefined;\n this.eSortNone.classList.toggle('ag-hidden', (alwaysHideNoSort || !isNone));\n }\n };\n SortIndicatorComp.prototype.setupMultiSortIndicator = function () {\n var _this = this;\n this.addInIcon('sortUnSort', this.eSortMixed, this.column);\n var isColumnShowingRowGroup = this.column.getColDef().showRowGroup;\n var areGroupsCoupled = this.gridOptionsWrapper.isColumnsSortingCoupledToGroup();\n if (areGroupsCoupled && isColumnShowingRowGroup) {\n // Watch global events, as row group columns can effect their display column.\n this.addManagedListener(this.eventService, Events.EVENT_SORT_CHANGED, function () { return _this.updateMultiSortIndicator(); });\n // when grouping changes so can sort indexes and icons\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, function () { return _this.updateMultiSortIndicator(); });\n this.updateMultiSortIndicator();\n }\n };\n SortIndicatorComp.prototype.updateMultiSortIndicator = function () {\n if (this.eSortMixed) {\n var isMixedSort = this.sortController.getDisplaySortForColumn(this.column) === 'mixed';\n this.eSortMixed.classList.toggle('ag-hidden', !isMixedSort);\n }\n };\n // we listen here for global sort events, NOT column sort events, as we want to do this\n // when sorting has been set on all column (if we listened just for our col (where we\n // set the asc / desc icons) then it's possible other cols are yet to get their sorting state.\n SortIndicatorComp.prototype.updateSortOrder = function () {\n var _this = this;\n var _a;\n if (!this.eSortOrder) {\n return;\n }\n var allColumnsWithSorting = this.sortController.getColumnsWithSortingOrdered();\n var indexThisCol = (_a = this.sortController.getDisplaySortIndexForColumn(this.column), (_a !== null && _a !== void 0 ? _a : -1));\n var moreThanOneColSorting = allColumnsWithSorting.some(function (col) { var _a; return _a = _this.sortController.getDisplaySortIndexForColumn(col), (_a !== null && _a !== void 0 ? _a : -1 >= 1); });\n var showIndex = indexThisCol >= 0 && moreThanOneColSorting;\n setDisplayed(this.eSortOrder, showIndex);\n if (indexThisCol >= 0) {\n this.eSortOrder.innerHTML = (indexThisCol + 1).toString();\n }\n else {\n clearElement(this.eSortOrder);\n }\n };\n SortIndicatorComp.TEMPLATE = \"\\n \\n \\n \\n \\n \\n \";\n __decorate([\n RefSelector('eSortOrder')\n ], SortIndicatorComp.prototype, \"eSortOrder\", void 0);\n __decorate([\n RefSelector('eSortAsc')\n ], SortIndicatorComp.prototype, \"eSortAsc\", void 0);\n __decorate([\n RefSelector('eSortDesc')\n ], SortIndicatorComp.prototype, \"eSortDesc\", void 0);\n __decorate([\n RefSelector('eSortMixed')\n ], SortIndicatorComp.prototype, \"eSortMixed\", void 0);\n __decorate([\n RefSelector('eSortNone')\n ], SortIndicatorComp.prototype, \"eSortNone\", void 0);\n __decorate([\n Autowired('columnModel')\n ], SortIndicatorComp.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('sortController')\n ], SortIndicatorComp.prototype, \"sortController\", void 0);\n return SortIndicatorComp;\n}(Component));\nexport { SortIndicatorComp };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired } from \"../../../context/context\";\nimport { Column } from \"../../../entities/column\";\nimport { firstExistingValue } from \"../../../utils/array\";\nimport { isIOSUserAgent } from \"../../../utils/browser\";\nimport { removeFromParent } from \"../../../utils/dom\";\nimport { exists } from \"../../../utils/generic\";\nimport { createIconNoSpan } from \"../../../utils/icon\";\nimport { escapeString } from \"../../../utils/string\";\nimport { Component } from \"../../../widgets/component\";\nimport { RefSelector } from \"../../../widgets/componentAnnotations\";\nimport { TouchListener } from \"../../../widgets/touchListener\";\nimport { SortIndicatorComp } from \"./sortIndicatorComp\";\nimport { Events } from \"../../../eventKeys\";\nvar HeaderComp = /** @class */ (function (_super) {\n __extends(HeaderComp, _super);\n function HeaderComp() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.lastMovingChanged = 0;\n return _this;\n }\n // this is a user component, and IComponent has \"public destroy()\" as part of the interface.\n // so we need to override destroy() just to make the method public.\n HeaderComp.prototype.destroy = function () {\n _super.prototype.destroy.call(this);\n };\n HeaderComp.prototype.refresh = function (params) {\n this.params = params;\n // if template changed, then recreate the whole comp, the code required to manage\n // a changing template is to difficult for what it's worth.\n if (this.workOutTemplate() != this.currentTemplate) {\n return false;\n }\n if (this.workOutShowMenu() != this.currentShowMenu) {\n return false;\n }\n if (this.workOutSort() != this.currentSort) {\n return false;\n }\n this.setDisplayName(params);\n return true;\n };\n HeaderComp.prototype.workOutTemplate = function () {\n var template = firstExistingValue(this.params.template, HeaderComp.TEMPLATE);\n // take account of any newlines & whitespace before/after the actual template\n template = template && template.trim ? template.trim() : template;\n return template;\n };\n HeaderComp.prototype.init = function (params) {\n this.params = params;\n this.currentTemplate = this.workOutTemplate();\n this.setTemplate(this.currentTemplate);\n this.setupTap();\n this.setupIcons(params.column);\n this.setMenu();\n this.setupSort();\n this.setupFilterIcon();\n this.setDisplayName(params);\n };\n HeaderComp.prototype.setDisplayName = function (params) {\n if (this.currentDisplayName != params.displayName) {\n this.currentDisplayName = params.displayName;\n var displayNameSanitised = escapeString(this.currentDisplayName);\n if (this.eText) {\n this.eText.innerHTML = displayNameSanitised;\n }\n }\n };\n HeaderComp.prototype.setupIcons = function (column) {\n this.addInIcon('menu', this.eMenu, column);\n this.addInIcon('filter', this.eFilter, column);\n };\n HeaderComp.prototype.addInIcon = function (iconName, eParent, column) {\n if (eParent == null) {\n return;\n }\n var eIcon = createIconNoSpan(iconName, this.gridOptionsWrapper, column);\n if (eIcon) {\n eParent.appendChild(eIcon);\n }\n };\n HeaderComp.prototype.setupTap = function () {\n var _this = this;\n var options = this.gridOptionsWrapper;\n if (options.isSuppressTouch()) {\n return;\n }\n var touchListener = new TouchListener(this.getGui(), true);\n var suppressMenuHide = options.isSuppressMenuHide();\n var tapMenuButton = suppressMenuHide && exists(this.eMenu);\n var menuTouchListener = tapMenuButton ? new TouchListener(this.eMenu, true) : touchListener;\n if (this.params.enableMenu) {\n var eventType = tapMenuButton ? 'EVENT_TAP' : 'EVENT_LONG_TAP';\n var showMenuFn = function (event) {\n options.getApi().showColumnMenuAfterMouseClick(_this.params.column, event.touchStart);\n };\n this.addManagedListener(menuTouchListener, TouchListener[eventType], showMenuFn);\n }\n if (this.params.enableSorting) {\n var tapListener = function (event) {\n var target = event.touchStart.target;\n // When suppressMenuHide is true, a tap on the menu icon will bubble up\n // to the header container, in that case we should not sort\n if (suppressMenuHide && _this.eMenu.contains(target)) {\n return;\n }\n _this.sortController.progressSort(_this.params.column, false, \"uiColumnSorted\");\n };\n this.addManagedListener(touchListener, TouchListener.EVENT_TAP, tapListener);\n }\n // if tapMenuButton is true `touchListener` and `menuTouchListener` are different\n // so we need to make sure to destroy both listeners here\n this.addDestroyFunc(function () { return touchListener.destroy(); });\n if (tapMenuButton) {\n this.addDestroyFunc(function () { return menuTouchListener.destroy(); });\n }\n };\n HeaderComp.prototype.workOutShowMenu = function () {\n // we don't show the menu if on an iPad/iPhone, as the user cannot have a pointer device/\n // However if suppressMenuHide is set to true the menu will be displayed alwasys, so it's ok\n // to show it on iPad in this case (as hover isn't needed). If suppressMenuHide\n // is false (default) user will need to use longpress to display the menu.\n var menuHides = !this.gridOptionsWrapper.isSuppressMenuHide();\n var onIpadAndMenuHides = isIOSUserAgent() && menuHides;\n var showMenu = this.params.enableMenu && !onIpadAndMenuHides;\n return showMenu;\n };\n HeaderComp.prototype.setMenu = function () {\n var _this = this;\n // if no menu provided in template, do nothing\n if (!this.eMenu) {\n return;\n }\n this.currentShowMenu = this.workOutShowMenu();\n if (!this.currentShowMenu) {\n removeFromParent(this.eMenu);\n return;\n }\n var suppressMenuHide = this.gridOptionsWrapper.isSuppressMenuHide();\n this.addManagedListener(this.eMenu, 'click', function () { return _this.showMenu(_this.eMenu); });\n this.eMenu.classList.toggle('ag-header-menu-always-show', suppressMenuHide);\n };\n HeaderComp.prototype.showMenu = function (eventSource) {\n if (!eventSource) {\n eventSource = this.eMenu;\n }\n this.menuFactory.showMenuAfterButtonClick(this.params.column, eventSource, 'columnMenu');\n };\n HeaderComp.prototype.workOutSort = function () {\n return this.params.enableSorting;\n };\n HeaderComp.prototype.setupSort = function () {\n var _this = this;\n this.currentSort = this.params.enableSorting;\n // eSortIndicator will not be present when customers provided custom header\n // templates, in that case, we need to look for provided sort elements and\n // manually create eSortIndicator.\n if (!this.eSortIndicator) {\n this.eSortIndicator = this.context.createBean(new SortIndicatorComp(true));\n this.eSortIndicator.attachCustomElements(this.eSortOrder, this.eSortAsc, this.eSortDesc, this.eSortMixed, this.eSortNone);\n }\n this.eSortIndicator.setupSort(this.params.column);\n // we set up the indicator prior to the check for whether this column is sortable, as it allows the indicator to\n // set up the multi sort indicator which can appear irrelevant of whether this column can itself be sorted.\n // this can occur in the case of a non-sortable group display column.\n if (!this.currentSort) {\n return;\n }\n var sortUsingCtrl = this.gridOptionsWrapper.isMultiSortKeyCtrl();\n // keep track of last time the moving changed flag was set\n this.addManagedListener(this.params.column, Column.EVENT_MOVING_CHANGED, function () {\n _this.lastMovingChanged = new Date().getTime();\n });\n // add the event on the header, so when clicked, we do sorting\n if (this.eLabel) {\n this.addManagedListener(this.eLabel, 'click', function (event) {\n // sometimes when moving a column via dragging, this was also firing a clicked event.\n // here is issue raised by user: https://ag-grid.zendesk.com/agent/tickets/1076\n // this check stops sort if a) column is moving or b) column moved less than 200ms ago (so caters for race condition)\n var moving = _this.params.column.isMoving();\n var nowTime = new Date().getTime();\n // typically there is <2ms if moving flag was set recently, as it would be done in same VM turn\n var movedRecently = (nowTime - _this.lastMovingChanged) < 50;\n var columnMoving = moving || movedRecently;\n if (!columnMoving) {\n var multiSort = sortUsingCtrl ? (event.ctrlKey || event.metaKey) : event.shiftKey;\n _this.params.progressSort(multiSort);\n }\n });\n }\n var onSortingChanged = function () {\n var _a;\n _this.addOrRemoveCssClass('ag-header-cell-sorted-asc', _this.params.column.isSortAscending());\n _this.addOrRemoveCssClass('ag-header-cell-sorted-desc', _this.params.column.isSortDescending());\n _this.addOrRemoveCssClass('ag-header-cell-sorted-none', _this.params.column.isSortNone());\n if (_this.params.column.getColDef().showRowGroup) {\n var sourceColumns = _this.columnModel.getSourceColumnsForGroupColumn(_this.params.column);\n // this == is intentional, as it allows null and undefined to match, which are both unsorted states\n var sortDirectionsMatch = (_a = sourceColumns) === null || _a === void 0 ? void 0 : _a.every(function (sourceCol) { return _this.params.column.getSort() == sourceCol.getSort(); });\n var isMultiSorting = !sortDirectionsMatch;\n _this.addOrRemoveCssClass('ag-header-cell-sorted-mixed', isMultiSorting);\n }\n };\n this.addManagedListener(this.eventService, Events.EVENT_SORT_CHANGED, onSortingChanged);\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, onSortingChanged);\n };\n HeaderComp.prototype.setupFilterIcon = function () {\n if (!this.eFilter) {\n return;\n }\n this.addManagedListener(this.params.column, Column.EVENT_FILTER_CHANGED, this.onFilterChanged.bind(this));\n this.onFilterChanged();\n };\n HeaderComp.prototype.onFilterChanged = function () {\n var filterPresent = this.params.column.isFilterActive();\n this.eFilter.classList.toggle('ag-hidden', !filterPresent);\n };\n HeaderComp.TEMPLATE = \"
\\n \\n
\\n \\n \\n \\n
\\n
\";\n __decorate([\n Autowired('sortController')\n ], HeaderComp.prototype, \"sortController\", void 0);\n __decorate([\n Autowired('menuFactory')\n ], HeaderComp.prototype, \"menuFactory\", void 0);\n __decorate([\n Autowired('columnModel')\n ], HeaderComp.prototype, \"columnModel\", void 0);\n __decorate([\n RefSelector('eFilter')\n ], HeaderComp.prototype, \"eFilter\", void 0);\n __decorate([\n RefSelector('eSortIndicator')\n ], HeaderComp.prototype, \"eSortIndicator\", void 0);\n __decorate([\n RefSelector('eMenu')\n ], HeaderComp.prototype, \"eMenu\", void 0);\n __decorate([\n RefSelector('eLabel')\n ], HeaderComp.prototype, \"eLabel\", void 0);\n __decorate([\n RefSelector('eText')\n ], HeaderComp.prototype, \"eText\", void 0);\n __decorate([\n RefSelector('eSortOrder')\n ], HeaderComp.prototype, \"eSortOrder\", void 0);\n __decorate([\n RefSelector('eSortAsc')\n ], HeaderComp.prototype, \"eSortAsc\", void 0);\n __decorate([\n RefSelector('eSortDesc')\n ], HeaderComp.prototype, \"eSortDesc\", void 0);\n __decorate([\n RefSelector('eSortMixed')\n ], HeaderComp.prototype, \"eSortMixed\", void 0);\n __decorate([\n RefSelector('eSortNone')\n ], HeaderComp.prototype, \"eSortNone\", void 0);\n return HeaderComp;\n}(Component));\nexport { HeaderComp };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired } from \"../../../context/context\";\nimport { ProvidedColumnGroup } from \"../../../entities/providedColumnGroup\";\nimport { setDisplayed } from \"../../../utils/dom\";\nimport { isStopPropagationForAgGrid, stopPropagationForAgGrid } from \"../../../utils/event\";\nimport { doOnce } from \"../../../utils/function\";\nimport { exists } from \"../../../utils/generic\";\nimport { createIconNoSpan } from \"../../../utils/icon\";\nimport { escapeString } from \"../../../utils/string\";\nimport { Component } from \"../../../widgets/component\";\nimport { RefSelector } from \"../../../widgets/componentAnnotations\";\nimport { TouchListener } from \"../../../widgets/touchListener\";\nvar HeaderGroupComp = /** @class */ (function (_super) {\n __extends(HeaderGroupComp, _super);\n function HeaderGroupComp() {\n return _super.call(this, HeaderGroupComp.TEMPLATE) || this;\n }\n // this is a user component, and IComponent has \"public destroy()\" as part of the interface.\n // so we need to override destroy() just to make the method public.\n HeaderGroupComp.prototype.destroy = function () {\n _super.prototype.destroy.call(this);\n };\n HeaderGroupComp.prototype.init = function (params) {\n this.params = params;\n this.checkWarnings();\n this.setupLabel();\n this.addGroupExpandIcon();\n this.setupExpandIcons();\n };\n HeaderGroupComp.prototype.checkWarnings = function () {\n var paramsAny = this.params;\n if (paramsAny.template) {\n var message_1 = \"AG Grid: A template was provided for Header Group Comp - templates are only supported for Header Comps (not groups)\";\n doOnce(function () { return console.warn(message_1); }, 'HeaderGroupComp.templateNotSupported');\n }\n };\n HeaderGroupComp.prototype.setupExpandIcons = function () {\n var _this = this;\n this.addInIcon(\"columnGroupOpened\", \"agOpened\");\n this.addInIcon(\"columnGroupClosed\", \"agClosed\");\n var expandAction = function (event) {\n if (isStopPropagationForAgGrid(event)) {\n return;\n }\n var newExpandedValue = !_this.params.columnGroup.isExpanded();\n _this.columnModel.setColumnGroupOpened(_this.params.columnGroup.getProvidedColumnGroup(), newExpandedValue, \"uiColumnExpanded\");\n };\n this.addTouchAndClickListeners(this.eCloseIcon, expandAction);\n this.addTouchAndClickListeners(this.eOpenIcon, expandAction);\n var stopPropagationAction = function (event) {\n stopPropagationForAgGrid(event);\n };\n // adding stopPropagation to the double click for the icons prevents double click action happening\n // when the icons are clicked. if the icons are double clicked, then the groups should open and\n // then close again straight away. if we also listened to double click, then the group would open,\n // close, then open, which is not what we want. double click should only action if the user double\n // clicks outside of the icons.\n this.addManagedListener(this.eCloseIcon, \"dblclick\", stopPropagationAction);\n this.addManagedListener(this.eOpenIcon, \"dblclick\", stopPropagationAction);\n this.addManagedListener(this.getGui(), \"dblclick\", expandAction);\n this.updateIconVisibility();\n var providedColumnGroup = this.params.columnGroup.getProvidedColumnGroup();\n this.addManagedListener(providedColumnGroup, ProvidedColumnGroup.EVENT_EXPANDED_CHANGED, this.updateIconVisibility.bind(this));\n this.addManagedListener(providedColumnGroup, ProvidedColumnGroup.EVENT_EXPANDABLE_CHANGED, this.updateIconVisibility.bind(this));\n };\n HeaderGroupComp.prototype.addTouchAndClickListeners = function (eElement, action) {\n var touchListener = new TouchListener(eElement, true);\n this.addManagedListener(touchListener, TouchListener.EVENT_TAP, action);\n this.addDestroyFunc(function () { return touchListener.destroy(); });\n this.addManagedListener(eElement, \"click\", action);\n };\n HeaderGroupComp.prototype.updateIconVisibility = function () {\n var columnGroup = this.params.columnGroup;\n if (columnGroup.isExpandable()) {\n var expanded = this.params.columnGroup.isExpanded();\n setDisplayed(this.eOpenIcon, expanded);\n setDisplayed(this.eCloseIcon, !expanded);\n }\n else {\n setDisplayed(this.eOpenIcon, false);\n setDisplayed(this.eCloseIcon, false);\n }\n };\n HeaderGroupComp.prototype.addInIcon = function (iconName, refName) {\n var eIcon = createIconNoSpan(iconName, this.gridOptionsWrapper, null);\n if (eIcon) {\n this.getRefElement(refName).appendChild(eIcon);\n }\n };\n HeaderGroupComp.prototype.addGroupExpandIcon = function () {\n if (!this.params.columnGroup.isExpandable()) {\n setDisplayed(this.eOpenIcon, false);\n setDisplayed(this.eCloseIcon, false);\n return;\n }\n };\n HeaderGroupComp.prototype.setupLabel = function () {\n // no renderer, default text render\n var displayName = this.params.displayName;\n if (exists(displayName)) {\n var displayNameSanitised = escapeString(displayName);\n this.getRefElement('agLabel').innerHTML = displayNameSanitised;\n }\n };\n HeaderGroupComp.TEMPLATE = \"
\\n \\n \\n \\n
\";\n __decorate([\n Autowired(\"columnModel\")\n ], HeaderGroupComp.prototype, \"columnModel\", void 0);\n __decorate([\n RefSelector(\"agOpened\")\n ], HeaderGroupComp.prototype, \"eOpenIcon\", void 0);\n __decorate([\n RefSelector(\"agClosed\")\n ], HeaderGroupComp.prototype, \"eCloseIcon\", void 0);\n return HeaderGroupComp;\n}(Component));\nexport { HeaderGroupComp };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { Component } from \"./component\";\nvar PopupComponent = /** @class */ (function (_super) {\n __extends(PopupComponent, _super);\n function PopupComponent() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n PopupComponent.prototype.isPopup = function () {\n return true;\n };\n PopupComponent.prototype.setParentComponent = function (container) {\n container.addCssClass('ag-has-popup');\n _super.prototype.setParentComponent.call(this, container);\n };\n PopupComponent.prototype.destroy = function () {\n var parentComp = this.parentComponent;\n var hasParent = parentComp && parentComp.isAlive();\n if (hasParent) {\n parentComp.getGui().classList.remove('ag-has-popup');\n }\n _super.prototype.destroy.call(this);\n };\n return PopupComponent;\n}(Component));\nexport { PopupComponent };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PopupComponent } from \"../../widgets/popupComponent\";\nimport { RefSelector } from \"../../widgets/componentAnnotations\";\nimport { exists } from \"../../utils/generic\";\nimport { KeyCode } from '../../constants/keyCode';\nvar LargeTextCellEditor = /** @class */ (function (_super) {\n __extends(LargeTextCellEditor, _super);\n function LargeTextCellEditor() {\n return _super.call(this, LargeTextCellEditor.TEMPLATE) || this;\n }\n LargeTextCellEditor.prototype.init = function (params) {\n this.params = params;\n this.focusAfterAttached = params.cellStartedEdit;\n this.eTextArea\n .setMaxLength(params.maxLength || 200)\n .setCols(params.cols || 60)\n .setRows(params.rows || 10);\n if (exists(params.value)) {\n this.eTextArea.setValue(params.value.toString(), true);\n }\n this.addGuiEventListener('keydown', this.onKeyDown.bind(this));\n };\n LargeTextCellEditor.prototype.onKeyDown = function (event) {\n var key = event.key;\n if (key === KeyCode.LEFT ||\n key === KeyCode.UP ||\n key === KeyCode.RIGHT ||\n key === KeyCode.DOWN ||\n (event.shiftKey && key === KeyCode.ENTER)) { // shift+enter allows for newlines\n event.stopPropagation();\n }\n };\n LargeTextCellEditor.prototype.afterGuiAttached = function () {\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n this.eTextArea.setInputAriaLabel(translate('ariaInputEditor', 'Input Editor'));\n if (this.focusAfterAttached) {\n this.eTextArea.getFocusableElement().focus();\n }\n };\n LargeTextCellEditor.prototype.getValue = function () {\n return this.params.parseValue(this.eTextArea.getValue());\n };\n LargeTextCellEditor.TEMPLATE = \"
\\n \\n
\";\n __decorate([\n RefSelector(\"eTextArea\")\n ], LargeTextCellEditor.prototype, \"eTextArea\", void 0);\n return LargeTextCellEditor;\n}(PopupComponent));\nexport { LargeTextCellEditor };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired } from \"../../context/context\";\nimport { PopupComponent } from \"../../widgets/popupComponent\";\nimport { RefSelector } from \"../../widgets/componentAnnotations\";\nimport { missing } from \"../../utils/generic\";\nimport { KeyCode } from '../../constants/keyCode';\nvar SelectCellEditor = /** @class */ (function (_super) {\n __extends(SelectCellEditor, _super);\n function SelectCellEditor() {\n var _this = _super.call(this, '
') || this;\n _this.startedByEnter = false;\n return _this;\n }\n SelectCellEditor.prototype.init = function (params) {\n var _this = this;\n this.focusAfterAttached = params.cellStartedEdit;\n if (missing(params.values)) {\n console.warn('AG Grid: no values found for select cellEditor');\n return;\n }\n this.startedByEnter = params.eventKey != null ? params.eventKey === KeyCode.ENTER : false;\n var hasValue = false;\n params.values.forEach(function (value) {\n var option = { value: value };\n var valueFormatted = _this.valueFormatterService.formatValue(params.column, null, value);\n var valueFormattedExits = valueFormatted !== null && valueFormatted !== undefined;\n option.text = valueFormattedExits ? valueFormatted : value;\n _this.eSelect.addOption(option);\n hasValue = hasValue || params.value === value;\n });\n if (hasValue) {\n this.eSelect.setValue(params.value, true);\n }\n else if (params.values.length) {\n this.eSelect.setValue(params.values[0], true);\n }\n // we don't want to add this if full row editing, otherwise selecting will stop the\n // full row editing.\n if (!this.gridOptionsWrapper.isFullRowEdit()) {\n this.eSelect.onValueChange(function () { return params.stopEditing(); });\n }\n };\n SelectCellEditor.prototype.afterGuiAttached = function () {\n if (this.focusAfterAttached) {\n this.eSelect.getFocusableElement().focus();\n }\n if (this.startedByEnter) {\n this.eSelect.showPicker();\n }\n };\n SelectCellEditor.prototype.focusIn = function () {\n this.eSelect.getFocusableElement().focus();\n };\n SelectCellEditor.prototype.getValue = function () {\n return this.eSelect.getValue();\n };\n SelectCellEditor.prototype.isPopup = function () {\n return false;\n };\n __decorate([\n Autowired('valueFormatterService')\n ], SelectCellEditor.prototype, \"valueFormatterService\", void 0);\n __decorate([\n RefSelector('eSelect')\n ], SelectCellEditor.prototype, \"eSelect\", void 0);\n return SelectCellEditor;\n}(PopupComponent));\nexport { SelectCellEditor };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { doOnce } from \"../../utils/function\";\nimport { SelectCellEditor } from \"./selectCellEditor\";\nvar PopupSelectCellEditor = /** @class */ (function (_super) {\n __extends(PopupSelectCellEditor, _super);\n function PopupSelectCellEditor() {\n var _this = _super.call(this) || this;\n doOnce(function () { return console.warn('AG Grid: The PopupSelectCellEditor (agPopupSelectCellEditor) is deprecated. Instead use {cellEditor: \"agSelectCellEditor\", cellEditorPopup: true} '); }, 'PopupSelectCellEditor.deprecated');\n return _this;\n }\n PopupSelectCellEditor.prototype.isPopup = function () {\n return true;\n };\n return PopupSelectCellEditor;\n}(SelectCellEditor));\nexport { PopupSelectCellEditor };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PopupComponent } from \"../../widgets/popupComponent\";\nimport { RefSelector } from \"../../widgets/componentAnnotations\";\nimport { exists } from \"../../utils/generic\";\nimport { isBrowserSafari } from \"../../utils/browser\";\nimport { KeyCode } from '../../constants/keyCode';\nvar TextCellEditor = /** @class */ (function (_super) {\n __extends(TextCellEditor, _super);\n function TextCellEditor() {\n return _super.call(this, TextCellEditor.TEMPLATE) || this;\n }\n TextCellEditor.prototype.init = function (params) {\n this.params = params;\n var eInput = this.eInput;\n var startValue;\n // cellStartedEdit is only false if we are doing fullRow editing\n if (params.cellStartedEdit) {\n this.focusAfterAttached = true;\n if (params.eventKey === KeyCode.BACKSPACE || params.eventKey === KeyCode.DELETE) {\n startValue = '';\n }\n else if (params.charPress) {\n startValue = params.charPress;\n }\n else {\n startValue = this.getStartValue(params);\n if (params.eventKey !== KeyCode.F2) {\n this.highlightAllOnFocus = true;\n }\n }\n }\n else {\n this.focusAfterAttached = false;\n startValue = this.getStartValue(params);\n }\n if (startValue != null) {\n eInput.setValue(startValue, true);\n }\n this.addManagedListener(eInput.getGui(), 'keydown', function (event) {\n var key = event.key;\n if (key === KeyCode.PAGE_UP || key === KeyCode.PAGE_DOWN) {\n event.preventDefault();\n }\n });\n };\n TextCellEditor.prototype.afterGuiAttached = function () {\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n var eInput = this.eInput;\n eInput.setInputAriaLabel(translate('ariaInputEditor', 'Input Editor'));\n if (!this.focusAfterAttached) {\n return;\n }\n // Added for AG-3238. We can't remove this explicit focus() because Chrome requires an input\n // to be focused before setSelectionRange will work. But it triggers a bug in Safari where\n // explicitly focusing then blurring an empty field will cause the parent container to scroll.\n if (!isBrowserSafari()) {\n eInput.getFocusableElement().focus();\n }\n var inputEl = eInput.getInputElement();\n if (this.highlightAllOnFocus) {\n inputEl.select();\n }\n else {\n // when we started editing, we want the caret at the end, not the start.\n // this comes into play in two scenarios:\n // a) when user hits F2\n // b) when user hits a printable character\n var value = eInput.getValue();\n var len = (exists(value) && value.length) || 0;\n if (len) {\n inputEl.setSelectionRange(len, len);\n }\n }\n };\n // gets called when tabbing trough cells and in full row edit mode\n TextCellEditor.prototype.focusIn = function () {\n var eInput = this.eInput;\n var focusEl = eInput.getFocusableElement();\n var inputEl = eInput.getInputElement();\n focusEl.focus();\n inputEl.select();\n };\n TextCellEditor.prototype.getValue = function () {\n var eInput = this.eInput;\n return this.params.parseValue(eInput.getValue());\n };\n TextCellEditor.prototype.getStartValue = function (params) {\n var formatValue = params.useFormatter || params.column.getColDef().refData;\n return formatValue ? params.formatValue(params.value) : params.value;\n };\n TextCellEditor.prototype.isPopup = function () {\n return false;\n };\n TextCellEditor.TEMPLATE = '
';\n __decorate([\n RefSelector('eInput')\n ], TextCellEditor.prototype, \"eInput\", void 0);\n return TextCellEditor;\n}(PopupComponent));\nexport { TextCellEditor };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { doOnce } from \"../../utils/function\";\nimport { TextCellEditor } from \"./textCellEditor\";\nvar PopupTextCellEditor = /** @class */ (function (_super) {\n __extends(PopupTextCellEditor, _super);\n function PopupTextCellEditor() {\n var _this = _super.call(this) || this;\n doOnce(function () { return console.warn('AG Grid: The PopupTextCellEditor (agPopupTextCellEditor) is deprecated. Instead use {cellEditor: \"agTextCellEditor\", cellEditorPopup: true} '); }, 'PopupTextCellEditor.deprecated');\n return _this;\n }\n PopupTextCellEditor.prototype.isPopup = function () {\n return true;\n };\n return PopupTextCellEditor;\n}(TextCellEditor));\nexport { PopupTextCellEditor };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired } from \"../../context/context\";\nimport { Component } from \"../../widgets/component\";\nimport { exists } from \"../../utils/generic\";\nimport { clearElement } from \"../../utils/dom\";\nvar ARROW_UP = '\\u2191';\nvar ARROW_DOWN = '\\u2193';\nvar AnimateShowChangeCellRenderer = /** @class */ (function (_super) {\n __extends(AnimateShowChangeCellRenderer, _super);\n function AnimateShowChangeCellRenderer() {\n var _this = _super.call(this, AnimateShowChangeCellRenderer.TEMPLATE) || this;\n _this.refreshCount = 0;\n return _this;\n }\n AnimateShowChangeCellRenderer.prototype.init = function (params) {\n // this.params = params;\n this.eValue = this.queryForHtmlElement('.ag-value-change-value');\n this.eDelta = this.queryForHtmlElement('.ag-value-change-delta');\n this.refresh(params);\n };\n AnimateShowChangeCellRenderer.prototype.showDelta = function (params, delta) {\n var absDelta = Math.abs(delta);\n var valueFormatted = params.formatValue(absDelta);\n var valueToUse = exists(valueFormatted) ? valueFormatted : absDelta;\n var deltaUp = (delta >= 0);\n if (deltaUp) {\n this.eDelta.innerHTML = ARROW_UP + valueToUse;\n }\n else {\n // because negative, use ABS to remove sign\n this.eDelta.innerHTML = ARROW_DOWN + valueToUse;\n }\n this.eDelta.classList.toggle('ag-value-change-delta-up', deltaUp);\n this.eDelta.classList.toggle('ag-value-change-delta-down', !deltaUp);\n };\n AnimateShowChangeCellRenderer.prototype.setTimerToRemoveDelta = function () {\n var _this = this;\n // the refreshCount makes sure that if the value updates again while\n // the below timer is waiting, then the below timer will realise it\n // is not the most recent and will not try to remove the delta value.\n this.refreshCount++;\n var refreshCountCopy = this.refreshCount;\n window.setTimeout(function () {\n if (refreshCountCopy === _this.refreshCount) {\n _this.hideDeltaValue();\n }\n }, 2000);\n };\n AnimateShowChangeCellRenderer.prototype.hideDeltaValue = function () {\n this.eValue.classList.remove('ag-value-change-value-highlight');\n clearElement(this.eDelta);\n };\n AnimateShowChangeCellRenderer.prototype.refresh = function (params) {\n var value = params.value;\n if (value === this.lastValue) {\n return false;\n }\n if (exists(params.valueFormatted)) {\n this.eValue.innerHTML = params.valueFormatted;\n }\n else if (exists(params.value)) {\n this.eValue.innerHTML = value;\n }\n else {\n clearElement(this.eValue);\n }\n // we don't show the delta if we are in the middle of a filter. see comment on FilterManager\n // with regards processingFilterChange\n if (this.filterManager.isSuppressFlashingCellsBecauseFiltering()) {\n return false;\n }\n if (typeof value === 'number' && typeof this.lastValue === 'number') {\n var delta = value - this.lastValue;\n this.showDelta(params, delta);\n }\n // highlight the current value, but only if it's not new, otherwise it\n // would get highlighted first time the value is shown\n if (this.lastValue) {\n this.eValue.classList.add('ag-value-change-value-highlight');\n }\n this.setTimerToRemoveDelta();\n this.lastValue = value;\n return true;\n };\n AnimateShowChangeCellRenderer.TEMPLATE = '' +\n '' +\n '' +\n '';\n __decorate([\n Autowired('filterManager')\n ], AnimateShowChangeCellRenderer.prototype, \"filterManager\", void 0);\n return AnimateShowChangeCellRenderer;\n}(Component));\nexport { AnimateShowChangeCellRenderer };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired } from \"../../context/context\";\nimport { Component } from \"../../widgets/component\";\nimport { loadTemplate, clearElement } from \"../../utils/dom\";\nimport { missing, exists } from \"../../utils/generic\";\nvar AnimateSlideCellRenderer = /** @class */ (function (_super) {\n __extends(AnimateSlideCellRenderer, _super);\n function AnimateSlideCellRenderer() {\n var _this = _super.call(this, AnimateSlideCellRenderer.TEMPLATE) || this;\n _this.refreshCount = 0;\n _this.eCurrent = _this.queryForHtmlElement('.ag-value-slide-current');\n return _this;\n }\n AnimateSlideCellRenderer.prototype.init = function (params) {\n this.refresh(params);\n };\n AnimateSlideCellRenderer.prototype.addSlideAnimation = function () {\n var _this = this;\n this.refreshCount++;\n // below we keep checking this, and stop working on the animation\n // if it no longer matches - this means another animation has started\n // and this one is stale.\n var refreshCountCopy = this.refreshCount;\n // if old animation, remove it\n if (this.ePrevious) {\n this.getGui().removeChild(this.ePrevious);\n }\n this.ePrevious = loadTemplate('');\n this.ePrevious.innerHTML = this.eCurrent.innerHTML;\n this.getGui().insertBefore(this.ePrevious, this.eCurrent);\n // having timeout of 0 allows use to skip to the next css turn,\n // so we know the previous css classes have been applied. so the\n // complex set of setTimeout below creates the animation\n window.setTimeout(function () {\n if (refreshCountCopy !== _this.refreshCount) {\n return;\n }\n _this.ePrevious.classList.add('ag-value-slide-out-end');\n }, 50);\n window.setTimeout(function () {\n if (refreshCountCopy !== _this.refreshCount) {\n return;\n }\n _this.getGui().removeChild(_this.ePrevious);\n _this.ePrevious = null;\n }, 3000);\n };\n AnimateSlideCellRenderer.prototype.refresh = function (params) {\n var value = params.value;\n if (missing(value)) {\n value = '';\n }\n if (value === this.lastValue) {\n return false;\n }\n // we don't show the delta if we are in the middle of a filter. see comment on FilterManager\n // with regards processingFilterChange\n if (this.filterManager.isSuppressFlashingCellsBecauseFiltering()) {\n return false;\n }\n this.addSlideAnimation();\n this.lastValue = value;\n if (exists(params.valueFormatted)) {\n this.eCurrent.innerHTML = params.valueFormatted;\n }\n else if (exists(params.value)) {\n this.eCurrent.innerHTML = value;\n }\n else {\n clearElement(this.eCurrent);\n }\n return true;\n };\n AnimateSlideCellRenderer.TEMPLATE = \"\\n \\n \";\n __decorate([\n Autowired('filterManager')\n ], AnimateSlideCellRenderer.prototype, \"filterManager\", void 0);\n return AnimateSlideCellRenderer;\n}(Component));\nexport { AnimateSlideCellRenderer };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nimport { EventService } from \"../eventService\";\nimport { Events } from \"../events\";\nimport { Constants } from \"../constants/constants\";\nimport { exists, missing, missingOrEmpty } from \"../utils/generic\";\nimport { getAllKeysInObjects } from \"../utils/object\";\nimport { debounce } from \"../utils/function\";\nexport var RowHighlightPosition;\n(function (RowHighlightPosition) {\n RowHighlightPosition[RowHighlightPosition[\"Above\"] = 0] = \"Above\";\n RowHighlightPosition[RowHighlightPosition[\"Below\"] = 1] = \"Below\";\n})(RowHighlightPosition || (RowHighlightPosition = {}));\nvar RowNode = /** @class */ (function () {\n function RowNode(beans) {\n /** The current row index. If the row is filtered out or in a collapsed group, this value will be `null`. */\n this.rowIndex = null;\n /** The key for the group eg Ireland, UK, USA */\n this.key = null;\n /** Children mapped by the pivot columns. */\n this.childrenMapped = {};\n /**\n * This will be `true` if it has a rowIndex assigned, otherwise `false`.\n */\n this.displayed = false;\n /** The row top position in pixels. */\n this.rowTop = null;\n /** The top pixel for this row last time, makes sense if data set was ordered or filtered,\n * it is used so new rows can animate in from their old position. */\n this.oldRowTop = null;\n /** `true` by default - can be overridden via gridOptions.isRowSelectable(rowNode) */\n this.selectable = true;\n /** Used by sorting service - to give deterministic sort to groups. Previously we\n * just id for this, however id is a string and had slower sorting compared to numbers. */\n this.__objectId = RowNode.OBJECT_ID_SEQUENCE++;\n /** When one or more Columns are using autoHeight, this keeps track of height of each autoHeight Cell,\n * indexed by the Column ID. */\n this.__autoHeights = {};\n /** `true` when nodes with the same id are being removed and added as part of the same batch transaction */\n this.alreadyRendered = false;\n this.highlighted = null;\n this.selected = false;\n this.onRowHeightChangedDebounced = debounce(this.onRowHeightChanged.bind(this), 100);\n this.beans = beans;\n }\n /** Replaces the data on the `rowNode`. When complete, the grid will refresh the the entire rendered row if it is showing. */\n RowNode.prototype.setData = function (data) {\n this.setDataCommon(data, false);\n };\n // similar to setRowData, however it is expected that the data is the same data item. this\n // is intended to be used with Redux type stores, where the whole data can be changed. we are\n // guaranteed that the data is the same entity (so grid doesn't need to worry about the id of the\n // underlying data changing, hence doesn't need to worry about selection). the grid, upon receiving\n // dataChanged event, will refresh the cells rather than rip them all out (so user can show transitions).\n RowNode.prototype.updateData = function (data) {\n this.setDataCommon(data, true);\n };\n RowNode.prototype.setDataCommon = function (data, update) {\n var oldData = this.data;\n this.data = data;\n this.beans.valueCache.onDataChanged();\n this.updateDataOnDetailNode();\n this.checkRowSelectable();\n var event = this.createDataChangedEvent(data, oldData, update);\n this.dispatchLocalEvent(event);\n };\n // when we are doing master / detail, the detail node is lazy created, but then kept around.\n // so if we show / hide the detail, the same detail rowNode is used. so we need to keep the data\n // in sync, otherwise expand/collapse of the detail would still show the old values.\n RowNode.prototype.updateDataOnDetailNode = function () {\n if (this.detailNode) {\n this.detailNode.data = this.data;\n }\n };\n RowNode.prototype.createDataChangedEvent = function (newData, oldData, update) {\n return {\n type: RowNode.EVENT_DATA_CHANGED,\n node: this,\n oldData: oldData,\n newData: newData,\n update: update\n };\n };\n RowNode.prototype.createLocalRowEvent = function (type) {\n return {\n type: type,\n node: this\n };\n };\n RowNode.prototype.getRowIndexString = function () {\n if (this.rowPinned === Constants.PINNED_TOP) {\n return 't-' + this.rowIndex;\n }\n if (this.rowPinned === Constants.PINNED_BOTTOM) {\n return 'b-' + this.rowIndex;\n }\n return this.rowIndex.toString();\n };\n RowNode.prototype.createDaemonNode = function () {\n var oldNode = new RowNode(this.beans);\n // just copy the id and data, this is enough for the node to be used\n // in the selection controller (the selection controller is the only\n // place where daemon nodes can live).\n oldNode.id = this.id;\n oldNode.data = this.data;\n oldNode.daemon = true;\n oldNode.selected = this.selected;\n oldNode.level = this.level;\n return oldNode;\n };\n RowNode.prototype.setDataAndId = function (data, id) {\n var oldNode = exists(this.id) ? this.createDaemonNode() : null;\n var oldData = this.data;\n this.data = data;\n this.updateDataOnDetailNode();\n this.setId(id);\n this.beans.selectionService.syncInRowNode(this, oldNode);\n this.checkRowSelectable();\n var event = this.createDataChangedEvent(data, oldData, false);\n this.dispatchLocalEvent(event);\n };\n RowNode.prototype.checkRowSelectable = function () {\n var isRowSelectableFunc = this.beans.gridOptionsWrapper.getIsRowSelectableFunc();\n this.setRowSelectable(isRowSelectableFunc ? isRowSelectableFunc(this) : true);\n };\n RowNode.prototype.setRowSelectable = function (newVal) {\n if (this.selectable !== newVal) {\n this.selectable = newVal;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_SELECTABLE_CHANGED));\n }\n var isGroupSelectsChildren = this.beans.gridOptionsWrapper.isGroupSelectsChildren();\n if (isGroupSelectsChildren) {\n var selected = this.calculateSelectedFromChildren();\n this.setSelected((selected !== null && selected !== void 0 ? selected : false));\n }\n }\n };\n RowNode.prototype.setId = function (id) {\n // see if user is providing the id's\n var getRowIdFunc = this.beans.gridOptionsWrapper.getRowIdFunc();\n if (getRowIdFunc) {\n // if user is providing the id's, then we set the id only after the data has been set.\n // this is important for virtual pagination and viewport, where empty rows exist.\n if (this.data) {\n // we pass 'true' as we skip this level when generating keys,\n // as we don't always have the key for this level (eg when updating\n // data via transaction on SSRM, we are getting key to look up the\n // RowNode, don't have the RowNode yet, thus no way to get the current key)\n var parentKeys = this.getGroupKeys(true);\n this.id = getRowIdFunc({\n data: this.data,\n parentKeys: parentKeys.length > 0 ? parentKeys : undefined,\n level: this.level\n });\n // make sure id provided doesn't start with 'row-group-' as this is reserved. also check that\n // it has 'startsWith' in case the user provided a number.\n if (this.id !== null && typeof this.id === 'string' && this.id.startsWith(RowNode.ID_PREFIX_ROW_GROUP)) {\n console.error(\"AG Grid: Row IDs cannot start with \" + RowNode.ID_PREFIX_ROW_GROUP + \", this is a reserved prefix for AG Grid's row grouping feature.\");\n }\n // force id to be a string\n if (this.id !== null && typeof this.id !== 'string') {\n this.id = '' + this.id;\n }\n }\n else {\n // this can happen if user has set blank into the rowNode after the row previously\n // having data. this happens in virtual page row model, when data is delete and\n // the page is refreshed.\n this.id = undefined;\n }\n }\n else {\n this.id = id;\n }\n };\n RowNode.prototype.getGroupKeys = function (excludeSelf) {\n if (excludeSelf === void 0) { excludeSelf = false; }\n var keys = [];\n var pointer = this;\n if (excludeSelf) {\n pointer = pointer.parent;\n }\n while (pointer && pointer.level >= 0) {\n keys.push(pointer.key);\n pointer = pointer.parent;\n }\n keys.reverse();\n return keys;\n };\n RowNode.prototype.isPixelInRange = function (pixel) {\n if (!exists(this.rowTop) || !exists(this.rowHeight)) {\n return false;\n }\n return pixel >= this.rowTop && pixel < (this.rowTop + this.rowHeight);\n };\n RowNode.prototype.setFirstChild = function (firstChild) {\n if (this.firstChild === firstChild) {\n return;\n }\n this.firstChild = firstChild;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_FIRST_CHILD_CHANGED));\n }\n };\n RowNode.prototype.setLastChild = function (lastChild) {\n if (this.lastChild === lastChild) {\n return;\n }\n this.lastChild = lastChild;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_LAST_CHILD_CHANGED));\n }\n };\n RowNode.prototype.setChildIndex = function (childIndex) {\n if (this.childIndex === childIndex) {\n return;\n }\n this.childIndex = childIndex;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_CHILD_INDEX_CHANGED));\n }\n };\n RowNode.prototype.setRowTop = function (rowTop) {\n this.oldRowTop = this.rowTop;\n if (this.rowTop === rowTop) {\n return;\n }\n this.rowTop = rowTop;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_TOP_CHANGED));\n }\n this.setDisplayed(rowTop !== null);\n };\n RowNode.prototype.clearRowTopAndRowIndex = function () {\n this.oldRowTop = null;\n this.setRowTop(null);\n this.setRowIndex(null);\n };\n RowNode.prototype.setDisplayed = function (displayed) {\n if (this.displayed === displayed) {\n return;\n }\n this.displayed = displayed;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_DISPLAYED_CHANGED));\n }\n };\n RowNode.prototype.setDragging = function (dragging) {\n if (this.dragging === dragging) {\n return;\n }\n this.dragging = dragging;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_DRAGGING_CHANGED));\n }\n };\n RowNode.prototype.setHighlighted = function (highlighted) {\n if (highlighted === this.highlighted) {\n return;\n }\n this.highlighted = highlighted;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_HIGHLIGHT_CHANGED));\n }\n };\n RowNode.prototype.setAllChildrenCount = function (allChildrenCount) {\n if (this.allChildrenCount === allChildrenCount) {\n return;\n }\n this.allChildrenCount = allChildrenCount;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_ALL_CHILDREN_COUNT_CHANGED));\n }\n };\n RowNode.prototype.setMaster = function (master) {\n if (this.master === master) {\n return;\n }\n // if changing AWAY from master, then unexpand, otherwise\n // next time it's shown it is expanded again\n if (this.master && !master) {\n this.expanded = false;\n }\n this.master = master;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_MASTER_CHANGED));\n }\n };\n RowNode.prototype.setGroup = function (group) {\n if (this.group === group) {\n return;\n }\n // if we used to be a group, and no longer, then close the node\n if (this.group && !group) {\n this.expanded = false;\n }\n this.group = group;\n this.updateHasChildren();\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_GROUP_CHANGED));\n }\n };\n /**\n * Sets the row height.\n * Call if you want to change the height initially assigned to the row.\n * After calling, you must call `api.onRowHeightChanged()` so the grid knows it needs to work out the placement of the rows. */\n RowNode.prototype.setRowHeight = function (rowHeight, estimated) {\n if (estimated === void 0) { estimated = false; }\n this.rowHeight = rowHeight;\n this.rowHeightEstimated = estimated;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_HEIGHT_CHANGED));\n }\n };\n RowNode.prototype.setRowAutoHeight = function (cellHeight, column) {\n if (!this.__autoHeights) {\n this.__autoHeights = {};\n }\n var autoHeights = this.__autoHeights;\n autoHeights[column.getId()] = cellHeight;\n if (cellHeight != null) {\n if (this.checkAutoHeightsDebounced == null) {\n this.checkAutoHeightsDebounced = debounce(this.checkAutoHeights.bind(this), 1);\n }\n this.checkAutoHeightsDebounced();\n }\n };\n RowNode.prototype.checkAutoHeights = function () {\n var notAllPresent = false;\n var nonePresent = true;\n var newRowHeight = 0;\n var autoHeights = this.__autoHeights;\n if (autoHeights == null) {\n return;\n }\n var displayedAutoHeightCols = this.beans.columnModel.getAllDisplayedAutoHeightCols();\n displayedAutoHeightCols.forEach(function (col) {\n var cellHeight = autoHeights[col.getId()];\n if (cellHeight == null) {\n notAllPresent = true;\n return;\n }\n nonePresent = false;\n if (cellHeight > newRowHeight) {\n newRowHeight = cellHeight;\n }\n });\n if (notAllPresent) {\n return;\n }\n // we take min of 10, so we don't adjust for empty rows. if <10, we put to default.\n // this prevents the row starting very small when waiting for async components,\n // which would then mean the grid squashes in far to many rows (as small heights\n // means more rows fit in) which looks crap. so best ignore small values and assume\n // we are still waiting for values to render.\n if (nonePresent || newRowHeight < 10) {\n newRowHeight = this.beans.gridOptionsWrapper.getRowHeightForNode(this).height;\n }\n if (newRowHeight == this.rowHeight) {\n return;\n }\n this.setRowHeight(newRowHeight);\n this.onRowHeightChangedDebounced();\n };\n /** This method is debounced. It is used for row auto-height. If we don't debounce,\n * then the Row Models will end up recalculating each row position\n * for each row height change and result in the Row Renderer laying out rows.\n * This is particularly bad if using print layout, and showing eg 1,000 rows,\n * each row will change it's height, causing Row Model to update 1,000 times.\n */\n RowNode.prototype.onRowHeightChanged = function () {\n var rowModel = this.beans.rowModel;\n if (rowModel.onRowHeightChanged) {\n rowModel.onRowHeightChanged();\n }\n };\n RowNode.prototype.setRowIndex = function (rowIndex) {\n if (this.rowIndex === rowIndex) {\n return;\n }\n this.rowIndex = rowIndex;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_ROW_INDEX_CHANGED));\n }\n };\n RowNode.prototype.setUiLevel = function (uiLevel) {\n if (this.uiLevel === uiLevel) {\n return;\n }\n this.uiLevel = uiLevel;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_UI_LEVEL_CHANGED));\n }\n };\n /**\n * Set the expanded state of this rowNode. Pass `true` to expand and `false` to collapse.\n */\n RowNode.prototype.setExpanded = function (expanded, e) {\n if (this.expanded === expanded) {\n return;\n }\n this.expanded = expanded;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_EXPANDED_CHANGED));\n }\n var event = Object.assign({}, this.createGlobalRowEvent(Events.EVENT_ROW_GROUP_OPENED), {\n expanded: expanded,\n event: e || null\n });\n this.beans.rowNodeEventThrottle.dispatchExpanded(event);\n // when using footers we need to refresh the group row, as the aggregation\n // values jump between group and footer\n if (this.beans.gridOptionsWrapper.isGroupIncludeFooter()) {\n this.beans.rowRenderer.refreshCells({ rowNodes: [this] });\n }\n };\n RowNode.prototype.createGlobalRowEvent = function (type) {\n return {\n type: type,\n node: this,\n data: this.data,\n rowIndex: this.rowIndex,\n rowPinned: this.rowPinned,\n context: this.beans.gridOptionsWrapper.getContext(),\n api: this.beans.gridOptionsWrapper.getApi(),\n columnApi: this.beans.gridOptionsWrapper.getColumnApi()\n };\n };\n RowNode.prototype.dispatchLocalEvent = function (event) {\n if (this.eventService) {\n this.eventService.dispatchEvent(event);\n }\n };\n /**\n * Replaces the value on the `rowNode` for the specified column. When complete,\n * the grid will refresh the rendered cell on the required row only.\n *\n * @param colKey The column where the value should be updated\n * @param newValue The new value\n * @param eventSource The source of the event\n * @returns `True` if the value was changed, otherwise `False`.\n */\n RowNode.prototype.setDataValue = function (colKey, newValue, eventSource) {\n // When it is done via the editors, no 'cell changed' event gets fired, as it's assumed that\n // the cell knows about the change given it's in charge of the editing.\n // this method is for the client to call, so the cell listens for the change\n // event, and also flashes the cell when the change occurs.\n var column = this.beans.columnModel.getPrimaryColumn(colKey);\n var oldValue = this.beans.valueService.getValue(column, this);\n var valueChanged = this.beans.valueService.setValue(this, column, newValue, eventSource);\n this.dispatchCellChangedEvent(column, newValue, oldValue);\n this.checkRowSelectable();\n return valueChanged;\n };\n RowNode.prototype.setGroupValue = function (colKey, newValue) {\n var column = this.beans.columnModel.getGridColumn(colKey);\n if (missing(this.groupData)) {\n this.groupData = {};\n }\n var columnId = column.getColId();\n var oldValue = this.groupData[columnId];\n if (oldValue === newValue) {\n return;\n }\n this.groupData[columnId] = newValue;\n this.dispatchCellChangedEvent(column, newValue, oldValue);\n };\n // sets the data for an aggregation\n RowNode.prototype.setAggData = function (newAggData) {\n var _this = this;\n // find out all keys that could potentially change\n var colIds = getAllKeysInObjects([this.aggData, newAggData]);\n var oldAggData = this.aggData;\n this.aggData = newAggData;\n // if no event service, nobody has registered for events, so no need fire event\n if (this.eventService) {\n colIds.forEach(function (colId) {\n var column = _this.beans.columnModel.getGridColumn(colId);\n var value = _this.aggData ? _this.aggData[colId] : undefined;\n var oldValue = oldAggData ? oldAggData[colId] : undefined;\n _this.dispatchCellChangedEvent(column, value, oldValue);\n });\n }\n };\n RowNode.prototype.updateHasChildren = function () {\n // we need to return true when this.group=true, as this is used by server side row model\n // (as children are lazy loaded and stored in a cache anyway). otherwise we return true\n // if children exist.\n var newValue = (this.group && !this.footer) || (this.childrenAfterGroup && this.childrenAfterGroup.length > 0);\n if (newValue !== this.__hasChildren) {\n this.__hasChildren = !!newValue;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_HAS_CHILDREN_CHANGED));\n }\n }\n };\n RowNode.prototype.hasChildren = function () {\n if (this.__hasChildren == null) {\n this.updateHasChildren();\n }\n return this.__hasChildren;\n };\n RowNode.prototype.isEmptyRowGroupNode = function () {\n return this.group && missingOrEmpty(this.childrenAfterGroup);\n };\n RowNode.prototype.dispatchCellChangedEvent = function (column, newValue, oldValue) {\n var cellChangedEvent = {\n type: RowNode.EVENT_CELL_CHANGED,\n node: this,\n column: column,\n newValue: newValue,\n oldValue: oldValue\n };\n this.dispatchLocalEvent(cellChangedEvent);\n };\n /**\n * The first time `quickFilter` runs, the grid creates a one-off string representation of the row.\n * This string is then used for the quick filter instead of hitting each column separately.\n * When you edit, using grid editing, this string gets cleared down.\n * However if you edit without using grid editing, you will need to clear this string down for the row to be updated with the new values.\n * Otherwise new values will not work with the `quickFilter`. */\n RowNode.prototype.resetQuickFilterAggregateText = function () {\n this.quickFilterAggregateText = null;\n };\n RowNode.prototype.isExpandable = function () {\n return (this.hasChildren() && !this.footer) || this.master ? true : false;\n };\n /** Returns:\n * - `true` if node is selected,\n * - `false` if the node isn't selected\n * - `undefined` if it's partially selected (group where not all children are selected). */\n RowNode.prototype.isSelected = function () {\n // for footers, we just return what our sibling selected state is, as cannot select a footer\n if (this.footer) {\n return this.sibling.isSelected();\n }\n return this.selected;\n };\n /** Perform a depth-first search of this node and its children. */\n RowNode.prototype.depthFirstSearch = function (callback) {\n if (this.childrenAfterGroup) {\n this.childrenAfterGroup.forEach(function (child) { return child.depthFirstSearch(callback); });\n }\n callback(this);\n };\n // + selectionController.calculatedSelectedForAllGroupNodes()\n RowNode.prototype.calculateSelectedFromChildren = function () {\n var _a;\n var atLeastOneSelected = false;\n var atLeastOneDeSelected = false;\n var atLeastOneMixed = false;\n if (!((_a = this.childrenAfterGroup) === null || _a === void 0 ? void 0 : _a.length)) {\n return this.selectable ? this.selected : null;\n }\n for (var i = 0; i < this.childrenAfterGroup.length; i++) {\n var child = this.childrenAfterGroup[i];\n var childState = child.isSelected();\n // non-selectable nodes must be calculated from their children, or ignored if no value results.\n if (!child.selectable) {\n var selectable = child.calculateSelectedFromChildren();\n if (selectable === null) {\n continue;\n }\n childState = selectable;\n }\n switch (childState) {\n case true:\n atLeastOneSelected = true;\n break;\n case false:\n atLeastOneDeSelected = true;\n break;\n default:\n atLeastOneMixed = true;\n break;\n }\n }\n if (atLeastOneMixed || (atLeastOneSelected && atLeastOneDeSelected)) {\n return undefined;\n }\n else if (atLeastOneSelected) {\n return true;\n }\n else if (atLeastOneDeSelected) {\n return false;\n }\n else if (!this.selectable) {\n return null;\n }\n else {\n return this.selected;\n }\n };\n RowNode.prototype.setSelectedInitialValue = function (selected) {\n this.selected = selected;\n };\n /**\n * Select (or deselect) the node.\n * @param newValue -`true` for selection, `false` for deselection.\n * @param clearSelection - If selecting, then passing `true` will select the node exclusively (i.e. NOT do multi select). If doing deselection, `clearSelection` has no impact.\n * @param suppressFinishActions - Pass `true` to prevent the `selectionChanged` from being fired. Note that the `rowSelected` event will still be fired.\n */\n RowNode.prototype.setSelected = function (newValue, clearSelection, suppressFinishActions) {\n if (clearSelection === void 0) { clearSelection = false; }\n if (suppressFinishActions === void 0) { suppressFinishActions = false; }\n this.setSelectedParams({\n newValue: newValue,\n clearSelection: clearSelection,\n suppressFinishActions: suppressFinishActions,\n rangeSelect: false\n });\n };\n RowNode.prototype.isRowPinned = function () {\n return this.rowPinned === Constants.PINNED_TOP || this.rowPinned === Constants.PINNED_BOTTOM;\n };\n // to make calling code more readable, this is the same method as setSelected except it takes names parameters\n RowNode.prototype.setSelectedParams = function (params) {\n var _a;\n var groupSelectsChildren = this.beans.gridOptionsWrapper.isGroupSelectsChildren();\n var newValue = params.newValue === true;\n var clearSelection = params.clearSelection === true;\n var suppressFinishActions = params.suppressFinishActions === true;\n var rangeSelect = params.rangeSelect === true;\n // groupSelectsFiltered only makes sense when group selects children\n var groupSelectsFiltered = groupSelectsChildren && (params.groupSelectsFiltered === true);\n if (this.id === undefined) {\n console.warn('AG Grid: cannot select node until id for node is known');\n return 0;\n }\n if (this.rowPinned) {\n console.warn('AG Grid: cannot select pinned rows');\n return 0;\n }\n // if we are a footer, we don't do selection, just pass the info\n // to the sibling (the parent of the group)\n if (this.footer) {\n return this.sibling.setSelectedParams(params);\n }\n if (rangeSelect && this.beans.selectionService.getLastSelectedNode()) {\n var newRowClicked = this.beans.selectionService.getLastSelectedNode() !== this;\n var allowMultiSelect = this.beans.gridOptionsWrapper.isRowSelectionMulti();\n if (newRowClicked && allowMultiSelect) {\n var nodesChanged = this.doRowRangeSelection(params.newValue);\n this.beans.selectionService.setLastSelectedNode(this);\n return nodesChanged;\n }\n }\n var updatedCount = 0;\n // when groupSelectsFiltered, then this node may end up intermediate despite\n // trying to set it to true / false. this group will be calculated further on\n // down when we call calculatedSelectedForAllGroupNodes(). we need to skip it\n // here, otherwise the updatedCount would include it.\n var skipThisNode = groupSelectsFiltered && this.group;\n if (!skipThisNode) {\n var thisNodeWasSelected = this.selectThisNode(newValue, params.event);\n if (thisNodeWasSelected) {\n updatedCount++;\n }\n }\n if (groupSelectsChildren && ((_a = this.childrenAfterGroup) === null || _a === void 0 ? void 0 : _a.length)) {\n updatedCount += this.selectChildNodes(newValue, groupSelectsFiltered);\n }\n // clear other nodes if not doing multi select\n if (!suppressFinishActions) {\n var clearOtherNodes = newValue && (clearSelection || !this.beans.gridOptionsWrapper.isRowSelectionMulti());\n if (clearOtherNodes) {\n updatedCount += this.beans.selectionService.clearOtherNodes(this);\n }\n // only if we selected something, then update groups and fire events\n if (updatedCount > 0) {\n this.beans.selectionService.updateGroupsFromChildrenSelections();\n // this is the very end of the 'action node', so we are finished all the updates,\n // include any parent / child changes that this method caused\n var event_1 = {\n type: Events.EVENT_SELECTION_CHANGED\n };\n this.beans.eventService.dispatchEvent(event_1);\n }\n // so if user next does shift-select, we know where to start the selection from\n if (newValue) {\n this.beans.selectionService.setLastSelectedNode(this);\n }\n }\n return updatedCount;\n };\n // selects all rows between this node and the last selected node (or the top if this is the first selection).\n // not to be mixed up with 'cell range selection' where you drag the mouse, this is row range selection, by\n // holding down 'shift'.\n RowNode.prototype.doRowRangeSelection = function (value) {\n var _this = this;\n if (value === void 0) { value = true; }\n var groupsSelectChildren = this.beans.gridOptionsWrapper.isGroupSelectsChildren();\n var lastSelectedNode = this.beans.selectionService.getLastSelectedNode();\n var nodesToSelect = this.beans.rowModel.getNodesInRangeForSelection(this, lastSelectedNode);\n var updatedCount = 0;\n nodesToSelect.forEach(function (rowNode) {\n if (rowNode.group && groupsSelectChildren || (value === false && _this === rowNode)) {\n return;\n }\n var nodeWasSelected = rowNode.selectThisNode(value);\n if (nodeWasSelected) {\n updatedCount++;\n }\n });\n this.beans.selectionService.updateGroupsFromChildrenSelections();\n var event = {\n type: Events.EVENT_SELECTION_CHANGED\n };\n this.beans.eventService.dispatchEvent(event);\n return updatedCount;\n };\n RowNode.prototype.isParentOfNode = function (potentialParent) {\n var parentNode = this.parent;\n while (parentNode) {\n if (parentNode === potentialParent) {\n return true;\n }\n parentNode = parentNode.parent;\n }\n return false;\n };\n RowNode.prototype.selectThisNode = function (newValue, e) {\n // we only check selectable when newValue=true (ie selecting) to allow unselecting values,\n // as selectable is dynamic, need a way to unselect rows when selectable becomes false.\n var selectionNotAllowed = !this.selectable && newValue;\n var selectionNotChanged = this.selected === newValue;\n if (selectionNotAllowed || selectionNotChanged) {\n return false;\n }\n this.selected = newValue;\n if (this.eventService) {\n this.dispatchLocalEvent(this.createLocalRowEvent(RowNode.EVENT_ROW_SELECTED));\n }\n var event = Object.assign({}, this.createGlobalRowEvent(Events.EVENT_ROW_SELECTED), {\n event: e || null\n });\n this.beans.eventService.dispatchEvent(event);\n return true;\n };\n RowNode.prototype.selectChildNodes = function (newValue, groupSelectsFiltered) {\n var children = groupSelectsFiltered ? this.childrenAfterAggFilter : this.childrenAfterGroup;\n if (missing(children)) {\n return 0;\n }\n var updatedCount = 0;\n for (var i = 0; i < children.length; i++) {\n updatedCount += children[i].setSelectedParams({\n newValue: newValue,\n clearSelection: false,\n suppressFinishActions: true,\n groupSelectsFiltered: groupSelectsFiltered\n });\n }\n return updatedCount;\n };\n /** Add an event listener. */\n RowNode.prototype.addEventListener = function (eventType, listener) {\n if (!this.eventService) {\n this.eventService = new EventService();\n }\n this.eventService.addEventListener(eventType, listener);\n };\n /** Remove event listener. */\n RowNode.prototype.removeEventListener = function (eventType, listener) {\n if (!this.eventService) {\n return;\n }\n this.eventService.removeEventListener(eventType, listener);\n if (this.eventService.noRegisteredListenersExist()) {\n this.eventService = null;\n }\n };\n RowNode.prototype.onMouseEnter = function () {\n this.dispatchLocalEvent(this.createLocalRowEvent(RowNode.EVENT_MOUSE_ENTER));\n };\n RowNode.prototype.onMouseLeave = function () {\n this.dispatchLocalEvent(this.createLocalRowEvent(RowNode.EVENT_MOUSE_LEAVE));\n };\n RowNode.prototype.getFirstChildOfFirstChild = function (rowGroupColumn) {\n var currentRowNode = this;\n var isCandidate = true;\n var foundFirstChildPath = false;\n var nodeToSwapIn = null;\n // if we are hiding groups, then if we are the first child, of the first child,\n // all the way up to the column we are interested in, then we show the group cell.\n while (isCandidate && !foundFirstChildPath) {\n var parentRowNode = currentRowNode.parent;\n var firstChild = exists(parentRowNode) && currentRowNode.firstChild;\n if (firstChild) {\n if (parentRowNode.rowGroupColumn === rowGroupColumn) {\n foundFirstChildPath = true;\n nodeToSwapIn = parentRowNode;\n }\n }\n else {\n isCandidate = false;\n }\n currentRowNode = parentRowNode;\n }\n return foundFirstChildPath ? nodeToSwapIn : null;\n };\n RowNode.prototype.isFullWidthCell = function () {\n var isFullWidthCellFunc = this.beans.gridOptionsWrapper.getIsFullWidthCellFunc();\n return isFullWidthCellFunc ? isFullWidthCellFunc({ rowNode: this }) : false;\n };\n /**\n * Returns the route of the row node. If the Row Node is a group, it returns the route to that Row Node.\n * If the Row Node is not a group, it returns `undefined`.\n */\n RowNode.prototype.getRoute = function () {\n if (this.key == null) {\n return;\n }\n var res = [];\n var pointer = this;\n while (pointer.key != null) {\n res.push(pointer.key);\n pointer = pointer.parent;\n }\n return res.reverse();\n };\n RowNode.ID_PREFIX_ROW_GROUP = 'row-group-';\n RowNode.ID_PREFIX_TOP_PINNED = 't-';\n RowNode.ID_PREFIX_BOTTOM_PINNED = 'b-';\n RowNode.OBJECT_ID_SEQUENCE = 0;\n RowNode.EVENT_ROW_SELECTED = 'rowSelected';\n RowNode.EVENT_DATA_CHANGED = 'dataChanged';\n RowNode.EVENT_CELL_CHANGED = 'cellChanged';\n RowNode.EVENT_ALL_CHILDREN_COUNT_CHANGED = 'allChildrenCountChanged';\n RowNode.EVENT_MASTER_CHANGED = 'masterChanged';\n RowNode.EVENT_GROUP_CHANGED = 'groupChanged';\n RowNode.EVENT_MOUSE_ENTER = 'mouseEnter';\n RowNode.EVENT_MOUSE_LEAVE = 'mouseLeave';\n RowNode.EVENT_HEIGHT_CHANGED = 'heightChanged';\n RowNode.EVENT_TOP_CHANGED = 'topChanged';\n RowNode.EVENT_DISPLAYED_CHANGED = 'displayedChanged';\n RowNode.EVENT_FIRST_CHILD_CHANGED = 'firstChildChanged';\n RowNode.EVENT_LAST_CHILD_CHANGED = 'lastChildChanged';\n RowNode.EVENT_CHILD_INDEX_CHANGED = 'childIndexChanged';\n RowNode.EVENT_ROW_INDEX_CHANGED = 'rowIndexChanged';\n RowNode.EVENT_EXPANDED_CHANGED = 'expandedChanged';\n RowNode.EVENT_HAS_CHILDREN_CHANGED = 'hasChildrenChanged';\n RowNode.EVENT_SELECTABLE_CHANGED = 'selectableChanged';\n RowNode.EVENT_UI_LEVEL_CHANGED = 'uiLevelChanged';\n RowNode.EVENT_HIGHLIGHT_CHANGED = 'rowHighlightChanged';\n RowNode.EVENT_DRAGGING_CHANGED = 'draggingChanged';\n return RowNode;\n}());\nexport { RowNode };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PostConstruct } from '../context/context';\nimport { Component } from '../widgets/component';\nimport { Events } from '../events';\nimport { RefSelector } from '../widgets/componentAnnotations';\nimport { RowNode } from '../entities/rowNode';\nimport { stopPropagationForAgGrid } from '../utils/event';\nvar CheckboxSelectionComponent = /** @class */ (function (_super) {\n __extends(CheckboxSelectionComponent, _super);\n function CheckboxSelectionComponent() {\n return _super.call(this, /* html*/ \"\\n
\\n \\n
\") || this;\n }\n CheckboxSelectionComponent.prototype.postConstruct = function () {\n this.eCheckbox.setPassive(true);\n };\n CheckboxSelectionComponent.prototype.getCheckboxId = function () {\n return this.eCheckbox.getInputElement().id;\n };\n CheckboxSelectionComponent.prototype.onDataChanged = function () {\n // when rows are loaded for the second time, this can impact the selection, as a row\n // could be loaded as already selected (if user scrolls down, and then up again).\n this.onSelectionChanged();\n };\n CheckboxSelectionComponent.prototype.onSelectableChanged = function () {\n this.showOrHideSelect();\n };\n CheckboxSelectionComponent.prototype.onSelectionChanged = function () {\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n var state = this.rowNode.isSelected();\n var stateName = state === undefined\n ? translate('ariaIndeterminate', 'indeterminate')\n : (state === true\n ? translate('ariaChecked', 'checked')\n : translate('ariaUnchecked', 'unchecked'));\n var ariaLabel = translate('ariaRowToggleSelection', 'Press Space to toggle row selection');\n this.eCheckbox.setValue(state, true);\n this.eCheckbox.setInputAriaLabel(ariaLabel + \" (\" + stateName + \")\");\n };\n CheckboxSelectionComponent.prototype.onCheckedClicked = function (event) {\n var groupSelectsFiltered = this.gridOptionsWrapper.isGroupSelectsFiltered();\n var updatedCount = this.rowNode.setSelectedParams({ newValue: false, rangeSelect: event.shiftKey, groupSelectsFiltered: groupSelectsFiltered });\n return updatedCount;\n };\n CheckboxSelectionComponent.prototype.onUncheckedClicked = function (event) {\n var groupSelectsFiltered = this.gridOptionsWrapper.isGroupSelectsFiltered();\n var updatedCount = this.rowNode.setSelectedParams({ newValue: true, rangeSelect: event.shiftKey, groupSelectsFiltered: groupSelectsFiltered });\n return updatedCount;\n };\n CheckboxSelectionComponent.prototype.init = function (params) {\n var _this = this;\n this.rowNode = params.rowNode;\n this.column = params.column;\n this.overrides = params.overrides;\n this.onSelectionChanged();\n // we don't want the row clicked event to fire when selecting the checkbox, otherwise the row\n // would possibly get selected twice\n this.addGuiEventListener('click', function (event) { return stopPropagationForAgGrid(event); });\n // likewise we don't want double click on this icon to open a group\n this.addGuiEventListener('dblclick', function (event) { return stopPropagationForAgGrid(event); });\n this.addManagedListener(this.eCheckbox.getInputElement(), 'click', function (event) {\n var isSelected = _this.eCheckbox.getValue();\n var previousValue = _this.eCheckbox.getPreviousValue();\n if (previousValue === undefined || isSelected === undefined) {\n // Indeterminate state - try toggling children to determine action.\n var result = _this.onUncheckedClicked(event || {});\n if (result === 0) {\n _this.onCheckedClicked(event);\n }\n }\n else if (isSelected) {\n _this.onCheckedClicked(event);\n }\n else {\n _this.onUncheckedClicked(event || {});\n }\n });\n this.addManagedListener(this.rowNode, RowNode.EVENT_ROW_SELECTED, this.onSelectionChanged.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_DATA_CHANGED, this.onDataChanged.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_SELECTABLE_CHANGED, this.onSelectableChanged.bind(this));\n var isRowSelectableFunc = this.gridOptionsWrapper.getIsRowSelectableFunc();\n var checkboxVisibleIsDynamic = isRowSelectableFunc || typeof this.getIsVisible() === 'function';\n if (checkboxVisibleIsDynamic) {\n var showOrHideSelectListener = this.showOrHideSelect.bind(this);\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, showOrHideSelectListener);\n this.addManagedListener(this.rowNode, RowNode.EVENT_DATA_CHANGED, showOrHideSelectListener);\n this.addManagedListener(this.rowNode, RowNode.EVENT_CELL_CHANGED, showOrHideSelectListener);\n this.showOrHideSelect();\n }\n this.eCheckbox.getInputElement().setAttribute('tabindex', '-1');\n };\n CheckboxSelectionComponent.prototype.showOrHideSelect = function () {\n var _a, _b, _c, _d;\n // if the isRowSelectable() is not provided the row node is selectable by default\n var selectable = this.rowNode.selectable;\n // checkboxSelection callback is deemed a legacy solution however we will still consider it's result.\n // If selectable, then also check the colDef callback. if not selectable, this it short circuits - no need\n // to call the colDef callback.\n var isVisible = this.getIsVisible();\n if (selectable) {\n if (typeof isVisible === 'function') {\n var extraParams = (_a = this.overrides) === null || _a === void 0 ? void 0 : _a.callbackParams;\n var params = (_b = this.column) === null || _b === void 0 ? void 0 : _b.createColumnFunctionCallbackParams(this.rowNode);\n selectable = params ? isVisible(__assign(__assign({}, extraParams), params)) : false;\n }\n else {\n selectable = (isVisible !== null && isVisible !== void 0 ? isVisible : false);\n }\n }\n var disableInsteadOfHide = (_c = this.column) === null || _c === void 0 ? void 0 : _c.getColDef().showDisabledCheckboxes;\n if (disableInsteadOfHide) {\n this.eCheckbox.setDisabled(!selectable);\n this.setVisible(true);\n this.setDisplayed(true);\n return;\n }\n if ((_d = this.overrides) === null || _d === void 0 ? void 0 : _d.removeHidden) {\n this.setDisplayed(selectable);\n return;\n }\n this.setVisible(selectable);\n };\n CheckboxSelectionComponent.prototype.getIsVisible = function () {\n var _a, _b;\n if (this.overrides) {\n return this.overrides.isVisible;\n }\n // column will be missing if groupUseEntireRow=true\n return (_b = (_a = this.column) === null || _a === void 0 ? void 0 : _a.getColDef()) === null || _b === void 0 ? void 0 : _b.checkboxSelection;\n };\n __decorate([\n RefSelector('eCheckbox')\n ], CheckboxSelectionComponent.prototype, \"eCheckbox\", void 0);\n __decorate([\n PostConstruct\n ], CheckboxSelectionComponent.prototype, \"postConstruct\", null);\n return CheckboxSelectionComponent;\n}(Component));\nexport { CheckboxSelectionComponent };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __values = (this && this.__values) || function(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\nimport { BeanStub } from \"../context/beanStub\";\nimport { PostConstruct, Bean, Autowired, PreDestroy } from \"../context/context\";\nimport { escapeString } from \"../utils/string\";\nimport { createIcon } from \"../utils/icon\";\nimport { flatten, removeFromArray } from \"../utils/array\";\nimport { getBodyHeight, getBodyWidth } from \"../utils/browser\";\nimport { loadTemplate, clearElement } from \"../utils/dom\";\nimport { isFunction } from \"../utils/function\";\nexport var DragSourceType;\n(function (DragSourceType) {\n DragSourceType[DragSourceType[\"ToolPanel\"] = 0] = \"ToolPanel\";\n DragSourceType[DragSourceType[\"HeaderCell\"] = 1] = \"HeaderCell\";\n DragSourceType[DragSourceType[\"RowDrag\"] = 2] = \"RowDrag\";\n DragSourceType[DragSourceType[\"ChartPanel\"] = 3] = \"ChartPanel\";\n})(DragSourceType || (DragSourceType = {}));\nexport var VerticalDirection;\n(function (VerticalDirection) {\n VerticalDirection[VerticalDirection[\"Up\"] = 0] = \"Up\";\n VerticalDirection[VerticalDirection[\"Down\"] = 1] = \"Down\";\n})(VerticalDirection || (VerticalDirection = {}));\nexport var HorizontalDirection;\n(function (HorizontalDirection) {\n HorizontalDirection[HorizontalDirection[\"Left\"] = 0] = \"Left\";\n HorizontalDirection[HorizontalDirection[\"Right\"] = 1] = \"Right\";\n})(HorizontalDirection || (HorizontalDirection = {}));\nvar DragAndDropService = /** @class */ (function (_super) {\n __extends(DragAndDropService, _super);\n function DragAndDropService() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.dragSourceAndParamsList = [];\n _this.dropTargets = [];\n return _this;\n }\n DragAndDropService_1 = DragAndDropService;\n DragAndDropService.prototype.init = function () {\n this.ePinnedIcon = createIcon('columnMovePin', this.gridOptionsWrapper, null);\n this.eHideIcon = createIcon('columnMoveHide', this.gridOptionsWrapper, null);\n this.eMoveIcon = createIcon('columnMoveMove', this.gridOptionsWrapper, null);\n this.eLeftIcon = createIcon('columnMoveLeft', this.gridOptionsWrapper, null);\n this.eRightIcon = createIcon('columnMoveRight', this.gridOptionsWrapper, null);\n this.eGroupIcon = createIcon('columnMoveGroup', this.gridOptionsWrapper, null);\n this.eAggregateIcon = createIcon('columnMoveValue', this.gridOptionsWrapper, null);\n this.ePivotIcon = createIcon('columnMovePivot', this.gridOptionsWrapper, null);\n this.eDropNotAllowedIcon = createIcon('dropNotAllowed', this.gridOptionsWrapper, null);\n };\n DragAndDropService.prototype.addDragSource = function (dragSource, allowTouch) {\n if (allowTouch === void 0) { allowTouch = false; }\n var params = {\n eElement: dragSource.eElement,\n dragStartPixels: dragSource.dragStartPixels,\n onDragStart: this.onDragStart.bind(this, dragSource),\n onDragStop: this.onDragStop.bind(this),\n onDragging: this.onDragging.bind(this)\n };\n this.dragSourceAndParamsList.push({ params: params, dragSource: dragSource });\n this.dragService.addDragSource(params, allowTouch);\n };\n DragAndDropService.prototype.removeDragSource = function (dragSource) {\n var sourceAndParams = this.dragSourceAndParamsList.find(function (item) { return item.dragSource === dragSource; });\n if (sourceAndParams) {\n this.dragService.removeDragSource(sourceAndParams.params);\n removeFromArray(this.dragSourceAndParamsList, sourceAndParams);\n }\n };\n DragAndDropService.prototype.clearDragSourceParamsList = function () {\n var _this = this;\n this.dragSourceAndParamsList.forEach(function (sourceAndParams) { return _this.dragService.removeDragSource(sourceAndParams.params); });\n this.dragSourceAndParamsList.length = 0;\n };\n DragAndDropService.prototype.nudge = function () {\n if (this.dragging) {\n this.onDragging(this.eventLastTime, true);\n }\n };\n DragAndDropService.prototype.onDragStart = function (dragSource, mouseEvent) {\n this.dragging = true;\n this.dragSource = dragSource;\n this.eventLastTime = mouseEvent;\n this.dragItem = this.dragSource.getDragItem();\n this.lastDropTarget = this.dragSource.dragSourceDropTarget;\n if (this.dragSource.onDragStarted) {\n this.dragSource.onDragStarted();\n }\n this.createGhost();\n };\n DragAndDropService.prototype.onDragStop = function (mouseEvent) {\n this.eventLastTime = null;\n this.dragging = false;\n if (this.dragSource.onDragStopped) {\n this.dragSource.onDragStopped();\n }\n if (this.lastDropTarget && this.lastDropTarget.onDragStop) {\n var draggingEvent = this.createDropTargetEvent(this.lastDropTarget, mouseEvent, null, null, false);\n this.lastDropTarget.onDragStop(draggingEvent);\n }\n this.lastDropTarget = null;\n this.dragItem = null;\n this.removeGhost();\n };\n DragAndDropService.prototype.onDragging = function (mouseEvent, fromNudge) {\n var _this = this;\n var _a, _b, _c, _d;\n var hDirection = this.getHorizontalDirection(mouseEvent);\n var vDirection = this.getVerticalDirection(mouseEvent);\n this.eventLastTime = mouseEvent;\n this.positionGhost(mouseEvent);\n // check if mouseEvent intersects with any of the drop targets\n var validDropTargets = this.dropTargets.filter(function (target) { return _this.isMouseOnDropTarget(mouseEvent, target); });\n var dropTarget = this.findCurrentDropTarget(mouseEvent, validDropTargets);\n if (dropTarget !== this.lastDropTarget) {\n this.leaveLastTargetIfExists(mouseEvent, hDirection, vDirection, fromNudge);\n if (this.lastDropTarget !== null && dropTarget === null) {\n (_b = (_a = this.dragSource).onGridExit) === null || _b === void 0 ? void 0 : _b.call(_a, this.dragItem);\n }\n if (this.lastDropTarget === null && dropTarget !== null) {\n (_d = (_c = this.dragSource).onGridEnter) === null || _d === void 0 ? void 0 : _d.call(_c, this.dragItem);\n }\n this.enterDragTargetIfExists(dropTarget, mouseEvent, hDirection, vDirection, fromNudge);\n this.lastDropTarget = dropTarget;\n }\n else if (dropTarget && dropTarget.onDragging) {\n var draggingEvent = this.createDropTargetEvent(dropTarget, mouseEvent, hDirection, vDirection, fromNudge);\n dropTarget.onDragging(draggingEvent);\n }\n };\n DragAndDropService.prototype.getAllContainersFromDropTarget = function (dropTarget) {\n var secondaryContainers = dropTarget.getSecondaryContainers ? dropTarget.getSecondaryContainers() : null;\n var containers = [[dropTarget.getContainer()]];\n return secondaryContainers ? containers.concat(secondaryContainers) : containers;\n };\n DragAndDropService.prototype.allContainersIntersect = function (mouseEvent, containers) {\n var e_1, _a;\n try {\n for (var containers_1 = __values(containers), containers_1_1 = containers_1.next(); !containers_1_1.done; containers_1_1 = containers_1.next()) {\n var container = containers_1_1.value;\n var rect = container.getBoundingClientRect();\n // if element is not visible, then width and height are zero\n if (rect.width === 0 || rect.height === 0) {\n return false;\n }\n var horizontalFit = mouseEvent.clientX >= rect.left && mouseEvent.clientX < rect.right;\n var verticalFit = mouseEvent.clientY >= rect.top && mouseEvent.clientY < rect.bottom;\n if (!horizontalFit || !verticalFit) {\n return false;\n }\n }\n }\n catch (e_1_1) { e_1 = { error: e_1_1 }; }\n finally {\n try {\n if (containers_1_1 && !containers_1_1.done && (_a = containers_1.return)) _a.call(containers_1);\n }\n finally { if (e_1) throw e_1.error; }\n }\n return true;\n };\n // checks if the mouse is on the drop target. it checks eContainer and eSecondaryContainers\n DragAndDropService.prototype.isMouseOnDropTarget = function (mouseEvent, dropTarget) {\n var e_2, _a;\n var allContainersFromDropTarget = this.getAllContainersFromDropTarget(dropTarget);\n var mouseOverTarget = false;\n try {\n for (var allContainersFromDropTarget_1 = __values(allContainersFromDropTarget), allContainersFromDropTarget_1_1 = allContainersFromDropTarget_1.next(); !allContainersFromDropTarget_1_1.done; allContainersFromDropTarget_1_1 = allContainersFromDropTarget_1.next()) {\n var currentContainers = allContainersFromDropTarget_1_1.value;\n if (this.allContainersIntersect(mouseEvent, currentContainers)) {\n mouseOverTarget = true;\n break;\n }\n }\n }\n catch (e_2_1) { e_2 = { error: e_2_1 }; }\n finally {\n try {\n if (allContainersFromDropTarget_1_1 && !allContainersFromDropTarget_1_1.done && (_a = allContainersFromDropTarget_1.return)) _a.call(allContainersFromDropTarget_1);\n }\n finally { if (e_2) throw e_2.error; }\n }\n if (dropTarget.targetContainsSource && !dropTarget.getContainer().contains(this.dragSource.eElement)) {\n return false;\n }\n return mouseOverTarget && dropTarget.isInterestedIn(this.dragSource.type, this.dragSource.eElement);\n };\n DragAndDropService.prototype.findCurrentDropTarget = function (mouseEvent, validDropTargets) {\n var e_3, _a, e_4, _b;\n var len = validDropTargets.length;\n if (len === 0) {\n return null;\n }\n if (len === 1) {\n return validDropTargets[0];\n }\n var eDocument = this.gridOptionsWrapper.getDocument();\n // elementsFromPoint return a list of elements under\n // the mouseEvent sorted from topMost to bottomMost\n var elementStack = eDocument.elementsFromPoint(mouseEvent.clientX, mouseEvent.clientY);\n try {\n // loop over the sorted elementStack to find which dropTarget comes first\n for (var elementStack_1 = __values(elementStack), elementStack_1_1 = elementStack_1.next(); !elementStack_1_1.done; elementStack_1_1 = elementStack_1.next()) {\n var el = elementStack_1_1.value;\n try {\n for (var validDropTargets_1 = (e_4 = void 0, __values(validDropTargets)), validDropTargets_1_1 = validDropTargets_1.next(); !validDropTargets_1_1.done; validDropTargets_1_1 = validDropTargets_1.next()) {\n var dropTarget = validDropTargets_1_1.value;\n var containers = flatten(this.getAllContainersFromDropTarget(dropTarget));\n if (containers.indexOf(el) !== -1) {\n return dropTarget;\n }\n }\n }\n catch (e_4_1) { e_4 = { error: e_4_1 }; }\n finally {\n try {\n if (validDropTargets_1_1 && !validDropTargets_1_1.done && (_b = validDropTargets_1.return)) _b.call(validDropTargets_1);\n }\n finally { if (e_4) throw e_4.error; }\n }\n }\n }\n catch (e_3_1) { e_3 = { error: e_3_1 }; }\n finally {\n try {\n if (elementStack_1_1 && !elementStack_1_1.done && (_a = elementStack_1.return)) _a.call(elementStack_1);\n }\n finally { if (e_3) throw e_3.error; }\n }\n // we should never hit this point of the code because only\n // valid dropTargets should be provided to this method.\n return null;\n };\n DragAndDropService.prototype.enterDragTargetIfExists = function (dropTarget, mouseEvent, hDirection, vDirection, fromNudge) {\n if (!dropTarget) {\n return;\n }\n if (dropTarget.onDragEnter) {\n var dragEnterEvent = this.createDropTargetEvent(dropTarget, mouseEvent, hDirection, vDirection, fromNudge);\n dropTarget.onDragEnter(dragEnterEvent);\n }\n this.setGhostIcon(dropTarget.getIconName ? dropTarget.getIconName() : null);\n };\n DragAndDropService.prototype.leaveLastTargetIfExists = function (mouseEvent, hDirection, vDirection, fromNudge) {\n if (!this.lastDropTarget) {\n return;\n }\n if (this.lastDropTarget.onDragLeave) {\n var dragLeaveEvent = this.createDropTargetEvent(this.lastDropTarget, mouseEvent, hDirection, vDirection, fromNudge);\n this.lastDropTarget.onDragLeave(dragLeaveEvent);\n }\n this.setGhostIcon(null);\n };\n DragAndDropService.prototype.addDropTarget = function (dropTarget) {\n this.dropTargets.push(dropTarget);\n };\n DragAndDropService.prototype.removeDropTarget = function (dropTarget) {\n this.dropTargets = this.dropTargets.filter(function (target) { return target.getContainer() !== dropTarget.getContainer(); });\n };\n DragAndDropService.prototype.hasExternalDropZones = function () {\n return this.dropTargets.some(function (zones) { return zones.external; });\n };\n DragAndDropService.prototype.findExternalZone = function (params) {\n var externalTargets = this.dropTargets.filter(function (target) { return target.external; });\n return externalTargets.find(function (zone) { return zone.getContainer() === params.getContainer(); }) || null;\n };\n DragAndDropService.prototype.getHorizontalDirection = function (event) {\n var clientX = this.eventLastTime && this.eventLastTime.clientX;\n var eClientX = event.clientX;\n if (clientX === eClientX) {\n return null;\n }\n return clientX > eClientX ? HorizontalDirection.Left : HorizontalDirection.Right;\n };\n DragAndDropService.prototype.getVerticalDirection = function (event) {\n var clientY = this.eventLastTime && this.eventLastTime.clientY;\n var eClientY = event.clientY;\n if (clientY === eClientY) {\n return null;\n }\n return clientY > eClientY ? VerticalDirection.Up : VerticalDirection.Down;\n };\n DragAndDropService.prototype.createDropTargetEvent = function (dropTarget, event, hDirection, vDirection, fromNudge) {\n // localise x and y to the target\n var dropZoneTarget = dropTarget.getContainer();\n var rect = dropZoneTarget.getBoundingClientRect();\n var _a = this, api = _a.gridApi, columnApi = _a.columnApi, dragItem = _a.dragItem, dragSource = _a.dragSource;\n var x = event.clientX - rect.left;\n var y = event.clientY - rect.top;\n return { event: event, x: x, y: y, vDirection: vDirection, hDirection: hDirection, dragSource: dragSource, fromNudge: fromNudge, dragItem: dragItem, api: api, columnApi: columnApi, dropZoneTarget: dropZoneTarget };\n };\n DragAndDropService.prototype.positionGhost = function (event) {\n var ghost = this.eGhost;\n if (!ghost) {\n return;\n }\n var ghostRect = ghost.getBoundingClientRect();\n var ghostHeight = ghostRect.height;\n // for some reason, without the '-2', it still overlapped by 1 or 2 pixels, which\n // then brought in scrollbars to the browser. no idea why, but putting in -2 here\n // works around it which is good enough for me.\n var browserWidth = getBodyWidth() - 2;\n var browserHeight = getBodyHeight() - 2;\n var top = event.pageY - (ghostHeight / 2);\n var left = event.pageX - 10;\n var eDocument = this.gridOptionsWrapper.getDocument();\n var win = (eDocument.defaultView || window);\n var windowScrollY = win.pageYOffset || eDocument.documentElement.scrollTop;\n var windowScrollX = win.pageXOffset || eDocument.documentElement.scrollLeft;\n // check ghost is not positioned outside of the browser\n if (browserWidth > 0 && ((left + ghost.clientWidth) > (browserWidth + windowScrollX))) {\n left = browserWidth + windowScrollX - ghost.clientWidth;\n }\n if (left < 0) {\n left = 0;\n }\n if (browserHeight > 0 && ((top + ghost.clientHeight) > (browserHeight + windowScrollY))) {\n top = browserHeight + windowScrollY - ghost.clientHeight;\n }\n if (top < 0) {\n top = 0;\n }\n ghost.style.left = left + \"px\";\n ghost.style.top = top + \"px\";\n };\n DragAndDropService.prototype.removeGhost = function () {\n if (this.eGhost && this.eGhostParent) {\n this.eGhostParent.removeChild(this.eGhost);\n }\n this.eGhost = null;\n };\n DragAndDropService.prototype.createGhost = function () {\n this.eGhost = loadTemplate(DragAndDropService_1.GHOST_TEMPLATE);\n this.mouseEventService.stampTopLevelGridCompWithGridInstance(this.eGhost);\n var theme = this.environment.getTheme().theme;\n if (theme) {\n this.eGhost.classList.add(theme);\n }\n this.eGhostIcon = this.eGhost.querySelector('.ag-dnd-ghost-icon');\n this.setGhostIcon(null);\n var eText = this.eGhost.querySelector('.ag-dnd-ghost-label');\n var dragItemName = this.dragSource.dragItemName;\n if (isFunction(dragItemName)) {\n dragItemName = dragItemName();\n }\n eText.innerHTML = escapeString(dragItemName) || '';\n this.eGhost.style.height = '25px';\n this.eGhost.style.top = '20px';\n this.eGhost.style.left = '20px';\n var eDocument = this.gridOptionsWrapper.getDocument();\n var targetEl = null;\n try {\n targetEl = eDocument.fullscreenElement;\n }\n catch (e) {\n // some environments like SalesForce will throw errors\n // simply by trying to read the fullscreenElement property\n }\n finally {\n if (!targetEl) {\n targetEl = eDocument.querySelector('body');\n }\n }\n this.eGhostParent = targetEl;\n if (!this.eGhostParent) {\n console.warn('AG Grid: could not find document body, it is needed for dragging columns');\n }\n else {\n this.eGhostParent.appendChild(this.eGhost);\n }\n };\n DragAndDropService.prototype.setGhostIcon = function (iconName, shake) {\n if (shake === void 0) { shake = false; }\n clearElement(this.eGhostIcon);\n var eIcon = null;\n if (!iconName) {\n iconName = this.dragSource.defaultIconName || DragAndDropService_1.ICON_NOT_ALLOWED;\n }\n switch (iconName) {\n case DragAndDropService_1.ICON_PINNED:\n eIcon = this.ePinnedIcon;\n break;\n case DragAndDropService_1.ICON_MOVE:\n eIcon = this.eMoveIcon;\n break;\n case DragAndDropService_1.ICON_LEFT:\n eIcon = this.eLeftIcon;\n break;\n case DragAndDropService_1.ICON_RIGHT:\n eIcon = this.eRightIcon;\n break;\n case DragAndDropService_1.ICON_GROUP:\n eIcon = this.eGroupIcon;\n break;\n case DragAndDropService_1.ICON_AGGREGATE:\n eIcon = this.eAggregateIcon;\n break;\n case DragAndDropService_1.ICON_PIVOT:\n eIcon = this.ePivotIcon;\n break;\n case DragAndDropService_1.ICON_NOT_ALLOWED:\n eIcon = this.eDropNotAllowedIcon;\n break;\n case DragAndDropService_1.ICON_HIDE:\n eIcon = this.eHideIcon;\n break;\n }\n this.eGhostIcon.classList.toggle('ag-shake-left-to-right', shake);\n if (eIcon === this.eHideIcon && this.gridOptionsWrapper.isSuppressDragLeaveHidesColumns()) {\n return;\n }\n if (eIcon) {\n this.eGhostIcon.appendChild(eIcon);\n }\n };\n var DragAndDropService_1;\n DragAndDropService.ICON_PINNED = 'pinned';\n DragAndDropService.ICON_MOVE = 'move';\n DragAndDropService.ICON_LEFT = 'left';\n DragAndDropService.ICON_RIGHT = 'right';\n DragAndDropService.ICON_GROUP = 'group';\n DragAndDropService.ICON_AGGREGATE = 'aggregate';\n DragAndDropService.ICON_PIVOT = 'pivot';\n DragAndDropService.ICON_NOT_ALLOWED = 'notAllowed';\n DragAndDropService.ICON_HIDE = 'hide';\n DragAndDropService.GHOST_TEMPLATE = \"
\\n \\n
\\n
\";\n __decorate([\n Autowired('dragService')\n ], DragAndDropService.prototype, \"dragService\", void 0);\n __decorate([\n Autowired('mouseEventService')\n ], DragAndDropService.prototype, \"mouseEventService\", void 0);\n __decorate([\n Autowired('environment')\n ], DragAndDropService.prototype, \"environment\", void 0);\n __decorate([\n Autowired('columnApi')\n ], DragAndDropService.prototype, \"columnApi\", void 0);\n __decorate([\n Autowired('gridApi')\n ], DragAndDropService.prototype, \"gridApi\", void 0);\n __decorate([\n PostConstruct\n ], DragAndDropService.prototype, \"init\", null);\n __decorate([\n PreDestroy\n ], DragAndDropService.prototype, \"clearDragSourceParamsList\", null);\n DragAndDropService = DragAndDropService_1 = __decorate([\n Bean('dragAndDropService')\n ], DragAndDropService);\n return DragAndDropService;\n}(BeanStub));\nexport { DragAndDropService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from \"../../widgets/component\";\nimport { Autowired, PostConstruct, PreDestroy } from \"../../context/context\";\nimport { RowNode } from \"../../entities/rowNode\";\nimport { DragSourceType } from \"../../dragAndDrop/dragAndDropService\";\nimport { Events } from \"../../eventKeys\";\nimport { BeanStub } from \"../../context/beanStub\";\nimport { createIconNoSpan } from \"../../utils/icon\";\nimport { doOnce, isFunction } from \"../../utils/function\";\nvar RowDragComp = /** @class */ (function (_super) {\n __extends(RowDragComp, _super);\n function RowDragComp(cellValueFn, rowNode, column, customGui, dragStartPixels, suppressVisibilityChange) {\n var _this = _super.call(this) || this;\n _this.cellValueFn = cellValueFn;\n _this.rowNode = rowNode;\n _this.column = column;\n _this.customGui = customGui;\n _this.dragStartPixels = dragStartPixels;\n _this.suppressVisibilityChange = suppressVisibilityChange;\n _this.dragSource = null;\n return _this;\n }\n RowDragComp.prototype.isCustomGui = function () {\n return this.customGui != null;\n };\n RowDragComp.prototype.postConstruct = function () {\n if (!this.customGui) {\n this.setTemplate(/* html */ \"
\");\n this.getGui().appendChild(createIconNoSpan('rowDrag', this.beans.gridOptionsWrapper, null));\n this.addDragSource();\n }\n else {\n this.setDragElement(this.customGui, this.dragStartPixels);\n }\n this.checkCompatibility();\n if (!this.suppressVisibilityChange) {\n var strategy = this.beans.gridOptionsWrapper.isRowDragManaged() ?\n new ManagedVisibilityStrategy(this, this.beans, this.rowNode, this.column) :\n new NonManagedVisibilityStrategy(this, this.beans, this.rowNode, this.column);\n this.createManagedBean(strategy, this.beans.context);\n }\n };\n RowDragComp.prototype.setDragElement = function (dragElement, dragStartPixels) {\n this.setTemplateFromElement(dragElement);\n this.addDragSource(dragStartPixels);\n };\n RowDragComp.prototype.getSelectedNodes = function () {\n var isRowDragMultiRow = this.beans.gridOptionsWrapper.isRowDragMultiRow();\n if (!isRowDragMultiRow) {\n return [this.rowNode];\n }\n var selection = this.beans.selectionService.getSelectedNodes();\n return selection.indexOf(this.rowNode) !== -1 ? selection : [this.rowNode];\n };\n // returns true if all compatibility items work out\n RowDragComp.prototype.checkCompatibility = function () {\n var managed = this.beans.gridOptionsWrapper.isRowDragManaged();\n var treeData = this.beans.gridOptionsWrapper.isTreeData();\n if (treeData && managed) {\n doOnce(function () {\n return console.warn('AG Grid: If using row drag with tree data, you cannot have rowDragManaged=true');\n }, 'RowDragComp.managedAndTreeData');\n }\n };\n RowDragComp.prototype.getDragItem = function () {\n return {\n rowNode: this.rowNode,\n rowNodes: this.getSelectedNodes(),\n columns: this.column ? [this.column] : undefined,\n defaultTextValue: this.cellValueFn(),\n };\n };\n RowDragComp.prototype.addDragSource = function (dragStartPixels) {\n var _this = this;\n if (dragStartPixels === void 0) { dragStartPixels = 4; }\n // if this is changing the drag element, delete the previous dragSource\n if (this.dragSource) {\n this.removeDragSource();\n }\n var rowDragText = this.column && this.column.getColDef().rowDragText;\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n this.dragSource = {\n type: DragSourceType.RowDrag,\n eElement: this.getGui(),\n dragItemName: function () {\n var _a;\n var dragItem = _this.getDragItem();\n var dragItemCount = ((_a = dragItem.rowNodes) === null || _a === void 0 ? void 0 : _a.length) || 1;\n if (rowDragText) {\n return rowDragText(dragItem, dragItemCount);\n }\n return dragItemCount === 1 ? _this.cellValueFn() : dragItemCount + \" \" + translate('rowDragRows', 'rows');\n },\n getDragItem: function () { return _this.getDragItem(); },\n dragStartPixels: dragStartPixels,\n dragSourceDomDataKey: this.beans.gridOptionsWrapper.getDomDataKey()\n };\n this.beans.dragAndDropService.addDragSource(this.dragSource, true);\n };\n RowDragComp.prototype.removeDragSource = function () {\n if (this.dragSource) {\n this.beans.dragAndDropService.removeDragSource(this.dragSource);\n }\n this.dragSource = null;\n };\n __decorate([\n Autowired('beans')\n ], RowDragComp.prototype, \"beans\", void 0);\n __decorate([\n PostConstruct\n ], RowDragComp.prototype, \"postConstruct\", null);\n __decorate([\n PreDestroy\n ], RowDragComp.prototype, \"removeDragSource\", null);\n return RowDragComp;\n}(Component));\nexport { RowDragComp };\nvar VisibilityStrategy = /** @class */ (function (_super) {\n __extends(VisibilityStrategy, _super);\n function VisibilityStrategy(parent, rowNode, column) {\n var _this = _super.call(this) || this;\n _this.parent = parent;\n _this.rowNode = rowNode;\n _this.column = column;\n return _this;\n }\n VisibilityStrategy.prototype.setDisplayedOrVisible = function (neverDisplayed) {\n if (neverDisplayed) {\n this.parent.setDisplayed(false);\n }\n else {\n var shown = true;\n var isShownSometimes = false;\n if (this.column) {\n shown = this.column.isRowDrag(this.rowNode) || this.parent.isCustomGui();\n isShownSometimes = isFunction(this.column.getColDef().rowDrag);\n }\n // if shown sometimes, them some rows can have drag handle while other don't,\n // so we use setVisible to keep the handles horizontally aligned (as setVisible\n // keeps the empty space, whereas setDisplayed looses the space)\n if (isShownSometimes) {\n this.parent.setDisplayed(true);\n this.parent.setVisible(shown);\n }\n else {\n this.parent.setDisplayed(shown);\n this.parent.setVisible(true);\n }\n }\n };\n return VisibilityStrategy;\n}(BeanStub));\n// when non managed, the visibility depends on suppressRowDrag property only\nvar NonManagedVisibilityStrategy = /** @class */ (function (_super) {\n __extends(NonManagedVisibilityStrategy, _super);\n function NonManagedVisibilityStrategy(parent, beans, rowNode, column) {\n var _this = _super.call(this, parent, rowNode, column) || this;\n _this.beans = beans;\n return _this;\n }\n NonManagedVisibilityStrategy.prototype.postConstruct = function () {\n this.addManagedListener(this.beans.gridOptionsWrapper, 'suppressRowDrag', this.onSuppressRowDrag.bind(this));\n // in case data changes, then we need to update visibility of drag item\n this.addManagedListener(this.rowNode, RowNode.EVENT_DATA_CHANGED, this.workOutVisibility.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_CELL_CHANGED, this.workOutVisibility.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_CELL_CHANGED, this.workOutVisibility.bind(this));\n this.addManagedListener(this.beans.eventService, Events.EVENT_NEW_COLUMNS_LOADED, this.workOutVisibility.bind(this));\n this.workOutVisibility();\n };\n NonManagedVisibilityStrategy.prototype.onSuppressRowDrag = function () {\n this.workOutVisibility();\n };\n NonManagedVisibilityStrategy.prototype.workOutVisibility = function () {\n // only show the drag if both sort and filter are not present\n var neverDisplayed = this.beans.gridOptionsWrapper.isSuppressRowDrag();\n this.setDisplayedOrVisible(neverDisplayed);\n };\n __decorate([\n PostConstruct\n ], NonManagedVisibilityStrategy.prototype, \"postConstruct\", null);\n return NonManagedVisibilityStrategy;\n}(VisibilityStrategy));\n// when managed, the visibility depends on sort, filter and row group, as well as suppressRowDrag property\nvar ManagedVisibilityStrategy = /** @class */ (function (_super) {\n __extends(ManagedVisibilityStrategy, _super);\n function ManagedVisibilityStrategy(parent, beans, rowNode, column) {\n var _this = _super.call(this, parent, rowNode, column) || this;\n _this.beans = beans;\n return _this;\n }\n ManagedVisibilityStrategy.prototype.postConstruct = function () {\n // we do not show the component if sort, filter or grouping is active\n this.addManagedListener(this.beans.eventService, Events.EVENT_SORT_CHANGED, this.workOutVisibility.bind(this));\n this.addManagedListener(this.beans.eventService, Events.EVENT_FILTER_CHANGED, this.workOutVisibility.bind(this));\n this.addManagedListener(this.beans.eventService, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, this.workOutVisibility.bind(this));\n this.addManagedListener(this.beans.eventService, Events.EVENT_NEW_COLUMNS_LOADED, this.workOutVisibility.bind(this));\n // in case data changes, then we need to update visibility of drag item\n this.addManagedListener(this.rowNode, RowNode.EVENT_DATA_CHANGED, this.workOutVisibility.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_CELL_CHANGED, this.workOutVisibility.bind(this));\n this.addManagedListener(this.beans.gridOptionsWrapper, 'suppressRowDrag', this.onSuppressRowDrag.bind(this));\n this.workOutVisibility();\n };\n ManagedVisibilityStrategy.prototype.onSuppressRowDrag = function () {\n this.workOutVisibility();\n };\n ManagedVisibilityStrategy.prototype.workOutVisibility = function () {\n // only show the drag if both sort and filter are not present\n var gridBodyCon = this.beans.ctrlsService.getGridBodyCtrl();\n var rowDragFeature = gridBodyCon.getRowDragFeature();\n var shouldPreventRowMove = rowDragFeature && rowDragFeature.shouldPreventRowMove();\n var suppressRowDrag = this.beans.gridOptionsWrapper.isSuppressRowDrag();\n var hasExternalDropZones = this.beans.dragAndDropService.hasExternalDropZones();\n var neverDisplayed = (shouldPreventRowMove && !hasExternalDropZones) || suppressRowDrag;\n this.setDisplayedOrVisible(neverDisplayed);\n };\n __decorate([\n PostConstruct\n ], ManagedVisibilityStrategy.prototype, \"postConstruct\", null);\n return ManagedVisibilityStrategy;\n}(VisibilityStrategy));\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Constants } from \"../../constants/constants\";\nimport { KeyCode } from \"../../constants/keyCode\";\nimport { BeanStub } from \"../../context/beanStub\";\nimport { Autowired } from \"../../context/context\";\nimport { RowNode } from \"../../entities/rowNode\";\nimport { isElementInEventPath, isStopPropagationForAgGrid, stopPropagationForAgGrid } from \"../../utils/event\";\nimport { removeAriaExpanded, setAriaExpanded } from \"../../utils/aria\";\nimport { doOnce } from \"../../utils/function\";\nimport { missing } from \"../../utils/generic\";\nimport { createIconNoSpan } from \"../../utils/icon\";\nimport { cloneObject } from \"../../utils/object\";\nimport { CheckboxSelectionComponent } from \"../checkboxSelectionComponent\";\nimport { RowDragComp } from \"../row/rowDragComp\";\nvar GroupCellRendererCtrl = /** @class */ (function (_super) {\n __extends(GroupCellRendererCtrl, _super);\n function GroupCellRendererCtrl() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n GroupCellRendererCtrl.prototype.init = function (comp, eGui, eCheckbox, eExpanded, eContracted, compClass, params) {\n this.params = params;\n this.eGui = eGui;\n this.eCheckbox = eCheckbox;\n this.eExpanded = eExpanded;\n this.eContracted = eContracted;\n this.comp = comp;\n this.compClass = compClass;\n var topLevelFooter = this.isTopLevelFooter();\n var embeddedRowMismatch = this.isEmbeddedRowMismatch();\n // This allows for empty strings to appear as groups since\n // it will only return for null or undefined.\n var nullValue = params.value == null;\n var skipCell = false;\n // if the groupCellRenderer is inside of a footer and groupHideOpenParents is true\n // we should only display the groupCellRenderer if the current column is the rowGroupedColumn\n if (this.gridOptionsWrapper.isGroupIncludeFooter() && this.gridOptionsWrapper.isGroupHideOpenParents()) {\n var node = params.node;\n if (node.footer) {\n var showRowGroup = params.colDef && params.colDef.showRowGroup;\n var rowGroupColumnId = node.rowGroupColumn && node.rowGroupColumn.getColId();\n skipCell = showRowGroup !== rowGroupColumnId;\n }\n }\n this.cellIsBlank = topLevelFooter ? false : (embeddedRowMismatch || nullValue || skipCell);\n if (this.cellIsBlank) {\n return;\n }\n this.setupShowingValueForOpenedParent();\n this.findDisplayedGroupNode();\n this.addFullWidthRowDraggerIfNeeded();\n this.addExpandAndContract();\n this.addCheckboxIfNeeded();\n this.addValueElement();\n this.setupIndent();\n this.refreshAriaExpanded();\n };\n GroupCellRendererCtrl.prototype.destroy = function () {\n _super.prototype.destroy.call(this);\n // property cleanup to avoid memory leaks\n this.expandListener = null;\n };\n GroupCellRendererCtrl.prototype.refreshAriaExpanded = function () {\n var _a = this.params, node = _a.node, eParentOfValue = _a.eParentOfValue;\n if (this.expandListener) {\n this.expandListener = this.expandListener();\n }\n if (!this.isExpandable()) {\n removeAriaExpanded(eParentOfValue);\n return;\n }\n var listener = function () {\n // for react, we don't use JSX, as setting attributes via jsx is slower\n setAriaExpanded(eParentOfValue, !!node.expanded);\n };\n this.expandListener = this.addManagedListener(node, RowNode.EVENT_EXPANDED_CHANGED, listener) || null;\n listener();\n };\n GroupCellRendererCtrl.prototype.isTopLevelFooter = function () {\n if (!this.gridOptionsWrapper.isGroupIncludeTotalFooter()) {\n return false;\n }\n if (this.params.value != null || this.params.node.level != -1) {\n return false;\n }\n // at this point, we know it's the root node and there is no value present, so it's a footer cell.\n // the only thing to work out is if we are displaying groups across multiple\n // columns (groupMultiAutoColumn=true), we only want 'total' to appear in the first column.\n var colDef = this.params.colDef;\n var doingFullWidth = colDef == null;\n if (doingFullWidth) {\n return true;\n }\n if (colDef.showRowGroup === true) {\n return true;\n }\n var rowGroupCols = this.columnModel.getRowGroupColumns();\n // this is a sanity check, rowGroupCols should always be present\n if (!rowGroupCols || rowGroupCols.length === 0) {\n return true;\n }\n var firstRowGroupCol = rowGroupCols[0];\n return firstRowGroupCol.getId() === colDef.showRowGroup;\n };\n // if we are doing embedded full width rows, we only show the renderer when\n // in the body, or if pinning in the pinned section, or if pinning and RTL,\n // in the right section. otherwise we would have the cell repeated in each section.\n GroupCellRendererCtrl.prototype.isEmbeddedRowMismatch = function () {\n if (!this.params.fullWidth || !this.gridOptionsWrapper.isEmbedFullWidthRows()) {\n return false;\n }\n var pinnedLeftCell = this.params.pinned === Constants.PINNED_LEFT;\n var pinnedRightCell = this.params.pinned === Constants.PINNED_RIGHT;\n var bodyCell = !pinnedLeftCell && !pinnedRightCell;\n if (this.gridOptionsWrapper.isEnableRtl()) {\n if (this.columnModel.isPinningLeft()) {\n return !pinnedRightCell;\n }\n return !bodyCell;\n }\n if (this.columnModel.isPinningLeft()) {\n return !pinnedLeftCell;\n }\n return !bodyCell;\n };\n GroupCellRendererCtrl.prototype.findDisplayedGroupNode = function () {\n var column = this.params.column;\n var rowNode = this.params.node;\n if (this.showingValueForOpenedParent) {\n var pointer = rowNode.parent;\n while (pointer != null) {\n if (pointer.rowGroupColumn && column.isRowGroupDisplayed(pointer.rowGroupColumn.getId())) {\n this.displayedGroupNode = pointer;\n break;\n }\n pointer = pointer.parent;\n }\n }\n // if we didn't find a displayed group, set it to the row node\n if (missing(this.displayedGroupNode)) {\n this.displayedGroupNode = rowNode;\n }\n };\n GroupCellRendererCtrl.prototype.setupShowingValueForOpenedParent = function () {\n // note - this code depends on sortService.updateGroupDataForHiddenOpenParents, where group data\n // is updated to reflect the dragged down parents\n var rowNode = this.params.node;\n var column = this.params.column;\n if (!this.gridOptionsWrapper.isGroupHideOpenParents()) {\n this.showingValueForOpenedParent = false;\n return;\n }\n // hideOpenParents means rowNode.groupData can have data for the group this column is displaying, even though\n // this rowNode isn't grouping by the column we are displaying\n // if no groupData at all, we are not showing a parent value\n if (!rowNode.groupData) {\n this.showingValueForOpenedParent = false;\n return;\n }\n // this is the normal case, in that we are showing a group for which this column is configured. note that\n // this means the Row Group is closed (if it was open, we would not be displaying it)\n var showingGroupNode = rowNode.rowGroupColumn != null;\n if (showingGroupNode) {\n var keyOfGroupingColumn = rowNode.rowGroupColumn.getId();\n var configuredToShowThisGroupLevel = column.isRowGroupDisplayed(keyOfGroupingColumn);\n // if showing group as normal, we didn't take group info from parent\n if (configuredToShowThisGroupLevel) {\n this.showingValueForOpenedParent = false;\n return;\n }\n }\n // see if we are showing a Group Value for the Displayed Group. if we are showing a group value, and this Row Node\n // is not grouping by this Displayed Group, we must of gotten the value from a parent node\n var valPresent = rowNode.groupData[column.getId()] != null;\n this.showingValueForOpenedParent = valPresent;\n };\n GroupCellRendererCtrl.prototype.addValueElement = function () {\n if (this.displayedGroupNode.footer) {\n this.addFooterValue();\n }\n else {\n this.addGroupValue();\n this.addChildCount();\n }\n };\n GroupCellRendererCtrl.prototype.addGroupValue = function () {\n // we try and use the cellRenderer of the column used for the grouping if we can\n var paramsAdjusted = this.adjustParamsWithDetailsFromRelatedColumn();\n var innerCompDetails = this.getInnerCompDetails(paramsAdjusted);\n var valueFormatted = paramsAdjusted.valueFormatted, value = paramsAdjusted.value;\n var valueWhenNoRenderer = valueFormatted != null ? valueFormatted : value;\n this.comp.setInnerRenderer(innerCompDetails, valueWhenNoRenderer);\n };\n GroupCellRendererCtrl.prototype.adjustParamsWithDetailsFromRelatedColumn = function () {\n var relatedColumn = this.displayedGroupNode.rowGroupColumn;\n var column = this.params.column;\n if (!relatedColumn) {\n return this.params;\n }\n var notFullWidth = column != null;\n if (notFullWidth) {\n var showingThisRowGroup = column.isRowGroupDisplayed(relatedColumn.getId());\n if (!showingThisRowGroup) {\n return this.params;\n }\n }\n var params = this.params;\n var _a = this.params, value = _a.value, node = _a.node;\n var valueFormatted = this.valueFormatterService.formatValue(relatedColumn, node, value);\n // we don't update the original params, as they could of come through React,\n // as react has RowGroupCellRenderer, which means the params could be props which\n // would be read only\n var paramsAdjusted = __assign(__assign({}, params), { valueFormatted: valueFormatted });\n return paramsAdjusted;\n };\n GroupCellRendererCtrl.prototype.addFooterValue = function () {\n var footerValueGetter = this.params.footerValueGetter;\n var footerValue = '';\n if (footerValueGetter) {\n // params is same as we were given, except we set the value as the item to display\n var paramsClone = cloneObject(this.params);\n paramsClone.value = this.params.value;\n if (typeof footerValueGetter === 'function') {\n footerValue = footerValueGetter(paramsClone);\n }\n else if (typeof footerValueGetter === 'string') {\n footerValue = this.expressionService.evaluate(footerValueGetter, paramsClone);\n }\n else {\n console.warn('AG Grid: footerValueGetter should be either a function or a string (expression)');\n }\n }\n else {\n footerValue = 'Total ' + (this.params.value != null ? this.params.value : '');\n }\n var innerCompDetails = this.getInnerCompDetails(this.params);\n this.comp.setInnerRenderer(innerCompDetails, footerValue);\n };\n GroupCellRendererCtrl.prototype.getInnerCompDetails = function (params) {\n var _this = this;\n // for full width rows, we don't do any of the below\n if (params.fullWidth) {\n return this.userComponentFactory.getFullWidthGroupRowInnerCellRenderer(this.gridOptions.groupRowRendererParams, params);\n }\n // when grouping, the normal case is we use the cell renderer of the grouped column. eg if grouping by country\n // and then rating, we will use the country cell renderer for each country group row and likewise the rating\n // cell renderer for each rating group row.\n //\n // however if the user has innerCellRenderer defined, this gets preference and we don't use cell renderers\n // of the grouped columns.\n //\n // so we check and use in the following order:\n //\n // 1) thisColDef.cellRendererParams.innerRenderer of the column showing the groups (eg auto group column)\n // 2) groupedColDef.cellRenderer of the grouped column\n // 3) groupedColDef.cellRendererParams.innerRenderer\n // we check if cell renderer provided for the group cell renderer, eg colDef.cellRendererParams.innerRenderer\n var innerCompDetails = this.userComponentFactory\n .getInnerRendererDetails(params, params);\n // avoid using GroupCellRenderer again, otherwise stack overflow, as we insert same renderer again and again.\n // this covers off chance user is grouping by a column that is also configured with GroupCellRenderer\n var isGroupRowRenderer = function (details) { return details && details.componentClass == _this.compClass; };\n if (innerCompDetails && !isGroupRowRenderer(innerCompDetails)) {\n // use the renderer defined in cellRendererParams.innerRenderer\n return innerCompDetails;\n }\n var relatedColumn = this.displayedGroupNode.rowGroupColumn;\n var relatedColDef = relatedColumn ? relatedColumn.getColDef() : undefined;\n if (!relatedColDef) {\n return;\n }\n // otherwise see if we can use the cellRenderer of the column we are grouping by\n var relatedCompDetails = this.userComponentFactory\n .getCellRendererDetails(relatedColDef, params);\n if (relatedCompDetails && !isGroupRowRenderer(relatedCompDetails)) {\n // Only if the original column is using a specific renderer, it it is a using a DEFAULT one ignore it\n return relatedCompDetails;\n }\n if (isGroupRowRenderer(relatedCompDetails) &&\n relatedColDef.cellRendererParams &&\n relatedColDef.cellRendererParams.innerRenderer) {\n // edge case - this comes from a column which has been grouped dynamically, that has a renderer 'group'\n // and has an inner cell renderer\n var res = this.userComponentFactory.getInnerRendererDetails(relatedColDef.cellRendererParams, params);\n return res;\n }\n };\n GroupCellRendererCtrl.prototype.addChildCount = function () {\n // only include the child count if it's included, eg if user doing custom aggregation,\n // then this could be left out, or set to -1, ie no child count\n if (this.params.suppressCount) {\n return;\n }\n this.addManagedListener(this.displayedGroupNode, RowNode.EVENT_ALL_CHILDREN_COUNT_CHANGED, this.updateChildCount.bind(this));\n // filtering changes the child count, so need to cater for it\n this.updateChildCount();\n };\n GroupCellRendererCtrl.prototype.updateChildCount = function () {\n var allChildrenCount = this.displayedGroupNode.allChildrenCount;\n var showingGroupForThisNode = this.isShowRowGroupForThisRow();\n var showCount = showingGroupForThisNode && allChildrenCount != null && allChildrenCount >= 0;\n var countString = showCount ? \"(\" + allChildrenCount + \")\" : \"\";\n this.comp.setChildCount(countString);\n };\n GroupCellRendererCtrl.prototype.isShowRowGroupForThisRow = function () {\n if (this.gridOptionsWrapper.isTreeData()) {\n return true;\n }\n var rowGroupColumn = this.displayedGroupNode.rowGroupColumn;\n if (!rowGroupColumn) {\n return false;\n }\n // column is null for fullWidthRows\n var column = this.params.column;\n var thisColumnIsInterested = column == null || column.isRowGroupDisplayed(rowGroupColumn.getId());\n return thisColumnIsInterested;\n };\n GroupCellRendererCtrl.prototype.addExpandAndContract = function () {\n var params = this.params;\n var eExpandedIcon = createIconNoSpan('groupExpanded', this.gridOptionsWrapper, null);\n var eContractedIcon = createIconNoSpan('groupContracted', this.gridOptionsWrapper, null);\n if (eExpandedIcon) {\n this.eExpanded.appendChild(eExpandedIcon);\n }\n if (eContractedIcon) {\n this.eContracted.appendChild(eContractedIcon);\n }\n var eGroupCell = params.eGridCell;\n // if editing groups, then double click is to start editing\n if (!this.gridOptionsWrapper.isEnableGroupEdit() && this.isExpandable() && !params.suppressDoubleClickExpand) {\n this.addManagedListener(eGroupCell, 'dblclick', this.onCellDblClicked.bind(this));\n }\n this.addManagedListener(this.eExpanded, 'click', this.onExpandClicked.bind(this));\n this.addManagedListener(this.eContracted, 'click', this.onExpandClicked.bind(this));\n // expand / contract as the user hits enter\n this.addManagedListener(eGroupCell, 'keydown', this.onKeyDown.bind(this));\n this.addManagedListener(params.node, RowNode.EVENT_EXPANDED_CHANGED, this.showExpandAndContractIcons.bind(this));\n this.showExpandAndContractIcons();\n // because we don't show the expand / contract when there are no children, we need to check every time\n // the number of children change.\n var expandableChangedListener = this.onRowNodeIsExpandableChanged.bind(this);\n this.addManagedListener(this.displayedGroupNode, RowNode.EVENT_ALL_CHILDREN_COUNT_CHANGED, expandableChangedListener);\n this.addManagedListener(this.displayedGroupNode, RowNode.EVENT_MASTER_CHANGED, expandableChangedListener);\n this.addManagedListener(this.displayedGroupNode, RowNode.EVENT_GROUP_CHANGED, expandableChangedListener);\n this.addManagedListener(this.displayedGroupNode, RowNode.EVENT_HAS_CHILDREN_CHANGED, expandableChangedListener);\n };\n GroupCellRendererCtrl.prototype.onExpandClicked = function (mouseEvent) {\n if (isStopPropagationForAgGrid(mouseEvent)) {\n return;\n }\n // so if we expand a node, it does not also get selected.\n stopPropagationForAgGrid(mouseEvent);\n this.onExpandOrContract(mouseEvent);\n };\n GroupCellRendererCtrl.prototype.onExpandOrContract = function (e) {\n // must use the displayedGroup, so if data was dragged down, we expand the parent, not this row\n var rowNode = this.displayedGroupNode;\n var nextExpandState = !rowNode.expanded;\n if (!nextExpandState && rowNode.sticky) {\n this.scrollToStickyNode(rowNode);\n }\n rowNode.setExpanded(nextExpandState, e);\n };\n GroupCellRendererCtrl.prototype.scrollToStickyNode = function (rowNode) {\n var gridBodyCtrl = this.ctrlsService.getGridBodyCtrl();\n var scrollFeature = gridBodyCtrl.getScrollFeature();\n scrollFeature.setVerticalScrollPosition(rowNode.rowTop - rowNode.stickyRowTop);\n };\n GroupCellRendererCtrl.prototype.isExpandable = function () {\n if (this.showingValueForOpenedParent) {\n return true;\n }\n var rowNode = this.displayedGroupNode;\n var reducedLeafNode = this.columnModel.isPivotMode() && rowNode.leafGroup;\n var expandableGroup = rowNode.isExpandable() && !rowNode.footer && !reducedLeafNode;\n if (!expandableGroup) {\n return false;\n }\n // column is null for fullWidthRows\n var column = this.params.column;\n var displayingForOneColumnOnly = column != null && typeof column.getColDef().showRowGroup === 'string';\n if (displayingForOneColumnOnly) {\n var showing = this.isShowRowGroupForThisRow();\n return showing;\n }\n return true;\n };\n GroupCellRendererCtrl.prototype.showExpandAndContractIcons = function () {\n var _a = this, params = _a.params, displayedGroup = _a.displayedGroupNode, columnModel = _a.columnModel;\n var node = params.node;\n var isExpandable = this.isExpandable();\n if (isExpandable) {\n // if expandable, show one based on expand state.\n // if we were dragged down, means our parent is always expanded\n var expanded = this.showingValueForOpenedParent ? true : node.expanded;\n this.comp.setExpandedDisplayed(expanded);\n this.comp.setContractedDisplayed(!expanded);\n }\n else {\n // it not expandable, show neither\n this.comp.setExpandedDisplayed(false);\n this.comp.setContractedDisplayed(false);\n }\n // compensation padding for leaf nodes, so there is blank space instead of the expand icon\n var pivotMode = columnModel.isPivotMode();\n var pivotModeAndLeafGroup = pivotMode && displayedGroup.leafGroup;\n var addExpandableCss = isExpandable && !pivotModeAndLeafGroup;\n var isTotalFooterNode = node.footer && node.level === -1;\n this.comp.addOrRemoveCssClass('ag-cell-expandable', addExpandableCss);\n this.comp.addOrRemoveCssClass('ag-row-group', addExpandableCss);\n if (pivotMode) {\n this.comp.addOrRemoveCssClass('ag-pivot-leaf-group', pivotModeAndLeafGroup);\n }\n else if (!isTotalFooterNode) {\n this.comp.addOrRemoveCssClass('ag-row-group-leaf-indent', !addExpandableCss);\n }\n };\n GroupCellRendererCtrl.prototype.onRowNodeIsExpandableChanged = function () {\n // maybe if no children now, we should hide the expand / contract icons\n this.showExpandAndContractIcons();\n // if we have no children, this impacts the indent\n this.setIndent();\n this.refreshAriaExpanded();\n };\n GroupCellRendererCtrl.prototype.setupIndent = function () {\n // only do this if an indent - as this overwrites the padding that\n // the theme set, which will make things look 'not aligned' for the\n // first group level.\n var node = this.params.node;\n var suppressPadding = this.params.suppressPadding;\n if (!suppressPadding) {\n this.addManagedListener(node, RowNode.EVENT_UI_LEVEL_CHANGED, this.setIndent.bind(this));\n this.setIndent();\n }\n };\n GroupCellRendererCtrl.prototype.setIndent = function () {\n if (this.gridOptionsWrapper.isGroupHideOpenParents()) {\n return;\n }\n var params = this.params;\n var rowNode = params.node;\n // if we are only showing one group column, we don't want to be indenting based on level\n var fullWithRow = !!params.colDef;\n var treeData = this.gridOptionsWrapper.isTreeData();\n var manyDimensionThisColumn = !fullWithRow || treeData || params.colDef.showRowGroup === true;\n var paddingCount = manyDimensionThisColumn ? rowNode.uiLevel : 0;\n var userProvidedPaddingPixelsTheDeprecatedWay = params.padding >= 0;\n if (userProvidedPaddingPixelsTheDeprecatedWay) {\n doOnce(function () { return console.warn('AG Grid: cellRendererParams.padding no longer works, it was deprecated in since v14.2 and removed in v26, configuring padding for groupCellRenderer should be done with Sass variables and themes. Please see the AG Grid documentation page for Themes, in particular the property $row-group-indent-size.'); }, 'groupCellRenderer->doDeprecatedWay');\n }\n if (this.indentClass) {\n this.comp.addOrRemoveCssClass(this.indentClass, false);\n }\n this.indentClass = 'ag-row-group-indent-' + paddingCount;\n this.comp.addOrRemoveCssClass(this.indentClass, true);\n };\n GroupCellRendererCtrl.prototype.addFullWidthRowDraggerIfNeeded = function () {\n var _this = this;\n if (!this.params.fullWidth || !this.params.rowDrag) {\n return;\n }\n var rowDragComp = new RowDragComp(function () { return _this.params.value; }, this.params.node);\n this.createManagedBean(rowDragComp, this.context);\n this.eGui.insertAdjacentElement('afterbegin', rowDragComp.getGui());\n };\n GroupCellRendererCtrl.prototype.isUserWantsSelected = function () {\n var paramsCheckbox = this.params.checkbox;\n // if a function, we always return true as change detection can show or hide the checkbox.\n return typeof paramsCheckbox === 'function' || paramsCheckbox === true;\n };\n GroupCellRendererCtrl.prototype.addCheckboxIfNeeded = function () {\n var _this = this;\n var rowNode = this.displayedGroupNode;\n var checkboxNeeded = this.isUserWantsSelected() &&\n // footers cannot be selected\n !rowNode.footer &&\n // pinned rows cannot be selected\n !rowNode.rowPinned &&\n // details cannot be selected\n !rowNode.detail;\n if (checkboxNeeded) {\n var cbSelectionComponent_1 = new CheckboxSelectionComponent();\n this.getContext().createBean(cbSelectionComponent_1);\n cbSelectionComponent_1.init({\n rowNode: rowNode,\n column: this.params.column,\n overrides: {\n isVisible: this.params.checkbox,\n callbackParams: this.params,\n removeHidden: true,\n },\n });\n this.eCheckbox.appendChild(cbSelectionComponent_1.getGui());\n this.addDestroyFunc(function () { return _this.getContext().destroyBean(cbSelectionComponent_1); });\n }\n this.comp.setCheckboxVisible(checkboxNeeded);\n };\n GroupCellRendererCtrl.prototype.onKeyDown = function (event) {\n var enterKeyPressed = event.key === KeyCode.ENTER;\n if (!enterKeyPressed || this.params.suppressEnterExpand) {\n return;\n }\n var cellEditable = this.params.column && this.params.column.isCellEditable(this.params.node);\n if (cellEditable) {\n return;\n }\n this.onExpandOrContract(event);\n };\n GroupCellRendererCtrl.prototype.onCellDblClicked = function (mouseEvent) {\n if (isStopPropagationForAgGrid(mouseEvent)) {\n return;\n }\n // we want to avoid acting on double click events on the expand / contract icon,\n // as that icons already has expand / collapse functionality on it. otherwise if\n // the icon was double clicked, we would get 'click', 'click', 'dblclick' which\n // is open->close->open, however double click should be open->close only.\n var targetIsExpandIcon = isElementInEventPath(this.eExpanded, mouseEvent)\n || isElementInEventPath(this.eContracted, mouseEvent);\n if (!targetIsExpandIcon) {\n this.onExpandOrContract(mouseEvent);\n }\n };\n __decorate([\n Autowired('expressionService')\n ], GroupCellRendererCtrl.prototype, \"expressionService\", void 0);\n __decorate([\n Autowired('valueFormatterService')\n ], GroupCellRendererCtrl.prototype, \"valueFormatterService\", void 0);\n __decorate([\n Autowired('columnModel')\n ], GroupCellRendererCtrl.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('userComponentFactory')\n ], GroupCellRendererCtrl.prototype, \"userComponentFactory\", void 0);\n __decorate([\n Autowired('gridOptions')\n ], GroupCellRendererCtrl.prototype, \"gridOptions\", void 0);\n __decorate([\n Autowired(\"ctrlsService\")\n ], GroupCellRendererCtrl.prototype, \"ctrlsService\", void 0);\n return GroupCellRendererCtrl;\n}(BeanStub));\nexport { GroupCellRendererCtrl };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { setAriaRole } from \"../../utils/aria\";\nimport { setDisplayed } from \"../../utils/dom\";\nimport { Component } from \"../../widgets/component\";\nimport { RefSelector } from \"../../widgets/componentAnnotations\";\nimport { GroupCellRendererCtrl } from \"./groupCellRendererCtrl\";\nvar GroupCellRenderer = /** @class */ (function (_super) {\n __extends(GroupCellRenderer, _super);\n function GroupCellRenderer() {\n return _super.call(this, GroupCellRenderer.TEMPLATE) || this;\n }\n GroupCellRenderer.prototype.init = function (params) {\n var _this = this;\n var compProxy = {\n setInnerRenderer: function (compDetails, valueToDisplay) { return _this.setRenderDetails(compDetails, valueToDisplay); },\n setChildCount: function (count) { return _this.eChildCount.innerHTML = count; },\n addOrRemoveCssClass: function (cssClass, value) { return _this.addOrRemoveCssClass(cssClass, value); },\n setContractedDisplayed: function (expanded) { return setDisplayed(_this.eContracted, expanded); },\n setExpandedDisplayed: function (expanded) { return setDisplayed(_this.eExpanded, expanded); },\n setCheckboxVisible: function (visible) { return _this.eCheckbox.classList.toggle('ag-invisible', !visible); }\n };\n var ctrl = this.createManagedBean(new GroupCellRendererCtrl());\n var fullWidth = !params.colDef;\n var eGui = this.getGui();\n ctrl.init(compProxy, eGui, this.eCheckbox, this.eExpanded, this.eContracted, this.constructor, params);\n if (fullWidth) {\n setAriaRole(eGui, 'gridcell');\n }\n };\n GroupCellRenderer.prototype.setRenderDetails = function (compDetails, valueToDisplay) {\n var _this = this;\n if (compDetails) {\n var componentPromise = compDetails.newAgStackInstance();\n if (!componentPromise) {\n return;\n }\n componentPromise.then(function (comp) {\n if (!comp) {\n return;\n }\n var destroyComp = function () { return _this.context.destroyBean(comp); };\n if (_this.isAlive()) {\n _this.eValue.appendChild(comp.getGui());\n _this.addDestroyFunc(destroyComp);\n }\n else {\n destroyComp();\n }\n });\n }\n else {\n this.eValue.innerText = valueToDisplay;\n }\n };\n // this is a user component, and IComponent has \"public destroy()\" as part of the interface.\n // so we need to have public here instead of private or protected\n GroupCellRenderer.prototype.destroy = function () {\n this.getContext().destroyBean(this.innerCellRenderer);\n _super.prototype.destroy.call(this);\n };\n GroupCellRenderer.prototype.refresh = function () {\n return false;\n };\n GroupCellRenderer.TEMPLATE = \"\\n \\n \\n \\n \\n \\n \";\n __decorate([\n RefSelector('eExpanded')\n ], GroupCellRenderer.prototype, \"eExpanded\", void 0);\n __decorate([\n RefSelector('eContracted')\n ], GroupCellRenderer.prototype, \"eContracted\", void 0);\n __decorate([\n RefSelector('eCheckbox')\n ], GroupCellRenderer.prototype, \"eCheckbox\", void 0);\n __decorate([\n RefSelector('eValue')\n ], GroupCellRenderer.prototype, \"eValue\", void 0);\n __decorate([\n RefSelector('eChildCount')\n ], GroupCellRenderer.prototype, \"eChildCount\", void 0);\n return GroupCellRenderer;\n}(Component));\nexport { GroupCellRenderer };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from \"../../widgets/component\";\nimport { RefSelector } from \"../../widgets/componentAnnotations\";\nimport { createIconNoSpan } from \"../../utils/icon\";\nvar LoadingCellRenderer = /** @class */ (function (_super) {\n __extends(LoadingCellRenderer, _super);\n function LoadingCellRenderer() {\n return _super.call(this, LoadingCellRenderer.TEMPLATE) || this;\n }\n LoadingCellRenderer.prototype.init = function (params) {\n params.node.failedLoad ? this.setupFailed() : this.setupLoading();\n };\n LoadingCellRenderer.prototype.setupFailed = function () {\n this.eLoadingText.innerText = 'ERR';\n };\n LoadingCellRenderer.prototype.setupLoading = function () {\n var eLoadingIcon = createIconNoSpan('groupLoading', this.gridOptionsWrapper, null);\n if (eLoadingIcon) {\n this.eLoadingIcon.appendChild(eLoadingIcon);\n }\n var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();\n this.eLoadingText.innerText = localeTextFunc('loadingOoo', 'Loading');\n };\n LoadingCellRenderer.prototype.refresh = function (params) {\n return false;\n };\n // this is a user component, and IComponent has \"public destroy()\" as part of the interface.\n // so we need to override destroy() just to make the method public.\n LoadingCellRenderer.prototype.destroy = function () {\n _super.prototype.destroy.call(this);\n };\n LoadingCellRenderer.TEMPLATE = \"
\\n \\n \\n
\";\n __decorate([\n RefSelector('eLoadingIcon')\n ], LoadingCellRenderer.prototype, \"eLoadingIcon\", void 0);\n __decorate([\n RefSelector('eLoadingText')\n ], LoadingCellRenderer.prototype, \"eLoadingText\", void 0);\n return LoadingCellRenderer;\n}(Component));\nexport { LoadingCellRenderer };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { Component } from \"../../widgets/component\";\nvar LoadingOverlayComponent = /** @class */ (function (_super) {\n __extends(LoadingOverlayComponent, _super);\n function LoadingOverlayComponent() {\n return _super.call(this) || this;\n }\n // this is a user component, and IComponent has \"public destroy()\" as part of the interface.\n // so we need to override destroy() just to make the method public.\n LoadingOverlayComponent.prototype.destroy = function () {\n _super.prototype.destroy.call(this);\n };\n LoadingOverlayComponent.prototype.init = function (params) {\n var template = this.gridOptionsWrapper.getOverlayLoadingTemplate() ?\n this.gridOptionsWrapper.getOverlayLoadingTemplate() : LoadingOverlayComponent.DEFAULT_LOADING_OVERLAY_TEMPLATE;\n var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();\n var localisedTemplate = template.replace('[LOADING...]', localeTextFunc('loadingOoo', 'Loading...'));\n this.setTemplate(localisedTemplate);\n };\n LoadingOverlayComponent.DEFAULT_LOADING_OVERLAY_TEMPLATE = '[LOADING...]';\n return LoadingOverlayComponent;\n}(Component));\nexport { LoadingOverlayComponent };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { Component } from \"../../widgets/component\";\nvar NoRowsOverlayComponent = /** @class */ (function (_super) {\n __extends(NoRowsOverlayComponent, _super);\n function NoRowsOverlayComponent() {\n return _super.call(this) || this;\n }\n // this is a user component, and IComponent has \"public destroy()\" as part of the interface.\n // so we need to override destroy() just to make the method public.\n NoRowsOverlayComponent.prototype.destroy = function () {\n _super.prototype.destroy.call(this);\n };\n NoRowsOverlayComponent.prototype.init = function (params) {\n var template = this.gridOptionsWrapper.getOverlayNoRowsTemplate() ?\n this.gridOptionsWrapper.getOverlayNoRowsTemplate() : NoRowsOverlayComponent.DEFAULT_NO_ROWS_TEMPLATE;\n var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();\n var localisedTemplate = template.replace('[NO_ROWS_TO_SHOW]', localeTextFunc('noRowsToShow', 'No Rows To Show'));\n this.setTemplate(localisedTemplate);\n };\n NoRowsOverlayComponent.DEFAULT_NO_ROWS_TEMPLATE = '[NO_ROWS_TO_SHOW]';\n return NoRowsOverlayComponent;\n}(Component));\nexport { NoRowsOverlayComponent };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { PopupComponent } from '../widgets/popupComponent';\nimport { escapeString } from '../utils/string';\nvar TooltipComponent = /** @class */ (function (_super) {\n __extends(TooltipComponent, _super);\n function TooltipComponent() {\n return _super.call(this, /* html */ \"
\") || this;\n }\n // will need to type params\n TooltipComponent.prototype.init = function (params) {\n var value = params.value;\n this.getGui().innerHTML = escapeString(value);\n };\n return TooltipComponent;\n}(PopupComponent));\nexport { TooltipComponent };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub\";\nimport { Autowired, Bean, PostConstruct } from \"../../context/context\";\nimport { ReadOnlyFloatingFilter } from \"../../filter/floating/provided/readOnlyFloatingFilter\";\nimport { DateFilter } from \"../../filter/provided/date/dateFilter\";\nimport { DateFloatingFilter } from \"../../filter/provided/date/dateFloatingFilter\";\nimport { DefaultDateComponent } from \"../../filter/provided/date/defaultDateComponent\";\nimport { NumberFilter } from \"../../filter/provided/number/numberFilter\";\nimport { NumberFloatingFilter } from \"../../filter/provided/number/numberFloatingFilter\";\nimport { TextFilter } from \"../../filter/provided/text/textFilter\";\nimport { TextFloatingFilter } from \"../../filter/provided/text/textFloatingFilter\";\nimport { HeaderComp } from \"../../headerRendering/cells/column/headerComp\";\nimport { HeaderGroupComp } from \"../../headerRendering/cells/columnGroup/headerGroupComp\";\nimport { SortIndicatorComp } from \"../../headerRendering/cells/column/sortIndicatorComp\";\nimport { LargeTextCellEditor } from \"../../rendering/cellEditors/largeTextCellEditor\";\nimport { PopupSelectCellEditor } from \"../../rendering/cellEditors/popupSelectCellEditor\";\nimport { PopupTextCellEditor } from \"../../rendering/cellEditors/popupTextCellEditor\";\nimport { SelectCellEditor } from \"../../rendering/cellEditors/selectCellEditor\";\nimport { TextCellEditor } from \"../../rendering/cellEditors/textCellEditor\";\nimport { AnimateShowChangeCellRenderer } from \"../../rendering/cellRenderers/animateShowChangeCellRenderer\";\nimport { AnimateSlideCellRenderer } from \"../../rendering/cellRenderers/animateSlideCellRenderer\";\nimport { GroupCellRenderer } from \"../../rendering/cellRenderers/groupCellRenderer\";\nimport { LoadingCellRenderer } from \"../../rendering/cellRenderers/loadingCellRenderer\";\nimport { LoadingOverlayComponent } from \"../../rendering/overlays/loadingOverlayComponent\";\nimport { NoRowsOverlayComponent } from \"../../rendering/overlays/noRowsOverlayComponent\";\nimport { TooltipComponent } from \"../../rendering/tooltipComponent\";\nimport { doOnce } from \"../../utils/function\";\nimport { iterateObject } from '../../utils/object';\nvar UserComponentRegistry = /** @class */ (function (_super) {\n __extends(UserComponentRegistry, _super);\n function UserComponentRegistry() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.agGridDefaults = {\n //date\n agDateInput: DefaultDateComponent,\n //header\n agColumnHeader: HeaderComp,\n agColumnGroupHeader: HeaderGroupComp,\n agSortIndicator: SortIndicatorComp,\n //floating filters\n agTextColumnFloatingFilter: TextFloatingFilter,\n agNumberColumnFloatingFilter: NumberFloatingFilter,\n agDateColumnFloatingFilter: DateFloatingFilter,\n agReadOnlyFloatingFilter: ReadOnlyFloatingFilter,\n // renderers\n agAnimateShowChangeCellRenderer: AnimateShowChangeCellRenderer,\n agAnimateSlideCellRenderer: AnimateSlideCellRenderer,\n agGroupCellRenderer: GroupCellRenderer,\n agGroupRowRenderer: GroupCellRenderer,\n agLoadingCellRenderer: LoadingCellRenderer,\n //editors\n agCellEditor: TextCellEditor,\n agTextCellEditor: TextCellEditor,\n agSelectCellEditor: SelectCellEditor,\n agPopupTextCellEditor: PopupTextCellEditor,\n agPopupSelectCellEditor: PopupSelectCellEditor,\n agLargeTextCellEditor: LargeTextCellEditor,\n //filter\n agTextColumnFilter: TextFilter,\n agNumberColumnFilter: NumberFilter,\n agDateColumnFilter: DateFilter,\n //overlays\n agLoadingOverlay: LoadingOverlayComponent,\n agNoRowsOverlay: NoRowsOverlayComponent,\n // tooltips\n agTooltipComponent: TooltipComponent\n };\n _this.agDeprecatedNames = {\n set: {\n newComponentName: 'agSetColumnFilter',\n propertyHolder: 'filter'\n },\n text: {\n newComponentName: 'agTextColumnFilter',\n propertyHolder: 'filter'\n },\n number: {\n newComponentName: 'agNumberColumnFilter',\n propertyHolder: 'filter'\n },\n date: {\n newComponentName: 'agDateColumnFilter',\n propertyHolder: 'filter'\n },\n group: {\n newComponentName: 'agGroupCellRenderer',\n propertyHolder: 'cellRenderer'\n },\n animateShowChange: {\n newComponentName: 'agAnimateShowChangeCellRenderer',\n propertyHolder: 'cellRenderer'\n },\n animateSlide: {\n newComponentName: 'agAnimateSlideCellRenderer',\n propertyHolder: 'cellRenderer'\n },\n select: {\n newComponentName: 'agSelectCellEditor',\n propertyHolder: 'cellEditor'\n },\n largeText: {\n newComponentName: 'agLargeTextCellEditor',\n propertyHolder: 'cellEditor'\n },\n popupSelect: {\n newComponentName: 'agPopupSelectCellEditor',\n propertyHolder: 'cellEditor'\n },\n popupText: {\n newComponentName: 'agPopupTextCellEditor',\n propertyHolder: 'cellEditor'\n },\n richSelect: {\n newComponentName: 'agRichSelectCellEditor',\n propertyHolder: 'cellEditor'\n },\n headerComponent: {\n newComponentName: 'agColumnHeader',\n propertyHolder: 'headerComponent'\n }\n };\n _this.jsComps = {};\n _this.fwComps = {};\n return _this;\n }\n UserComponentRegistry.prototype.init = function () {\n var _this = this;\n if (this.gridOptions.components != null) {\n iterateObject(this.gridOptions.components, function (key, component) { return _this.registerJsComponent(key, component); });\n }\n if (this.gridOptions.frameworkComponents != null) {\n iterateObject(this.gridOptions.frameworkComponents, function (key, component) { return _this.registerFwComponent(key, component); });\n }\n };\n UserComponentRegistry.prototype.registerDefaultComponent = function (rawName, component) {\n var name = this.translateIfDeprecated(rawName);\n if (this.agGridDefaults[name]) {\n console.error(\"Trying to overwrite a default component. You should call registerComponent\");\n return;\n }\n this.agGridDefaults[name] = component;\n };\n UserComponentRegistry.prototype.registerJsComponent = function (rawName, component) {\n var name = this.translateIfDeprecated(rawName);\n if (this.fwComps[name]) {\n console.error(\"Trying to register a component that you have already registered for frameworks: \" + name);\n return;\n }\n this.jsComps[name] = component;\n };\n /**\n * B the business interface (ie IHeader)\n * A the agGridComponent interface (ie IHeaderComp). The final object acceptable by ag-grid\n */\n UserComponentRegistry.prototype.registerFwComponent = function (rawName, component) {\n var warningMessage = \"AG Grid: As of v27, registering components via grid property frameworkComponents is deprecated. Instead register both JavaScript AND Framework Components via the components property.\";\n doOnce(function () { return console.warn(warningMessage); }, \"UserComponentRegistry.frameworkComponentsDeprecated\");\n var name = this.translateIfDeprecated(rawName);\n this.fwComps[name] = component;\n };\n UserComponentRegistry.prototype.retrieve = function (rawName) {\n var name = this.translateIfDeprecated(rawName);\n var createResult = function (component, componentFromFramework) { return ({ componentFromFramework: componentFromFramework, component: component }); };\n // FrameworkOverrides.frameworkComponent() is used in two locations:\n // 1) for Vue, user provided components get registered via a framework specific way.\n // 2) for React, it's how the React UI provides alternative default components (eg GroupCellRenderer and DetailCellRenderer)\n var registeredViaFrameworkComp = this.getFrameworkOverrides().frameworkComponent(name, this.gridOptions.components);\n if (registeredViaFrameworkComp != null) {\n return createResult(registeredViaFrameworkComp, true);\n }\n var frameworkComponent = this.fwComps[name];\n if (frameworkComponent) {\n return createResult(frameworkComponent, true);\n }\n var jsComponent = this.jsComps[name];\n if (jsComponent) {\n var isFwkComp = this.getFrameworkOverrides().isFrameworkComponent(jsComponent);\n return createResult(jsComponent, isFwkComp);\n }\n var defaultComponent = this.agGridDefaults[name];\n if (defaultComponent) {\n return createResult(defaultComponent, false);\n }\n if (Object.keys(this.agGridDefaults).indexOf(name) < 0) {\n console.warn(\"AG Grid: Looking for component [\" + name + \"] but it wasn't found.\");\n }\n return null;\n };\n UserComponentRegistry.prototype.translateIfDeprecated = function (raw) {\n var deprecatedInfo = this.agDeprecatedNames[raw];\n if (deprecatedInfo != null) {\n doOnce(function () {\n console.warn(\"ag-grid. Since v15.0 component names have been renamed to be namespaced. You should rename \" + deprecatedInfo.propertyHolder + \":\" + raw + \" to \" + deprecatedInfo.propertyHolder + \":\" + deprecatedInfo.newComponentName);\n }, 'DEPRECATE_COMPONENT_' + raw);\n return deprecatedInfo.newComponentName;\n }\n return raw;\n };\n __decorate([\n Autowired('gridOptions')\n ], UserComponentRegistry.prototype, \"gridOptions\", void 0);\n __decorate([\n Autowired('agComponentUtils')\n ], UserComponentRegistry.prototype, \"agComponentUtils\", void 0);\n __decorate([\n PostConstruct\n ], UserComponentRegistry.prototype, \"init\", null);\n UserComponentRegistry = __decorate([\n Bean('userComponentRegistry')\n ], UserComponentRegistry);\n return UserComponentRegistry;\n}(BeanStub));\nexport { UserComponentRegistry };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nexport var DateComponent = {\n propertyName: 'dateComponent',\n cellRenderer: false\n};\nexport var HeaderComponent = {\n propertyName: 'headerComponent',\n cellRenderer: false\n};\nexport var HeaderGroupComponent = {\n propertyName: 'headerGroupComponent',\n cellRenderer: false\n};\nexport var CellRendererComponent = {\n propertyName: 'cellRenderer',\n cellRenderer: true\n};\nexport var CellEditorComponent = {\n propertyName: 'cellEditor',\n cellRenderer: false\n};\nexport var InnerRendererComponent = {\n propertyName: 'innerRenderer',\n cellRenderer: true\n};\nexport var LoadingOverlayComponent = {\n propertyName: 'loadingOverlayComponent',\n cellRenderer: false\n};\nexport var NoRowsOverlayComponent = {\n propertyName: 'noRowsOverlayComponent',\n cellRenderer: false\n};\nexport var TooltipComponent = {\n propertyName: 'tooltipComponent',\n cellRenderer: false\n};\nexport var FilterComponent = {\n propertyName: 'filter',\n cellRenderer: false\n};\nexport var FloatingFilterComponent = {\n propertyName: 'floatingFilterComponent',\n cellRenderer: false\n};\nexport var ToolPanelComponent = {\n propertyName: 'toolPanel',\n cellRenderer: false\n};\nexport var StatusPanelComponent = {\n propertyName: 'statusPanel',\n cellRenderer: false\n};\nexport var FullWidth = {\n propertyName: 'fullWidthCellRenderer',\n cellRenderer: true\n};\nexport var FullWidthLoading = {\n propertyName: 'loadingCellRenderer',\n cellRenderer: true\n};\nexport var FullWidthGroup = {\n propertyName: 'groupRowRenderer',\n cellRenderer: true\n};\nexport var FullWidthDetail = {\n propertyName: 'detailCellRenderer',\n cellRenderer: true\n};\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar FloatingFilterMapper = /** @class */ (function () {\n function FloatingFilterMapper() {\n }\n FloatingFilterMapper.getFloatingFilterType = function (filterType) {\n return this.filterToFloatingFilterMapping[filterType];\n };\n FloatingFilterMapper.filterToFloatingFilterMapping = {\n set: 'agSetColumnFloatingFilter',\n agSetColumnFilter: 'agSetColumnFloatingFilter',\n multi: 'agMultiColumnFloatingFilter',\n agMultiColumnFilter: 'agMultiColumnFloatingFilter',\n number: 'agNumberColumnFloatingFilter',\n agNumberColumnFilter: 'agNumberColumnFloatingFilter',\n date: 'agDateColumnFloatingFilter',\n agDateColumnFilter: 'agDateColumnFloatingFilter',\n text: 'agTextColumnFloatingFilter',\n agTextColumnFilter: 'agTextColumnFloatingFilter'\n };\n return FloatingFilterMapper;\n}());\nexport { FloatingFilterMapper };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub\";\nimport { Autowired, Bean, Optional } from \"../../context/context\";\nimport { AgPromise } from \"../../utils\";\nimport { mergeDeep } from '../../utils/object';\nimport { CellEditorComponent, CellRendererComponent, DateComponent, FilterComponent, FloatingFilterComponent, FullWidth, FullWidthDetail, FullWidthGroup, FullWidthLoading, HeaderComponent, HeaderGroupComponent, InnerRendererComponent, LoadingOverlayComponent, NoRowsOverlayComponent, StatusPanelComponent, ToolPanelComponent, TooltipComponent } from \"./componentTypes\";\nimport { FloatingFilterMapper } from '../../filter/floating/floatingFilterMapper';\nimport { ModuleNames } from '../../modules/moduleNames';\nimport { ModuleRegistry } from '../../modules/moduleRegistry';\nimport { doOnce } from \"../../utils/function\";\nvar ANNOTATIONS = '__annotations__';\nvar UserComponentFactory = /** @class */ (function (_super) {\n __extends(UserComponentFactory, _super);\n function UserComponentFactory() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n UserComponentFactory.prototype.getHeaderCompDetails = function (colDef, params) {\n return this.getCompDetails(colDef, HeaderComponent, 'agColumnHeader', params);\n };\n UserComponentFactory.prototype.getHeaderGroupCompDetails = function (params) {\n var colGroupDef = params.columnGroup.getColGroupDef();\n return this.getCompDetails(colGroupDef, HeaderGroupComponent, 'agColumnGroupHeader', params);\n };\n // this one is unusual, as it can be LoadingCellRenderer, DetailCellRenderer, FullWidthCellRenderer or GroupRowRenderer.\n // so we have to pass the type in.\n UserComponentFactory.prototype.getFullWidthCellRendererDetails = function (params) {\n return this.getCompDetails(this.gridOptions, FullWidth, null, params, true);\n };\n UserComponentFactory.prototype.getFullWidthLoadingCellRendererDetails = function (params) {\n return this.getCompDetails(this.gridOptions, FullWidthLoading, 'agLoadingCellRenderer', params, true);\n };\n UserComponentFactory.prototype.getFullWidthGroupCellRendererDetails = function (params) {\n return this.getCompDetails(this.gridOptions, FullWidthGroup, 'agGroupRowRenderer', params, true);\n };\n UserComponentFactory.prototype.getFullWidthDetailCellRendererDetails = function (params) {\n return this.getCompDetails(this.gridOptions, FullWidthDetail, 'agDetailCellRenderer', params, true);\n };\n // CELL RENDERER\n UserComponentFactory.prototype.getInnerRendererDetails = function (def, params) {\n return this.getCompDetails(def, InnerRendererComponent, null, params);\n };\n UserComponentFactory.prototype.getFullWidthGroupRowInnerCellRenderer = function (def, params) {\n return this.getCompDetails(def, InnerRendererComponent, null, params);\n };\n UserComponentFactory.prototype.getCellRendererDetails = function (def, params) {\n return this.getCompDetails(def, CellRendererComponent, null, params);\n };\n // CELL EDITOR\n UserComponentFactory.prototype.getCellEditorDetails = function (def, params) {\n return this.getCompDetails(def, CellEditorComponent, 'agCellEditor', params, true);\n };\n // FILTER\n UserComponentFactory.prototype.getFilterDetails = function (def, params, defaultFilter) {\n return this.getCompDetails(def, FilterComponent, defaultFilter, params, true);\n };\n UserComponentFactory.prototype.getDateCompDetails = function (params) {\n return this.getCompDetails(this.gridOptions, DateComponent, 'agDateInput', params, true);\n };\n UserComponentFactory.prototype.getLoadingOverlayCompDetails = function (params) {\n return this.getCompDetails(this.gridOptions, LoadingOverlayComponent, 'agLoadingOverlay', params, true);\n };\n UserComponentFactory.prototype.getNoRowsOverlayCompDetails = function (params) {\n return this.getCompDetails(this.gridOptions, NoRowsOverlayComponent, 'agNoRowsOverlay', params, true);\n };\n UserComponentFactory.prototype.getTooltipCompDetails = function (params) {\n return this.getCompDetails(params.colDef, TooltipComponent, 'agTooltipComponent', params, true);\n };\n UserComponentFactory.prototype.getSetFilterCellRendererDetails = function (def, params) {\n return this.getCompDetails(def, CellRendererComponent, null, params);\n };\n UserComponentFactory.prototype.getFloatingFilterCompDetails = function (def, params, defaultFloatingFilter) {\n return this.getCompDetails(def, FloatingFilterComponent, defaultFloatingFilter, params);\n };\n UserComponentFactory.prototype.getToolPanelCompDetails = function (toolPanelDef, params) {\n return this.getCompDetails(toolPanelDef, ToolPanelComponent, null, params, true);\n };\n UserComponentFactory.prototype.getStatusPanelCompDetails = function (def, params) {\n return this.getCompDetails(def, StatusPanelComponent, null, params, true);\n };\n UserComponentFactory.prototype.getCompDetails = function (defObject, type, defaultName, params, mandatory) {\n var _this = this;\n if (mandatory === void 0) { mandatory = false; }\n var propertyName = type.propertyName, cellRenderer = type.cellRenderer;\n var _a = this.getCompKeys(defObject, type, params), compName = _a.compName, jsComp = _a.jsComp, fwComp = _a.fwComp, paramsFromSelector = _a.paramsFromSelector, popupFromSelector = _a.popupFromSelector, popupPositionFromSelector = _a.popupPositionFromSelector;\n var lookupFromRegistry = function (key) {\n var item = _this.userComponentRegistry.retrieve(key);\n if (item) {\n jsComp = !item.componentFromFramework ? item.component : undefined;\n fwComp = item.componentFromFramework ? item.component : undefined;\n }\n };\n // if compOption is a string, means we need to look the item up\n if (compName != null) {\n lookupFromRegistry(compName);\n }\n // if lookup brought nothing back, and we have a default, lookup the default\n if (jsComp == null && fwComp == null && defaultName != null) {\n lookupFromRegistry(defaultName);\n }\n // if we have a comp option, and it's a function, replace it with an object equivalent adaptor\n if (jsComp && cellRenderer && !this.agComponentUtils.doesImplementIComponent(jsComp)) {\n jsComp = this.agComponentUtils.adaptFunction(propertyName, jsComp);\n }\n if (!jsComp && !fwComp) {\n if (mandatory) {\n console.error(\"Could not find component \" + compName + \", did you forget to configure this component?\");\n }\n return;\n }\n var paramsMerged = this.mergeParamsWithApplicationProvidedParams(defObject, type, params, paramsFromSelector);\n var componentFromFramework = jsComp == null;\n var componentClass = jsComp ? jsComp : fwComp;\n return {\n componentFromFramework: componentFromFramework,\n componentClass: componentClass,\n params: paramsMerged,\n type: type,\n popupFromSelector: popupFromSelector,\n popupPositionFromSelector: popupPositionFromSelector,\n newAgStackInstance: function () { return _this.newAgStackInstance(componentClass, componentFromFramework, paramsMerged, type); }\n };\n };\n UserComponentFactory.prototype.getCompKeys = function (defObject, type, params) {\n var _this = this;\n var propertyName = type.propertyName;\n var compName;\n var jsComp;\n var fwComp;\n var paramsFromSelector;\n var popupFromSelector;\n var popupPositionFromSelector;\n // there are two types of js comps, class based and func based. we can only check for\n // class based, by checking if getGui() exists. no way to differentiate js func based vs eg react func based\n // const isJsClassComp = (comp: any) => this.agComponentUtils.doesImplementIComponent(comp);\n // const fwActive = this.frameworkComponentWrapper != null;\n // pull from defObject if available\n if (defObject) {\n var defObjectAny = defObject;\n // if selector, use this\n var selectorFunc = defObjectAny[propertyName + 'Selector'];\n var selectorRes = selectorFunc ? selectorFunc(params) : null;\n var assignComp = function (providedJsComp, providedFwComp) {\n var xxxFrameworkDeprecatedWarn = function () {\n var warningMessage = \"AG Grid: As of v27, the property \" + propertyName + \"Framework is deprecated. The property \" + propertyName + \" can now be used for JavaScript AND Framework Components.\";\n doOnce(function () { return console.warn(warningMessage); }, \"UserComponentFactory.\" + propertyName + \"FrameworkDeprecated\");\n };\n if (typeof providedJsComp === 'string') {\n compName = providedJsComp;\n }\n else if (typeof providedFwComp === 'string') {\n xxxFrameworkDeprecatedWarn();\n compName = providedFwComp;\n // comp===true for filters, which means use the default comp\n }\n else if (providedJsComp != null && providedJsComp !== true) {\n var isFwkComp = _this.getFrameworkOverrides().isFrameworkComponent(providedJsComp);\n if (isFwkComp) {\n fwComp = providedJsComp;\n }\n else {\n jsComp = providedJsComp;\n }\n }\n else if (providedFwComp != null) {\n xxxFrameworkDeprecatedWarn();\n fwComp = providedFwComp;\n }\n };\n if (selectorRes) {\n if (selectorRes.frameworkComponent != null) {\n var warningMessage_1 = \"AG Grid: As of v27, the return for \" + propertyName + \"Selector has attributes [component, params] only. The attribute frameworkComponent is deprecated. You should now return back Framework Components using the 'component' attribute and the grid works out if it's a framework component or not.\";\n doOnce(function () { return console.warn(warningMessage_1); }, \"UserComponentFactory.\" + propertyName + \"FrameworkSelectorDeprecated\");\n assignComp(selectorRes.frameworkComponent, undefined);\n }\n else {\n assignComp(selectorRes.component, undefined);\n }\n paramsFromSelector = selectorRes.params;\n popupFromSelector = selectorRes.popup;\n popupPositionFromSelector = selectorRes.popupPosition;\n }\n else {\n // if no selector, or result of selector is empty, take from defObject\n assignComp(defObjectAny[propertyName], defObjectAny[propertyName + 'Framework']);\n }\n }\n return { compName: compName, jsComp: jsComp, fwComp: fwComp, paramsFromSelector: paramsFromSelector, popupFromSelector: popupFromSelector, popupPositionFromSelector: popupPositionFromSelector };\n };\n UserComponentFactory.prototype.newAgStackInstance = function (ComponentClass, componentFromFramework, params, type) {\n var propertyName = type.propertyName;\n var jsComponent = !componentFromFramework;\n // using javascript component\n var instance;\n if (jsComponent) {\n instance = new ComponentClass();\n }\n else {\n // Using framework component\n var thisComponentConfig = this.componentMetadataProvider.retrieve(propertyName);\n instance = this.frameworkComponentWrapper.wrap(ComponentClass, thisComponentConfig.mandatoryMethodList, thisComponentConfig.optionalMethodList, type);\n }\n var deferredInit = this.initComponent(instance, params);\n if (deferredInit == null) {\n return AgPromise.resolve(instance);\n }\n return deferredInit.then(function () { return instance; });\n };\n // used by Floating Filter\n UserComponentFactory.prototype.mergeParamsWithApplicationProvidedParams = function (defObject, type, paramsFromGrid, paramsFromSelector) {\n if (paramsFromSelector === void 0) { paramsFromSelector = null; }\n var params = {\n context: this.gridOptionsWrapper.getContext(),\n columnApi: this.gridOptionsWrapper.getColumnApi(),\n api: this.gridOptionsWrapper.getApi()\n };\n mergeDeep(params, paramsFromGrid);\n // pull user params from either the old prop name and new prop name\n // eg either cellRendererParams and cellCompParams\n var defObjectAny = defObject;\n var userParams = defObjectAny && defObjectAny[type.propertyName + 'Params'];\n if (typeof userParams === 'function') {\n var userParamsFromFunc = userParams(paramsFromGrid);\n mergeDeep(params, userParamsFromFunc);\n }\n else if (typeof userParams === 'object') {\n mergeDeep(params, userParams);\n }\n mergeDeep(params, paramsFromSelector);\n return params;\n };\n UserComponentFactory.prototype.initComponent = function (component, params) {\n this.context.createBean(component);\n if (component.init == null) {\n return;\n }\n return component.init(params);\n };\n UserComponentFactory.prototype.getDefaultFloatingFilterType = function (def) {\n if (def == null) {\n return null;\n }\n var defaultFloatingFilterType = null;\n var _a = this.getCompKeys(def, FilterComponent), compName = _a.compName, jsComp = _a.jsComp, fwComp = _a.fwComp;\n if (compName) {\n // will be undefined if not in the map\n defaultFloatingFilterType = FloatingFilterMapper.getFloatingFilterType(compName);\n }\n else {\n var usingDefaultFilter = (jsComp == null && fwComp == null) && (def.filter === true);\n if (usingDefaultFilter) {\n var setFilterModuleLoaded = ModuleRegistry.isRegistered(ModuleNames.SetFilterModule);\n defaultFloatingFilterType = setFilterModuleLoaded ? 'agSetColumnFloatingFilter' : 'agTextColumnFloatingFilter';\n }\n }\n return defaultFloatingFilterType;\n };\n __decorate([\n Autowired('gridOptions')\n ], UserComponentFactory.prototype, \"gridOptions\", void 0);\n __decorate([\n Autowired('agComponentUtils')\n ], UserComponentFactory.prototype, \"agComponentUtils\", void 0);\n __decorate([\n Autowired('componentMetadataProvider')\n ], UserComponentFactory.prototype, \"componentMetadataProvider\", void 0);\n __decorate([\n Autowired('userComponentRegistry')\n ], UserComponentFactory.prototype, \"userComponentRegistry\", void 0);\n __decorate([\n Optional('frameworkComponentWrapper')\n ], UserComponentFactory.prototype, \"frameworkComponentWrapper\", void 0);\n UserComponentFactory = __decorate([\n Bean('userComponentFactory')\n ], UserComponentFactory);\n return UserComponentFactory;\n}(BeanStub));\nexport { UserComponentFactory };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\n// Excel Export\nexport var ExcelFactoryMode;\n(function (ExcelFactoryMode) {\n ExcelFactoryMode[ExcelFactoryMode[\"SINGLE_SHEET\"] = 0] = \"SINGLE_SHEET\";\n ExcelFactoryMode[ExcelFactoryMode[\"MULTI_SHEET\"] = 1] = \"MULTI_SHEET\";\n})(ExcelFactoryMode || (ExcelFactoryMode = {}));\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean, PreDestroy, Autowired, PostConstruct } from \"../context/context\";\nimport { Events } from \"../events\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { exists } from \"../utils/generic\";\nimport { removeFromArray } from \"../utils/array\";\nimport { areEventsNear } from \"../utils/mouse\";\nimport { isBrowserSafari } from \"../utils/browser\";\n/** Adds drag listening onto an element. In AG Grid this is used twice, first is resizing columns,\n * second is moving the columns and column groups around (ie the 'drag' part of Drag and Drop. */\nvar DragService = /** @class */ (function (_super) {\n __extends(DragService, _super);\n function DragService() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.dragEndFunctions = [];\n _this.dragSources = [];\n return _this;\n }\n DragService.prototype.init = function () {\n this.logger = this.loggerFactory.create('DragService');\n };\n DragService.prototype.removeAllListeners = function () {\n this.dragSources.forEach(this.removeListener.bind(this));\n this.dragSources.length = 0;\n };\n DragService.prototype.removeListener = function (dragSourceAndListener) {\n var element = dragSourceAndListener.dragSource.eElement;\n var mouseDownListener = dragSourceAndListener.mouseDownListener;\n element.removeEventListener('mousedown', mouseDownListener);\n // remove touch listener only if it exists\n if (dragSourceAndListener.touchEnabled) {\n var touchStartListener = dragSourceAndListener.touchStartListener;\n element.removeEventListener('touchstart', touchStartListener, { passive: true });\n }\n };\n DragService.prototype.removeDragSource = function (params) {\n var dragSourceAndListener = this.dragSources.find(function (item) { return item.dragSource === params; });\n if (!dragSourceAndListener) {\n return;\n }\n this.removeListener(dragSourceAndListener);\n removeFromArray(this.dragSources, dragSourceAndListener);\n };\n DragService.prototype.isDragging = function () {\n return this.dragging;\n };\n DragService.prototype.addDragSource = function (params, includeTouch) {\n var _this = this;\n if (includeTouch === void 0) { includeTouch = false; }\n var mouseListener = this.onMouseDown.bind(this, params);\n params.eElement.addEventListener('mousedown', mouseListener);\n var touchListener = null;\n var suppressTouch = this.gridOptionsWrapper.isSuppressTouch();\n if (includeTouch && !suppressTouch) {\n touchListener = function (touchEvent) {\n if (touchEvent.cancelable) {\n touchEvent.preventDefault();\n }\n _this.onTouchStart(params, touchEvent);\n };\n // we set passive=false, as we want to prevent default on this event\n params.eElement.addEventListener('touchstart', touchListener, { passive: false });\n }\n this.dragSources.push({\n dragSource: params,\n mouseDownListener: mouseListener,\n touchStartListener: touchListener,\n touchEnabled: includeTouch\n });\n };\n // gets called whenever mouse down on any drag source\n DragService.prototype.onTouchStart = function (params, touchEvent) {\n var _this = this;\n this.currentDragParams = params;\n this.dragging = false;\n var touch = touchEvent.touches[0];\n this.touchLastTime = touch;\n this.touchStart = touch;\n var touchMoveEvent = function (e) { return _this.onTouchMove(e, params.eElement); };\n var touchEndEvent = function (e) { return _this.onTouchUp(e, params.eElement); };\n var documentTouchMove = function (e) { if (e.cancelable) {\n e.preventDefault();\n } };\n var target = touchEvent.target;\n var events = [\n // Prevents the page document from moving while we are dragging items around.\n // preventDefault needs to be called in the touchmove listener and never inside the\n // touchstart, because using touchstart causes the click event to be cancelled on touch devices.\n { target: document, type: 'touchmove', listener: documentTouchMove, options: { passive: false } },\n { target: target, type: 'touchmove', listener: touchMoveEvent, options: { passive: true } },\n { target: target, type: 'touchend', listener: touchEndEvent, options: { passive: true } },\n { target: target, type: 'touchcancel', listener: touchEndEvent, options: { passive: true } }\n ];\n // temporally add these listeners, for the duration of the drag\n this.addTemporaryEvents(events);\n // see if we want to start dragging straight away\n if (params.dragStartPixels === 0) {\n this.onCommonMove(touch, this.touchStart, params.eElement);\n }\n };\n // gets called whenever mouse down on any drag source\n DragService.prototype.onMouseDown = function (params, mouseEvent) {\n var _this = this;\n var e = mouseEvent;\n if (params.skipMouseEvent && params.skipMouseEvent(mouseEvent)) {\n return;\n }\n // if there are two elements with parent / child relationship, and both are draggable,\n // when we drag the child, we should NOT drag the parent. an example of this is row moving\n // and range selection - row moving should get preference when use drags the rowDrag component.\n if (e._alreadyProcessedByDragService) {\n return;\n }\n e._alreadyProcessedByDragService = true;\n // only interested in left button clicks\n if (mouseEvent.button !== 0) {\n return;\n }\n this.currentDragParams = params;\n this.dragging = false;\n this.mouseStartEvent = mouseEvent;\n var eDocument = this.gridOptionsWrapper.getDocument();\n var mouseMoveEvent = function (event) { return _this.onMouseMove(event, params.eElement); };\n var mouseUpEvent = function (event) { return _this.onMouseUp(event, params.eElement); };\n var contextEvent = function (event) { return event.preventDefault(); };\n var target = eDocument;\n var events = [\n { target: target, type: 'mousemove', listener: mouseMoveEvent },\n { target: target, type: 'mouseup', listener: mouseUpEvent },\n { target: target, type: 'contextmenu', listener: contextEvent }\n ];\n // temporally add these listeners, for the duration of the drag\n this.addTemporaryEvents(events);\n //see if we want to start dragging straight away\n if (params.dragStartPixels === 0) {\n this.onMouseMove(mouseEvent, params.eElement);\n }\n };\n DragService.prototype.addTemporaryEvents = function (events) {\n events.forEach(function (currentEvent) {\n var target = currentEvent.target, type = currentEvent.type, listener = currentEvent.listener, options = currentEvent.options;\n target.addEventListener(type, listener, options);\n });\n this.dragEndFunctions.push(function () {\n events.forEach(function (currentEvent) {\n var target = currentEvent.target, type = currentEvent.type, listener = currentEvent.listener, options = currentEvent.options;\n target.removeEventListener(type, listener, options);\n });\n });\n };\n // returns true if the event is close to the original event by X pixels either vertically or horizontally.\n // we only start dragging after X pixels so this allows us to know if we should start dragging yet.\n DragService.prototype.isEventNearStartEvent = function (currentEvent, startEvent) {\n // by default, we wait 4 pixels before starting the drag\n var dragStartPixels = this.currentDragParams.dragStartPixels;\n var requiredPixelDiff = exists(dragStartPixels) ? dragStartPixels : 4;\n return areEventsNear(currentEvent, startEvent, requiredPixelDiff);\n };\n DragService.prototype.getFirstActiveTouch = function (touchList) {\n for (var i = 0; i < touchList.length; i++) {\n if (touchList[i].identifier === this.touchStart.identifier) {\n return touchList[i];\n }\n }\n return null;\n };\n DragService.prototype.onCommonMove = function (currentEvent, startEvent, el) {\n if (!this.dragging) {\n // if mouse hasn't travelled from the start position enough, do nothing\n if (!this.dragging && this.isEventNearStartEvent(currentEvent, startEvent)) {\n return;\n }\n this.dragging = true;\n var event_1 = {\n type: Events.EVENT_DRAG_STARTED,\n target: el\n };\n this.eventService.dispatchEvent(event_1);\n this.currentDragParams.onDragStart(startEvent);\n // we need ONE drag action at the startEvent, so that we are guaranteed the drop target\n // at the start gets notified. this is because the drag can start outside of the element\n // that started it, as the mouse is allowed drag away from the mouse down before it's\n // considered a drag (the isEventNearStartEvent() above). if we didn't do this, then\n // it would be possible to click a column by the edge, then drag outside of the drop zone\n // in less than 4 pixels and the drag officially starts outside of the header but the header\n // wouldn't be notified of the dragging.\n this.currentDragParams.onDragging(startEvent);\n }\n this.currentDragParams.onDragging(currentEvent);\n };\n DragService.prototype.onTouchMove = function (touchEvent, el) {\n var touch = this.getFirstActiveTouch(touchEvent.touches);\n if (!touch) {\n return;\n }\n // this.___statusPanel.setInfoText(Math.random() + ' onTouchMove preventDefault stopPropagation');\n this.onCommonMove(touch, this.touchStart, el);\n };\n // only gets called after a mouse down - as this is only added after mouseDown\n // and is removed when mouseUp happens\n DragService.prototype.onMouseMove = function (mouseEvent, el) {\n // when `isEnableCellTextSelect` is `true`, we need to preventDefault on mouseMove\n // to avoid the grid text being selected while dragging components.\n // Note: Safari also has an issue, where `user-select: none` is not being respected.\n if ((this.gridOptionsWrapper.isEnableCellTextSelect() || isBrowserSafari()) &&\n // The event type can be `mousedown` when `dragStartPixels=0`\n // we should only preventDefault on `mousemove`.\n mouseEvent.type === 'mousemove' &&\n mouseEvent.cancelable &&\n this.mouseEventService.isEventFromThisGrid(mouseEvent) &&\n // we should not prevent mouseMove when above a form field\n // as that would prevent the text in the field from being selected\n !this.isOverFormFieldElement(mouseEvent)) {\n mouseEvent.preventDefault();\n }\n this.onCommonMove(mouseEvent, this.mouseStartEvent, el);\n };\n DragService.prototype.isOverFormFieldElement = function (mouseEvent) {\n var _a, _b;\n var el = mouseEvent.target;\n var tagName = (_a = el) === null || _a === void 0 ? void 0 : _a.tagName.toLocaleLowerCase();\n return !!((_b = tagName) === null || _b === void 0 ? void 0 : _b.match('^a$|textarea|input|select|button'));\n };\n DragService.prototype.onTouchUp = function (touchEvent, el) {\n var touch = this.getFirstActiveTouch(touchEvent.changedTouches);\n // i haven't worked this out yet, but there is no matching touch\n // when we get the touch up event. to get around this, we swap in\n // the last touch. this is a hack to 'get it working' while we\n // figure out what's going on, why we are not getting a touch in\n // current event.\n if (!touch) {\n touch = this.touchLastTime;\n }\n // if mouse was left up before we started to move, then this is a tap.\n // we check this before onUpCommon as onUpCommon resets the dragging\n // let tap = !this.dragging;\n // let tapTarget = this.currentDragParams.eElement;\n this.onUpCommon(touch, el);\n // if tap, tell user\n // console.log(`${Math.random()} tap = ${tap}`);\n // if (tap) {\n // tapTarget.click();\n // }\n };\n DragService.prototype.onMouseUp = function (mouseEvent, el) {\n this.onUpCommon(mouseEvent, el);\n };\n DragService.prototype.onUpCommon = function (eventOrTouch, el) {\n if (this.dragging) {\n this.dragging = false;\n this.currentDragParams.onDragStop(eventOrTouch);\n var event_2 = {\n type: Events.EVENT_DRAG_STOPPED,\n target: el\n };\n this.eventService.dispatchEvent(event_2);\n }\n this.mouseStartEvent = null;\n this.touchStart = null;\n this.touchLastTime = null;\n this.currentDragParams = null;\n this.dragEndFunctions.forEach(function (func) { return func(); });\n this.dragEndFunctions.length = 0;\n };\n __decorate([\n Autowired('loggerFactory')\n ], DragService.prototype, \"loggerFactory\", void 0);\n __decorate([\n Autowired('mouseEventService')\n ], DragService.prototype, \"mouseEventService\", void 0);\n __decorate([\n PostConstruct\n ], DragService.prototype, \"init\", null);\n __decorate([\n PreDestroy\n ], DragService.prototype, \"removeAllListeners\", null);\n DragService = __decorate([\n Bean('dragService')\n ], DragService);\n return DragService;\n}(BeanStub));\nexport { DragService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { AgPromise, _ } from '../utils';\nimport { Autowired, Bean, PostConstruct, PreDestroy } from '../context/context';\nimport { Events } from '../events';\nimport { ModuleNames } from '../modules/moduleNames';\nimport { ModuleRegistry } from '../modules/moduleRegistry';\nimport { BeanStub } from '../context/beanStub';\nimport { convertToSet } from '../utils/set';\nimport { exists } from '../utils/generic';\nimport { mergeDeep, cloneObject } from '../utils/object';\nimport { loadTemplate } from '../utils/dom';\nvar FilterManager = /** @class */ (function (_super) {\n __extends(FilterManager, _super);\n function FilterManager() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.allColumnFilters = new Map();\n _this.activeAggregateFilters = [];\n _this.activeColumnFilters = [];\n _this.quickFilter = null;\n _this.quickFilterParts = null;\n // this is true when the grid is processing the filter change. this is used by the cell comps, so that they\n // don't flash when data changes due to filter changes. there is no need to flash when filter changes as the\n // user is in control, so doesn't make sense to show flashing changes. for example, go to main demo where\n // this feature is turned off (hack code to always return false for isSuppressFlashingCellsBecauseFiltering(), put in)\n // 100,000 rows and group by country. then do some filtering. all the cells flash, which is silly.\n _this.processingFilterChange = false;\n return _this;\n }\n FilterManager_1 = FilterManager;\n FilterManager.prototype.init = function () {\n var _this = this;\n this.addManagedListener(this.eventService, Events.EVENT_GRID_COLUMNS_CHANGED, function () { return _this.onColumnsChanged(); });\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_VALUE_CHANGED, function () { return _this.refreshFiltersForAggregations(); });\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PIVOT_CHANGED, function () { return _this.refreshFiltersForAggregations(); });\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PIVOT_MODE_CHANGED, function () { return _this.refreshFiltersForAggregations(); });\n this.quickFilter = this.parseQuickFilter(this.gridOptionsWrapper.getQuickFilterText());\n this.setQuickFilterParts();\n this.allowShowChangeAfterFilter = this.gridOptionsWrapper.isAllowShowChangeAfterFilter();\n this.externalFilterPresent = this.gridOptionsWrapper.isExternalFilterPresent();\n };\n FilterManager.prototype.setQuickFilterParts = function () {\n this.quickFilterParts = this.quickFilter ? this.quickFilter.split(' ') : null;\n };\n FilterManager.prototype.setFilterModel = function (model) {\n var _this = this;\n var allPromises = [];\n var previousModel = this.getFilterModel();\n if (model) {\n // mark the filters as we set them, so any active filters left over we stop\n var modelKeys_1 = convertToSet(Object.keys(model));\n this.allColumnFilters.forEach(function (filterWrapper, colId) {\n var newModel = model[colId];\n allPromises.push(_this.setModelOnFilterWrapper(filterWrapper.filterPromise, newModel));\n modelKeys_1.delete(colId);\n });\n // at this point, processedFields contains data for which we don't have a filter working yet\n modelKeys_1.forEach(function (colId) {\n var column = _this.columnModel.getPrimaryColumn(colId) || _this.columnModel.getGridColumn(colId);\n if (!column) {\n console.warn('AG Grid: setFilterModel() - no column found for colId: ' + colId);\n return;\n }\n if (!column.isFilterAllowed()) {\n console.warn('AG Grid: setFilterModel() - unable to fully apply model, filtering disabled for colId: ' + colId);\n return;\n }\n var filterWrapper = _this.getOrCreateFilterWrapper(column, 'NO_UI');\n if (!filterWrapper) {\n console.warn('AG-Grid: setFilterModel() - unable to fully apply model, unable to create filter for colId: ' + colId);\n return;\n }\n allPromises.push(_this.setModelOnFilterWrapper(filterWrapper.filterPromise, model[colId]));\n });\n }\n else {\n this.allColumnFilters.forEach(function (filterWrapper) {\n allPromises.push(_this.setModelOnFilterWrapper(filterWrapper.filterPromise, null));\n });\n }\n AgPromise.all(allPromises).then(function () {\n var currentModel = _this.getFilterModel();\n var columns = [];\n _this.allColumnFilters.forEach(function (filterWrapper, colId) {\n var before = previousModel ? previousModel[colId] : null;\n var after = currentModel ? currentModel[colId] : null;\n if (!_.jsonEquals(before, after)) {\n columns.push(filterWrapper.column);\n }\n });\n if (columns.length > 0) {\n _this.onFilterChanged({ columns: columns });\n }\n });\n };\n FilterManager.prototype.setModelOnFilterWrapper = function (filterPromise, newModel) {\n return new AgPromise(function (resolve) {\n filterPromise.then(function (filter) {\n if (typeof filter.setModel !== 'function') {\n console.warn('AG Grid: filter missing setModel method, which is needed for setFilterModel');\n resolve();\n }\n (filter.setModel(newModel) || AgPromise.resolve()).then(function () { return resolve(); });\n });\n });\n };\n FilterManager.prototype.getFilterModel = function () {\n var result = {};\n this.allColumnFilters.forEach(function (filterWrapper, key) {\n // because user can provide filters, we provide useful error checking and messages\n var filterPromise = filterWrapper.filterPromise;\n var filter = filterPromise.resolveNow(null, function (promiseFilter) { return promiseFilter; });\n if (filter == null) {\n return null;\n }\n if (typeof filter.getModel !== 'function') {\n console.warn('AG Grid: filter API missing getModel method, which is needed for getFilterModel');\n return;\n }\n var model = filter.getModel();\n if (exists(model)) {\n result[key] = model;\n }\n });\n return result;\n };\n FilterManager.prototype.isColumnFilterPresent = function () {\n return this.activeColumnFilters.length > 0;\n };\n FilterManager.prototype.isAggregateFilterPresent = function () {\n return !!this.activeAggregateFilters.length;\n };\n FilterManager.prototype.isExternalFilterPresent = function () {\n return this.externalFilterPresent;\n };\n FilterManager.prototype.doAggregateFiltersPass = function (node, filterToSkip) {\n return this.doColumnFiltersPass(node, filterToSkip, true);\n };\n // called by:\n // 1) onFilterChanged()\n // 2) onNewRowsLoaded()\n FilterManager.prototype.updateActiveFilters = function () {\n var _this = this;\n this.activeColumnFilters.length = 0;\n this.activeAggregateFilters.length = 0;\n var isFilterActive = function (filter) {\n if (!filter) {\n return false;\n } // this never happens, including to avoid compile error\n if (!filter.isFilterActive) {\n console.warn('AG Grid: Filter is missing isFilterActive() method');\n return false;\n }\n return filter.isFilterActive();\n };\n var groupFilterEnabled = !!this.gridOptionsWrapper.getGroupAggFiltering();\n var isAggFilter = function (column) {\n var isSecondary = !column.isPrimary();\n // the only filters that can appear on secondary columns are groupAgg filters\n if (isSecondary) {\n return true;\n }\n var isShowingPrimaryColumns = !_this.columnModel.isPivotActive();\n var isValueActive = column.isValueActive();\n // primary columns are only ever groupAgg filters if a) value is active and b) showing primary columns\n if (!isValueActive || !isShowingPrimaryColumns) {\n return false;\n }\n // from here on we know: isPrimary=true, isValueActive=true, isShowingPrimaryColumns=true\n if (_this.columnModel.isPivotMode()) {\n // primary column is pretending to be a pivot column, ie pivotMode=true, but we are\n // still showing primary columns\n return true;\n }\n else {\n // we are not pivoting, so we groupFilter when it's an agg column\n return groupFilterEnabled;\n }\n };\n this.allColumnFilters.forEach(function (filterWrapper) {\n if (filterWrapper.filterPromise.resolveNow(false, isFilterActive)) {\n var filterComp = filterWrapper.filterPromise.resolveNow(null, function (filter) { return filter; });\n if (isAggFilter(filterWrapper.column)) {\n _this.activeAggregateFilters.push(filterComp);\n }\n else {\n _this.activeColumnFilters.push(filterComp);\n }\n }\n });\n };\n FilterManager.prototype.updateFilterFlagInColumns = function (source, additionalEventAttributes) {\n this.allColumnFilters.forEach(function (filterWrapper) {\n var isFilterActive = filterWrapper.filterPromise.resolveNow(false, function (filter) { return filter.isFilterActive(); });\n filterWrapper.column.setFilterActive(isFilterActive, source, additionalEventAttributes);\n });\n };\n FilterManager.prototype.isAnyFilterPresent = function () {\n return this.isQuickFilterPresent() || this.isColumnFilterPresent() || this.isAggregateFilterPresent() || this.isExternalFilterPresent();\n };\n FilterManager.prototype.doColumnFiltersPass = function (node, filterToSkip, targetAggregates) {\n var data = node.data, aggData = node.aggData;\n var targetedFilters = targetAggregates ? this.activeAggregateFilters : this.activeColumnFilters;\n var targetedData = targetAggregates ? aggData : data;\n for (var i = 0; i < targetedFilters.length; i++) {\n var filter = targetedFilters[i];\n if (filter == null || filter === filterToSkip) {\n continue;\n }\n if (typeof filter.doesFilterPass !== 'function') {\n // because users can do custom filters, give nice error message\n throw new Error('Filter is missing method doesFilterPass');\n }\n if (!filter.doesFilterPass({ node: node, data: targetedData })) {\n return false;\n }\n }\n return true;\n };\n FilterManager.prototype.parseQuickFilter = function (newFilter) {\n if (!exists(newFilter)) {\n return null;\n }\n if (!this.gridOptionsWrapper.isRowModelDefault()) {\n console.warn('AG Grid - Quick filtering only works with the Client-Side Row Model');\n return null;\n }\n return newFilter.toUpperCase();\n };\n FilterManager.prototype.setQuickFilter = function (newFilter) {\n if (newFilter != null && typeof newFilter !== 'string') {\n console.warn(\"AG Grid - setQuickFilter() only supports string inputs, received: \" + typeof newFilter);\n return;\n }\n var parsedFilter = this.parseQuickFilter(newFilter);\n if (this.quickFilter !== parsedFilter) {\n this.quickFilter = parsedFilter;\n this.setQuickFilterParts();\n this.onFilterChanged();\n }\n };\n FilterManager.prototype.refreshFiltersForAggregations = function () {\n var isAggFiltering = this.gridOptionsWrapper.getGroupAggFiltering();\n if (isAggFiltering) {\n this.onFilterChanged();\n }\n };\n // sometimes (especially in React) the filter can call onFilterChanged when we are in the middle\n // of a render cycle. this would be bad, so we wait for render cycle to complete when this happens.\n // this happens in react when we change React State in the grid (eg setting RowCtrl's in RowContainer)\n // which results in React State getting applied in the main application, triggering a useEffect() to\n // be kicked off adn then the application calling the grid's API. in AG-6554, the custom filter was\n // getting it's useEffect() triggered in this way.\n FilterManager.prototype.callOnFilterChangedOutsideRenderCycle = function (params) {\n var _this = this;\n if (params === void 0) { params = {}; }\n var action = function () { return _this.onFilterChanged(params); };\n if (this.rowRenderer.isRefreshInProgress()) {\n setTimeout(action, 0);\n }\n else {\n action();\n }\n };\n FilterManager.prototype.onFilterChanged = function (params) {\n if (params === void 0) { params = {}; }\n var filterInstance = params.filterInstance, additionalEventAttributes = params.additionalEventAttributes, columns = params.columns;\n this.updateActiveFilters();\n this.updateFilterFlagInColumns('filterChanged', additionalEventAttributes);\n this.externalFilterPresent = this.gridOptionsWrapper.isExternalFilterPresent();\n this.allColumnFilters.forEach(function (filterWrapper) {\n if (!filterWrapper.filterPromise) {\n return;\n }\n filterWrapper.filterPromise.then(function (filter) {\n if (filter && filter !== filterInstance && filter.onAnyFilterChanged) {\n filter.onAnyFilterChanged();\n }\n });\n });\n var filterChangedEvent = {\n type: Events.EVENT_FILTER_CHANGED,\n columns: columns || [],\n };\n if (additionalEventAttributes) {\n mergeDeep(filterChangedEvent, additionalEventAttributes);\n }\n // because internal events are not async in ag-grid, when the dispatchEvent\n // method comes back, we know all listeners have finished executing.\n this.processingFilterChange = true;\n this.eventService.dispatchEvent(filterChangedEvent);\n this.processingFilterChange = false;\n };\n FilterManager.prototype.isSuppressFlashingCellsBecauseFiltering = function () {\n // if user has elected to always flash cell changes, then always return false, otherwise we suppress flashing\n // changes when filtering\n return !this.allowShowChangeAfterFilter && this.processingFilterChange;\n };\n FilterManager.prototype.isQuickFilterPresent = function () {\n return this.quickFilter !== null;\n };\n FilterManager.prototype.doesRowPassOtherFilters = function (filterToSkip, node) {\n return this.doesRowPassFilter({ rowNode: node, filterInstanceToSkip: filterToSkip });\n };\n FilterManager.prototype.doesRowPassQuickFilterNoCache = function (node, filterPart) {\n var _this = this;\n var columns = this.columnModel.getAllColumnsForQuickFilter();\n return columns.some(function (column) {\n var part = _this.getQuickFilterTextForColumn(column, node);\n return exists(part) && part.indexOf(filterPart) >= 0;\n });\n };\n FilterManager.prototype.doesRowPassQuickFilterCache = function (node, filterPart) {\n if (!node.quickFilterAggregateText) {\n this.aggregateRowForQuickFilter(node);\n }\n return node.quickFilterAggregateText.indexOf(filterPart) >= 0;\n };\n FilterManager.prototype.doesRowPassQuickFilter = function (node) {\n var _this = this;\n var usingCache = this.gridOptionsWrapper.isCacheQuickFilter();\n // each part must pass, if any fails, then the whole filter fails\n return this.quickFilterParts.every(function (part) {\n return usingCache ? _this.doesRowPassQuickFilterCache(node, part) : _this.doesRowPassQuickFilterNoCache(node, part);\n });\n };\n FilterManager.prototype.doesRowPassAggregateFilters = function (params) {\n if (this.isAggregateFilterPresent() && !this.doAggregateFiltersPass(params.rowNode, params.filterInstanceToSkip)) {\n return false;\n }\n // got this far, all filters pass\n return true;\n };\n FilterManager.prototype.doesRowPassFilter = function (params) {\n // the row must pass ALL of the filters, so if any of them fail,\n // we return true. that means if a row passes the quick filter,\n // but fails the column filter, it fails overall\n // first up, check quick filter\n if (this.isQuickFilterPresent() && !this.doesRowPassQuickFilter(params.rowNode)) {\n return false;\n }\n // secondly, give the client a chance to reject this row\n if (this.isExternalFilterPresent() && !this.gridOptionsWrapper.doesExternalFilterPass(params.rowNode)) {\n return false;\n }\n // lastly, check column filter\n if (this.isColumnFilterPresent() && !this.doColumnFiltersPass(params.rowNode, params.filterInstanceToSkip)) {\n return false;\n }\n // got this far, all filters pass\n return true;\n };\n FilterManager.prototype.getQuickFilterTextForColumn = function (column, node) {\n var value = this.valueService.getValue(column, node, true);\n var colDef = column.getColDef();\n if (colDef.getQuickFilterText) {\n var params = {\n value: value,\n node: node,\n data: node.data,\n column: column,\n colDef: colDef,\n api: this.gridOptionsWrapper.getApi(),\n columnApi: this.gridOptionsWrapper.getColumnApi(),\n context: this.gridOptionsWrapper.getContext()\n };\n value = colDef.getQuickFilterText(params);\n }\n return exists(value) ? value.toString().toUpperCase() : null;\n };\n FilterManager.prototype.aggregateRowForQuickFilter = function (node) {\n var _this = this;\n var stringParts = [];\n var columns = this.columnModel.getAllColumnsForQuickFilter();\n columns.forEach(function (column) {\n var part = _this.getQuickFilterTextForColumn(column, node);\n if (exists(part)) {\n stringParts.push(part);\n }\n });\n node.quickFilterAggregateText = stringParts.join(FilterManager_1.QUICK_FILTER_SEPARATOR);\n };\n FilterManager.prototype.onNewRowsLoaded = function (source) {\n this.allColumnFilters.forEach(function (filterWrapper) {\n filterWrapper.filterPromise.then(function (filter) {\n if (filter.onNewRowsLoaded) {\n filter.onNewRowsLoaded();\n }\n });\n });\n this.updateFilterFlagInColumns(source);\n this.updateActiveFilters();\n };\n FilterManager.prototype.createValueGetter = function (column) {\n var _this = this;\n return function (_a) {\n var node = _a.node;\n return _this.valueService.getValue(column, node, true);\n };\n };\n FilterManager.prototype.getFilterComponent = function (column, source, createIfDoesNotExist) {\n if (createIfDoesNotExist === void 0) { createIfDoesNotExist = true; }\n var _a;\n if (createIfDoesNotExist) {\n return ((_a = this.getOrCreateFilterWrapper(column, source)) === null || _a === void 0 ? void 0 : _a.filterPromise) || null;\n }\n var filterWrapper = this.cachedFilter(column);\n return filterWrapper ? filterWrapper.filterPromise : null;\n };\n FilterManager.prototype.isFilterActive = function (column) {\n var filterWrapper = this.cachedFilter(column);\n return !!filterWrapper && filterWrapper.filterPromise.resolveNow(false, function (filter) { return filter.isFilterActive(); });\n };\n FilterManager.prototype.getOrCreateFilterWrapper = function (column, source) {\n if (!column.isFilterAllowed()) {\n return null;\n }\n var filterWrapper = this.cachedFilter(column);\n if (!filterWrapper) {\n filterWrapper = this.createFilterWrapper(column, source);\n this.allColumnFilters.set(column.getColId(), filterWrapper);\n }\n else if (source !== 'NO_UI') {\n this.putIntoGui(filterWrapper, source);\n }\n return filterWrapper;\n };\n FilterManager.prototype.cachedFilter = function (column) {\n return this.allColumnFilters.get(column.getColId());\n };\n FilterManager.prototype.createFilterInstance = function (column) {\n var _this = this;\n var defaultFilter = ModuleRegistry.isRegistered(ModuleNames.SetFilterModule) ? 'agSetColumnFilter' : 'agTextColumnFilter';\n var colDef = column.getColDef();\n var filterInstance;\n var params = __assign(__assign({}, this.createFilterParams(column, colDef)), { filterModifiedCallback: function () {\n var event = {\n type: Events.EVENT_FILTER_MODIFIED,\n column: column,\n filterInstance: filterInstance\n };\n _this.eventService.dispatchEvent(event);\n }, filterChangedCallback: function (additionalEventAttributes) {\n var params = { filterInstance: filterInstance, additionalEventAttributes: additionalEventAttributes, columns: [column] };\n _this.callOnFilterChangedOutsideRenderCycle(params);\n }, doesRowPassOtherFilter: function (node) { return _this.doesRowPassOtherFilters(filterInstance, node); } });\n var compDetails = this.userComponentFactory.getFilterDetails(colDef, params, defaultFilter);\n if (!compDetails) {\n return null;\n }\n var componentPromise = compDetails.newAgStackInstance();\n if (componentPromise) {\n componentPromise.then(function (r) { return filterInstance = r; });\n }\n return componentPromise;\n };\n FilterManager.prototype.createFilterParams = function (column, colDef) {\n var params = {\n api: this.gridOptionsWrapper.getApi(),\n columnApi: this.gridOptionsWrapper.getColumnApi(),\n column: column,\n colDef: cloneObject(colDef),\n rowModel: this.rowModel,\n filterChangedCallback: function () { },\n filterModifiedCallback: function () { },\n valueGetter: this.createValueGetter(column),\n context: this.gridOptionsWrapper.getContext(),\n doesRowPassOtherFilter: function () { return true; },\n };\n return params;\n };\n FilterManager.prototype.createFilterWrapper = function (column, source) {\n var filterWrapper = {\n column: column,\n filterPromise: null,\n compiledElement: null,\n guiPromise: AgPromise.resolve(null)\n };\n filterWrapper.filterPromise = this.createFilterInstance(column);\n if (filterWrapper.filterPromise) {\n this.putIntoGui(filterWrapper, source);\n }\n return filterWrapper;\n };\n FilterManager.prototype.putIntoGui = function (filterWrapper, source) {\n var _this = this;\n var eFilterGui = document.createElement('div');\n eFilterGui.className = 'ag-filter';\n filterWrapper.guiPromise = new AgPromise(function (resolve) {\n filterWrapper.filterPromise.then(function (filter) {\n var guiFromFilter = filter.getGui();\n if (!exists(guiFromFilter)) {\n console.warn(\"AG Grid: getGui method from filter returned \" + guiFromFilter + \", it should be a DOM element or an HTML template string.\");\n }\n // for backwards compatibility with Angular 1 - we\n // used to allow providing back HTML from getGui().\n // once we move away from supporting Angular 1\n // directly, we can change this.\n if (typeof guiFromFilter === 'string') {\n guiFromFilter = loadTemplate(guiFromFilter);\n }\n eFilterGui.appendChild(guiFromFilter);\n resolve(eFilterGui);\n var event = {\n type: Events.EVENT_FILTER_OPENED,\n column: filterWrapper.column,\n source: source,\n eGui: eFilterGui\n };\n _this.eventService.dispatchEvent(event);\n });\n });\n };\n FilterManager.prototype.onColumnsChanged = function () {\n var _this = this;\n var columns = [];\n this.allColumnFilters.forEach(function (wrapper, colId) {\n var currentColumn;\n if (wrapper.column.isPrimary()) {\n currentColumn = _this.columnModel.getPrimaryColumn(colId);\n }\n else {\n currentColumn = _this.columnModel.getGridColumn(colId);\n }\n if (currentColumn) {\n return;\n }\n columns.push(wrapper.column);\n _this.disposeFilterWrapper(wrapper, 'filterDestroyed');\n });\n if (columns.length > 0) {\n this.onFilterChanged({ columns: columns });\n }\n };\n // destroys the filter, so it not longer takes part\n FilterManager.prototype.destroyFilter = function (column, source) {\n if (source === void 0) { source = 'api'; }\n var filterWrapper = this.allColumnFilters.get(column.getColId());\n if (filterWrapper) {\n this.disposeFilterWrapper(filterWrapper, source);\n this.onFilterChanged({ columns: [column] });\n }\n };\n FilterManager.prototype.disposeFilterWrapper = function (filterWrapper, source) {\n var _this = this;\n filterWrapper.filterPromise.then(function (filter) {\n (filter.setModel(null) || AgPromise.resolve()).then(function () {\n _this.getContext().destroyBean(filter);\n filterWrapper.column.setFilterActive(false, source);\n _this.allColumnFilters.delete(filterWrapper.column.getColId());\n });\n });\n };\n FilterManager.prototype.destroy = function () {\n var _this = this;\n _super.prototype.destroy.call(this);\n this.allColumnFilters.forEach(function (filterWrapper) { return _this.disposeFilterWrapper(filterWrapper, 'filterDestroyed'); });\n };\n var FilterManager_1;\n FilterManager.QUICK_FILTER_SEPARATOR = '\\n';\n __decorate([\n Autowired('valueService')\n ], FilterManager.prototype, \"valueService\", void 0);\n __decorate([\n Autowired('columnModel')\n ], FilterManager.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('rowModel')\n ], FilterManager.prototype, \"rowModel\", void 0);\n __decorate([\n Autowired('userComponentFactory')\n ], FilterManager.prototype, \"userComponentFactory\", void 0);\n __decorate([\n Autowired('rowRenderer')\n ], FilterManager.prototype, \"rowRenderer\", void 0);\n __decorate([\n PostConstruct\n ], FilterManager.prototype, \"init\", null);\n __decorate([\n PreDestroy\n ], FilterManager.prototype, \"destroy\", null);\n FilterManager = FilterManager_1 = __decorate([\n Bean('filterManager')\n ], FilterManager);\n return FilterManager;\n}(BeanStub));\nexport { FilterManager };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { Component } from \"../../../widgets/component\";\nvar AbstractHeaderCellComp = /** @class */ (function (_super) {\n __extends(AbstractHeaderCellComp, _super);\n function AbstractHeaderCellComp(template, ctrl) {\n var _this = _super.call(this, template) || this;\n _this.ctrl = ctrl;\n return _this;\n }\n AbstractHeaderCellComp.prototype.getCtrl = function () {\n return this.ctrl;\n };\n return AbstractHeaderCellComp;\n}(Component));\nexport { AbstractHeaderCellComp };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PostConstruct } from '../../../context/context';\nimport { RefSelector } from '../../../widgets/componentAnnotations';\nimport { AbstractHeaderCellComp } from '../abstractCell/abstractHeaderCellComp';\nvar HeaderFilterCellComp = /** @class */ (function (_super) {\n __extends(HeaderFilterCellComp, _super);\n function HeaderFilterCellComp(ctrl) {\n return _super.call(this, HeaderFilterCellComp.TEMPLATE, ctrl) || this;\n }\n HeaderFilterCellComp.prototype.postConstruct = function () {\n var _this = this;\n var eGui = this.getGui();\n var compProxy = {\n addOrRemoveCssClass: function (cssClassName, on) { return _this.addOrRemoveCssClass(cssClassName, on); },\n addOrRemoveBodyCssClass: function (cssClassName, on) { return _this.eFloatingFilterBody.classList.toggle(cssClassName, on); },\n addOrRemoveButtonWrapperCssClass: function (cssClassName, on) { return _this.eButtonWrapper.classList.toggle(cssClassName, on); },\n setCompDetails: function (compDetails) { return _this.setCompDetails(compDetails); },\n getFloatingFilterComp: function () { return _this.compPromise; },\n setWidth: function (width) { return eGui.style.width = width; },\n setMenuIcon: function (eIcon) { return _this.eButtonShowMainFilter.appendChild(eIcon); }\n };\n this.ctrl.setComp(compProxy, eGui, this.eButtonShowMainFilter, this.eFloatingFilterBody);\n };\n HeaderFilterCellComp.prototype.setCompDetails = function (compDetails) {\n var _this = this;\n // because we are providing defaultFloatingFilterType, we know it will never be undefined;\n this.compPromise = compDetails.newAgStackInstance();\n this.compPromise.then(function (comp) { return _this.afterCompCreated(comp); });\n };\n HeaderFilterCellComp.prototype.afterCompCreated = function (comp) {\n var _this = this;\n if (!comp) {\n return;\n }\n this.addDestroyFunc(function () { return _this.context.destroyBean(comp); });\n if (!this.isAlive()) {\n return;\n }\n this.eFloatingFilterBody.appendChild(comp.getGui());\n if (comp.afterGuiAttached) {\n comp.afterGuiAttached();\n }\n };\n HeaderFilterCellComp.TEMPLATE = \"
\\n
\\n
\\n \\n
\\n
\";\n __decorate([\n RefSelector('eFloatingFilterBody')\n ], HeaderFilterCellComp.prototype, \"eFloatingFilterBody\", void 0);\n __decorate([\n RefSelector('eButtonWrapper')\n ], HeaderFilterCellComp.prototype, \"eButtonWrapper\", void 0);\n __decorate([\n RefSelector('eButtonShowMainFilter')\n ], HeaderFilterCellComp.prototype, \"eButtonShowMainFilter\", void 0);\n __decorate([\n PostConstruct\n ], HeaderFilterCellComp.prototype, \"postConstruct\", null);\n return HeaderFilterCellComp;\n}(AbstractHeaderCellComp));\nexport { HeaderFilterCellComp };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Constants } from \"../constants/constants\";\nimport { Autowired, PostConstruct } from \"../context/context\";\nimport { GridOptionsWrapper } from \"../gridOptionsWrapper\";\nimport { BeanStub } from \"../context/beanStub\";\nexport var LayoutCssClasses;\n(function (LayoutCssClasses) {\n LayoutCssClasses[\"AUTO_HEIGHT\"] = \"ag-layout-auto-height\";\n LayoutCssClasses[\"NORMAL\"] = \"ag-layout-normal\";\n LayoutCssClasses[\"PRINT\"] = \"ag-layout-print\";\n})(LayoutCssClasses || (LayoutCssClasses = {}));\nvar LayoutFeature = /** @class */ (function (_super) {\n __extends(LayoutFeature, _super);\n function LayoutFeature(view) {\n var _this = _super.call(this) || this;\n _this.view = view;\n return _this;\n }\n LayoutFeature.prototype.postConstruct = function () {\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_DOM_LAYOUT, this.updateLayoutClasses.bind(this));\n this.updateLayoutClasses();\n };\n LayoutFeature.prototype.updateLayoutClasses = function () {\n var domLayout = this.gridOptionsWrapper.getDomLayout();\n var params = {\n autoHeight: domLayout === Constants.DOM_LAYOUT_AUTO_HEIGHT,\n normal: domLayout === Constants.DOM_LAYOUT_NORMAL,\n print: domLayout === Constants.DOM_LAYOUT_PRINT\n };\n var cssClass = params.autoHeight ? LayoutCssClasses.AUTO_HEIGHT :\n params.print ? LayoutCssClasses.PRINT : LayoutCssClasses.NORMAL;\n this.view.updateLayoutClasses(cssClass, params);\n };\n __decorate([\n Autowired('gridOptionsWrapper')\n ], LayoutFeature.prototype, \"gridOptionsWrapper\", void 0);\n __decorate([\n PostConstruct\n ], LayoutFeature.prototype, \"postConstruct\", null);\n return LayoutFeature;\n}(BeanStub));\nexport { LayoutFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { getInnerHeight, getScrollLeft, isRtlNegativeScroll, setScrollLeft } from \"../utils/dom\";\nimport { Events } from \"../eventKeys\";\nimport { debounce } from \"../utils/function\";\nimport { isIOSUserAgent } from \"../utils/browser\";\nimport { Constants } from \"../constants/constants\";\nvar GridBodyScrollFeature = /** @class */ (function (_super) {\n __extends(GridBodyScrollFeature, _super);\n function GridBodyScrollFeature(eBodyViewport) {\n var _this = _super.call(this) || this;\n _this.scrollLeft = -1;\n _this.nextScrollTop = -1;\n _this.scrollTop = -1;\n _this.eBodyViewport = eBodyViewport;\n _this.resetLastHorizontalScrollElementDebounced = debounce(_this.resetLastHorizontalScrollElement.bind(_this), 500);\n return _this;\n }\n GridBodyScrollFeature.prototype.postConstruct = function () {\n var _this = this;\n this.enableRtl = this.gridOptionsWrapper.isEnableRtl();\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, this.onDisplayedColumnsWidthChanged.bind(this));\n this.ctrlsService.whenReady(function (p) {\n _this.centerRowContainerCtrl = p.centerRowContainerCtrl;\n _this.onDisplayedColumnsWidthChanged();\n _this.addScrollListener();\n });\n };\n GridBodyScrollFeature.prototype.addScrollListener = function () {\n var fakeHScroll = this.ctrlsService.getFakeHScrollCtrl();\n this.addManagedListener(this.centerRowContainerCtrl.getViewportElement(), 'scroll', this.onCenterViewportScroll.bind(this));\n this.addManagedListener(fakeHScroll.getViewport(), 'scroll', this.onFakeHorizontalScroll.bind(this));\n var onVerticalScroll = this.gridOptionsWrapper.isDebounceVerticalScrollbar() ?\n debounce(this.onVerticalScroll.bind(this), 100)\n : this.onVerticalScroll.bind(this);\n this.addManagedListener(this.eBodyViewport, 'scroll', onVerticalScroll);\n };\n GridBodyScrollFeature.prototype.onDisplayedColumnsWidthChanged = function () {\n if (this.enableRtl) {\n // because RTL is all backwards, a change in the width of the row\n // can cause a change in the scroll position, without a scroll event,\n // because the scroll position in RTL is a function that depends on\n // the width. to be convinced of this, take out this line, enable RTL,\n // scroll all the way to the left and then resize a column\n this.horizontallyScrollHeaderCenterAndFloatingCenter();\n }\n };\n GridBodyScrollFeature.prototype.horizontallyScrollHeaderCenterAndFloatingCenter = function (scrollLeft) {\n // when doing RTL, this method gets called once prematurely\n var notYetInitialised = this.centerRowContainerCtrl == null;\n if (notYetInitialised) {\n return;\n }\n if (scrollLeft === undefined) {\n scrollLeft = this.centerRowContainerCtrl.getCenterViewportScrollLeft();\n }\n var offset = this.enableRtl ? scrollLeft : -scrollLeft;\n var topCenterContainer = this.ctrlsService.getTopCenterRowContainerCtrl();\n var stickyTopCenterContainer = this.ctrlsService.getStickyTopCenterRowContainerCtrl();\n var bottomCenterContainer = this.ctrlsService.getBottomCenterRowContainerCtrl();\n var fakeHScroll = this.ctrlsService.getFakeHScrollCtrl();\n var centerHeaderContainer = this.ctrlsService.getHeaderRowContainerCtrl();\n centerHeaderContainer.setHorizontalScroll(offset);\n bottomCenterContainer.setContainerTranslateX(offset);\n topCenterContainer.setContainerTranslateX(offset);\n stickyTopCenterContainer.setContainerTranslateX(offset);\n var centerViewport = this.centerRowContainerCtrl.getViewportElement();\n var isCenterViewportLastHorizontal = this.lastHorizontalScrollElement === centerViewport;\n var partner = isCenterViewportLastHorizontal ?\n fakeHScroll.getViewport() :\n this.centerRowContainerCtrl.getViewportElement();\n setScrollLeft(partner, Math.abs(scrollLeft), this.enableRtl);\n };\n GridBodyScrollFeature.prototype.isControllingScroll = function (eDiv) {\n if (!this.lastHorizontalScrollElement) {\n this.lastHorizontalScrollElement = eDiv;\n return true;\n }\n return eDiv === this.lastHorizontalScrollElement;\n };\n GridBodyScrollFeature.prototype.onFakeHorizontalScroll = function () {\n var fakeHScrollViewport = this.ctrlsService.getFakeHScrollCtrl().getViewport();\n if (!this.isControllingScroll(fakeHScrollViewport)) {\n return;\n }\n this.onBodyHorizontalScroll(fakeHScrollViewport);\n };\n GridBodyScrollFeature.prototype.onCenterViewportScroll = function () {\n var centerContainerViewport = this.centerRowContainerCtrl.getViewportElement();\n if (!this.isControllingScroll(centerContainerViewport)) {\n return;\n }\n this.onBodyHorizontalScroll(centerContainerViewport);\n };\n GridBodyScrollFeature.prototype.onBodyHorizontalScroll = function (eSource) {\n var centerContainerViewport = this.centerRowContainerCtrl.getViewportElement();\n var scrollLeft = centerContainerViewport.scrollLeft;\n if (this.shouldBlockScrollUpdate('horizontal', scrollLeft, true)) {\n return;\n }\n // we do Math.round() rather than Math.floor(), to mirror how scroll values are applied.\n // eg if a scale is applied (ie user has zoomed the browser), then applying scroll=200\n // could result in 199.88, which then floor(199.88) = 199, however round(199.88) = 200.\n // initially Math.floor() was used, however this caused (almost) infinite loop with aligned grids,\n // as the scroll would move 1px at at time bouncing from one grid to the next (eg one grid would cause\n // scroll to 200px, the next to 199px, then the first back to 198px and so on).\n this.doHorizontalScroll(Math.round(getScrollLeft(eSource, this.enableRtl)));\n this.resetLastHorizontalScrollElementDebounced();\n };\n GridBodyScrollFeature.prototype.onVerticalScroll = function () {\n var scrollTop = this.eBodyViewport.scrollTop;\n if (this.shouldBlockScrollUpdate('vertical', scrollTop, true)) {\n return;\n }\n this.animationFrameService.setScrollTop(scrollTop);\n this.nextScrollTop = scrollTop;\n if (this.gridOptionsWrapper.isSuppressAnimationFrame()) {\n this.scrollTop = this.nextScrollTop;\n this.redrawRowsAfterScroll();\n }\n else {\n this.animationFrameService.schedule();\n }\n };\n GridBodyScrollFeature.prototype.resetLastHorizontalScrollElement = function () {\n this.lastHorizontalScrollElement = null;\n };\n GridBodyScrollFeature.prototype.doHorizontalScroll = function (scrollLeft) {\n var fakeHScrollViewport = this.ctrlsService.getFakeHScrollCtrl().getViewport();\n var fakeScrollLeft = getScrollLeft(fakeHScrollViewport, this.enableRtl);\n if (this.scrollLeft === scrollLeft && scrollLeft === fakeScrollLeft) {\n return;\n }\n this.scrollLeft = scrollLeft;\n this.fireScrollEvent('horizontal');\n this.horizontallyScrollHeaderCenterAndFloatingCenter(scrollLeft);\n this.onHorizontalViewportChanged();\n };\n GridBodyScrollFeature.prototype.fireScrollEvent = function (direction) {\n var _this = this;\n var bodyScrollEvent = {\n type: Events.EVENT_BODY_SCROLL,\n direction: direction,\n left: this.scrollLeft,\n top: this.scrollTop\n };\n this.eventService.dispatchEvent(bodyScrollEvent);\n window.clearTimeout(this.scrollTimer);\n this.scrollTimer = undefined;\n this.scrollTimer = window.setTimeout(function () {\n var bodyScrollEndEvent = Object.assign({}, bodyScrollEvent, {\n type: Events.EVENT_BODY_SCROLL_END\n });\n _this.eventService.dispatchEvent(bodyScrollEndEvent);\n }, 100);\n };\n GridBodyScrollFeature.prototype.shouldBlockScrollUpdate = function (direction, scrollTo, touchOnly) {\n // touch devices allow elastic scroll - which temporally scrolls the panel outside of the viewport\n // (eg user uses touch to go to the left of the grid, but drags past the left, the rows will actually\n // scroll past the left until the user releases the mouse). when this happens, we want ignore the scroll,\n // as otherwise it was causing the rows and header to flicker.\n if (touchOnly === void 0) { touchOnly = false; }\n // sometimes when scrolling, we got values that extended the maximum scroll allowed. we used to\n // ignore these scrolls. problem is the max scroll position could be skipped (eg the previous scroll event\n // could be 10px before the max position, and then current scroll event could be 20px after the max position).\n // if we just ignored the last event, we would be setting the scroll to 10px before the max position, when in\n // actual fact the user has exceeded the max scroll and thus scroll should be set to the max.\n if (touchOnly && !isIOSUserAgent()) {\n return false;\n }\n if (direction === 'vertical') {\n var clientHeight = getInnerHeight(this.eBodyViewport);\n var scrollHeight = this.eBodyViewport.scrollHeight;\n if (scrollTo < 0 || (scrollTo + clientHeight > scrollHeight)) {\n return true;\n }\n }\n if (direction === 'horizontal') {\n var clientWidth = this.centerRowContainerCtrl.getCenterWidth();\n var scrollWidth = this.centerRowContainerCtrl.getViewportElement().scrollWidth;\n if (this.enableRtl && isRtlNegativeScroll()) {\n if (scrollTo > 0) {\n return true;\n }\n }\n else if (scrollTo < 0) {\n return true;\n }\n if (Math.abs(scrollTo) + clientWidth > scrollWidth) {\n return true;\n }\n }\n return false;\n };\n GridBodyScrollFeature.prototype.redrawRowsAfterScroll = function () {\n this.fireScrollEvent('vertical');\n };\n GridBodyScrollFeature.prototype.onHorizontalViewportChanged = function () {\n this.centerRowContainerCtrl.onHorizontalViewportChanged();\n };\n // this is to cater for AG-3274, where grid is removed from the dom and then inserted back in again.\n // (which happens with some implementations of tabbing). this can result in horizontal scroll getting\n // reset back to the left, however no scroll event is fired. so we need to get header to also scroll\n // back to the left to be kept in sync.\n // adding and removing the grid from the DOM both resets the scroll position and\n // triggers a resize event, so notify listeners if the scroll position has changed\n GridBodyScrollFeature.prototype.checkScrollLeft = function () {\n if (this.scrollLeft !== this.centerRowContainerCtrl.getCenterViewportScrollLeft()) {\n this.onBodyHorizontalScroll(this.centerRowContainerCtrl.getViewportElement());\n }\n };\n GridBodyScrollFeature.prototype.executeAnimationFrameScroll = function () {\n var frameNeeded = this.scrollTop != this.nextScrollTop;\n if (frameNeeded) {\n this.scrollTop = this.nextScrollTop;\n this.redrawRowsAfterScroll();\n }\n return frameNeeded;\n };\n // called by scrollHorizontally method and alignedGridsService\n GridBodyScrollFeature.prototype.setHorizontalScrollPosition = function (hScrollPosition) {\n var minScrollLeft = 0;\n var maxScrollLeft = this.centerRowContainerCtrl.getViewportElement().scrollWidth - this.centerRowContainerCtrl.getCenterWidth();\n if (this.shouldBlockScrollUpdate('horizontal', hScrollPosition)) {\n if (this.enableRtl && isRtlNegativeScroll()) {\n hScrollPosition = hScrollPosition > 0 ? 0 : maxScrollLeft;\n }\n else {\n hScrollPosition = Math.min(Math.max(hScrollPosition, minScrollLeft), maxScrollLeft);\n }\n }\n setScrollLeft(this.centerRowContainerCtrl.getViewportElement(), Math.abs(hScrollPosition), this.enableRtl);\n // we need to manually do the event handling (rather than wait for the event)\n // for the alignedGridsService, as if we don't, the aligned grid service gets\n // notified async, and then it's 'consuming' flag doesn't get used right, and\n // we can end up with an infinite loop\n this.doHorizontalScroll(hScrollPosition);\n };\n GridBodyScrollFeature.prototype.setVerticalScrollPosition = function (vScrollPosition) {\n this.eBodyViewport.scrollTop = vScrollPosition;\n };\n GridBodyScrollFeature.prototype.getVScrollPosition = function () {\n var result = {\n top: this.eBodyViewport.scrollTop,\n bottom: this.eBodyViewport.scrollTop + this.eBodyViewport.offsetHeight\n };\n return result;\n };\n GridBodyScrollFeature.prototype.getHScrollPosition = function () {\n return this.centerRowContainerCtrl.getHScrollPosition();\n };\n GridBodyScrollFeature.prototype.isHorizontalScrollShowing = function () {\n return this.centerRowContainerCtrl.isHorizontalScrollShowing();\n };\n // called by the headerRootComp and moveColumnController\n GridBodyScrollFeature.prototype.scrollHorizontally = function (pixels) {\n var oldScrollPosition = this.centerRowContainerCtrl.getViewportElement().scrollLeft;\n this.setHorizontalScrollPosition(oldScrollPosition + pixels);\n return this.centerRowContainerCtrl.getViewportElement().scrollLeft - oldScrollPosition;\n };\n // gets called by rowRenderer when new data loaded, as it will want to scroll to the top\n GridBodyScrollFeature.prototype.scrollToTop = function () {\n this.eBodyViewport.scrollTop = 0;\n };\n // Valid values for position are bottom, middle and top\n GridBodyScrollFeature.prototype.ensureNodeVisible = function (comparator, position) {\n if (position === void 0) { position = null; }\n // look for the node index we want to display\n var rowCount = this.rowModel.getRowCount();\n var indexToSelect = -1;\n // go through all the nodes, find the one we want to show\n for (var i = 0; i < rowCount; i++) {\n var node = this.rowModel.getRow(i);\n if (typeof comparator === 'function') {\n // Have to assert type here, as type could be TData & Function\n var predicate = comparator;\n if (node && predicate(node)) {\n indexToSelect = i;\n break;\n }\n }\n else {\n // check object equality against node and data\n if (comparator === node || comparator === node.data) {\n indexToSelect = i;\n break;\n }\n }\n }\n if (indexToSelect >= 0) {\n this.ensureIndexVisible(indexToSelect, position);\n }\n };\n // Valid values for position are bottom, middle and top\n // position should be {'top','middle','bottom', or undefined/null}.\n // if undefined/null, then the grid will to the minimal amount of scrolling,\n // eg if grid needs to scroll up, it scrolls until row is on top,\n // if grid needs to scroll down, it scrolls until row is on bottom,\n // if row is already in view, grid does not scroll\n GridBodyScrollFeature.prototype.ensureIndexVisible = function (index, position) {\n // if for print or auto height, everything is always visible\n if (this.gridOptionsWrapper.getDomLayout() === Constants.DOM_LAYOUT_PRINT) {\n return;\n }\n var rowCount = this.paginationProxy.getRowCount();\n if (typeof index !== 'number' || index < 0 || index >= rowCount) {\n console.warn('invalid row index for ensureIndexVisible: ' + index);\n return;\n }\n var isPaging = this.gridOptionsWrapper.isPagination();\n var paginationPanelEnabled = isPaging && !this.gridOptionsWrapper.isSuppressPaginationPanel();\n if (!paginationPanelEnabled) {\n this.paginationProxy.goToPageWithIndex(index);\n }\n var gridBodyCtrl = this.ctrlsService.getGridBodyCtrl();\n var stickyTopHeight = gridBodyCtrl.getStickyTopHeight();\n var rowNode = this.paginationProxy.getRow(index);\n var rowGotShiftedDuringOperation;\n do {\n var startingRowTop = rowNode.rowTop;\n var startingRowHeight = rowNode.rowHeight;\n var paginationOffset = this.paginationProxy.getPixelOffset();\n var rowTopPixel = rowNode.rowTop - paginationOffset;\n var rowBottomPixel = rowTopPixel + rowNode.rowHeight;\n var scrollPosition = this.getVScrollPosition();\n var heightOffset = this.heightScaler.getDivStretchOffset();\n var vScrollTop = scrollPosition.top + heightOffset;\n var vScrollBottom = scrollPosition.bottom + heightOffset;\n var viewportHeight = vScrollBottom - vScrollTop;\n // work out the pixels for top, middle and bottom up front,\n // make the if/else below easier to read\n var pxTop = this.heightScaler.getScrollPositionForPixel(rowTopPixel);\n var pxBottom = this.heightScaler.getScrollPositionForPixel(rowBottomPixel - viewportHeight);\n // make sure if middle, the row is not outside the top of the grid\n var pxMiddle = Math.min((pxTop + pxBottom) / 2, rowTopPixel);\n var rowAboveViewport = (vScrollTop + stickyTopHeight) > rowTopPixel;\n var rowBelowViewport = vScrollBottom < rowBottomPixel;\n var newScrollPosition = null;\n if (position === 'top') {\n newScrollPosition = pxTop;\n }\n else if (position === 'bottom') {\n newScrollPosition = pxBottom;\n }\n else if (position === 'middle') {\n newScrollPosition = pxMiddle;\n }\n else if (rowAboveViewport) {\n // if row is before, scroll up with row at top\n newScrollPosition = pxTop - stickyTopHeight;\n }\n else if (rowBelowViewport) {\n // if row is after, scroll down with row at bottom\n newScrollPosition = pxBottom;\n }\n if (newScrollPosition !== null) {\n this.eBodyViewport.scrollTop = newScrollPosition;\n this.rowRenderer.redrawAfterScroll();\n }\n // the row can get shifted if during the rendering (during rowRenderer.redrawAfterScroll()),\n // the height of a row changes due to lazy calculation of row heights when using\n // colDef.autoHeight or gridOptions.getRowHeight.\n // if row was shifted, then the position we scrolled to is incorrect.\n rowGotShiftedDuringOperation = (startingRowTop !== rowNode.rowTop)\n || (startingRowHeight !== rowNode.rowHeight);\n } while (rowGotShiftedDuringOperation);\n // so when we return back to user, the cells have rendered\n this.animationFrameService.flushAllFrames();\n };\n GridBodyScrollFeature.prototype.ensureColumnVisible = function (key, position) {\n if (position === void 0) { position = 'auto'; }\n var column = this.columnModel.getGridColumn(key);\n if (!column) {\n return;\n }\n // calling ensureColumnVisible on a pinned column doesn't make sense\n if (column.isPinned()) {\n return;\n }\n // defensive\n if (!this.columnModel.isColumnDisplayed(column)) {\n return;\n }\n var newHorizontalScroll = this.getPositionedHorizontalScroll(column, position);\n if (newHorizontalScroll !== null) {\n this.centerRowContainerCtrl.setCenterViewportScrollLeft(newHorizontalScroll);\n }\n // this will happen anyway, as the move will cause a 'scroll' event on the body, however\n // it is possible that the ensureColumnVisible method is called from within AG Grid and\n // the caller will need to have the columns rendered to continue, which will be before\n // the event has been worked on (which is the case for cell navigation).\n this.centerRowContainerCtrl.onHorizontalViewportChanged();\n // so when we return back to user, the cells have rendered\n this.animationFrameService.flushAllFrames();\n };\n GridBodyScrollFeature.prototype.getPositionedHorizontalScroll = function (column, position) {\n var _a = this.isColumnOutsideViewport(column), columnBeforeStart = _a.columnBeforeStart, columnAfterEnd = _a.columnAfterEnd;\n var viewportTooSmallForColumn = this.centerRowContainerCtrl.getCenterWidth() < column.getActualWidth();\n var viewportWidth = this.centerRowContainerCtrl.getCenterWidth();\n var isRtl = this.enableRtl;\n var alignColToStart = (isRtl ? columnBeforeStart : columnAfterEnd) || viewportTooSmallForColumn;\n var alignColToEnd = isRtl ? columnAfterEnd : columnBeforeStart;\n if (position !== 'auto') {\n alignColToStart = position === 'start';\n alignColToEnd = position === 'end';\n }\n var isMiddle = position === 'middle';\n if (alignColToStart || alignColToEnd || isMiddle) {\n var _b = this.getColumnBounds(column), colLeft = _b.colLeft, colMiddle = _b.colMiddle, colRight = _b.colRight;\n if (isMiddle) {\n return colMiddle - viewportWidth / 2;\n }\n if (alignColToStart) {\n return isRtl ? colRight : colLeft;\n }\n return isRtl ? (colLeft - viewportWidth) : (colRight - viewportWidth);\n }\n return null;\n };\n GridBodyScrollFeature.prototype.isColumnOutsideViewport = function (column) {\n var _a = this.getViewportBounds(), viewportStart = _a.start, viewportEnd = _a.end;\n var _b = this.getColumnBounds(column), colLeft = _b.colLeft, colRight = _b.colRight;\n var isRtl = this.enableRtl;\n var columnBeforeStart = isRtl ? (viewportStart > colRight) : (viewportEnd < colRight);\n var columnAfterEnd = isRtl ? (viewportEnd < colLeft) : (viewportStart > colLeft);\n return { columnBeforeStart: columnBeforeStart, columnAfterEnd: columnAfterEnd };\n };\n GridBodyScrollFeature.prototype.getColumnBounds = function (column) {\n var isRtl = this.enableRtl;\n var bodyWidth = this.columnModel.getBodyContainerWidth();\n var colWidth = column.getActualWidth();\n var colLeft = column.getLeft();\n var multiplier = isRtl ? -1 : 1;\n var colLeftPixel = isRtl ? (bodyWidth - colLeft) : colLeft;\n var colRightPixel = colLeftPixel + colWidth * multiplier;\n var colMidPixel = colLeftPixel + colWidth / 2 * multiplier;\n return { colLeft: colLeftPixel, colMiddle: colMidPixel, colRight: colRightPixel };\n };\n GridBodyScrollFeature.prototype.getViewportBounds = function () {\n var viewportWidth = this.centerRowContainerCtrl.getCenterWidth();\n var scrollPosition = this.centerRowContainerCtrl.getCenterViewportScrollLeft();\n var viewportStartPixel = scrollPosition;\n var viewportEndPixel = viewportWidth + scrollPosition;\n return { start: viewportStartPixel, end: viewportEndPixel, width: viewportWidth };\n };\n __decorate([\n Autowired('ctrlsService')\n ], GridBodyScrollFeature.prototype, \"ctrlsService\", void 0);\n __decorate([\n Autowired('animationFrameService')\n ], GridBodyScrollFeature.prototype, \"animationFrameService\", void 0);\n __decorate([\n Autowired('paginationProxy')\n ], GridBodyScrollFeature.prototype, \"paginationProxy\", void 0);\n __decorate([\n Autowired('rowModel')\n ], GridBodyScrollFeature.prototype, \"rowModel\", void 0);\n __decorate([\n Autowired('rowContainerHeightService')\n ], GridBodyScrollFeature.prototype, \"heightScaler\", void 0);\n __decorate([\n Autowired('rowRenderer')\n ], GridBodyScrollFeature.prototype, \"rowRenderer\", void 0);\n __decorate([\n Autowired('columnModel')\n ], GridBodyScrollFeature.prototype, \"columnModel\", void 0);\n __decorate([\n PostConstruct\n ], GridBodyScrollFeature.prototype, \"postConstruct\", null);\n return GridBodyScrollFeature;\n}(BeanStub));\nexport { GridBodyScrollFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar AutoScrollService = /** @class */ (function () {\n function AutoScrollService(params) {\n this.tickingInterval = null;\n this.onScrollCallback = null;\n this.scrollContainer = params.scrollContainer;\n this.scrollHorizontally = params.scrollAxis.indexOf('x') !== -1;\n this.scrollVertically = params.scrollAxis.indexOf('y') !== -1;\n this.scrollByTick = params.scrollByTick != null ? params.scrollByTick : 20;\n if (params.onScrollCallback) {\n this.onScrollCallback = params.onScrollCallback;\n }\n if (this.scrollVertically) {\n this.getVerticalPosition = params.getVerticalPosition;\n this.setVerticalPosition = params.setVerticalPosition;\n }\n if (this.scrollHorizontally) {\n this.getHorizontalPosition = params.getHorizontalPosition;\n this.setHorizontalPosition = params.setHorizontalPosition;\n }\n this.shouldSkipVerticalScroll = params.shouldSkipVerticalScroll || (function () { return false; });\n this.shouldSkipHorizontalScroll = params.shouldSkipHorizontalScroll || (function () { return false; });\n }\n AutoScrollService.prototype.check = function (mouseEvent, forceSkipVerticalScroll) {\n if (forceSkipVerticalScroll === void 0) { forceSkipVerticalScroll = false; }\n var skipVerticalScroll = forceSkipVerticalScroll || this.shouldSkipVerticalScroll();\n if (skipVerticalScroll && this.shouldSkipHorizontalScroll()) {\n return;\n }\n var rect = this.scrollContainer.getBoundingClientRect();\n var scrollTick = this.scrollByTick;\n this.tickLeft = mouseEvent.clientX < (rect.left + scrollTick);\n this.tickRight = mouseEvent.clientX > (rect.right - scrollTick);\n this.tickUp = mouseEvent.clientY < (rect.top + scrollTick) && !skipVerticalScroll;\n this.tickDown = mouseEvent.clientY > (rect.bottom - scrollTick) && !skipVerticalScroll;\n if (this.tickLeft || this.tickRight || this.tickUp || this.tickDown) {\n this.ensureTickingStarted();\n }\n else {\n this.ensureCleared();\n }\n };\n AutoScrollService.prototype.ensureTickingStarted = function () {\n if (this.tickingInterval === null) {\n this.tickingInterval = window.setInterval(this.doTick.bind(this), 100);\n this.tickCount = 0;\n }\n };\n AutoScrollService.prototype.doTick = function () {\n this.tickCount++;\n var tickAmount;\n tickAmount = this.tickCount > 20 ? 200 : (this.tickCount > 10 ? 80 : 40);\n if (this.scrollVertically) {\n var vScrollPosition = this.getVerticalPosition();\n if (this.tickUp) {\n this.setVerticalPosition(vScrollPosition - tickAmount);\n }\n if (this.tickDown) {\n this.setVerticalPosition(vScrollPosition + tickAmount);\n }\n }\n if (this.scrollHorizontally) {\n var hScrollPosition = this.getHorizontalPosition();\n if (this.tickLeft) {\n this.setHorizontalPosition(hScrollPosition - tickAmount);\n }\n if (this.tickRight) {\n this.setHorizontalPosition(hScrollPosition + tickAmount);\n }\n }\n if (this.onScrollCallback) {\n this.onScrollCallback();\n }\n };\n AutoScrollService.prototype.ensureCleared = function () {\n if (this.tickingInterval) {\n window.clearInterval(this.tickingInterval);\n this.tickingInterval = null;\n }\n };\n return AutoScrollService;\n}());\nexport { AutoScrollService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nimport { DragAndDropService, DragSourceType, VerticalDirection } from \"../dragAndDrop/dragAndDropService\";\nimport { Autowired, Optional, PostConstruct } from \"../context/context\";\nimport { Events } from \"../eventKeys\";\nimport { RowHighlightPosition } from \"../entities/rowNode\";\nimport { last } from '../utils/array';\nimport { BeanStub } from \"../context/beanStub\";\nimport { missingOrEmpty } from \"../utils/generic\";\nimport { doOnce } from \"../utils/function\";\nimport { AutoScrollService } from \"../autoScrollService\";\nvar RowDragFeature = /** @class */ (function (_super) {\n __extends(RowDragFeature, _super);\n function RowDragFeature(eContainer) {\n var _this = _super.call(this) || this;\n _this.isMultiRowDrag = false;\n _this.isGridSorted = false;\n _this.isGridFiltered = false;\n _this.isRowGroupActive = false;\n _this.eContainer = eContainer;\n return _this;\n }\n RowDragFeature.prototype.postConstruct = function () {\n var _this = this;\n if (this.gridOptionsWrapper.isRowModelDefault()) {\n this.clientSideRowModel = this.rowModel;\n }\n var refreshStatus = function () {\n _this.onSortChanged();\n _this.onFilterChanged();\n _this.onRowGroupChanged();\n };\n this.addManagedListener(this.eventService, Events.EVENT_SORT_CHANGED, this.onSortChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_FILTER_CHANGED, this.onFilterChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, this.onRowGroupChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_MODEL_UPDATED, function () {\n refreshStatus();\n });\n refreshStatus();\n this.ctrlsService.whenReady(function () {\n var gridBodyCon = _this.ctrlsService.getGridBodyCtrl();\n _this.autoScrollService = new AutoScrollService({\n scrollContainer: gridBodyCon.getBodyViewportElement(),\n scrollAxis: 'y',\n getVerticalPosition: function () { return gridBodyCon.getScrollFeature().getVScrollPosition().top; },\n setVerticalPosition: function (position) { return gridBodyCon.getScrollFeature().setVerticalScrollPosition(position); },\n onScrollCallback: function () { _this.onDragging(_this.lastDraggingEvent); }\n });\n });\n };\n RowDragFeature.prototype.onSortChanged = function () {\n this.isGridSorted = this.sortController.isSortActive();\n };\n RowDragFeature.prototype.onFilterChanged = function () {\n this.isGridFiltered = this.filterManager.isAnyFilterPresent();\n };\n RowDragFeature.prototype.onRowGroupChanged = function () {\n var rowGroups = this.columnModel.getRowGroupColumns();\n this.isRowGroupActive = !missingOrEmpty(rowGroups);\n };\n RowDragFeature.prototype.getContainer = function () {\n return this.eContainer;\n };\n RowDragFeature.prototype.isInterestedIn = function (type) {\n return type === DragSourceType.RowDrag;\n };\n RowDragFeature.prototype.getIconName = function () {\n var managedDrag = this.gridOptionsWrapper.isRowDragManaged();\n if (managedDrag && this.shouldPreventRowMove()) {\n return DragAndDropService.ICON_NOT_ALLOWED;\n }\n return DragAndDropService.ICON_MOVE;\n };\n RowDragFeature.prototype.shouldPreventRowMove = function () {\n return this.isGridSorted || this.isGridFiltered || this.isRowGroupActive;\n };\n RowDragFeature.prototype.getRowNodes = function (draggingEvent) {\n var _this = this;\n if (!this.isFromThisGrid(draggingEvent)) {\n return draggingEvent.dragItem.rowNodes || [];\n }\n var isRowDragMultiRow = this.gridOptionsWrapper.isRowDragMultiRow();\n var selectedNodes = __spread(this.selectionService.getSelectedNodes()).sort(function (a, b) {\n if (a.rowIndex == null || b.rowIndex == null) {\n return 0;\n }\n return _this.getRowIndexNumber(a) - _this.getRowIndexNumber(b);\n });\n var currentNode = draggingEvent.dragItem.rowNode;\n if (isRowDragMultiRow && selectedNodes.indexOf(currentNode) !== -1) {\n this.isMultiRowDrag = true;\n return selectedNodes;\n }\n this.isMultiRowDrag = false;\n return [currentNode];\n };\n RowDragFeature.prototype.onDragEnter = function (draggingEvent) {\n // builds a lits of all rows being dragged before firing events\n draggingEvent.dragItem.rowNodes = this.getRowNodes(draggingEvent);\n // when entering, we fire the enter event, then in onEnterOrDragging,\n // we also fire the move event. so we get both events when entering.\n this.dispatchGridEvent(Events.EVENT_ROW_DRAG_ENTER, draggingEvent);\n this.getRowNodes(draggingEvent).forEach(function (rowNode) {\n rowNode.setDragging(true);\n });\n this.onEnterOrDragging(draggingEvent);\n };\n RowDragFeature.prototype.onDragging = function (draggingEvent) {\n this.onEnterOrDragging(draggingEvent);\n };\n RowDragFeature.prototype.isFromThisGrid = function (draggingEvent) {\n var dragSourceDomDataKey = draggingEvent.dragSource.dragSourceDomDataKey;\n return dragSourceDomDataKey === this.gridOptionsWrapper.getDomDataKey();\n };\n RowDragFeature.prototype.isDropZoneWithinThisGrid = function (draggingEvent) {\n var gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n var gridGui = gridBodyCon.getGui();\n var dropZoneTarget = draggingEvent.dropZoneTarget;\n return !gridGui.contains(dropZoneTarget);\n };\n RowDragFeature.prototype.onEnterOrDragging = function (draggingEvent) {\n // this event is fired for enter and move\n this.dispatchGridEvent(Events.EVENT_ROW_DRAG_MOVE, draggingEvent);\n this.lastDraggingEvent = draggingEvent;\n var pixel = this.mouseEventService.getNormalisedPosition(draggingEvent).y;\n var managedDrag = this.gridOptionsWrapper.isRowDragManaged();\n if (managedDrag) {\n this.doManagedDrag(draggingEvent, pixel);\n }\n this.autoScrollService.check(draggingEvent.event);\n };\n RowDragFeature.prototype.doManagedDrag = function (draggingEvent, pixel) {\n var isFromThisGrid = this.isFromThisGrid(draggingEvent);\n var managedDrag = this.gridOptionsWrapper.isRowDragManaged();\n var rowNodes = draggingEvent.dragItem.rowNodes;\n if (managedDrag && this.shouldPreventRowMove()) {\n return;\n }\n if (this.gridOptionsWrapper.isSuppressMoveWhenRowDragging() || !isFromThisGrid) {\n if (!this.isDropZoneWithinThisGrid(draggingEvent)) {\n this.clientSideRowModel.highlightRowAtPixel(rowNodes[0], pixel);\n }\n }\n else {\n this.moveRows(rowNodes, pixel);\n }\n };\n RowDragFeature.prototype.getRowIndexNumber = function (rowNode) {\n return parseInt(last(rowNode.getRowIndexString().split('-')), 10);\n };\n RowDragFeature.prototype.moveRowAndClearHighlight = function (draggingEvent) {\n var _this = this;\n var lastHighlightedRowNode = this.clientSideRowModel.getLastHighlightedRowNode();\n var isBelow = lastHighlightedRowNode && lastHighlightedRowNode.highlighted === RowHighlightPosition.Below;\n var pixel = this.mouseEventService.getNormalisedPosition(draggingEvent).y;\n var rowNodes = draggingEvent.dragItem.rowNodes;\n var increment = isBelow ? 1 : 0;\n if (this.isFromThisGrid(draggingEvent)) {\n rowNodes.forEach(function (rowNode) {\n if (rowNode.rowTop < pixel) {\n increment -= 1;\n }\n });\n this.moveRows(rowNodes, pixel, increment);\n }\n else {\n var getRowIdFunc_1 = this.gridOptionsWrapper.getRowIdFunc();\n var addIndex = this.clientSideRowModel.getRowIndexAtPixel(pixel) + 1;\n if (this.clientSideRowModel.getHighlightPosition(pixel) === RowHighlightPosition.Above) {\n addIndex--;\n }\n this.clientSideRowModel.updateRowData({\n add: rowNodes\n .map(function (node) { return node.data; })\n .filter(function (data) { return !_this.clientSideRowModel.getRowNode(getRowIdFunc_1 ? getRowIdFunc_1({ data: data, level: 0 }) : data.id); }),\n addIndex: addIndex\n });\n }\n this.clearRowHighlight();\n };\n RowDragFeature.prototype.clearRowHighlight = function () {\n this.clientSideRowModel.highlightRowAtPixel(null);\n };\n RowDragFeature.prototype.moveRows = function (rowNodes, pixel, increment) {\n if (increment === void 0) { increment = 0; }\n var rowWasMoved = this.clientSideRowModel.ensureRowsAtPixel(rowNodes, pixel, increment);\n if (rowWasMoved) {\n this.focusService.clearFocusedCell();\n if (this.rangeService) {\n this.rangeService.removeAllCellRanges();\n }\n }\n };\n RowDragFeature.prototype.addRowDropZone = function (params) {\n var _this = this;\n if (!params.getContainer()) {\n doOnce(function () { return console.warn('AG Grid: addRowDropZone - A container target needs to be provided'); }, 'add-drop-zone-empty-target');\n return;\n }\n if (this.dragAndDropService.findExternalZone(params)) {\n console.warn('AG Grid: addRowDropZone - target already exists in the list of DropZones. Use `removeRowDropZone` before adding it again.');\n return;\n }\n var processedParams = {\n getContainer: params.getContainer\n };\n if (params.fromGrid) {\n params.fromGrid = undefined;\n processedParams = params;\n }\n else {\n if (params.onDragEnter) {\n processedParams.onDragEnter = function (e) {\n params.onDragEnter(_this.draggingToRowDragEvent(Events.EVENT_ROW_DRAG_ENTER, e));\n };\n }\n if (params.onDragLeave) {\n processedParams.onDragLeave = function (e) {\n params.onDragLeave(_this.draggingToRowDragEvent(Events.EVENT_ROW_DRAG_LEAVE, e));\n };\n }\n if (params.onDragging) {\n processedParams.onDragging = function (e) {\n params.onDragging(_this.draggingToRowDragEvent(Events.EVENT_ROW_DRAG_MOVE, e));\n };\n }\n if (params.onDragStop) {\n processedParams.onDragStop = function (e) {\n params.onDragStop(_this.draggingToRowDragEvent(Events.EVENT_ROW_DRAG_END, e));\n };\n }\n }\n this.dragAndDropService.addDropTarget(__assign({ isInterestedIn: function (type) { return type === DragSourceType.RowDrag; }, getIconName: function () { return DragAndDropService.ICON_MOVE; }, external: true }, processedParams));\n };\n RowDragFeature.prototype.getRowDropZone = function (events) {\n var _this = this;\n var getContainer = this.getContainer.bind(this);\n var onDragEnter = this.onDragEnter.bind(this);\n var onDragLeave = this.onDragLeave.bind(this);\n var onDragging = this.onDragging.bind(this);\n var onDragStop = this.onDragStop.bind(this);\n if (!events) {\n return { getContainer: getContainer, onDragEnter: onDragEnter, onDragLeave: onDragLeave, onDragging: onDragging, onDragStop: onDragStop, /* @private */ fromGrid: true };\n }\n return {\n getContainer: getContainer,\n onDragEnter: events.onDragEnter\n ? (function (e) {\n onDragEnter(e);\n events.onDragEnter(_this.draggingToRowDragEvent(Events.EVENT_ROW_DRAG_ENTER, e));\n })\n : onDragEnter,\n onDragLeave: events.onDragLeave\n ? (function (e) {\n onDragLeave(e);\n events.onDragLeave(_this.draggingToRowDragEvent(Events.EVENT_ROW_DRAG_LEAVE, e));\n })\n : onDragLeave,\n onDragging: events.onDragging\n ? (function (e) {\n onDragging(e);\n events.onDragging(_this.draggingToRowDragEvent(Events.EVENT_ROW_DRAG_MOVE, e));\n })\n : onDragging,\n onDragStop: events.onDragStop\n ? (function (e) {\n onDragStop(e);\n events.onDragStop(_this.draggingToRowDragEvent(Events.EVENT_ROW_DRAG_END, e));\n })\n : onDragStop,\n fromGrid: true /* @private */\n };\n };\n RowDragFeature.prototype.draggingToRowDragEvent = function (type, draggingEvent) {\n var yNormalised = this.mouseEventService.getNormalisedPosition(draggingEvent).y;\n var mouseIsPastLastRow = yNormalised > this.paginationProxy.getCurrentPageHeight();\n var overIndex = -1;\n var overNode;\n if (!mouseIsPastLastRow) {\n overIndex = this.rowModel.getRowIndexAtPixel(yNormalised);\n overNode = this.rowModel.getRow(overIndex);\n }\n var vDirectionString;\n switch (draggingEvent.vDirection) {\n case VerticalDirection.Down:\n vDirectionString = 'down';\n break;\n case VerticalDirection.Up:\n vDirectionString = 'up';\n break;\n default:\n vDirectionString = null;\n break;\n }\n var event = {\n type: type,\n api: this.gridOptionsWrapper.getApi(),\n columnApi: this.gridOptionsWrapper.getColumnApi(),\n context: this.gridOptionsWrapper.getContext(),\n event: draggingEvent.event,\n node: draggingEvent.dragItem.rowNode,\n nodes: draggingEvent.dragItem.rowNodes,\n overIndex: overIndex,\n overNode: overNode,\n y: yNormalised,\n vDirection: vDirectionString\n };\n return event;\n };\n RowDragFeature.prototype.dispatchGridEvent = function (type, draggingEvent) {\n var event = this.draggingToRowDragEvent(type, draggingEvent);\n this.eventService.dispatchEvent(event);\n };\n RowDragFeature.prototype.onDragLeave = function (draggingEvent) {\n this.dispatchGridEvent(Events.EVENT_ROW_DRAG_LEAVE, draggingEvent);\n this.stopDragging(draggingEvent);\n if (this.gridOptionsWrapper.isRowDragManaged()) {\n this.clearRowHighlight();\n }\n if (this.isFromThisGrid(draggingEvent)) {\n this.isMultiRowDrag = false;\n }\n };\n RowDragFeature.prototype.onDragStop = function (draggingEvent) {\n this.dispatchGridEvent(Events.EVENT_ROW_DRAG_END, draggingEvent);\n this.stopDragging(draggingEvent);\n if (this.gridOptionsWrapper.isRowDragManaged() &&\n (this.gridOptionsWrapper.isSuppressMoveWhenRowDragging() || !this.isFromThisGrid(draggingEvent)) &&\n !this.isDropZoneWithinThisGrid(draggingEvent)) {\n this.moveRowAndClearHighlight(draggingEvent);\n }\n };\n RowDragFeature.prototype.stopDragging = function (draggingEvent) {\n this.autoScrollService.ensureCleared();\n this.getRowNodes(draggingEvent).forEach(function (rowNode) {\n rowNode.setDragging(false);\n });\n };\n __decorate([\n Autowired('dragAndDropService')\n ], RowDragFeature.prototype, \"dragAndDropService\", void 0);\n __decorate([\n Autowired('rowModel')\n ], RowDragFeature.prototype, \"rowModel\", void 0);\n __decorate([\n Autowired('paginationProxy')\n ], RowDragFeature.prototype, \"paginationProxy\", void 0);\n __decorate([\n Autowired('columnModel')\n ], RowDragFeature.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('focusService')\n ], RowDragFeature.prototype, \"focusService\", void 0);\n __decorate([\n Autowired('sortController')\n ], RowDragFeature.prototype, \"sortController\", void 0);\n __decorate([\n Autowired('filterManager')\n ], RowDragFeature.prototype, \"filterManager\", void 0);\n __decorate([\n Autowired('selectionService')\n ], RowDragFeature.prototype, \"selectionService\", void 0);\n __decorate([\n Autowired('mouseEventService')\n ], RowDragFeature.prototype, \"mouseEventService\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], RowDragFeature.prototype, \"ctrlsService\", void 0);\n __decorate([\n Optional('rangeService')\n ], RowDragFeature.prototype, \"rangeService\", void 0);\n __decorate([\n PostConstruct\n ], RowDragFeature.prototype, \"postConstruct\", null);\n return RowDragFeature;\n}(BeanStub));\nexport { RowDragFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../context/beanStub\";\nimport { Autowired, Optional } from \"../context/context\";\nimport { LayoutFeature } from \"../styling/layoutFeature\";\nimport { Events } from \"../eventKeys\";\nimport { GridBodyScrollFeature } from \"./gridBodyScrollFeature\";\nimport { getInnerWidth, isElementChildOfClass, isVerticalScrollShowing } from \"../utils/dom\";\nimport { RowDragFeature } from \"./rowDragFeature\";\nimport { getTabIndex } from \"../utils/browser\";\nimport { Constants } from \"../constants/constants\";\nexport var RowAnimationCssClasses;\n(function (RowAnimationCssClasses) {\n RowAnimationCssClasses[\"ANIMATION_ON\"] = \"ag-row-animation\";\n RowAnimationCssClasses[\"ANIMATION_OFF\"] = \"ag-row-no-animation\";\n})(RowAnimationCssClasses || (RowAnimationCssClasses = {}));\nexport var CSS_CLASS_CELL_SELECTABLE = 'ag-selectable';\nexport var CSS_CLASS_FORCE_VERTICAL_SCROLL = 'ag-force-vertical-scroll';\nexport var CSS_CLASS_COLUMN_MOVING = 'ag-column-moving';\nvar GridBodyCtrl = /** @class */ (function (_super) {\n __extends(GridBodyCtrl, _super);\n function GridBodyCtrl() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.stickyTopHeight = 0;\n return _this;\n }\n GridBodyCtrl.prototype.getScrollFeature = function () {\n return this.bodyScrollFeature;\n };\n GridBodyCtrl.prototype.getBodyViewportElement = function () {\n return this.eBodyViewport;\n };\n GridBodyCtrl.prototype.setComp = function (comp, eGridBody, eBodyViewport, eTop, eBottom, eStickyTop) {\n this.comp = comp;\n this.eGridBody = eGridBody;\n this.eBodyViewport = eBodyViewport;\n this.eTop = eTop;\n this.eBottom = eBottom;\n this.eStickyTop = eStickyTop;\n this.setCellTextSelection(this.gridOptionsWrapper.isEnableCellTextSelect());\n this.createManagedBean(new LayoutFeature(this.comp));\n this.bodyScrollFeature = this.createManagedBean(new GridBodyScrollFeature(this.eBodyViewport));\n this.addRowDragListener();\n this.setupRowAnimationCssClass();\n this.addEventListeners();\n this.addFocusListeners([eTop, eBodyViewport, eBottom, eStickyTop]);\n this.onGridColumnsChanged();\n this.addBodyViewportListener();\n this.setFloatingHeights();\n this.disableBrowserDragging();\n this.addStopEditingWhenGridLosesFocus();\n this.ctrlsService.registerGridBodyCtrl(this);\n };\n GridBodyCtrl.prototype.getComp = function () {\n return this.comp;\n };\n GridBodyCtrl.prototype.addEventListeners = function () {\n this.addManagedListener(this.eventService, Events.EVENT_GRID_COLUMNS_CHANGED, this.onGridColumnsChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_SCROLL_VISIBILITY_CHANGED, this.onScrollVisibilityChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_PINNED_ROW_DATA_CHANGED, this.onPinnedRowDataChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_HEADER_HEIGHT_CHANGED, this.onHeaderHeightChanged.bind(this));\n };\n GridBodyCtrl.prototype.addFocusListeners = function (elements) {\n var _this = this;\n elements.forEach(function (element) {\n _this.addManagedListener(element, 'focusin', function (e) {\n var target = e.target;\n // element being focused is nested?\n var isFocusedElementNested = isElementChildOfClass(target, 'ag-root', element);\n element.classList.toggle('ag-has-focus', !isFocusedElementNested);\n });\n _this.addManagedListener(element, 'focusout', function (e) {\n var target = e.target, relatedTarget = e.relatedTarget;\n var gridContainRelatedTarget = element.contains(relatedTarget);\n var isNestedRelatedTarget = isElementChildOfClass(relatedTarget, 'ag-root', element);\n var isNestedTarget = isElementChildOfClass(target, 'ag-root', element);\n // element losing focus belongs to a nested grid,\n // it should not be handled here.\n if (isNestedTarget) {\n return;\n }\n // the grid does not contain, or the focus element is within\n // a nested grid\n if (!gridContainRelatedTarget || isNestedRelatedTarget) {\n element.classList.remove('ag-has-focus');\n }\n });\n });\n };\n // used by ColumnAnimationService\n GridBodyCtrl.prototype.setColumnMovingCss = function (moving) {\n this.comp.setColumnMovingCss(moving ? CSS_CLASS_COLUMN_MOVING : null, moving);\n };\n GridBodyCtrl.prototype.setCellTextSelection = function (selectable) {\n if (selectable === void 0) { selectable = false; }\n var cssClass = selectable ? CSS_CLASS_CELL_SELECTABLE : null;\n this.comp.setCellSelectableCss(cssClass, selectable);\n };\n GridBodyCtrl.prototype.onScrollVisibilityChanged = function () {\n var visible = this.scrollVisibleService.isVerticalScrollShowing();\n this.setVerticalScrollPaddingVisible(visible);\n this.setStickyTopWidth(visible);\n };\n GridBodyCtrl.prototype.onGridColumnsChanged = function () {\n var columns = this.columnModel.getAllGridColumns();\n this.comp.setColumnCount(columns ? columns.length : 0);\n };\n // if we do not do this, then the user can select a pic in the grid (eg an image in a custom cell renderer)\n // and then that will start the browser native drag n' drop, which messes up with our own drag and drop.\n GridBodyCtrl.prototype.disableBrowserDragging = function () {\n this.addManagedListener(this.eGridBody, 'dragstart', function (event) {\n if (event.target instanceof HTMLImageElement) {\n event.preventDefault();\n return false;\n }\n });\n };\n GridBodyCtrl.prototype.addStopEditingWhenGridLosesFocus = function () {\n var _this = this;\n if (!this.gridOptionsWrapper.isStopEditingWhenCellsLoseFocus()) {\n return;\n }\n var focusOutListener = function (event) {\n // this is the element the focus is moving to\n var elementWithFocus = event.relatedTarget;\n if (getTabIndex(elementWithFocus) === null) {\n _this.rowRenderer.stopEditing();\n return;\n }\n var clickInsideGrid = \n // see if click came from inside the viewports\n viewports.some(function (viewport) { return viewport.contains(elementWithFocus); })\n // and also that it's not from a detail grid\n && _this.mouseEventService.isElementInThisGrid(elementWithFocus);\n if (!clickInsideGrid) {\n var popupService = _this.popupService;\n clickInsideGrid =\n popupService.getActivePopups().some(function (popup) { return popup.contains(elementWithFocus); }) ||\n popupService.isElementWithinCustomPopup(elementWithFocus);\n }\n if (!clickInsideGrid) {\n _this.rowRenderer.stopEditing();\n }\n };\n var viewports = [this.eBodyViewport, this.eBottom, this.eTop, this.eStickyTop];\n viewports.forEach(function (viewport) { return _this.addManagedListener(viewport, 'focusout', focusOutListener); });\n };\n GridBodyCtrl.prototype.updateRowCount = function () {\n var headerCount = this.headerNavigationService.getHeaderRowCount();\n var rowCount = this.rowModel.isLastRowIndexKnown() ? this.rowModel.getRowCount() : -1;\n var total = rowCount === -1 ? -1 : (headerCount + rowCount);\n this.comp.setRowCount(total);\n };\n GridBodyCtrl.prototype.registerBodyViewportResizeListener = function (listener) {\n this.comp.registerBodyViewportResizeListener(listener);\n };\n GridBodyCtrl.prototype.setVerticalScrollPaddingVisible = function (visible) {\n var overflowY = visible ? 'scroll' : 'hidden';\n this.comp.setPinnedTopBottomOverflowY(overflowY);\n };\n GridBodyCtrl.prototype.isVerticalScrollShowing = function () {\n var show = this.gridOptionsWrapper.isAlwaysShowVerticalScroll();\n var cssClass = show ? CSS_CLASS_FORCE_VERTICAL_SCROLL : null;\n var allowVerticalScroll = this.gridOptionsWrapper.getDomLayout() === Constants.DOM_LAYOUT_NORMAL;\n this.comp.setAlwaysVerticalScrollClass(cssClass, show);\n return show || (allowVerticalScroll && isVerticalScrollShowing(this.eBodyViewport));\n };\n GridBodyCtrl.prototype.setupRowAnimationCssClass = function () {\n var _this = this;\n var listener = function () {\n // we don't want to use row animation if scaling, as rows jump strangely as you scroll,\n // when scaling and doing row animation.\n var animateRows = _this.gridOptionsWrapper.isAnimateRows() && !_this.rowContainerHeightService.isStretching();\n var animateRowsCssClass = animateRows ? RowAnimationCssClasses.ANIMATION_ON : RowAnimationCssClasses.ANIMATION_OFF;\n _this.comp.setRowAnimationCssOnBodyViewport(animateRowsCssClass, animateRows);\n };\n listener();\n this.addManagedListener(this.eventService, Events.EVENT_HEIGHT_SCALE_CHANGED, listener);\n };\n GridBodyCtrl.prototype.getGridBodyElement = function () {\n return this.eGridBody;\n };\n GridBodyCtrl.prototype.addBodyViewportListener = function () {\n var _this = this;\n // we want to listen for clicks directly on the eBodyViewport, so the user has a way of showing\n // the context menu if no rows or columns are displayed, or user simply clicks outside of a cell\n var listener = function (mouseEvent) {\n if (_this.gridOptionsWrapper.isPreventDefaultOnContextMenu()) {\n mouseEvent.preventDefault();\n }\n var target = mouseEvent.target;\n if (target === _this.eBodyViewport || target === _this.ctrlsService.getCenterRowContainerCtrl().getViewportElement()) {\n // show it\n if (_this.contextMenuFactory) {\n _this.contextMenuFactory.onContextMenu(mouseEvent, null, null, null, null, _this.eGridBody);\n }\n }\n };\n this.addManagedListener(this.eBodyViewport, 'contextmenu', listener);\n this.addManagedListener(this.eBodyViewport, 'wheel', this.onBodyViewportWheel.bind(this));\n this.addManagedListener(this.eStickyTop, 'wheel', this.onStickyTopWheel.bind(this));\n };\n GridBodyCtrl.prototype.onBodyViewportWheel = function (e) {\n if (!this.gridOptionsWrapper.isSuppressScrollWhenPopupsAreOpen()) {\n return;\n }\n if (this.popupService.hasAnchoredPopup()) {\n e.preventDefault();\n }\n };\n GridBodyCtrl.prototype.onStickyTopWheel = function (e) {\n e.preventDefault();\n if (e.offsetY) {\n this.scrollVertically(e.deltaY);\n }\n };\n GridBodyCtrl.prototype.getGui = function () {\n return this.eGridBody;\n };\n // called by rowDragFeature\n GridBodyCtrl.prototype.scrollVertically = function (pixels) {\n var oldScrollPosition = this.eBodyViewport.scrollTop;\n this.bodyScrollFeature.setVerticalScrollPosition(oldScrollPosition + pixels);\n return this.eBodyViewport.scrollTop - oldScrollPosition;\n };\n GridBodyCtrl.prototype.addRowDragListener = function () {\n this.rowDragFeature = this.createManagedBean(new RowDragFeature(this.eBodyViewport));\n this.dragAndDropService.addDropTarget(this.rowDragFeature);\n };\n GridBodyCtrl.prototype.getRowDragFeature = function () {\n return this.rowDragFeature;\n };\n GridBodyCtrl.prototype.onPinnedRowDataChanged = function () {\n this.setFloatingHeights();\n };\n GridBodyCtrl.prototype.setFloatingHeights = function () {\n var pinnedRowModel = this.pinnedRowModel;\n var floatingTopHeight = pinnedRowModel.getPinnedTopTotalHeight();\n if (floatingTopHeight) {\n // adding 1px for cell bottom border\n floatingTopHeight += 1;\n }\n var floatingBottomHeight = pinnedRowModel.getPinnedBottomTotalHeight();\n if (floatingBottomHeight) {\n // adding 1px for cell bottom border\n floatingBottomHeight += 1;\n }\n this.comp.setTopHeight(floatingTopHeight);\n this.comp.setBottomHeight(floatingBottomHeight);\n this.comp.setTopDisplay(floatingTopHeight ? 'inherit' : 'none');\n this.comp.setBottomDisplay(floatingBottomHeight ? 'inherit' : 'none');\n this.setStickyTopOffsetTop();\n };\n GridBodyCtrl.prototype.setStickyTopHeight = function (height) {\n if (height === void 0) { height = 0; }\n // console.log('setting sticky top height ' + height);\n this.comp.setStickyTopHeight(height + \"px\");\n this.stickyTopHeight = height;\n };\n GridBodyCtrl.prototype.getStickyTopHeight = function () {\n return this.stickyTopHeight;\n };\n GridBodyCtrl.prototype.setStickyTopWidth = function (vScrollVisible) {\n if (!vScrollVisible) {\n this.comp.setStickyTopWidth('100%');\n }\n else {\n var scrollbarWidth = this.gridOptionsWrapper.getScrollbarWidth();\n this.comp.setStickyTopWidth(\"calc(100% - \" + scrollbarWidth + \"px)\");\n }\n };\n GridBodyCtrl.prototype.onHeaderHeightChanged = function () {\n this.setStickyTopOffsetTop();\n };\n GridBodyCtrl.prototype.setStickyTopOffsetTop = function () {\n var headerCtrl = this.ctrlsService.getGridHeaderCtrl();\n var headerHeight = headerCtrl.getHeaderHeight();\n var pinnedTopHeight = this.pinnedRowModel.getPinnedTopTotalHeight();\n var height = 0;\n if (headerHeight > 0) {\n height += headerHeight + 1;\n }\n if (pinnedTopHeight > 0) {\n height += pinnedTopHeight + 1;\n }\n this.comp.setStickyTopTop(height + \"px\");\n };\n // method will call itself if no available width. this covers if the grid\n // isn't visible, but is just about to be visible.\n GridBodyCtrl.prototype.sizeColumnsToFit = function (params, nextTimeout) {\n var _this = this;\n var removeScrollWidth = this.isVerticalScrollShowing();\n var scrollWidthToRemove = removeScrollWidth ? this.gridOptionsWrapper.getScrollbarWidth() : 0;\n var bodyViewportWidth = getInnerWidth(this.eBodyViewport);\n var availableWidth = bodyViewportWidth - scrollWidthToRemove;\n if (availableWidth > 0) {\n this.columnModel.sizeColumnsToFit(availableWidth, \"sizeColumnsToFit\", false, params);\n return;\n }\n if (nextTimeout === undefined) {\n window.setTimeout(function () {\n _this.sizeColumnsToFit(params, 100);\n }, 0);\n }\n else if (nextTimeout === 100) {\n window.setTimeout(function () {\n _this.sizeColumnsToFit(params, 500);\n }, 100);\n }\n else if (nextTimeout === 500) {\n window.setTimeout(function () {\n _this.sizeColumnsToFit(params, -1);\n }, 500);\n }\n else {\n console.warn('AG Grid: tried to call sizeColumnsToFit() but the grid is coming back with ' +\n 'zero width, maybe the grid is not visible yet on the screen?');\n }\n };\n // + rangeService\n GridBodyCtrl.prototype.addScrollEventListener = function (listener) {\n this.eBodyViewport.addEventListener('scroll', listener);\n };\n // + focusService\n GridBodyCtrl.prototype.removeScrollEventListener = function (listener) {\n this.eBodyViewport.removeEventListener('scroll', listener);\n };\n __decorate([\n Autowired('rowContainerHeightService')\n ], GridBodyCtrl.prototype, \"rowContainerHeightService\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], GridBodyCtrl.prototype, \"ctrlsService\", void 0);\n __decorate([\n Autowired('columnModel')\n ], GridBodyCtrl.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('scrollVisibleService')\n ], GridBodyCtrl.prototype, \"scrollVisibleService\", void 0);\n __decorate([\n Optional('contextMenuFactory')\n ], GridBodyCtrl.prototype, \"contextMenuFactory\", void 0);\n __decorate([\n Autowired('headerNavigationService')\n ], GridBodyCtrl.prototype, \"headerNavigationService\", void 0);\n __decorate([\n Autowired('dragAndDropService')\n ], GridBodyCtrl.prototype, \"dragAndDropService\", void 0);\n __decorate([\n Autowired('pinnedRowModel')\n ], GridBodyCtrl.prototype, \"pinnedRowModel\", void 0);\n __decorate([\n Autowired('rowRenderer')\n ], GridBodyCtrl.prototype, \"rowRenderer\", void 0);\n __decorate([\n Autowired('popupService')\n ], GridBodyCtrl.prototype, \"popupService\", void 0);\n __decorate([\n Autowired('mouseEventService')\n ], GridBodyCtrl.prototype, \"mouseEventService\", void 0);\n __decorate([\n Autowired('rowModel')\n ], GridBodyCtrl.prototype, \"rowModel\", void 0);\n return GridBodyCtrl;\n}(BeanStub));\nexport { GridBodyCtrl };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nexport var SelectionHandleType;\n(function (SelectionHandleType) {\n SelectionHandleType[SelectionHandleType[\"FILL\"] = 0] = \"FILL\";\n SelectionHandleType[SelectionHandleType[\"RANGE\"] = 1] = \"RANGE\";\n})(SelectionHandleType || (SelectionHandleType = {}));\nexport var CellRangeType;\n(function (CellRangeType) {\n CellRangeType[CellRangeType[\"VALUE\"] = 0] = \"VALUE\";\n CellRangeType[CellRangeType[\"DIMENSION\"] = 1] = \"DIMENSION\";\n})(CellRangeType || (CellRangeType = {}));\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nimport { includes, last } from \"../../utils/array\";\nimport { CellRangeType, SelectionHandleType } from \"../../interfaces/IRangeService\";\nimport { missing } from \"../../utils/generic\";\nimport { setAriaSelected } from \"../../utils/aria\";\nvar CSS_CELL_RANGE_SELECTED = 'ag-cell-range-selected';\nvar CSS_CELL_RANGE_CHART = 'ag-cell-range-chart';\nvar CSS_CELL_RANGE_SINGLE_CELL = 'ag-cell-range-single-cell';\nvar CSS_CELL_RANGE_CHART_CATEGORY = 'ag-cell-range-chart-category';\nvar CSS_CELL_RANGE_HANDLE = 'ag-cell-range-handle';\nvar CSS_CELL_RANGE_TOP = 'ag-cell-range-top';\nvar CSS_CELL_RANGE_RIGHT = 'ag-cell-range-right';\nvar CSS_CELL_RANGE_BOTTOM = 'ag-cell-range-bottom';\nvar CSS_CELL_RANGE_LEFT = 'ag-cell-range-left';\nvar CellRangeFeature = /** @class */ (function () {\n function CellRangeFeature(beans, ctrl) {\n this.beans = beans;\n this.cellCtrl = ctrl;\n }\n CellRangeFeature.prototype.setComp = function (cellComp, eGui) {\n this.cellComp = cellComp;\n this.eGui = eGui;\n this.onRangeSelectionChanged();\n };\n CellRangeFeature.prototype.onRangeSelectionChanged = function () {\n // when using reactUi, given UI is async, it's possible this method is called before the comp is registered\n if (!this.cellComp) {\n return;\n }\n this.rangeCount = this.beans.rangeService.getCellRangeCount(this.cellCtrl.getCellPosition());\n this.hasChartRange = this.getHasChartRange();\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_SELECTED, this.rangeCount !== 0);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_SELECTED + \"-1\", this.rangeCount === 1);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_SELECTED + \"-2\", this.rangeCount === 2);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_SELECTED + \"-3\", this.rangeCount === 3);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_SELECTED + \"-4\", this.rangeCount >= 4);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_CHART, this.hasChartRange);\n setAriaSelected(this.eGui, this.rangeCount > 0 ? true : undefined);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_SINGLE_CELL, this.isSingleCell());\n this.updateRangeBorders();\n this.refreshHandle();\n };\n CellRangeFeature.prototype.updateRangeBorders = function () {\n var rangeBorders = this.getRangeBorders();\n var isSingleCell = this.isSingleCell();\n var isTop = !isSingleCell && rangeBorders.top;\n var isRight = !isSingleCell && rangeBorders.right;\n var isBottom = !isSingleCell && rangeBorders.bottom;\n var isLeft = !isSingleCell && rangeBorders.left;\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_TOP, isTop);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_RIGHT, isRight);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_BOTTOM, isBottom);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_LEFT, isLeft);\n };\n CellRangeFeature.prototype.isSingleCell = function () {\n var rangeService = this.beans.rangeService;\n return this.rangeCount === 1 && rangeService && !rangeService.isMoreThanOneCell();\n };\n CellRangeFeature.prototype.getHasChartRange = function () {\n var rangeService = this.beans.rangeService;\n if (!this.rangeCount || !rangeService) {\n return false;\n }\n var cellRanges = rangeService.getCellRanges();\n return cellRanges.length > 0 && cellRanges.every(function (range) { return includes([CellRangeType.DIMENSION, CellRangeType.VALUE], range.type); });\n };\n CellRangeFeature.prototype.updateRangeBordersIfRangeCount = function () {\n // we only need to update range borders if we are in a range\n if (this.rangeCount > 0) {\n this.updateRangeBorders();\n this.refreshHandle();\n }\n };\n CellRangeFeature.prototype.getRangeBorders = function () {\n var _this = this;\n var isRtl = this.beans.gridOptionsWrapper.isEnableRtl();\n var top = false;\n var right = false;\n var bottom = false;\n var left = false;\n var thisCol = this.cellCtrl.getCellPosition().column;\n var _a = this.beans, rangeService = _a.rangeService, columnModel = _a.columnModel;\n var leftCol;\n var rightCol;\n if (isRtl) {\n leftCol = columnModel.getDisplayedColAfter(thisCol);\n rightCol = columnModel.getDisplayedColBefore(thisCol);\n }\n else {\n leftCol = columnModel.getDisplayedColBefore(thisCol);\n rightCol = columnModel.getDisplayedColAfter(thisCol);\n }\n var ranges = rangeService.getCellRanges().filter(function (range) { return rangeService.isCellInSpecificRange(_this.cellCtrl.getCellPosition(), range); });\n // this means we are the first column in the grid\n if (!leftCol) {\n left = true;\n }\n // this means we are the last column in the grid\n if (!rightCol) {\n right = true;\n }\n for (var i = 0; i < ranges.length; i++) {\n if (top && right && bottom && left) {\n break;\n }\n var range = ranges[i];\n var startRow = rangeService.getRangeStartRow(range);\n var endRow = rangeService.getRangeEndRow(range);\n if (!top && this.beans.rowPositionUtils.sameRow(startRow, this.cellCtrl.getCellPosition())) {\n top = true;\n }\n if (!bottom && this.beans.rowPositionUtils.sameRow(endRow, this.cellCtrl.getCellPosition())) {\n bottom = true;\n }\n if (!left && leftCol && range.columns.indexOf(leftCol) < 0) {\n left = true;\n }\n if (!right && rightCol && range.columns.indexOf(rightCol) < 0) {\n right = true;\n }\n }\n return { top: top, right: right, bottom: bottom, left: left };\n };\n CellRangeFeature.prototype.refreshHandle = function () {\n if (!this.beans.rangeService) {\n return;\n }\n var shouldHaveSelectionHandle = this.shouldHaveSelectionHandle();\n if (this.selectionHandle && !shouldHaveSelectionHandle) {\n this.selectionHandle = this.beans.context.destroyBean(this.selectionHandle);\n }\n if (shouldHaveSelectionHandle) {\n this.addSelectionHandle();\n }\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_HANDLE, !!this.selectionHandle);\n };\n CellRangeFeature.prototype.shouldHaveSelectionHandle = function () {\n var _a = this.beans, gridOptionsWrapper = _a.gridOptionsWrapper, rangeService = _a.rangeService;\n var cellRanges = rangeService.getCellRanges();\n var rangesLen = cellRanges.length;\n if (this.rangeCount < 1 || rangesLen < 1) {\n return false;\n }\n var cellRange = last(cellRanges);\n var cellPosition = this.cellCtrl.getCellPosition();\n var isFillHandleAvailable = gridOptionsWrapper.isEnableFillHandle() && !this.cellCtrl.isSuppressFillHandle();\n var isRangeHandleAvailable = gridOptionsWrapper.isEnableRangeHandle();\n var handleIsAvailable = rangesLen === 1 && !this.cellCtrl.isEditing() && (isFillHandleAvailable || isRangeHandleAvailable);\n if (this.hasChartRange) {\n var hasCategoryRange = cellRanges[0].type === CellRangeType.DIMENSION;\n var isCategoryCell = hasCategoryRange && rangeService.isCellInSpecificRange(cellPosition, cellRanges[0]);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_CHART_CATEGORY, isCategoryCell);\n handleIsAvailable = cellRange.type === CellRangeType.VALUE;\n }\n return handleIsAvailable &&\n cellRange.endRow != null &&\n rangeService.isContiguousRange(cellRange) &&\n rangeService.isBottomRightCell(cellRange, cellPosition);\n };\n CellRangeFeature.prototype.addSelectionHandle = function () {\n var _a = this.beans, gridOptionsWrapper = _a.gridOptionsWrapper, rangeService = _a.rangeService;\n var cellRangeType = last(rangeService.getCellRanges()).type;\n var selectionHandleFill = gridOptionsWrapper.isEnableFillHandle() && missing(cellRangeType);\n var type = selectionHandleFill ? SelectionHandleType.FILL : SelectionHandleType.RANGE;\n if (this.selectionHandle && this.selectionHandle.getType() !== type) {\n this.selectionHandle = this.beans.context.destroyBean(this.selectionHandle);\n }\n if (!this.selectionHandle) {\n this.selectionHandle = this.beans.selectionHandleFactory.createSelectionHandle(type);\n }\n this.selectionHandle.refresh(this.cellCtrl);\n };\n CellRangeFeature.prototype.destroy = function () {\n this.beans.context.destroyBean(this.selectionHandle);\n };\n return CellRangeFeature;\n}());\nexport { CellRangeFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { areEqual, last } from \"../../utils/array\";\nimport { Events } from \"../../eventKeys\";\nimport { missing } from \"../../utils/generic\";\nimport { Constants } from \"../../constants/constants\";\nimport { BeanStub } from \"../../context/beanStub\";\n/**\n * Takes care of:\n * #) Cell Width (including when doing cell spanning, which makes width cover many columns)\n * #) Cell Height (when doing row span, otherwise we don't touch the height as it's just row height)\n * #) Cell Left (the horizontal positioning of the cell, the vertical positioning is on the row)\n */\nvar CellPositionFeature = /** @class */ (function (_super) {\n __extends(CellPositionFeature, _super);\n function CellPositionFeature(ctrl, beans) {\n var _this = _super.call(this) || this;\n _this.cellCtrl = ctrl;\n _this.beans = beans;\n _this.column = ctrl.getColumn();\n _this.rowNode = ctrl.getRowNode();\n _this.setupColSpan();\n _this.setupRowSpan();\n return _this;\n }\n CellPositionFeature.prototype.setupRowSpan = function () {\n this.rowSpan = this.column.getRowSpan(this.rowNode);\n };\n CellPositionFeature.prototype.setComp = function (eGui) {\n this.eGui = eGui;\n this.onLeftChanged();\n this.onWidthChanged();\n this.applyRowSpan();\n };\n CellPositionFeature.prototype.onDisplayColumnsChanged = function () {\n var colsSpanning = this.getColSpanningList();\n if (!areEqual(this.colsSpanning, colsSpanning)) {\n this.colsSpanning = colsSpanning;\n this.onWidthChanged();\n this.onLeftChanged(); // left changes when doing RTL\n }\n };\n CellPositionFeature.prototype.setupColSpan = function () {\n // if no col span is active, then we don't set it up, as it would be wasteful of CPU\n if (this.column.getColDef().colSpan == null) {\n return;\n }\n this.colsSpanning = this.getColSpanningList();\n // because we are col spanning, a reorder of the cols can change what cols we are spanning over\n this.addManagedListener(this.beans.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayColumnsChanged.bind(this));\n // because we are spanning over multiple cols, we check for width any time any cols width changes.\n // this is expensive - really we should be explicitly checking only the cols we are spanning over\n // instead of every col, however it would be tricky code to track the cols we are spanning over, so\n // because hardly anyone will be using colSpan, am favouring this easier way for more maintainable code.\n this.addManagedListener(this.beans.eventService, Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, this.onWidthChanged.bind(this));\n };\n CellPositionFeature.prototype.onWidthChanged = function () {\n if (!this.eGui) {\n return;\n }\n var width = this.getCellWidth();\n this.eGui.style.width = width + \"px\";\n };\n CellPositionFeature.prototype.getCellWidth = function () {\n if (!this.colsSpanning) {\n return this.column.getActualWidth();\n }\n return this.colsSpanning.reduce(function (width, col) { return width + col.getActualWidth(); }, 0);\n };\n CellPositionFeature.prototype.getColSpanningList = function () {\n var colSpan = this.column.getColSpan(this.rowNode);\n var colsSpanning = [];\n // if just one col, the col span is just the column we are in\n if (colSpan === 1) {\n colsSpanning.push(this.column);\n }\n else {\n var pointer = this.column;\n var pinned = this.column.getPinned();\n for (var i = 0; pointer && i < colSpan; i++) {\n colsSpanning.push(pointer);\n pointer = this.beans.columnModel.getDisplayedColAfter(pointer);\n if (!pointer || missing(pointer)) {\n break;\n }\n // we do not allow col spanning to span outside of pinned areas\n if (pinned !== pointer.getPinned()) {\n break;\n }\n }\n }\n return colsSpanning;\n };\n CellPositionFeature.prototype.onLeftChanged = function () {\n if (!this.eGui) {\n return;\n }\n var left = this.modifyLeftForPrintLayout(this.getCellLeft());\n this.eGui.style.left = left + 'px';\n };\n CellPositionFeature.prototype.getCellLeft = function () {\n var mostLeftCol;\n if (this.beans.gridOptionsWrapper.isEnableRtl() && this.colsSpanning) {\n mostLeftCol = last(this.colsSpanning);\n }\n else {\n mostLeftCol = this.column;\n }\n return mostLeftCol.getLeft();\n };\n CellPositionFeature.prototype.modifyLeftForPrintLayout = function (leftPosition) {\n if (!this.cellCtrl.isPrintLayout() || this.column.getPinned() === Constants.PINNED_LEFT) {\n return leftPosition;\n }\n var leftWidth = this.beans.columnModel.getDisplayedColumnsLeftWidth();\n if (this.column.getPinned() === Constants.PINNED_RIGHT) {\n var bodyWidth = this.beans.columnModel.getBodyContainerWidth();\n return leftWidth + bodyWidth + (leftPosition || 0);\n }\n // is in body\n return leftWidth + (leftPosition || 0);\n };\n CellPositionFeature.prototype.applyRowSpan = function () {\n if (this.rowSpan === 1) {\n return;\n }\n var singleRowHeight = this.beans.gridOptionsWrapper.getRowHeightAsNumber();\n var totalRowHeight = singleRowHeight * this.rowSpan;\n this.eGui.style.height = totalRowHeight + \"px\";\n this.eGui.style.zIndex = '1';\n };\n // overriding to make public, as we don't dispose this bean via context\n CellPositionFeature.prototype.destroy = function () {\n _super.prototype.destroy.call(this);\n };\n return CellPositionFeature;\n}(BeanStub));\nexport { CellPositionFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { BeanStub } from \"../../context/beanStub\";\nvar CellCustomStyleFeature = /** @class */ (function (_super) {\n __extends(CellCustomStyleFeature, _super);\n function CellCustomStyleFeature(ctrl, beans) {\n var _this = _super.call(this) || this;\n _this.staticClasses = [];\n _this.cellCtrl = ctrl;\n _this.beans = beans;\n _this.column = ctrl.getColumn();\n _this.rowNode = ctrl.getRowNode();\n return _this;\n }\n CellCustomStyleFeature.prototype.setComp = function (comp) {\n this.cellComp = comp;\n this.applyUserStyles();\n this.applyCellClassRules();\n this.applyClassesFromColDef();\n };\n CellCustomStyleFeature.prototype.applyCellClassRules = function () {\n var _this = this;\n var colDef = this.column.getColDef();\n var cellClassParams = {\n value: this.cellCtrl.getValue(),\n data: this.rowNode.data,\n node: this.rowNode,\n colDef: colDef,\n column: this.column,\n rowIndex: this.rowNode.rowIndex,\n api: this.beans.gridOptionsWrapper.getApi(),\n columnApi: this.beans.gridOptionsWrapper.getColumnApi(),\n context: this.beans.gridOptionsWrapper.getContext()\n };\n this.beans.stylingService.processClassRules(colDef.cellClassRules, cellClassParams, function (className) { return _this.cellComp.addOrRemoveCssClass(className, true); }, function (className) { return _this.cellComp.addOrRemoveCssClass(className, false); });\n };\n CellCustomStyleFeature.prototype.applyUserStyles = function () {\n var colDef = this.column.getColDef();\n if (!colDef.cellStyle) {\n return;\n }\n var styles;\n if (typeof colDef.cellStyle === 'function') {\n var cellStyleParams = {\n column: this.column,\n value: this.cellCtrl.getValue(),\n colDef: colDef,\n data: this.rowNode.data,\n node: this.rowNode,\n rowIndex: this.rowNode.rowIndex,\n api: this.beans.gridOptionsWrapper.getApi(),\n columnApi: this.beans.gridOptionsWrapper.getColumnApi(),\n context: this.beans.gridOptionsWrapper.getContext(),\n };\n var cellStyleFunc = colDef.cellStyle;\n styles = cellStyleFunc(cellStyleParams);\n }\n else {\n styles = colDef.cellStyle;\n }\n this.cellComp.setUserStyles(styles);\n };\n CellCustomStyleFeature.prototype.applyClassesFromColDef = function () {\n var _this = this;\n var colDef = this.column.getColDef();\n var cellClassParams = {\n value: this.cellCtrl.getValue(),\n data: this.rowNode.data,\n node: this.rowNode,\n column: this.column,\n colDef: colDef,\n rowIndex: this.rowNode.rowIndex,\n api: this.beans.gridOptionsWrapper.getApi(),\n columnApi: this.beans.gridOptionsWrapper.getColumnApi(),\n context: this.beans.gridOptionsWrapper.getContext()\n };\n if (this.staticClasses.length) {\n this.staticClasses.forEach(function (className) { return _this.cellComp.addOrRemoveCssClass(className, false); });\n }\n this.staticClasses = this.beans.stylingService.getStaticCellClasses(colDef, cellClassParams);\n if (this.staticClasses.length) {\n this.staticClasses.forEach(function (className) { return _this.cellComp.addOrRemoveCssClass(className, true); });\n }\n };\n // overriding to make public, as we don't dispose this bean via context\n CellCustomStyleFeature.prototype.destroy = function () {\n _super.prototype.destroy.call(this);\n };\n return CellCustomStyleFeature;\n}(BeanStub));\nexport { CellCustomStyleFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { BeanStub } from \"../context/beanStub\";\nimport { CustomTooltipFeature } from \"./customTooltipFeature\";\nvar TooltipFeature = /** @class */ (function (_super) {\n __extends(TooltipFeature, _super);\n function TooltipFeature(ctrl, beans) {\n var _this = _super.call(this) || this;\n _this.ctrl = ctrl;\n _this.beans = beans;\n return _this;\n }\n TooltipFeature.prototype.setComp = function (comp) {\n this.comp = comp;\n this.setupTooltip();\n };\n TooltipFeature.prototype.setupTooltip = function () {\n this.browserTooltips = this.beans.gridOptionsWrapper.isEnableBrowserTooltips();\n this.updateTooltipText();\n if (this.browserTooltips) {\n this.comp.setTitle(this.tooltip != null ? this.tooltip : undefined);\n }\n else {\n this.createTooltipFeatureIfNeeded();\n }\n };\n TooltipFeature.prototype.updateTooltipText = function () {\n this.tooltip = this.ctrl.getTooltipValue();\n };\n TooltipFeature.prototype.createTooltipFeatureIfNeeded = function () {\n var _this = this;\n if (this.genericTooltipFeature != null) {\n return;\n }\n var parent = {\n getTooltipParams: function () { return _this.getTooltipParams(); },\n getGui: function () { return _this.ctrl.getGui(); }\n };\n this.genericTooltipFeature = this.createManagedBean(new CustomTooltipFeature(parent), this.beans.context);\n };\n TooltipFeature.prototype.refreshToolTip = function () {\n this.updateTooltipText();\n if (this.browserTooltips) {\n this.comp.setTitle(this.tooltip != null ? this.tooltip : undefined);\n }\n };\n TooltipFeature.prototype.getTooltipParams = function () {\n var ctrl = this.ctrl;\n var column = ctrl.getColumn ? ctrl.getColumn() : undefined;\n var colDef = ctrl.getColDef ? ctrl.getColDef() : undefined;\n var rowNode = ctrl.getRowNode ? ctrl.getRowNode() : undefined;\n return {\n location: ctrl.getLocation(),\n colDef: colDef,\n column: column,\n rowIndex: ctrl.getRowIndex ? ctrl.getRowIndex() : undefined,\n node: rowNode,\n data: rowNode ? rowNode.data : undefined,\n value: this.getTooltipText(),\n valueFormatted: ctrl.getValueFormatted ? ctrl.getValueFormatted() : undefined,\n };\n };\n TooltipFeature.prototype.getTooltipText = function () {\n return this.tooltip;\n };\n // overriding to make public, as we don't dispose this bean via context\n TooltipFeature.prototype.destroy = function () {\n _super.prototype.destroy.call(this);\n };\n return TooltipFeature;\n}(BeanStub));\nexport { TooltipFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, Optional, PostConstruct } from \"../context/context\";\n/** Using the IoC has a slight performance consideration, which is no problem most of the\n * time, unless we are trashing objects - which is the case when scrolling and rowComp\n * and cellComp. So for performance reasons, RowComp and CellComp do not get autowired\n * with the IoC. Instead they get passed this object which is all the beans the RowComp\n * and CellComp need. Not autowiring all the cells gives performance improvement. */\nvar Beans = /** @class */ (function () {\n function Beans() {\n }\n Beans.prototype.postConstruct = function () {\n this.doingMasterDetail = this.gridOptionsWrapper.isMasterDetail();\n if (this.gridOptionsWrapper.isRowModelDefault()) {\n this.clientSideRowModel = this.rowModel;\n }\n if (this.gridOptionsWrapper.isRowModelServerSide()) {\n this.serverSideRowModel = this.rowModel;\n }\n };\n __decorate([\n Autowired('resizeObserverService')\n ], Beans.prototype, \"resizeObserverService\", void 0);\n __decorate([\n Autowired('paginationProxy')\n ], Beans.prototype, \"paginationProxy\", void 0);\n __decorate([\n Autowired('context')\n ], Beans.prototype, \"context\", void 0);\n __decorate([\n Autowired('columnApi')\n ], Beans.prototype, \"columnApi\", void 0);\n __decorate([\n Autowired('gridApi')\n ], Beans.prototype, \"gridApi\", void 0);\n __decorate([\n Autowired('gridOptionsWrapper')\n ], Beans.prototype, \"gridOptionsWrapper\", void 0);\n __decorate([\n Autowired('expressionService')\n ], Beans.prototype, \"expressionService\", void 0);\n __decorate([\n Autowired('rowRenderer')\n ], Beans.prototype, \"rowRenderer\", void 0);\n __decorate([\n Autowired('templateService')\n ], Beans.prototype, \"templateService\", void 0);\n __decorate([\n Autowired('valueService')\n ], Beans.prototype, \"valueService\", void 0);\n __decorate([\n Autowired('eventService')\n ], Beans.prototype, \"eventService\", void 0);\n __decorate([\n Autowired('columnModel')\n ], Beans.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('headerNavigationService')\n ], Beans.prototype, \"headerNavigationService\", void 0);\n __decorate([\n Autowired('navigationService')\n ], Beans.prototype, \"navigationService\", void 0);\n __decorate([\n Autowired('columnAnimationService')\n ], Beans.prototype, \"columnAnimationService\", void 0);\n __decorate([\n Optional('rangeService')\n ], Beans.prototype, \"rangeService\", void 0);\n __decorate([\n Autowired('focusService')\n ], Beans.prototype, \"focusService\", void 0);\n __decorate([\n Optional('contextMenuFactory')\n ], Beans.prototype, \"contextMenuFactory\", void 0);\n __decorate([\n Autowired('popupService')\n ], Beans.prototype, \"popupService\", void 0);\n __decorate([\n Autowired('valueFormatterService')\n ], Beans.prototype, \"valueFormatterService\", void 0);\n __decorate([\n Autowired('stylingService')\n ], Beans.prototype, \"stylingService\", void 0);\n __decorate([\n Autowired('columnHoverService')\n ], Beans.prototype, \"columnHoverService\", void 0);\n __decorate([\n Autowired('userComponentFactory')\n ], Beans.prototype, \"userComponentFactory\", void 0);\n __decorate([\n Autowired('userComponentRegistry')\n ], Beans.prototype, \"userComponentRegistry\", void 0);\n __decorate([\n Autowired('animationFrameService')\n ], Beans.prototype, \"animationFrameService\", void 0);\n __decorate([\n Autowired('dragAndDropService')\n ], Beans.prototype, \"dragAndDropService\", void 0);\n __decorate([\n Autowired('sortController')\n ], Beans.prototype, \"sortController\", void 0);\n __decorate([\n Autowired('filterManager')\n ], Beans.prototype, \"filterManager\", void 0);\n __decorate([\n Autowired('rowContainerHeightService')\n ], Beans.prototype, \"rowContainerHeightService\", void 0);\n __decorate([\n Autowired('frameworkOverrides')\n ], Beans.prototype, \"frameworkOverrides\", void 0);\n __decorate([\n Autowired('cellPositionUtils')\n ], Beans.prototype, \"cellPositionUtils\", void 0);\n __decorate([\n Autowired('rowPositionUtils')\n ], Beans.prototype, \"rowPositionUtils\", void 0);\n __decorate([\n Autowired('selectionService')\n ], Beans.prototype, \"selectionService\", void 0);\n __decorate([\n Optional('selectionHandleFactory')\n ], Beans.prototype, \"selectionHandleFactory\", void 0);\n __decorate([\n Autowired('rowCssClassCalculator')\n ], Beans.prototype, \"rowCssClassCalculator\", void 0);\n __decorate([\n Autowired('rowModel')\n ], Beans.prototype, \"rowModel\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], Beans.prototype, \"ctrlsService\", void 0);\n __decorate([\n Autowired('ctrlsFactory')\n ], Beans.prototype, \"ctrlsFactory\", void 0);\n __decorate([\n Autowired('agStackComponentsRegistry')\n ], Beans.prototype, \"agStackComponentsRegistry\", void 0);\n __decorate([\n Autowired('valueCache')\n ], Beans.prototype, \"valueCache\", void 0);\n __decorate([\n Autowired('rowNodeEventThrottle')\n ], Beans.prototype, \"rowNodeEventThrottle\", void 0);\n __decorate([\n PostConstruct\n ], Beans.prototype, \"postConstruct\", null);\n Beans = __decorate([\n Bean('beans')\n ], Beans);\n return Beans;\n}());\nexport { Beans };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { Events } from \"../../events\";\nimport { isBrowserEdge, isIOSUserAgent } from \"../../utils/browser\";\nimport { isElementChildOfClass, isFocusableFormField } from \"../../utils/dom\";\nimport { isEventSupported, isStopPropagationForAgGrid } from \"../../utils/event\";\nimport { Beans } from \"../beans\";\nvar CellMouseListenerFeature = /** @class */ (function (_super) {\n __extends(CellMouseListenerFeature, _super);\n function CellMouseListenerFeature(ctrl, beans, column) {\n var _this = _super.call(this) || this;\n _this.cellCtrl = ctrl;\n _this.beans = beans;\n _this.column = column;\n return _this;\n }\n CellMouseListenerFeature.prototype.onMouseEvent = function (eventName, mouseEvent) {\n if (isStopPropagationForAgGrid(mouseEvent)) {\n return;\n }\n switch (eventName) {\n case 'click':\n this.onCellClicked(mouseEvent);\n break;\n case 'mousedown':\n case 'touchstart':\n this.onMouseDown(mouseEvent);\n break;\n case 'dblclick':\n this.onCellDoubleClicked(mouseEvent);\n break;\n case 'mouseout':\n this.onMouseOut(mouseEvent);\n break;\n case 'mouseover':\n this.onMouseOver(mouseEvent);\n break;\n }\n };\n CellMouseListenerFeature.prototype.onCellClicked = function (mouseEvent) {\n // iPad doesn't have double click - so we need to mimic it to enable editing for iPad.\n if (this.isDoubleClickOnIPad()) {\n this.onCellDoubleClicked(mouseEvent);\n mouseEvent.preventDefault(); // if we don't do this, then iPad zooms in\n return;\n }\n var _a = this.beans, eventService = _a.eventService, rangeService = _a.rangeService, gridOptionsWrapper = _a.gridOptionsWrapper;\n var multiKeyPressed = mouseEvent.ctrlKey || mouseEvent.metaKey;\n if (rangeService && multiKeyPressed) {\n // the mousedown event has created the range already, so we only intersect if there is more than one\n // range on this cell\n if (rangeService.getCellRangeCount(this.cellCtrl.getCellPosition()) > 1) {\n rangeService.intersectLastRange(true);\n }\n }\n var cellClickedEvent = this.cellCtrl.createEvent(mouseEvent, Events.EVENT_CELL_CLICKED);\n eventService.dispatchEvent(cellClickedEvent);\n var colDef = this.column.getColDef();\n if (colDef.onCellClicked) {\n // to make callback async, do in a timeout\n window.setTimeout(function () { return colDef.onCellClicked(cellClickedEvent); }, 0);\n }\n var editOnSingleClick = (gridOptionsWrapper.isSingleClickEdit() || colDef.singleClickEdit)\n && !gridOptionsWrapper.isSuppressClickEdit();\n if (editOnSingleClick) {\n this.cellCtrl.startRowOrCellEdit();\n }\n };\n // returns true if on iPad and this is second 'click' event in 200ms\n CellMouseListenerFeature.prototype.isDoubleClickOnIPad = function () {\n if (!isIOSUserAgent() || isEventSupported('dblclick')) {\n return false;\n }\n var nowMillis = new Date().getTime();\n var res = nowMillis - this.lastIPadMouseClickEvent < 200;\n this.lastIPadMouseClickEvent = nowMillis;\n return res;\n };\n CellMouseListenerFeature.prototype.onCellDoubleClicked = function (mouseEvent) {\n var colDef = this.column.getColDef();\n // always dispatch event to eventService\n var cellDoubleClickedEvent = this.cellCtrl.createEvent(mouseEvent, Events.EVENT_CELL_DOUBLE_CLICKED);\n this.beans.eventService.dispatchEvent(cellDoubleClickedEvent);\n // check if colDef also wants to handle event\n if (typeof colDef.onCellDoubleClicked === 'function') {\n // to make the callback async, do in a timeout\n window.setTimeout(function () { return colDef.onCellDoubleClicked(cellDoubleClickedEvent); }, 0);\n }\n var editOnDoubleClick = !this.beans.gridOptionsWrapper.isSingleClickEdit()\n && !this.beans.gridOptionsWrapper.isSuppressClickEdit();\n if (editOnDoubleClick) {\n this.cellCtrl.startRowOrCellEdit(null, null, mouseEvent);\n }\n };\n CellMouseListenerFeature.prototype.onMouseDown = function (mouseEvent) {\n var ctrlKey = mouseEvent.ctrlKey, metaKey = mouseEvent.metaKey, shiftKey = mouseEvent.shiftKey;\n var target = mouseEvent.target;\n var _a = this.beans, eventService = _a.eventService, rangeService = _a.rangeService;\n // do not change the range for right-clicks inside an existing range\n if (this.isRightClickInExistingRange(mouseEvent)) {\n return;\n }\n var ranges = rangeService && rangeService.getCellRanges().length != 0;\n if (!shiftKey || !ranges) {\n // We only need to pass true to focusCell when the browser is IE/Edge and we are trying\n // to focus the cell itself. This should never be true if the mousedown was triggered\n // due to a click on a cell editor for example.\n var forceBrowserFocus = (isBrowserEdge()) && !this.cellCtrl.isEditing() && !isFocusableFormField(target);\n this.cellCtrl.focusCell(forceBrowserFocus);\n }\n // if shift clicking, and a range exists, we keep the focus on the cell that started the\n // range as the user then changes the range selection.\n if (shiftKey && ranges) {\n // this stops the cell from getting focused\n mouseEvent.preventDefault();\n }\n // if we are clicking on a checkbox, we need to make sure the cell wrapping that checkbox\n // is focused but we don't want to change the range selection, so return here.\n if (this.containsWidget(target)) {\n return;\n }\n if (rangeService) {\n var thisCell = this.cellCtrl.getCellPosition();\n if (shiftKey) {\n rangeService.extendLatestRangeToCell(thisCell);\n }\n else {\n var ctrlKeyPressed = ctrlKey || metaKey;\n rangeService.setRangeToCell(thisCell, ctrlKeyPressed);\n }\n }\n eventService.dispatchEvent(this.cellCtrl.createEvent(mouseEvent, Events.EVENT_CELL_MOUSE_DOWN));\n };\n CellMouseListenerFeature.prototype.isRightClickInExistingRange = function (mouseEvent) {\n var rangeService = this.beans.rangeService;\n if (rangeService) {\n var cellInRange = rangeService.isCellInAnyRange(this.cellCtrl.getCellPosition());\n if (cellInRange && mouseEvent.button === 2) {\n return true;\n }\n }\n return false;\n };\n CellMouseListenerFeature.prototype.containsWidget = function (target) {\n return isElementChildOfClass(target, 'ag-selection-checkbox', 3);\n };\n CellMouseListenerFeature.prototype.onMouseOut = function (mouseEvent) {\n if (this.mouseStayingInsideCell(mouseEvent)) {\n return;\n }\n var cellMouseOutEvent = this.cellCtrl.createEvent(mouseEvent, Events.EVENT_CELL_MOUSE_OUT);\n this.beans.eventService.dispatchEvent(cellMouseOutEvent);\n this.beans.columnHoverService.clearMouseOver();\n };\n CellMouseListenerFeature.prototype.onMouseOver = function (mouseEvent) {\n if (this.mouseStayingInsideCell(mouseEvent)) {\n return;\n }\n var cellMouseOverEvent = this.cellCtrl.createEvent(mouseEvent, Events.EVENT_CELL_MOUSE_OVER);\n this.beans.eventService.dispatchEvent(cellMouseOverEvent);\n this.beans.columnHoverService.setMouseOver([this.column]);\n };\n CellMouseListenerFeature.prototype.mouseStayingInsideCell = function (e) {\n if (!e.target || !e.relatedTarget) {\n return false;\n }\n var eGui = this.cellCtrl.getGui();\n var cellContainsTarget = eGui.contains(e.target);\n var cellContainsRelatedTarget = eGui.contains(e.relatedTarget);\n return cellContainsTarget && cellContainsRelatedTarget;\n };\n CellMouseListenerFeature.prototype.destroy = function () {\n };\n return CellMouseListenerFeature;\n}(Beans));\nexport { CellMouseListenerFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { BeanStub } from \"../../context/beanStub\";\nimport { KeyCode } from \"../../constants/keyCode\";\nimport { isEventFromPrintableCharacter } from \"../../utils/keyboard\";\nvar CellKeyboardListenerFeature = /** @class */ (function (_super) {\n __extends(CellKeyboardListenerFeature, _super);\n function CellKeyboardListenerFeature(ctrl, beans, column, rowNode, rowCtrl) {\n var _this = _super.call(this) || this;\n _this.cellCtrl = ctrl;\n _this.beans = beans;\n _this.rowNode = rowNode;\n _this.rowCtrl = rowCtrl;\n return _this;\n }\n CellKeyboardListenerFeature.prototype.setComp = function (eGui) {\n this.eGui = eGui;\n };\n CellKeyboardListenerFeature.prototype.onKeyDown = function (event) {\n var key = event.key;\n switch (key) {\n case KeyCode.ENTER:\n this.onEnterKeyDown(event);\n break;\n case KeyCode.F2:\n this.onF2KeyDown(event);\n break;\n case KeyCode.ESCAPE:\n this.onEscapeKeyDown(event);\n break;\n case KeyCode.TAB:\n this.onTabKeyDown(event);\n break;\n case KeyCode.BACKSPACE:\n case KeyCode.DELETE:\n this.onBackspaceOrDeleteKeyPressed(key, event);\n break;\n case KeyCode.DOWN:\n case KeyCode.UP:\n case KeyCode.RIGHT:\n case KeyCode.LEFT:\n this.onNavigationKeyPressed(event, key);\n break;\n }\n };\n CellKeyboardListenerFeature.prototype.onNavigationKeyPressed = function (event, key) {\n if (this.cellCtrl.isEditing()) {\n return;\n }\n if (event.shiftKey && this.cellCtrl.isRangeSelectionEnabled()) {\n this.onShiftRangeSelect(event);\n }\n else {\n this.beans.navigationService.navigateToNextCell(event, key, this.cellCtrl.getCellPosition(), true);\n }\n // if we don't prevent default, the grid will scroll with the navigation keys\n event.preventDefault();\n };\n CellKeyboardListenerFeature.prototype.onShiftRangeSelect = function (event) {\n if (!this.beans.rangeService) {\n return;\n }\n var endCell = this.beans.rangeService.extendLatestRangeInDirection(event);\n if (endCell) {\n this.beans.navigationService.ensureCellVisible(endCell);\n }\n };\n CellKeyboardListenerFeature.prototype.onTabKeyDown = function (event) {\n this.beans.navigationService.onTabKeyDown(this.cellCtrl, event);\n };\n CellKeyboardListenerFeature.prototype.onBackspaceOrDeleteKeyPressed = function (key, event) {\n if (!this.cellCtrl.isEditing()) {\n this.cellCtrl.startRowOrCellEdit(key, undefined, event);\n }\n };\n CellKeyboardListenerFeature.prototype.onEnterKeyDown = function (e) {\n if (this.cellCtrl.isEditing() || this.rowCtrl.isEditing()) {\n this.cellCtrl.stopEditingAndFocus();\n }\n else {\n if (this.beans.gridOptionsWrapper.isEnterMovesDown()) {\n this.beans.navigationService.navigateToNextCell(null, KeyCode.DOWN, this.cellCtrl.getCellPosition(), false);\n }\n else {\n this.cellCtrl.startRowOrCellEdit(KeyCode.ENTER, undefined, e);\n if (this.cellCtrl.isEditing()) {\n // if we started editing, then we need to prevent default, otherwise the Enter action can get\n // applied to the cell editor. this happened, for example, with largeTextCellEditor where not\n // preventing default results in a 'new line' character getting inserted in the text area\n // when the editing was started\n e.preventDefault();\n }\n }\n }\n };\n CellKeyboardListenerFeature.prototype.onF2KeyDown = function (event) {\n if (!this.cellCtrl.isEditing()) {\n this.cellCtrl.startRowOrCellEdit(KeyCode.F2, undefined, event);\n }\n };\n CellKeyboardListenerFeature.prototype.onEscapeKeyDown = function (event) {\n if (this.cellCtrl.isEditing()) {\n this.cellCtrl.stopRowOrCellEdit(true);\n this.cellCtrl.focusCell(true);\n }\n };\n CellKeyboardListenerFeature.prototype.onKeyPress = function (event) {\n // check this, in case focus is on a (for example) a text field inside the cell,\n // in which cse we should not be listening for these key pressed\n var eventTarget = event.target;\n var eventOnChildComponent = eventTarget !== this.eGui;\n if (eventOnChildComponent || this.cellCtrl.isEditing()) {\n return;\n }\n var pressedChar = String.fromCharCode(event.charCode);\n if (pressedChar === ' ') {\n this.onSpaceKeyPressed(event);\n }\n else if (isEventFromPrintableCharacter(event)) {\n this.cellCtrl.startRowOrCellEdit(null, pressedChar, event);\n // if we don't prevent default, then the keypress also gets applied to the text field\n // (at least when doing the default editor), but we need to allow the editor to decide\n // what it wants to do. we only do this IF editing was started - otherwise it messes\n // up when the use is not doing editing, but using rendering with text fields in cellRenderer\n // (as it would block the the user from typing into text fields).\n event.preventDefault();\n }\n };\n CellKeyboardListenerFeature.prototype.onSpaceKeyPressed = function (event) {\n var gridOptionsWrapper = this.beans.gridOptionsWrapper;\n if (!this.cellCtrl.isEditing() && gridOptionsWrapper.isRowSelection()) {\n var currentSelection = this.rowNode.isSelected();\n var newSelection = !currentSelection;\n if (newSelection || !gridOptionsWrapper.isSuppressRowDeselection()) {\n var groupSelectsFiltered = this.beans.gridOptionsWrapper.isGroupSelectsFiltered();\n var updatedCount = this.rowNode.setSelectedParams({\n newValue: newSelection,\n rangeSelect: event.shiftKey,\n groupSelectsFiltered: groupSelectsFiltered\n });\n if (currentSelection === undefined && updatedCount === 0) {\n this.rowNode.setSelectedParams({\n newValue: false,\n rangeSelect: event.shiftKey,\n groupSelectsFiltered: groupSelectsFiltered\n });\n }\n }\n }\n // prevent default as space key, by default, moves browser scroll down\n event.preventDefault();\n };\n CellKeyboardListenerFeature.prototype.destroy = function () {\n _super.prototype.destroy.call(this);\n };\n return CellKeyboardListenerFeature;\n}(BeanStub));\nexport { CellKeyboardListenerFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from \"../widgets/component\";\nimport { PostConstruct } from \"../context/context\";\nimport { createIconNoSpan } from \"../utils/icon\";\nvar DndSourceComp = /** @class */ (function (_super) {\n __extends(DndSourceComp, _super);\n function DndSourceComp(rowNode, column, beans, eCell) {\n var _this = _super.call(this, \"
\") || this;\n _this.rowNode = rowNode;\n _this.column = column;\n _this.beans = beans;\n _this.eCell = eCell;\n return _this;\n }\n DndSourceComp.prototype.postConstruct = function () {\n var eGui = this.getGui();\n eGui.appendChild(createIconNoSpan('rowDrag', this.beans.gridOptionsWrapper, null));\n // we need to stop the event propagation here to avoid starting a range selection while dragging\n this.addGuiEventListener('mousedown', function (e) {\n e.stopPropagation();\n });\n this.addDragSource();\n this.checkVisibility();\n };\n DndSourceComp.prototype.addDragSource = function () {\n this.addGuiEventListener('dragstart', this.onDragStart.bind(this));\n };\n DndSourceComp.prototype.onDragStart = function (dragEvent) {\n var _this = this;\n var providedOnRowDrag = this.column.getColDef().dndSourceOnRowDrag;\n dragEvent.dataTransfer.setDragImage(this.eCell, 0, 0);\n // default behaviour is to convert data to json and set into drag component\n var defaultOnRowDrag = function () {\n try {\n var jsonData = JSON.stringify(_this.rowNode.data);\n dragEvent.dataTransfer.setData('application/json', jsonData);\n dragEvent.dataTransfer.setData('text/plain', jsonData);\n }\n catch (e) {\n // if we cannot convert the data to json, then we do not set the type\n }\n };\n if (providedOnRowDrag) {\n var params = {\n rowNode: this.rowNode, dragEvent: dragEvent,\n api: this.gridOptionsWrapper.getApi(),\n columnApi: this.gridOptionsWrapper.getColumnApi(),\n context: this.gridOptionsWrapper.getContext()\n };\n providedOnRowDrag(params);\n }\n else {\n defaultOnRowDrag();\n }\n };\n DndSourceComp.prototype.checkVisibility = function () {\n var visible = this.column.isDndSource(this.rowNode);\n this.setDisplayed(visible);\n };\n __decorate([\n PostConstruct\n ], DndSourceComp.prototype, \"postConstruct\", null);\n return DndSourceComp;\n}(Component));\nexport { DndSourceComp };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nimport { Events } from \"../../events\";\nimport { CellRangeFeature } from \"./cellRangeFeature\";\nimport { exists, makeNull } from \"../../utils/generic\";\nimport { BeanStub } from \"../../context/beanStub\";\nimport { CellPositionFeature } from \"./cellPositionFeature\";\nimport { escapeString } from \"../../utils/string\";\nimport { CellCustomStyleFeature } from \"./cellCustomStyleFeature\";\nimport { TooltipFeature } from \"../../widgets/tooltipFeature\";\nimport { CellMouseListenerFeature } from \"./cellMouseListenerFeature\";\nimport { CellKeyboardListenerFeature } from \"./cellKeyboardListenerFeature\";\nimport { KeyCode } from \"../../constants/keyCode\";\nimport { CheckboxSelectionComponent } from \"../checkboxSelectionComponent\";\nimport { DndSourceComp } from \"../dndSourceComp\";\nimport { doOnce } from \"../../utils/function\";\nimport { RowDragComp } from \"../row/rowDragComp\";\nimport { getValueUsingField } from \"../../utils/object\";\nimport { getElementSize } from \"../../utils/dom\";\nimport { setAriaColIndex } from \"../../utils/aria\";\nvar CSS_CELL = 'ag-cell';\nvar CSS_AUTO_HEIGHT = 'ag-cell-auto-height';\nvar CSS_NORMAL_HEIGHT = 'ag-cell-normal-height';\nvar CSS_CELL_FOCUS = 'ag-cell-focus';\nvar CSS_CELL_FIRST_RIGHT_PINNED = 'ag-cell-first-right-pinned';\nvar CSS_CELL_LAST_LEFT_PINNED = 'ag-cell-last-left-pinned';\nvar CSS_CELL_NOT_INLINE_EDITING = 'ag-cell-not-inline-editing';\nvar CSS_CELL_INLINE_EDITING = 'ag-cell-inline-editing';\nvar CSS_CELL_POPUP_EDITING = 'ag-cell-popup-editing';\nvar CSS_COLUMN_HOVER = 'ag-column-hover';\nvar CSS_CELL_WRAP_TEXT = 'ag-cell-wrap-text';\nvar instanceIdSequence = 0;\nvar CellCtrl = /** @class */ (function (_super) {\n __extends(CellCtrl, _super);\n function CellCtrl(column, rowNode, beans, rowCtrl) {\n var _this = _super.call(this) || this;\n _this.suppressRefreshCell = false;\n _this.onCellCompAttachedFuncs = [];\n _this.column = column;\n _this.rowNode = rowNode;\n _this.beans = beans;\n _this.rowCtrl = rowCtrl;\n // unique id to this instance, including the column ID to help with debugging in React as it's used in 'key'\n _this.instanceId = column.getId() + '-' + instanceIdSequence++;\n _this.createCellPosition();\n _this.addFeatures();\n return _this;\n }\n CellCtrl.prototype.addFeatures = function () {\n var _this = this;\n this.cellPositionFeature = new CellPositionFeature(this, this.beans);\n this.addDestroyFunc(function () { return _this.cellPositionFeature.destroy(); });\n this.cellCustomStyleFeature = new CellCustomStyleFeature(this, this.beans);\n this.addDestroyFunc(function () { return _this.cellCustomStyleFeature.destroy(); });\n this.cellMouseListenerFeature = new CellMouseListenerFeature(this, this.beans, this.column);\n this.addDestroyFunc(function () { return _this.cellMouseListenerFeature.destroy(); });\n this.cellKeyboardListenerFeature = new CellKeyboardListenerFeature(this, this.beans, this.column, this.rowNode, this.rowCtrl);\n this.addDestroyFunc(function () { return _this.cellKeyboardListenerFeature.destroy(); });\n var rangeSelectionEnabled = this.beans.rangeService && this.beans.gridOptionsWrapper.isEnableRangeSelection();\n if (rangeSelectionEnabled) {\n this.cellRangeFeature = new CellRangeFeature(this.beans, this);\n this.addDestroyFunc(function () { return _this.cellRangeFeature.destroy(); });\n }\n this.addTooltipFeature();\n };\n CellCtrl.prototype.addTooltipFeature = function () {\n var _this = this;\n var getTooltipValue = function () {\n var colDef = _this.column.getColDef();\n var data = _this.rowNode.data;\n if (colDef.tooltipField && exists(data)) {\n return getValueUsingField(data, colDef.tooltipField, _this.column.isTooltipFieldContainsDots());\n }\n var valueGetter = colDef.tooltipValueGetter;\n if (valueGetter) {\n return valueGetter({\n location: 'cell',\n api: _this.beans.gridOptionsWrapper.getApi(),\n columnApi: _this.beans.gridOptionsWrapper.getColumnApi(),\n context: _this.beans.gridOptionsWrapper.getContext(),\n colDef: _this.column.getColDef(),\n column: _this.column,\n rowIndex: _this.cellPosition.rowIndex,\n node: _this.rowNode,\n data: _this.rowNode.data,\n value: _this.value,\n valueFormatted: _this.valueFormatted,\n });\n }\n return null;\n };\n var tooltipCtrl = {\n getColumn: function () { return _this.column; },\n getColDef: function () { return _this.column.getColDef(); },\n getRowIndex: function () { return _this.cellPosition.rowIndex; },\n getRowNode: function () { return _this.rowNode; },\n getGui: function () { return _this.getGui(); },\n getLocation: function () { return 'cell'; },\n getTooltipValue: getTooltipValue,\n // this makes no sense, why is the cell formatted value passed to the tooltip???\n getValueFormatted: function () { return _this.valueFormatted; }\n };\n this.tooltipFeature = new TooltipFeature(tooltipCtrl, this.beans);\n this.addDestroyFunc(function () { return _this.tooltipFeature.destroy(); });\n };\n CellCtrl.prototype.setComp = function (comp, eGui, eCellWrapper, printLayout, startEditing) {\n this.cellComp = comp;\n this.gow = this.beans.gridOptionsWrapper;\n this.eGui = eGui;\n this.eCellWrapper = eCellWrapper;\n this.printLayout = printLayout;\n // we force to make sure formatter gets called at least once,\n // even if value has not changed (is is undefined)\n this.updateAndFormatValue(true);\n this.addDomData();\n this.onCellFocused();\n this.applyStaticCssClasses();\n this.setWrapText();\n this.onFirstRightPinnedChanged();\n this.onLastLeftPinnedChanged();\n this.onColumnHover();\n this.setupControlComps();\n this.setupAutoHeight();\n this.setAriaColIndex();\n if (!this.gow.isSuppressCellFocus()) {\n this.cellComp.setTabIndex(-1);\n }\n var colIdSanitised = escapeString(this.column.getId());\n this.cellComp.setColId(colIdSanitised);\n this.cellComp.setRole('gridcell');\n this.cellPositionFeature.setComp(eGui);\n this.cellCustomStyleFeature.setComp(comp);\n this.tooltipFeature.setComp(comp);\n this.cellKeyboardListenerFeature.setComp(this.eGui);\n if (this.cellRangeFeature) {\n this.cellRangeFeature.setComp(comp, eGui);\n }\n if (startEditing && this.isCellEditable()) {\n this.startEditing();\n }\n else {\n this.showValue();\n }\n if (this.onCellCompAttachedFuncs.length) {\n this.onCellCompAttachedFuncs.forEach(function (func) { return func(); });\n this.onCellCompAttachedFuncs = [];\n }\n };\n CellCtrl.prototype.setupAutoHeight = function () {\n var _this = this;\n if (!this.column.isAutoHeight()) {\n return;\n }\n var eAutoHeightContainer = this.eCellWrapper;\n var eParentCell = eAutoHeightContainer.parentElement;\n // taking minRowHeight from getRowHeightForNode means the getRowHeight() callback is used,\n // thus allowing different min heights for different rows.\n var minRowHeight = this.beans.gridOptionsWrapper.getRowHeightForNode(this.rowNode).height;\n var measureHeight = function (timesCalled) {\n if (_this.editing) {\n return;\n }\n // because of the retry's below, it's possible the retry's go beyond\n // the rows life.\n if (!_this.isAlive()) {\n return;\n }\n var _a = getElementSize(eParentCell), paddingTop = _a.paddingTop, paddingBottom = _a.paddingBottom;\n var wrapperHeight = eAutoHeightContainer.offsetHeight;\n var autoHeight = wrapperHeight + paddingTop + paddingBottom;\n if (timesCalled < 5) {\n // if not in doc yet, means framework not yet inserted, so wait for next VM turn,\n // maybe it will be ready next VM turn\n var doc = _this.beans.gridOptionsWrapper.getDocument();\n var notYetInDom = !doc || !doc.contains(eAutoHeightContainer);\n // this happens in React, where React hasn't put any content in. we say 'possibly'\n // as a) may not be React and b) the cell could be empty anyway\n var possiblyNoContentYet = autoHeight == 0;\n if (notYetInDom || possiblyNoContentYet) {\n _this.beans.frameworkOverrides.setTimeout(function () { return measureHeight(timesCalled + 1); }, 0);\n return;\n }\n }\n var newHeight = Math.max(autoHeight, minRowHeight);\n _this.rowNode.setRowAutoHeight(newHeight, _this.column);\n };\n var listener = function () { return measureHeight(0); };\n // do once to set size in case size doesn't change, common when cell is blank\n listener();\n var destroyResizeObserver = this.beans.resizeObserverService.observeResize(eAutoHeightContainer, listener);\n this.addDestroyFunc(function () {\n destroyResizeObserver();\n _this.rowNode.setRowAutoHeight(undefined, _this.column);\n });\n };\n CellCtrl.prototype.getInstanceId = function () {\n return this.instanceId;\n };\n CellCtrl.prototype.showValue = function (forceNewCellRendererInstance) {\n if (forceNewCellRendererInstance === void 0) { forceNewCellRendererInstance = false; }\n var valueToDisplay = this.valueFormatted != null ? this.valueFormatted : this.value;\n var params = this.createCellRendererParams();\n var compDetails = this.beans.userComponentFactory.getCellRendererDetails(this.column.getColDef(), params);\n this.cellComp.setRenderDetails(compDetails, valueToDisplay, forceNewCellRendererInstance);\n this.refreshHandle();\n };\n CellCtrl.prototype.setupControlComps = function () {\n var colDef = this.column.getColDef();\n this.includeSelection = this.isIncludeControl(colDef.checkboxSelection);\n this.includeRowDrag = this.isIncludeControl(colDef.rowDrag);\n this.includeDndSource = this.isIncludeControl(colDef.dndSource);\n this.cellComp.setIncludeSelection(this.includeSelection);\n this.cellComp.setIncludeDndSource(this.includeDndSource);\n this.cellComp.setIncludeRowDrag(this.includeRowDrag);\n };\n CellCtrl.prototype.isForceWrapper = function () {\n // text selection requires the value to be wrapped in another element\n var forceWrapper = this.beans.gridOptionsWrapper.isEnableCellTextSelection() || this.column.isAutoHeight();\n return forceWrapper;\n };\n CellCtrl.prototype.isIncludeControl = function (value) {\n var rowNodePinned = this.rowNode.rowPinned != null;\n var isFunc = typeof value === 'function';\n var res = rowNodePinned ? false : isFunc || value === true;\n return res;\n };\n CellCtrl.prototype.refreshShouldDestroy = function () {\n var colDef = this.column.getColDef();\n var selectionChanged = this.includeSelection != this.isIncludeControl(colDef.checkboxSelection);\n var rowDragChanged = this.includeRowDrag != this.isIncludeControl(colDef.rowDrag);\n var dndSourceChanged = this.includeDndSource != this.isIncludeControl(colDef.dndSource);\n return selectionChanged || rowDragChanged || dndSourceChanged;\n };\n // either called internally if single cell editing, or called by rowRenderer if row editing\n CellCtrl.prototype.startEditing = function (key, charPress, cellStartedEdit, event) {\n var _this = this;\n if (key === void 0) { key = null; }\n if (charPress === void 0) { charPress = null; }\n if (cellStartedEdit === void 0) { cellStartedEdit = false; }\n if (event === void 0) { event = null; }\n var _a, _b;\n if (!this.isCellEditable() || this.editing) {\n return;\n }\n // because of async in React, the cellComp may not be set yet, if no cellComp then we are\n // yet to initialise the cell, so we re-schedule this operation for when celLComp is attached\n if (!this.cellComp) {\n this.onCellCompAttachedFuncs.push(function () { _this.startEditing(key, charPress, cellStartedEdit, event); });\n return;\n }\n var editorParams = this.createCellEditorParams(key, charPress, cellStartedEdit);\n var colDef = this.column.getColDef();\n var compDetails = this.beans.userComponentFactory.getCellEditorDetails(colDef, editorParams);\n // if cellEditorSelector was used, we give preference to popup and popupPosition from the selector\n var popup = ((_a = compDetails) === null || _a === void 0 ? void 0 : _a.popupFromSelector) != null ? compDetails.popupFromSelector : !!colDef.cellEditorPopup;\n var position = ((_b = compDetails) === null || _b === void 0 ? void 0 : _b.popupPositionFromSelector) != null ? compDetails.popupPositionFromSelector : colDef.cellEditorPopupPosition;\n this.setEditing(true, popup);\n this.cellComp.setEditDetails(compDetails, popup, position);\n var e = this.createEvent(event, Events.EVENT_CELL_EDITING_STARTED);\n this.beans.eventService.dispatchEvent(e);\n };\n CellCtrl.prototype.setEditing = function (editing, inPopup) {\n if (inPopup === void 0) { inPopup = false; }\n if (this.editing === editing) {\n return;\n }\n this.editing = editing;\n this.editingInPopup = inPopup;\n this.setInlineEditingClass();\n this.refreshHandle();\n };\n // pass in 'true' to cancel the editing.\n CellCtrl.prototype.stopRowOrCellEdit = function (cancel) {\n if (cancel === void 0) { cancel = false; }\n if (this.beans.gridOptionsWrapper.isFullRowEdit()) {\n this.rowCtrl.stopRowEditing(cancel);\n }\n else {\n this.stopEditing(cancel);\n }\n };\n CellCtrl.prototype.onPopupEditorClosed = function () {\n if (!this.isEditing()) {\n return;\n }\n // note: this happens because of a click outside of the grid or if the popupEditor\n // is closed with `Escape` key. if another cell was clicked, then the editing will\n // have already stopped and returned on the conditional above.\n this.stopEditingAndFocus();\n };\n CellCtrl.prototype.takeValueFromCellEditor = function (cancel) {\n var noValueResult = { newValueExists: false };\n if (cancel) {\n return noValueResult;\n }\n var cellEditor = this.cellComp.getCellEditor();\n if (!cellEditor) {\n return noValueResult;\n }\n var userWantsToCancel = cellEditor.isCancelAfterEnd && cellEditor.isCancelAfterEnd();\n if (userWantsToCancel) {\n return noValueResult;\n }\n var newValue = cellEditor.getValue();\n return {\n newValue: newValue,\n newValueExists: true\n };\n };\n /**\n * @returns `True` if the value changes, otherwise `False`.\n */\n CellCtrl.prototype.saveNewValue = function (oldValue, newValue) {\n if (newValue === oldValue) {\n return false;\n }\n if (this.beans.gridOptionsWrapper.isReadOnlyEdit()) {\n this.dispatchEventForSaveValueReadOnly(oldValue, newValue);\n return false;\n }\n // we suppressRefreshCell because the call to rowNode.setDataValue() results in change detection\n // getting triggered, which results in all cells getting refreshed. we do not want this refresh\n // to happen on this call as we want to call it explicitly below. otherwise refresh gets called twice.\n // if we only did this refresh (and not the one below) then the cell would flash and not be forced.\n this.suppressRefreshCell = true;\n var valueChanged = this.rowNode.setDataValue(this.column, newValue);\n this.suppressRefreshCell = false;\n return valueChanged;\n };\n CellCtrl.prototype.dispatchEventForSaveValueReadOnly = function (oldValue, newValue) {\n var rowNode = this.rowNode;\n var event = {\n type: Events.EVENT_CELL_EDIT_REQUEST,\n event: null,\n rowIndex: rowNode.rowIndex,\n rowPinned: rowNode.rowPinned,\n column: this.column,\n api: this.beans.gridApi,\n columnApi: this.beans.columnApi,\n colDef: this.column.getColDef(),\n context: this.beans.gridOptionsWrapper.getContext(),\n data: rowNode.data,\n node: rowNode,\n oldValue: oldValue,\n newValue: newValue,\n value: newValue,\n source: undefined\n };\n this.beans.eventService.dispatchEvent(event);\n };\n /**\n * Ends the Cell Editing\n * @param cancel `True` if the edit process is being canceled.\n * @returns `True` if the value of the `GridCell` has been updated, otherwise `False`.\n */\n CellCtrl.prototype.stopEditing = function (cancel) {\n if (cancel === void 0) { cancel = false; }\n if (!this.editing) {\n return false;\n }\n var _a = this.takeValueFromCellEditor(cancel), newValue = _a.newValue, newValueExists = _a.newValueExists;\n var oldValue = this.getValueFromValueService();\n var valueChanged = false;\n if (newValueExists) {\n valueChanged = this.saveNewValue(oldValue, newValue);\n }\n this.setEditing(false);\n this.cellComp.setEditDetails(); // passing nothing stops editing\n this.updateAndFormatValue();\n this.refreshCell({ forceRefresh: true, suppressFlash: true });\n this.dispatchEditingStoppedEvent(oldValue, newValue);\n return valueChanged;\n };\n CellCtrl.prototype.dispatchEditingStoppedEvent = function (oldValue, newValue) {\n var editingStoppedEvent = __assign(__assign({}, this.createEvent(null, Events.EVENT_CELL_EDITING_STOPPED)), { oldValue: oldValue,\n newValue: newValue });\n this.beans.eventService.dispatchEvent(editingStoppedEvent);\n };\n // if we are editing inline, then we don't have the padding in the cell (set in the themes)\n // to allow the text editor full access to the entire cell\n CellCtrl.prototype.setInlineEditingClass = function () {\n var _this = this;\n if (!this.isAlive()) {\n return;\n }\n // because of async in React, the cellComp may not be set yet, if no cellComp then we are\n // yet to initialise the cell, so we re-schedule this operation for when celLComp is attached\n if (!this.cellComp) {\n this.onCellCompAttachedFuncs.push(function () { _this.setInlineEditingClass(); });\n return;\n }\n // ag-cell-inline-editing - appears when user is inline editing\n // ag-cell-not-inline-editing - appears when user is no inline editing\n // ag-cell-popup-editing - appears when user is editing cell in popup (appears on the cell, not on the popup)\n // note: one of {ag-cell-inline-editing, ag-cell-not-inline-editing} is always present, they toggle.\n // however {ag-cell-popup-editing} shows when popup, so you have both {ag-cell-popup-editing}\n // and {ag-cell-not-inline-editing} showing at the same time.\n var editingInline = this.editing && !this.editingInPopup;\n var popupEditorShowing = this.editing && this.editingInPopup;\n this.cellComp.addOrRemoveCssClass(CSS_CELL_INLINE_EDITING, editingInline);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_NOT_INLINE_EDITING, !editingInline);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_POPUP_EDITING, popupEditorShowing);\n this.rowCtrl.setInlineEditingCss(this.editing);\n };\n // this is needed as the JS CellComp still allows isPopup() on the CellEditor class, so\n // it's possible the editor is in a popup even though it's not configured via the colDef as so\n CellCtrl.prototype.hackSayEditingInPopup = function () {\n if (this.editingInPopup) {\n return;\n }\n this.editingInPopup = true;\n this.setInlineEditingClass();\n };\n CellCtrl.prototype.createCellEditorParams = function (key, charPress, cellStartedEdit) {\n var res = {\n value: this.getValueFromValueService(),\n key: key,\n eventKey: key,\n charPress: charPress,\n column: this.column,\n colDef: this.column.getColDef(),\n rowIndex: this.getCellPosition().rowIndex,\n node: this.rowNode,\n data: this.rowNode.data,\n api: this.beans.gridOptionsWrapper.getApi(),\n cellStartedEdit: cellStartedEdit,\n columnApi: this.beans.gridOptionsWrapper.getColumnApi(),\n context: this.beans.gridOptionsWrapper.getContext(),\n onKeyDown: this.onKeyDown.bind(this),\n stopEditing: this.stopEditingAndFocus.bind(this),\n eGridCell: this.getGui(),\n parseValue: this.parseValue.bind(this),\n formatValue: this.formatValue.bind(this)\n };\n return res;\n };\n CellCtrl.prototype.createCellRendererParams = function () {\n var _this = this;\n var addRowCompListener = function (eventType, listener) {\n console.warn('AG Grid: since AG Grid v26, params.addRowCompListener() is deprecated. If you need this functionality, please contact AG Grid support and advise why so that we can revert with an appropriate workaround, as we dont have any valid use cases for it. This method was originally provided as a work around to know when cells were destroyed in AG Grid before custom Cell Renderers could be provided.');\n _this.rowCtrl.addEventListener(eventType, listener);\n };\n var res = {\n value: this.value,\n valueFormatted: this.valueFormatted,\n getValue: this.getValueFromValueService.bind(this),\n setValue: function (value) { return _this.beans.valueService.setValue(_this.rowNode, _this.column, value); },\n formatValue: this.formatValue.bind(this),\n data: this.rowNode.data,\n node: this.rowNode,\n pinned: this.column.getPinned(),\n colDef: this.column.getColDef(),\n column: this.column,\n rowIndex: this.getCellPosition().rowIndex,\n api: this.beans.gridOptionsWrapper.getApi(),\n columnApi: this.beans.gridOptionsWrapper.getColumnApi(),\n context: this.beans.gridOptionsWrapper.getContext(),\n refreshCell: this.refreshCell.bind(this),\n eGridCell: this.getGui(),\n eParentOfValue: this.cellComp.getParentOfValue(),\n registerRowDragger: function (rowDraggerElement, dragStartPixels, value, suppressVisibilityChange) { return _this.registerRowDragger(rowDraggerElement, dragStartPixels, suppressVisibilityChange); },\n // this function is not documented anywhere, so we could drop it\n // it was in the olden days to allow user to register for when rendered\n // row was removed (the row comp was removed), however now that the user\n // can provide components for cells, the destroy method gets call when this\n // happens so no longer need to fire event.\n addRowCompListener: addRowCompListener\n };\n return res;\n };\n CellCtrl.prototype.parseValue = function (newValue) {\n var colDef = this.column.getColDef();\n var params = {\n node: this.rowNode,\n data: this.rowNode.data,\n oldValue: this.getValue(),\n newValue: newValue,\n colDef: colDef,\n column: this.column,\n api: this.beans.gridOptionsWrapper.getApi(),\n columnApi: this.beans.gridOptionsWrapper.getColumnApi(),\n context: this.beans.gridOptionsWrapper.getContext()\n };\n var valueParser = colDef.valueParser;\n return exists(valueParser) ? this.beans.expressionService.evaluate(valueParser, params) : newValue;\n };\n CellCtrl.prototype.setFocusOutOnEditor = function () {\n if (!this.editing) {\n return;\n }\n var cellEditor = this.cellComp.getCellEditor();\n if (cellEditor && cellEditor.focusOut) {\n cellEditor.focusOut();\n }\n };\n CellCtrl.prototype.setFocusInOnEditor = function () {\n if (!this.editing) {\n return;\n }\n var cellEditor = this.cellComp.getCellEditor();\n if (cellEditor && cellEditor.focusIn) {\n // if the editor is present, then we just focus it\n cellEditor.focusIn();\n }\n else {\n // if the editor is not present, it means async cell editor (eg React fibre)\n // and we are trying to set focus before the cell editor is present, so we\n // focus the cell instead\n this.focusCell(true);\n }\n };\n CellCtrl.prototype.onCellChanged = function (event) {\n // because of async in React, the cellComp may not be set yet, if no cellComp then we are\n // yet to initialise the cell, so no need to refresh.\n if (!this.cellComp) {\n return;\n }\n var eventImpactsThisCell = event.column === this.column;\n if (eventImpactsThisCell) {\n this.refreshCell({});\n }\n };\n // + stop editing {forceRefresh: true, suppressFlash: true}\n // + event cellChanged {}\n // + cellRenderer.params.refresh() {} -> method passes 'as is' to the cellRenderer, so params could be anything\n // + rowCtrl: event dataChanged {suppressFlash: !update, newData: !update}\n // + rowCtrl: api refreshCells() {animate: true/false}\n // + rowRenderer: api softRefreshView() {}\n CellCtrl.prototype.refreshCell = function (params) {\n // if we are in the middle of 'stopEditing', then we don't refresh here, as refresh gets called explicitly\n if (this.suppressRefreshCell || this.editing) {\n return;\n }\n // In React, due to async, it's possible a refresh was asked for before the CellComp\n // has been set. If this happens, we skip the refresh, as the cell is going to be\n // initialised anyway once the CellComp is set.\n if (!this.cellComp) {\n return;\n }\n var colDef = this.column.getColDef();\n var newData = params != null && !!params.newData;\n var suppressFlash = (params != null && !!params.suppressFlash) || !!colDef.suppressCellFlash;\n // we always refresh if cell has no value - this can happen when user provides Cell Renderer and the\n // cell renderer doesn't rely on a value, instead it could be looking directly at the data, or maybe\n // printing the current time (which would be silly)???. Generally speaking\n // non of {field, valueGetter, showRowGroup} is bad in the users application, however for this edge case, it's\n // best always refresh and take the performance hit rather than never refresh and users complaining in support\n // that cells are not updating.\n var noValueProvided = colDef.field == null && colDef.valueGetter == null && colDef.showRowGroup == null;\n var forceRefresh = (params && params.forceRefresh) || noValueProvided || newData;\n var valuesDifferent = this.updateAndFormatValue();\n var dataNeedsUpdating = forceRefresh || valuesDifferent;\n if (dataNeedsUpdating) {\n // if it's 'new data', then we don't refresh the cellRenderer, even if refresh method is available.\n // this is because if the whole data is new (ie we are showing stock price 'BBA' now and not 'SSD')\n // then we are not showing a movement in the stock price, rather we are showing different stock.\n this.showValue(newData);\n // we don't want to flash the cells when processing a filter change, as otherwise the UI would\n // be to busy. see comment in FilterManager with regards processingFilterChange\n var processingFilterChange = this.beans.filterManager.isSuppressFlashingCellsBecauseFiltering();\n var flashCell = !suppressFlash && !processingFilterChange &&\n (this.beans.gridOptionsWrapper.isEnableCellChangeFlash() || colDef.enableCellChangeFlash);\n if (flashCell) {\n this.flashCell();\n }\n this.cellCustomStyleFeature.applyUserStyles();\n this.cellCustomStyleFeature.applyClassesFromColDef();\n }\n this.refreshToolTip();\n // we do cellClassRules even if the value has not changed, so that users who have rules that\n // look at other parts of the row (where the other part of the row might of changed) will work.\n this.cellCustomStyleFeature.applyCellClassRules();\n };\n // cell editors call this, when they want to stop for reasons other\n // than what we pick up on. eg selecting from a dropdown ends editing.\n CellCtrl.prototype.stopEditingAndFocus = function (suppressNavigateAfterEdit) {\n if (suppressNavigateAfterEdit === void 0) { suppressNavigateAfterEdit = false; }\n this.stopRowOrCellEdit();\n this.focusCell(true);\n if (!suppressNavigateAfterEdit) {\n this.navigateAfterEdit();\n }\n };\n CellCtrl.prototype.navigateAfterEdit = function () {\n var fullRowEdit = this.beans.gridOptionsWrapper.isFullRowEdit();\n if (fullRowEdit) {\n return;\n }\n var enterMovesDownAfterEdit = this.beans.gridOptionsWrapper.isEnterMovesDownAfterEdit();\n if (enterMovesDownAfterEdit) {\n this.beans.navigationService.navigateToNextCell(null, KeyCode.DOWN, this.getCellPosition(), false);\n }\n };\n // user can also call this via API\n CellCtrl.prototype.flashCell = function (delays) {\n var flashDelay = delays && delays.flashDelay;\n var fadeDelay = delays && delays.fadeDelay;\n this.animateCell('data-changed', flashDelay, fadeDelay);\n };\n CellCtrl.prototype.animateCell = function (cssName, flashDelay, fadeDelay) {\n var _this = this;\n var fullName = \"ag-cell-\" + cssName;\n var animationFullName = \"ag-cell-\" + cssName + \"-animation\";\n var gridOptionsWrapper = this.beans.gridOptionsWrapper;\n if (!flashDelay) {\n flashDelay = gridOptionsWrapper.getCellFlashDelay();\n }\n if (!exists(fadeDelay)) {\n fadeDelay = gridOptionsWrapper.getCellFadeDelay();\n }\n // we want to highlight the cells, without any animation\n this.cellComp.addOrRemoveCssClass(fullName, true);\n this.cellComp.addOrRemoveCssClass(animationFullName, false);\n // then once that is applied, we remove the highlight with animation\n window.setTimeout(function () {\n if (!_this.isAlive()) {\n return;\n }\n _this.cellComp.addOrRemoveCssClass(fullName, false);\n _this.cellComp.addOrRemoveCssClass(animationFullName, true);\n _this.eGui.style.transition = \"background-color \" + fadeDelay + \"ms\";\n window.setTimeout(function () {\n if (!_this.isAlive()) {\n return;\n }\n // and then to leave things as we got them, we remove the animation\n _this.cellComp.addOrRemoveCssClass(animationFullName, false);\n _this.eGui.style.transition = '';\n }, fadeDelay);\n }, flashDelay);\n };\n CellCtrl.prototype.onFlashCells = function (event) {\n if (!this.cellComp) {\n return;\n }\n var cellId = this.beans.cellPositionUtils.createId(this.getCellPosition());\n var shouldFlash = event.cells[cellId];\n if (shouldFlash) {\n this.animateCell('highlight');\n }\n };\n CellCtrl.prototype.isCellEditable = function () {\n return this.column.isCellEditable(this.rowNode);\n };\n CellCtrl.prototype.isSuppressFillHandle = function () {\n return this.column.isSuppressFillHandle();\n };\n CellCtrl.prototype.formatValue = function (value) {\n var res = this.callValueFormatter(value);\n return res != null ? res : value;\n };\n CellCtrl.prototype.callValueFormatter = function (value) {\n return this.beans.valueFormatterService.formatValue(this.column, this.rowNode, value);\n };\n CellCtrl.prototype.updateAndFormatValue = function (force) {\n if (force === void 0) { force = false; }\n var oldValue = this.value;\n var oldValueFormatted = this.valueFormatted;\n this.value = this.getValueFromValueService();\n this.valueFormatted = this.callValueFormatter(this.value);\n var valuesDifferent = force ? true :\n !this.valuesAreEqual(oldValue, this.value) || this.valueFormatted != oldValueFormatted;\n return valuesDifferent;\n };\n CellCtrl.prototype.valuesAreEqual = function (val1, val2) {\n // if the user provided an equals method, use that, otherwise do simple comparison\n var colDef = this.column.getColDef();\n return colDef.equals ? colDef.equals(val1, val2) : val1 === val2;\n };\n CellCtrl.prototype.getComp = function () {\n return this.cellComp;\n };\n CellCtrl.prototype.getValueFromValueService = function () {\n // if we don't check this, then the grid will render leaf groups as open even if we are not\n // allowing the user to open leaf groups. confused? remember for pivot mode we don't allow\n // opening leaf groups, so we have to force leafGroups to be closed in case the user expanded\n // them via the API, or user user expanded them in the UI before turning on pivot mode\n var lockedClosedGroup = this.rowNode.leafGroup && this.beans.columnModel.isPivotMode();\n var isOpenGroup = this.rowNode.group && this.rowNode.expanded && !this.rowNode.footer && !lockedClosedGroup;\n // are we showing group footers\n var groupFootersEnabled = this.beans.gridOptionsWrapper.isGroupIncludeFooter();\n // if doing footers, we normally don't show agg data at group level when group is open\n var groupAlwaysShowAggData = this.beans.gridOptionsWrapper.isGroupSuppressBlankHeader();\n // if doing grouping and footers, we don't want to include the agg value\n // in the header when the group is open\n var ignoreAggData = (isOpenGroup && groupFootersEnabled) && !groupAlwaysShowAggData;\n var value = this.beans.valueService.getValue(this.column, this.rowNode, false, ignoreAggData);\n return value;\n };\n CellCtrl.prototype.getValue = function () {\n return this.value;\n };\n CellCtrl.prototype.getValueFormatted = function () {\n return this.valueFormatted;\n };\n CellCtrl.prototype.addDomData = function () {\n var _this = this;\n var element = this.getGui();\n this.beans.gridOptionsWrapper.setDomData(element, CellCtrl.DOM_DATA_KEY_CELL_CTRL, this);\n this.addDestroyFunc(function () { return _this.beans.gridOptionsWrapper.setDomData(element, CellCtrl.DOM_DATA_KEY_CELL_CTRL, null); });\n };\n CellCtrl.prototype.createEvent = function (domEvent, eventType) {\n var event = {\n type: eventType,\n node: this.rowNode,\n data: this.rowNode.data,\n value: this.value,\n column: this.column,\n colDef: this.column.getColDef(),\n context: this.beans.gridOptionsWrapper.getContext(),\n api: this.beans.gridApi,\n columnApi: this.beans.columnApi,\n rowPinned: this.rowNode.rowPinned,\n event: domEvent,\n rowIndex: this.rowNode.rowIndex\n };\n return event;\n };\n CellCtrl.prototype.onKeyPress = function (event) {\n this.cellKeyboardListenerFeature.onKeyPress(event);\n };\n CellCtrl.prototype.onKeyDown = function (event) {\n this.cellKeyboardListenerFeature.onKeyDown(event);\n };\n CellCtrl.prototype.onMouseEvent = function (eventName, mouseEvent) {\n this.cellMouseListenerFeature.onMouseEvent(eventName, mouseEvent);\n };\n CellCtrl.prototype.getGui = function () {\n return this.eGui;\n };\n CellCtrl.prototype.refreshToolTip = function () {\n this.tooltipFeature.refreshToolTip();\n };\n CellCtrl.prototype.getColSpanningList = function () {\n return this.cellPositionFeature.getColSpanningList();\n };\n CellCtrl.prototype.onLeftChanged = function () {\n if (!this.cellComp) {\n return;\n }\n this.cellPositionFeature.onLeftChanged();\n };\n CellCtrl.prototype.onDisplayedColumnsChanged = function () {\n if (!this.eGui) {\n return;\n }\n this.setAriaColIndex();\n };\n CellCtrl.prototype.setAriaColIndex = function () {\n var colIdx = this.beans.columnModel.getAriaColumnIndex(this.column);\n setAriaColIndex(this.getGui(), colIdx); // for react, we don't use JSX, as it slowed down column moving\n };\n CellCtrl.prototype.isSuppressNavigable = function () {\n return this.column.isSuppressNavigable(this.rowNode);\n };\n CellCtrl.prototype.onWidthChanged = function () {\n return this.cellPositionFeature.onWidthChanged();\n };\n CellCtrl.prototype.getColumn = function () {\n return this.column;\n };\n CellCtrl.prototype.getRowNode = function () {\n return this.rowNode;\n };\n CellCtrl.prototype.getBeans = function () {\n return this.beans;\n };\n CellCtrl.prototype.isPrintLayout = function () {\n return this.printLayout;\n };\n CellCtrl.prototype.appendChild = function (htmlElement) {\n this.eGui.appendChild(htmlElement);\n };\n CellCtrl.prototype.refreshHandle = function () {\n if (this.cellRangeFeature) {\n this.cellRangeFeature.refreshHandle();\n }\n };\n CellCtrl.prototype.getCellPosition = function () {\n return this.cellPosition;\n };\n CellCtrl.prototype.isEditing = function () {\n return this.editing;\n };\n // called by rowRenderer when user navigates via tab key\n CellCtrl.prototype.startRowOrCellEdit = function (key, charPress, event) {\n if (event === void 0) { event = null; }\n if (!this.cellComp) {\n return;\n }\n if (this.beans.gridOptionsWrapper.isFullRowEdit()) {\n this.rowCtrl.startRowEditing(key, charPress, this);\n }\n else {\n this.startEditing(key, charPress, true, event);\n }\n };\n CellCtrl.prototype.getRowCtrl = function () {\n return this.rowCtrl;\n };\n CellCtrl.prototype.getRowPosition = function () {\n return {\n rowIndex: this.cellPosition.rowIndex,\n rowPinned: this.cellPosition.rowPinned\n };\n };\n CellCtrl.prototype.updateRangeBordersIfRangeCount = function () {\n if (!this.cellComp) {\n return;\n }\n if (this.cellRangeFeature) {\n this.cellRangeFeature.updateRangeBordersIfRangeCount();\n }\n };\n CellCtrl.prototype.onRangeSelectionChanged = function () {\n if (!this.cellComp) {\n return;\n }\n if (this.cellRangeFeature) {\n this.cellRangeFeature.onRangeSelectionChanged();\n }\n };\n CellCtrl.prototype.isRangeSelectionEnabled = function () {\n return this.cellRangeFeature != null;\n };\n CellCtrl.prototype.focusCell = function (forceBrowserFocus) {\n if (forceBrowserFocus === void 0) { forceBrowserFocus = false; }\n this.beans.focusService.setFocusedCell({\n rowIndex: this.getCellPosition().rowIndex,\n column: this.column,\n rowPinned: this.rowNode.rowPinned,\n forceBrowserFocus: forceBrowserFocus\n });\n };\n CellCtrl.prototype.onRowIndexChanged = function () {\n // when index changes, this influences items that need the index, so we update the\n // grid cell so they are working off the new index.\n this.createCellPosition();\n // when the index of the row changes, ie means the cell may have lost or gained focus\n this.onCellFocused();\n // check range selection\n if (this.cellRangeFeature) {\n this.cellRangeFeature.onRangeSelectionChanged();\n }\n };\n CellCtrl.prototype.onFirstRightPinnedChanged = function () {\n if (!this.cellComp) {\n return;\n }\n var firstRightPinned = this.column.isFirstRightPinned();\n this.cellComp.addOrRemoveCssClass(CSS_CELL_FIRST_RIGHT_PINNED, firstRightPinned);\n };\n CellCtrl.prototype.onLastLeftPinnedChanged = function () {\n if (!this.cellComp) {\n return;\n }\n var lastLeftPinned = this.column.isLastLeftPinned();\n this.cellComp.addOrRemoveCssClass(CSS_CELL_LAST_LEFT_PINNED, lastLeftPinned);\n };\n CellCtrl.prototype.onCellFocused = function (event) {\n if (!this.cellComp || this.gow.isSuppressCellFocus()) {\n return;\n }\n var cellFocused = this.beans.focusService.isCellFocused(this.cellPosition);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_FOCUS, cellFocused);\n // see if we need to force browser focus - this can happen if focus is programmatically set\n if (cellFocused && event && event.forceBrowserFocus) {\n var focusEl = this.cellComp.getFocusableElement();\n focusEl.focus({ preventScroll: !!event.preventScrollOnBrowserFocus });\n }\n // if another cell was focused, and we are editing, then stop editing\n var fullRowEdit = this.beans.gridOptionsWrapper.isFullRowEdit();\n if (!cellFocused && !fullRowEdit && this.editing) {\n this.stopRowOrCellEdit();\n }\n };\n CellCtrl.prototype.createCellPosition = function () {\n this.cellPosition = {\n rowIndex: this.rowNode.rowIndex,\n rowPinned: makeNull(this.rowNode.rowPinned),\n column: this.column\n };\n };\n // CSS Classes that only get applied once, they never change\n CellCtrl.prototype.applyStaticCssClasses = function () {\n this.cellComp.addOrRemoveCssClass(CSS_CELL, true);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_NOT_INLINE_EDITING, true);\n // normal cells fill the height of the row. autoHeight cells have no height to let them\n // fit the height of content.\n var autoHeight = this.column.isAutoHeight() == true;\n this.cellComp.addOrRemoveCssClass(CSS_AUTO_HEIGHT, autoHeight);\n this.cellComp.addOrRemoveCssClass(CSS_NORMAL_HEIGHT, !autoHeight);\n };\n CellCtrl.prototype.onColumnHover = function () {\n if (!this.cellComp) {\n return;\n }\n if (!this.beans.gridOptionsWrapper.isColumnHoverHighlight()) {\n return;\n }\n var isHovered = this.beans.columnHoverService.isHovered(this.column);\n this.cellComp.addOrRemoveCssClass(CSS_COLUMN_HOVER, isHovered);\n };\n CellCtrl.prototype.onColDefChanged = function () {\n if (!this.cellComp) {\n return;\n }\n this.setWrapText();\n if (!this.editing) {\n this.refreshCell({ forceRefresh: true, suppressFlash: true });\n }\n };\n CellCtrl.prototype.setWrapText = function () {\n var value = this.column.getColDef().wrapText == true;\n this.cellComp.addOrRemoveCssClass(CSS_CELL_WRAP_TEXT, value);\n };\n CellCtrl.prototype.dispatchCellContextMenuEvent = function (event) {\n var colDef = this.column.getColDef();\n var cellContextMenuEvent = this.createEvent(event, Events.EVENT_CELL_CONTEXT_MENU);\n this.beans.eventService.dispatchEvent(cellContextMenuEvent);\n if (colDef.onCellContextMenu) {\n // to make the callback async, do in a timeout\n window.setTimeout(function () { return colDef.onCellContextMenu(cellContextMenuEvent); }, 0);\n }\n };\n CellCtrl.prototype.getCellRenderer = function () {\n return this.cellComp ? this.cellComp.getCellRenderer() : null;\n };\n CellCtrl.prototype.getCellEditor = function () {\n return this.cellComp ? this.cellComp.getCellEditor() : null;\n };\n CellCtrl.prototype.destroy = function () {\n this.onCellCompAttachedFuncs = [];\n _super.prototype.destroy.call(this);\n };\n CellCtrl.prototype.createSelectionCheckbox = function () {\n var cbSelectionComponent = new CheckboxSelectionComponent();\n this.beans.context.createBean(cbSelectionComponent);\n cbSelectionComponent.init({ rowNode: this.rowNode, column: this.column });\n // put the checkbox in before the value\n return cbSelectionComponent;\n };\n CellCtrl.prototype.createDndSource = function () {\n var dndSourceComp = new DndSourceComp(this.rowNode, this.column, this.beans, this.eGui);\n this.beans.context.createBean(dndSourceComp);\n return dndSourceComp;\n };\n CellCtrl.prototype.registerRowDragger = function (customElement, dragStartPixels, suppressVisibilityChange) {\n var _this = this;\n // if previously existed, then we are only updating\n if (this.customRowDragComp) {\n this.customRowDragComp.setDragElement(customElement, dragStartPixels);\n return;\n }\n var newComp = this.createRowDragComp(customElement, dragStartPixels, suppressVisibilityChange);\n if (newComp) {\n this.customRowDragComp = newComp;\n this.addDestroyFunc(function () { return _this.beans.context.destroyBean(newComp); });\n }\n };\n CellCtrl.prototype.createRowDragComp = function (customElement, dragStartPixels, suppressVisibilityChange) {\n var _this = this;\n var pagination = this.beans.gridOptionsWrapper.isPagination();\n var rowDragManaged = this.beans.gridOptionsWrapper.isRowDragManaged();\n var clientSideRowModelActive = this.beans.gridOptionsWrapper.isRowModelDefault();\n if (rowDragManaged) {\n // row dragging only available in default row model\n if (!clientSideRowModelActive) {\n doOnce(function () { return console.warn('AG Grid: managed row dragging is only allowed in the Client Side Row Model'); }, 'CellComp.addRowDragging');\n return;\n }\n if (pagination) {\n doOnce(function () { return console.warn('AG Grid: managed row dragging is not possible when doing pagination'); }, 'CellComp.addRowDragging');\n return;\n }\n }\n // otherwise (normal case) we are creating a RowDraggingComp for the first time\n var rowDragComp = new RowDragComp(function () { return _this.value; }, this.rowNode, this.column, customElement, dragStartPixels, suppressVisibilityChange);\n this.beans.context.createBean(rowDragComp);\n return rowDragComp;\n };\n CellCtrl.DOM_DATA_KEY_CELL_CTRL = 'cellCtrl';\n return CellCtrl;\n}(BeanStub));\nexport { CellCtrl };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __values = (this && this.__values) || function(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nimport { Constants } from \"../../constants/constants\";\nimport { BeanStub } from \"../../context/beanStub\";\nimport { RowHighlightPosition, RowNode } from \"../../entities/rowNode\";\nimport { Events } from \"../../events\";\nimport { RowContainerType } from \"../../gridBodyComp/rowContainer/rowContainerCtrl\";\nimport { ModuleNames } from \"../../modules/moduleNames\";\nimport { ModuleRegistry } from \"../../modules/moduleRegistry\";\nimport { setAriaExpanded, setAriaLabel, setAriaRowIndex, setAriaSelected } from \"../../utils/aria\";\nimport { isElementChildOfClass } from \"../../utils/dom\";\nimport { isStopPropagationForAgGrid } from \"../../utils/event\";\nimport { doOnce, executeNextVMTurn } from \"../../utils/function\";\nimport { exists, makeNull } from \"../../utils/generic\";\nimport { escapeString } from \"../../utils/string\";\nimport { CellCtrl } from \"../cell/cellCtrl\";\nimport { RowDragComp } from \"./rowDragComp\";\nexport var RowType;\n(function (RowType) {\n RowType[\"Normal\"] = \"Normal\";\n RowType[\"FullWidth\"] = \"FullWidth\";\n RowType[\"FullWidthLoading\"] = \"FullWidthLoading\";\n RowType[\"FullWidthGroup\"] = \"FullWidthGroup\";\n RowType[\"FullWidthDetail\"] = \"FullWidthDetail\";\n})(RowType || (RowType = {}));\nvar instanceIdSequence = 0;\nvar RowCtrl = /** @class */ (function (_super) {\n __extends(RowCtrl, _super);\n function RowCtrl(rowNode, beans, animateIn, useAnimationFrameForCreate, printLayout) {\n var _this = _super.call(this) || this;\n _this.allRowGuis = [];\n _this.active = true;\n _this.centerCellCtrls = { list: [], map: {} };\n _this.leftCellCtrls = { list: [], map: {} };\n _this.rightCellCtrls = { list: [], map: {} };\n _this.lastMouseDownOnDragger = false;\n _this.updateColumnListsPending = false;\n _this.beans = beans;\n _this.rowNode = rowNode;\n _this.paginationPage = _this.beans.paginationProxy.getCurrentPage();\n _this.useAnimationFrameForCreate = useAnimationFrameForCreate;\n _this.printLayout = printLayout;\n _this.instanceId = rowNode.id + '-' + instanceIdSequence++;\n _this.setAnimateFlags(animateIn);\n _this.rowFocused = _this.beans.focusService.isRowFocused(_this.rowNode.rowIndex, _this.rowNode.rowPinned);\n _this.rowLevel = _this.beans.rowCssClassCalculator.calculateRowLevel(_this.rowNode);\n _this.setRowType();\n _this.addListeners();\n return _this;\n }\n RowCtrl.prototype.isSticky = function () {\n return this.rowNode.sticky;\n };\n RowCtrl.prototype.getBeans = function () {\n return this.beans;\n };\n RowCtrl.prototype.getInstanceId = function () {\n return this.instanceId;\n };\n RowCtrl.prototype.setComp = function (rowComp, element, containerType) {\n var gui = { rowComp: rowComp, element: element, containerType: containerType };\n this.allRowGuis.push(gui);\n if (containerType === RowContainerType.LEFT) {\n this.leftGui = gui;\n }\n else if (containerType === RowContainerType.RIGHT) {\n this.rightGui = gui;\n }\n else if (containerType === RowContainerType.FULL_WIDTH) {\n this.fullWidthGui = gui;\n }\n else {\n this.centerGui = gui;\n }\n var allNormalPresent = this.leftGui != null && this.rightGui != null && this.centerGui != null;\n var fullWidthPresent = this.fullWidthGui != null;\n if (allNormalPresent || fullWidthPresent) {\n this.initialiseRowComps();\n }\n if (this.rowType !== 'FullWidthLoading') {\n // this is fired within setComp as we know that the component renderer is now trying to render.\n // linked with the fact the function implementation queues behind requestAnimationFrame should allow\n // us to be certain that all rendering is done by the time the event fires.\n this.beans.rowRenderer.dispatchFirstDataRenderedEvent();\n }\n };\n RowCtrl.prototype.isCacheable = function () {\n return this.rowType === RowType.FullWidthDetail\n && this.beans.gridOptionsWrapper.isKeepDetailRows();\n };\n RowCtrl.prototype.setCached = function (cached) {\n var displayValue = cached ? 'none' : '';\n this.allRowGuis.forEach(function (rg) { return rg.element.style.display = displayValue; });\n };\n RowCtrl.prototype.initialiseRowComps = function () {\n var _this = this;\n var gow = this.beans.gridOptionsWrapper;\n this.onRowHeightChanged();\n this.updateRowIndexes();\n this.setFocusedClasses();\n this.setStylesFromGridOptions();\n if (gow.isRowSelection() && this.rowNode.selectable) {\n this.onRowSelected();\n }\n this.updateColumnLists(!this.useAnimationFrameForCreate);\n if (this.slideRowIn) {\n executeNextVMTurn(this.onTopChanged.bind(this));\n }\n if (this.fadeRowIn) {\n executeNextVMTurn(function () {\n _this.allRowGuis.forEach(function (gui) { return gui.rowComp.addOrRemoveCssClass('ag-opacity-zero', false); });\n });\n }\n var businessKey = this.getRowBusinessKey();\n var rowIdSanitised = escapeString(this.rowNode.id);\n var businessKeySanitised = escapeString(businessKey);\n this.allRowGuis.forEach(function (gui) {\n var comp = gui.rowComp;\n comp.setRole('row');\n var initialRowClasses = _this.getInitialRowClasses(gui.containerType);\n initialRowClasses.forEach(function (name) { return comp.addOrRemoveCssClass(name, true); });\n if (_this.rowNode.group) {\n setAriaExpanded(gui.element, _this.rowNode.expanded == true);\n }\n if (rowIdSanitised != null) {\n comp.setRowId(rowIdSanitised);\n }\n if (businessKeySanitised != null) {\n comp.setRowBusinessKey(businessKeySanitised);\n }\n if (_this.isFullWidth() && !_this.beans.gridOptionsWrapper.isSuppressCellFocus()) {\n comp.setTabIndex(-1);\n }\n // DOM DATA\n gow.setDomData(gui.element, RowCtrl.DOM_DATA_KEY_ROW_CTRL, _this);\n _this.addDestroyFunc(function () { return gow.setDomData(gui.element, RowCtrl.DOM_DATA_KEY_ROW_CTRL, null); });\n // adding hover functionality adds listener to this row, so we\n // do it lazily in an animation frame\n if (_this.useAnimationFrameForCreate) {\n _this.beans.animationFrameService.createTask(_this.addHoverFunctionality.bind(_this, gui.element), _this.rowNode.rowIndex, 'createTasksP2');\n }\n else {\n _this.addHoverFunctionality(gui.element);\n }\n if (_this.isFullWidth()) {\n _this.setupFullWidth(gui);\n }\n if (gow.isRowDragEntireRow()) {\n _this.addRowDraggerToRow(gui);\n }\n if (_this.useAnimationFrameForCreate) {\n // the height animation we only want active after the row is alive for 1 second.\n // this stops the row animation working when rows are initially crated. otherwise\n // auto-height rows get inserted into the dom and resized immediately, which gives\n // very bad UX (eg 10 rows get inserted, then all 10 expand, look particularly bad\n // when scrolling). so this makes sure when rows are shown for the first time, they\n // are resized immediately without animation.\n _this.beans.animationFrameService.addDestroyTask(function () {\n if (!_this.isAlive()) {\n return;\n }\n gui.rowComp.addOrRemoveCssClass('ag-after-created', true);\n });\n }\n });\n this.executeProcessRowPostCreateFunc();\n };\n RowCtrl.prototype.addRowDraggerToRow = function (gui) {\n var gow = this.beans.gridOptionsWrapper;\n if (gow.isEnableRangeSelection()) {\n doOnce(function () {\n console.warn('AG Grid: Setting `rowDragEntireRow: true` in the gridOptions doesn\\'t work with `enableRangeSelection: true`');\n }, 'rowDragAndRangeSelectionEnabled');\n return;\n }\n var rowDragComp = new RowDragComp(function () { return '1 row'; }, this.rowNode, undefined, gui.element, undefined, true);\n this.createManagedBean(rowDragComp, this.beans.context);\n };\n RowCtrl.prototype.setupFullWidth = function (gui) {\n var pinned = this.getPinnedForContainer(gui.containerType);\n var params = this.createFullWidthParams(gui.element, pinned);\n var masterDetailModuleLoaded = ModuleRegistry.isRegistered(ModuleNames.MasterDetailModule);\n if (this.rowType == RowType.FullWidthDetail && !masterDetailModuleLoaded) {\n if (ModuleRegistry.isPackageBased()) {\n console.warn(\"AG Grid: cell renderer 'agDetailCellRenderer' (for master detail) not found. Can only be used with ag-grid-enterprise package.\");\n }\n else {\n console.warn(\"AG Grid: cell renderer 'agDetailCellRenderer' (for master detail) not found. Can only be used with AG Grid Enterprise Module \" + ModuleNames.MasterDetailModule);\n }\n return;\n }\n var compDetails;\n switch (this.rowType) {\n case RowType.FullWidthDetail:\n compDetails = this.beans.userComponentFactory.getFullWidthDetailCellRendererDetails(params);\n break;\n case RowType.FullWidthGroup:\n compDetails = this.beans.userComponentFactory.getFullWidthGroupCellRendererDetails(params);\n break;\n case RowType.FullWidthLoading:\n compDetails = this.beans.userComponentFactory.getFullWidthLoadingCellRendererDetails(params);\n break;\n default:\n compDetails = this.beans.userComponentFactory.getFullWidthCellRendererDetails(params);\n break;\n }\n gui.rowComp.showFullWidth(compDetails);\n };\n RowCtrl.prototype.isPrintLayout = function () {\n return this.printLayout;\n };\n // use by autoWidthCalculator, as it clones the elements\n RowCtrl.prototype.getCellElement = function (column) {\n var cellCtrl = this.getCellCtrl(column);\n return cellCtrl ? cellCtrl.getGui() : null;\n };\n RowCtrl.prototype.executeProcessRowPostCreateFunc = function () {\n var func = this.beans.gridOptionsWrapper.getProcessRowPostCreateFunc();\n if (!func) {\n return;\n }\n var params = {\n eRow: this.centerGui ? this.centerGui.element : undefined,\n ePinnedLeftRow: this.leftGui ? this.leftGui.element : undefined,\n ePinnedRightRow: this.rightGui ? this.rightGui.element : undefined,\n node: this.rowNode,\n rowIndex: this.rowNode.rowIndex,\n addRenderedRowListener: this.addEventListener.bind(this),\n };\n func(params);\n };\n RowCtrl.prototype.setRowType = function () {\n var isStub = this.rowNode.stub;\n var isFullWidthCell = this.rowNode.isFullWidthCell();\n var isDetailCell = this.beans.doingMasterDetail && this.rowNode.detail;\n var pivotMode = this.beans.columnModel.isPivotMode();\n // we only use full width for groups, not footers. it wouldn't make sense to include footers if not looking\n // for totals. if users complain about this, then we should introduce a new property 'footerUseEntireRow'\n // so each can be set independently (as a customer complained about footers getting full width, hence\n // introducing this logic)\n var isGroupRow = !!this.rowNode.group && !this.rowNode.footer;\n var isFullWidthGroup = isGroupRow && this.beans.gridOptionsWrapper.isGroupUseEntireRow(pivotMode);\n if (isStub) {\n this.rowType = RowType.FullWidthLoading;\n }\n else if (isDetailCell) {\n this.rowType = RowType.FullWidthDetail;\n }\n else if (isFullWidthCell) {\n this.rowType = RowType.FullWidth;\n }\n else if (isFullWidthGroup) {\n this.rowType = RowType.FullWidthGroup;\n }\n else {\n this.rowType = RowType.Normal;\n }\n };\n RowCtrl.prototype.updateColumnLists = function (suppressAnimationFrame) {\n var _this = this;\n if (suppressAnimationFrame === void 0) { suppressAnimationFrame = false; }\n if (this.isFullWidth()) {\n return;\n }\n var noAnimation = suppressAnimationFrame\n || this.beans.gridOptionsWrapper.isSuppressAnimationFrame()\n || this.printLayout;\n if (noAnimation) {\n this.updateColumnListsImpl();\n return;\n }\n if (this.updateColumnListsPending) {\n return;\n }\n this.beans.animationFrameService.createTask(function () {\n if (!_this.active) {\n return;\n }\n _this.updateColumnListsImpl();\n }, this.rowNode.rowIndex, 'createTasksP1');\n this.updateColumnListsPending = true;\n };\n RowCtrl.prototype.createCellCtrls = function (prev, cols, pinned) {\n var _this = this;\n if (pinned === void 0) { pinned = null; }\n var res = {\n list: [],\n map: {}\n };\n var addCell = function (colInstanceId, cellCtrl) {\n res.list.push(cellCtrl);\n res.map[colInstanceId] = cellCtrl;\n };\n cols.forEach(function (col) {\n // we use instanceId's rather than colId as it's possible there is a Column with same Id,\n // but it's referring to a different column instance. Happens a lot with pivot, as pivot col id's are\n // reused eg pivot_0, pivot_1 etc\n var colInstanceId = col.getInstanceId();\n var cellCtrl = prev.map[colInstanceId];\n if (!cellCtrl) {\n cellCtrl = new CellCtrl(col, _this.rowNode, _this.beans, _this);\n }\n addCell(colInstanceId, cellCtrl);\n });\n prev.list.forEach(function (prevCellCtrl) {\n var cellInResult = res.map[prevCellCtrl.getColumn().getInstanceId()] != null;\n if (cellInResult) {\n return;\n }\n var keepCell = !_this.isCellEligibleToBeRemoved(prevCellCtrl, pinned);\n if (keepCell) {\n addCell(prevCellCtrl.getColumn().getInstanceId(), prevCellCtrl);\n return;\n }\n prevCellCtrl.destroy();\n });\n return res;\n };\n RowCtrl.prototype.updateColumnListsImpl = function () {\n var _this = this;\n this.updateColumnListsPending = false;\n var columnModel = this.beans.columnModel;\n if (this.printLayout) {\n this.centerCellCtrls = this.createCellCtrls(this.centerCellCtrls, columnModel.getAllDisplayedColumns());\n this.leftCellCtrls = { list: [], map: {} };\n this.rightCellCtrls = { list: [], map: {} };\n }\n else {\n var centerCols = columnModel.getViewportCenterColumnsForRow(this.rowNode);\n this.centerCellCtrls = this.createCellCtrls(this.centerCellCtrls, centerCols);\n var leftCols = columnModel.getDisplayedLeftColumnsForRow(this.rowNode);\n this.leftCellCtrls = this.createCellCtrls(this.leftCellCtrls, leftCols, Constants.PINNED_LEFT);\n var rightCols = columnModel.getDisplayedRightColumnsForRow(this.rowNode);\n this.rightCellCtrls = this.createCellCtrls(this.rightCellCtrls, rightCols, Constants.PINNED_RIGHT);\n }\n this.allRowGuis.forEach(function (item) {\n var cellControls = item.containerType === RowContainerType.LEFT ? _this.leftCellCtrls :\n item.containerType === RowContainerType.RIGHT ? _this.rightCellCtrls : _this.centerCellCtrls;\n item.rowComp.setCellCtrls(cellControls.list);\n });\n };\n RowCtrl.prototype.isCellEligibleToBeRemoved = function (cellCtrl, nextContainerPinned) {\n var REMOVE_CELL = true;\n var KEEP_CELL = false;\n // always remove the cell if it's not rendered or if it's in the wrong pinned location\n var column = cellCtrl.getColumn();\n if (column.getPinned() != nextContainerPinned) {\n return REMOVE_CELL;\n }\n // we want to try and keep editing and focused cells\n var editing = cellCtrl.isEditing();\n var focused = this.beans.focusService.isCellFocused(cellCtrl.getCellPosition());\n var mightWantToKeepCell = editing || focused;\n if (mightWantToKeepCell) {\n var column_1 = cellCtrl.getColumn();\n var displayedColumns = this.beans.columnModel.getAllDisplayedColumns();\n var cellStillDisplayed = displayedColumns.indexOf(column_1) >= 0;\n return cellStillDisplayed ? KEEP_CELL : REMOVE_CELL;\n }\n return REMOVE_CELL;\n };\n RowCtrl.prototype.setAnimateFlags = function (animateIn) {\n if (!this.isSticky() && animateIn) {\n var oldRowTopExists = exists(this.rowNode.oldRowTop);\n // if the row had a previous position, we slide it in (animate row top)\n this.slideRowIn = oldRowTopExists;\n // if the row had no previous position, we fade it in (animate\n this.fadeRowIn = !oldRowTopExists;\n }\n else {\n this.slideRowIn = false;\n this.fadeRowIn = false;\n }\n };\n RowCtrl.prototype.isEditing = function () {\n return this.editingRow;\n };\n RowCtrl.prototype.stopRowEditing = function (cancel) {\n this.stopEditing(cancel);\n };\n RowCtrl.prototype.isFullWidth = function () {\n return this.rowType !== RowType.Normal;\n };\n RowCtrl.prototype.getRowType = function () {\n return this.rowType;\n };\n RowCtrl.prototype.refreshFullWidth = function () {\n var _this = this;\n // returns 'true' if refresh succeeded\n var tryRefresh = function (gui, pinned) {\n if (!gui) {\n return true;\n } // no refresh needed\n var cellRenderer = gui.rowComp.getFullWidthCellRenderer();\n // no cell renderer, either means comp not yet ready, or comp ready but now reference\n // to it (happens in react when comp is stateless). if comp not ready, we don't need to\n // refresh, however we don't know which one, so we refresh to cover the case where it's\n // react comp without reference so need to force a refresh\n if (!cellRenderer) {\n return false;\n }\n // no refresh method present, so can't refresh, hard refresh needed\n if (!cellRenderer.refresh) {\n return false;\n }\n var params = _this.createFullWidthParams(gui.element, pinned);\n var refreshSucceeded = cellRenderer.refresh(params);\n return refreshSucceeded;\n };\n var fullWidthSuccess = tryRefresh(this.fullWidthGui, null);\n var centerSuccess = tryRefresh(this.centerGui, null);\n var leftSuccess = tryRefresh(this.leftGui, Constants.PINNED_LEFT);\n var rightSuccess = tryRefresh(this.rightGui, Constants.PINNED_RIGHT);\n var allFullWidthRowsRefreshed = fullWidthSuccess && centerSuccess && leftSuccess && rightSuccess;\n return allFullWidthRowsRefreshed;\n };\n RowCtrl.prototype.addListeners = function () {\n this.addManagedListener(this.rowNode, RowNode.EVENT_HEIGHT_CHANGED, this.onRowHeightChanged.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_ROW_SELECTED, this.onRowSelected.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_ROW_INDEX_CHANGED, this.onRowIndexChanged.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_TOP_CHANGED, this.onTopChanged.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_EXPANDED_CHANGED, this.updateExpandedCss.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_HAS_CHILDREN_CHANGED, this.updateExpandedCss.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_DATA_CHANGED, this.onRowNodeDataChanged.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_CELL_CHANGED, this.onRowNodeCellChanged.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_HIGHLIGHT_CHANGED, this.onRowNodeHighlightChanged.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_DRAGGING_CHANGED, this.onRowNodeDraggingChanged.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_UI_LEVEL_CHANGED, this.onUiLevelChanged.bind(this));\n var eventService = this.beans.eventService;\n this.addManagedListener(eventService, Events.EVENT_PAGINATION_PIXEL_OFFSET_CHANGED, this.onPaginationPixelOffsetChanged.bind(this));\n this.addManagedListener(eventService, Events.EVENT_HEIGHT_SCALE_CHANGED, this.onTopChanged.bind(this));\n this.addManagedListener(eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this));\n this.addManagedListener(eventService, Events.EVENT_VIRTUAL_COLUMNS_CHANGED, this.onVirtualColumnsChanged.bind(this));\n this.addManagedListener(eventService, Events.EVENT_CELL_FOCUSED, this.onCellFocusChanged.bind(this));\n this.addManagedListener(eventService, Events.EVENT_PAGINATION_CHANGED, this.onPaginationChanged.bind(this));\n this.addManagedListener(eventService, Events.EVENT_MODEL_UPDATED, this.onModelUpdated.bind(this));\n this.addManagedListener(eventService, Events.EVENT_COLUMN_MOVED, this.onColumnMoved.bind(this));\n this.addListenersForCellComps();\n };\n RowCtrl.prototype.onColumnMoved = function () {\n this.updateColumnLists();\n };\n RowCtrl.prototype.addListenersForCellComps = function () {\n var _this = this;\n this.addManagedListener(this.rowNode, RowNode.EVENT_ROW_INDEX_CHANGED, function () {\n _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.onRowIndexChanged(); });\n });\n this.addManagedListener(this.rowNode, RowNode.EVENT_CELL_CHANGED, function (event) {\n _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.onCellChanged(event); });\n });\n };\n RowCtrl.prototype.onRowNodeDataChanged = function (event) {\n // if this is an update, we want to refresh, as this will allow the user to put in a transition\n // into the cellRenderer refresh method. otherwise this might be completely new data, in which case\n // we will want to completely replace the cells\n this.getAllCellCtrls().forEach(function (cellCtrl) {\n return cellCtrl.refreshCell({\n suppressFlash: !event.update,\n newData: !event.update\n });\n });\n // check for selected also, as this could be after lazy loading of the row data, in which case\n // the id might of just gotten set inside the row and the row selected state may of changed\n // as a result. this is what happens when selected rows are loaded in virtual pagination.\n // - niall note - since moving to the stub component, this may no longer be true, as replacing\n // the stub component now replaces the entire row\n this.onRowSelected();\n // as data has changed, then the style and class needs to be recomputed\n this.postProcessCss();\n };\n RowCtrl.prototype.onRowNodeCellChanged = function () {\n // as data has changed, then the style and class needs to be recomputed\n this.postProcessCss();\n };\n RowCtrl.prototype.postProcessCss = function () {\n this.setStylesFromGridOptions();\n this.postProcessClassesFromGridOptions();\n this.postProcessRowClassRules();\n this.postProcessRowDragging();\n };\n RowCtrl.prototype.onRowNodeHighlightChanged = function () {\n var highlighted = this.rowNode.highlighted;\n this.allRowGuis.forEach(function (gui) {\n var aboveOn = highlighted === RowHighlightPosition.Above;\n var belowOn = highlighted === RowHighlightPosition.Below;\n gui.rowComp.addOrRemoveCssClass('ag-row-highlight-above', aboveOn);\n gui.rowComp.addOrRemoveCssClass('ag-row-highlight-below', belowOn);\n });\n };\n RowCtrl.prototype.onRowNodeDraggingChanged = function () {\n this.postProcessRowDragging();\n };\n RowCtrl.prototype.postProcessRowDragging = function () {\n var dragging = this.rowNode.dragging;\n this.allRowGuis.forEach(function (gui) { return gui.rowComp.addOrRemoveCssClass('ag-row-dragging', dragging); });\n };\n RowCtrl.prototype.updateExpandedCss = function () {\n var expandable = this.rowNode.isExpandable();\n var expanded = this.rowNode.expanded == true;\n this.allRowGuis.forEach(function (gui) {\n gui.rowComp.addOrRemoveCssClass('ag-row-group', expandable);\n gui.rowComp.addOrRemoveCssClass('ag-row-group-expanded', expandable && expanded);\n gui.rowComp.addOrRemoveCssClass('ag-row-group-contracted', expandable && !expanded);\n setAriaExpanded(gui.element, expandable && expanded);\n });\n };\n RowCtrl.prototype.onDisplayedColumnsChanged = function () {\n // we skip animations for onDisplayedColumnChanged, as otherwise the client could remove columns and\n // then set data, and any old valueGetter's (ie from cols that were removed) would still get called.\n this.updateColumnLists(true);\n if (this.beans.columnModel.wasAutoRowHeightEverActive()) {\n this.rowNode.checkAutoHeights();\n }\n };\n RowCtrl.prototype.onVirtualColumnsChanged = function () {\n this.updateColumnLists();\n };\n RowCtrl.prototype.getRowPosition = function () {\n return {\n rowPinned: makeNull(this.rowNode.rowPinned),\n rowIndex: this.rowNode.rowIndex\n };\n };\n RowCtrl.prototype.onKeyboardNavigate = function (keyboardEvent) {\n var currentFullWidthComp = this.allRowGuis.find(function (c) { return c.element.contains(keyboardEvent.target); });\n var currentFullWidthContainer = currentFullWidthComp ? currentFullWidthComp.element : null;\n var isFullWidthContainerFocused = currentFullWidthContainer === keyboardEvent.target;\n if (!isFullWidthContainerFocused) {\n return;\n }\n var node = this.rowNode;\n var lastFocusedCell = this.beans.focusService.getFocusedCell();\n var cellPosition = {\n rowIndex: node.rowIndex,\n rowPinned: node.rowPinned,\n column: (lastFocusedCell && lastFocusedCell.column)\n };\n this.beans.navigationService.navigateToNextCell(keyboardEvent, keyboardEvent.key, cellPosition, true);\n keyboardEvent.preventDefault();\n };\n RowCtrl.prototype.onTabKeyDown = function (keyboardEvent) {\n if (keyboardEvent.defaultPrevented || isStopPropagationForAgGrid(keyboardEvent)) {\n return;\n }\n var currentFullWidthComp = this.allRowGuis.find(function (c) { return c.element.contains(keyboardEvent.target); });\n var currentFullWidthContainer = currentFullWidthComp ? currentFullWidthComp.element : null;\n var isFullWidthContainerFocused = currentFullWidthContainer === keyboardEvent.target;\n var nextEl = null;\n if (!isFullWidthContainerFocused) {\n nextEl = this.beans.focusService.findNextFocusableElement(currentFullWidthContainer, false, keyboardEvent.shiftKey);\n }\n if ((this.isFullWidth() && isFullWidthContainerFocused) || !nextEl) {\n this.beans.navigationService.onTabKeyDown(this, keyboardEvent);\n }\n };\n RowCtrl.prototype.onFullWidthRowFocused = function (event) {\n var _a;\n var node = this.rowNode;\n var isFocused = this.isFullWidth() && event.rowIndex === node.rowIndex && event.rowPinned == node.rowPinned;\n var element = this.fullWidthGui ? this.fullWidthGui.element : (_a = this.centerGui) === null || _a === void 0 ? void 0 : _a.element;\n if (!element) {\n return;\n } // can happen with react ui, comp not yet ready\n element.classList.toggle('ag-full-width-focus', isFocused);\n if (isFocused) {\n // we don't scroll normal rows into view when we focus them, so we don't want\n // to scroll Full Width rows either.\n element.focus({ preventScroll: true });\n }\n };\n RowCtrl.prototype.refreshCell = function (cellCtrl) {\n this.centerCellCtrls = this.removeCellCtrl(this.centerCellCtrls, cellCtrl);\n this.leftCellCtrls = this.removeCellCtrl(this.leftCellCtrls, cellCtrl);\n this.rightCellCtrls = this.removeCellCtrl(this.rightCellCtrls, cellCtrl);\n this.updateColumnLists();\n };\n RowCtrl.prototype.removeCellCtrl = function (prev, cellCtrlToRemove) {\n var res = {\n list: [],\n map: {}\n };\n prev.list.forEach(function (cellCtrl) {\n if (cellCtrl === cellCtrlToRemove) {\n return;\n }\n res.list.push(cellCtrl);\n res.map[cellCtrl.getInstanceId()] = cellCtrl;\n });\n return res;\n };\n RowCtrl.prototype.onMouseEvent = function (eventName, mouseEvent) {\n switch (eventName) {\n case 'dblclick':\n this.onRowDblClick(mouseEvent);\n break;\n case 'click':\n this.onRowClick(mouseEvent);\n break;\n case 'touchstart':\n case 'mousedown':\n this.onRowMouseDown(mouseEvent);\n break;\n }\n };\n RowCtrl.prototype.createRowEvent = function (type, domEvent) {\n return {\n type: type,\n node: this.rowNode,\n data: this.rowNode.data,\n rowIndex: this.rowNode.rowIndex,\n rowPinned: this.rowNode.rowPinned,\n context: this.beans.gridOptionsWrapper.getContext(),\n api: this.beans.gridOptionsWrapper.getApi(),\n columnApi: this.beans.gridOptionsWrapper.getColumnApi(),\n event: domEvent\n };\n };\n RowCtrl.prototype.createRowEventWithSource = function (type, domEvent) {\n var event = this.createRowEvent(type, domEvent);\n // when first developing this, we included the rowComp in the event.\n // this seems very weird. so when introducing the event types, i left the 'source'\n // out of the type, and just include the source in the two places where this event\n // was fired (rowClicked and rowDoubleClicked). it doesn't make sense for any\n // users to be using this, as the rowComp isn't an object we expose, so would be\n // very surprising if a user was using it.\n event.source = this;\n return event;\n };\n RowCtrl.prototype.onRowDblClick = function (mouseEvent) {\n if (isStopPropagationForAgGrid(mouseEvent)) {\n return;\n }\n var agEvent = this.createRowEventWithSource(Events.EVENT_ROW_DOUBLE_CLICKED, mouseEvent);\n this.beans.eventService.dispatchEvent(agEvent);\n };\n RowCtrl.prototype.onRowMouseDown = function (mouseEvent) {\n this.lastMouseDownOnDragger = isElementChildOfClass(mouseEvent.target, 'ag-row-drag', 3);\n if (!this.isFullWidth()) {\n return;\n }\n var node = this.rowNode;\n var columnModel = this.beans.columnModel;\n if (this.beans.rangeService) {\n this.beans.rangeService.removeAllCellRanges();\n }\n this.beans.focusService.setFocusedCell({\n rowIndex: node.rowIndex,\n column: columnModel.getAllDisplayedColumns()[0],\n rowPinned: node.rowPinned,\n forceBrowserFocus: true\n });\n };\n RowCtrl.prototype.onRowClick = function (mouseEvent) {\n var stop = isStopPropagationForAgGrid(mouseEvent) || this.lastMouseDownOnDragger;\n if (stop) {\n return;\n }\n var agEvent = this.createRowEventWithSource(Events.EVENT_ROW_CLICKED, mouseEvent);\n this.beans.eventService.dispatchEvent(agEvent);\n // ctrlKey for windows, metaKey for Apple\n var multiSelectKeyPressed = mouseEvent.ctrlKey || mouseEvent.metaKey;\n var shiftKeyPressed = mouseEvent.shiftKey;\n // we do not allow selecting the group by clicking, when groupSelectChildren, as the logic to\n // handle this is broken. to observe, change the logic below and allow groups to be selected.\n // you will see the group gets selected, then all children get selected, then the grid unselects\n // the children (as the default behaviour when clicking is to unselect other rows) which results\n // in the group getting unselected (as all children are unselected). the correct thing would be\n // to change this, so that children of the selected group are not then subsequenly un-selected.\n var groupSelectsChildren = this.beans.gridOptionsWrapper.isGroupSelectsChildren();\n if (\n // we do not allow selecting groups by clicking (as the click here expands the group), or if it's a detail row,\n // so return if it's a group row\n (groupSelectsChildren && this.rowNode.group) ||\n // this is needed so we don't unselect other rows when we click this row, eg if this row is not selectable,\n // and we click it, the selection should not change (ie any currently selected row should stay selected)\n !this.rowNode.selectable ||\n // we also don't allow selection of pinned rows\n this.rowNode.rowPinned ||\n // if no selection method enabled, do nothing\n !this.beans.gridOptionsWrapper.isRowSelection() ||\n // if click selection suppressed, do nothing\n this.beans.gridOptionsWrapper.isSuppressRowClickSelection()) {\n return;\n }\n var multiSelectOnClick = this.beans.gridOptionsWrapper.isRowMultiSelectWithClick();\n var rowDeselectionWithCtrl = !this.beans.gridOptionsWrapper.isSuppressRowDeselection();\n if (this.rowNode.isSelected()) {\n if (multiSelectOnClick) {\n this.rowNode.setSelectedParams({ newValue: false, event: mouseEvent });\n }\n else if (multiSelectKeyPressed) {\n if (rowDeselectionWithCtrl) {\n this.rowNode.setSelectedParams({ newValue: false, event: mouseEvent });\n }\n }\n else {\n // selected with no multi key, must make sure anything else is unselected\n this.rowNode.setSelectedParams({ newValue: true, clearSelection: !shiftKeyPressed, rangeSelect: shiftKeyPressed, event: mouseEvent });\n }\n }\n else {\n var clearSelection = multiSelectOnClick ? false : !multiSelectKeyPressed;\n this.rowNode.setSelectedParams({ newValue: true, clearSelection: clearSelection, rangeSelect: shiftKeyPressed, event: mouseEvent });\n }\n };\n RowCtrl.prototype.setupDetailRowAutoHeight = function (eDetailGui) {\n var _this = this;\n if (this.rowType !== RowType.FullWidthDetail) {\n return;\n }\n if (!this.beans.gridOptionsWrapper.isDetailRowAutoHeight()) {\n return;\n }\n var checkRowSizeFunc = function () {\n var clientHeight = eDetailGui.clientHeight;\n // if the UI is not ready, the height can be 0, which we ignore, as otherwise a flicker will occur\n // as UI goes from the default height, to 0, then to the real height as UI becomes ready. this means\n // it's not possible for have 0 as auto-height, however this is an improbable use case, as even an\n // empty detail grid would still have some styling around it giving at least a few pixels.\n if (clientHeight != null && clientHeight > 0) {\n // we do the update in a timeout, to make sure we are not calling from inside the grid\n // doing another update\n var updateRowHeightFunc = function () {\n _this.rowNode.setRowHeight(clientHeight);\n if (_this.beans.clientSideRowModel) {\n _this.beans.clientSideRowModel.onRowHeightChanged();\n }\n else if (_this.beans.serverSideRowModel) {\n _this.beans.serverSideRowModel.onRowHeightChanged();\n }\n };\n _this.beans.frameworkOverrides.setTimeout(updateRowHeightFunc, 0);\n }\n };\n var resizeObserverDestroyFunc = this.beans.resizeObserverService.observeResize(eDetailGui, checkRowSizeFunc);\n this.addDestroyFunc(resizeObserverDestroyFunc);\n checkRowSizeFunc();\n };\n RowCtrl.prototype.createFullWidthParams = function (eRow, pinned) {\n var _this = this;\n var params = {\n fullWidth: true,\n data: this.rowNode.data,\n node: this.rowNode,\n value: this.rowNode.key,\n valueFormatted: this.rowNode.key,\n rowIndex: this.rowNode.rowIndex,\n api: this.beans.gridOptionsWrapper.getApi(),\n columnApi: this.beans.gridOptionsWrapper.getColumnApi(),\n context: this.beans.gridOptionsWrapper.getContext(),\n // these need to be taken out, as part of 'afterAttached' now\n eGridCell: eRow,\n eParentOfValue: eRow,\n pinned: pinned,\n addRenderedRowListener: this.addEventListener.bind(this),\n registerRowDragger: function (rowDraggerElement, dragStartPixels, value, suppressVisibilityChange) { return _this.addFullWidthRowDragging(rowDraggerElement, dragStartPixels, value, suppressVisibilityChange); }\n };\n return params;\n };\n RowCtrl.prototype.addFullWidthRowDragging = function (rowDraggerElement, dragStartPixels, value, suppressVisibilityChange) {\n if (value === void 0) { value = ''; }\n if (!this.isFullWidth()) {\n return;\n }\n var rowDragComp = new RowDragComp(function () { return value; }, this.rowNode, undefined, rowDraggerElement, dragStartPixels, suppressVisibilityChange);\n this.createManagedBean(rowDragComp, this.beans.context);\n };\n RowCtrl.prototype.onUiLevelChanged = function () {\n var newLevel = this.beans.rowCssClassCalculator.calculateRowLevel(this.rowNode);\n if (this.rowLevel != newLevel) {\n var classToAdd_1 = 'ag-row-level-' + newLevel;\n var classToRemove_1 = 'ag-row-level-' + this.rowLevel;\n this.allRowGuis.forEach(function (gui) {\n gui.rowComp.addOrRemoveCssClass(classToAdd_1, true);\n gui.rowComp.addOrRemoveCssClass(classToRemove_1, false);\n });\n }\n this.rowLevel = newLevel;\n };\n RowCtrl.prototype.isFirstRowOnPage = function () {\n return this.rowNode.rowIndex === this.beans.paginationProxy.getPageFirstRow();\n };\n RowCtrl.prototype.isLastRowOnPage = function () {\n return this.rowNode.rowIndex === this.beans.paginationProxy.getPageLastRow();\n };\n RowCtrl.prototype.onModelUpdated = function () {\n this.refreshFirstAndLastRowStyles();\n };\n RowCtrl.prototype.refreshFirstAndLastRowStyles = function () {\n var newFirst = this.isFirstRowOnPage();\n var newLast = this.isLastRowOnPage();\n if (this.firstRowOnPage !== newFirst) {\n this.firstRowOnPage = newFirst;\n this.allRowGuis.forEach(function (gui) { return gui.rowComp.addOrRemoveCssClass('ag-row-first', newFirst); });\n }\n if (this.lastRowOnPage !== newLast) {\n this.lastRowOnPage = newLast;\n this.allRowGuis.forEach(function (gui) { return gui.rowComp.addOrRemoveCssClass('ag-row-last', newLast); });\n }\n };\n RowCtrl.prototype.stopEditing = function (cancel) {\n var e_1, _a;\n if (cancel === void 0) { cancel = false; }\n // if we are already stopping row edit, there is\n // no need to start this process again.\n if (this.stoppingRowEdit) {\n return;\n }\n var cellControls = this.getAllCellCtrls();\n var isRowEdit = this.editingRow;\n this.stoppingRowEdit = true;\n var fireRowEditEvent = false;\n try {\n for (var cellControls_1 = __values(cellControls), cellControls_1_1 = cellControls_1.next(); !cellControls_1_1.done; cellControls_1_1 = cellControls_1.next()) {\n var ctrl = cellControls_1_1.value;\n var valueChanged = ctrl.stopEditing(cancel);\n if (isRowEdit && !cancel && !fireRowEditEvent && valueChanged) {\n fireRowEditEvent = true;\n }\n }\n }\n catch (e_1_1) { e_1 = { error: e_1_1 }; }\n finally {\n try {\n if (cellControls_1_1 && !cellControls_1_1.done && (_a = cellControls_1.return)) _a.call(cellControls_1);\n }\n finally { if (e_1) throw e_1.error; }\n }\n if (fireRowEditEvent) {\n var event_1 = this.createRowEvent(Events.EVENT_ROW_VALUE_CHANGED);\n this.beans.eventService.dispatchEvent(event_1);\n }\n if (isRowEdit) {\n this.setEditingRow(false);\n }\n this.stoppingRowEdit = false;\n };\n RowCtrl.prototype.setInlineEditingCss = function (editing) {\n this.allRowGuis.forEach(function (gui) {\n gui.rowComp.addOrRemoveCssClass(\"ag-row-inline-editing\", editing);\n gui.rowComp.addOrRemoveCssClass(\"ag-row-not-inline-editing\", !editing);\n });\n };\n RowCtrl.prototype.setEditingRow = function (value) {\n this.editingRow = value;\n this.allRowGuis.forEach(function (gui) { return gui.rowComp.addOrRemoveCssClass('ag-row-editing', value); });\n var event = value ?\n this.createRowEvent(Events.EVENT_ROW_EDITING_STARTED)\n : this.createRowEvent(Events.EVENT_ROW_EDITING_STOPPED);\n this.beans.eventService.dispatchEvent(event);\n };\n RowCtrl.prototype.startRowEditing = function (key, charPress, sourceRenderedCell, event) {\n if (key === void 0) { key = null; }\n if (charPress === void 0) { charPress = null; }\n if (sourceRenderedCell === void 0) { sourceRenderedCell = null; }\n if (event === void 0) { event = null; }\n // don't do it if already editing\n if (this.editingRow) {\n return;\n }\n this.getAllCellCtrls().forEach(function (cellCtrl) {\n var cellStartedEdit = cellCtrl === sourceRenderedCell;\n if (cellStartedEdit) {\n cellCtrl.startEditing(key, charPress, cellStartedEdit, event);\n }\n else {\n cellCtrl.startEditing(null, null, cellStartedEdit, event);\n }\n });\n this.setEditingRow(true);\n };\n RowCtrl.prototype.getAllCellCtrls = function () {\n var res = __spread(this.centerCellCtrls.list, this.leftCellCtrls.list, this.rightCellCtrls.list);\n return res;\n };\n RowCtrl.prototype.postProcessClassesFromGridOptions = function () {\n var _this = this;\n var cssClasses = this.beans.rowCssClassCalculator.processClassesFromGridOptions(this.rowNode);\n if (!cssClasses || !cssClasses.length) {\n return;\n }\n cssClasses.forEach(function (classStr) {\n _this.allRowGuis.forEach(function (c) { return c.rowComp.addOrRemoveCssClass(classStr, true); });\n });\n };\n RowCtrl.prototype.postProcessRowClassRules = function () {\n var _this = this;\n this.beans.rowCssClassCalculator.processRowClassRules(this.rowNode, function (className) {\n _this.allRowGuis.forEach(function (gui) { return gui.rowComp.addOrRemoveCssClass(className, true); });\n }, function (className) {\n _this.allRowGuis.forEach(function (gui) { return gui.rowComp.addOrRemoveCssClass(className, false); });\n });\n };\n RowCtrl.prototype.setStylesFromGridOptions = function () {\n var rowStyles = this.processStylesFromGridOptions();\n this.allRowGuis.forEach(function (gui) { return gui.rowComp.setUserStyles(rowStyles); });\n };\n RowCtrl.prototype.getRowBusinessKey = function () {\n var businessKeyForNodeFunc = this.beans.gridOptionsWrapper.getBusinessKeyForNodeFunc();\n if (typeof businessKeyForNodeFunc !== 'function') {\n return;\n }\n return businessKeyForNodeFunc(this.rowNode);\n };\n RowCtrl.prototype.getPinnedForContainer = function (rowContainerType) {\n var pinned = rowContainerType === RowContainerType.LEFT\n ? Constants.PINNED_LEFT\n : rowContainerType === RowContainerType.RIGHT\n ? Constants.PINNED_RIGHT\n : null;\n return pinned;\n };\n RowCtrl.prototype.getInitialRowClasses = function (rowContainerType) {\n var pinned = this.getPinnedForContainer(rowContainerType);\n var params = {\n rowNode: this.rowNode,\n rowFocused: this.rowFocused,\n fadeRowIn: this.fadeRowIn,\n rowIsEven: this.rowNode.rowIndex % 2 === 0,\n rowLevel: this.rowLevel,\n fullWidthRow: this.isFullWidth(),\n firstRowOnPage: this.isFirstRowOnPage(),\n lastRowOnPage: this.isLastRowOnPage(),\n printLayout: this.printLayout,\n expandable: this.rowNode.isExpandable(),\n pinned: pinned\n };\n return this.beans.rowCssClassCalculator.getInitialRowClasses(params);\n };\n RowCtrl.prototype.processStylesFromGridOptions = function () {\n // part 1 - rowStyle\n var rowStyle = this.beans.gridOptionsWrapper.getRowStyle();\n if (rowStyle && typeof rowStyle === 'function') {\n console.warn('AG Grid: rowStyle should be an object of key/value styles, not be a function, use getRowStyle() instead');\n return;\n }\n // part 1 - rowStyleFunc\n var rowStyleFunc = this.beans.gridOptionsWrapper.getRowStyleFunc();\n var rowStyleFuncResult;\n if (rowStyleFunc) {\n var params = {\n data: this.rowNode.data,\n node: this.rowNode,\n rowIndex: this.rowNode.rowIndex\n };\n rowStyleFuncResult = rowStyleFunc(params);\n }\n return Object.assign({}, rowStyle, rowStyleFuncResult);\n };\n RowCtrl.prototype.onRowSelected = function () {\n var _this = this;\n // Treat undefined as false, if we pass undefined down it gets treated as toggle class, rather than explicitly\n // setting the required value\n var selected = !!this.rowNode.isSelected();\n this.allRowGuis.forEach(function (gui) {\n gui.rowComp.addOrRemoveCssClass('ag-row-selected', selected);\n setAriaSelected(gui.element, selected ? true : undefined);\n var ariaLabel = _this.createAriaLabel();\n setAriaLabel(gui.element, ariaLabel == null ? '' : ariaLabel);\n });\n };\n RowCtrl.prototype.createAriaLabel = function () {\n var selected = this.rowNode.isSelected();\n if (selected && this.beans.gridOptionsWrapper.isSuppressRowDeselection()) {\n return undefined;\n }\n var translate = this.beans.gridOptionsWrapper.getLocaleTextFunc();\n var label = translate(selected ? 'ariaRowDeselect' : 'ariaRowSelect', \"Press SPACE to \" + (selected ? 'deselect' : 'select') + \" this row.\");\n return label;\n };\n RowCtrl.prototype.isUseAnimationFrameForCreate = function () {\n return this.useAnimationFrameForCreate;\n };\n RowCtrl.prototype.addHoverFunctionality = function (eRow) {\n var _this = this;\n // because we use animation frames to do this, it's possible the row no longer exists\n // by the time we get to add it\n if (!this.active) {\n return;\n }\n // because mouseenter and mouseleave do not propagate, we cannot listen on the gridPanel\n // like we do for all the other mouse events.\n // because of the pinning, we cannot simply add / remove the class based on the eRow. we\n // have to check all eRow's (body & pinned). so the trick is if any of the rows gets a\n // mouse hover, it sets such in the rowNode, and then all three reflect the change as\n // all are listening for event on the row node.\n // step 1 - add listener, to set flag on row node\n this.addManagedListener(eRow, 'mouseenter', function () { return _this.rowNode.onMouseEnter(); });\n this.addManagedListener(eRow, 'mouseleave', function () { return _this.rowNode.onMouseLeave(); });\n // step 2 - listen for changes on row node (which any eRow can trigger)\n this.addManagedListener(this.rowNode, RowNode.EVENT_MOUSE_ENTER, function () {\n // if hover turned off, we don't add the class. we do this here so that if the application\n // toggles this property mid way, we remove the hover form the last row, but we stop\n // adding hovers from that point onwards.\n if (!_this.beans.gridOptionsWrapper.isSuppressRowHoverHighlight()) {\n eRow.classList.add('ag-row-hover');\n }\n });\n this.addManagedListener(this.rowNode, RowNode.EVENT_MOUSE_LEAVE, function () {\n eRow.classList.remove('ag-row-hover');\n });\n };\n // for animation, we don't want to animate entry or exit to a very far away pixel,\n // otherwise the row would move so fast, it would appear to disappear. so this method\n // moves the row closer to the viewport if it is far away, so the row slide in / out\n // at a speed the user can see.\n RowCtrl.prototype.roundRowTopToBounds = function (rowTop) {\n var gridBodyCon = this.beans.ctrlsService.getGridBodyCtrl();\n var range = gridBodyCon.getScrollFeature().getVScrollPosition();\n var minPixel = this.applyPaginationOffset(range.top, true) - 100;\n var maxPixel = this.applyPaginationOffset(range.bottom, true) + 100;\n return Math.min(Math.max(minPixel, rowTop), maxPixel);\n };\n RowCtrl.prototype.getFrameworkOverrides = function () {\n return this.beans.frameworkOverrides;\n };\n RowCtrl.prototype.onRowHeightChanged = function () {\n // check for exists first - if the user is resetting the row height, then\n // it will be null (or undefined) momentarily until the next time the flatten\n // stage is called where the row will then update again with a new height\n if (this.rowNode.rowHeight == null) {\n return;\n }\n var rowHeight = this.rowNode.rowHeight;\n var defaultRowHeight = this.beans.gridOptionsWrapper.getDefaultRowHeight();\n var isHeightFromFunc = this.beans.gridOptionsWrapper.isGetRowHeightFunction();\n var heightFromFunc = isHeightFromFunc ? this.beans.gridOptionsWrapper.getRowHeightForNode(this.rowNode).height : undefined;\n var lineHeight = heightFromFunc ? Math.min(defaultRowHeight, heightFromFunc) - 2 + \"px\" : undefined;\n this.allRowGuis.forEach(function (gui) {\n gui.element.style.height = rowHeight + \"px\";\n // If the row height is coming from a function, this means some rows can\n // be smaller than the theme had intended. so we set --ag-line-height on\n // the row, which is picked up by the theme CSS and is used in a calc\n // for the CSS line-height property, which makes sure the line-height is\n // not bigger than the row height, otherwise the row text would not fit.\n // We do not use rowNode.rowHeight here, as this could be the result of autoHeight,\n // and we found using the autoHeight result causes a loop, where changing the\n // line-height them impacts the cell height, resulting in a new autoHeight,\n // resulting in a new line-height and so on loop.\n // const heightFromFunc = this.beans.gridOptionsWrapper.getRowHeightForNode(this.rowNode).height;\n if (lineHeight) {\n gui.element.style.setProperty('--ag-line-height', lineHeight);\n }\n });\n };\n RowCtrl.prototype.addEventListener = function (eventType, listener) {\n if (eventType === 'renderedRowRemoved' || eventType === 'rowRemoved') {\n eventType = Events.EVENT_VIRTUAL_ROW_REMOVED;\n console.warn('AG Grid: Since version 11, event renderedRowRemoved is now called ' + Events.EVENT_VIRTUAL_ROW_REMOVED);\n }\n _super.prototype.addEventListener.call(this, eventType, listener);\n };\n RowCtrl.prototype.removeEventListener = function (eventType, listener) {\n if (eventType === 'renderedRowRemoved' || eventType === 'rowRemoved') {\n eventType = Events.EVENT_VIRTUAL_ROW_REMOVED;\n console.warn('AG Grid: Since version 11, event renderedRowRemoved and rowRemoved is now called ' + Events.EVENT_VIRTUAL_ROW_REMOVED);\n }\n _super.prototype.removeEventListener.call(this, eventType, listener);\n };\n // note - this is NOT called by context, as we don't wire / unwire the CellComp for performance reasons.\n RowCtrl.prototype.destroyFirstPass = function () {\n this.active = false;\n // why do we have this method? shouldn't everything below be added as a destroy func beside\n // the corresponding create logic?\n this.setupRemoveAnimation();\n var event = this.createRowEvent(Events.EVENT_VIRTUAL_ROW_REMOVED);\n this.dispatchEvent(event);\n this.beans.eventService.dispatchEvent(event);\n _super.prototype.destroy.call(this);\n };\n RowCtrl.prototype.setupRemoveAnimation = function () {\n // we don't animate sticky rows\n if (this.isSticky()) {\n return;\n }\n var rowStillVisibleJustNotInViewport = this.rowNode.rowTop != null;\n if (rowStillVisibleJustNotInViewport) {\n // if the row is not rendered, but in viewport, it means it has moved,\n // so we animate the row out. if the new location is very far away,\n // the animation will be so fast the row will look like it's just disappeared,\n // so instead we animate to a position just outside the viewport.\n var rowTop = this.roundRowTopToBounds(this.rowNode.rowTop);\n this.setRowTop(rowTop);\n }\n else {\n this.allRowGuis.forEach(function (gui) { return gui.rowComp.addOrRemoveCssClass('ag-opacity-zero', true); });\n }\n };\n RowCtrl.prototype.destroySecondPass = function () {\n this.allRowGuis.length = 0;\n var destroyCellCtrls = function (ctrls) {\n ctrls.list.forEach(function (c) { return c.destroy(); });\n return { list: [], map: {} };\n };\n this.centerCellCtrls = destroyCellCtrls(this.centerCellCtrls);\n this.leftCellCtrls = destroyCellCtrls(this.leftCellCtrls);\n this.rightCellCtrls = destroyCellCtrls(this.rightCellCtrls);\n };\n RowCtrl.prototype.setFocusedClasses = function () {\n var _this = this;\n this.allRowGuis.forEach(function (gui) {\n gui.rowComp.addOrRemoveCssClass('ag-row-focus', _this.rowFocused);\n gui.rowComp.addOrRemoveCssClass('ag-row-no-focus', !_this.rowFocused);\n });\n };\n RowCtrl.prototype.onCellFocusChanged = function () {\n var rowFocused = this.beans.focusService.isRowFocused(this.rowNode.rowIndex, this.rowNode.rowPinned);\n if (rowFocused !== this.rowFocused) {\n this.rowFocused = rowFocused;\n this.setFocusedClasses();\n }\n // if we are editing, then moving the focus out of a row will stop editing\n if (!rowFocused && this.editingRow) {\n this.stopEditing(false);\n }\n };\n RowCtrl.prototype.onPaginationChanged = function () {\n var currentPage = this.beans.paginationProxy.getCurrentPage();\n // it is possible this row is in the new page, but the page number has changed, which means\n // it needs to reposition itself relative to the new page\n if (this.paginationPage !== currentPage) {\n this.paginationPage = currentPage;\n this.onTopChanged();\n }\n this.refreshFirstAndLastRowStyles();\n };\n RowCtrl.prototype.onTopChanged = function () {\n this.setRowTop(this.rowNode.rowTop);\n };\n RowCtrl.prototype.onPaginationPixelOffsetChanged = function () {\n // the pixel offset is used when calculating rowTop to set on the row DIV\n this.onTopChanged();\n };\n // applies pagination offset, eg if on second page, and page height is 500px, then removes\n // 500px from the top position, so a row with rowTop 600px is displayed at location 100px.\n // reverse will take the offset away rather than add.\n RowCtrl.prototype.applyPaginationOffset = function (topPx, reverse) {\n if (reverse === void 0) { reverse = false; }\n if (this.rowNode.isRowPinned()) {\n return topPx;\n }\n var pixelOffset = this.beans.paginationProxy.getPixelOffset();\n var multiplier = reverse ? 1 : -1;\n return topPx + (pixelOffset * multiplier);\n };\n RowCtrl.prototype.setRowTop = function (pixels) {\n // print layout uses normal flow layout for row positioning\n if (this.printLayout) {\n return;\n }\n // need to make sure rowTop is not null, as this can happen if the node was once\n // visible (ie parent group was expanded) but is now not visible\n if (exists(pixels)) {\n var afterPaginationPixels = this.applyPaginationOffset(pixels);\n var afterScalingPixels = this.rowNode.isRowPinned() ? afterPaginationPixels : this.beans.rowContainerHeightService.getRealPixelPosition(afterPaginationPixels);\n var topPx = afterScalingPixels + \"px\";\n this.setRowTopStyle(topPx);\n }\n };\n // the top needs to be set into the DOM element when the element is created, not updated afterwards.\n // otherwise the transition would not work, as it would be transitioning from zero (the unset value).\n // for example, suppose a row that is outside the viewport, then user does a filter to remove other rows\n // and this row now appears in the viewport, and the row moves up (ie it was under the viewport and not rendered,\n // but now is in the viewport) then a new RowComp is created, however it should have it's position initialised\n // to below the viewport, so the row will appear to animate up. if we didn't set the initial position at creation\n // time, the row would animate down (ie from position zero).\n RowCtrl.prototype.getInitialRowTop = function () {\n var suppressRowTransform = this.beans.gridOptionsWrapper.isSuppressRowTransform();\n return suppressRowTransform ? this.getInitialRowTopShared() : undefined;\n };\n RowCtrl.prototype.getInitialTransform = function () {\n var suppressRowTransform = this.beans.gridOptionsWrapper.isSuppressRowTransform();\n return suppressRowTransform ? undefined : \"translateY(\" + this.getInitialRowTopShared() + \")\";\n };\n RowCtrl.prototype.getInitialRowTopShared = function () {\n // print layout uses normal flow layout for row positioning\n if (this.printLayout) {\n return '';\n }\n var rowTop;\n if (this.isSticky()) {\n rowTop = this.rowNode.stickyRowTop;\n }\n else {\n // if sliding in, we take the old row top. otherwise we just set the current row top.\n var pixels = this.slideRowIn ? this.roundRowTopToBounds(this.rowNode.oldRowTop) : this.rowNode.rowTop;\n var afterPaginationPixels = this.applyPaginationOffset(pixels);\n // we don't apply scaling if row is pinned\n rowTop = this.rowNode.isRowPinned() ? afterPaginationPixels : this.beans.rowContainerHeightService.getRealPixelPosition(afterPaginationPixels);\n }\n return rowTop + 'px';\n };\n RowCtrl.prototype.setRowTopStyle = function (topPx) {\n var suppressRowTransform = this.beans.gridOptionsWrapper.isSuppressRowTransform();\n this.allRowGuis.forEach(function (gui) { return suppressRowTransform ?\n gui.rowComp.setTop(topPx) :\n gui.rowComp.setTransform(\"translateY(\" + topPx + \")\"); });\n };\n RowCtrl.prototype.getRowNode = function () {\n return this.rowNode;\n };\n RowCtrl.prototype.getCellCtrl = function (column) {\n // first up, check for cell directly linked to this column\n var res = null;\n this.getAllCellCtrls().forEach(function (cellCtrl) {\n if (cellCtrl.getColumn() == column) {\n res = cellCtrl;\n }\n });\n if (res != null) {\n return res;\n }\n // second up, if not found, then check for spanned cols.\n // we do this second (and not at the same time) as this is\n // more expensive, as spanning cols is a\n // infrequently used feature so we don't need to do this most\n // of the time\n this.getAllCellCtrls().forEach(function (cellCtrl) {\n if (cellCtrl.getColSpanningList().indexOf(column) >= 0) {\n res = cellCtrl;\n }\n });\n return res;\n };\n RowCtrl.prototype.onRowIndexChanged = function () {\n // we only bother updating if the rowIndex is present. if it is not present, it means this row\n // is child of a group node, and the group node was closed, it's the only way to have no row index.\n // when this happens, row is about to be de-rendered, so we don't care, rowComp is about to die!\n if (this.rowNode.rowIndex != null) {\n this.onCellFocusChanged();\n this.updateRowIndexes();\n this.postProcessCss();\n }\n };\n RowCtrl.prototype.updateRowIndexes = function () {\n var rowIndexStr = this.rowNode.getRowIndexString();\n var headerRowCount = this.beans.headerNavigationService.getHeaderRowCount();\n var rowIsEven = this.rowNode.rowIndex % 2 === 0;\n var ariaRowIndex = headerRowCount + this.rowNode.rowIndex + 1;\n this.allRowGuis.forEach(function (c) {\n c.rowComp.setRowIndex(rowIndexStr);\n c.rowComp.addOrRemoveCssClass('ag-row-even', rowIsEven);\n c.rowComp.addOrRemoveCssClass('ag-row-odd', !rowIsEven);\n setAriaRowIndex(c.element, ariaRowIndex);\n });\n };\n // returns the pinned left container, either the normal one, or the embedded full with one if exists\n RowCtrl.prototype.getPinnedLeftRowElement = function () {\n return this.leftGui ? this.leftGui.element : undefined;\n };\n // returns the pinned right container, either the normal one, or the embedded full with one if exists\n RowCtrl.prototype.getPinnedRightRowElement = function () {\n return this.rightGui ? this.rightGui.element : undefined;\n };\n // returns the body container, either the normal one, or the embedded full with one if exists\n RowCtrl.prototype.getBodyRowElement = function () {\n return this.centerGui ? this.centerGui.element : undefined;\n };\n // returns the full width container\n RowCtrl.prototype.getFullWidthRowElement = function () {\n return this.fullWidthGui ? this.fullWidthGui.element : undefined;\n };\n RowCtrl.DOM_DATA_KEY_ROW_CTRL = 'renderedRow';\n return RowCtrl;\n}(BeanStub));\nexport { RowCtrl };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nimport { BeanStub } from \"../../context/beanStub\";\nimport { getCtrlForEvent, isStopPropagationForAgGrid, isEventSupported } from \"../../utils/event\";\nimport { Autowired, Optional, PostConstruct } from \"../../context/context\";\nimport { RowCtrl } from \"../../rendering/row/rowCtrl\";\nimport { isIOSUserAgent } from \"../../utils/browser\";\nimport { TouchListener } from \"../../widgets/touchListener\";\nimport { isUserSuppressingKeyboardEvent } from \"../../utils/keyboard\";\nimport { Events } from \"../../events\";\nimport { KeyCode } from \"../../constants/keyCode\";\nimport { Constants } from \"../../constants/constants\";\nimport { missingOrEmpty } from \"../../utils/generic\";\nimport { last } from \"../../utils/array\";\nimport { normaliseQwertyAzerty } from \"../../utils/keyboard\";\nimport { ModuleRegistry } from \"../../modules/moduleRegistry\";\nimport { ModuleNames } from \"../../modules/moduleNames\";\nimport { CellCtrl } from \"../../rendering/cell/cellCtrl\";\nvar RowContainerEventsFeature = /** @class */ (function (_super) {\n __extends(RowContainerEventsFeature, _super);\n function RowContainerEventsFeature(element) {\n var _this = _super.call(this) || this;\n _this.element = element;\n return _this;\n }\n RowContainerEventsFeature.prototype.postConstruct = function () {\n this.addMouseListeners();\n this.mockContextMenuForIPad();\n this.addKeyboardEvents();\n };\n RowContainerEventsFeature.prototype.addKeyboardEvents = function () {\n var _this = this;\n var eventNames = ['keydown', 'keypress'];\n eventNames.forEach(function (eventName) {\n var listener = _this.processKeyboardEvent.bind(_this, eventName);\n _this.addManagedListener(_this.element, eventName, listener);\n });\n };\n RowContainerEventsFeature.prototype.addMouseListeners = function () {\n var _this = this;\n var mouseDownEvent = isEventSupported('touchstart') ? 'touchstart' : 'mousedown';\n var eventNames = ['dblclick', 'contextmenu', 'mouseover', 'mouseout', 'click', mouseDownEvent];\n eventNames.forEach(function (eventName) {\n var listener = _this.processMouseEvent.bind(_this, eventName);\n _this.addManagedListener(_this.element, eventName, listener);\n });\n };\n RowContainerEventsFeature.prototype.processMouseEvent = function (eventName, mouseEvent) {\n if (!this.mouseEventService.isEventFromThisGrid(mouseEvent) ||\n isStopPropagationForAgGrid(mouseEvent)) {\n return;\n }\n var rowComp = this.getRowForEvent(mouseEvent);\n var cellCtrl = this.mouseEventService.getRenderedCellForEvent(mouseEvent);\n if (eventName === \"contextmenu\") {\n this.handleContextMenuMouseEvent(mouseEvent, null, rowComp, cellCtrl);\n }\n else {\n if (cellCtrl) {\n cellCtrl.onMouseEvent(eventName, mouseEvent);\n }\n if (rowComp) {\n rowComp.onMouseEvent(eventName, mouseEvent);\n }\n }\n };\n RowContainerEventsFeature.prototype.mockContextMenuForIPad = function () {\n var _this = this;\n // we do NOT want this when not in iPad, otherwise we will be doing\n if (!isIOSUserAgent()) {\n return;\n }\n var touchListener = new TouchListener(this.element);\n var longTapListener = function (event) {\n var rowComp = _this.getRowForEvent(event.touchEvent);\n var cellComp = _this.mouseEventService.getRenderedCellForEvent(event.touchEvent);\n _this.handleContextMenuMouseEvent(null, event.touchEvent, rowComp, cellComp);\n };\n this.addManagedListener(touchListener, TouchListener.EVENT_LONG_TAP, longTapListener);\n this.addDestroyFunc(function () { return touchListener.destroy(); });\n };\n RowContainerEventsFeature.prototype.getRowForEvent = function (event) {\n var sourceElement = event.target;\n while (sourceElement) {\n var rowCon = this.gridOptionsWrapper.getDomData(sourceElement, RowCtrl.DOM_DATA_KEY_ROW_CTRL);\n if (rowCon) {\n return rowCon;\n }\n sourceElement = sourceElement.parentElement;\n }\n return null;\n };\n RowContainerEventsFeature.prototype.handleContextMenuMouseEvent = function (mouseEvent, touchEvent, rowComp, cellCtrl) {\n var rowNode = rowComp ? rowComp.getRowNode() : null;\n var column = cellCtrl ? cellCtrl.getColumn() : null;\n var value = null;\n if (column) {\n var event_1 = mouseEvent ? mouseEvent : touchEvent;\n cellCtrl.dispatchCellContextMenuEvent(event_1);\n value = this.valueService.getValue(column, rowNode);\n }\n // if user clicked on a cell, anchor to that cell, otherwise anchor to the grid panel\n var gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n var anchorToElement = cellCtrl ? cellCtrl.getGui() : gridBodyCon.getGridBodyElement();\n if (this.contextMenuFactory) {\n this.contextMenuFactory.onContextMenu(mouseEvent, touchEvent, rowNode, column, value, anchorToElement);\n }\n };\n RowContainerEventsFeature.prototype.processKeyboardEvent = function (eventName, keyboardEvent) {\n var cellComp = getCtrlForEvent(this.gridOptionsWrapper, keyboardEvent, CellCtrl.DOM_DATA_KEY_CELL_CTRL);\n var rowComp = getCtrlForEvent(this.gridOptionsWrapper, keyboardEvent, RowCtrl.DOM_DATA_KEY_ROW_CTRL);\n if (keyboardEvent.defaultPrevented) {\n return;\n }\n if (cellComp) {\n this.processCellKeyboardEvent(cellComp, eventName, keyboardEvent);\n }\n else if (rowComp && rowComp.isFullWidth()) {\n this.processFullWidthRowKeyboardEvent(rowComp, eventName, keyboardEvent);\n }\n };\n RowContainerEventsFeature.prototype.processCellKeyboardEvent = function (cellCtrl, eventName, keyboardEvent) {\n var rowNode = cellCtrl.getRowNode();\n var column = cellCtrl.getColumn();\n var editing = cellCtrl.isEditing();\n var gridProcessingAllowed = !isUserSuppressingKeyboardEvent(this.gridOptionsWrapper, keyboardEvent, rowNode, column, editing);\n if (gridProcessingAllowed) {\n switch (eventName) {\n case 'keydown':\n // first see if it's a scroll key, page up / down, home / end etc\n var wasScrollKey = !editing && this.navigationService.handlePageScrollingKey(keyboardEvent);\n // if not a scroll key, then we pass onto cell\n if (!wasScrollKey) {\n cellCtrl.onKeyDown(keyboardEvent);\n }\n // perform clipboard and undo / redo operations\n this.doGridOperations(keyboardEvent, cellCtrl.isEditing());\n break;\n case 'keypress':\n cellCtrl.onKeyPress(keyboardEvent);\n break;\n }\n }\n if (eventName === 'keydown') {\n var cellKeyDownEvent = cellCtrl.createEvent(keyboardEvent, Events.EVENT_CELL_KEY_DOWN);\n this.eventService.dispatchEvent(cellKeyDownEvent);\n }\n if (eventName === 'keypress') {\n var cellKeyPressEvent = cellCtrl.createEvent(keyboardEvent, Events.EVENT_CELL_KEY_PRESS);\n this.eventService.dispatchEvent(cellKeyPressEvent);\n }\n };\n RowContainerEventsFeature.prototype.processFullWidthRowKeyboardEvent = function (rowComp, eventName, keyboardEvent) {\n var rowNode = rowComp.getRowNode();\n var focusedCell = this.focusService.getFocusedCell();\n var column = (focusedCell && focusedCell.column);\n var gridProcessingAllowed = !isUserSuppressingKeyboardEvent(this.gridOptionsWrapper, keyboardEvent, rowNode, column, false);\n if (gridProcessingAllowed) {\n var key = keyboardEvent.key;\n if (eventName === 'keydown') {\n switch (key) {\n case KeyCode.UP:\n case KeyCode.DOWN:\n rowComp.onKeyboardNavigate(keyboardEvent);\n break;\n case KeyCode.TAB:\n rowComp.onTabKeyDown(keyboardEvent);\n default:\n }\n }\n }\n if (eventName === 'keydown') {\n var cellKeyDownEvent = rowComp.createRowEvent(Events.EVENT_CELL_KEY_DOWN, keyboardEvent);\n this.eventService.dispatchEvent(cellKeyDownEvent);\n }\n if (eventName === 'keypress') {\n var cellKeyPressEvent = rowComp.createRowEvent(Events.EVENT_CELL_KEY_PRESS, keyboardEvent);\n this.eventService.dispatchEvent(cellKeyPressEvent);\n }\n };\n RowContainerEventsFeature.prototype.doGridOperations = function (keyboardEvent, editing) {\n // check if ctrl or meta key pressed\n if (!keyboardEvent.ctrlKey && !keyboardEvent.metaKey) {\n return;\n }\n // if the cell the event came from is editing, then we do not\n // want to do the default shortcut keys, otherwise the editor\n // (eg a text field) would not be able to do the normal cut/copy/paste\n if (editing) {\n return;\n }\n // for copy / paste, we don't want to execute when the event\n // was from a child grid (happens in master detail)\n if (!this.mouseEventService.isEventFromThisGrid(keyboardEvent)) {\n return;\n }\n var keyCode = normaliseQwertyAzerty(keyboardEvent);\n if (keyCode === KeyCode.A) {\n return this.onCtrlAndA(keyboardEvent);\n }\n if (keyCode === KeyCode.C) {\n return this.onCtrlAndC(keyboardEvent);\n }\n if (keyCode === KeyCode.V) {\n return this.onCtrlAndV();\n }\n if (keyCode === KeyCode.D) {\n return this.onCtrlAndD(keyboardEvent);\n }\n if (keyCode === KeyCode.Z) {\n return keyboardEvent.shiftKey ? this.undoRedoService.redo() : this.undoRedoService.undo();\n }\n if (keyCode === KeyCode.Y) {\n return this.undoRedoService.redo();\n }\n };\n RowContainerEventsFeature.prototype.onCtrlAndA = function (event) {\n var _a = this, pinnedRowModel = _a.pinnedRowModel, paginationProxy = _a.paginationProxy, rangeService = _a.rangeService;\n var PINNED_BOTTOM = Constants.PINNED_BOTTOM, PINNED_TOP = Constants.PINNED_TOP;\n if (rangeService && paginationProxy.isRowsToRender()) {\n var _b = __read([\n pinnedRowModel.isEmpty(PINNED_TOP),\n pinnedRowModel.isEmpty(PINNED_BOTTOM)\n ], 2), isEmptyPinnedTop = _b[0], isEmptyPinnedBottom = _b[1];\n var floatingStart = isEmptyPinnedTop ? null : PINNED_TOP;\n var floatingEnd = void 0;\n var rowEnd = void 0;\n if (isEmptyPinnedBottom) {\n floatingEnd = null;\n rowEnd = this.paginationProxy.getRowCount() - 1;\n }\n else {\n floatingEnd = PINNED_BOTTOM;\n rowEnd = pinnedRowModel.getPinnedBottomRowData().length - 1;\n }\n var allDisplayedColumns = this.columnModel.getAllDisplayedColumns();\n if (missingOrEmpty(allDisplayedColumns)) {\n return;\n }\n rangeService.setCellRange({\n rowStartIndex: 0,\n rowStartPinned: floatingStart,\n rowEndIndex: rowEnd,\n rowEndPinned: floatingEnd,\n columnStart: allDisplayedColumns[0],\n columnEnd: last(allDisplayedColumns)\n });\n }\n event.preventDefault();\n };\n RowContainerEventsFeature.prototype.onCtrlAndC = function (event) {\n if (!this.clipboardService || this.gridOptionsWrapper.isEnableCellTextSelection()) {\n return;\n }\n this.clipboardService.copyToClipboard();\n event.preventDefault();\n };\n RowContainerEventsFeature.prototype.onCtrlAndV = function () {\n if (ModuleRegistry.isRegistered(ModuleNames.ClipboardModule) && !this.gridOptionsWrapper.isSuppressClipboardPaste()) {\n this.clipboardService.pasteFromClipboard();\n }\n };\n RowContainerEventsFeature.prototype.onCtrlAndD = function (event) {\n if (ModuleRegistry.isRegistered(ModuleNames.ClipboardModule) && !this.gridOptionsWrapper.isSuppressClipboardPaste()) {\n this.clipboardService.copyRangeDown();\n }\n event.preventDefault();\n };\n __decorate([\n Autowired('mouseEventService')\n ], RowContainerEventsFeature.prototype, \"mouseEventService\", void 0);\n __decorate([\n Autowired('valueService')\n ], RowContainerEventsFeature.prototype, \"valueService\", void 0);\n __decorate([\n Optional('contextMenuFactory')\n ], RowContainerEventsFeature.prototype, \"contextMenuFactory\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], RowContainerEventsFeature.prototype, \"ctrlsService\", void 0);\n __decorate([\n Autowired('navigationService')\n ], RowContainerEventsFeature.prototype, \"navigationService\", void 0);\n __decorate([\n Autowired('focusService')\n ], RowContainerEventsFeature.prototype, \"focusService\", void 0);\n __decorate([\n Autowired('undoRedoService')\n ], RowContainerEventsFeature.prototype, \"undoRedoService\", void 0);\n __decorate([\n Autowired('columnModel')\n ], RowContainerEventsFeature.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('paginationProxy')\n ], RowContainerEventsFeature.prototype, \"paginationProxy\", void 0);\n __decorate([\n Autowired('pinnedRowModel')\n ], RowContainerEventsFeature.prototype, \"pinnedRowModel\", void 0);\n __decorate([\n Optional('rangeService')\n ], RowContainerEventsFeature.prototype, \"rangeService\", void 0);\n __decorate([\n Optional('clipboardService')\n ], RowContainerEventsFeature.prototype, \"clipboardService\", void 0);\n __decorate([\n PostConstruct\n ], RowContainerEventsFeature.prototype, \"postConstruct\", null);\n return RowContainerEventsFeature;\n}(BeanStub));\nexport { RowContainerEventsFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../context/beanStub\";\nimport { Autowired, PostConstruct } from \"../context/context\";\nimport { Events } from \"../events\";\nimport { getInnerHeight } from \"../utils/dom\";\n// listens to changes in the center viewport size, for column and row virtualisation,\n// and adjusts grid as necessary. there are two viewports, one for horizontal and one for\n// vertical scrolling.\nvar ViewportSizeFeature = /** @class */ (function (_super) {\n __extends(ViewportSizeFeature, _super);\n function ViewportSizeFeature(centerContainerCtrl) {\n var _this = _super.call(this) || this;\n _this.centerContainerCtrl = centerContainerCtrl;\n return _this;\n }\n ViewportSizeFeature.prototype.postConstruct = function () {\n var _this = this;\n this.ctrlsService.whenReady(function () {\n _this.gridBodyCtrl = _this.ctrlsService.getGridBodyCtrl();\n _this.listenForResize();\n });\n this.addManagedListener(this.eventService, Events.EVENT_SCROLLBAR_WIDTH_CHANGED, this.onScrollbarWidthChanged.bind(this));\n };\n ViewportSizeFeature.prototype.listenForResize = function () {\n var _this = this;\n var listener = function () { return _this.onCenterViewportResized(); };\n // centerContainer gets horizontal resizes\n this.centerContainerCtrl.registerViewportResizeListener(listener);\n // eBodyViewport gets vertical resizes\n this.gridBodyCtrl.registerBodyViewportResizeListener(listener);\n };\n ViewportSizeFeature.prototype.onScrollbarWidthChanged = function () {\n this.checkViewportAndScrolls();\n };\n ViewportSizeFeature.prototype.onCenterViewportResized = function () {\n if (this.centerContainerCtrl.isViewportVisible()) {\n this.checkViewportAndScrolls();\n var newWidth = this.centerContainerCtrl.getCenterWidth();\n if (newWidth !== this.centerWidth) {\n this.centerWidth = newWidth;\n this.columnModel.refreshFlexedColumns({ viewportWidth: this.centerWidth, updateBodyWidths: true, fireResizedEvent: true });\n }\n }\n else {\n this.bodyHeight = 0;\n }\n };\n // gets called every time the viewport size changes. we use this to check visibility of scrollbars\n // in the grid panel, and also to check size and position of viewport for row and column virtualisation.\n ViewportSizeFeature.prototype.checkViewportAndScrolls = function () {\n // results in updating anything that depends on scroll showing\n this.updateScrollVisibleService();\n // fires event if height changes, used by PaginationService, HeightScalerService, RowRenderer\n this.checkBodyHeight();\n // check for virtual columns for ColumnController\n this.onHorizontalViewportChanged();\n this.gridBodyCtrl.getScrollFeature().checkScrollLeft();\n };\n ViewportSizeFeature.prototype.getBodyHeight = function () {\n return this.bodyHeight;\n };\n ViewportSizeFeature.prototype.checkBodyHeight = function () {\n var eBodyViewport = this.gridBodyCtrl.getBodyViewportElement();\n var bodyHeight = getInnerHeight(eBodyViewport);\n if (this.bodyHeight !== bodyHeight) {\n this.bodyHeight = bodyHeight;\n var event_1 = {\n type: Events.EVENT_BODY_HEIGHT_CHANGED\n };\n this.eventService.dispatchEvent(event_1);\n }\n };\n ViewportSizeFeature.prototype.updateScrollVisibleService = function () {\n // because of column animation (which takes 200ms), we have to do this twice.\n // eg if user removes cols anywhere except at the RHS, then the cols on the RHS\n // will animate to the left to fill the gap. this animation means just after\n // the cols are removed, the remaining cols are still in the original location\n // at the start of the animation, so pre animation the H scrollbar is still needed,\n // but post animation it is not.\n this.updateScrollVisibleServiceImpl();\n setTimeout(this.updateScrollVisibleServiceImpl.bind(this), 500);\n };\n ViewportSizeFeature.prototype.updateScrollVisibleServiceImpl = function () {\n var params = {\n horizontalScrollShowing: this.isHorizontalScrollShowing(),\n verticalScrollShowing: this.gridBodyCtrl.isVerticalScrollShowing()\n };\n this.scrollVisibleService.setScrollsVisible(params);\n // fix - gridComp should just listen to event from above\n this.gridBodyCtrl.setVerticalScrollPaddingVisible(params.verticalScrollShowing);\n };\n ViewportSizeFeature.prototype.isHorizontalScrollShowing = function () {\n var isAlwaysShowHorizontalScroll = this.gridOptionsWrapper.isAlwaysShowHorizontalScroll();\n return isAlwaysShowHorizontalScroll || this.centerContainerCtrl.isViewportHScrollShowing();\n };\n // this gets called whenever a change in the viewport, so we can inform column controller it has to work\n // out the virtual columns again. gets called from following locations:\n // + ensureColVisible, scroll, init, layoutChanged, displayedColumnsChanged, API (doLayout)\n ViewportSizeFeature.prototype.onHorizontalViewportChanged = function () {\n var scrollWidth = this.centerContainerCtrl.getCenterWidth();\n var scrollPosition = this.centerContainerCtrl.getViewportScrollLeft();\n this.columnModel.setViewportPosition(scrollWidth, scrollPosition);\n };\n __decorate([\n Autowired('ctrlsService')\n ], ViewportSizeFeature.prototype, \"ctrlsService\", void 0);\n __decorate([\n Autowired('columnModel')\n ], ViewportSizeFeature.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('scrollVisibleService')\n ], ViewportSizeFeature.prototype, \"scrollVisibleService\", void 0);\n __decorate([\n PostConstruct\n ], ViewportSizeFeature.prototype, \"postConstruct\", null);\n return ViewportSizeFeature;\n}(BeanStub));\nexport { ViewportSizeFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub\";\nimport { Autowired, PostConstruct } from \"../../context/context\";\nimport { Events } from \"../../eventKeys\";\nimport { setDisplayed, setFixedWidth } from \"../../utils/dom\";\nvar SetPinnedLeftWidthFeature = /** @class */ (function (_super) {\n __extends(SetPinnedLeftWidthFeature, _super);\n function SetPinnedLeftWidthFeature(element) {\n var _this = _super.call(this) || this;\n _this.element = element;\n return _this;\n }\n SetPinnedLeftWidthFeature.prototype.postConstruct = function () {\n this.addManagedListener(this.eventService, Events.EVENT_LEFT_PINNED_WIDTH_CHANGED, this.onPinnedLeftWidthChanged.bind(this));\n };\n SetPinnedLeftWidthFeature.prototype.onPinnedLeftWidthChanged = function () {\n var leftWidth = this.pinnedWidthService.getPinnedLeftWidth();\n var displayed = leftWidth > 0;\n setDisplayed(this.element, displayed);\n if (displayed) {\n setFixedWidth(this.element, leftWidth);\n }\n };\n __decorate([\n Autowired('pinnedWidthService')\n ], SetPinnedLeftWidthFeature.prototype, \"pinnedWidthService\", void 0);\n __decorate([\n PostConstruct\n ], SetPinnedLeftWidthFeature.prototype, \"postConstruct\", null);\n return SetPinnedLeftWidthFeature;\n}(BeanStub));\nexport { SetPinnedLeftWidthFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from \"../../context/context\";\nimport { Events } from \"../../eventKeys\";\nimport { setDisplayed, setFixedWidth } from \"../../utils/dom\";\nimport { BeanStub } from \"../../context/beanStub\";\nvar SetPinnedRightWidthFeature = /** @class */ (function (_super) {\n __extends(SetPinnedRightWidthFeature, _super);\n function SetPinnedRightWidthFeature(element) {\n var _this = _super.call(this) || this;\n _this.element = element;\n return _this;\n }\n SetPinnedRightWidthFeature.prototype.postConstruct = function () {\n this.addManagedListener(this.eventService, Events.EVENT_RIGHT_PINNED_WIDTH_CHANGED, this.onPinnedRightWidthChanged.bind(this));\n };\n SetPinnedRightWidthFeature.prototype.onPinnedRightWidthChanged = function () {\n var rightWidth = this.pinnedWidthService.getPinnedRightWidth();\n var displayed = rightWidth > 0;\n setDisplayed(this.element, displayed);\n if (displayed) {\n setFixedWidth(this.element, rightWidth);\n }\n };\n __decorate([\n Autowired('pinnedWidthService')\n ], SetPinnedRightWidthFeature.prototype, \"pinnedWidthService\", void 0);\n __decorate([\n PostConstruct\n ], SetPinnedRightWidthFeature.prototype, \"postConstruct\", null);\n return SetPinnedRightWidthFeature;\n}(BeanStub));\nexport { SetPinnedRightWidthFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub\";\nimport { Autowired, PostConstruct } from \"../../context/context\";\nimport { Events } from \"../../eventKeys\";\nvar SetHeightFeature = /** @class */ (function (_super) {\n __extends(SetHeightFeature, _super);\n function SetHeightFeature(eContainer, eWrapper) {\n var _this = _super.call(this) || this;\n _this.eContainer = eContainer;\n _this.eWrapper = eWrapper;\n return _this;\n }\n SetHeightFeature.prototype.postConstruct = function () {\n this.addManagedListener(this.eventService, Events.EVENT_ROW_CONTAINER_HEIGHT_CHANGED, this.onHeightChanged.bind(this));\n };\n SetHeightFeature.prototype.onHeightChanged = function () {\n var height = this.maxDivHeightScaler.getUiContainerHeight();\n var heightString = height != null ? height + \"px\" : \"\";\n this.eContainer.style.height = heightString;\n if (this.eWrapper) {\n this.eWrapper.style.height = heightString;\n }\n };\n __decorate([\n Autowired(\"rowContainerHeightService\")\n ], SetHeightFeature.prototype, \"maxDivHeightScaler\", void 0);\n __decorate([\n PostConstruct\n ], SetHeightFeature.prototype, \"postConstruct\", null);\n return SetHeightFeature;\n}(BeanStub));\nexport { SetHeightFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub\";\nimport { missing } from \"../../utils/generic\";\nimport { Autowired, Optional, PostConstruct } from \"../../context/context\";\nvar DragListenerFeature = /** @class */ (function (_super) {\n __extends(DragListenerFeature, _super);\n function DragListenerFeature(eContainer) {\n var _this = _super.call(this) || this;\n _this.eContainer = eContainer;\n return _this;\n }\n DragListenerFeature.prototype.postConstruct = function () {\n var _this = this;\n if (!this.gridOptionsWrapper.isEnableRangeSelection() || // no range selection if no property\n missing(this.rangeService) // no range selection if not enterprise version\n ) {\n return;\n }\n var params = {\n eElement: this.eContainer,\n onDragStart: this.rangeService.onDragStart.bind(this.rangeService),\n onDragStop: this.rangeService.onDragStop.bind(this.rangeService),\n onDragging: this.rangeService.onDragging.bind(this.rangeService)\n };\n this.dragService.addDragSource(params);\n this.addDestroyFunc(function () { return _this.dragService.removeDragSource(params); });\n };\n __decorate([\n Optional('rangeService')\n ], DragListenerFeature.prototype, \"rangeService\", void 0);\n __decorate([\n Autowired('dragService')\n ], DragListenerFeature.prototype, \"dragService\", void 0);\n __decorate([\n PostConstruct\n ], DragListenerFeature.prototype, \"postConstruct\", null);\n return DragListenerFeature;\n}(BeanStub));\nexport { DragListenerFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../context/beanStub\";\nimport { Autowired, PostConstruct } from \"../context/context\";\nimport { GridOptionsWrapper } from \"../gridOptionsWrapper\";\nimport { Constants } from \"../constants/constants\";\nimport { Events } from \"../eventKeys\";\nvar CenterWidthFeature = /** @class */ (function (_super) {\n __extends(CenterWidthFeature, _super);\n function CenterWidthFeature(callback) {\n var _this = _super.call(this) || this;\n _this.callback = callback;\n return _this;\n }\n CenterWidthFeature.prototype.postConstruct = function () {\n var listener = this.setWidth.bind(this);\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_DOM_LAYOUT, listener);\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, listener);\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, listener);\n this.setWidth();\n };\n CenterWidthFeature.prototype.setWidth = function () {\n var columnModel = this.columnModel;\n var printLayout = this.gridOptionsWrapper.getDomLayout() === Constants.DOM_LAYOUT_PRINT;\n var centerWidth = columnModel.getBodyContainerWidth();\n var leftWidth = columnModel.getDisplayedColumnsLeftWidth();\n var rightWidth = columnModel.getDisplayedColumnsRightWidth();\n var totalWidth = printLayout ? centerWidth + leftWidth + rightWidth : centerWidth;\n this.callback(totalWidth);\n };\n __decorate([\n Autowired('columnModel')\n ], CenterWidthFeature.prototype, \"columnModel\", void 0);\n __decorate([\n PostConstruct\n ], CenterWidthFeature.prototype, \"postConstruct\", null);\n return CenterWidthFeature;\n}(BeanStub));\nexport { CenterWidthFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nimport { BeanStub } from \"../../context/beanStub\";\nimport { Autowired, PostConstruct } from \"../../context/context\";\nimport { Events } from \"../../eventKeys\";\nimport { RowContainerEventsFeature } from \"./rowContainerEventsFeature\";\nimport { getInnerWidth, getScrollLeft, isHorizontalScrollShowing, isVisible, setScrollLeft } from \"../../utils/dom\";\nimport { ViewportSizeFeature } from \"../viewportSizeFeature\";\nimport { convertToMap } from \"../../utils/map\";\nimport { SetPinnedLeftWidthFeature } from \"./setPinnedLeftWidthFeature\";\nimport { SetPinnedRightWidthFeature } from \"./setPinnedRightWidthFeature\";\nimport { SetHeightFeature } from \"./setHeightFeature\";\nimport { DragListenerFeature } from \"./dragListenerFeature\";\nimport { CenterWidthFeature } from \"../centerWidthFeature\";\nimport { Constants } from \"../../constants/constants\";\nimport { GridOptionsWrapper } from \"../../gridOptionsWrapper\";\nexport var RowContainerName;\n(function (RowContainerName) {\n RowContainerName[\"LEFT\"] = \"left\";\n RowContainerName[\"RIGHT\"] = \"right\";\n RowContainerName[\"CENTER\"] = \"center\";\n RowContainerName[\"FULL_WIDTH\"] = \"fullWidth\";\n RowContainerName[\"TOP_LEFT\"] = \"topLeft\";\n RowContainerName[\"TOP_RIGHT\"] = \"topRight\";\n RowContainerName[\"TOP_CENTER\"] = \"topCenter\";\n RowContainerName[\"TOP_FULL_WIDTH\"] = \"topFullWidth\";\n RowContainerName[\"STICKY_TOP_LEFT\"] = \"stickyTopLeft\";\n RowContainerName[\"STICKY_TOP_RIGHT\"] = \"stickyTopRight\";\n RowContainerName[\"STICKY_TOP_CENTER\"] = \"stickyTopCenter\";\n RowContainerName[\"STICKY_TOP_FULL_WIDTH\"] = \"stickyTopFullWidth\";\n RowContainerName[\"BOTTOM_LEFT\"] = \"bottomLeft\";\n RowContainerName[\"BOTTOM_RIGHT\"] = \"bottomRight\";\n RowContainerName[\"BOTTOM_CENTER\"] = \"bottomCenter\";\n RowContainerName[\"BOTTOM_FULL_WIDTH\"] = \"bottomFullWidth\";\n})(RowContainerName || (RowContainerName = {}));\nexport var RowContainerType;\n(function (RowContainerType) {\n RowContainerType[\"LEFT\"] = \"left\";\n RowContainerType[\"RIGHT\"] = \"right\";\n RowContainerType[\"CENTER\"] = \"center\";\n RowContainerType[\"FULL_WIDTH\"] = \"fullWidth\";\n})(RowContainerType || (RowContainerType = {}));\nexport function getRowContainerTypeForName(name) {\n switch (name) {\n case RowContainerName.CENTER:\n case RowContainerName.TOP_CENTER:\n case RowContainerName.STICKY_TOP_CENTER:\n case RowContainerName.BOTTOM_CENTER:\n return RowContainerType.CENTER;\n case RowContainerName.LEFT:\n case RowContainerName.TOP_LEFT:\n case RowContainerName.STICKY_TOP_LEFT:\n case RowContainerName.BOTTOM_LEFT:\n return RowContainerType.LEFT;\n case RowContainerName.RIGHT:\n case RowContainerName.TOP_RIGHT:\n case RowContainerName.STICKY_TOP_RIGHT:\n case RowContainerName.BOTTOM_RIGHT:\n return RowContainerType.RIGHT;\n case RowContainerName.FULL_WIDTH:\n case RowContainerName.TOP_FULL_WIDTH:\n case RowContainerName.STICKY_TOP_FULL_WIDTH:\n case RowContainerName.BOTTOM_FULL_WIDTH:\n return RowContainerType.FULL_WIDTH;\n default:\n throw Error('Invalid Row Container Type');\n }\n}\nvar ContainerCssClasses = convertToMap([\n [RowContainerName.CENTER, 'ag-center-cols-container'],\n [RowContainerName.LEFT, 'ag-pinned-left-cols-container'],\n [RowContainerName.RIGHT, 'ag-pinned-right-cols-container'],\n [RowContainerName.FULL_WIDTH, 'ag-full-width-container'],\n [RowContainerName.TOP_CENTER, 'ag-floating-top-container'],\n [RowContainerName.TOP_LEFT, 'ag-pinned-left-floating-top'],\n [RowContainerName.TOP_RIGHT, 'ag-pinned-right-floating-top'],\n [RowContainerName.TOP_FULL_WIDTH, 'ag-floating-top-full-width-container'],\n [RowContainerName.STICKY_TOP_CENTER, 'ag-sticky-top-container'],\n [RowContainerName.STICKY_TOP_LEFT, 'ag-pinned-left-sticky-top'],\n [RowContainerName.STICKY_TOP_RIGHT, 'ag-pinned-right-sticky-top'],\n [RowContainerName.STICKY_TOP_FULL_WIDTH, 'ag-sticky-top-full-width-container'],\n [RowContainerName.BOTTOM_CENTER, 'ag-floating-bottom-container'],\n [RowContainerName.BOTTOM_LEFT, 'ag-pinned-left-floating-bottom'],\n [RowContainerName.BOTTOM_RIGHT, 'ag-pinned-right-floating-bottom'],\n [RowContainerName.BOTTOM_FULL_WIDTH, 'ag-floating-bottom-full-width-container'],\n]);\nvar ViewportCssClasses = convertToMap([\n [RowContainerName.CENTER, 'ag-center-cols-viewport'],\n [RowContainerName.TOP_CENTER, 'ag-floating-top-viewport'],\n [RowContainerName.STICKY_TOP_CENTER, 'ag-sticky-top-viewport'],\n [RowContainerName.BOTTOM_CENTER, 'ag-floating-bottom-viewport'],\n]);\nvar WrapperCssClasses = convertToMap([\n [RowContainerName.CENTER, 'ag-center-cols-clipper'],\n]);\nvar RowContainerCtrl = /** @class */ (function (_super) {\n __extends(RowContainerCtrl, _super);\n function RowContainerCtrl(name) {\n var _this = _super.call(this) || this;\n _this.name = name;\n return _this;\n }\n RowContainerCtrl.getRowContainerCssClasses = function (name) {\n var containerClass = ContainerCssClasses.get(name);\n var viewportClass = ViewportCssClasses.get(name);\n var wrapperClass = WrapperCssClasses.get(name);\n return { container: containerClass, viewport: viewportClass, wrapper: wrapperClass };\n };\n RowContainerCtrl.getPinned = function (name) {\n switch (name) {\n case RowContainerName.BOTTOM_LEFT:\n case RowContainerName.TOP_LEFT:\n case RowContainerName.STICKY_TOP_LEFT:\n case RowContainerName.LEFT:\n return Constants.PINNED_LEFT;\n case RowContainerName.BOTTOM_RIGHT:\n case RowContainerName.TOP_RIGHT:\n case RowContainerName.STICKY_TOP_RIGHT:\n case RowContainerName.RIGHT:\n return Constants.PINNED_RIGHT;\n default:\n return null;\n }\n };\n RowContainerCtrl.prototype.postConstruct = function () {\n var _this = this;\n this.enableRtl = this.gridOptionsWrapper.isEnableRtl();\n this.embedFullWidthRows = this.gridOptionsWrapper.isEmbedFullWidthRows();\n this.forContainers([RowContainerName.CENTER], function () { return _this.viewportSizeFeature = _this.createManagedBean(new ViewportSizeFeature(_this)); });\n };\n RowContainerCtrl.prototype.registerWithCtrlsService = function () {\n switch (this.name) {\n case RowContainerName.CENTER:\n this.ctrlsService.registerCenterRowContainerCtrl(this);\n break;\n case RowContainerName.LEFT:\n this.ctrlsService.registerLeftRowContainerCtrl(this);\n break;\n case RowContainerName.RIGHT:\n this.ctrlsService.registerRightRowContainerCtrl(this);\n break;\n case RowContainerName.TOP_CENTER:\n this.ctrlsService.registerTopCenterRowContainerCtrl(this);\n break;\n case RowContainerName.TOP_LEFT:\n this.ctrlsService.registerTopLeftRowContainerCon(this);\n break;\n case RowContainerName.TOP_RIGHT:\n this.ctrlsService.registerTopRightRowContainerCtrl(this);\n break;\n case RowContainerName.STICKY_TOP_CENTER:\n this.ctrlsService.registerStickyTopCenterRowContainerCtrl(this);\n break;\n case RowContainerName.STICKY_TOP_LEFT:\n this.ctrlsService.registerStickyTopLeftRowContainerCon(this);\n break;\n case RowContainerName.STICKY_TOP_RIGHT:\n this.ctrlsService.registerStickyTopRightRowContainerCtrl(this);\n break;\n case RowContainerName.BOTTOM_CENTER:\n this.ctrlsService.registerBottomCenterRowContainerCtrl(this);\n break;\n case RowContainerName.BOTTOM_LEFT:\n this.ctrlsService.registerBottomLeftRowContainerCtrl(this);\n break;\n case RowContainerName.BOTTOM_RIGHT:\n this.ctrlsService.registerBottomRightRowContainerCtrl(this);\n break;\n }\n };\n RowContainerCtrl.prototype.forContainers = function (names, callback) {\n if (names.indexOf(this.name) >= 0) {\n callback();\n }\n };\n RowContainerCtrl.prototype.getContainerElement = function () {\n return this.eContainer;\n };\n RowContainerCtrl.prototype.getViewportSizeFeature = function () {\n return this.viewportSizeFeature;\n };\n RowContainerCtrl.prototype.setComp = function (view, eContainer, eViewport, eWrapper) {\n var _this = this;\n this.comp = view;\n this.eContainer = eContainer;\n this.eViewport = eViewport;\n this.eWrapper = eWrapper;\n this.createManagedBean(new RowContainerEventsFeature(this.eContainer));\n this.addPreventScrollWhileDragging();\n this.listenOnDomOrder();\n this.stopHScrollOnPinnedRows();\n var allTopNoFW = [RowContainerName.TOP_CENTER, RowContainerName.TOP_LEFT, RowContainerName.TOP_RIGHT];\n var allStickyTopNoFW = [RowContainerName.STICKY_TOP_CENTER, RowContainerName.STICKY_TOP_LEFT, RowContainerName.STICKY_TOP_RIGHT];\n var allBottomNoFW = [RowContainerName.BOTTOM_CENTER, RowContainerName.BOTTOM_LEFT, RowContainerName.BOTTOM_RIGHT];\n var allMiddleNoFW = [RowContainerName.CENTER, RowContainerName.LEFT, RowContainerName.RIGHT];\n var allNoFW = __spread(allTopNoFW, allBottomNoFW, allMiddleNoFW, allStickyTopNoFW);\n var allMiddle = [RowContainerName.CENTER, RowContainerName.LEFT, RowContainerName.RIGHT, RowContainerName.FULL_WIDTH];\n var allCenter = [RowContainerName.CENTER, RowContainerName.TOP_CENTER, RowContainerName.STICKY_TOP_CENTER, RowContainerName.BOTTOM_CENTER];\n var allLeft = [RowContainerName.LEFT, RowContainerName.BOTTOM_LEFT, RowContainerName.TOP_LEFT, RowContainerName.STICKY_TOP_LEFT];\n var allRight = [RowContainerName.RIGHT, RowContainerName.BOTTOM_RIGHT, RowContainerName.TOP_RIGHT, RowContainerName.STICKY_TOP_RIGHT];\n this.forContainers(allLeft, function () { return _this.createManagedBean(new SetPinnedLeftWidthFeature(_this.eContainer)); });\n this.forContainers(allRight, function () { return _this.createManagedBean(new SetPinnedRightWidthFeature(_this.eContainer)); });\n this.forContainers(allMiddle, function () { return _this.createManagedBean(new SetHeightFeature(_this.eContainer, _this.eWrapper)); });\n this.forContainers(allNoFW, function () { return _this.createManagedBean(new DragListenerFeature(_this.eContainer)); });\n this.forContainers(allCenter, function () { return _this.createManagedBean(new CenterWidthFeature(function (width) { return _this.comp.setContainerWidth(width + \"px\"); })); });\n this.addListeners();\n this.registerWithCtrlsService();\n };\n RowContainerCtrl.prototype.addListeners = function () {\n var _this = this;\n this.addManagedListener(this.eventService, Events.EVENT_SCROLL_VISIBILITY_CHANGED, function () { return _this.onScrollVisibilityChanged(); });\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, function () { return _this.onDisplayedColumnsChanged(); });\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, function () { return _this.onDisplayedColumnsWidthChanged(); });\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_ROWS_CHANGED, function () { return _this.onDisplayedRowsChanged(); });\n this.onScrollVisibilityChanged();\n this.onDisplayedColumnsChanged();\n this.onDisplayedColumnsWidthChanged();\n this.onDisplayedRowsChanged();\n };\n RowContainerCtrl.prototype.listenOnDomOrder = function () {\n var _this = this;\n // sticky section must show rows in set order\n var allStickyContainers = [RowContainerName.STICKY_TOP_CENTER, RowContainerName.STICKY_TOP_LEFT, RowContainerName.STICKY_TOP_RIGHT, RowContainerName.STICKY_TOP_FULL_WIDTH];\n var isStickContainer = allStickyContainers.indexOf(this.name) >= 0;\n if (isStickContainer) {\n this.comp.setDomOrder(true);\n return;\n }\n var listener = function () { return _this.comp.setDomOrder(_this.gridOptionsWrapper.isEnsureDomOrder()); };\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_DOM_LAYOUT, listener);\n listener();\n };\n // when editing a pinned row, if the cell is half outside the scrollable area, the browser can\n // scroll the column into view. we do not want this, the pinned sections should never scroll.\n // so we listen to scrolls on these containers and reset the scroll if we find one.\n RowContainerCtrl.prototype.stopHScrollOnPinnedRows = function () {\n var _this = this;\n this.forContainers([RowContainerName.TOP_CENTER, RowContainerName.STICKY_TOP_CENTER, RowContainerName.BOTTOM_CENTER], function () {\n var resetScrollLeft = function () { return _this.eViewport.scrollLeft = 0; };\n _this.addManagedListener(_this.eViewport, 'scroll', resetScrollLeft);\n });\n };\n RowContainerCtrl.prototype.onDisplayedColumnsChanged = function () {\n var _this = this;\n this.forContainers([RowContainerName.CENTER], function () { return _this.onHorizontalViewportChanged(); });\n };\n RowContainerCtrl.prototype.onDisplayedColumnsWidthChanged = function () {\n var _this = this;\n this.forContainers([RowContainerName.CENTER], function () { return _this.onHorizontalViewportChanged(); });\n };\n RowContainerCtrl.prototype.onScrollVisibilityChanged = function () {\n if (this.name !== RowContainerName.CENTER) {\n return;\n }\n var visible = this.scrollVisibleService.isHorizontalScrollShowing();\n var scrollbarWidth = visible ? (this.gridOptionsWrapper.getScrollbarWidth() || 0) : 0;\n var height = scrollbarWidth == 0 ? '100%' : \"calc(100% + \" + scrollbarWidth + \"px)\";\n this.comp.setViewportHeight(height);\n };\n // this methods prevents the grid views from being scrolled while the dragService is being used\n // eg. the view should not scroll up and down while dragging rows using the rowDragComp.\n RowContainerCtrl.prototype.addPreventScrollWhileDragging = function () {\n var _this = this;\n var preventScroll = function (e) {\n if (_this.dragService.isDragging()) {\n if (e.cancelable) {\n e.preventDefault();\n }\n }\n };\n this.eContainer.addEventListener('touchmove', preventScroll, { passive: false });\n this.addDestroyFunc(function () { return _this.eContainer.removeEventListener('touchmove', preventScroll); });\n };\n // this gets called whenever a change in the viewport, so we can inform column controller it has to work\n // out the virtual columns again. gets called from following locations:\n // + ensureColVisible, scroll, init, layoutChanged, displayedColumnsChanged, API (doLayout)\n RowContainerCtrl.prototype.onHorizontalViewportChanged = function () {\n var scrollWidth = this.getCenterWidth();\n var scrollPosition = this.getCenterViewportScrollLeft();\n this.columnModel.setViewportPosition(scrollWidth, scrollPosition);\n };\n RowContainerCtrl.prototype.getCenterWidth = function () {\n return getInnerWidth(this.eViewport);\n };\n RowContainerCtrl.prototype.getCenterViewportScrollLeft = function () {\n // we defer to a util, as how you calculated scrollLeft when doing RTL depends on the browser\n return getScrollLeft(this.eViewport, this.enableRtl);\n };\n RowContainerCtrl.prototype.registerViewportResizeListener = function (listener) {\n var unsubscribeFromResize = this.resizeObserverService.observeResize(this.eViewport, listener);\n this.addDestroyFunc(function () { return unsubscribeFromResize(); });\n };\n RowContainerCtrl.prototype.isViewportVisible = function () {\n return isVisible(this.eViewport);\n };\n RowContainerCtrl.prototype.isViewportHScrollShowing = function () {\n return isHorizontalScrollShowing(this.eViewport);\n };\n RowContainerCtrl.prototype.getViewportScrollLeft = function () {\n return getScrollLeft(this.eViewport, this.enableRtl);\n };\n RowContainerCtrl.prototype.isHorizontalScrollShowing = function () {\n var isAlwaysShowHorizontalScroll = this.gridOptionsWrapper.isAlwaysShowHorizontalScroll();\n return isAlwaysShowHorizontalScroll || isHorizontalScrollShowing(this.eViewport);\n };\n RowContainerCtrl.prototype.getViewportElement = function () {\n return this.eViewport;\n };\n RowContainerCtrl.prototype.setContainerTranslateX = function (amount) {\n this.eContainer.style.transform = \"translateX(\" + amount + \"px)\";\n };\n RowContainerCtrl.prototype.getHScrollPosition = function () {\n var res = {\n left: this.eViewport.scrollLeft,\n right: this.eViewport.scrollLeft + this.eViewport.offsetWidth\n };\n return res;\n };\n RowContainerCtrl.prototype.setCenterViewportScrollLeft = function (value) {\n // we defer to a util, as how you calculated scrollLeft when doing RTL depends on the browser\n setScrollLeft(this.eViewport, value, this.enableRtl);\n };\n RowContainerCtrl.prototype.onDisplayedRowsChanged = function () {\n var _this = this;\n var fullWithContainer = this.name === RowContainerName.TOP_FULL_WIDTH\n || this.name === RowContainerName.STICKY_TOP_FULL_WIDTH\n || this.name === RowContainerName.BOTTOM_FULL_WIDTH\n || this.name === RowContainerName.FULL_WIDTH;\n var doesRowMatch = function (rowCtrl) {\n var fullWidthRow = rowCtrl.isFullWidth();\n var printLayout = _this.gridOptionsWrapper.getDomLayout() === Constants.DOM_LAYOUT_PRINT;\n var embedFW = _this.embedFullWidthRows || printLayout;\n var match = fullWithContainer ?\n !embedFW && fullWidthRow\n : embedFW || !fullWidthRow;\n return match;\n };\n // this list contains either all pinned top, center or pinned bottom rows\n var allRowsRegardlessOfFullWidth = this.getRowCtrls();\n // this filters out rows not for this container, eg if it's a full with row, but we are not full with container\n var rowsThisContainer = allRowsRegardlessOfFullWidth.filter(doesRowMatch);\n this.comp.setRowCtrls(rowsThisContainer);\n };\n RowContainerCtrl.prototype.getRowCtrls = function () {\n switch (this.name) {\n case RowContainerName.TOP_CENTER:\n case RowContainerName.TOP_LEFT:\n case RowContainerName.TOP_RIGHT:\n case RowContainerName.TOP_FULL_WIDTH:\n return this.rowRenderer.getTopRowCtrls();\n case RowContainerName.STICKY_TOP_CENTER:\n case RowContainerName.STICKY_TOP_LEFT:\n case RowContainerName.STICKY_TOP_RIGHT:\n case RowContainerName.STICKY_TOP_FULL_WIDTH:\n return this.rowRenderer.getStickyTopRowCtrls();\n case RowContainerName.BOTTOM_CENTER:\n case RowContainerName.BOTTOM_LEFT:\n case RowContainerName.BOTTOM_RIGHT:\n case RowContainerName.BOTTOM_FULL_WIDTH:\n return this.rowRenderer.getBottomRowCtrls();\n default:\n return this.rowRenderer.getRowCtrls();\n }\n };\n __decorate([\n Autowired('scrollVisibleService')\n ], RowContainerCtrl.prototype, \"scrollVisibleService\", void 0);\n __decorate([\n Autowired('dragService')\n ], RowContainerCtrl.prototype, \"dragService\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], RowContainerCtrl.prototype, \"ctrlsService\", void 0);\n __decorate([\n Autowired('columnModel')\n ], RowContainerCtrl.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('resizeObserverService')\n ], RowContainerCtrl.prototype, \"resizeObserverService\", void 0);\n __decorate([\n Autowired('rowRenderer')\n ], RowContainerCtrl.prototype, \"rowRenderer\", void 0);\n __decorate([\n PostConstruct\n ], RowContainerCtrl.prototype, \"postConstruct\", null);\n return RowContainerCtrl;\n}(BeanStub));\nexport { RowContainerCtrl };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Optional, PostConstruct } from '../context/context';\nimport { LayoutCssClasses } from \"../styling/layoutFeature\";\nimport { setAriaColCount, setAriaMultiSelectable, setAriaRowCount } from '../utils/aria';\nimport { Component } from '../widgets/component';\nimport { RefSelector } from '../widgets/componentAnnotations';\nimport { CSS_CLASS_CELL_SELECTABLE, CSS_CLASS_COLUMN_MOVING, CSS_CLASS_FORCE_VERTICAL_SCROLL, GridBodyCtrl, RowAnimationCssClasses } from \"./gridBodyCtrl\";\nimport { RowContainerName } from \"./rowContainer/rowContainerCtrl\";\nvar GRID_BODY_TEMPLATE = /* html */ \"
\\n \\n
\\n \\n \\n \\n \\n
\\n
\\n \\n \\n \\n \\n
\\n
\\n \\n \\n \\n \\n
\\n
\\n \\n \\n \\n \\n
\\n \\n \\n
\";\nvar GridBodyComp = /** @class */ (function (_super) {\n __extends(GridBodyComp, _super);\n function GridBodyComp() {\n return _super.call(this, GRID_BODY_TEMPLATE) || this;\n }\n GridBodyComp.prototype.init = function () {\n var _this = this;\n var setHeight = function (height, element) {\n var heightString = height + \"px\";\n element.style.minHeight = heightString;\n element.style.height = heightString;\n };\n var compProxy = {\n setRowAnimationCssOnBodyViewport: function (cssClass, animate) { return _this.setRowAnimationCssOnBodyViewport(cssClass, animate); },\n setColumnCount: function (count) { return setAriaColCount(_this.getGui(), count); },\n setRowCount: function (count) { return setAriaRowCount(_this.getGui(), count); },\n setTopHeight: function (height) { return setHeight(height, _this.eTop); },\n setBottomHeight: function (height) { return setHeight(height, _this.eBottom); },\n setTopDisplay: function (display) { return _this.eTop.style.display = display; },\n setBottomDisplay: function (display) { return _this.eBottom.style.display = display; },\n setStickyTopHeight: function (height) { return _this.eStickyTop.style.height = height; },\n setStickyTopTop: function (top) { return _this.eStickyTop.style.top = top; },\n setStickyTopWidth: function (width) { return _this.eStickyTop.style.width = width; },\n setColumnMovingCss: function (cssClass, flag) { return _this.addOrRemoveCssClass(CSS_CLASS_COLUMN_MOVING, flag); },\n updateLayoutClasses: function (cssClass, params) {\n var bodyViewportClassList = _this.eBodyViewport.classList;\n bodyViewportClassList.toggle(LayoutCssClasses.AUTO_HEIGHT, params.autoHeight);\n bodyViewportClassList.toggle(LayoutCssClasses.NORMAL, params.normal);\n bodyViewportClassList.toggle(LayoutCssClasses.PRINT, params.print);\n _this.addOrRemoveCssClass(LayoutCssClasses.AUTO_HEIGHT, params.autoHeight);\n _this.addOrRemoveCssClass(LayoutCssClasses.NORMAL, params.normal);\n _this.addOrRemoveCssClass(LayoutCssClasses.PRINT, params.print);\n },\n setAlwaysVerticalScrollClass: function (cssClass, on) {\n return _this.eBodyViewport.classList.toggle(CSS_CLASS_FORCE_VERTICAL_SCROLL, on);\n },\n registerBodyViewportResizeListener: function (listener) {\n var unsubscribeFromResize = _this.resizeObserverService.observeResize(_this.eBodyViewport, listener);\n _this.addDestroyFunc(function () { return unsubscribeFromResize(); });\n },\n setPinnedTopBottomOverflowY: function (overflow) { return _this.eTop.style.overflowY = _this.eBottom.style.overflowY = overflow; },\n setCellSelectableCss: function (cssClass, selectable) {\n [_this.eTop, _this.eBodyViewport, _this.eBottom]\n .forEach(function (ct) { return ct.classList.toggle(CSS_CLASS_CELL_SELECTABLE, selectable); });\n },\n };\n this.ctrl = this.createManagedBean(new GridBodyCtrl());\n this.ctrl.setComp(compProxy, this.getGui(), this.eBodyViewport, this.eTop, this.eBottom, this.eStickyTop);\n if (this.rangeService || this.gridOptionsWrapper.isRowSelectionMulti()) {\n setAriaMultiSelectable(this.getGui(), true);\n }\n };\n GridBodyComp.prototype.setRowAnimationCssOnBodyViewport = function (cssClass, animateRows) {\n var bodyViewportClassList = this.eBodyViewport.classList;\n bodyViewportClassList.toggle(RowAnimationCssClasses.ANIMATION_ON, animateRows);\n bodyViewportClassList.toggle(RowAnimationCssClasses.ANIMATION_OFF, !animateRows);\n };\n GridBodyComp.prototype.getFloatingTopBottom = function () {\n return [this.eTop, this.eBottom];\n };\n __decorate([\n Autowired('resizeObserverService')\n ], GridBodyComp.prototype, \"resizeObserverService\", void 0);\n __decorate([\n Optional('rangeService')\n ], GridBodyComp.prototype, \"rangeService\", void 0);\n __decorate([\n RefSelector('eBodyViewport')\n ], GridBodyComp.prototype, \"eBodyViewport\", void 0);\n __decorate([\n RefSelector('eStickyTop')\n ], GridBodyComp.prototype, \"eStickyTop\", void 0);\n __decorate([\n RefSelector('eTop')\n ], GridBodyComp.prototype, \"eTop\", void 0);\n __decorate([\n RefSelector('eBottom')\n ], GridBodyComp.prototype, \"eBottom\", void 0);\n __decorate([\n RefSelector('gridHeader')\n ], GridBodyComp.prototype, \"headerRootComp\", void 0);\n __decorate([\n PostConstruct\n ], GridBodyComp.prototype, \"init\", null);\n return GridBodyComp;\n}(Component));\nexport { GridBodyComp };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean, Autowired, PostConstruct } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { Events } from \"../events\";\nvar ScrollVisibleService = /** @class */ (function (_super) {\n __extends(ScrollVisibleService, _super);\n function ScrollVisibleService() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n ScrollVisibleService.prototype.postConstruct = function () {\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, this.onDisplayedColumnsWidthChanged.bind(this));\n };\n ScrollVisibleService.prototype.onDisplayedColumnsChanged = function () {\n this.update();\n };\n ScrollVisibleService.prototype.onDisplayedColumnsWidthChanged = function () {\n this.update();\n };\n ScrollVisibleService.prototype.update = function () {\n // because of column animation (which takes 200ms), we have to do this twice.\n // eg if user removes cols anywhere except at the RHS, then the cols on the RHS\n // will animate to the left to fill the gap. this animation means just after\n // the cols are removed, the remaining cols are still in the original location\n // at the start of the animation, so pre animation the H scrollbar is still needed,\n // but post animation it is not.\n this.updateImpl();\n setTimeout(this.updateImpl.bind(this), 500);\n };\n ScrollVisibleService.prototype.updateImpl = function () {\n var centerRowCtrl = this.ctrlsService.getCenterRowContainerCtrl();\n if (!centerRowCtrl) {\n return;\n }\n var params = {\n horizontalScrollShowing: centerRowCtrl.isHorizontalScrollShowing(),\n verticalScrollShowing: this.isVerticalScrollShowing()\n };\n this.setScrollsVisible(params);\n };\n ScrollVisibleService.prototype.setScrollsVisible = function (params) {\n var atLeastOneDifferent = this.horizontalScrollShowing !== params.horizontalScrollShowing ||\n this.verticalScrollShowing !== params.verticalScrollShowing;\n if (atLeastOneDifferent) {\n this.horizontalScrollShowing = params.horizontalScrollShowing;\n this.verticalScrollShowing = params.verticalScrollShowing;\n var event_1 = {\n type: Events.EVENT_SCROLL_VISIBILITY_CHANGED\n };\n this.eventService.dispatchEvent(event_1);\n }\n };\n // used by pagination service - to know page height\n ScrollVisibleService.prototype.isHorizontalScrollShowing = function () {\n return this.horizontalScrollShowing;\n };\n // used by header container\n ScrollVisibleService.prototype.isVerticalScrollShowing = function () {\n return this.verticalScrollShowing;\n };\n __decorate([\n Autowired('ctrlsService')\n ], ScrollVisibleService.prototype, \"ctrlsService\", void 0);\n __decorate([\n PostConstruct\n ], ScrollVisibleService.prototype, \"postConstruct\", null);\n ScrollVisibleService = __decorate([\n Bean('scrollVisibleService')\n ], ScrollVisibleService);\n return ScrollVisibleService;\n}(BeanStub));\nexport { ScrollVisibleService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean } from \"../context/context\";\nimport { Autowired } from \"../context/context\";\nimport { NumberSequence } from '../utils';\nimport { Constants } from \"../constants/constants\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { getCtrlForEvent } from \"../utils/event\";\nimport { exists } from \"../utils/generic\";\nimport { CellCtrl } from \"../rendering/cell/cellCtrl\";\nvar MouseEventService = /** @class */ (function (_super) {\n __extends(MouseEventService, _super);\n function MouseEventService() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.gridInstanceId = MouseEventService_1.gridInstanceSequence.next();\n return _this;\n }\n MouseEventService_1 = MouseEventService;\n // we put the instance id onto the main DOM element. this is used for events, when grids are inside grids,\n // so the grid can work out if the even came from this grid or a grid inside this one. see the ctrl+v logic\n // for where this is used.\n MouseEventService.prototype.stampTopLevelGridCompWithGridInstance = function (eGridDiv) {\n eGridDiv[MouseEventService_1.GRID_DOM_KEY] = this.gridInstanceId;\n };\n MouseEventService.prototype.getRenderedCellForEvent = function (event) {\n return getCtrlForEvent(this.gridOptionsWrapper, event, CellCtrl.DOM_DATA_KEY_CELL_CTRL);\n };\n // walks the path of the event, and returns true if this grid is the first one that it finds. if doing\n // master / detail grids, and a child grid is found, then it returns false. this stops things like copy/paste\n // getting executed on many grids at the same time.\n MouseEventService.prototype.isEventFromThisGrid = function (event) {\n var res = this.isElementInThisGrid(event.target);\n return res;\n };\n MouseEventService.prototype.isElementInThisGrid = function (element) {\n var pointer = element;\n while (pointer) {\n var instanceId = pointer[MouseEventService_1.GRID_DOM_KEY];\n if (exists(instanceId)) {\n var eventFromThisGrid = instanceId === this.gridInstanceId;\n return eventFromThisGrid;\n }\n pointer = pointer.parentElement;\n }\n return false;\n };\n MouseEventService.prototype.getCellPositionForEvent = function (event) {\n var cellComp = this.getRenderedCellForEvent(event);\n return cellComp ? cellComp.getCellPosition() : null;\n };\n MouseEventService.prototype.getNormalisedPosition = function (event) {\n var gridPanelHasScrolls = this.gridOptionsWrapper.getDomLayout() === Constants.DOM_LAYOUT_NORMAL;\n var e = event;\n var x;\n var y;\n if (e.clientX != null || e.clientY != null) {\n x = e.clientX;\n y = e.clientY;\n }\n else {\n x = e.x;\n y = e.y;\n }\n if (gridPanelHasScrolls) {\n var gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n var vRange = gridBodyCon.getScrollFeature().getVScrollPosition();\n var hRange = gridBodyCon.getScrollFeature().getHScrollPosition();\n x += hRange.left;\n y += vRange.top;\n }\n return { x: x, y: y };\n };\n var MouseEventService_1;\n MouseEventService.gridInstanceSequence = new NumberSequence();\n MouseEventService.GRID_DOM_KEY = '__ag_grid_instance';\n __decorate([\n Autowired('ctrlsService')\n ], MouseEventService.prototype, \"ctrlsService\", void 0);\n MouseEventService = MouseEventService_1 = __decorate([\n Bean('mouseEventService')\n ], MouseEventService);\n return MouseEventService;\n}(BeanStub));\nexport { MouseEventService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, Optional, PostConstruct } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { exists, missing } from \"../utils/generic\";\nimport { last } from \"../utils/array\";\nimport { KeyCode } from '../constants/keyCode';\nimport { CellCtrl } from \"../rendering/cell/cellCtrl\";\nimport { RowCtrl } from \"../rendering/row/rowCtrl\";\nimport { doOnce, throttle } from \"../utils/function\";\nimport { Constants } from \"../constants/constants\";\nimport { Events } from \"../eventKeys\";\nvar NavigationService = /** @class */ (function (_super) {\n __extends(NavigationService, _super);\n function NavigationService() {\n var _this = _super.call(this) || this;\n _this.onPageDown = throttle(_this.onPageDown, 100);\n _this.onPageUp = throttle(_this.onPageUp, 100);\n return _this;\n }\n NavigationService.prototype.postConstruct = function () {\n var _this = this;\n this.ctrlsService.whenReady(function (p) {\n _this.gridBodyCon = p.gridBodyCtrl;\n });\n };\n NavigationService.prototype.handlePageScrollingKey = function (event) {\n var key = event.key;\n var alt = event.altKey;\n var ctrl = event.ctrlKey || event.metaKey;\n var rangeServiceShouldHandleShift = !!this.rangeService && event.shiftKey;\n var currentCell = this.mouseEventService.getCellPositionForEvent(event);\n if (!currentCell) {\n return false;\n }\n var processed = false;\n switch (key) {\n case KeyCode.PAGE_HOME:\n case KeyCode.PAGE_END:\n // handle home and end when ctrl & alt are NOT pressed\n if (!ctrl && !alt) {\n this.onHomeOrEndKey(key);\n processed = true;\n }\n break;\n case KeyCode.LEFT:\n case KeyCode.RIGHT:\n case KeyCode.UP:\n case KeyCode.DOWN:\n // handle when ctrl is pressed only, if shift is pressed\n // it will be handled by the rangeService\n if (ctrl && !alt && !rangeServiceShouldHandleShift) {\n this.onCtrlUpDownLeftRight(key, currentCell);\n processed = true;\n }\n break;\n case KeyCode.PAGE_DOWN:\n // handle page up and page down when ctrl & alt are NOT pressed\n if (!ctrl && !alt) {\n this.onPageDown(currentCell);\n processed = true;\n }\n break;\n case KeyCode.PAGE_UP:\n // handle page up and page down when ctrl & alt are NOT pressed\n if (!ctrl && !alt) {\n this.onPageUp(currentCell);\n processed = true;\n }\n break;\n }\n if (processed) {\n event.preventDefault();\n }\n return processed;\n };\n NavigationService.prototype.navigateTo = function (navigateParams) {\n var scrollIndex = navigateParams.scrollIndex, scrollType = navigateParams.scrollType, scrollColumn = navigateParams.scrollColumn, focusIndex = navigateParams.focusIndex, focusColumn = navigateParams.focusColumn;\n if (exists(scrollColumn) && !scrollColumn.isPinned()) {\n this.gridBodyCon.getScrollFeature().ensureColumnVisible(scrollColumn);\n }\n if (exists(scrollIndex)) {\n this.gridBodyCon.getScrollFeature().ensureIndexVisible(scrollIndex, scrollType);\n }\n // setFocusedCell relies on the browser default focus behavior to scroll the focused cell into view,\n // however, this behavior will cause the cell border to be cut off, or if we have sticky rows, the\n // cell will be completely hidden, so we call ensureIndexVisible without a position to guarantee\n // minimal scroll to get the row into view.\n if (!navigateParams.isAsync) {\n this.gridBodyCon.getScrollFeature().ensureIndexVisible(focusIndex);\n }\n // if we don't do this, the range will be left on the last cell, which will leave the last focused cell\n // highlighted.\n this.focusService.setFocusedCell({ rowIndex: focusIndex, column: focusColumn, rowPinned: null, forceBrowserFocus: true });\n if (this.rangeService) {\n var cellPosition = { rowIndex: focusIndex, rowPinned: null, column: focusColumn };\n this.rangeService.setRangeToCell(cellPosition);\n }\n };\n NavigationService.prototype.onPageDown = function (gridCell) {\n var gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n var scrollPosition = gridBodyCon.getScrollFeature().getVScrollPosition();\n var pixelsInOnePage = this.getViewportHeight();\n var pagingPixelOffset = this.paginationProxy.getPixelOffset();\n var currentPageBottomPixel = scrollPosition.top + pixelsInOnePage;\n var currentPageBottomRow = this.paginationProxy.getRowIndexAtPixel(currentPageBottomPixel + pagingPixelOffset);\n if (this.columnModel.isAutoRowHeightActive()) {\n this.navigateToNextPageWithAutoHeight(gridCell, currentPageBottomRow);\n }\n else {\n this.navigateToNextPage(gridCell, currentPageBottomRow);\n }\n };\n NavigationService.prototype.onPageUp = function (gridCell) {\n var gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n var scrollPosition = gridBodyCon.getScrollFeature().getVScrollPosition();\n var pagingPixelOffset = this.paginationProxy.getPixelOffset();\n var currentPageTopPixel = scrollPosition.top;\n var currentPageTopRow = this.paginationProxy.getRowIndexAtPixel(currentPageTopPixel + pagingPixelOffset);\n if (this.columnModel.isAutoRowHeightActive()) {\n this.navigateToNextPageWithAutoHeight(gridCell, currentPageTopRow, true);\n }\n else {\n this.navigateToNextPage(gridCell, currentPageTopRow, true);\n }\n };\n NavigationService.prototype.navigateToNextPage = function (gridCell, scrollIndex, up) {\n if (up === void 0) { up = false; }\n var _a, _b;\n var pixelsInOnePage = this.getViewportHeight();\n var firstRow = this.paginationProxy.getPageFirstRow();\n var lastRow = this.paginationProxy.getPageLastRow();\n var pagingPixelOffset = this.paginationProxy.getPixelOffset();\n var currentRowNode = this.paginationProxy.getRow(gridCell.rowIndex);\n var rowPixelDiff = up\n ? (((_a = currentRowNode) === null || _a === void 0 ? void 0 : _a.rowHeight) - pixelsInOnePage - pagingPixelOffset)\n : (pixelsInOnePage - pagingPixelOffset);\n var nextCellPixel = ((_b = currentRowNode) === null || _b === void 0 ? void 0 : _b.rowTop) + rowPixelDiff;\n var focusIndex = this.paginationProxy.getRowIndexAtPixel(nextCellPixel + pagingPixelOffset);\n if (focusIndex === gridCell.rowIndex) {\n var diff = up ? -1 : 1;\n scrollIndex = focusIndex = gridCell.rowIndex + diff;\n }\n var scrollType;\n if (up) {\n scrollType = 'bottom';\n if (focusIndex < firstRow) {\n focusIndex = firstRow;\n }\n if (scrollIndex < firstRow) {\n scrollIndex = firstRow;\n }\n }\n else {\n scrollType = 'top';\n if (focusIndex > lastRow) {\n focusIndex = lastRow;\n }\n if (scrollIndex > lastRow) {\n scrollIndex = lastRow;\n }\n }\n if (this.isRowTallerThanView(focusIndex)) {\n scrollIndex = focusIndex;\n scrollType = 'top';\n }\n this.navigateTo({\n scrollIndex: scrollIndex,\n scrollType: scrollType,\n scrollColumn: null,\n focusIndex: focusIndex,\n focusColumn: gridCell.column\n });\n };\n NavigationService.prototype.navigateToNextPageWithAutoHeight = function (gridCell, scrollIndex, up) {\n var _this = this;\n if (up === void 0) { up = false; }\n // because autoHeight will calculate the height of rows after scroll\n // first we scroll towards the required point, then we add a small\n // delay to allow the height to be recalculated, check which index\n // should be focused and then finally navigate to that index.\n // TODO: we should probably have an event fired once to scrollbar has\n // settled and all rowHeights have been calculated instead of relying\n // on a setTimeout of 50ms.\n this.navigateTo({\n scrollIndex: scrollIndex,\n scrollType: up ? 'bottom' : 'top',\n scrollColumn: null,\n focusIndex: scrollIndex,\n focusColumn: gridCell.column\n });\n setTimeout(function () {\n var focusIndex = _this.getNextFocusIndexForAutoHeight(gridCell, up);\n _this.navigateTo({\n scrollIndex: scrollIndex,\n scrollType: up ? 'bottom' : 'top',\n scrollColumn: null,\n focusIndex: focusIndex,\n focusColumn: gridCell.column,\n isAsync: true\n });\n }, 50);\n };\n NavigationService.prototype.getNextFocusIndexForAutoHeight = function (gridCell, up) {\n if (up === void 0) { up = false; }\n var _a;\n var step = up ? -1 : 1;\n var pixelsInOnePage = this.getViewportHeight();\n var lastRowIndex = this.paginationProxy.getPageLastRow();\n var pixelSum = 0;\n var currentIndex = gridCell.rowIndex;\n while (currentIndex >= 0 && currentIndex <= lastRowIndex) {\n var currentCell = this.paginationProxy.getRow(currentIndex);\n if (currentCell) {\n var currentCellHeight = (_a = currentCell.rowHeight, (_a !== null && _a !== void 0 ? _a : 0));\n if (pixelSum + currentCellHeight > pixelsInOnePage) {\n break;\n }\n pixelSum += currentCellHeight;\n }\n currentIndex += step;\n }\n return Math.max(0, Math.min(currentIndex, lastRowIndex));\n };\n NavigationService.prototype.getViewportHeight = function () {\n var gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n var scrollPosition = gridBodyCon.getScrollFeature().getVScrollPosition();\n var scrollbarWidth = this.gridOptionsWrapper.getScrollbarWidth();\n var pixelsInOnePage = scrollPosition.bottom - scrollPosition.top;\n if (this.ctrlsService.getCenterRowContainerCtrl().isHorizontalScrollShowing()) {\n pixelsInOnePage -= scrollbarWidth;\n }\n return pixelsInOnePage;\n };\n NavigationService.prototype.isRowTallerThanView = function (rowIndex) {\n var rowNode = this.paginationProxy.getRow(rowIndex);\n if (!rowNode) {\n return false;\n }\n var rowHeight = rowNode.rowHeight;\n if (typeof rowHeight !== 'number') {\n return false;\n }\n return rowHeight > this.getViewportHeight();\n };\n NavigationService.prototype.onCtrlUpDownLeftRight = function (key, gridCell) {\n var cellToFocus = this.cellNavigationService.getNextCellToFocus(key, gridCell, true);\n var rowIndex = cellToFocus.rowIndex, column = cellToFocus.column;\n this.navigateTo({\n scrollIndex: rowIndex,\n scrollType: null,\n scrollColumn: column,\n focusIndex: rowIndex,\n focusColumn: column\n });\n };\n // home brings focus to top left cell, end brings focus to bottom right, grid scrolled to bring\n // same cell into view (which means either scroll all the way up, or all the way down).\n NavigationService.prototype.onHomeOrEndKey = function (key) {\n var homeKey = key === KeyCode.PAGE_HOME;\n var allColumns = this.columnModel.getAllDisplayedColumns();\n var columnToSelect = homeKey ? allColumns[0] : last(allColumns);\n var scrollIndex = homeKey ? this.paginationProxy.getPageFirstRow() : this.paginationProxy.getPageLastRow();\n this.navigateTo({\n scrollIndex: scrollIndex,\n scrollType: null,\n scrollColumn: columnToSelect,\n focusIndex: scrollIndex,\n focusColumn: columnToSelect\n });\n };\n // result of keyboard event\n NavigationService.prototype.onTabKeyDown = function (previous, keyboardEvent) {\n var backwards = keyboardEvent.shiftKey;\n var movedToNextCell = this.tabToNextCellCommon(previous, backwards, keyboardEvent);\n if (movedToNextCell) {\n // only prevent default if we found a cell. so if user is on last cell and hits tab, then we default\n // to the normal tabbing so user can exit the grid.\n keyboardEvent.preventDefault();\n return;\n }\n // if we didn't move to next cell, then need to tab out of the cells, ie to the header (if going\n // backwards)\n if (backwards) {\n var _a = previous.getRowPosition(), rowIndex = _a.rowIndex, rowPinned = _a.rowPinned;\n var firstRow = rowPinned ? rowIndex === 0 : rowIndex === this.paginationProxy.getPageFirstRow();\n if (firstRow) {\n keyboardEvent.preventDefault();\n this.focusService.focusLastHeader(keyboardEvent);\n }\n }\n else {\n // if the case it's a popup editor, the focus is on the editor and not the previous cell.\n // in order for the tab navigation to work, we need to focus the browser back onto the\n // previous cell.\n if (previous instanceof CellCtrl) {\n previous.focusCell(true);\n }\n if (this.focusService.focusNextGridCoreContainer(backwards)) {\n keyboardEvent.preventDefault();\n }\n }\n };\n // comes from API\n NavigationService.prototype.tabToNextCell = function (backwards, event) {\n var focusedCell = this.focusService.getFocusedCell();\n // if no focus, then cannot navigate\n if (!focusedCell) {\n return false;\n }\n var cellOrRow = this.getCellByPosition(focusedCell);\n // if cell is not rendered, means user has scrolled away from the cell\n // or that the focusedCell is a Full Width Row\n if (!cellOrRow) {\n cellOrRow = this.rowRenderer.getRowByPosition(focusedCell);\n if (!cellOrRow || !cellOrRow.isFullWidth()) {\n return false;\n }\n }\n return this.tabToNextCellCommon(cellOrRow, backwards, event);\n };\n NavigationService.prototype.tabToNextCellCommon = function (previous, backwards, event) {\n var editing = previous.isEditing();\n // if cell is not editing, there is still chance row is editing if it's Full Row Editing\n if (!editing && previous instanceof CellCtrl) {\n var cell = previous;\n var row = cell.getRowCtrl();\n if (row) {\n editing = row.isEditing();\n }\n }\n var res;\n if (editing) {\n // if we are editing, we know it's not a Full Width Row (RowComp)\n if (this.gridOptionsWrapper.isFullRowEdit()) {\n res = this.moveToNextEditingRow(previous, backwards, event);\n }\n else {\n res = this.moveToNextEditingCell(previous, backwards, event);\n }\n }\n else {\n res = this.moveToNextCellNotEditing(previous, backwards);\n }\n // if a cell wasn't found, it's possible that focus was moved to the header\n return res || !!this.focusService.getFocusedHeader();\n };\n NavigationService.prototype.moveToNextEditingCell = function (previousCell, backwards, event) {\n if (event === void 0) { event = null; }\n var previousPos = previousCell.getCellPosition();\n // before we stop editing, we need to focus the cell element\n // so the grid doesn't detect that focus has left the grid\n previousCell.getGui().focus();\n // need to do this before getting next cell to edit, in case the next cell\n // has editable function (eg colDef.editable=func() ) and it depends on the\n // result of this cell, so need to save updates from the first edit, in case\n // the value is referenced in the function.\n previousCell.stopEditing();\n // find the next cell to start editing\n var nextCell = this.findNextCellToFocusOn(previousPos, backwards, true);\n if (nextCell == null) {\n return false;\n }\n // only prevent default if we found a cell. so if user is on last cell and hits tab, then we default\n // to the normal tabbing so user can exit the grid.\n nextCell.startEditing(null, null, true, event);\n nextCell.focusCell(false);\n return true;\n };\n NavigationService.prototype.moveToNextEditingRow = function (previousCell, backwards, event) {\n if (event === void 0) { event = null; }\n var previousPos = previousCell.getCellPosition();\n // find the next cell to start editing\n var nextCell = this.findNextCellToFocusOn(previousPos, backwards, true);\n if (nextCell == null) {\n return false;\n }\n var nextPos = nextCell.getCellPosition();\n var previousEditable = this.isCellEditable(previousPos);\n var nextEditable = this.isCellEditable(nextPos);\n var rowsMatch = nextPos && previousPos.rowIndex === nextPos.rowIndex && previousPos.rowPinned === nextPos.rowPinned;\n if (previousEditable) {\n previousCell.setFocusOutOnEditor();\n }\n if (!rowsMatch) {\n var pRow = previousCell.getRowCtrl();\n pRow.stopEditing();\n var nRow = nextCell.getRowCtrl();\n nRow.startRowEditing(undefined, undefined, undefined, event);\n }\n if (nextEditable) {\n nextCell.setFocusInOnEditor();\n nextCell.focusCell();\n }\n else {\n nextCell.focusCell(true);\n }\n return true;\n };\n NavigationService.prototype.moveToNextCellNotEditing = function (previousCell, backwards) {\n var displayedColumns = this.columnModel.getAllDisplayedColumns();\n var cellPos;\n if (previousCell instanceof RowCtrl) {\n cellPos = __assign(__assign({}, previousCell.getRowPosition()), { column: backwards ? displayedColumns[0] : last(displayedColumns) });\n }\n else {\n cellPos = previousCell.getCellPosition();\n }\n // find the next cell to start editing\n var nextCell = this.findNextCellToFocusOn(cellPos, backwards, false);\n // only prevent default if we found a cell. so if user is on last cell and hits tab, then we default\n // to the normal tabbing so user can exit the grid.\n if (nextCell instanceof CellCtrl) {\n nextCell.focusCell(true);\n }\n else if (nextCell) {\n return this.tryToFocusFullWidthRow(nextCell.getRowPosition(), backwards);\n }\n return exists(nextCell);\n };\n // called by the cell, when tab is pressed while editing.\n // @return: RenderedCell when navigation successful, otherwise null\n NavigationService.prototype.findNextCellToFocusOn = function (previousPosition, backwards, startEditing) {\n var nextPosition = previousPosition;\n while (true) {\n if (previousPosition !== nextPosition) {\n previousPosition = nextPosition;\n }\n if (!backwards) {\n nextPosition = this.getLastCellOfColSpan(nextPosition);\n }\n nextPosition = this.cellNavigationService.getNextTabbedCell(nextPosition, backwards);\n // allow user to override what cell to go to next\n var userFunc = this.gridOptionsWrapper.getTabToNextCellFunc();\n if (exists(userFunc)) {\n var params = {\n backwards: backwards,\n editing: startEditing,\n previousCellPosition: previousPosition,\n nextCellPosition: nextPosition ? nextPosition : null\n };\n var userCell = userFunc(params);\n if (exists(userCell)) {\n if (userCell.floating) {\n doOnce(function () { console.warn(\"AG Grid: tabToNextCellFunc return type should have attributes: rowIndex, rowPinned, column. However you had 'floating', maybe you meant 'rowPinned'?\"); }, 'no floating in userCell');\n userCell.rowPinned = userCell.floating;\n }\n nextPosition = {\n rowIndex: userCell.rowIndex,\n column: userCell.column,\n rowPinned: userCell.rowPinned\n };\n }\n else {\n nextPosition = null;\n }\n }\n // if no 'next cell', means we have got to last cell of grid, so nothing to move to,\n // so bottom right cell going forwards, or top left going backwards\n if (!nextPosition) {\n return null;\n }\n if (nextPosition.rowIndex < 0) {\n var headerLen = this.headerNavigationService.getHeaderRowCount();\n this.focusService.focusHeaderPosition({\n headerPosition: {\n headerRowIndex: headerLen + (nextPosition.rowIndex),\n column: nextPosition.column\n }\n });\n return null;\n }\n // if editing, but cell not editable, skip cell. we do this before we do all of\n // the 'ensure index visible' and 'flush all frames', otherwise if we are skipping\n // a bunch of cells (eg 10 rows) then all the work on ensuring cell visible is useless\n // (except for the last one) which causes grid to stall for a while.\n // note - for full row edit, we do focus non-editable cells, as the row stays in edit mode.\n var fullRowEdit = this.gridOptionsWrapper.isFullRowEdit();\n if (startEditing && !fullRowEdit) {\n var cellIsEditable = this.isCellEditable(nextPosition);\n if (!cellIsEditable) {\n continue;\n }\n }\n this.ensureCellVisible(nextPosition);\n // we have to call this after ensureColumnVisible - otherwise it could be a virtual column\n // or row that is not currently in view, hence the renderedCell would not exist\n var nextCell = this.getCellByPosition(nextPosition);\n // if next cell is fullWidth row, then no rendered cell,\n // as fullWidth rows have no cells, so we skip it\n if (!nextCell) {\n var row = this.rowRenderer.getRowByPosition(nextPosition);\n if (!row || !row.isFullWidth()) {\n continue;\n }\n else {\n return row;\n }\n }\n if (nextCell.isSuppressNavigable()) {\n continue;\n }\n // by default, when we click a cell, it gets selected into a range, so to keep keyboard navigation\n // consistent, we set into range here also.\n if (this.rangeService) {\n this.rangeService.setRangeToCell(nextPosition);\n }\n // we successfully tabbed onto a grid cell, so return true\n return nextCell;\n }\n };\n NavigationService.prototype.isCellEditable = function (cell) {\n var rowNode = this.lookupRowNodeForCell(cell);\n if (rowNode) {\n return cell.column.isCellEditable(rowNode);\n }\n return false;\n };\n NavigationService.prototype.getCellByPosition = function (cellPosition) {\n var rowCtrl = this.rowRenderer.getRowByPosition(cellPosition);\n if (!rowCtrl) {\n return null;\n }\n return rowCtrl.getCellCtrl(cellPosition.column);\n };\n NavigationService.prototype.lookupRowNodeForCell = function (cell) {\n if (cell.rowPinned === Constants.PINNED_TOP) {\n return this.pinnedRowModel.getPinnedTopRow(cell.rowIndex);\n }\n if (cell.rowPinned === Constants.PINNED_BOTTOM) {\n return this.pinnedRowModel.getPinnedBottomRow(cell.rowIndex);\n }\n return this.paginationProxy.getRow(cell.rowIndex);\n };\n // we use index for rows, but column object for columns, as the next column (by index) might not\n // be visible (header grouping) so it's not reliable, so using the column object instead.\n NavigationService.prototype.navigateToNextCell = function (event, key, currentCell, allowUserOverride) {\n // we keep searching for a next cell until we find one. this is how the group rows get skipped\n var nextCell = currentCell;\n var hitEdgeOfGrid = false;\n while (nextCell && (nextCell === currentCell || !this.isValidNavigateCell(nextCell))) {\n // if the current cell is spanning across multiple columns, we need to move\n // our current position to be the last cell on the right before finding the\n // the next target.\n if (this.gridOptionsWrapper.isEnableRtl()) {\n if (key === KeyCode.LEFT) {\n nextCell = this.getLastCellOfColSpan(nextCell);\n }\n }\n else if (key === KeyCode.RIGHT) {\n nextCell = this.getLastCellOfColSpan(nextCell);\n }\n nextCell = this.cellNavigationService.getNextCellToFocus(key, nextCell);\n // eg if going down, and nextCell=undefined, means we are gone past the last row\n hitEdgeOfGrid = missing(nextCell);\n }\n if (hitEdgeOfGrid && event && event.key === KeyCode.UP) {\n nextCell = {\n rowIndex: -1,\n rowPinned: null,\n column: currentCell.column\n };\n }\n // allow user to override what cell to go to next. when doing normal cell navigation (with keys)\n // we allow this, however if processing 'enter after edit' we don't allow override\n if (allowUserOverride) {\n var userFunc = this.gridOptionsWrapper.getNavigateToNextCellFunc();\n if (exists(userFunc)) {\n var params = {\n key: key,\n previousCellPosition: currentCell,\n nextCellPosition: nextCell ? nextCell : null,\n event: event\n };\n var userCell = userFunc(params);\n if (exists(userCell)) {\n if (userCell.floating) {\n doOnce(function () { console.warn(\"AG Grid: tabToNextCellFunc return type should have attributes: rowIndex, rowPinned, column. However you had 'floating', maybe you meant 'rowPinned'?\"); }, 'no floating in userCell');\n userCell.rowPinned = userCell.floating;\n }\n nextCell = {\n rowPinned: userCell.rowPinned,\n rowIndex: userCell.rowIndex,\n column: userCell.column\n };\n }\n else {\n nextCell = null;\n }\n }\n }\n // no next cell means we have reached a grid boundary, eg left, right, top or bottom of grid\n if (!nextCell) {\n return;\n }\n if (nextCell.rowIndex < 0) {\n var headerLen = this.headerNavigationService.getHeaderRowCount();\n this.focusService.focusHeaderPosition({\n headerPosition: { headerRowIndex: headerLen + (nextCell.rowIndex), column: currentCell.column },\n event: event || undefined\n });\n return;\n }\n // in case we have col spanning we get the cellComp and use it to get the\n // position. This was we always focus the first cell inside the spanning.\n var normalisedPosition = this.getNormalisedPosition(nextCell);\n if (normalisedPosition) {\n this.focusPosition(normalisedPosition);\n }\n else {\n this.tryToFocusFullWidthRow(nextCell);\n }\n };\n NavigationService.prototype.getNormalisedPosition = function (cellPosition) {\n // ensureCellVisible first, to make sure cell at position is rendered.\n this.ensureCellVisible(cellPosition);\n var cellCtrl = this.getCellByPosition(cellPosition);\n // not guaranteed to have a cellComp when using the SSRM as blocks are loading.\n if (!cellCtrl) {\n return null;\n }\n cellPosition = cellCtrl.getCellPosition();\n // we call this again, as nextCell can be different to it's previous value due to Column Spanning\n // (ie if cursor moving from right to left, and cell is spanning columns, then nextCell was the\n // last column in the group, however now it's the first column in the group). if we didn't do\n // ensureCellVisible again, then we could only be showing the last portion (last column) of the\n // merged cells.\n this.ensureCellVisible(cellPosition);\n return cellPosition;\n };\n NavigationService.prototype.tryToFocusFullWidthRow = function (position, backwards) {\n if (backwards === void 0) { backwards = false; }\n var displayedColumns = this.columnModel.getAllDisplayedColumns();\n var rowComp = this.rowRenderer.getRowByPosition(position);\n if (!rowComp || !rowComp.isFullWidth()) {\n return false;\n }\n var currentCellFocused = this.focusService.getFocusedCell();\n var cellPosition = {\n rowIndex: position.rowIndex,\n rowPinned: position.rowPinned,\n column: position.column || (backwards ? last(displayedColumns) : displayedColumns[0])\n };\n this.focusPosition(cellPosition);\n var fromBelow = currentCellFocused != null ? this.rowPositionUtils.before(cellPosition, currentCellFocused) : false;\n var focusEvent = {\n type: Events.EVENT_FULL_WIDTH_ROW_FOCUSED,\n rowIndex: cellPosition.rowIndex,\n rowPinned: cellPosition.rowPinned,\n column: cellPosition.column,\n isFullWidthCell: true,\n floating: cellPosition.rowPinned,\n fromBelow: fromBelow\n };\n this.eventService.dispatchEvent(focusEvent);\n return true;\n };\n NavigationService.prototype.focusPosition = function (cellPosition) {\n this.focusService.setFocusedCell({\n rowIndex: cellPosition.rowIndex,\n column: cellPosition.column,\n rowPinned: cellPosition.rowPinned,\n forceBrowserFocus: true\n });\n if (this.rangeService) {\n this.rangeService.setRangeToCell(cellPosition);\n }\n };\n NavigationService.prototype.isValidNavigateCell = function (cell) {\n var rowNode = this.rowPositionUtils.getRowNode(cell);\n // we do not allow focusing on detail rows and full width rows\n return !!rowNode;\n };\n NavigationService.prototype.getLastCellOfColSpan = function (cell) {\n var cellCtrl = this.getCellByPosition(cell);\n if (!cellCtrl) {\n return cell;\n }\n var colSpanningList = cellCtrl.getColSpanningList();\n if (colSpanningList.length === 1) {\n return cell;\n }\n return {\n rowIndex: cell.rowIndex,\n column: last(colSpanningList),\n rowPinned: cell.rowPinned\n };\n };\n NavigationService.prototype.ensureCellVisible = function (gridCell) {\n var _a;\n var isGroupStickyEnabled = this.gridOptionsWrapper.isGroupRowsSticky();\n var rowNode = this.rowModel.getRow(gridCell.rowIndex);\n // sticky rows are always visible, so the grid shouldn't scroll to focus them.\n var skipScrollToRow = isGroupStickyEnabled && ((_a = rowNode) === null || _a === void 0 ? void 0 : _a.sticky);\n // this scrolls the row into view\n if (!skipScrollToRow && missing(gridCell.rowPinned)) {\n this.gridBodyCon.getScrollFeature().ensureIndexVisible(gridCell.rowIndex);\n }\n if (!gridCell.column.isPinned()) {\n this.gridBodyCon.getScrollFeature().ensureColumnVisible(gridCell.column);\n }\n };\n __decorate([\n Autowired('mouseEventService')\n ], NavigationService.prototype, \"mouseEventService\", void 0);\n __decorate([\n Autowired('paginationProxy')\n ], NavigationService.prototype, \"paginationProxy\", void 0);\n __decorate([\n Autowired('focusService')\n ], NavigationService.prototype, \"focusService\", void 0);\n __decorate([\n Optional('rangeService')\n ], NavigationService.prototype, \"rangeService\", void 0);\n __decorate([\n Autowired('columnModel')\n ], NavigationService.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('rowModel')\n ], NavigationService.prototype, \"rowModel\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], NavigationService.prototype, \"ctrlsService\", void 0);\n __decorate([\n Autowired('rowRenderer')\n ], NavigationService.prototype, \"rowRenderer\", void 0);\n __decorate([\n Autowired('headerNavigationService')\n ], NavigationService.prototype, \"headerNavigationService\", void 0);\n __decorate([\n Autowired(\"rowPositionUtils\")\n ], NavigationService.prototype, \"rowPositionUtils\", void 0);\n __decorate([\n Autowired(\"cellNavigationService\")\n ], NavigationService.prototype, \"cellNavigationService\", void 0);\n __decorate([\n Autowired(\"pinnedRowModel\")\n ], NavigationService.prototype, \"pinnedRowModel\", void 0);\n __decorate([\n PostConstruct\n ], NavigationService.prototype, \"postConstruct\", null);\n NavigationService = __decorate([\n Bean('navigationService')\n ], NavigationService);\n return NavigationService;\n}(BeanStub));\nexport { NavigationService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PopupComponent } from \"../../widgets/popupComponent\";\nimport { isUserSuppressingKeyboardEvent } from \"../../utils/keyboard\";\nimport { PostConstruct } from \"../../context/context\";\nvar PopupEditorWrapper = /** @class */ (function (_super) {\n __extends(PopupEditorWrapper, _super);\n function PopupEditorWrapper(params) {\n var _this = _super.call(this, /* html */ \"
\") || this;\n _this.params = params;\n return _this;\n }\n PopupEditorWrapper.prototype.postConstruct = function () {\n this.gridOptionsWrapper.setDomData(this.getGui(), PopupEditorWrapper.DOM_KEY_POPUP_EDITOR_WRAPPER, true);\n this.addKeyDownListener();\n };\n PopupEditorWrapper.prototype.addKeyDownListener = function () {\n var _this = this;\n var eGui = this.getGui();\n var params = this.params;\n var listener = function (event) {\n if (!isUserSuppressingKeyboardEvent(_this.gridOptionsWrapper, event, params.node, params.column, true)) {\n params.onKeyDown(event);\n }\n };\n this.addManagedListener(eGui, 'keydown', listener);\n };\n PopupEditorWrapper.DOM_KEY_POPUP_EDITOR_WRAPPER = 'popupEditorWrapper';\n __decorate([\n PostConstruct\n ], PopupEditorWrapper.prototype, \"postConstruct\", null);\n return PopupEditorWrapper;\n}(PopupComponent));\nexport { PopupEditorWrapper };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { Component } from \"../../widgets/component\";\nimport { PopupEditorWrapper } from \"./../cellEditors/popupEditorWrapper\";\nimport { setAriaDescribedBy, setAriaRole } from \"../../utils/aria\";\nimport { escapeString } from \"../../utils/string\";\nimport { missing } from \"../../utils/generic\";\nimport { addStylesToElement, clearElement, loadTemplate, removeFromParent } from \"../../utils/dom\";\nimport { browserSupportsPreventScroll } from \"../../utils/browser\";\nvar CellComp = /** @class */ (function (_super) {\n __extends(CellComp, _super);\n function CellComp(beans, cellCtrl, printLayout, eRow, editingRow) {\n var _this = _super.call(this) || this;\n // every time we go into edit mode, or back again, this gets incremented.\n // it's the components way of dealing with the async nature of framework components,\n // so if a framework component takes a while to be created, we know if the object\n // is still relevant when creating is finished. eg we could click edit / un-edit 20\n // times before the first React edit component comes back - we should discard\n // the first 19.\n _this.rendererVersion = 0;\n _this.editorVersion = 0;\n _this.beans = beans;\n _this.column = cellCtrl.getColumn();\n _this.rowNode = cellCtrl.getRowNode();\n _this.rowCtrl = cellCtrl.getRowCtrl();\n _this.eRow = eRow;\n _this.setTemplate(/* html */ \"
\");\n var eGui = _this.getGui();\n _this.forceWrapper = cellCtrl.isForceWrapper();\n _this.refreshWrapper(false);\n var setAttribute = function (name, value, element) {\n var actualElement = element ? element : eGui;\n if (value != null && value != '') {\n actualElement.setAttribute(name, value);\n }\n else {\n actualElement.removeAttribute(name);\n }\n };\n var compProxy = {\n addOrRemoveCssClass: function (cssClassName, on) { return _this.addOrRemoveCssClass(cssClassName, on); },\n setUserStyles: function (styles) { return addStylesToElement(eGui, styles); },\n getFocusableElement: function () { return _this.getFocusableElement(); },\n setTabIndex: function (tabIndex) { return setAttribute('tabindex', tabIndex.toString()); },\n setRole: function (role) { return setAriaRole(eGui, role); },\n setColId: function (colId) { return setAttribute('col-id', colId); },\n setTitle: function (title) { return setAttribute('title', title); },\n setIncludeSelection: function (include) { return _this.includeSelection = include; },\n setIncludeRowDrag: function (include) { return _this.includeRowDrag = include; },\n setIncludeDndSource: function (include) { return _this.includeDndSource = include; },\n setRenderDetails: function (compDetails, valueToDisplay, force) {\n return _this.setRenderDetails(compDetails, valueToDisplay, force);\n },\n setEditDetails: function (compDetails, popup, position) {\n return _this.setEditDetails(compDetails, popup, position);\n },\n getCellEditor: function () { return _this.cellEditor || null; },\n getCellRenderer: function () { return _this.cellRenderer || null; },\n getParentOfValue: function () { return _this.getParentOfValue(); }\n };\n _this.cellCtrl = cellCtrl;\n cellCtrl.setComp(compProxy, _this.getGui(), _this.eCellWrapper, printLayout, editingRow);\n return _this;\n }\n CellComp.prototype.getParentOfValue = function () {\n if (this.eCellValue) {\n // if not editing, and using wrapper, then value goes in eCellValue\n return this.eCellValue;\n }\n if (this.eCellWrapper) {\n // if editing, and using wrapper, value (cell editor) goes in eCellWrapper\n return this.eCellWrapper;\n }\n // if editing or rendering, and not using wrapper, value (or comp) is directly inside cell\n return this.getGui();\n };\n CellComp.prototype.setRenderDetails = function (compDetails, valueToDisplay, forceNewCellRendererInstance) {\n // this can happen if the users asks for the cell to refresh, but we are not showing the vale as we are editing\n var isInlineEditing = this.cellEditor && !this.cellEditorPopupWrapper;\n if (isInlineEditing) {\n return;\n }\n // this means firstRender will be true for one pass only, as it's initialised to undefined\n this.firstRender = this.firstRender == null;\n // if display template has changed, means any previous Cell Renderer is in the wrong location\n var controlWrapperChanged = this.refreshWrapper(false);\n // all of these have dependencies on the eGui, so only do them after eGui is set\n if (compDetails) {\n var neverRefresh = forceNewCellRendererInstance || controlWrapperChanged;\n var cellRendererRefreshSuccessful = neverRefresh ? false : this.refreshCellRenderer(compDetails);\n if (!cellRendererRefreshSuccessful) {\n this.destroyRenderer();\n this.createCellRendererInstance(compDetails);\n }\n }\n else {\n this.destroyRenderer();\n this.insertValueWithoutCellRenderer(valueToDisplay);\n }\n };\n CellComp.prototype.setEditDetails = function (compDetails, popup, position) {\n if (compDetails) {\n this.createCellEditorInstance(compDetails, popup, position);\n }\n else {\n this.destroyEditor();\n }\n };\n CellComp.prototype.removeControls = function () {\n this.checkboxSelectionComp = this.beans.context.destroyBean(this.checkboxSelectionComp);\n this.dndSourceComp = this.beans.context.destroyBean(this.dndSourceComp);\n this.rowDraggingComp = this.beans.context.destroyBean(this.rowDraggingComp);\n };\n // returns true if wrapper was changed\n CellComp.prototype.refreshWrapper = function (editing) {\n var providingControls = this.includeRowDrag || this.includeDndSource || this.includeSelection;\n var usingWrapper = providingControls || this.forceWrapper;\n var putWrapperIn = usingWrapper && this.eCellWrapper == null;\n if (putWrapperIn) {\n this.eCellWrapper = loadTemplate(\"
\");\n this.getGui().appendChild(this.eCellWrapper);\n }\n var takeWrapperOut = !usingWrapper && this.eCellWrapper != null;\n if (takeWrapperOut) {\n removeFromParent(this.eCellWrapper);\n this.eCellWrapper = undefined;\n }\n this.addOrRemoveCssClass('ag-cell-value', !usingWrapper);\n var usingCellValue = !editing && usingWrapper;\n var putCellValueIn = usingCellValue && this.eCellValue == null;\n if (putCellValueIn) {\n this.eCellValue = loadTemplate(\"\");\n this.eCellWrapper.appendChild(this.eCellValue);\n }\n var takeCellValueOut = !usingCellValue && this.eCellValue != null;\n if (takeCellValueOut) {\n removeFromParent(this.eCellValue);\n this.eCellValue = undefined;\n }\n var templateChanged = putWrapperIn || takeWrapperOut || putCellValueIn || takeCellValueOut;\n if (templateChanged) {\n this.removeControls();\n }\n if (!editing && providingControls) {\n this.addControls();\n }\n return templateChanged;\n };\n CellComp.prototype.addControls = function () {\n var id = this.eCellValue.id = \"cell-\" + this.getCompId();\n var describedByIds = [];\n if (this.includeRowDrag) {\n if (this.rowDraggingComp == null) {\n this.rowDraggingComp = this.cellCtrl.createRowDragComp();\n if (this.rowDraggingComp) {\n // put the checkbox in before the value\n this.eCellWrapper.insertBefore(this.rowDraggingComp.getGui(), this.eCellValue);\n }\n }\n }\n if (this.includeDndSource) {\n if (this.dndSourceComp == null) {\n this.dndSourceComp = this.cellCtrl.createDndSource();\n // put the checkbox in before the value\n this.eCellWrapper.insertBefore(this.dndSourceComp.getGui(), this.eCellValue);\n }\n }\n if (this.includeSelection) {\n if (this.checkboxSelectionComp == null) {\n this.checkboxSelectionComp = this.cellCtrl.createSelectionCheckbox();\n this.eCellWrapper.insertBefore(this.checkboxSelectionComp.getGui(), this.eCellValue);\n }\n describedByIds.push(this.checkboxSelectionComp.getCheckboxId());\n }\n describedByIds.push(id);\n setAriaDescribedBy(this.getGui(), describedByIds.join(' '));\n };\n CellComp.prototype.createCellEditorInstance = function (compDetails, popup, position) {\n var _this = this;\n var versionCopy = this.editorVersion;\n var cellEditorPromise = compDetails.newAgStackInstance();\n if (!cellEditorPromise) {\n return;\n } // if empty, userComponentFactory already did a console message\n var params = compDetails.params;\n cellEditorPromise.then(function (c) { return _this.afterCellEditorCreated(versionCopy, c, params, popup, position); });\n // if we don't do this, and editor component is async, then there will be a period\n // when the component isn't present and keyboard navigation won't work - so example\n // of user hitting tab quickly (more quickly than renderers getting created) won't work\n var cellEditorAsync = missing(this.cellEditor);\n if (cellEditorAsync && params.cellStartedEdit) {\n this.cellCtrl.focusCell(true);\n }\n };\n CellComp.prototype.insertValueWithoutCellRenderer = function (valueToDisplay) {\n var eParent = this.getParentOfValue();\n clearElement(eParent);\n var escapedValue = valueToDisplay != null ? escapeString(valueToDisplay) : null;\n if (escapedValue != null) {\n eParent.innerHTML = escapedValue;\n }\n };\n CellComp.prototype.destroyEditorAndRenderer = function () {\n this.destroyRenderer();\n this.destroyEditor();\n };\n CellComp.prototype.destroyRenderer = function () {\n var context = this.beans.context;\n this.cellRenderer = context.destroyBean(this.cellRenderer);\n removeFromParent(this.cellRendererGui);\n this.cellRendererGui = null;\n this.rendererVersion++;\n };\n CellComp.prototype.destroyEditor = function () {\n var context = this.beans.context;\n if (this.hideEditorPopup) {\n this.hideEditorPopup();\n }\n this.hideEditorPopup = undefined;\n this.cellEditor = context.destroyBean(this.cellEditor);\n this.cellEditorPopupWrapper = context.destroyBean(this.cellEditorPopupWrapper);\n removeFromParent(this.cellEditorGui);\n this.cellEditorGui = null;\n this.editorVersion++;\n };\n CellComp.prototype.refreshCellRenderer = function (compClassAndParams) {\n if (this.cellRenderer == null || this.cellRenderer.refresh == null) {\n return false;\n }\n // if different Cell Renderer configured this time (eg user is using selector, and\n // returns different component) then don't refresh, force recreate of Cell Renderer\n if (this.cellRendererClass !== compClassAndParams.componentClass) {\n return false;\n }\n // take any custom params off of the user\n var result = this.cellRenderer.refresh(compClassAndParams.params);\n // NOTE on undefined: previous version of the cellRenderer.refresh() interface\n // returned nothing, if the method existed, we assumed it refreshed. so for\n // backwards compatibility, we assume if method exists and returns nothing,\n // that it was successful.\n return result === true || result === undefined;\n };\n CellComp.prototype.createCellRendererInstance = function (compDetails) {\n var _this = this;\n // never use task service if angularCompileRows=true, as that assume the cell renderers\n // are finished when the row is created. also we never use it if animation frame service\n // is turned off.\n // and lastly we never use it if doing auto-height, as the auto-height service checks the\n // row height directly after the cell is created, it doesn't wait around for the tasks to complete\n var angularCompileRows = this.beans.gridOptionsWrapper.isAngularCompileRows();\n var suppressAnimationFrame = this.beans.gridOptionsWrapper.isSuppressAnimationFrame();\n var useTaskService = !angularCompileRows && !suppressAnimationFrame;\n var displayComponentVersionCopy = this.rendererVersion;\n var componentClass = compDetails.componentClass;\n var createCellRendererFunc = function () {\n var staleTask = _this.rendererVersion !== displayComponentVersionCopy || !_this.isAlive();\n if (staleTask) {\n return;\n }\n // this can return null in the event that the user has switched from a renderer component to nothing, for example\n // when using a cellRendererSelect to return a component or null depending on row data etc\n var componentPromise = compDetails.newAgStackInstance();\n var callback = _this.afterCellRendererCreated.bind(_this, displayComponentVersionCopy, componentClass);\n if (componentPromise) {\n componentPromise.then(callback);\n }\n };\n // we only use task service when rendering for first time, which means it is not used when doing edits.\n // if we changed this (always use task service) would make sense, however it would break tests, possibly\n // test of users.\n if (useTaskService && this.firstRender) {\n this.beans.animationFrameService.createTask(createCellRendererFunc, this.rowNode.rowIndex, 'createTasksP2');\n }\n else {\n createCellRendererFunc();\n }\n };\n CellComp.prototype.getCtrl = function () {\n return this.cellCtrl;\n };\n CellComp.prototype.getRowCtrl = function () {\n return this.rowCtrl;\n };\n CellComp.prototype.getCellRenderer = function () {\n return this.cellRenderer;\n };\n CellComp.prototype.getCellEditor = function () {\n return this.cellEditor;\n };\n CellComp.prototype.afterCellRendererCreated = function (cellRendererVersion, cellRendererClass, cellRenderer) {\n var staleTask = !this.isAlive() || cellRendererVersion !== this.rendererVersion;\n if (staleTask) {\n this.beans.context.destroyBean(cellRenderer);\n return;\n }\n this.cellRenderer = cellRenderer;\n this.cellRendererClass = cellRendererClass;\n this.cellRendererGui = this.cellRenderer.getGui();\n if (this.cellRendererGui != null) {\n var eParent = this.getParentOfValue();\n clearElement(eParent);\n eParent.appendChild(this.cellRendererGui);\n }\n };\n CellComp.prototype.afterCellEditorCreated = function (requestVersion, cellEditor, params, popup, position) {\n // if editingCell=false, means user cancelled the editor before component was ready.\n // if versionMismatch, then user cancelled the edit, then started the edit again, and this\n // is the first editor which is now stale.\n var staleComp = requestVersion !== this.editorVersion;\n if (staleComp) {\n this.beans.context.destroyBean(cellEditor);\n return;\n }\n var editingCancelledByUserComp = cellEditor.isCancelBeforeStart && cellEditor.isCancelBeforeStart();\n if (editingCancelledByUserComp) {\n this.beans.context.destroyBean(cellEditor);\n this.cellCtrl.stopEditing();\n return;\n }\n if (!cellEditor.getGui) {\n console.warn(\"AG Grid: cellEditor for column \" + this.column.getId() + \" is missing getGui() method\");\n this.beans.context.destroyBean(cellEditor);\n return;\n }\n this.cellEditor = cellEditor;\n this.cellEditorGui = cellEditor.getGui();\n var cellEditorInPopup = popup || (cellEditor.isPopup !== undefined && cellEditor.isPopup());\n if (cellEditorInPopup) {\n if (!popup) {\n this.cellCtrl.hackSayEditingInPopup();\n }\n this.addPopupCellEditor(params, position);\n }\n else {\n this.addInCellEditor();\n }\n if (cellEditor.afterGuiAttached) {\n cellEditor.afterGuiAttached();\n }\n };\n CellComp.prototype.addInCellEditor = function () {\n var eGui = this.getGui();\n // if focus is inside the cell, we move focus to the cell itself\n // before removing it's contents, otherwise errors could be thrown.\n var eDocument = this.beans.gridOptionsWrapper.getDocument();\n if (eGui.contains(eDocument.activeElement)) {\n eGui.focus();\n }\n this.destroyRenderer();\n this.refreshWrapper(true);\n this.clearParentOfValue();\n if (this.cellEditorGui) {\n var eParent = this.getParentOfValue();\n eParent.appendChild(this.cellEditorGui);\n }\n };\n CellComp.prototype.addPopupCellEditor = function (params, position) {\n var _this = this;\n if (this.beans.gridOptionsWrapper.isFullRowEdit()) {\n console.warn('AG Grid: popup cellEditor does not work with fullRowEdit - you cannot use them both ' +\n '- either turn off fullRowEdit, or stop using popup editors.');\n }\n var cellEditor = this.cellEditor;\n // if a popup, then we wrap in a popup editor and return the popup\n this.cellEditorPopupWrapper = this.beans.context.createBean(new PopupEditorWrapper(params));\n var ePopupGui = this.cellEditorPopupWrapper.getGui();\n if (this.cellEditorGui) {\n ePopupGui.appendChild(this.cellEditorGui);\n }\n var popupService = this.beans.popupService;\n var useModelPopup = this.beans.gridOptionsWrapper.isStopEditingWhenCellsLoseFocus();\n // see if position provided by colDef, if not then check old way of method on cellComp\n var positionToUse = position != null ? position : cellEditor.getPopupPosition ? cellEditor.getPopupPosition() : 'over';\n var positionParams = {\n column: this.column,\n rowNode: this.rowNode,\n type: 'popupCellEditor',\n eventSource: this.getGui(),\n ePopup: ePopupGui,\n keepWithinBounds: true\n };\n var positionCallback = positionToUse === 'under' ?\n popupService.positionPopupUnderComponent.bind(popupService, positionParams)\n : popupService.positionPopupOverComponent.bind(popupService, positionParams);\n var translate = this.beans.gridOptionsWrapper.getLocaleTextFunc();\n var addPopupRes = popupService.addPopup({\n modal: useModelPopup,\n eChild: ePopupGui,\n closeOnEsc: true,\n closedCallback: function () { _this.cellCtrl.onPopupEditorClosed(); },\n anchorToElement: this.getGui(),\n positionCallback: positionCallback,\n ariaLabel: translate('ariaLabelCellEditor', 'Cell Editor')\n });\n if (addPopupRes) {\n this.hideEditorPopup = addPopupRes.hideFunc;\n }\n };\n CellComp.prototype.detach = function () {\n this.eRow.removeChild(this.getGui());\n };\n // if the row is also getting destroyed, then we don't need to remove from dom,\n // as the row will also get removed, so no need to take out the cells from the row\n // if the row is going (removing is an expensive operation, so only need to remove\n // the top part)\n //\n // note - this is NOT called by context, as we don't wire / unwire the CellComp for performance reasons.\n CellComp.prototype.destroy = function () {\n this.cellCtrl.stopEditing();\n this.destroyEditorAndRenderer();\n this.removeControls();\n _super.prototype.destroy.call(this);\n };\n CellComp.prototype.clearParentOfValue = function () {\n var eGui = this.getGui();\n // if focus is inside the cell, we move focus to the cell itself\n // before removing it's contents, otherwise errors could be thrown.\n var eDocument = this.beans.gridOptionsWrapper.getDocument();\n if (eGui.contains(eDocument.activeElement) && browserSupportsPreventScroll()) {\n eGui.focus({ preventScroll: true });\n }\n clearElement(this.getParentOfValue());\n };\n return CellComp;\n}(Component));\nexport { CellComp };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { Component } from \"../../widgets/component\";\nimport { addStylesToElement, setDomChildOrder } from \"../../utils/dom\";\nimport { CellComp } from \"../cell/cellComp\";\nimport { getAllValuesInObject } from \"../../utils/object\";\nimport { setAriaRole } from \"../../utils/aria\";\nvar RowComp = /** @class */ (function (_super) {\n __extends(RowComp, _super);\n function RowComp(ctrl, beans, containerType) {\n var _this = _super.call(this) || this;\n _this.cellComps = {};\n _this.beans = beans;\n _this.rowCtrl = ctrl;\n _this.setTemplate(/* html */ \"
\");\n var eGui = _this.getGui();\n var style = eGui.style;\n var compProxy = {\n setDomOrder: function (domOrder) { return _this.domOrder = domOrder; },\n setCellCtrls: function (cellCtrls) { return _this.setCellCtrls(cellCtrls); },\n showFullWidth: function (compDetails) { return _this.showFullWidth(compDetails); },\n getFullWidthCellRenderer: function () { return _this.getFullWidthCellRenderer(); },\n addOrRemoveCssClass: function (name, on) { return _this.addOrRemoveCssClass(name, on); },\n setUserStyles: function (styles) { return addStylesToElement(eGui, styles); },\n setTop: function (top) { return style.top = top; },\n setTransform: function (transform) { return style.transform = transform; },\n setRowIndex: function (rowIndex) { return eGui.setAttribute('row-index', rowIndex); },\n setRole: function (role) { return setAriaRole(eGui, role); },\n setRowId: function (rowId) { return eGui.setAttribute('row-id', rowId); },\n setRowBusinessKey: function (businessKey) { return eGui.setAttribute('row-business-key', businessKey); },\n setTabIndex: function (tabIndex) { return eGui.setAttribute('tabindex', tabIndex.toString()); }\n };\n ctrl.setComp(compProxy, _this.getGui(), containerType);\n return _this;\n }\n RowComp.prototype.getInitialStyle = function () {\n var transform = this.rowCtrl.getInitialTransform();\n var top = this.rowCtrl.getInitialRowTop();\n return transform ? \"transform: \" + transform : \"top: \" + top;\n };\n RowComp.prototype.showFullWidth = function (compDetails) {\n var _this = this;\n var callback = function (cellRenderer) {\n if (_this.isAlive()) {\n var eGui = cellRenderer.getGui();\n _this.getGui().appendChild(eGui);\n _this.rowCtrl.setupDetailRowAutoHeight(eGui);\n _this.setFullWidthRowComp(cellRenderer);\n }\n else {\n _this.beans.context.destroyBean(cellRenderer);\n }\n };\n // if not in cache, create new one\n var res = compDetails.newAgStackInstance();\n if (!res) {\n return;\n }\n res.then(callback);\n };\n RowComp.prototype.setCellCtrls = function (cellCtrls) {\n var _this = this;\n var cellsToRemove = Object.assign({}, this.cellComps);\n cellCtrls.forEach(function (cellCtrl) {\n var key = cellCtrl.getInstanceId();\n var existingCellComp = _this.cellComps[key];\n if (existingCellComp == null) {\n _this.newCellComp(cellCtrl);\n }\n else {\n cellsToRemove[key] = null;\n }\n });\n var cellCompsToRemove = getAllValuesInObject(cellsToRemove)\n .filter(function (cellComp) { return cellComp != null; });\n this.destroyCells(cellCompsToRemove);\n this.ensureDomOrder(cellCtrls);\n };\n RowComp.prototype.ensureDomOrder = function (cellCtrls) {\n var _this = this;\n if (!this.domOrder) {\n return;\n }\n var elementsInOrder = [];\n cellCtrls.forEach(function (cellCtrl) {\n var cellComp = _this.cellComps[cellCtrl.getInstanceId()];\n if (cellComp) {\n elementsInOrder.push(cellComp.getGui());\n }\n });\n setDomChildOrder(this.getGui(), elementsInOrder);\n };\n RowComp.prototype.newCellComp = function (cellCtrl) {\n var cellComp = new CellComp(this.beans, cellCtrl, this.rowCtrl.isPrintLayout(), this.getGui(), this.rowCtrl.isEditing());\n this.cellComps[cellCtrl.getInstanceId()] = cellComp;\n this.getGui().appendChild(cellComp.getGui());\n };\n RowComp.prototype.destroy = function () {\n _super.prototype.destroy.call(this);\n this.destroyAllCells();\n };\n RowComp.prototype.destroyAllCells = function () {\n var cellsToDestroy = getAllValuesInObject(this.cellComps).filter(function (cp) { return cp != null; });\n this.destroyCells(cellsToDestroy);\n };\n RowComp.prototype.setFullWidthRowComp = function (fullWidthRowComponent) {\n var _this = this;\n if (this.fullWidthCellRenderer) {\n console.error('AG Grid - should not be setting fullWidthRowComponent twice');\n }\n this.fullWidthCellRenderer = fullWidthRowComponent;\n this.addDestroyFunc(function () {\n _this.fullWidthCellRenderer = _this.beans.context.destroyBean(_this.fullWidthCellRenderer);\n });\n };\n RowComp.prototype.getFullWidthCellRenderer = function () {\n return this.fullWidthCellRenderer;\n };\n RowComp.prototype.destroyCells = function (cellComps) {\n var _this = this;\n cellComps.forEach(function (cellComp) {\n // could be old reference, ie removed cell\n if (!cellComp) {\n return;\n }\n // check cellComp belongs in this container\n var instanceId = cellComp.getCtrl().getInstanceId();\n if (_this.cellComps[instanceId] !== cellComp) {\n return;\n }\n cellComp.detach();\n cellComp.destroy();\n _this.cellComps[instanceId] = null;\n });\n };\n return RowComp;\n}(Component));\nexport { RowComp };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from \"../../widgets/component\";\nimport { RefSelector } from \"../../widgets/componentAnnotations\";\nimport { Autowired, PostConstruct, PreDestroy } from \"../../context/context\";\nimport { getRowContainerTypeForName, RowContainerCtrl, RowContainerName } from \"./rowContainerCtrl\";\nimport { ensureDomOrder, insertWithDomOrder } from \"../../utils/dom\";\nimport { RowComp } from \"../../rendering/row/rowComp\";\nimport { getAllValuesInObject } from \"../../utils/object\";\nimport { setAriaRole } from \"../../utils/aria\";\nfunction templateFactory() {\n var name = Component.elementGettingCreated.getAttribute('name');\n var cssClasses = RowContainerCtrl.getRowContainerCssClasses(name);\n var res;\n var template1 = name === RowContainerName.CENTER;\n var template2 = name === RowContainerName.TOP_CENTER\n || name === RowContainerName.STICKY_TOP_CENTER\n || name === RowContainerName.BOTTOM_CENTER;\n if (template1) {\n res = /* html */\n \"
\\n
\\n
\\n
\\n
\";\n }\n else if (template2) {\n res = /* html */\n \"
\\n
\\n
\";\n }\n else {\n res = /* html */\n \"
\";\n }\n return res;\n}\nvar RowContainerComp = /** @class */ (function (_super) {\n __extends(RowContainerComp, _super);\n function RowContainerComp() {\n var _this = _super.call(this, templateFactory()) || this;\n _this.rowComps = {};\n _this.name = Component.elementGettingCreated.getAttribute('name');\n _this.type = getRowContainerTypeForName(_this.name);\n return _this;\n }\n RowContainerComp.prototype.postConstruct = function () {\n var _this = this;\n var compProxy = {\n setViewportHeight: function (height) { return _this.eViewport.style.height = height; },\n setRowCtrls: function (rowCtrls) { return _this.setRowCtrls(rowCtrls); },\n setDomOrder: function (domOrder) {\n _this.domOrder = domOrder;\n },\n setContainerWidth: function (width) { return _this.eContainer.style.width = width; }\n };\n var ctrl = this.createManagedBean(new RowContainerCtrl(this.name));\n ctrl.setComp(compProxy, this.eContainer, this.eViewport, this.eWrapper);\n };\n RowContainerComp.prototype.preDestroy = function () {\n // destroys all row comps\n this.setRowCtrls([]);\n };\n RowContainerComp.prototype.setRowCtrls = function (rowCtrls) {\n var _this = this;\n var oldRows = __assign({}, this.rowComps);\n this.rowComps = {};\n this.lastPlacedElement = null;\n var processRow = function (rowCon) {\n var instanceId = rowCon.getInstanceId();\n var existingRowComp = oldRows[instanceId];\n if (existingRowComp) {\n _this.rowComps[instanceId] = existingRowComp;\n delete oldRows[instanceId];\n _this.ensureDomOrder(existingRowComp.getGui());\n }\n else {\n var rowComp = _this.newRowComp(rowCon);\n _this.rowComps[instanceId] = rowComp;\n _this.appendRow(rowComp.getGui());\n }\n };\n rowCtrls.forEach(processRow);\n getAllValuesInObject(oldRows).forEach(function (oldRowComp) {\n _this.eContainer.removeChild(oldRowComp.getGui());\n oldRowComp.destroy();\n });\n setAriaRole(this.eContainer, rowCtrls.length ? \"rowgroup\" : \"presentation\");\n };\n RowContainerComp.prototype.appendRow = function (element) {\n if (this.domOrder) {\n insertWithDomOrder(this.eContainer, element, this.lastPlacedElement);\n }\n else {\n this.eContainer.appendChild(element);\n }\n this.lastPlacedElement = element;\n };\n RowContainerComp.prototype.ensureDomOrder = function (eRow) {\n if (this.domOrder) {\n ensureDomOrder(this.eContainer, eRow, this.lastPlacedElement);\n this.lastPlacedElement = eRow;\n }\n };\n RowContainerComp.prototype.newRowComp = function (rowCtrl) {\n var pinned = RowContainerCtrl.getPinned(this.name);\n var res = new RowComp(rowCtrl, this.beans, this.type);\n return res;\n };\n __decorate([\n Autowired('beans')\n ], RowContainerComp.prototype, \"beans\", void 0);\n __decorate([\n RefSelector('eViewport')\n ], RowContainerComp.prototype, \"eViewport\", void 0);\n __decorate([\n RefSelector('eContainer')\n ], RowContainerComp.prototype, \"eContainer\", void 0);\n __decorate([\n RefSelector('eWrapper')\n ], RowContainerComp.prototype, \"eWrapper\", void 0);\n __decorate([\n PostConstruct\n ], RowContainerComp.prototype, \"postConstruct\", null);\n __decorate([\n PreDestroy\n ], RowContainerComp.prototype, \"preDestroy\", null);\n return RowContainerComp;\n}(Component));\nexport { RowContainerComp };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { DragAndDropService } from \"../../dragAndDrop/dragAndDropService\";\nimport { Autowired } from \"../../context/context\";\nvar BodyDropPivotTarget = /** @class */ (function () {\n function BodyDropPivotTarget(pinned) {\n this.columnsToAggregate = [];\n this.columnsToGroup = [];\n this.columnsToPivot = [];\n this.pinned = pinned;\n }\n /** Callback for when drag enters */\n BodyDropPivotTarget.prototype.onDragEnter = function (draggingEvent) {\n var _this = this;\n this.clearColumnsList();\n // in pivot mode, we don't accept any drops if functions are read only\n if (this.gridOptionsWrapper.isFunctionsReadOnly()) {\n return;\n }\n var dragColumns = draggingEvent.dragItem.columns;\n if (!dragColumns) {\n return;\n }\n dragColumns.forEach(function (column) {\n // we don't allow adding secondary columns\n if (!column.isPrimary()) {\n return;\n }\n if (column.isAnyFunctionActive()) {\n return;\n }\n if (column.isAllowValue()) {\n _this.columnsToAggregate.push(column);\n }\n else if (column.isAllowRowGroup()) {\n _this.columnsToGroup.push(column);\n }\n else if (column.isAllowPivot()) {\n _this.columnsToPivot.push(column);\n }\n });\n };\n BodyDropPivotTarget.prototype.getIconName = function () {\n var totalColumns = this.columnsToAggregate.length + this.columnsToGroup.length + this.columnsToPivot.length;\n if (totalColumns > 0) {\n return this.pinned ? DragAndDropService.ICON_PINNED : DragAndDropService.ICON_MOVE;\n }\n return null;\n };\n /** Callback for when drag leaves */\n BodyDropPivotTarget.prototype.onDragLeave = function (draggingEvent) {\n // if we are taking columns out of the center, then we remove them from the report\n this.clearColumnsList();\n };\n BodyDropPivotTarget.prototype.clearColumnsList = function () {\n this.columnsToAggregate.length = 0;\n this.columnsToGroup.length = 0;\n this.columnsToPivot.length = 0;\n };\n /** Callback for when dragging */\n BodyDropPivotTarget.prototype.onDragging = function (draggingEvent) {\n };\n /** Callback for when drag stops */\n BodyDropPivotTarget.prototype.onDragStop = function (draggingEvent) {\n if (this.columnsToAggregate.length > 0) {\n this.columnModel.addValueColumns(this.columnsToAggregate, \"toolPanelDragAndDrop\");\n }\n if (this.columnsToGroup.length > 0) {\n this.columnModel.addRowGroupColumns(this.columnsToGroup, \"toolPanelDragAndDrop\");\n }\n if (this.columnsToPivot.length > 0) {\n this.columnModel.addPivotColumns(this.columnsToPivot, \"toolPanelDragAndDrop\");\n }\n };\n __decorate([\n Autowired('columnModel')\n ], BodyDropPivotTarget.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('gridOptionsWrapper')\n ], BodyDropPivotTarget.prototype, \"gridOptionsWrapper\", void 0);\n return BodyDropPivotTarget;\n}());\nexport { BodyDropPivotTarget };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nimport { Autowired, PostConstruct } from \"../../context/context\";\nimport { Constants } from \"../../constants/constants\";\nimport { DragAndDropService, DragSourceType, HorizontalDirection } from \"../../dragAndDrop/dragAndDropService\";\nimport { missing, exists } from \"../../utils/generic\";\nimport { sortNumerically, last, includes } from \"../../utils/array\";\nimport { _ } from \"../../utils\";\nvar MoveColumnFeature = /** @class */ (function () {\n function MoveColumnFeature(pinned, eContainer) {\n this.needToMoveLeft = false;\n this.needToMoveRight = false;\n this.pinned = pinned;\n this.eContainer = eContainer;\n this.centerContainer = !exists(pinned);\n }\n MoveColumnFeature.prototype.init = function () {\n var _this = this;\n this.ctrlsService.whenReady(function () {\n _this.gridBodyCon = _this.ctrlsService.getGridBodyCtrl();\n });\n };\n MoveColumnFeature.prototype.getIconName = function () {\n return this.pinned ? DragAndDropService.ICON_PINNED : DragAndDropService.ICON_MOVE;\n };\n MoveColumnFeature.prototype.onDragEnter = function (draggingEvent) {\n // we do dummy drag, so make sure column appears in the right location when first placed\n var columns = draggingEvent.dragItem.columns;\n var dragCameFromToolPanel = draggingEvent.dragSource.type === DragSourceType.ToolPanel;\n if (dragCameFromToolPanel) {\n // the if statement doesn't work if drag leaves grid, then enters again\n this.setColumnsVisible(columns, true, \"uiColumnDragged\");\n }\n else {\n // restore previous state of visible columns upon re-entering. this means if the user drags\n // a group out, and then drags the group back in, only columns that were originally visible\n // will be visible again. otherwise a group with three columns (but only two visible) could\n // be dragged out, then when it's dragged in again, all three are visible. this stops that.\n var visibleState_1 = draggingEvent.dragItem.visibleState;\n var visibleColumns = (columns || []).filter(function (column) { return visibleState_1[column.getId()]; });\n this.setColumnsVisible(visibleColumns, true, \"uiColumnDragged\");\n }\n this.setColumnsPinned(columns, this.pinned, \"uiColumnDragged\");\n this.onDragging(draggingEvent, true, true);\n };\n MoveColumnFeature.prototype.onDragLeave = function (draggingEvent) {\n this.ensureIntervalCleared();\n };\n MoveColumnFeature.prototype.setColumnsVisible = function (columns, visible, source) {\n if (source === void 0) { source = \"api\"; }\n if (columns) {\n var allowedCols = columns.filter(function (c) { return !c.getColDef().lockVisible; });\n this.columnModel.setColumnsVisible(allowedCols, visible, source);\n }\n };\n MoveColumnFeature.prototype.setColumnsPinned = function (columns, pinned, source) {\n if (source === void 0) { source = \"api\"; }\n if (columns) {\n var allowedCols = columns.filter(function (c) { return !c.getColDef().lockPinned; });\n this.columnModel.setColumnsPinned(allowedCols, pinned, source);\n }\n };\n MoveColumnFeature.prototype.onDragStop = function () {\n this.ensureIntervalCleared();\n };\n MoveColumnFeature.prototype.normaliseX = function (x) {\n // flip the coordinate if doing RTL\n if (this.gridOptionsWrapper.isEnableRtl()) {\n var clientWidth = this.eContainer.clientWidth;\n x = clientWidth - x;\n }\n // adjust for scroll only if centre container (the pinned containers don't scroll)\n if (this.centerContainer) {\n x += this.ctrlsService.getCenterRowContainerCtrl().getCenterViewportScrollLeft();\n }\n return x;\n };\n MoveColumnFeature.prototype.checkCenterForScrolling = function (xAdjustedForScroll) {\n if (this.centerContainer) {\n // scroll if the mouse has gone outside the grid (or just outside the scrollable part if pinning)\n // putting in 50 buffer, so even if user gets to edge of grid, a scroll will happen\n var firstVisiblePixel = this.ctrlsService.getCenterRowContainerCtrl().getCenterViewportScrollLeft();\n var lastVisiblePixel = firstVisiblePixel + this.ctrlsService.getCenterRowContainerCtrl().getCenterWidth();\n if (this.gridOptionsWrapper.isEnableRtl()) {\n this.needToMoveRight = xAdjustedForScroll < (firstVisiblePixel + 50);\n this.needToMoveLeft = xAdjustedForScroll > (lastVisiblePixel - 50);\n }\n else {\n this.needToMoveLeft = xAdjustedForScroll < (firstVisiblePixel + 50);\n this.needToMoveRight = xAdjustedForScroll > (lastVisiblePixel - 50);\n }\n if (this.needToMoveLeft || this.needToMoveRight) {\n this.ensureIntervalStarted();\n }\n else {\n this.ensureIntervalCleared();\n }\n }\n };\n MoveColumnFeature.prototype.onDragging = function (draggingEvent, fromEnter, fakeEvent) {\n var _this = this;\n if (fromEnter === void 0) { fromEnter = false; }\n if (fakeEvent === void 0) { fakeEvent = false; }\n this.lastDraggingEvent = draggingEvent;\n // if moving up or down (ie not left or right) then do nothing\n if (missing(draggingEvent.hDirection)) {\n return;\n }\n var mouseXNormalised = this.normaliseX(draggingEvent.x);\n // if the user is dragging into the panel, ie coming from the side panel into the main grid,\n // we don't want to scroll the grid this time, it would appear like the table is jumping\n // each time a column is dragged in.\n if (!fromEnter) {\n this.checkCenterForScrolling(mouseXNormalised);\n }\n var hDirectionNormalised = this.normaliseDirection(draggingEvent.hDirection);\n var dragSourceType = draggingEvent.dragSource.type;\n var columnsToMove = draggingEvent.dragSource.getDragItem().columns;\n columnsToMove = columnsToMove.filter(function (col) {\n if (col.getColDef().lockPinned) {\n // if locked return true only if both col and container are same pin type.\n // double equals (==) here on purpose so that null==undefined is true (for not pinned options)\n return col.getPinned() == _this.pinned;\n }\n // if not pin locked, then always allowed to be in this container\n return true;\n });\n this.attemptMoveColumns(dragSourceType, columnsToMove, hDirectionNormalised, mouseXNormalised, fromEnter, fakeEvent);\n };\n MoveColumnFeature.prototype.normaliseDirection = function (hDirection) {\n if (this.gridOptionsWrapper.isEnableRtl()) {\n switch (hDirection) {\n case HorizontalDirection.Left: return HorizontalDirection.Right;\n case HorizontalDirection.Right: return HorizontalDirection.Left;\n default: console.error(\"AG Grid: Unknown direction \" + hDirection);\n }\n }\n else {\n return hDirection;\n }\n };\n // returns the index of the first column in the list ONLY if the cols are all beside\n // each other. if the cols are not beside each other, then returns null\n MoveColumnFeature.prototype.calculateOldIndex = function (movingCols) {\n var gridCols = this.columnModel.getAllGridColumns();\n var indexes = sortNumerically(movingCols.map(function (col) { return gridCols.indexOf(col); }));\n var firstIndex = indexes[0];\n var lastIndex = last(indexes);\n var spread = lastIndex - firstIndex;\n var gapsExist = spread !== indexes.length - 1;\n return gapsExist ? null : firstIndex;\n };\n MoveColumnFeature.prototype.attemptMoveColumns = function (dragSourceType, allMovingColumns, hDirection, mouseX, fromEnter, fakeEvent) {\n var draggingLeft = hDirection === HorizontalDirection.Left;\n var draggingRight = hDirection === HorizontalDirection.Right;\n if (dragSourceType === DragSourceType.HeaderCell) {\n // If the columns we're dragging are the only visible columns of their group, move the hidden ones too\n var newCols_1 = [];\n allMovingColumns.forEach(function (col) {\n var movingGroup = null;\n var parent = col.getParent();\n while (parent != null && parent.getDisplayedLeafColumns().length === 1) {\n movingGroup = parent;\n parent = parent.getParent();\n }\n if (movingGroup != null) {\n movingGroup.getLeafColumns().forEach(function (newCol) {\n if (!newCols_1.includes(newCol)) {\n newCols_1.push(newCol);\n }\n });\n }\n else if (!newCols_1.includes(col)) {\n newCols_1.push(col);\n }\n });\n allMovingColumns = newCols_1;\n }\n // it is important to sort the moving columns as they are in grid columns, as the list of moving columns\n // could themselves be part of 'married children' groups, which means we need to maintain the order within\n // the moving list.\n var allMovingColumnsOrdered = allMovingColumns.slice();\n this.columnModel.sortColumnsLikeGridColumns(allMovingColumnsOrdered);\n var validMoves = this.calculateValidMoves(allMovingColumnsOrdered, draggingRight, mouseX);\n // if cols are not adjacent, then this returns null. when moving, we constrain the direction of the move\n // (ie left or right) to the mouse direction. however\n var oldIndex = this.calculateOldIndex(allMovingColumnsOrdered);\n if (validMoves.length === 0) {\n return;\n }\n var firstValidMove = validMoves[0];\n // the two check below stop an error when the user grabs a group my a middle column, then\n // it is possible the mouse pointer is to the right of a column while been dragged left.\n // so we need to make sure that the mouse pointer is actually left of the left most column\n // if moving left, and right of the right most column if moving right\n // we check 'fromEnter' below so we move the column to the new spot if the mouse is coming from\n // outside the grid, eg if the column is moving from side panel, mouse is moving left, then we should\n // place the column to the RHS even if the mouse is moving left and the column is already on\n // the LHS. otherwise we stick to the rule described above.\n var constrainDirection = oldIndex !== null && !fromEnter;\n // don't consider 'fromEnter' when dragging header cells, otherwise group can jump to opposite direction of drag\n if (dragSourceType == DragSourceType.HeaderCell) {\n constrainDirection = oldIndex !== null;\n }\n // if the event was faked by a change in column pin state, then the original location of the column\n // is not reliable for dictating where the column may now be placed.\n if (constrainDirection && !fakeEvent) {\n // only allow left drag if this column is moving left\n if (draggingLeft && firstValidMove >= oldIndex) {\n return;\n }\n // only allow right drag if this column is moving right\n if (draggingRight && firstValidMove <= oldIndex) {\n return;\n }\n }\n // From when we find a move that passes all the rules\n // Remember what that move would look like in terms of displayed cols\n // keep going with further moves until we find a different result in displayed output\n // In this way potentialMoves contains all potential moves over 'hidden' columns\n var displayedCols = this.columnModel.getAllDisplayedColumns();\n var potentialMoves = [];\n var targetOrder = null;\n for (var i = 0; i < validMoves.length; i++) {\n var move = validMoves[i];\n var order = this.columnModel.getProposedColumnOrder(allMovingColumnsOrdered, move);\n if (!this.columnModel.doesOrderPassRules(order)) {\n continue;\n }\n var displayedOrder = order.filter(function (col) { return displayedCols.includes(col); });\n if (targetOrder === null) {\n targetOrder = displayedOrder;\n }\n else if (!_.areEqual(displayedOrder, targetOrder)) {\n break; // Stop looking for potential moves if the displayed result changes from the target\n }\n var fragCount = this.groupFragCount(order);\n potentialMoves.push({ move: move, fragCount: fragCount });\n }\n if (potentialMoves.length === 0) {\n return;\n }\n // The best move is the move with least group fragmentation\n potentialMoves.sort(function (a, b) { return a.fragCount - b.fragCount; });\n var bestMove = potentialMoves[0].move;\n this.columnModel.moveColumns(allMovingColumnsOrdered, bestMove, \"uiColumnDragged\");\n };\n // A measure of how fragmented in terms of groups an order of columns is\n MoveColumnFeature.prototype.groupFragCount = function (columns) {\n function parents(col) {\n var result = [];\n var parent = col.getOriginalParent();\n while (parent != null) {\n result.push(parent);\n parent = parent.getOriginalParent();\n }\n return result;\n }\n var count = 0;\n var _loop_1 = function (i) {\n var _a;\n var a = parents(columns[i]);\n var b = parents(columns[i + 1]);\n // iterate over the longest one\n _a = __read(a.length > b.length ? [a, b] : [b, a], 2), a = _a[0], b = _a[1];\n a.forEach(function (parent) {\n if (b.indexOf(parent) === -1) {\n count++; // More fragmented if other column doesn't share the parent\n }\n });\n };\n for (var i = 0; i < columns.length - 1; i++) {\n _loop_1(i);\n }\n return count;\n };\n MoveColumnFeature.prototype.calculateValidMoves = function (movingCols, draggingRight, mouseX) {\n var isMoveBlocked = this.gridOptionsWrapper.isSuppressMovableColumns() || movingCols.some(function (col) { return col.getColDef().suppressMovable; });\n if (isMoveBlocked) {\n return [];\n }\n // this is the list of cols on the screen, so it's these we use when comparing the x mouse position\n var allDisplayedCols = this.columnModel.getDisplayedColumns(this.pinned);\n // but this list is the list of all cols, when we move a col it's the index within this list that gets used,\n // so the result we return has to be and index location for this list\n var allGridCols = this.columnModel.getAllGridColumns();\n var movingDisplayedCols = allDisplayedCols.filter(function (col) { return includes(movingCols, col); });\n var otherDisplayedCols = allDisplayedCols.filter(function (col) { return !includes(movingCols, col); });\n var otherGridCols = allGridCols.filter(function (col) { return !includes(movingCols, col); });\n // work out how many DISPLAYED columns fit before the 'x' position. this gives us the displayIndex.\n // for example, if cols are a,b,c,d and we find a,b fit before 'x', then we want to place the moving\n // col between b and c (so that it is under the mouse position).\n var displayIndex = 0;\n var availableWidth = mouseX;\n // if we are dragging right, then the columns will be to the left of the mouse, so we also want to\n // include the width of the moving columns\n if (draggingRight) {\n var widthOfMovingDisplayedCols_1 = 0;\n movingDisplayedCols.forEach(function (col) { return widthOfMovingDisplayedCols_1 += col.getActualWidth(); });\n availableWidth -= widthOfMovingDisplayedCols_1;\n }\n if (availableWidth > 0) {\n // now count how many of the displayed columns will fit to the left\n for (var i = 0; i < otherDisplayedCols.length; i++) {\n var col = otherDisplayedCols[i];\n availableWidth -= col.getActualWidth();\n if (availableWidth < 0) {\n break;\n }\n displayIndex++;\n }\n // trial and error, if going right, we adjust by one, i didn't manage to quantify why, but it works\n if (draggingRight) {\n displayIndex++;\n }\n }\n // the display index is with respect to all the showing columns, however when we move, it's with\n // respect to all grid columns, so we need to translate from display index to grid index\n var firstValidMove;\n if (displayIndex > 0) {\n var leftColumn = otherDisplayedCols[displayIndex - 1];\n firstValidMove = otherGridCols.indexOf(leftColumn) + 1;\n }\n else {\n firstValidMove = otherGridCols.indexOf(otherDisplayedCols[0]);\n if (firstValidMove === -1) {\n firstValidMove = 0;\n }\n }\n var validMoves = [firstValidMove];\n var numberComparator = function (a, b) { return a - b; };\n // add in other valid moves due to hidden columns and married children. for example, a particular\n // move might break a group that has married children (so move isn't valid), however there could\n // be hidden columns (not displayed) that we could jump over to make the move valid. because\n // they are hidden, user doesn't see any different, however it allows moves that would otherwise\n // not work. for example imagine a group with 9 columns and all columns are hidden except the\n // middle one (so 4 hidden to left, 4 hidden to right), then when moving 'firstValidMove' will\n // be relative to the not-shown column, however we need to consider the move jumping over all the\n // hidden children. if we didn't do this, then if the group just described was at the end (RHS) of the\n // grid, there would be no way to put a column after it (as the grid would only consider beside the\n // visible column, which would fail valid move rules).\n if (draggingRight) {\n // if dragging right, then we add all the additional moves to the right. so in other words\n // if the next move is not valid, find the next move to the right that is valid.\n var pointer = firstValidMove + 1;\n var lastIndex = allGridCols.length - 1;\n while (pointer <= lastIndex) {\n validMoves.push(pointer);\n pointer++;\n }\n // adding columns here means the order is now messed up\n validMoves.sort(numberComparator);\n }\n else {\n // if dragging left we do the reverse of dragging right, we add in all the valid moves to the\n // left. however we also have to consider moves to the right for all hidden columns first.\n // (this logic is hard to reason with, it was worked out with trial and error,\n // more observation rather than science).\n // add moves to the right\n var pointer = firstValidMove;\n var lastIndex = allGridCols.length - 1;\n var displacedCol = allGridCols[pointer];\n while (pointer <= lastIndex && this.isColumnHidden(allDisplayedCols, displacedCol)) {\n pointer++;\n validMoves.push(pointer);\n displacedCol = allGridCols[pointer];\n }\n // add moves to the left\n pointer = firstValidMove - 1;\n var firstDisplayIndex = 0;\n while (pointer >= firstDisplayIndex) {\n validMoves.push(pointer);\n pointer--;\n }\n // adding columns here means the order is now messed up\n validMoves.sort(numberComparator).reverse();\n }\n return validMoves;\n };\n // isHidden takes into account visible=false and group=closed, ie it is not displayed\n MoveColumnFeature.prototype.isColumnHidden = function (displayedColumns, col) {\n return displayedColumns.indexOf(col) < 0;\n };\n MoveColumnFeature.prototype.ensureIntervalStarted = function () {\n if (!this.movingIntervalId) {\n this.intervalCount = 0;\n this.failedMoveAttempts = 0;\n this.movingIntervalId = window.setInterval(this.moveInterval.bind(this), 100);\n if (this.needToMoveLeft) {\n this.dragAndDropService.setGhostIcon(DragAndDropService.ICON_LEFT, true);\n }\n else {\n this.dragAndDropService.setGhostIcon(DragAndDropService.ICON_RIGHT, true);\n }\n }\n };\n MoveColumnFeature.prototype.ensureIntervalCleared = function () {\n if (this.movingIntervalId) {\n window.clearInterval(this.movingIntervalId);\n this.movingIntervalId = null;\n this.dragAndDropService.setGhostIcon(DragAndDropService.ICON_MOVE);\n }\n };\n MoveColumnFeature.prototype.moveInterval = function () {\n // the amounts we move get bigger at each interval, so the speed accelerates, starting a bit slow\n // and getting faster. this is to give smoother user experience. we max at 100px to limit the speed.\n var pixelsToMove;\n this.intervalCount++;\n pixelsToMove = 10 + (this.intervalCount * 5);\n if (pixelsToMove > 100) {\n pixelsToMove = 100;\n }\n var pixelsMoved = null;\n var scrollFeature = this.gridBodyCon.getScrollFeature();\n if (this.needToMoveLeft) {\n pixelsMoved = scrollFeature.scrollHorizontally(-pixelsToMove);\n }\n else if (this.needToMoveRight) {\n pixelsMoved = scrollFeature.scrollHorizontally(pixelsToMove);\n }\n if (pixelsMoved !== 0) {\n this.onDragging(this.lastDraggingEvent);\n this.failedMoveAttempts = 0;\n }\n else {\n // we count the failed move attempts. if we fail to move 7 times, then we pin the column.\n // this is how we achieve pining by dragging the column to the edge of the grid.\n this.failedMoveAttempts++;\n var columns = this.lastDraggingEvent.dragItem.columns;\n var columnsThatCanPin = columns.filter(function (c) { return !c.getColDef().lockPinned; });\n if (columnsThatCanPin.length > 0) {\n this.dragAndDropService.setGhostIcon(DragAndDropService.ICON_PINNED);\n if (this.failedMoveAttempts > 7) {\n var pinType = this.needToMoveLeft ? Constants.PINNED_LEFT : Constants.PINNED_RIGHT;\n this.setColumnsPinned(columnsThatCanPin, pinType, \"uiColumnDragged\");\n this.dragAndDropService.nudge();\n }\n }\n }\n };\n __decorate([\n Autowired('columnModel')\n ], MoveColumnFeature.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('dragAndDropService')\n ], MoveColumnFeature.prototype, \"dragAndDropService\", void 0);\n __decorate([\n Autowired('gridOptionsWrapper')\n ], MoveColumnFeature.prototype, \"gridOptionsWrapper\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], MoveColumnFeature.prototype, \"ctrlsService\", void 0);\n __decorate([\n PostConstruct\n ], MoveColumnFeature.prototype, \"init\", null);\n return MoveColumnFeature;\n}());\nexport { MoveColumnFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { DragSourceType } from \"../../dragAndDrop/dragAndDropService\";\nimport { Autowired, PostConstruct } from \"../../context/context\";\nimport { MoveColumnFeature } from \"./moveColumnFeature\";\nimport { BodyDropPivotTarget } from \"./bodyDropPivotTarget\";\nimport { Constants } from \"../../constants/constants\";\nimport { BeanStub } from \"../../context/beanStub\";\nvar BodyDropTarget = /** @class */ (function (_super) {\n __extends(BodyDropTarget, _super);\n function BodyDropTarget(pinned, eContainer) {\n var _this = _super.call(this) || this;\n _this.pinned = pinned;\n _this.eContainer = eContainer;\n return _this;\n }\n BodyDropTarget.prototype.postConstruct = function () {\n var _this = this;\n this.ctrlsService.whenReady(function (p) {\n switch (_this.pinned) {\n case Constants.PINNED_LEFT:\n _this.eSecondaryContainers = [\n [p.gridBodyCtrl.getBodyViewportElement(), p.leftRowContainerCtrl.getContainerElement()],\n [p.bottomLeftRowContainerCtrl.getContainerElement()],\n [p.topLeftRowContainerCtrl.getContainerElement()]\n ];\n break;\n case Constants.PINNED_RIGHT:\n _this.eSecondaryContainers = [\n [p.gridBodyCtrl.getBodyViewportElement(), p.rightRowContainerCtrl.getContainerElement()],\n [p.bottomRightRowContainerCtrl.getContainerElement()],\n [p.topRightRowContainerCtrl.getContainerElement()]\n ];\n break;\n default:\n _this.eSecondaryContainers = [\n [p.gridBodyCtrl.getBodyViewportElement(), p.centerRowContainerCtrl.getViewportElement()],\n [p.bottomCenterRowContainerCtrl.getViewportElement()],\n [p.topCenterRowContainerCtrl.getViewportElement()]\n ];\n break;\n }\n });\n };\n BodyDropTarget.prototype.isInterestedIn = function (type) {\n return type === DragSourceType.HeaderCell ||\n (type === DragSourceType.ToolPanel && this.gridOptionsWrapper.isAllowDragFromColumnsToolPanel());\n };\n BodyDropTarget.prototype.getSecondaryContainers = function () {\n return this.eSecondaryContainers;\n };\n BodyDropTarget.prototype.getContainer = function () {\n return this.eContainer;\n };\n BodyDropTarget.prototype.init = function () {\n this.moveColumnFeature = this.createManagedBean(new MoveColumnFeature(this.pinned, this.eContainer));\n this.bodyDropPivotTarget = this.createManagedBean(new BodyDropPivotTarget(this.pinned));\n this.dragAndDropService.addDropTarget(this);\n };\n BodyDropTarget.prototype.getIconName = function () {\n return this.currentDropListener.getIconName();\n };\n // we want to use the bodyPivotTarget if the user is dragging columns in from the toolPanel\n // and we are in pivot mode, as it has to logic to set pivot/value/group on the columns when\n // dropped into the grid's body.\n BodyDropTarget.prototype.isDropColumnInPivotMode = function (draggingEvent) {\n // in pivot mode, then if moving a column (ie didn't come from toolpanel) then it's\n // a standard column move, however if it came from the toolpanel, then we are introducing\n // dimensions or values to the grid\n return this.columnModel.isPivotMode() && draggingEvent.dragSource.type === DragSourceType.ToolPanel;\n };\n BodyDropTarget.prototype.onDragEnter = function (draggingEvent) {\n // we pick the drop listener depending on whether we are in pivot mode are not. if we are\n // in pivot mode, then dropping cols changes the row group, pivot, value stats. otherwise\n // we change visibility state and position.\n this.currentDropListener = this.isDropColumnInPivotMode(draggingEvent) ? this.bodyDropPivotTarget : this.moveColumnFeature;\n this.currentDropListener.onDragEnter(draggingEvent);\n };\n BodyDropTarget.prototype.onDragLeave = function (params) {\n this.currentDropListener.onDragLeave(params);\n };\n BodyDropTarget.prototype.onDragging = function (params) {\n this.currentDropListener.onDragging(params);\n };\n BodyDropTarget.prototype.onDragStop = function (params) {\n this.currentDropListener.onDragStop(params);\n };\n __decorate([\n Autowired('dragAndDropService')\n ], BodyDropTarget.prototype, \"dragAndDropService\", void 0);\n __decorate([\n Autowired('columnModel')\n ], BodyDropTarget.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], BodyDropTarget.prototype, \"ctrlsService\", void 0);\n __decorate([\n PostConstruct\n ], BodyDropTarget.prototype, \"postConstruct\", null);\n __decorate([\n PostConstruct\n ], BodyDropTarget.prototype, \"init\", null);\n return BodyDropTarget;\n}(BeanStub));\nexport { BodyDropTarget };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nimport { missing } from \"../../utils/generic\";\nvar CssClassApplier = /** @class */ (function () {\n function CssClassApplier() {\n }\n CssClassApplier.getHeaderClassesFromColDef = function (abstractColDef, gridOptionsWrapper, column, columnGroup) {\n if (missing(abstractColDef)) {\n return [];\n }\n return this.getColumnClassesFromCollDef(abstractColDef.headerClass, abstractColDef, gridOptionsWrapper, column, columnGroup);\n };\n CssClassApplier.getToolPanelClassesFromColDef = function (abstractColDef, gridOptionsWrapper, column, columnGroup) {\n if (missing(abstractColDef)) {\n return [];\n }\n return this.getColumnClassesFromCollDef(abstractColDef.toolPanelClass, abstractColDef, gridOptionsWrapper, column, columnGroup);\n };\n CssClassApplier.getClassParams = function (abstractColDef, gridOptionsWrapper, column, columnGroup) {\n return {\n // bad naming, as colDef here can be a group or a column,\n // however most people won't appreciate the difference,\n // so keeping it as colDef to avoid confusion.\n colDef: abstractColDef,\n column: column,\n columnGroup: columnGroup,\n api: gridOptionsWrapper.getApi(),\n columnApi: gridOptionsWrapper.getColumnApi(),\n context: gridOptionsWrapper.getContext()\n };\n };\n CssClassApplier.getColumnClassesFromCollDef = function (classesOrFunc, abstractColDef, gridOptionsWrapper, column, columnGroup) {\n if (missing(classesOrFunc)) {\n return [];\n }\n var classToUse;\n if (typeof classesOrFunc === 'function') {\n var params = this.getClassParams(abstractColDef, gridOptionsWrapper, column, columnGroup);\n classToUse = classesOrFunc(params);\n }\n else {\n classToUse = classesOrFunc;\n }\n if (typeof classToUse === 'string') {\n return [classToUse];\n }\n if (Array.isArray(classToUse)) {\n return __spread(classToUse);\n }\n return [];\n };\n return CssClassApplier;\n}());\nexport { CssClassApplier };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PostConstruct, PreDestroy } from \"../../../context/context\";\nimport { removeAriaSort, setAriaDescription, setAriaSort } from \"../../../utils/aria\";\nimport { RefSelector } from \"../../../widgets/componentAnnotations\";\nimport { AbstractHeaderCellComp } from \"../abstractCell/abstractHeaderCellComp\";\nvar HeaderCellComp = /** @class */ (function (_super) {\n __extends(HeaderCellComp, _super);\n function HeaderCellComp(ctrl) {\n var _this = _super.call(this, HeaderCellComp.TEMPLATE, ctrl) || this;\n _this.headerCompVersion = 0;\n _this.column = ctrl.getColumnGroupChild();\n _this.pinned = ctrl.getPinned();\n return _this;\n }\n HeaderCellComp.prototype.postConstruct = function () {\n var _this = this;\n var eGui = this.getGui();\n var setAttribute = function (name, value, element) {\n var actualElement = element ? element : eGui;\n if (value != null && value != '') {\n actualElement.setAttribute(name, value);\n }\n else {\n actualElement.removeAttribute(name);\n }\n };\n var compProxy = {\n setWidth: function (width) { return eGui.style.width = width; },\n addOrRemoveCssClass: function (cssClassName, on) { return _this.addOrRemoveCssClass(cssClassName, on); },\n setColId: function (id) { return setAttribute('col-id', id); },\n setTitle: function (title) { return setAttribute('title', title); },\n setAriaDescription: function (label) { return setAriaDescription(eGui, label); },\n setAriaSort: function (sort) { return sort ? setAriaSort(eGui, sort) : removeAriaSort(eGui); },\n setUserCompDetails: function (compDetails) { return _this.setUserCompDetails(compDetails); },\n getUserCompInstance: function () { return _this.headerComp; }\n };\n this.ctrl.setComp(compProxy, this.getGui(), this.eResize, this.eHeaderCompWrapper);\n var selectAllGui = this.ctrl.getSelectAllGui();\n this.eResize.insertAdjacentElement('afterend', selectAllGui);\n };\n HeaderCellComp.prototype.destroyHeaderComp = function () {\n if (this.headerComp) {\n this.eHeaderCompWrapper.removeChild(this.headerCompGui);\n this.headerComp = this.destroyBean(this.headerComp);\n this.headerCompGui = undefined;\n }\n };\n HeaderCellComp.prototype.setUserCompDetails = function (compDetails) {\n var _this = this;\n this.headerCompVersion++;\n var versionCopy = this.headerCompVersion;\n compDetails.newAgStackInstance().then(function (comp) { return _this.afterCompCreated(versionCopy, comp); });\n };\n HeaderCellComp.prototype.afterCompCreated = function (version, headerComp) {\n if (version != this.headerCompVersion || !this.isAlive()) {\n this.destroyBean(headerComp);\n return;\n }\n this.destroyHeaderComp();\n this.headerComp = headerComp;\n this.headerCompGui = headerComp.getGui();\n this.eHeaderCompWrapper.appendChild(this.headerCompGui);\n this.ctrl.setDragSource(this.getGui());\n };\n HeaderCellComp.TEMPLATE = \"
\\n
\\n
\\n
\";\n __decorate([\n RefSelector('eResize')\n ], HeaderCellComp.prototype, \"eResize\", void 0);\n __decorate([\n RefSelector('eHeaderCompWrapper')\n ], HeaderCellComp.prototype, \"eHeaderCompWrapper\", void 0);\n __decorate([\n PostConstruct\n ], HeaderCellComp.prototype, \"postConstruct\", null);\n __decorate([\n PreDestroy\n ], HeaderCellComp.prototype, \"destroyHeaderComp\", null);\n return HeaderCellComp;\n}(AbstractHeaderCellComp));\nexport { HeaderCellComp };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from \"../../../context/context\";\nimport { RefSelector } from \"../../../widgets/componentAnnotations\";\nimport { AbstractHeaderCellComp } from \"../abstractCell/abstractHeaderCellComp\";\nvar HeaderGroupCellComp = /** @class */ (function (_super) {\n __extends(HeaderGroupCellComp, _super);\n function HeaderGroupCellComp(ctrl) {\n return _super.call(this, HeaderGroupCellComp.TEMPLATE, ctrl) || this;\n }\n HeaderGroupCellComp.prototype.postConstruct = function () {\n var _this = this;\n var eGui = this.getGui();\n var setAttribute = function (key, value) {\n return value != undefined ? eGui.setAttribute(key, value) : eGui.removeAttribute(key);\n };\n var compProxy = {\n addOrRemoveCssClass: function (cssClassName, on) { return _this.addOrRemoveCssClass(cssClassName, on); },\n addOrRemoveResizableCssClass: function (cssClassName, on) { return _this.eResize.classList.toggle(cssClassName, on); },\n setWidth: function (width) { return eGui.style.width = width; },\n setColId: function (id) { return eGui.setAttribute(\"col-id\", id); },\n setAriaExpanded: function (expanded) { return setAttribute('aria-expanded', expanded); },\n setTitle: function (title) { return setAttribute(\"title\", title); },\n setUserCompDetails: function (details) { return _this.setUserCompDetails(details); }\n };\n this.ctrl.setComp(compProxy, eGui, this.eResize);\n };\n HeaderGroupCellComp.prototype.setUserCompDetails = function (details) {\n var _this = this;\n details.newAgStackInstance().then(function (comp) { return _this.afterHeaderCompCreated(comp); });\n };\n HeaderGroupCellComp.prototype.afterHeaderCompCreated = function (headerGroupComp) {\n var _this = this;\n var destroyFunc = function () { return _this.destroyBean(headerGroupComp); };\n if (!this.isAlive()) {\n destroyFunc();\n return;\n }\n this.getGui().appendChild(headerGroupComp.getGui());\n this.addDestroyFunc(destroyFunc);\n this.ctrl.setDragSource(headerGroupComp.getGui());\n };\n HeaderGroupCellComp.TEMPLATE = \"
\\n
\\n
\";\n __decorate([\n Autowired('userComponentFactory')\n ], HeaderGroupCellComp.prototype, \"userComponentFactory\", void 0);\n __decorate([\n RefSelector('eResize')\n ], HeaderGroupCellComp.prototype, \"eResize\", void 0);\n __decorate([\n PostConstruct\n ], HeaderGroupCellComp.prototype, \"postConstruct\", null);\n return HeaderGroupCellComp;\n}(AbstractHeaderCellComp));\nexport { HeaderGroupCellComp };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PostConstruct, PreDestroy } from '../../context/context';\nimport { setAriaRowIndex } from '../../utils/aria';\nimport { setDomChildOrder } from '../../utils/dom';\nimport { getAllValuesInObject, iterateObject } from '../../utils/object';\nimport { Component } from '../../widgets/component';\nimport { HeaderCellComp } from '../cells/column/headerCellComp';\nimport { HeaderGroupCellComp } from '../cells/columnGroup/headerGroupCellComp';\nimport { HeaderFilterCellComp } from '../cells/floatingFilter/headerFilterCellComp';\nexport var HeaderRowType;\n(function (HeaderRowType) {\n HeaderRowType[\"COLUMN_GROUP\"] = \"group\";\n HeaderRowType[\"COLUMN\"] = \"column\";\n HeaderRowType[\"FLOATING_FILTER\"] = \"filter\";\n})(HeaderRowType || (HeaderRowType = {}));\nvar HeaderRowComp = /** @class */ (function (_super) {\n __extends(HeaderRowComp, _super);\n function HeaderRowComp(ctrl) {\n var _this = _super.call(this) || this;\n _this.headerComps = {};\n var extraClass = ctrl.getType() == HeaderRowType.COLUMN_GROUP ? \"ag-header-row-column-group\" :\n ctrl.getType() == HeaderRowType.FLOATING_FILTER ? \"ag-header-row-column-filter\" : \"ag-header-row-column\";\n _this.setTemplate(/* html */ \"
\");\n _this.ctrl = ctrl;\n return _this;\n }\n //noinspection JSUnusedLocalSymbols\n HeaderRowComp.prototype.init = function () {\n var _this = this;\n var compProxy = {\n setTransform: function (transform) { return _this.getGui().style.transform = transform; },\n setHeight: function (height) { return _this.getGui().style.height = height; },\n setTop: function (top) { return _this.getGui().style.top = top; },\n setHeaderCtrls: function (ctrls) { return _this.setHeaderCtrls(ctrls); },\n setWidth: function (width) { return _this.getGui().style.width = width; },\n setAriaRowIndex: function (rowIndex) { return setAriaRowIndex(_this.getGui(), rowIndex); }\n };\n this.ctrl.setComp(compProxy);\n };\n HeaderRowComp.prototype.destroyHeaderCtrls = function () {\n this.setHeaderCtrls([]);\n };\n HeaderRowComp.prototype.setHeaderCtrls = function (ctrls) {\n var _this = this;\n if (!this.isAlive()) {\n return;\n }\n var oldComps = this.headerComps;\n this.headerComps = {};\n ctrls.forEach(function (ctrl) {\n var id = ctrl.getInstanceId();\n var comp = oldComps[id];\n delete oldComps[id];\n if (comp == null) {\n comp = _this.createHeaderComp(ctrl);\n _this.getGui().appendChild(comp.getGui());\n }\n _this.headerComps[id] = comp;\n });\n iterateObject(oldComps, function (id, comp) {\n _this.getGui().removeChild(comp.getGui());\n _this.destroyBean(comp);\n });\n var ensureDomOrder = this.gridOptionsWrapper.isEnsureDomOrder();\n if (ensureDomOrder) {\n var comps = getAllValuesInObject(this.headerComps);\n // ordering the columns by left position orders them in the order they appear on the screen\n comps.sort(function (a, b) {\n var leftA = a.getCtrl().getColumnGroupChild().getLeft();\n var leftB = b.getCtrl().getColumnGroupChild().getLeft();\n return leftA - leftB;\n });\n var elementsInOrder = comps.map(function (c) { return c.getGui(); });\n setDomChildOrder(this.getGui(), elementsInOrder);\n }\n };\n HeaderRowComp.prototype.createHeaderComp = function (headerCtrl) {\n var result;\n switch (this.ctrl.getType()) {\n case HeaderRowType.COLUMN_GROUP:\n result = new HeaderGroupCellComp(headerCtrl);\n break;\n case HeaderRowType.FLOATING_FILTER:\n result = new HeaderFilterCellComp(headerCtrl);\n break;\n default:\n result = new HeaderCellComp(headerCtrl);\n break;\n }\n this.createBean(result);\n result.setParentComponent(this);\n return result;\n };\n __decorate([\n PostConstruct\n ], HeaderRowComp.prototype, \"init\", null);\n __decorate([\n PreDestroy\n ], HeaderRowComp.prototype, \"destroyHeaderCtrls\", null);\n return HeaderRowComp;\n}(Component));\nexport { HeaderRowComp };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../../context/beanStub\";\nimport { Autowired } from \"../../../context/context\";\nimport { isUserSuppressingHeaderKeyboardEvent } from \"../../../utils/keyboard\";\nimport { KeyCode } from \"../.././../constants/keyCode\";\nvar instanceIdSequence = 0;\nvar AbstractHeaderCellCtrl = /** @class */ (function (_super) {\n __extends(AbstractHeaderCellCtrl, _super);\n function AbstractHeaderCellCtrl(columnGroupChild, parentRowCtrl) {\n var _this = _super.call(this) || this;\n _this.lastFocusEvent = null;\n _this.columnGroupChild = columnGroupChild;\n _this.parentRowCtrl = parentRowCtrl;\n // unique id to this instance, including the column ID to help with debugging in React as it's used in 'key'\n _this.instanceId = columnGroupChild.getUniqueId() + '-' + instanceIdSequence++;\n return _this;\n }\n AbstractHeaderCellCtrl.prototype.shouldStopEventPropagation = function (e) {\n var _a = this.focusService.getFocusedHeader(), headerRowIndex = _a.headerRowIndex, column = _a.column;\n return isUserSuppressingHeaderKeyboardEvent(this.gridOptionsWrapper, e, headerRowIndex, column);\n };\n AbstractHeaderCellCtrl.prototype.getWrapperHasFocus = function () {\n var eDocument = this.gridOptionsWrapper.getDocument();\n var activeEl = eDocument.activeElement;\n return activeEl === this.eGui;\n };\n AbstractHeaderCellCtrl.prototype.setGui = function (eGui) {\n this.eGui = eGui;\n this.addDomData();\n };\n AbstractHeaderCellCtrl.prototype.handleKeyDown = function (e) {\n var wrapperHasFocus = this.getWrapperHasFocus();\n switch (e.key) {\n case KeyCode.PAGE_DOWN:\n case KeyCode.PAGE_UP:\n case KeyCode.PAGE_HOME:\n case KeyCode.PAGE_END:\n if (wrapperHasFocus) {\n e.preventDefault();\n }\n }\n };\n AbstractHeaderCellCtrl.prototype.addDomData = function () {\n var _this = this;\n var key = AbstractHeaderCellCtrl.DOM_DATA_KEY_HEADER_CTRL;\n this.gridOptionsWrapper.setDomData(this.eGui, key, this);\n this.addDestroyFunc(function () { return _this.gridOptionsWrapper.setDomData(_this.eGui, key, null); });\n };\n AbstractHeaderCellCtrl.prototype.getGui = function () {\n return this.eGui;\n };\n AbstractHeaderCellCtrl.prototype.focus = function (event) {\n if (!this.eGui) {\n return false;\n }\n this.lastFocusEvent = event || null;\n this.eGui.focus();\n return true;\n };\n AbstractHeaderCellCtrl.prototype.getRowIndex = function () {\n return this.parentRowCtrl.getRowIndex();\n };\n AbstractHeaderCellCtrl.prototype.getParentRowCtrl = function () {\n return this.parentRowCtrl;\n };\n AbstractHeaderCellCtrl.prototype.getPinned = function () {\n return this.parentRowCtrl.getPinned();\n };\n AbstractHeaderCellCtrl.prototype.getInstanceId = function () {\n return this.instanceId;\n };\n AbstractHeaderCellCtrl.prototype.getColumnGroupChild = function () {\n return this.columnGroupChild;\n };\n AbstractHeaderCellCtrl.DOM_DATA_KEY_HEADER_CTRL = 'headerCtrl';\n __decorate([\n Autowired('focusService')\n ], AbstractHeaderCellCtrl.prototype, \"focusService\", void 0);\n __decorate([\n Autowired('beans')\n ], AbstractHeaderCellCtrl.prototype, \"beans\", void 0);\n __decorate([\n Autowired('userComponentFactory')\n ], AbstractHeaderCellCtrl.prototype, \"userComponentFactory\", void 0);\n return AbstractHeaderCellCtrl;\n}(BeanStub));\nexport { AbstractHeaderCellCtrl };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nexport var ClientSideRowModelSteps;\n(function (ClientSideRowModelSteps) {\n ClientSideRowModelSteps[\"EVERYTHING\"] = \"group\";\n ClientSideRowModelSteps[\"FILTER\"] = \"filter\";\n ClientSideRowModelSteps[\"SORT\"] = \"sort\";\n ClientSideRowModelSteps[\"MAP\"] = \"map\";\n ClientSideRowModelSteps[\"AGGREGATE\"] = \"aggregate\";\n ClientSideRowModelSteps[\"FILTER_AGGREGATES\"] = \"filter_aggregates\";\n ClientSideRowModelSteps[\"PIVOT\"] = \"pivot\";\n ClientSideRowModelSteps[\"NOTHING\"] = \"nothing\";\n})(ClientSideRowModelSteps || (ClientSideRowModelSteps = {}));\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Constants } from \"./constants/constants\";\nimport { Autowired, Bean, Optional, PostConstruct, PreDestroy } from \"./context/context\";\nimport { SideBarDefParser } from \"./entities/sideBar\";\nimport { GridOptionsWrapper } from \"./gridOptionsWrapper\";\nimport { ClientSideRowModelSteps } from \"./interfaces/iClientSideRowModel\";\nimport { ExcelFactoryMode } from \"./interfaces/iExcelCreator\";\nimport { ModuleNames } from \"./modules/moduleNames\";\nimport { ModuleRegistry } from \"./modules/moduleRegistry\";\nimport { doOnce } from \"./utils/function\";\nimport { exists, missing } from \"./utils/generic\";\nimport { iterateObject, removeAllReferences } from \"./utils/object\";\nimport { camelCaseToHumanText } from \"./utils/string\";\nexport function unwrapUserComp(comp) {\n var compAsAny = comp;\n var isProxy = compAsAny != null && compAsAny.getFrameworkComponentInstance != null;\n return isProxy ? compAsAny.getFrameworkComponentInstance() : comp;\n}\nvar GridApi = /** @class */ (function () {\n function GridApi() {\n this.detailGridInfoMap = {};\n this.destroyCalled = false;\n }\n GridApi.prototype.registerOverlayWrapperComp = function (overlayWrapperComp) {\n this.overlayWrapperComp = overlayWrapperComp;\n };\n GridApi.prototype.registerSideBarComp = function (sideBarComp) {\n this.sideBarComp = sideBarComp;\n };\n GridApi.prototype.init = function () {\n var _this = this;\n switch (this.rowModel.getType()) {\n case Constants.ROW_MODEL_TYPE_CLIENT_SIDE:\n this.clientSideRowModel = this.rowModel;\n break;\n case Constants.ROW_MODEL_TYPE_INFINITE:\n this.infiniteRowModel = this.rowModel;\n break;\n case Constants.ROW_MODEL_TYPE_SERVER_SIDE:\n this.serverSideRowModel = this.rowModel;\n break;\n }\n this.ctrlsService.whenReady(function () {\n _this.gridBodyCtrl = _this.ctrlsService.getGridBodyCtrl();\n });\n };\n /** Used internally by grid. Not intended to be used by the client. Interface may change between releases. */\n GridApi.prototype.__getAlignedGridService = function () {\n return this.alignedGridsService;\n };\n /** Used internally by grid. Not intended to be used by the client. Interface may change between releases. */\n GridApi.prototype.__getContext = function () {\n return this.context;\n };\n /** Register a detail grid with the master grid when it is created. */\n GridApi.prototype.addDetailGridInfo = function (id, gridInfo) {\n this.detailGridInfoMap[id] = gridInfo;\n };\n /** Unregister a detail grid from the master grid when it is destroyed. */\n GridApi.prototype.removeDetailGridInfo = function (id) {\n this.detailGridInfoMap[id] = undefined;\n };\n /** Returns the `DetailGridInfo` corresponding to the supplied `detailGridId`. */\n GridApi.prototype.getDetailGridInfo = function (id) {\n return this.detailGridInfoMap[id];\n };\n /** Iterates through each `DetailGridInfo` in the grid and calls the supplied callback on each. */\n GridApi.prototype.forEachDetailGridInfo = function (callback) {\n var index = 0;\n iterateObject(this.detailGridInfoMap, function (id, gridInfo) {\n // check for undefined, as old references will still be lying around\n if (exists(gridInfo)) {\n callback(gridInfo, index);\n index++;\n }\n });\n };\n /** Similar to `exportDataAsCsv`, except returns the result as a string rather than download it. */\n GridApi.prototype.getDataAsCsv = function (params) {\n if (ModuleRegistry.assertRegistered(ModuleNames.CsvExportModule, 'api.getDataAsCsv')) {\n return this.csvCreator.getDataAsCsv(params);\n }\n };\n /** Downloads a CSV export of the grid's data. */\n GridApi.prototype.exportDataAsCsv = function (params) {\n if (ModuleRegistry.assertRegistered(ModuleNames.CsvExportModule, 'api.exportDataAsCSv')) {\n this.csvCreator.exportDataAsCsv(params);\n }\n };\n GridApi.prototype.getExcelExportMode = function (params) {\n var baseParams = this.gridOptionsWrapper.getDefaultExportParams('excel');\n var mergedParams = Object.assign({ exportMode: 'xlsx' }, baseParams, params);\n return mergedParams.exportMode;\n };\n /** Similar to `exportDataAsExcel`, except instead of downloading a file, it will return a [Blob](https://developer.mozilla.org/en-US/docs/Web/API/Blob) to be processed by the user. */\n GridApi.prototype.getDataAsExcel = function (params) {\n if (!ModuleRegistry.assertRegistered(ModuleNames.ExcelExportModule, 'api.getDataAsExcel')) {\n return;\n }\n var exportMode = this.getExcelExportMode(params);\n if (this.excelCreator.getFactoryMode(exportMode) === ExcelFactoryMode.MULTI_SHEET) {\n console.warn('AG Grid: The Excel Exporter is currently on Multi Sheet mode. End that operation by calling `api.getMultipleSheetAsExcel()` or `api.exportMultipleSheetsAsExcel()`');\n return;\n }\n return this.excelCreator.getDataAsExcel(params);\n };\n /** Downloads an Excel export of the grid's data. */\n GridApi.prototype.exportDataAsExcel = function (params) {\n if (!ModuleRegistry.assertRegistered(ModuleNames.ExcelExportModule, 'api.exportDataAsExcel')) {\n return;\n }\n var exportMode = this.getExcelExportMode(params);\n if (this.excelCreator.getFactoryMode(exportMode) === ExcelFactoryMode.MULTI_SHEET) {\n console.warn('AG Grid: The Excel Exporter is currently on Multi Sheet mode. End that operation by calling `api.getMultipleSheetAsExcel()` or `api.exportMultipleSheetsAsExcel()`');\n return;\n }\n this.excelCreator.exportDataAsExcel(params);\n };\n /** This is method to be used to get the grid's data as a sheet, that will later be exported either by `getMultipleSheetsAsExcel()` or `exportMultipleSheetsAsExcel()`. */\n GridApi.prototype.getSheetDataForExcel = function (params) {\n if (!ModuleRegistry.assertRegistered(ModuleNames.ExcelExportModule, 'api.getSheetDataForExcel')) {\n return;\n }\n var exportMode = this.getExcelExportMode(params);\n this.excelCreator.setFactoryMode(ExcelFactoryMode.MULTI_SHEET, exportMode);\n return this.excelCreator.getSheetDataForExcel(params);\n };\n /** Similar to `exportMultipleSheetsAsExcel`, except instead of downloading a file, it will return a [Blob](https://developer.mozilla.org/en-US/docs/Web/API/Blob) to be processed by the user. */\n GridApi.prototype.getMultipleSheetsAsExcel = function (params) {\n if (ModuleRegistry.assertRegistered(ModuleNames.ExcelExportModule, 'api.getMultipleSheetsAsExcel')) {\n return this.excelCreator.getMultipleSheetsAsExcel(params);\n }\n };\n /** Downloads an Excel export of multiple sheets in one file. */\n GridApi.prototype.exportMultipleSheetsAsExcel = function (params) {\n if (ModuleRegistry.assertRegistered(ModuleNames.ExcelExportModule, 'api.exportMultipleSheetsAsExcel')) {\n return this.excelCreator.exportMultipleSheetsAsExcel(params);\n }\n };\n /** @deprecated */\n GridApi.prototype.setEnterpriseDatasource = function (datasource) {\n console.warn(\"AG Grid: since version 18.x, api.setEnterpriseDatasource() should be replaced with api.setServerSideDatasource()\");\n this.setServerSideDatasource(datasource);\n };\n /**\n * Sets an ARIA property in the grid panel (element with `role=\\\"grid\\\"`), and removes an ARIA property when the value is null.\n *\n * Example: `api.setGridAriaProperty('label', 'my grid')` will set `aria-label=\\\"my grid\\\"`.\n *\n * `api.setGridAriaProperty('label', null)` will remove the `aria-label` attribute from the grid element.\n */\n GridApi.prototype.setGridAriaProperty = function (property, value) {\n if (!property) {\n return;\n }\n var eGrid = this.ctrlsService.getGridBodyCtrl().getGui();\n var ariaProperty = \"aria-\" + property;\n if (value === null) {\n eGrid.removeAttribute(ariaProperty);\n }\n else {\n eGrid.setAttribute(ariaProperty, value);\n }\n };\n /** Set new datasource for Server-Side Row Model. */\n GridApi.prototype.setServerSideDatasource = function (datasource) {\n if (this.serverSideRowModel) {\n // should really have an IEnterpriseRowModel interface, so we are not casting to any\n this.serverSideRowModel.setDatasource(datasource);\n }\n else {\n console.warn(\"AG Grid: you can only use an enterprise datasource when gridOptions.rowModelType is '\" + Constants.ROW_MODEL_TYPE_SERVER_SIDE + \"'\");\n }\n };\n /**\n * Updates the `cacheBlockSize` used by `serverSideInfiniteScroll` when requesting data from the server.\n *\n * Note this purges all the cached data and reloads all the rows of the grid.\n * */\n GridApi.prototype.setCacheBlockSize = function (blockSize) {\n if (!this.serverSideRowModel) {\n console.warn(\"AG Grid: you can only set cacheBlockSize with gridOptions.rowModelType '\" + Constants.ROW_MODEL_TYPE_SERVER_SIDE + \"'\");\n return;\n }\n this.gridOptionsWrapper.setProperty('cacheBlockSize', blockSize);\n this.serverSideRowModel.resetRootStore();\n };\n /** Set new datasource for Infinite Row Model. */\n GridApi.prototype.setDatasource = function (datasource) {\n if (this.gridOptionsWrapper.isRowModelInfinite()) {\n this.rowModel.setDatasource(datasource);\n }\n else {\n console.warn(\"AG Grid: you can only use a datasource when gridOptions.rowModelType is '\" + Constants.ROW_MODEL_TYPE_INFINITE + \"'\");\n }\n };\n /** Set new datasource for Viewport Row Model. */\n GridApi.prototype.setViewportDatasource = function (viewportDatasource) {\n if (this.gridOptionsWrapper.isRowModelViewport()) {\n // this is bad coding, because it's using an interface that's exposed in the enterprise.\n // really we should create an interface in the core for viewportDatasource and let\n // the enterprise implement it, rather than casting to 'any' here\n this.rowModel.setViewportDatasource(viewportDatasource);\n }\n else {\n console.warn(\"AG Grid: you can only use a viewport datasource when gridOptions.rowModelType is '\" + Constants.ROW_MODEL_TYPE_VIEWPORT + \"'\");\n }\n };\n /** Set the row data. */\n GridApi.prototype.setRowData = function (rowData) {\n // immutable service is part of the CSRM module, if missing, no CSRM\n var missingImmutableService = this.immutableService == null;\n if (missingImmutableService) {\n console.warn('AG Grid: you can only set rowData when using the Client Side Row Model');\n return;\n }\n // if no keys provided provided for rows, then we can tread the operation as Immutable\n if (this.immutableService.isActive()) {\n this.immutableService.setRowData(rowData);\n }\n else {\n this.selectionService.reset();\n this.clientSideRowModel.setRowData(rowData);\n }\n };\n /** @deprecated */\n GridApi.prototype.setFloatingTopRowData = function (rows) {\n console.warn('AG Grid: since v12, api.setFloatingTopRowData() is now api.setPinnedTopRowData()');\n this.setPinnedTopRowData(rows);\n };\n /** @deprecated */\n GridApi.prototype.setFloatingBottomRowData = function (rows) {\n console.warn('AG Grid: since v12, api.setFloatingBottomRowData() is now api.setPinnedBottomRowData()');\n this.setPinnedBottomRowData(rows);\n };\n /** @deprecated */\n GridApi.prototype.getFloatingTopRowCount = function () {\n console.warn('AG Grid: since v12, api.getFloatingTopRowCount() is now api.getPinnedTopRowCount()');\n return this.getPinnedTopRowCount();\n };\n /** @deprecated */\n GridApi.prototype.getFloatingBottomRowCount = function () {\n console.warn('AG Grid: since v12, api.getFloatingBottomRowCount() is now api.getPinnedBottomRowCount()');\n return this.getPinnedBottomRowCount();\n };\n /** @deprecated */\n GridApi.prototype.getFloatingTopRow = function (index) {\n console.warn('AG Grid: since v12, api.getFloatingTopRow() is now api.getPinnedTopRow()');\n return this.getPinnedTopRow(index);\n };\n /** @deprecated */\n GridApi.prototype.getFloatingBottomRow = function (index) {\n console.warn('AG Grid: since v12, api.getFloatingBottomRow() is now api.getPinnedBottomRow()');\n return this.getPinnedBottomRow(index);\n };\n /** Set the top pinned rows. Call with no rows / undefined to clear top pinned rows. */\n GridApi.prototype.setPinnedTopRowData = function (rows) {\n this.pinnedRowModel.setPinnedTopRowData(rows);\n };\n /** Set the bottom pinned rows. Call with no rows / undefined to clear bottom pinned rows. */\n GridApi.prototype.setPinnedBottomRowData = function (rows) {\n this.pinnedRowModel.setPinnedBottomRowData(rows);\n };\n /** Gets the number of top pinned rows. */\n GridApi.prototype.getPinnedTopRowCount = function () {\n return this.pinnedRowModel.getPinnedTopRowCount();\n };\n /** Gets the number of bottom pinned rows. */\n GridApi.prototype.getPinnedBottomRowCount = function () {\n return this.pinnedRowModel.getPinnedBottomRowCount();\n };\n /** Gets the top pinned row with the specified index. */\n GridApi.prototype.getPinnedTopRow = function (index) {\n return this.pinnedRowModel.getPinnedTopRow(index);\n };\n /** Gets the top pinned row with the specified index. */\n GridApi.prototype.getPinnedBottomRow = function (index) {\n return this.pinnedRowModel.getPinnedBottomRow(index);\n };\n /**\n * Call to set new column definitions. The grid will redraw all the column headers, and then redraw all of the rows.\n */\n GridApi.prototype.setColumnDefs = function (colDefs, source) {\n if (source === void 0) { source = \"api\"; }\n this.columnModel.setColumnDefs(colDefs, source);\n };\n /** Call to set new auto group column definition. The grid will recreate any auto-group columns if present. */\n GridApi.prototype.setAutoGroupColumnDef = function (colDef, source) {\n if (source === void 0) { source = \"api\"; }\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_AUTO_GROUP_COLUMN_DEF, colDef, true);\n };\n /** Call to set new Default Column Definition. */\n GridApi.prototype.setDefaultColDef = function (colDef, source) {\n if (source === void 0) { source = \"api\"; }\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_DEFAULT_COL_DEF, colDef, true);\n };\n GridApi.prototype.expireValueCache = function () {\n this.valueCache.expire();\n };\n /**\n * Returns an object with two properties:\n * - `top`: The top pixel position of the current scroll in the grid\n * - `bottom`: The bottom pixel position of the current scroll in the grid\n */\n GridApi.prototype.getVerticalPixelRange = function () {\n return this.gridBodyCtrl.getScrollFeature().getVScrollPosition();\n };\n /**\n * Returns an object with two properties:\n * - `left`: The left pixel position of the current scroll in the grid\n * - `right`: The right pixel position of the current scroll in the grid\n */\n GridApi.prototype.getHorizontalPixelRange = function () {\n return this.gridBodyCtrl.getScrollFeature().getHScrollPosition();\n };\n /** If `true`, the horizontal scrollbar will always be present, even if not required. Otherwise, it will only be displayed when necessary. */\n GridApi.prototype.setAlwaysShowHorizontalScroll = function (show) {\n this.gridOptionsWrapper.setProperty('alwaysShowHorizontalScroll', show);\n };\n /** If `true`, the vertical scrollbar will always be present, even if not required. Otherwise it will only be displayed when necessary. */\n GridApi.prototype.setAlwaysShowVerticalScroll = function (show) {\n this.gridOptionsWrapper.setProperty('alwaysShowVerticalScroll', show);\n };\n /** Force refresh all tool panels by calling their `refresh` method. */\n GridApi.prototype.refreshToolPanel = function () {\n if (!this.sideBarComp) {\n return;\n }\n this.sideBarComp.refresh();\n };\n /** Performs change detection on all cells, refreshing cells where required. */\n GridApi.prototype.refreshCells = function (params) {\n if (params === void 0) { params = {}; }\n if (Array.isArray(params)) {\n // the old version of refreshCells() took an array of rowNodes for the first argument\n console.warn('since AG Grid v11.1, refreshCells() now takes parameters, please see the documentation.');\n return;\n }\n this.rowRenderer.refreshCells(params);\n };\n /** Flash rows, columns or individual cells. */\n GridApi.prototype.flashCells = function (params) {\n if (params === void 0) { params = {}; }\n this.rowRenderer.flashCells(params);\n };\n /** Remove row(s) from the DOM and recreate them again from scratch. */\n GridApi.prototype.redrawRows = function (params) {\n if (params === void 0) { params = {}; }\n var rowNodes = params ? params.rowNodes : undefined;\n this.rowRenderer.redrawRows(rowNodes);\n };\n GridApi.prototype.setFunctionsReadOnly = function (readOnly) {\n this.gridOptionsWrapper.setProperty('functionsReadOnly', readOnly);\n };\n /** Redraws the header. Useful if a column name changes, or something else that changes how the column header is displayed. */\n GridApi.prototype.refreshHeader = function () {\n this.ctrlsService.getHeaderRowContainerCtrls().forEach(function (c) { return c.refresh(); });\n };\n /** Returns `true` if any filter is set. This includes quick filter, advanced filter or external filter. */\n GridApi.prototype.isAnyFilterPresent = function () {\n return this.filterManager.isAnyFilterPresent();\n };\n /** Returns `true` if any column filter is set, otherwise `false`. */\n GridApi.prototype.isColumnFilterPresent = function () {\n return this.filterManager.isColumnFilterPresent() || this.filterManager.isAggregateFilterPresent();\n };\n /** Returns `true` if the quick filter is set, otherwise `false`. */\n GridApi.prototype.isQuickFilterPresent = function () {\n return this.filterManager.isQuickFilterPresent();\n };\n /**\n * Returns the row model inside the table.\n * From here you can see the original rows, rows after filter has been applied,\n * rows after aggregation has been applied, and the final set of 'to be displayed' rows.\n */\n GridApi.prototype.getModel = function () {\n return this.rowModel;\n };\n /** Expand or collapse a specific row node. */\n GridApi.prototype.setRowNodeExpanded = function (rowNode, expanded) {\n if (rowNode) {\n rowNode.setExpanded(expanded);\n }\n };\n /**\n * If after getting the model, you expand or collapse a group, call this method to inform the grid.\n * It will work out the final set of 'to be displayed' rows again (i.e. expand or collapse the group visually).\n */\n GridApi.prototype.onGroupExpandedOrCollapsed = function (deprecated_refreshFromIndex) {\n if (missing(this.clientSideRowModel)) {\n console.warn('AG Grid: cannot call onGroupExpandedOrCollapsed unless using normal row model');\n }\n if (exists(deprecated_refreshFromIndex)) {\n console.warn('AG Grid: api.onGroupExpandedOrCollapsed - refreshFromIndex parameter is no longer used, the grid will refresh all rows');\n }\n // we don't really want the user calling this if only one rowNode was expanded, instead they should be\n // calling rowNode.setExpanded(boolean) - this way we do a 'keepRenderedRows=false' so that the whole\n // grid gets refreshed again - otherwise the row with the rowNodes that were changed won't get updated,\n // and thus the expand icon in the group cell won't get 'opened' or 'closed'.\n this.clientSideRowModel.refreshModel({ step: ClientSideRowModelSteps.MAP });\n };\n GridApi.prototype.refreshInMemoryRowModel = function (step) {\n console.warn(\"ag-grid: since version 18.x, api.refreshInMemoryRowModel() should be replaced with api.refreshClientSideRowModel()\");\n this.refreshClientSideRowModel(step);\n };\n /** Gets the Client-Side Row Model to refresh, executing the grouping, filtering and sorting again. */\n GridApi.prototype.refreshClientSideRowModel = function (step) {\n if (missing(this.clientSideRowModel)) {\n console.warn('cannot call refreshClientSideRowModel unless using normal row model');\n }\n var paramsStep = ClientSideRowModelSteps.EVERYTHING;\n var stepsMapped = {\n group: ClientSideRowModelSteps.EVERYTHING,\n filter: ClientSideRowModelSteps.FILTER,\n map: ClientSideRowModelSteps.MAP,\n aggregate: ClientSideRowModelSteps.AGGREGATE,\n sort: ClientSideRowModelSteps.SORT,\n pivot: ClientSideRowModelSteps.PIVOT\n };\n if (exists(step)) {\n paramsStep = stepsMapped[step];\n }\n if (missing(paramsStep)) {\n console.error(\"AG Grid: invalid step \" + step + \", available steps are \" + Object.keys(stepsMapped).join(', '));\n return;\n }\n var animate = !this.gridOptionsWrapper.isSuppressAnimationFrame();\n var modelParams = {\n step: paramsStep,\n keepRenderedRows: true,\n keepEditingRows: true,\n animate: animate\n };\n this.clientSideRowModel.refreshModel(modelParams);\n };\n /** Returns `true` when there are no more animation frames left to process. */\n GridApi.prototype.isAnimationFrameQueueEmpty = function () {\n return this.animationFrameService.isQueueEmpty();\n };\n GridApi.prototype.flushAllAnimationFrames = function () {\n this.animationFrameService.flushAllFrames();\n };\n /**\n * Returns the row node with the given ID.\n * The row node ID is the one you provide from the callback `getRowId(params)`,\n * otherwise the ID is a number (cast as string) auto-generated by the grid when\n * the row data is set.\n */\n GridApi.prototype.getRowNode = function (id) {\n return this.rowModel.getRowNode(id);\n };\n /**\n * Gets the sizes that various UI elements will be rendered at with the current theme.\n * If you override the row or header height using `gridOptions`, the override value you provided will be returned.\n */\n GridApi.prototype.getSizesForCurrentTheme = function () {\n return {\n rowHeight: this.gridOptionsWrapper.getRowHeightAsNumber(),\n headerHeight: this.gridOptionsWrapper.getHeaderHeight()\n };\n };\n /** Expand all groups. */\n GridApi.prototype.expandAll = function () {\n if (this.clientSideRowModel) {\n this.clientSideRowModel.expandOrCollapseAll(true);\n }\n else if (this.serverSideRowModel) {\n this.serverSideRowModel.expandAll(true);\n }\n else {\n console.warn('AG Grid: expandAll only works with Client Side Row Model and Server Side Row Model');\n }\n };\n /** Collapse all groups. */\n GridApi.prototype.collapseAll = function () {\n if (this.clientSideRowModel) {\n this.clientSideRowModel.expandOrCollapseAll(false);\n }\n else if (this.serverSideRowModel) {\n this.serverSideRowModel.expandAll(false);\n }\n else {\n console.warn('AG Grid: collapseAll only works with Client Side Row Model and Server Side Row Model');\n }\n };\n /** Gets the tool panel instance corresponding to the supplied `id`. */\n GridApi.prototype.getToolPanelInstance = function (id) {\n if (!this.sideBarComp) {\n console.warn('AG Grid: toolPanel is only available in AG Grid Enterprise');\n return;\n }\n var comp = this.sideBarComp.getToolPanelInstance(id);\n return unwrapUserComp(comp);\n };\n GridApi.prototype.addVirtualRowListener = function (eventName, rowIndex, callback) {\n if (typeof eventName !== 'string') {\n console.warn('AG Grid: addVirtualRowListener is deprecated, please use addRenderedRowListener.');\n }\n this.addRenderedRowListener(eventName, rowIndex, callback);\n };\n /**\n * Registers a callback to a virtual row.\n * A virtual row is a row that is visually rendered on the screen (rows that are not visible because of the scroll position are not rendered).\n * Unlike normal events, you do not need to unregister rendered row listeners.\n * When the rendered row is removed from the grid, all associated rendered row listeners will also be removed.\n * Currently supports only one event, `virtualRowRemoved`;\n * listen for this event if your `cellRenderer` needs to do cleanup when the row no longer exists.\n */\n GridApi.prototype.addRenderedRowListener = function (eventName, rowIndex, callback) {\n if (eventName === 'virtualRowSelected') {\n console.warn(\"AG Grid: event virtualRowSelected is deprecated, to register for individual row\\n selection events, add a listener directly to the row node.\");\n }\n this.rowRenderer.addRenderedRowListener(eventName, rowIndex, callback);\n };\n /** Pass a quick filter text into the grid for filtering. */\n GridApi.prototype.setQuickFilter = function (newFilter) {\n this.filterManager.setQuickFilter(newFilter);\n };\n GridApi.prototype.selectIndex = function (index, tryMulti, suppressEvents) {\n console.warn('AG Grid: do not use api for selection, call node.setSelected(value) instead');\n if (suppressEvents) {\n console.warn('AG Grid: suppressEvents is no longer supported, stop listening for the event if you no longer want it');\n }\n this.selectionService.selectIndex(index, tryMulti);\n };\n GridApi.prototype.deselectIndex = function (index, suppressEvents) {\n if (suppressEvents === void 0) { suppressEvents = false; }\n console.warn('AG Grid: do not use api for selection, call node.setSelected(value) instead');\n if (suppressEvents) {\n console.warn('AG Grid: suppressEvents is no longer supported, stop listening for the event if you no longer want it');\n }\n this.selectionService.deselectIndex(index);\n };\n GridApi.prototype.selectNode = function (node, tryMulti, suppressEvents) {\n if (tryMulti === void 0) { tryMulti = false; }\n if (suppressEvents === void 0) { suppressEvents = false; }\n console.warn('AG Grid: API for selection is deprecated, call node.setSelected(value) instead');\n if (suppressEvents) {\n console.warn('AG Grid: suppressEvents is no longer supported, stop listening for the event if you no longer want it');\n }\n node.setSelectedParams({ newValue: true, clearSelection: !tryMulti });\n };\n GridApi.prototype.deselectNode = function (node, suppressEvents) {\n if (suppressEvents === void 0) { suppressEvents = false; }\n console.warn('AG Grid: API for selection is deprecated, call node.setSelected(value) instead');\n if (suppressEvents) {\n console.warn('AG Grid: suppressEvents is no longer supported, stop listening for the event if you no longer want it');\n }\n node.setSelectedParams({ newValue: false });\n };\n /** Select all rows, regardless of filtering and rows that are not visible due to grouping being enabled and their groups not expanded. */\n GridApi.prototype.selectAll = function () {\n this.selectionService.selectAllRowNodes();\n };\n /** Clear all row selections, regardless of filtering. */\n GridApi.prototype.deselectAll = function () {\n this.selectionService.deselectAllRowNodes();\n };\n /** Select all filtered rows. */\n GridApi.prototype.selectAllFiltered = function () {\n this.selectionService.selectAllRowNodes(true);\n };\n /** Clear all filtered selections. */\n GridApi.prototype.deselectAllFiltered = function () {\n this.selectionService.deselectAllRowNodes(true);\n };\n GridApi.prototype.recomputeAggregates = function () {\n if (missing(this.clientSideRowModel)) {\n console.warn('cannot call recomputeAggregates unless using normal row model');\n }\n console.warn(\"recomputeAggregates is deprecated, please call api.refreshClientSideRowModel('aggregate') instead\");\n this.clientSideRowModel.refreshModel({ step: ClientSideRowModelSteps.AGGREGATE });\n };\n /**\n * Sets columns to adjust in size to fit the grid horizontally.\n **/\n GridApi.prototype.sizeColumnsToFit = function (params) {\n this.gridBodyCtrl.sizeColumnsToFit(params);\n };\n /** Show the 'loading' overlay. */\n GridApi.prototype.showLoadingOverlay = function () {\n this.overlayWrapperComp.showLoadingOverlay();\n };\n /** Show the 'no rows' overlay. */\n GridApi.prototype.showNoRowsOverlay = function () {\n this.overlayWrapperComp.showNoRowsOverlay();\n };\n /** Hides the overlay if showing. */\n GridApi.prototype.hideOverlay = function () {\n this.overlayWrapperComp.hideOverlay();\n };\n GridApi.prototype.isNodeSelected = function (node) {\n console.warn('AG Grid: no need to call api.isNodeSelected(), just call node.isSelected() instead');\n return node.isSelected();\n };\n GridApi.prototype.getSelectedNodesById = function () {\n console.error('AG Grid: since version 3.4, getSelectedNodesById no longer exists, use getSelectedNodes() instead');\n return null;\n };\n /**\n * Returns an unsorted list of selected nodes.\n * Getting the underlying node (rather than the data) is useful when working with tree / aggregated data,\n * as the node can be traversed.\n */\n GridApi.prototype.getSelectedNodes = function () {\n return this.selectionService.getSelectedNodes();\n };\n /** Returns an unsorted list of selected rows (i.e. row data that you provided). */\n GridApi.prototype.getSelectedRows = function () {\n return this.selectionService.getSelectedRows();\n };\n /**\n * Returns a list of all selected nodes at 'best cost', a feature to be used with groups / trees.\n * If a group has all its children selected, then the group appears in the result, but not the children.\n * Designed for use with `'children'` as the group selection type, where groups don't actually appear in the selection normally.\n */\n GridApi.prototype.getBestCostNodeSelection = function () {\n return this.selectionService.getBestCostNodeSelection();\n };\n /** Retrieve rendered nodes. Due to virtualisation this will contain only the current visible rows and those in the buffer. */\n GridApi.prototype.getRenderedNodes = function () {\n return this.rowRenderer.getRenderedNodes();\n };\n GridApi.prototype.ensureColIndexVisible = function (index) {\n console.warn('AG Grid: ensureColIndexVisible(index) no longer supported, use ensureColumnVisible(colKey) instead.');\n };\n /**\n * Ensures the column is visible by scrolling the table if needed.\n *\n * This will have no effect before the firstDataRendered event has fired.\n *\n * @param key - The column to ensure visible\n * @param position - Where the column will be positioned.\n * - `auto` - Scrolls the minimum amount to make sure the column is visible.\n * - `start` - Scrolls the column to the start of the viewport.\n * - `middle` - Scrolls the column to the middle of the viewport.\n * - `end` - Scrolls the column to the end of the viewport.\n */\n GridApi.prototype.ensureColumnVisible = function (key, position) {\n if (position === void 0) { position = 'auto'; }\n this.gridBodyCtrl.getScrollFeature().ensureColumnVisible(key, position);\n };\n /**\n * Vertically scrolls the grid until the provided row index is inside the visible viewport.\n * If a position is provided, the grid will attempt to scroll until the row is at the given position within the viewport.\n * This will have no effect before the firstDataRendered event has fired.\n */\n GridApi.prototype.ensureIndexVisible = function (index, position) {\n this.gridBodyCtrl.getScrollFeature().ensureIndexVisible(index, position);\n };\n /**\n * Vertically scrolls the grid until the provided row (or a row matching the provided comparator) is inside the visible viewport.\n * If a position is provided, the grid will attempt to scroll until the row is at the given position within the viewport.\n * This will have no effect before the firstDataRendered event has fired.\n */\n GridApi.prototype.ensureNodeVisible = function (nodeSelector, position) {\n if (position === void 0) { position = null; }\n this.gridBodyCtrl.getScrollFeature().ensureNodeVisible(nodeSelector, position);\n };\n /**\n * Similar to `forEachNode`, except lists all the leaf nodes.\n * This effectively goes through all the data that you provided to the grid before the grid performed any grouping.\n * If using tree data, goes through all the nodes for the data you provided, including nodes that have children,\n * but excluding groups the grid created where gaps were missing in the hierarchy.\n */\n GridApi.prototype.forEachLeafNode = function (callback) {\n if (missing(this.clientSideRowModel)) {\n console.warn('cannot call forEachNode unless using normal row model');\n }\n this.clientSideRowModel.forEachLeafNode(callback);\n };\n /**\n * Iterates through each node (row) in the grid and calls the callback for each node.\n * This works similar to the `forEach` method on a JavaScript array.\n * This is called for every node, ignoring any filtering or sorting applied within the grid.\n * If using the Infinite Row Model, then this gets called for each page loaded in the page cache.\n */\n GridApi.prototype.forEachNode = function (callback) {\n this.rowModel.forEachNode(callback);\n };\n /** Similar to `forEachNode`, except skips any filtered out data. */\n GridApi.prototype.forEachNodeAfterFilter = function (callback) {\n if (missing(this.clientSideRowModel)) {\n console.warn('cannot call forEachNodeAfterFilter unless using normal row model');\n }\n this.clientSideRowModel.forEachNodeAfterFilter(callback);\n };\n /** Similar to `forEachNodeAfterFilter`, except the callbacks are called in the order the rows are displayed in the grid. */\n GridApi.prototype.forEachNodeAfterFilterAndSort = function (callback) {\n if (missing(this.clientSideRowModel)) {\n console.warn('cannot call forEachNodeAfterFilterAndSort unless using normal row model');\n }\n this.clientSideRowModel.forEachNodeAfterFilterAndSort(callback);\n };\n /**\n * Returns the filter component instance for a column.\n * `key` can be a string field name or a ColDef object (matches on object reference, useful if field names are not unique).\n * If your filter is created asynchronously, `getFilterInstance` will return `null` so you will need to use the `callback` to access the filter instance instead.\n */\n GridApi.prototype.getFilterInstance = function (key, callback) {\n var res = this.getFilterInstanceImpl(key, function (instance) {\n if (!callback) {\n return;\n }\n var unwrapped = unwrapUserComp(instance);\n callback(unwrapped);\n });\n var unwrapped = unwrapUserComp(res);\n return unwrapped;\n };\n GridApi.prototype.getFilterInstanceImpl = function (key, callback) {\n var column = this.columnModel.getPrimaryColumn(key);\n if (!column) {\n return undefined;\n }\n var filterPromise = this.filterManager.getFilterComponent(column, 'NO_UI');\n var currentValue = filterPromise && filterPromise.resolveNow(null, function (filterComp) { return filterComp; });\n if (currentValue) {\n setTimeout(callback, 0, currentValue);\n }\n else if (filterPromise) {\n filterPromise.then(function (comp) {\n callback(comp);\n });\n }\n return currentValue;\n };\n /** Destroys a filter. Useful to force a particular filter to be created from scratch again. */\n GridApi.prototype.destroyFilter = function (key) {\n var column = this.columnModel.getPrimaryColumn(key);\n if (column) {\n return this.filterManager.destroyFilter(column, \"filterDestroyed\");\n }\n };\n /** Gets the status panel instance corresponding to the supplied `id`. */\n GridApi.prototype.getStatusPanel = function (key) {\n if (!this.statusBarService) {\n return;\n }\n var comp = this.statusBarService.getStatusPanel(key);\n return unwrapUserComp(comp);\n };\n GridApi.prototype.getColumnDef = function (key) {\n var column = this.columnModel.getPrimaryColumn(key);\n if (column) {\n return column.getColDef();\n }\n return null;\n };\n /**\n * Returns the current column definitions.\n */\n GridApi.prototype.getColumnDefs = function () { return this.columnModel.getColumnDefs(); };\n /** Informs the grid that a filter has changed. This is typically called after a filter change through one of the filter APIs. */\n GridApi.prototype.onFilterChanged = function () {\n this.filterManager.onFilterChanged();\n };\n /**\n * Gets the grid to act as if the sort was changed.\n * Useful if you update some values and want to get the grid to reorder them according to the new values.\n */\n GridApi.prototype.onSortChanged = function () {\n this.sortController.onSortChanged('api');\n };\n /** Sets the state of all the advanced filters. Provide it with what you get from `getFilterModel()` to restore filter state. */\n GridApi.prototype.setFilterModel = function (model) {\n this.filterManager.setFilterModel(model);\n };\n /** Gets the current state of all the advanced filters. Used for saving filter state. */\n GridApi.prototype.getFilterModel = function () {\n return this.filterManager.getFilterModel();\n };\n /** Returns the focused cell (or the last focused cell if the grid lost focus). */\n GridApi.prototype.getFocusedCell = function () {\n return this.focusService.getFocusedCell();\n };\n /** Clears the focused cell. */\n GridApi.prototype.clearFocusedCell = function () {\n return this.focusService.clearFocusedCell();\n };\n /** Sets the focus to the specified cell. `rowPinned` can be either 'top', 'bottom' or null (for not pinned). */\n GridApi.prototype.setFocusedCell = function (rowIndex, colKey, rowPinned) {\n this.focusService.setFocusedCell({ rowIndex: rowIndex, column: colKey, rowPinned: rowPinned, forceBrowserFocus: true });\n };\n /** Sets the `suppressRowDrag` property. */\n GridApi.prototype.setSuppressRowDrag = function (value) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_SUPPRESS_ROW_DRAG, value);\n };\n /** Sets the `suppressMoveWhenRowDragging` property. */\n GridApi.prototype.setSuppressMoveWhenRowDragging = function (value) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_SUPPRESS_MOVE_WHEN_ROW_DRAG, value);\n };\n /** Sets the `suppressRowClickSelection` property. */\n GridApi.prototype.setSuppressRowClickSelection = function (value) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_SUPPRESS_ROW_CLICK_SELECTION, value);\n };\n /** Adds a drop zone outside of the grid where rows can be dropped. */\n GridApi.prototype.addRowDropZone = function (params) {\n this.gridBodyCtrl.getRowDragFeature().addRowDropZone(params);\n };\n /** Removes an external drop zone added by `addRowDropZone`. */\n GridApi.prototype.removeRowDropZone = function (params) {\n var activeDropTarget = this.dragAndDropService.findExternalZone(params);\n if (activeDropTarget) {\n this.dragAndDropService.removeDropTarget(activeDropTarget);\n }\n };\n /** Returns the `RowDropZoneParams` to be used by another grid's `addRowDropZone` method. */\n GridApi.prototype.getRowDropZoneParams = function (events) {\n return this.gridBodyCtrl.getRowDragFeature().getRowDropZone(events);\n };\n /** Sets the height in pixels for the row containing the column label header. */\n GridApi.prototype.setHeaderHeight = function (headerHeight) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_HEADER_HEIGHT, headerHeight);\n };\n /**\n * Switch between layout options: `normal`, `autoHeight`, `print`.\n * Defaults to `normal` if no domLayout provided.\n */\n GridApi.prototype.setDomLayout = function (domLayout) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_DOM_LAYOUT, domLayout);\n };\n /** Sets the `enableCellTextSelection` property. */\n GridApi.prototype.setEnableCellTextSelection = function (selectable) {\n this.gridBodyCtrl.setCellTextSelection(selectable);\n };\n /** Sets the preferred direction for the selection fill handle. */\n GridApi.prototype.setFillHandleDirection = function (direction) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_FILL_HANDLE_DIRECTION, direction);\n };\n /** Sets the height in pixels for the rows containing header column groups. */\n GridApi.prototype.setGroupHeaderHeight = function (headerHeight) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_GROUP_HEADER_HEIGHT, headerHeight);\n };\n /** Sets the height in pixels for the row containing the floating filters. */\n GridApi.prototype.setFloatingFiltersHeight = function (headerHeight) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_FLOATING_FILTERS_HEIGHT, headerHeight);\n };\n /** Sets the height in pixels for the row containing the columns when in pivot mode. */\n GridApi.prototype.setPivotHeaderHeight = function (headerHeight) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_PIVOT_HEADER_HEIGHT, headerHeight);\n };\n /** Sets the height in pixels for the row containing header column groups when in pivot mode. */\n GridApi.prototype.setPivotGroupHeaderHeight = function (headerHeight) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_PIVOT_GROUP_HEADER_HEIGHT, headerHeight);\n };\n GridApi.prototype.setIsExternalFilterPresent = function (isExternalFilterPresentFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_IS_EXTERNAL_FILTER_PRESENT, isExternalFilterPresentFunc);\n };\n GridApi.prototype.setDoesExternalFilterPass = function (doesExternalFilterPassFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_DOES_EXTERNAL_FILTER_PASS, doesExternalFilterPassFunc);\n };\n GridApi.prototype.setNavigateToNextCell = function (navigateToNextCellFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_NAVIGATE_TO_NEXT_CELL, navigateToNextCellFunc);\n };\n GridApi.prototype.setTabToNextCell = function (tabToNextCellFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_TAB_TO_NEXT_CELL, tabToNextCellFunc);\n };\n GridApi.prototype.setTabToNextHeader = function (tabToNextHeaderFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_TAB_TO_NEXT_HEADER, tabToNextHeaderFunc);\n };\n GridApi.prototype.setNavigateToNextHeader = function (navigateToNextHeaderFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_NAVIGATE_TO_NEXT_HEADER, navigateToNextHeaderFunc);\n };\n GridApi.prototype.setGroupRowAggNodes = function (groupRowAggNodesFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_GROUP_ROW_AGG_NODES, groupRowAggNodesFunc);\n };\n GridApi.prototype.setGetGroupRowAgg = function (getGroupRowAggFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_GET_GROUP_ROW_AGG, getGroupRowAggFunc);\n };\n GridApi.prototype.setGetBusinessKeyForNode = function (getBusinessKeyForNodeFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_GET_BUSINESS_KEY_FOR_NODE, getBusinessKeyForNodeFunc);\n };\n GridApi.prototype.setGetChildCount = function (getChildCountFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_GET_CHILD_COUNT, getChildCountFunc);\n };\n GridApi.prototype.setProcessRowPostCreate = function (processRowPostCreateFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_PROCESS_ROW_POST_CREATE, processRowPostCreateFunc);\n };\n GridApi.prototype.setGetRowNodeId = function (getRowNodeIdFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_GET_ROW_NODE_ID, getRowNodeIdFunc);\n };\n GridApi.prototype.setGetRowId = function (getRowIdFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_GET_ROW_ID, getRowIdFunc);\n };\n GridApi.prototype.setGetRowClass = function (rowClassFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_GET_ROW_CLASS, rowClassFunc);\n };\n GridApi.prototype.setIsFullWidthCell = function (isFullWidthCellFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_IS_FULL_WIDTH_CELL, isFullWidthCellFunc);\n };\n GridApi.prototype.setIsFullWidthRow = function (isFullWidthRowFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_IS_FULL_WIDTH_ROW, isFullWidthRowFunc);\n };\n GridApi.prototype.setIsRowSelectable = function (isRowSelectableFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_IS_ROW_SELECTABLE, isRowSelectableFunc);\n };\n GridApi.prototype.setIsRowMaster = function (isRowMasterFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_IS_ROW_MASTER, isRowMasterFunc);\n };\n GridApi.prototype.setPostSort = function (postSortFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_POST_SORT, postSortFunc);\n };\n GridApi.prototype.setPostSortRows = function (postSortRowsFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_POST_SORT_ROWS, postSortRowsFunc);\n };\n GridApi.prototype.setGetDocument = function (getDocumentFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_GET_DOCUMENT, getDocumentFunc);\n };\n GridApi.prototype.setGetContextMenuItems = function (getContextMenuItemsFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_GET_CONTEXT_MENU_ITEMS, getContextMenuItemsFunc);\n };\n GridApi.prototype.setGetMainMenuItems = function (getMainMenuItemsFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_GET_MAIN_MENU_ITEMS, getMainMenuItemsFunc);\n };\n GridApi.prototype.setProcessCellForClipboard = function (processCellForClipboardFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_PROCESS_CELL_FOR_CLIPBOARD, processCellForClipboardFunc);\n };\n GridApi.prototype.setSendToClipboard = function (sendToClipboardFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_SEND_TO_CLIPBOARD, sendToClipboardFunc);\n };\n GridApi.prototype.setProcessCellFromClipboard = function (processCellFromClipboardFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_PROCESS_CELL_FROM_CLIPBOARD, processCellFromClipboardFunc);\n };\n /** @deprecated use `setProcessPivotResultColDef` instead */\n GridApi.prototype.setProcessSecondaryColDef = function (processSecondaryColDefFunc) {\n console.warn('AG Grid: since version 28.0.x setProcessSecondaryColDef has been renamed, please use setProcessPivotResultColDef instead');\n this.setProcessPivotResultColDef(processSecondaryColDefFunc);\n };\n /** @deprecated use `setProcessPivotResultColGroupDef` instead */\n GridApi.prototype.setProcessSecondaryColGroupDef = function (processSecondaryColGroupDefFunc) {\n console.warn('AG Grid: since version 28.0.x setProcessSecondaryColGroupDef has been renamed, please use setProcessPivotResultColGroupDef instead');\n this.setProcessPivotResultColGroupDef(processSecondaryColGroupDefFunc);\n };\n GridApi.prototype.setProcessPivotResultColDef = function (processPivotResultColDefFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_PROCESS_PIVOT_RESULT_COL_DEF, processPivotResultColDefFunc);\n };\n GridApi.prototype.setProcessPivotResultColGroupDef = function (processPivotResultColGroupDefFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_PROCESS_PIVOT_RESULT_COL_GROUP_DEF, processPivotResultColGroupDefFunc);\n };\n GridApi.prototype.setPostProcessPopup = function (postProcessPopupFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_POST_PROCESS_POPUP, postProcessPopupFunc);\n };\n GridApi.prototype.setDefaultGroupOrderComparator = function (defaultGroupOrderComparatorFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_DEFAULT_GROUP_ORDER_COMPARATOR, defaultGroupOrderComparatorFunc);\n };\n GridApi.prototype.setInitialGroupOrderComparator = function (initialGroupOrderComparatorFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_INITIAL_GROUP_ORDER_COMPARATOR, initialGroupOrderComparatorFunc);\n };\n GridApi.prototype.setGetChartToolbarItems = function (getChartToolbarItemsFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_GET_CHART_TOOLBAR_ITEMS, getChartToolbarItemsFunc);\n };\n GridApi.prototype.setPaginationNumberFormatter = function (paginationNumberFormatterFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_PAGINATION_NUMBER_FORMATTER, paginationNumberFormatterFunc);\n };\n /** @deprecated\n * use setGetServerSideGroupLevelParams instead\n */\n GridApi.prototype.setGetServerSideStoreParams = function (getServerSideStoreParamsFunc) {\n this.setGetServerSideGroupLevelParams(getServerSideStoreParamsFunc);\n };\n GridApi.prototype.setGetServerSideGroupLevelParams = function (getServerSideGroupLevelParamsFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_GET_SERVER_SIDE_GROUP_PARAMS, getServerSideGroupLevelParamsFunc);\n };\n GridApi.prototype.setIsServerSideGroupOpenByDefault = function (isServerSideGroupOpenByDefaultFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_IS_SERVER_SIDE_GROUPS_OPEN_BY_DEFAULT, isServerSideGroupOpenByDefaultFunc);\n };\n GridApi.prototype.setIsApplyServerSideTransaction = function (isApplyServerSideTransactionFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_IS_APPLY_SERVER_SIDE_TRANSACTION, isApplyServerSideTransactionFunc);\n };\n GridApi.prototype.setIsServerSideGroup = function (isServerSideGroupFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_IS_SERVER_SIDE_GROUP, isServerSideGroupFunc);\n };\n GridApi.prototype.setGetServerSideGroupKey = function (getServerSideGroupKeyFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_GET_SERVER_SIDE_GROUP_KEY, getServerSideGroupKeyFunc);\n };\n GridApi.prototype.setGetRowStyle = function (rowStyleFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_GET_ROW_STYLE, rowStyleFunc);\n };\n GridApi.prototype.setGetRowHeight = function (rowHeightFunc) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_GET_ROW_HEIGHT, rowHeightFunc);\n };\n /** Returns `true` if the side bar is visible. */\n GridApi.prototype.isSideBarVisible = function () {\n return this.sideBarComp ? this.sideBarComp.isDisplayed() : false;\n };\n /** Show/hide the entire side bar, including any visible panel and the tab buttons. */\n GridApi.prototype.setSideBarVisible = function (show) {\n if (!this.sideBarComp) {\n if (show) {\n console.warn('AG Grid: sideBar is not loaded');\n }\n return;\n }\n this.sideBarComp.setDisplayed(show);\n };\n /** Sets the side bar position relative to the grid. Possible values are `'left'` or `'right'`. */\n GridApi.prototype.setSideBarPosition = function (position) {\n if (!this.sideBarComp) {\n console.warn('AG Grid: sideBar is not loaded');\n return;\n }\n this.sideBarComp.setSideBarPosition(position);\n };\n /** Opens a particular tool panel. Provide the ID of the tool panel to open. */\n GridApi.prototype.openToolPanel = function (key) {\n if (!this.sideBarComp) {\n console.warn('AG Grid: toolPanel is only available in AG Grid Enterprise');\n return;\n }\n this.sideBarComp.openToolPanel(key);\n };\n /** Closes the currently open tool panel (if any). */\n GridApi.prototype.closeToolPanel = function () {\n if (!this.sideBarComp) {\n console.warn('AG Grid: toolPanel is only available in AG Grid Enterprise');\n return;\n }\n this.sideBarComp.close();\n };\n /** Returns the ID of the currently shown tool panel if any, otherwise `null`. */\n GridApi.prototype.getOpenedToolPanel = function () {\n return this.sideBarComp ? this.sideBarComp.openedItem() : null;\n };\n /** Returns the current side bar configuration. If a shortcut was used, returns the detailed long form. */\n GridApi.prototype.getSideBar = function () {\n return this.gridOptionsWrapper.getSideBar();\n };\n /** Resets the side bar to the provided configuration. The parameter is the same as the sideBar grid property. The side bar is re-created from scratch with the new config. */\n GridApi.prototype.setSideBar = function (def) {\n this.gridOptionsWrapper.setProperty('sideBar', SideBarDefParser.parse(def));\n };\n GridApi.prototype.setSuppressClipboardPaste = function (value) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_SUPPRESS_CLIPBOARD_PASTE, value);\n };\n /** Returns `true` if the tool panel is showing, otherwise `false`. */\n GridApi.prototype.isToolPanelShowing = function () {\n return this.sideBarComp.isToolPanelShowing();\n };\n GridApi.prototype.doLayout = function () {\n var message = \"AG Grid - since version 25.1, doLayout was taken out, as it's not needed. The grid responds to grid size changes automatically\";\n doOnce(function () { return console.warn(message); }, 'doLayoutDeprecated');\n };\n /** Tells the grid to recalculate the row heights. */\n GridApi.prototype.resetRowHeights = function () {\n if (exists(this.clientSideRowModel)) {\n if (this.columnModel.isAutoRowHeightActive()) {\n console.warn('AG Grid: calling gridApi.resetRowHeights() makes no sense when using Auto Row Height.');\n return;\n }\n this.clientSideRowModel.resetRowHeights();\n }\n };\n GridApi.prototype.setGroupRemoveSingleChildren = function (value) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_GROUP_REMOVE_SINGLE_CHILDREN, value);\n };\n GridApi.prototype.setGroupRemoveLowestSingleChildren = function (value) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_GROUP_REMOVE_LOWEST_SINGLE_CHILDREN, value);\n };\n GridApi.prototype.setGroupDisplayType = function (value) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_GROUP_DISPLAY_TYPE, value);\n };\n /** Tells the grid a row height has changed. To be used after calling `rowNode.setRowHeight(newHeight)`. */\n GridApi.prototype.onRowHeightChanged = function () {\n if (this.clientSideRowModel) {\n this.clientSideRowModel.onRowHeightChanged();\n }\n else if (this.serverSideRowModel) {\n this.serverSideRowModel.onRowHeightChanged();\n }\n };\n /**\n * Gets the value for a column for a particular `rowNode` (row).\n * This is useful if you want the raw value of a cell e.g. if implementing your own CSV export.\n */\n GridApi.prototype.getValue = function (colKey, rowNode) {\n var column = this.columnModel.getPrimaryColumn(colKey);\n if (missing(column)) {\n column = this.columnModel.getGridColumn(colKey);\n }\n if (missing(column)) {\n return null;\n }\n return this.valueService.getValue(column, rowNode);\n };\n /** Add an event listener for the specified `eventType`. Works similar to `addEventListener` for a browser DOM element. */\n GridApi.prototype.addEventListener = function (eventType, listener) {\n var async = this.gridOptionsWrapper.useAsyncEvents();\n this.eventService.addEventListener(eventType, listener, async);\n };\n /** Add an event listener for all event types coming from the grid. */\n GridApi.prototype.addGlobalListener = function (listener) {\n var async = this.gridOptionsWrapper.useAsyncEvents();\n this.eventService.addGlobalListener(listener, async);\n };\n /** Remove an event listener. */\n GridApi.prototype.removeEventListener = function (eventType, listener) {\n var async = this.gridOptionsWrapper.useAsyncEvents();\n this.eventService.removeEventListener(eventType, listener, async);\n };\n /** Remove a global event listener. */\n GridApi.prototype.removeGlobalListener = function (listener) {\n var async = this.gridOptionsWrapper.useAsyncEvents();\n this.eventService.removeGlobalListener(listener, async);\n };\n GridApi.prototype.dispatchEvent = function (event) {\n this.eventService.dispatchEvent(event);\n };\n /** Will destroy the grid and release resources. If you are using a framework you do not need to call this, as the grid links in with the framework lifecycle. However if you are using Web Components or native JavaScript, you do need to call this, to avoid a memory leak in your application. */\n GridApi.prototype.destroy = function () {\n // this is needed as GridAPI is a bean, and GridAPI.destroy() is called as part\n // of context.destroy(). so we need to stop the infinite loop.\n if (this.destroyCalled) {\n return;\n }\n this.destroyCalled = true;\n // destroy the UI first (as they use the services)\n var gridCtrl = this.ctrlsService.getGridCtrl();\n if (gridCtrl) {\n gridCtrl.destroyGridUi();\n }\n // destroy the services\n this.context.destroy();\n };\n GridApi.prototype.cleanDownReferencesToAvoidMemoryLeakInCaseApplicationIsKeepingReferenceToDestroyedGrid = function () {\n // some users were raising support issues with regards memory leaks. the problem was the customers applications\n // were keeping references to the API. trying to educate them all would be difficult, easier to just remove\n // all references in the API so at least the core grid can be garbage collected.\n //\n // wait about 100ms before clearing down the references, in case user has some cleanup to do,\n // and needs to deference the API first\n setTimeout(removeAllReferences.bind(window, this, 'Grid API'), 100);\n };\n GridApi.prototype.warnIfDestroyed = function (methodName) {\n if (this.destroyCalled) {\n console.warn(\"AG Grid: Grid API method \" + methodName + \" was called on a grid that was destroyed.\");\n }\n return this.destroyCalled;\n };\n /** Reset the quick filter cache text on every rowNode. */\n GridApi.prototype.resetQuickFilter = function () {\n if (this.warnIfDestroyed('resetQuickFilter')) {\n return;\n }\n this.rowModel.forEachNode(function (node) { return node.quickFilterAggregateText = null; });\n };\n GridApi.prototype.getRangeSelections = function () {\n console.warn(\"AG Grid: in v20.1.x, api.getRangeSelections() is gone, please use getCellRanges() instead.\\n We had to change how cell selections works a small bit to allow charting to integrate. The return type of\\n getCellRanges() is a bit different, please check the AG Grid documentation.\");\n return null;\n };\n /** Returns the list of selected cell ranges. */\n GridApi.prototype.getCellRanges = function () {\n if (this.rangeService) {\n return this.rangeService.getCellRanges();\n }\n console.warn('AG Grid: cell range selection is only available in AG Grid Enterprise');\n return null;\n };\n GridApi.prototype.camelCaseToHumanReadable = function (camelCase) {\n return camelCaseToHumanText(camelCase);\n };\n GridApi.prototype.addRangeSelection = function (deprecatedNoLongerUsed) {\n console.warn('AG Grid: As of version 21.x, range selection changed slightly to allow charting integration. Please call api.addCellRange() instead of api.addRangeSelection()');\n };\n /** Adds the provided cell range to the selected ranges. */\n GridApi.prototype.addCellRange = function (params) {\n if (!this.rangeService) {\n console.warn('AG Grid: cell range selection is only available in AG Grid Enterprise');\n }\n this.rangeService.addCellRange(params);\n };\n /** Clears the selected ranges. */\n GridApi.prototype.clearRangeSelection = function () {\n if (!this.rangeService) {\n console.warn('AG Grid: cell range selection is only available in AG Grid Enterprise');\n }\n this.rangeService.removeAllCellRanges();\n };\n /** Reverts the last cell edit. */\n GridApi.prototype.undoCellEditing = function () {\n this.undoRedoService.undo();\n };\n /** Re-applies the most recently undone cell edit. */\n GridApi.prototype.redoCellEditing = function () {\n this.undoRedoService.redo();\n };\n /** Returns current number of available cell edit undo operations. */\n GridApi.prototype.getCurrentUndoSize = function () {\n return this.undoRedoService.getCurrentUndoStackSize();\n };\n /** Returns current number of available cell edit redo operations. */\n GridApi.prototype.getCurrentRedoSize = function () {\n return this.undoRedoService.getCurrentRedoStackSize();\n };\n /** Returns a list of models with information about the charts that are currently rendered from the grid. */\n GridApi.prototype.getChartModels = function () {\n if (ModuleRegistry.assertRegistered(ModuleNames.RangeSelectionModule, 'api.getChartModels') &&\n ModuleRegistry.assertRegistered(ModuleNames.GridChartsModule, 'api.getChartModels')) {\n return this.chartService.getChartModels();\n }\n };\n /** Returns the `ChartRef` using the supplied `chartId`. */\n GridApi.prototype.getChartRef = function (chartId) {\n if (ModuleRegistry.assertRegistered(ModuleNames.RangeSelectionModule, 'api.getChartRef') &&\n ModuleRegistry.assertRegistered(ModuleNames.GridChartsModule, 'api.getChartRef')) {\n return this.chartService.getChartRef(chartId);\n }\n };\n /** Returns a string containing the requested data URL which contains a representation of the chart image. */\n GridApi.prototype.getChartImageDataURL = function (params) {\n if (ModuleRegistry.assertRegistered(ModuleNames.RangeSelectionModule, 'api.getChartImageDataURL') &&\n ModuleRegistry.assertRegistered(ModuleNames.GridChartsModule, 'api.getChartImageDataURL')) {\n return this.chartService.getChartImageDataURL(params);\n }\n };\n /** Used to programmatically create charts from a range. */\n GridApi.prototype.createRangeChart = function (params) {\n if (ModuleRegistry.assertRegistered(ModuleNames.RangeSelectionModule, 'api.createRangeChart') &&\n ModuleRegistry.assertRegistered(ModuleNames.GridChartsModule, 'api.createRangeChart')) {\n return this.chartService.createRangeChart(params);\n }\n };\n /** Used to programmatically create cross filter charts from a range. */\n GridApi.prototype.createCrossFilterChart = function (params) {\n if (ModuleRegistry.assertRegistered(ModuleNames.RangeSelectionModule, 'api.createCrossFilterChart') &&\n ModuleRegistry.assertRegistered(ModuleNames.GridChartsModule, 'api.createCrossFilterChart')) {\n return this.chartService.createCrossFilterChart(params);\n }\n };\n /** Restores a chart using the `ChartModel` that was previously obtained from `getChartModels()`. */\n GridApi.prototype.restoreChart = function (chartModel, chartContainer) {\n if (ModuleRegistry.assertRegistered(ModuleNames.RangeSelectionModule, 'api.restoreChart') &&\n ModuleRegistry.assertRegistered(ModuleNames.GridChartsModule, 'api.restoreChart')) {\n return this.chartService.restoreChart(chartModel, chartContainer);\n }\n };\n /** Used to programmatically create pivot charts from a grid. */\n GridApi.prototype.createPivotChart = function (params) {\n if (ModuleRegistry.assertRegistered(ModuleNames.RangeSelectionModule, 'api.createPivotChart') &&\n ModuleRegistry.assertRegistered(ModuleNames.GridChartsModule, 'api.createPivotChart')) {\n return this.chartService.createPivotChart(params);\n }\n };\n /** Copies the selected rows to the clipboard. */\n GridApi.prototype.copySelectedRowsToClipboard = function (params) {\n if (!this.clipboardService) {\n console.warn('AG Grid: clipboard is only available in AG Grid Enterprise');\n }\n this.clipboardService.copySelectedRowsToClipboard(params);\n };\n /** Copies the selected ranges to the clipboard. */\n GridApi.prototype.copySelectedRangeToClipboard = function (params) {\n if (!this.clipboardService) {\n console.warn('AG Grid: clipboard is only available in AG Grid Enterprise');\n }\n this.clipboardService.copySelectedRangeToClipboard(params);\n };\n /** Copies the selected range down, similar to `Ctrl + D` in Excel. */\n GridApi.prototype.copySelectedRangeDown = function () {\n if (!this.clipboardService) {\n console.warn('AG Grid: clipboard is only available in AG Grid Enterprise');\n }\n this.clipboardService.copyRangeDown();\n };\n /** Shows the column menu after and positions it relative to the provided button element. Use in conjunction with your own header template. */\n GridApi.prototype.showColumnMenuAfterButtonClick = function (colKey, buttonElement) {\n // use grid column so works with pivot mode\n var column = this.columnModel.getGridColumn(colKey);\n this.menuFactory.showMenuAfterButtonClick(column, buttonElement, 'columnMenu');\n };\n /** Shows the column menu after and positions it relative to the mouse event. Use in conjunction with your own header template. */\n GridApi.prototype.showColumnMenuAfterMouseClick = function (colKey, mouseEvent) {\n // use grid column so works with pivot mode\n var column = this.columnModel.getGridColumn(colKey);\n if (!column) {\n column = this.columnModel.getPrimaryColumn(colKey);\n }\n if (!column) {\n console.error(\"AG Grid: column '\" + colKey + \"' not found\");\n return;\n }\n this.menuFactory.showMenuAfterMouseEvent(column, mouseEvent);\n };\n /** Hides any visible context menu or column menu. */\n GridApi.prototype.hidePopupMenu = function () {\n // hide the context menu if in enterprise\n if (this.contextMenuFactory) {\n this.contextMenuFactory.hideActiveMenu();\n }\n // and hide the column menu always\n this.menuFactory.hideActiveMenu();\n };\n /** DOM element to use as the popup parent for grid popups (context menu, column menu etc). */\n GridApi.prototype.setPopupParent = function (ePopupParent) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_POPUP_PARENT, ePopupParent);\n };\n /** Navigates the grid focus to the next cell, as if tabbing. */\n GridApi.prototype.tabToNextCell = function (event) {\n return this.navigationService.tabToNextCell(false, event);\n };\n /** Navigates the grid focus to the previous cell, as if shift-tabbing. */\n GridApi.prototype.tabToPreviousCell = function (event) {\n return this.navigationService.tabToNextCell(true, event);\n };\n /** Returns the list of active cell renderer instances. */\n GridApi.prototype.getCellRendererInstances = function (params) {\n if (params === void 0) { params = {}; }\n var res = this.rowRenderer.getCellRendererInstances(params);\n var unwrapped = res.map(unwrapUserComp);\n return unwrapped;\n };\n /** Returns the list of active cell editor instances. Optionally provide parameters to restrict to certain columns / row nodes. */\n GridApi.prototype.getCellEditorInstances = function (params) {\n if (params === void 0) { params = {}; }\n var res = this.rowRenderer.getCellEditorInstances(params);\n var unwrapped = res.map(unwrapUserComp);\n return unwrapped;\n };\n /** If the grid is editing, returns back details of the editing cell(s). */\n GridApi.prototype.getEditingCells = function () {\n return this.rowRenderer.getEditingCells();\n };\n /** If a cell is editing, it stops the editing. Pass `true` if you want to cancel the editing (i.e. don't accept changes). */\n GridApi.prototype.stopEditing = function (cancel) {\n if (cancel === void 0) { cancel = false; }\n this.rowRenderer.stopEditing(cancel);\n };\n /** Start editing the provided cell. If another cell is editing, the editing will be stopped in that other cell. */\n GridApi.prototype.startEditingCell = function (params) {\n var column = this.columnModel.getGridColumn(params.colKey);\n if (!column) {\n console.warn(\"AG Grid: no column found for \" + params.colKey);\n return;\n }\n var cellPosition = {\n rowIndex: params.rowIndex,\n rowPinned: params.rowPinned || null,\n column: column\n };\n var notPinned = params.rowPinned == null;\n if (notPinned) {\n this.gridBodyCtrl.getScrollFeature().ensureIndexVisible(params.rowIndex);\n }\n var cell = this.navigationService.getCellByPosition(cellPosition);\n if (!cell) {\n return;\n }\n cell.startRowOrCellEdit(params.key, params.charPress);\n };\n /** Add an aggregation function with the specified key. */\n GridApi.prototype.addAggFunc = function (key, aggFunc) {\n if (this.aggFuncService) {\n this.aggFuncService.addAggFunc(key, aggFunc);\n }\n };\n /** Add aggregations function with the specified keys. */\n GridApi.prototype.addAggFuncs = function (aggFuncs) {\n if (this.aggFuncService) {\n this.aggFuncService.addAggFuncs(aggFuncs);\n }\n };\n /** Clears all aggregation functions (including those provided by the grid). */\n GridApi.prototype.clearAggFuncs = function () {\n if (this.aggFuncService) {\n this.aggFuncService.clear();\n }\n };\n /** Apply transactions to the server side row model. */\n GridApi.prototype.applyServerSideTransaction = function (transaction) {\n if (!this.serverSideTransactionManager) {\n console.warn('AG Grid: Cannot apply Server Side Transaction if not using the Server Side Row Model.');\n return;\n }\n return this.serverSideTransactionManager.applyTransaction(transaction);\n };\n GridApi.prototype.applyServerSideTransactionAsync = function (transaction, callback) {\n if (!this.serverSideTransactionManager) {\n console.warn('AG Grid: Cannot apply Server Side Transaction if not using the Server Side Row Model.');\n return;\n }\n return this.serverSideTransactionManager.applyTransactionAsync(transaction, callback);\n };\n /** Gets all failed server side loads to retry. */\n GridApi.prototype.retryServerSideLoads = function () {\n if (!this.serverSideRowModel) {\n console.warn('AG Grid: API retryServerSideLoads() can only be used when using Server-Side Row Model.');\n return;\n }\n this.serverSideRowModel.retryLoads();\n };\n GridApi.prototype.flushServerSideAsyncTransactions = function () {\n if (!this.serverSideTransactionManager) {\n console.warn('AG Grid: Cannot flush Server Side Transaction if not using the Server Side Row Model.');\n return;\n }\n return this.serverSideTransactionManager.flushAsyncTransactions();\n };\n /** Update row data. Pass a transaction object with lists for `add`, `remove` and `update`. */\n GridApi.prototype.applyTransaction = function (rowDataTransaction) {\n if (!this.clientSideRowModel) {\n console.error('AG Grid: updateRowData() only works with ClientSideRowModel. Working with InfiniteRowModel was deprecated in v23.1 and removed in v24.1');\n return;\n }\n var res = this.clientSideRowModel.updateRowData(rowDataTransaction);\n // refresh all the full width rows\n this.rowRenderer.refreshFullWidthRows(res.update);\n // do change detection for all present cells\n if (!this.gridOptionsWrapper.isSuppressChangeDetection()) {\n this.rowRenderer.refreshCells();\n }\n return res;\n };\n /** Sets the `deltaSort` property */\n GridApi.prototype.setDeltaSort = function (enable) {\n this.gridOptionsWrapper.setProperty('deltaSort', enable);\n };\n /** @deprecated */\n GridApi.prototype.updateRowData = function (rowDataTransaction) {\n var message = 'AG Grid: as of v23.1, grid API updateRowData(transaction) is now called applyTransaction(transaction). updateRowData is deprecated and will be removed in a future major release.';\n doOnce(function () { return console.warn(message); }, 'updateRowData deprecated');\n return this.applyTransaction(rowDataTransaction);\n };\n /** Same as `applyTransaction` except executes asynchronously for efficiency. */\n GridApi.prototype.applyTransactionAsync = function (rowDataTransaction, callback) {\n if (!this.clientSideRowModel) {\n console.error('AG Grid: api.applyTransactionAsync() only works with ClientSideRowModel.');\n return;\n }\n this.clientSideRowModel.batchUpdateRowData(rowDataTransaction, callback);\n };\n /** Executes any remaining asynchronous grid transactions, if any are waiting to be executed. */\n GridApi.prototype.flushAsyncTransactions = function () {\n if (!this.clientSideRowModel) {\n console.error('AG Grid: api.applyTransactionAsync() only works with ClientSideRowModel.');\n return;\n }\n this.clientSideRowModel.flushAsyncTransactions();\n };\n /** @deprecated */\n GridApi.prototype.batchUpdateRowData = function (rowDataTransaction, callback) {\n var message = 'AG Grid: as of v23.1, grid API batchUpdateRowData(transaction, callback) is now called applyTransactionAsync(transaction, callback). batchUpdateRowData is deprecated and will be removed in a future major release.';\n doOnce(function () { return console.warn(message); }, 'batchUpdateRowData deprecated');\n this.applyTransactionAsync(rowDataTransaction, callback);\n };\n /** @deprecated */\n GridApi.prototype.insertItemsAtIndex = function (index, items, skipRefresh) {\n if (skipRefresh === void 0) { skipRefresh = false; }\n console.warn('AG Grid: insertItemsAtIndex() is deprecated, use updateRowData(transaction) instead.');\n this.updateRowData({ add: items, addIndex: index, update: null, remove: null });\n };\n /** @deprecated */\n GridApi.prototype.removeItems = function (rowNodes, skipRefresh) {\n if (skipRefresh === void 0) { skipRefresh = false; }\n console.warn('AG Grid: removeItems() is deprecated, use updateRowData(transaction) instead.');\n var dataToRemove = rowNodes.map(function (rowNode) { return rowNode.data; });\n this.updateRowData({ add: null, addIndex: null, update: null, remove: dataToRemove });\n };\n /** @deprecated */\n GridApi.prototype.addItems = function (items, skipRefresh) {\n if (skipRefresh === void 0) { skipRefresh = false; }\n console.warn('AG Grid: addItems() is deprecated, use updateRowData(transaction) instead.');\n this.updateRowData({ add: items, addIndex: null, update: null, remove: null });\n };\n /** @deprecated */\n GridApi.prototype.refreshVirtualPageCache = function () {\n console.warn('AG Grid: refreshVirtualPageCache() is now called refreshInfiniteCache(), please call refreshInfiniteCache() instead');\n this.refreshInfiniteCache();\n };\n /** @deprecated */\n GridApi.prototype.refreshInfinitePageCache = function () {\n console.warn('AG Grid: refreshInfinitePageCache() is now called refreshInfiniteCache(), please call refreshInfiniteCache() instead');\n this.refreshInfiniteCache();\n };\n /**\n * Marks all the currently loaded blocks in the cache for reload.\n * If you have 10 blocks in the cache, all 10 will be marked for reload.\n * The old data will continue to be displayed until the new data is loaded.\n */\n GridApi.prototype.refreshInfiniteCache = function () {\n if (this.infiniteRowModel) {\n this.infiniteRowModel.refreshCache();\n }\n else {\n console.warn(\"AG Grid: api.refreshInfiniteCache is only available when rowModelType='infinite'.\");\n }\n };\n /** @deprecated */\n GridApi.prototype.purgeVirtualPageCache = function () {\n console.warn('AG Grid: purgeVirtualPageCache() is now called purgeInfiniteCache(), please call purgeInfiniteCache() instead');\n this.purgeInfinitePageCache();\n };\n /** @deprecated */\n GridApi.prototype.purgeInfinitePageCache = function () {\n console.warn('AG Grid: purgeInfinitePageCache() is now called purgeInfiniteCache(), please call purgeInfiniteCache() instead');\n this.purgeInfiniteCache();\n };\n /**\n * Purges the cache.\n * The grid is then told to refresh. Only the blocks required to display the current data on screen are fetched (typically no more than 2).\n * The grid will display nothing while the new blocks are loaded.\n * Use this to immediately remove the old data from the user.\n */\n GridApi.prototype.purgeInfiniteCache = function () {\n if (this.infiniteRowModel) {\n this.infiniteRowModel.purgeCache();\n }\n else {\n console.warn(\"AG Grid: api.purgeInfiniteCache is only available when rowModelType='infinite'.\");\n }\n };\n /** @deprecated */\n GridApi.prototype.purgeEnterpriseCache = function (route) {\n console.warn(\"ag-grid: since version 18.x, api.purgeEnterpriseCache() should be replaced with api.purgeServerSideCache()\");\n this.purgeServerSideCache(route);\n };\n /** @deprecated */\n GridApi.prototype.purgeServerSideCache = function (route) {\n if (route === void 0) { route = []; }\n if (this.serverSideRowModel) {\n console.warn(\"AG Grid: since v25.0, api.purgeServerSideCache is deprecated. Please use api.refreshServerSide({purge: true}) instead.\");\n this.refreshServerSide({\n route: route,\n purge: true\n });\n }\n else {\n console.warn(\"AG Grid: api.purgeServerSideCache is only available when rowModelType='serverSide'.\");\n }\n };\n /**\n * Refresh a server-side level.\n * If you pass no parameters, then the top level store is purged.\n * To purge a child level, pass in the string of keys to get to the desired level.\n */\n GridApi.prototype.refreshServerSide = function (params) {\n if (!this.serverSideRowModel) {\n console.warn(\"AG Grid: api.refreshServerSide is only available when rowModelType='serverSide'.\");\n }\n this.serverSideRowModel.refreshStore(params);\n };\n /** @deprecated use `refreshServerSide` instead */\n GridApi.prototype.refreshServerSideStore = function (params) {\n var message = \"AG Grid: Grid API refreshServerSideStore() was renamed to refreshServerSide() in v28.0\";\n doOnce(function () { return console.warn(message); }, 'refreshServerSideStore-renamed');\n return this.refreshServerSide(params);\n };\n /** @deprecated use `getServerSideGroupLevelState` instead */\n GridApi.prototype.getServerSideStoreState = function () {\n var message = \"AG Grid: Grid API getServerSideStoreState() was renamed to getServerSideGroupLevelState() in v28.0\";\n doOnce(function () { return console.warn(message); }, 'getServerSideStoreState-renamed');\n return this.getServerSideGroupLevelState();\n };\n /** Returns info on all server side group levels. */\n GridApi.prototype.getServerSideGroupLevelState = function () {\n if (!this.serverSideRowModel) {\n console.warn(\"AG Grid: api.getServerSideGroupLevelState is only available when rowModelType='serverSide'.\");\n return [];\n }\n return this.serverSideRowModel.getStoreState();\n };\n GridApi.prototype.getVirtualRowCount = function () {\n console.warn('AG Grid: getVirtualRowCount() is now called getInfiniteRowCount(), please call getInfiniteRowCount() instead');\n return this.getInfiniteRowCount();\n };\n /** The row count defines how many rows the grid allows scrolling to. */\n GridApi.prototype.getInfiniteRowCount = function () {\n if (this.infiniteRowModel) {\n return this.infiniteRowModel.getRowCount();\n }\n else {\n console.warn(\"AG Grid: api.getVirtualRowCount is only available when rowModelType='virtual'.\");\n }\n };\n GridApi.prototype.isMaxRowFound = function () {\n console.warn(\"AG Grid: api.isLastRowIndexKnown is deprecated, please use api.isLastRowIndexKnown()\");\n return this.isLastRowIndexKnown();\n };\n /** Returns `true` if grid allows for scrolling past the last row to load more rows, thus providing infinite scroll. */\n GridApi.prototype.isLastRowIndexKnown = function () {\n if (this.infiniteRowModel) {\n return this.infiniteRowModel.isLastRowIndexKnown();\n }\n else {\n console.warn(\"AG Grid: api.isMaxRowFound is only available when rowModelType='virtual'.\");\n }\n };\n GridApi.prototype.setVirtualRowCount = function (rowCount, maxRowFound) {\n console.warn('AG Grid: setVirtualRowCount() is now called setInfiniteRowCount(), please call setInfiniteRowCount() instead');\n this.setRowCount(rowCount, maxRowFound);\n };\n GridApi.prototype.setInfiniteRowCount = function (rowCount, maxRowFound) {\n console.warn('AG Grid: setInfiniteRowCount() is now called setRowCount(), please call setRowCount() instead');\n this.setRowCount(rowCount, maxRowFound);\n };\n /**\n * Sets the `rowCount` and `lastRowIndexKnown` properties.\n * The second parameter, `lastRowIndexKnown`, is optional and if left out, only `rowCount` is set.\n * Set `rowCount` to adjust the height of the vertical scroll.\n * Set `lastRowIndexKnown` to enable / disable searching for more rows.\n * Use this method if you add or remove rows into the dataset and need to reset the number of rows or put the data back into 'look for data' mode.\n */\n GridApi.prototype.setRowCount = function (rowCount, maxRowFound) {\n if (this.infiniteRowModel) {\n this.infiniteRowModel.setRowCount(rowCount, maxRowFound);\n }\n else {\n console.warn(\"AG Grid: api.setRowCount is only available for Infinite Row Model.\");\n }\n };\n GridApi.prototype.getVirtualPageState = function () {\n console.warn('AG Grid: getVirtualPageState() is now called getCacheBlockState(), please call getCacheBlockState() instead');\n return this.getCacheBlockState();\n };\n GridApi.prototype.getInfinitePageState = function () {\n console.warn('AG Grid: getInfinitePageState() is now called getCacheBlockState(), please call getCacheBlockState() instead');\n return this.getCacheBlockState();\n };\n /**\n * Returns an object representing the state of the cache. This is useful for debugging and understanding how the cache is working.\n */\n GridApi.prototype.getCacheBlockState = function () {\n return this.rowNodeBlockLoader.getBlockState();\n };\n GridApi.prototype.checkGridSize = function () {\n console.warn(\"in AG Grid v25.2.0, checkGridSize() was removed, as it was legacy and didn't do anything uesful.\");\n };\n GridApi.prototype.getFirstRenderedRow = function () {\n console.warn('in AG Grid v12, getFirstRenderedRow() was renamed to getFirstDisplayedRow()');\n return this.getFirstDisplayedRow();\n };\n /** Get the index of the first displayed row due to scrolling (includes invisible rendered rows in the buffer). */\n GridApi.prototype.getFirstDisplayedRow = function () {\n return this.rowRenderer.getFirstVirtualRenderedRow();\n };\n GridApi.prototype.getLastRenderedRow = function () {\n console.warn('in AG Grid v12, getLastRenderedRow() was renamed to getLastDisplayedRow()');\n return this.getLastDisplayedRow();\n };\n /** Get the index of the last displayed row due to scrolling (includes invisible rendered rows in the buffer). */\n GridApi.prototype.getLastDisplayedRow = function () {\n return this.rowRenderer.getLastVirtualRenderedRow();\n };\n /** Returns the displayed `RowNode` at the given `index`. */\n GridApi.prototype.getDisplayedRowAtIndex = function (index) {\n return this.rowModel.getRow(index);\n };\n /** Returns the total number of displayed rows. */\n GridApi.prototype.getDisplayedRowCount = function () {\n return this.rowModel.getRowCount();\n };\n /**\n * Returns `true` when the last page is known.\n * This will always be `true` if you are using the Client-Side Row Model for pagination.\n * Returns `false` when the last page is not known; this only happens when using Infinite Row Model.\n */\n GridApi.prototype.paginationIsLastPageFound = function () {\n return this.paginationProxy.isLastPageFound();\n };\n /** Returns how many rows are being shown per page. */\n GridApi.prototype.paginationGetPageSize = function () {\n return this.paginationProxy.getPageSize();\n };\n /** Sets the `paginationPageSize`, then re-paginates the grid so the changes are applied immediately. */\n GridApi.prototype.paginationSetPageSize = function (size) {\n this.gridOptionsWrapper.setProperty('paginationPageSize', size);\n };\n /** Returns the 0-based index of the page which is showing. */\n GridApi.prototype.paginationGetCurrentPage = function () {\n return this.paginationProxy.getCurrentPage();\n };\n /** Returns the total number of pages. Returns `null` if `paginationIsLastPageFound() === false`. */\n GridApi.prototype.paginationGetTotalPages = function () {\n return this.paginationProxy.getTotalPages();\n };\n /** The total number of rows. Returns `null` if `paginationIsLastPageFound() === false`. */\n GridApi.prototype.paginationGetRowCount = function () {\n return this.paginationProxy.getMasterRowCount();\n };\n /** Navigates to the next page. */\n GridApi.prototype.paginationGoToNextPage = function () {\n this.paginationProxy.goToNextPage();\n };\n /** Navigates to the previous page. */\n GridApi.prototype.paginationGoToPreviousPage = function () {\n this.paginationProxy.goToPreviousPage();\n };\n /** Navigates to the first page. */\n GridApi.prototype.paginationGoToFirstPage = function () {\n this.paginationProxy.goToFirstPage();\n };\n /** Navigates to the last page. */\n GridApi.prototype.paginationGoToLastPage = function () {\n this.paginationProxy.goToLastPage();\n };\n /** Goes to the specified page. If the page requested doesn't exist, it will go to the last page. */\n GridApi.prototype.paginationGoToPage = function (page) {\n this.paginationProxy.goToPage(page);\n };\n GridApi.prototype.setRowClass = function (className) {\n this.gridOptionsWrapper.setProperty(GridOptionsWrapper.PROP_ROW_CLASS, className);\n };\n __decorate([\n Optional('immutableService')\n ], GridApi.prototype, \"immutableService\", void 0);\n __decorate([\n Optional('csvCreator')\n ], GridApi.prototype, \"csvCreator\", void 0);\n __decorate([\n Optional('excelCreator')\n ], GridApi.prototype, \"excelCreator\", void 0);\n __decorate([\n Autowired('rowRenderer')\n ], GridApi.prototype, \"rowRenderer\", void 0);\n __decorate([\n Autowired('navigationService')\n ], GridApi.prototype, \"navigationService\", void 0);\n __decorate([\n Autowired('filterManager')\n ], GridApi.prototype, \"filterManager\", void 0);\n __decorate([\n Autowired('columnModel')\n ], GridApi.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('selectionService')\n ], GridApi.prototype, \"selectionService\", void 0);\n __decorate([\n Autowired('gridOptionsWrapper')\n ], GridApi.prototype, \"gridOptionsWrapper\", void 0);\n __decorate([\n Autowired('valueService')\n ], GridApi.prototype, \"valueService\", void 0);\n __decorate([\n Autowired('alignedGridsService')\n ], GridApi.prototype, \"alignedGridsService\", void 0);\n __decorate([\n Autowired('eventService')\n ], GridApi.prototype, \"eventService\", void 0);\n __decorate([\n Autowired('pinnedRowModel')\n ], GridApi.prototype, \"pinnedRowModel\", void 0);\n __decorate([\n Autowired('context')\n ], GridApi.prototype, \"context\", void 0);\n __decorate([\n Autowired('rowModel')\n ], GridApi.prototype, \"rowModel\", void 0);\n __decorate([\n Autowired('sortController')\n ], GridApi.prototype, \"sortController\", void 0);\n __decorate([\n Autowired('paginationProxy')\n ], GridApi.prototype, \"paginationProxy\", void 0);\n __decorate([\n Autowired('focusService')\n ], GridApi.prototype, \"focusService\", void 0);\n __decorate([\n Autowired('dragAndDropService')\n ], GridApi.prototype, \"dragAndDropService\", void 0);\n __decorate([\n Optional('rangeService')\n ], GridApi.prototype, \"rangeService\", void 0);\n __decorate([\n Optional('clipboardService')\n ], GridApi.prototype, \"clipboardService\", void 0);\n __decorate([\n Optional('aggFuncService')\n ], GridApi.prototype, \"aggFuncService\", void 0);\n __decorate([\n Autowired('menuFactory')\n ], GridApi.prototype, \"menuFactory\", void 0);\n __decorate([\n Optional('contextMenuFactory')\n ], GridApi.prototype, \"contextMenuFactory\", void 0);\n __decorate([\n Autowired('valueCache')\n ], GridApi.prototype, \"valueCache\", void 0);\n __decorate([\n Autowired('animationFrameService')\n ], GridApi.prototype, \"animationFrameService\", void 0);\n __decorate([\n Optional('statusBarService')\n ], GridApi.prototype, \"statusBarService\", void 0);\n __decorate([\n Optional('chartService')\n ], GridApi.prototype, \"chartService\", void 0);\n __decorate([\n Optional('undoRedoService')\n ], GridApi.prototype, \"undoRedoService\", void 0);\n __decorate([\n Optional('rowNodeBlockLoader')\n ], GridApi.prototype, \"rowNodeBlockLoader\", void 0);\n __decorate([\n Optional('ssrmTransactionManager')\n ], GridApi.prototype, \"serverSideTransactionManager\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], GridApi.prototype, \"ctrlsService\", void 0);\n __decorate([\n Optional('frameworkComponentWrapper')\n ], GridApi.prototype, \"frameworkComponentWrapper\", void 0);\n __decorate([\n PostConstruct\n ], GridApi.prototype, \"init\", null);\n __decorate([\n PreDestroy\n ], GridApi.prototype, \"cleanDownReferencesToAvoidMemoryLeakInCaseApplicationIsKeepingReferenceToDestroyedGrid\", null);\n GridApi = __decorate([\n Bean('gridApi')\n ], GridApi);\n return GridApi;\n}());\nexport { GridApi };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Column } from \"../../entities/column\";\nimport { BeanStub } from \"../../context/beanStub\";\nimport { Constants } from \"../../constants/constants\";\nimport { PostConstruct } from \"../../context/context\";\nimport { setAriaColIndex, setAriaColSpan } from \"../../utils/aria\";\nimport { last } from \"../../utils/array\";\nimport { exists } from \"../../utils/generic\";\nimport { Events } from \"../../eventKeys\";\nimport { GridOptionsWrapper } from \"../../gridOptionsWrapper\";\nvar SetLeftFeature = /** @class */ (function (_super) {\n __extends(SetLeftFeature, _super);\n function SetLeftFeature(columnOrGroup, eCell, beans, colsSpanning) {\n var _this = _super.call(this) || this;\n _this.columnOrGroup = columnOrGroup;\n _this.eCell = eCell;\n _this.ariaEl = _this.eCell.querySelector('[role=columnheader]') || _this.eCell;\n _this.colsSpanning = colsSpanning;\n _this.beans = beans;\n return _this;\n }\n SetLeftFeature.prototype.setColsSpanning = function (colsSpanning) {\n this.colsSpanning = colsSpanning;\n this.onLeftChanged();\n };\n SetLeftFeature.prototype.getColumnOrGroup = function () {\n if (this.beans.gridOptionsWrapper.isEnableRtl() && this.colsSpanning) {\n return last(this.colsSpanning);\n }\n return this.columnOrGroup;\n };\n SetLeftFeature.prototype.postConstruct = function () {\n this.addManagedListener(this.columnOrGroup, Column.EVENT_LEFT_CHANGED, this.onLeftChanged.bind(this));\n this.setLeftFirstTime();\n // when in print layout, the left position is also dependent on the width of the pinned sections.\n // so additionally update left if any column width changes.\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, this.onLeftChanged.bind(this));\n // setting left has a dependency on print layout\n this.addManagedListener(this.beans.gridOptionsWrapper, GridOptionsWrapper.PROP_DOM_LAYOUT, this.onLeftChanged.bind(this));\n };\n SetLeftFeature.prototype.setLeftFirstTime = function () {\n var suppressMoveAnimation = this.beans.gridOptionsWrapper.isSuppressColumnMoveAnimation();\n var oldLeftExists = exists(this.columnOrGroup.getOldLeft());\n var animateColumnMove = this.beans.columnAnimationService.isActive() && oldLeftExists && !suppressMoveAnimation;\n if (animateColumnMove) {\n this.animateInLeft();\n }\n else {\n this.onLeftChanged();\n }\n };\n SetLeftFeature.prototype.animateInLeft = function () {\n var _this = this;\n var colOrGroup = this.getColumnOrGroup();\n var left = colOrGroup.getLeft();\n var oldLeft = colOrGroup.getOldLeft();\n var oldActualLeft = this.modifyLeftForPrintLayout(colOrGroup, oldLeft);\n var actualLeft = this.modifyLeftForPrintLayout(colOrGroup, left);\n this.setLeft(oldActualLeft);\n // we must keep track of the left we want to set to, as this would otherwise lead to a race\n // condition, if the user changed the left value many times in one VM turn, then we want to make\n // make sure the actualLeft we set in the timeout below (in the next VM turn) is the correct left\n // position. eg if user changes column position twice, then setLeft() below executes twice in next\n // VM turn, but only one (the correct one) should get applied.\n this.actualLeft = actualLeft;\n this.beans.columnAnimationService.executeNextVMTurn(function () {\n // test this left value is the latest one to be applied, and if not, do nothing\n if (_this.actualLeft === actualLeft) {\n _this.setLeft(actualLeft);\n }\n });\n };\n SetLeftFeature.prototype.onLeftChanged = function () {\n var colOrGroup = this.getColumnOrGroup();\n var left = colOrGroup.getLeft();\n this.actualLeft = this.modifyLeftForPrintLayout(colOrGroup, left);\n this.setLeft(this.actualLeft);\n };\n SetLeftFeature.prototype.modifyLeftForPrintLayout = function (colOrGroup, leftPosition) {\n var printLayout = this.beans.gridOptionsWrapper.getDomLayout() === Constants.DOM_LAYOUT_PRINT;\n if (!printLayout) {\n return leftPosition;\n }\n if (colOrGroup.getPinned() === Constants.PINNED_LEFT) {\n return leftPosition;\n }\n var leftWidth = this.beans.columnModel.getDisplayedColumnsLeftWidth();\n if (colOrGroup.getPinned() === Constants.PINNED_RIGHT) {\n var bodyWidth = this.beans.columnModel.getBodyContainerWidth();\n return leftWidth + bodyWidth + leftPosition;\n }\n // is in body\n return leftWidth + leftPosition;\n };\n SetLeftFeature.prototype.setLeft = function (value) {\n // if the value is null, then that means the column is no longer\n // displayed. there is logic in the rendering to fade these columns\n // out, so we don't try and change their left positions.\n if (exists(value)) {\n this.eCell.style.left = value + \"px\";\n }\n var indexColumn;\n if (this.columnOrGroup instanceof Column) {\n indexColumn = this.columnOrGroup;\n }\n else {\n var columnGroup = this.columnOrGroup;\n var children = columnGroup.getLeafColumns();\n if (!children.length) {\n return;\n }\n if (children.length > 1) {\n setAriaColSpan(this.ariaEl, children.length);\n }\n indexColumn = children[0];\n }\n var index = this.beans.columnModel.getAriaColumnIndex(indexColumn);\n setAriaColIndex(this.ariaEl, index);\n };\n __decorate([\n PostConstruct\n ], SetLeftFeature.prototype, \"postConstruct\", null);\n return SetLeftFeature;\n}(BeanStub));\nexport { SetLeftFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub\";\nimport { Autowired, PostConstruct } from \"../../context/context\";\nvar HoverFeature = /** @class */ (function (_super) {\n __extends(HoverFeature, _super);\n function HoverFeature(columns, element) {\n var _this = _super.call(this) || this;\n _this.columns = columns;\n _this.element = element;\n return _this;\n }\n HoverFeature.prototype.postConstruct = function () {\n if (this.gridOptionsWrapper.isColumnHoverHighlight()) {\n this.addMouseHoverListeners();\n }\n };\n HoverFeature.prototype.addMouseHoverListeners = function () {\n this.addManagedListener(this.element, 'mouseout', this.onMouseOut.bind(this));\n this.addManagedListener(this.element, 'mouseover', this.onMouseOver.bind(this));\n };\n HoverFeature.prototype.onMouseOut = function () {\n this.columnHoverService.clearMouseOver();\n };\n HoverFeature.prototype.onMouseOver = function () {\n this.columnHoverService.setMouseOver(this.columns);\n };\n __decorate([\n Autowired('columnHoverService')\n ], HoverFeature.prototype, \"columnHoverService\", void 0);\n __decorate([\n PostConstruct\n ], HoverFeature.prototype, \"postConstruct\", null);\n return HoverFeature;\n}(BeanStub));\nexport { HoverFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { AbstractHeaderCellCtrl } from \"../abstractCell/abstractHeaderCellCtrl\";\nimport { KeyCode } from '../../../constants/keyCode';\nimport { Autowired } from '../../../context/context';\nimport { Column } from '../../../entities/column';\nimport { Events } from '../../../events';\nimport { unwrapUserComp } from '../../../gridApi';\nimport { SetLeftFeature } from '../../../rendering/features/setLeftFeature';\nimport { isElementChildOfClass } from '../../../utils/dom';\nimport { createIconNoSpan } from '../../../utils/icon';\nimport { ManagedFocusFeature } from '../../../widgets/managedFocusFeature';\nimport { HoverFeature } from '../hoverFeature';\nimport { FilterComponent } from \"../../../components/framework/componentTypes\";\nvar HeaderFilterCellCtrl = /** @class */ (function (_super) {\n __extends(HeaderFilterCellCtrl, _super);\n function HeaderFilterCellCtrl(column, parentRowCtrl) {\n var _this = _super.call(this, column, parentRowCtrl) || this;\n _this.column = column;\n return _this;\n }\n HeaderFilterCellCtrl.prototype.setComp = function (comp, eGui, eButtonShowMainFilter, eFloatingFilterBody) {\n _super.prototype.setGui.call(this, eGui);\n this.comp = comp;\n this.eButtonShowMainFilter = eButtonShowMainFilter;\n this.eFloatingFilterBody = eFloatingFilterBody;\n var colDef = this.column.getColDef();\n var filterExists = !!colDef.filter || !!colDef.filterFramework;\n var floatingFilterExists = !!colDef.floatingFilter;\n this.active = filterExists && floatingFilterExists;\n this.setupWidth();\n this.setupLeft();\n this.setupHover();\n this.setupFocus();\n this.setupUserComp();\n this.setupSyncWithFilter();\n this.setupUi();\n this.addManagedListener(this.eButtonShowMainFilter, 'click', this.showParentFilter.bind(this));\n };\n HeaderFilterCellCtrl.prototype.setupUi = function () {\n this.comp.addOrRemoveButtonWrapperCssClass('ag-hidden', !this.active || this.suppressFilterButton);\n if (!this.active) {\n return;\n }\n this.comp.addOrRemoveBodyCssClass('ag-floating-filter-full-body', this.suppressFilterButton);\n this.comp.addOrRemoveBodyCssClass('ag-floating-filter-body', !this.suppressFilterButton);\n var eMenuIcon = createIconNoSpan('filter', this.gridOptionsWrapper, this.column);\n if (eMenuIcon) {\n this.eButtonShowMainFilter.appendChild(eMenuIcon);\n }\n };\n HeaderFilterCellCtrl.prototype.setupFocus = function () {\n this.createManagedBean(new ManagedFocusFeature(this.eGui, {\n shouldStopEventPropagation: this.shouldStopEventPropagation.bind(this),\n onTabKeyDown: this.onTabKeyDown.bind(this),\n handleKeyDown: this.handleKeyDown.bind(this),\n onFocusIn: this.onFocusIn.bind(this)\n }));\n };\n HeaderFilterCellCtrl.prototype.onTabKeyDown = function (e) {\n var eDocument = this.gridOptionsWrapper.getDocument();\n var activeEl = eDocument.activeElement;\n var wrapperHasFocus = activeEl === this.eGui;\n if (wrapperHasFocus) {\n return;\n }\n var nextFocusableEl = this.focusService.findNextFocusableElement(this.eGui, null, e.shiftKey);\n if (nextFocusableEl) {\n this.beans.headerNavigationService.scrollToColumn(this.column);\n e.preventDefault();\n nextFocusableEl.focus();\n return;\n }\n var nextFocusableColumn = this.findNextColumnWithFloatingFilter(e.shiftKey);\n if (!nextFocusableColumn) {\n return;\n }\n if (this.focusService.focusHeaderPosition({\n headerPosition: {\n headerRowIndex: this.getParentRowCtrl().getRowIndex(),\n column: nextFocusableColumn\n },\n event: e\n })) {\n e.preventDefault();\n }\n };\n HeaderFilterCellCtrl.prototype.findNextColumnWithFloatingFilter = function (backwards) {\n var columModel = this.beans.columnModel;\n var nextCol = this.column;\n do {\n nextCol = backwards\n ? columModel.getDisplayedColBefore(nextCol)\n : columModel.getDisplayedColAfter(nextCol);\n if (!nextCol) {\n break;\n }\n } while (!nextCol.getColDef().filter || !nextCol.getColDef().floatingFilter);\n return nextCol;\n };\n HeaderFilterCellCtrl.prototype.handleKeyDown = function (e) {\n _super.prototype.handleKeyDown.call(this, e);\n var wrapperHasFocus = this.getWrapperHasFocus();\n switch (e.key) {\n case KeyCode.UP:\n case KeyCode.DOWN:\n if (!wrapperHasFocus) {\n e.preventDefault();\n }\n case KeyCode.LEFT:\n case KeyCode.RIGHT:\n if (wrapperHasFocus) {\n return;\n }\n e.stopPropagation();\n case KeyCode.ENTER:\n if (wrapperHasFocus) {\n if (this.focusService.focusInto(this.eGui)) {\n e.preventDefault();\n }\n }\n break;\n case KeyCode.ESCAPE:\n if (!wrapperHasFocus) {\n this.eGui.focus();\n }\n }\n };\n HeaderFilterCellCtrl.prototype.onFocusIn = function (e) {\n var isRelatedWithin = this.eGui.contains(e.relatedTarget);\n // when the focus is already within the component,\n // we default to the browser's behavior\n if (isRelatedWithin) {\n return;\n }\n var notFromHeaderWrapper = !!e.relatedTarget && !e.relatedTarget.classList.contains('ag-floating-filter');\n var fromWithinHeader = !!e.relatedTarget && isElementChildOfClass(e.relatedTarget, 'ag-floating-filter');\n if (notFromHeaderWrapper && fromWithinHeader && e.target === this.eGui) {\n var lastFocusEvent = this.lastFocusEvent;\n var fromTab = !!(lastFocusEvent && lastFocusEvent.key === KeyCode.TAB);\n if (lastFocusEvent && fromTab) {\n var shouldFocusLast = lastFocusEvent.shiftKey;\n this.focusService.focusInto(this.eGui, shouldFocusLast);\n }\n }\n var rowIndex = this.getRowIndex();\n this.beans.focusService.setFocusedHeader(rowIndex, this.column);\n };\n HeaderFilterCellCtrl.prototype.setupHover = function () {\n var _this = this;\n this.createManagedBean(new HoverFeature([this.column], this.eGui));\n var listener = function () {\n if (!_this.gridOptionsWrapper.isColumnHoverHighlight()) {\n return;\n }\n var hovered = _this.columnHoverService.isHovered(_this.column);\n _this.comp.addOrRemoveCssClass('ag-column-hover', hovered);\n };\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_HOVER_CHANGED, listener);\n listener();\n };\n HeaderFilterCellCtrl.prototype.setupLeft = function () {\n var setLeftFeature = new SetLeftFeature(this.column, this.eGui, this.beans);\n this.createManagedBean(setLeftFeature);\n };\n HeaderFilterCellCtrl.prototype.setupUserComp = function () {\n var _this = this;\n if (!this.active) {\n return;\n }\n var colDef = this.column.getColDef();\n var filterParams = this.filterManager.createFilterParams(this.column, colDef);\n var finalFilterParams = this.userComponentFactory.mergeParamsWithApplicationProvidedParams(colDef, FilterComponent, filterParams);\n var defaultFloatingFilterType = this.userComponentFactory.getDefaultFloatingFilterType(colDef);\n if (defaultFloatingFilterType == null) {\n defaultFloatingFilterType = 'agReadOnlyFloatingFilter';\n }\n var params = {\n column: this.column,\n filterParams: finalFilterParams,\n currentParentModel: function () { return _this.currentParentModel(); },\n parentFilterInstance: function (cb) { return _this.parentFilterInstance(cb); },\n showParentFilter: function () { return _this.showParentFilter(); },\n suppressFilterButton: false // This one might be overridden from the colDef\n };\n // this is unusual - we need a params value OUTSIDE the component the params are for.\n // the params are for the floating filter component, but this property is actually for the wrapper.\n this.suppressFilterButton = colDef.floatingFilterComponentParams ? !!colDef.floatingFilterComponentParams.suppressFilterButton : false;\n var compDetails = this.userComponentFactory.getFloatingFilterCompDetails(colDef, params, defaultFloatingFilterType);\n if (compDetails) {\n this.comp.setCompDetails(compDetails);\n }\n };\n HeaderFilterCellCtrl.prototype.currentParentModel = function () {\n var filterComponent = this.getFilterComponent(false);\n return filterComponent ? filterComponent.resolveNow(null, function (filter) { return filter && filter.getModel(); }) : null;\n };\n HeaderFilterCellCtrl.prototype.getFilterComponent = function (createIfDoesNotExist) {\n if (createIfDoesNotExist === void 0) { createIfDoesNotExist = true; }\n return this.filterManager.getFilterComponent(this.column, 'NO_UI', createIfDoesNotExist);\n };\n HeaderFilterCellCtrl.prototype.parentFilterInstance = function (callback) {\n var filterComponent = this.getFilterComponent();\n if (filterComponent == null) {\n return;\n }\n filterComponent.then(function (instance) {\n callback(unwrapUserComp(instance));\n });\n };\n HeaderFilterCellCtrl.prototype.showParentFilter = function () {\n var eventSource = this.suppressFilterButton ? this.eFloatingFilterBody : this.eButtonShowMainFilter;\n this.menuFactory.showMenuAfterButtonClick(this.column, eventSource, 'floatingFilter', 'filterMenuTab', ['filterMenuTab']);\n };\n HeaderFilterCellCtrl.prototype.setupSyncWithFilter = function () {\n var _this = this;\n if (!this.active) {\n return;\n }\n var syncWithFilter = function (filterChangedEvent) {\n var compPromise = _this.comp.getFloatingFilterComp();\n if (!compPromise) {\n return;\n }\n var parentModel = _this.currentParentModel();\n compPromise.then(function (comp) {\n if (comp) {\n comp.onParentModelChanged(parentModel, filterChangedEvent);\n }\n });\n };\n this.addManagedListener(this.column, Column.EVENT_FILTER_CHANGED, syncWithFilter);\n if (this.filterManager.isFilterActive(this.column)) {\n syncWithFilter(null);\n }\n };\n HeaderFilterCellCtrl.prototype.setupWidth = function () {\n var _this = this;\n var listener = function () {\n var width = _this.column.getActualWidth() + \"px\";\n _this.comp.setWidth(width);\n };\n this.addManagedListener(this.column, Column.EVENT_WIDTH_CHANGED, listener);\n listener();\n };\n __decorate([\n Autowired('filterManager')\n ], HeaderFilterCellCtrl.prototype, \"filterManager\", void 0);\n __decorate([\n Autowired('columnHoverService')\n ], HeaderFilterCellCtrl.prototype, \"columnHoverService\", void 0);\n __decorate([\n Autowired('menuFactory')\n ], HeaderFilterCellCtrl.prototype, \"menuFactory\", void 0);\n return HeaderFilterCellCtrl;\n}(AbstractHeaderCellCtrl));\nexport { HeaderFilterCellCtrl };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Constants } from \"../../../constants/constants\";\nimport { BeanStub } from \"../../../context/beanStub\";\nimport { Autowired, PostConstruct } from \"../../../context/context\";\nimport { setDisplayed } from \"../../../utils/dom\";\nimport { TouchListener } from \"../../../widgets/touchListener\";\nvar ResizeFeature = /** @class */ (function (_super) {\n __extends(ResizeFeature, _super);\n function ResizeFeature(pinned, column, eResize, comp, ctrl) {\n var _this = _super.call(this) || this;\n _this.pinned = pinned;\n _this.column = column;\n _this.eResize = eResize;\n _this.comp = comp;\n _this.ctrl = ctrl;\n return _this;\n }\n ResizeFeature.prototype.postConstruct = function () {\n var _this = this;\n var colDef = this.column.getColDef();\n var destroyResizeFuncs = [];\n var canResize;\n var canAutosize;\n var addResize = function () {\n setDisplayed(_this.eResize, canResize);\n if (!canResize) {\n return;\n }\n var finishedWithResizeFunc = _this.horizontalResizeService.addResizeBar({\n eResizeBar: _this.eResize,\n onResizeStart: _this.onResizeStart.bind(_this),\n onResizing: _this.onResizing.bind(_this, false),\n onResizeEnd: _this.onResizing.bind(_this, true)\n });\n destroyResizeFuncs.push(finishedWithResizeFunc);\n if (canAutosize) {\n var skipHeaderOnAutoSize_1 = _this.gridOptionsWrapper.isSkipHeaderOnAutoSize();\n var autoSizeColListener_1 = function () {\n _this.columnModel.autoSizeColumn(_this.column, skipHeaderOnAutoSize_1, \"uiColumnResized\");\n };\n _this.eResize.addEventListener('dblclick', autoSizeColListener_1);\n var touchListener_1 = new TouchListener(_this.eResize);\n touchListener_1.addEventListener(TouchListener.EVENT_DOUBLE_TAP, autoSizeColListener_1);\n _this.addDestroyFunc(function () {\n _this.eResize.removeEventListener('dblclick', autoSizeColListener_1);\n touchListener_1.removeEventListener(TouchListener.EVENT_DOUBLE_TAP, autoSizeColListener_1);\n touchListener_1.destroy();\n });\n }\n };\n var removeResize = function () {\n destroyResizeFuncs.forEach(function (f) { return f(); });\n destroyResizeFuncs.length = 0;\n };\n var refresh = function () {\n var resize = _this.column.isResizable();\n var autoSize = !_this.gridOptionsWrapper.isSuppressAutoSize() && !colDef.suppressAutoSize;\n var propertyChange = resize !== canResize || autoSize !== canAutosize;\n if (propertyChange) {\n canResize = resize;\n canAutosize = autoSize;\n removeResize();\n addResize();\n }\n };\n refresh();\n this.addDestroyFunc(removeResize);\n this.ctrl.addRefreshFunction(refresh);\n };\n ResizeFeature.prototype.onResizing = function (finished, resizeAmount) {\n var resizeAmountNormalised = this.normaliseResizeAmount(resizeAmount);\n var columnWidths = [{ key: this.column, newWidth: this.resizeStartWidth + resizeAmountNormalised }];\n this.columnModel.setColumnWidths(columnWidths, this.resizeWithShiftKey, finished, \"uiColumnDragged\");\n if (finished) {\n this.comp.addOrRemoveCssClass('ag-column-resizing', false);\n }\n };\n ResizeFeature.prototype.onResizeStart = function (shiftKey) {\n this.resizeStartWidth = this.column.getActualWidth();\n this.resizeWithShiftKey = shiftKey;\n this.comp.addOrRemoveCssClass('ag-column-resizing', true);\n };\n // optionally inverts the drag, depending on pinned and RTL\n // note - this method is duplicated in RenderedHeaderGroupCell - should refactor out?\n ResizeFeature.prototype.normaliseResizeAmount = function (dragChange) {\n var result = dragChange;\n var notPinningLeft = this.pinned !== Constants.PINNED_LEFT;\n var pinningRight = this.pinned === Constants.PINNED_RIGHT;\n if (this.gridOptionsWrapper.isEnableRtl()) {\n // for RTL, dragging left makes the col bigger, except when pinning left\n if (notPinningLeft) {\n result *= -1;\n }\n }\n else {\n // for LTR (ie normal), dragging left makes the col smaller, except when pinning right\n if (pinningRight) {\n result *= -1;\n }\n }\n return result;\n };\n __decorate([\n Autowired('horizontalResizeService')\n ], ResizeFeature.prototype, \"horizontalResizeService\", void 0);\n __decorate([\n Autowired('columnModel')\n ], ResizeFeature.prototype, \"columnModel\", void 0);\n __decorate([\n PostConstruct\n ], ResizeFeature.prototype, \"postConstruct\", null);\n return ResizeFeature;\n}(BeanStub));\nexport { ResizeFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { Events } from \"../events\";\nimport { AgAbstractInputField } from './agAbstractInputField';\nvar AgCheckbox = /** @class */ (function (_super) {\n __extends(AgCheckbox, _super);\n function AgCheckbox(config, className, inputType) {\n if (className === void 0) { className = 'ag-checkbox'; }\n if (inputType === void 0) { inputType = 'checkbox'; }\n var _this = _super.call(this, config, className, inputType) || this;\n _this.labelAlignment = 'right';\n _this.selected = false;\n _this.readOnly = false;\n _this.passive = false;\n return _this;\n }\n AgCheckbox.prototype.addInputListeners = function () {\n this.addManagedListener(this.eInput, 'click', this.onCheckboxClick.bind(this));\n this.addManagedListener(this.eLabel, 'click', this.toggle.bind(this));\n };\n AgCheckbox.prototype.getNextValue = function () {\n return this.selected === undefined ? true : !this.selected;\n };\n AgCheckbox.prototype.setPassive = function (passive) {\n this.passive = passive;\n };\n AgCheckbox.prototype.isReadOnly = function () {\n return this.readOnly;\n };\n AgCheckbox.prototype.setReadOnly = function (readOnly) {\n this.eWrapper.classList.toggle('ag-disabled', readOnly);\n this.eInput.disabled = readOnly;\n this.readOnly = readOnly;\n };\n AgCheckbox.prototype.setDisabled = function (disabled) {\n this.eWrapper.classList.toggle('ag-disabled', disabled);\n return _super.prototype.setDisabled.call(this, disabled);\n };\n AgCheckbox.prototype.toggle = function () {\n if (this.eInput.disabled) {\n return;\n }\n var previousValue = this.isSelected();\n var nextValue = this.getNextValue();\n if (this.passive) {\n this.dispatchChange(nextValue, previousValue);\n }\n else {\n this.setValue(nextValue);\n }\n };\n AgCheckbox.prototype.getValue = function () {\n return this.isSelected();\n };\n AgCheckbox.prototype.setValue = function (value, silent) {\n this.refreshSelectedClass(value);\n this.setSelected(value, silent);\n return this;\n };\n AgCheckbox.prototype.setName = function (name) {\n var input = this.getInputElement();\n input.name = name;\n return this;\n };\n AgCheckbox.prototype.isSelected = function () {\n return this.selected;\n };\n AgCheckbox.prototype.setSelected = function (selected, silent) {\n if (this.isSelected() === selected) {\n return;\n }\n this.previousValue = this.isSelected();\n selected = this.selected = typeof selected === 'boolean' ? selected : undefined;\n this.eInput.checked = selected;\n this.eInput.indeterminate = selected === undefined;\n if (!silent) {\n this.dispatchChange(this.selected, this.previousValue);\n }\n };\n AgCheckbox.prototype.dispatchChange = function (selected, previousValue, event) {\n this.dispatchEvent({ type: AgCheckbox.EVENT_CHANGED, selected: selected, previousValue: previousValue, event: event });\n var input = this.getInputElement();\n var checkboxChangedEvent = {\n type: Events.EVENT_CHECKBOX_CHANGED,\n id: input.id,\n name: input.name,\n selected: selected,\n previousValue: previousValue\n };\n this.eventService.dispatchEvent(checkboxChangedEvent);\n };\n AgCheckbox.prototype.onCheckboxClick = function (e) {\n if (this.passive || this.eInput.disabled) {\n return;\n }\n var previousValue = this.isSelected();\n var selected = this.selected = e.target.checked;\n this.refreshSelectedClass(selected);\n this.dispatchChange(selected, previousValue, e);\n };\n AgCheckbox.prototype.refreshSelectedClass = function (value) {\n this.eWrapper.classList.toggle('ag-checked', value === true);\n this.eWrapper.classList.toggle('ag-indeterminate', value == null);\n };\n return AgCheckbox;\n}(AgAbstractInputField));\nexport { AgCheckbox };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { AgCheckbox } from \"../../../widgets/agCheckbox\";\nimport { BeanStub } from \"../../../context/beanStub\";\nimport { Autowired } from \"../../../context/context\";\nimport { Events } from \"../../../events\";\nimport { Constants } from \"../../../constants/constants\";\nimport { setAriaRole } from \"../../../utils/aria\";\nvar SelectAllFeature = /** @class */ (function (_super) {\n __extends(SelectAllFeature, _super);\n function SelectAllFeature(column) {\n var _this = _super.call(this) || this;\n _this.cbSelectAllVisible = false;\n _this.processingEventFromCheckbox = false;\n _this.column = column;\n var colDef = column.getColDef();\n _this.filteredOnly = colDef ? !!colDef.headerCheckboxSelectionFilteredOnly : false;\n return _this;\n }\n SelectAllFeature.prototype.onSpaceKeyPressed = function (e) {\n var checkbox = this.cbSelectAll;\n var eDocument = this.gridOptionsWrapper.getDocument();\n if (checkbox.isDisplayed() && !checkbox.getGui().contains(eDocument.activeElement)) {\n e.preventDefault();\n checkbox.setValue(!checkbox.getValue());\n }\n };\n SelectAllFeature.prototype.getCheckboxGui = function () {\n return this.cbSelectAll.getGui();\n };\n SelectAllFeature.prototype.setComp = function (ctrl) {\n this.headerCellCtrl = ctrl;\n this.cbSelectAll = this.createManagedBean(new AgCheckbox());\n this.cbSelectAll.addCssClass('ag-header-select-all');\n setAriaRole(this.cbSelectAll.getGui(), 'presentation');\n this.showOrHideSelectAll();\n this.addManagedListener(this.eventService, Events.EVENT_NEW_COLUMNS_LOADED, this.showOrHideSelectAll.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, this.showOrHideSelectAll.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_SELECTION_CHANGED, this.onSelectionChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_MODEL_UPDATED, this.onModelChanged.bind(this));\n this.addManagedListener(this.cbSelectAll, AgCheckbox.EVENT_CHANGED, this.onCbSelectAll.bind(this));\n this.cbSelectAll.getInputElement().setAttribute('tabindex', '-1');\n this.refreshSelectAllLabel();\n };\n SelectAllFeature.prototype.showOrHideSelectAll = function () {\n this.cbSelectAllVisible = this.isCheckboxSelection();\n this.cbSelectAll.setDisplayed(this.cbSelectAllVisible);\n if (this.cbSelectAllVisible) {\n // in case user is trying this feature with the wrong model type\n this.checkRightRowModelType();\n // make sure checkbox is showing the right state\n this.updateStateOfCheckbox();\n }\n this.refreshSelectAllLabel();\n };\n SelectAllFeature.prototype.onModelChanged = function () {\n if (!this.cbSelectAllVisible) {\n return;\n }\n this.updateStateOfCheckbox();\n };\n SelectAllFeature.prototype.onSelectionChanged = function () {\n if (!this.cbSelectAllVisible) {\n return;\n }\n this.updateStateOfCheckbox();\n };\n SelectAllFeature.prototype.getNextCheckboxState = function (selectionCount) {\n // if no rows, always have it unselected\n if (selectionCount.selected === 0 && selectionCount.notSelected === 0) {\n return false;\n }\n // if mix of selected and unselected, this is the tri-state\n if (selectionCount.selected > 0 && selectionCount.notSelected > 0) {\n return null;\n }\n // only selected\n if (selectionCount.selected > 0) {\n return true;\n }\n // nothing selected\n return false;\n };\n SelectAllFeature.prototype.updateStateOfCheckbox = function () {\n if (this.processingEventFromCheckbox) {\n return;\n }\n this.processingEventFromCheckbox = true;\n var selectionCount = this.getSelectionCount();\n var allSelected = this.getNextCheckboxState(selectionCount);\n this.cbSelectAll.setValue(allSelected);\n this.refreshSelectAllLabel();\n this.processingEventFromCheckbox = false;\n };\n SelectAllFeature.prototype.refreshSelectAllLabel = function () {\n if (!this.cbSelectAllVisible) {\n this.headerCellCtrl.setAriaDescriptionProperty('selectAll', null);\n }\n else {\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n var checked = this.cbSelectAll.getValue();\n var ariaStatus = checked ? translate('ariaChecked', 'checked') : translate('ariaUnchecked', 'unchecked');\n var ariaLabel = translate('ariaRowSelectAll', 'Press Space to toggle all rows selection');\n this.headerCellCtrl.setAriaDescriptionProperty('selectAll', ariaLabel + \" (\" + ariaStatus + \")\");\n }\n this.headerCellCtrl.refreshAriaDescription();\n };\n SelectAllFeature.prototype.getSelectionCount = function () {\n var _this = this;\n var selectedCount = 0;\n var notSelectedCount = 0;\n var callback = function (node) {\n if (_this.gridOptionsWrapper.isGroupSelectsChildren() && node.group) {\n return;\n }\n if (node.isSelected()) {\n selectedCount++;\n }\n else if (!node.selectable) {\n // don't count non-selectable nodes!\n }\n else {\n notSelectedCount++;\n }\n };\n if (this.filteredOnly) {\n this.gridApi.forEachNodeAfterFilter(callback);\n }\n else {\n this.gridApi.forEachNode(callback);\n }\n return {\n notSelected: notSelectedCount,\n selected: selectedCount\n };\n };\n SelectAllFeature.prototype.checkRightRowModelType = function () {\n var rowModelType = this.rowModel.getType();\n var rowModelMatches = rowModelType === Constants.ROW_MODEL_TYPE_CLIENT_SIDE;\n if (!rowModelMatches) {\n console.warn(\"AG Grid: selectAllCheckbox is only available if using normal row model, you are using \" + rowModelType);\n }\n };\n SelectAllFeature.prototype.onCbSelectAll = function () {\n if (this.processingEventFromCheckbox) {\n return;\n }\n if (!this.cbSelectAllVisible) {\n return;\n }\n var value = this.cbSelectAll.getValue();\n if (value) {\n this.selectionService.selectAllRowNodes(this.filteredOnly);\n }\n else {\n this.selectionService.deselectAllRowNodes(this.filteredOnly);\n }\n };\n SelectAllFeature.prototype.isCheckboxSelection = function () {\n var result = this.column.getColDef().headerCheckboxSelection;\n if (typeof result === 'function') {\n var func = result;\n var params = {\n column: this.column,\n colDef: this.column.getColDef(),\n columnApi: this.columnApi,\n api: this.gridApi,\n context: this.gridOptionsWrapper.getContext()\n };\n result = func(params);\n }\n if (result) {\n if (this.gridOptionsWrapper.isRowModelServerSide()) {\n console.warn('AG Grid: headerCheckboxSelection is not supported for Server Side Row Model');\n return false;\n }\n if (this.gridOptionsWrapper.isRowModelInfinite()) {\n console.warn('AG Grid: headerCheckboxSelection is not supported for Infinite Row Model');\n return false;\n }\n if (this.gridOptionsWrapper.isRowModelViewport()) {\n console.warn('AG Grid: headerCheckboxSelection is not supported for Viewport Row Model');\n return false;\n }\n // otherwise the row model is compatible, so return true\n return true;\n }\n return false;\n };\n __decorate([\n Autowired('gridApi')\n ], SelectAllFeature.prototype, \"gridApi\", void 0);\n __decorate([\n Autowired('columnApi')\n ], SelectAllFeature.prototype, \"columnApi\", void 0);\n __decorate([\n Autowired('rowModel')\n ], SelectAllFeature.prototype, \"rowModel\", void 0);\n __decorate([\n Autowired('selectionService')\n ], SelectAllFeature.prototype, \"selectionService\", void 0);\n return SelectAllFeature;\n}(BeanStub));\nexport { SelectAllFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { KeyCode } from '../../../constants/keyCode';\nimport { Autowired, PreDestroy } from \"../../../context/context\";\nimport { DragAndDropService, DragSourceType } from \"../../../dragAndDrop/dragAndDropService\";\nimport { Column } from \"../../../entities/column\";\nimport { Events } from \"../../../eventKeys\";\nimport { SetLeftFeature } from \"../../../rendering/features/setLeftFeature\";\nimport { getAriaSortState } from \"../../../utils/aria\";\nimport { ManagedFocusFeature } from \"../../../widgets/managedFocusFeature\";\nimport { TooltipFeature } from \"../../../widgets/tooltipFeature\";\nimport { AbstractHeaderCellCtrl } from \"../abstractCell/abstractHeaderCellCtrl\";\nimport { CssClassApplier } from \"../cssClassApplier\";\nimport { HoverFeature } from \"../hoverFeature\";\nimport { ResizeFeature } from \"./resizeFeature\";\nimport { SelectAllFeature } from \"./selectAllFeature\";\nimport { getElementSize } from \"../../../utils/dom\";\nvar HeaderCellCtrl = /** @class */ (function (_super) {\n __extends(HeaderCellCtrl, _super);\n function HeaderCellCtrl(column, parentRowCtrl) {\n var _this = _super.call(this, column, parentRowCtrl) || this;\n _this.refreshFunctions = [];\n _this.userHeaderClasses = new Set();\n _this.ariaDescriptionProperties = new Map();\n _this.column = column;\n return _this;\n }\n HeaderCellCtrl.prototype.setComp = function (comp, eGui, eResize, eHeaderCompWrapper) {\n var _this = this;\n _super.prototype.setGui.call(this, eGui);\n this.comp = comp;\n this.updateState();\n this.setupWidth();\n this.setupMovingCss();\n this.setupMenuClass();\n this.setupSortableClass();\n this.setupWrapTextClass();\n this.setupAutoHeight(eHeaderCompWrapper);\n this.addColumnHoverListener();\n this.setupFilterCss();\n this.setupColId();\n this.setupClassesFromColDef();\n this.setupTooltip();\n this.addActiveHeaderMouseListeners();\n this.setupSelectAll();\n this.setupUserComp();\n this.refreshAria();\n this.createManagedBean(new ResizeFeature(this.getPinned(), this.column, eResize, comp, this));\n this.createManagedBean(new HoverFeature([this.column], eGui));\n this.createManagedBean(new SetLeftFeature(this.column, eGui, this.beans));\n this.createManagedBean(new ManagedFocusFeature(eGui, {\n shouldStopEventPropagation: function (e) { return _this.shouldStopEventPropagation(e); },\n onTabKeyDown: function () { return null; },\n handleKeyDown: this.handleKeyDown.bind(this),\n onFocusIn: this.onFocusIn.bind(this),\n onFocusOut: this.onFocusOut.bind(this)\n }));\n this.addManagedListener(this.column, Column.EVENT_COL_DEF_CHANGED, this.onColDefChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_VALUE_CHANGED, this.onColumnValueChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, this.onColumnRowGroupChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PIVOT_CHANGED, this.onColumnPivotChanged.bind(this));\n };\n HeaderCellCtrl.prototype.setupUserComp = function () {\n var compDetails = this.lookupUserCompDetails();\n this.setCompDetails(compDetails);\n };\n HeaderCellCtrl.prototype.setCompDetails = function (compDetails) {\n this.userCompDetails = compDetails;\n this.comp.setUserCompDetails(compDetails);\n };\n HeaderCellCtrl.prototype.lookupUserCompDetails = function () {\n var params = this.createParams();\n var colDef = this.column.getColDef();\n return this.userComponentFactory.getHeaderCompDetails(colDef, params);\n };\n HeaderCellCtrl.prototype.createParams = function () {\n var _this = this;\n var colDef = this.column.getColDef();\n var params = {\n column: this.column,\n displayName: this.displayName,\n enableSorting: colDef.sortable,\n enableMenu: this.menuEnabled,\n showColumnMenu: function (source) {\n _this.gridApi.showColumnMenuAfterButtonClick(_this.column, source);\n },\n progressSort: function (multiSort) {\n _this.sortController.progressSort(_this.column, !!multiSort, \"uiColumnSorted\");\n },\n setSort: function (sort, multiSort) {\n _this.sortController.setSortForColumn(_this.column, sort, !!multiSort, \"uiColumnSorted\");\n },\n api: this.gridApi,\n columnApi: this.columnApi,\n context: this.gridOptionsWrapper.getContext(),\n eGridHeader: this.getGui()\n };\n return params;\n };\n HeaderCellCtrl.prototype.setupSelectAll = function () {\n this.selectAllFeature = this.createManagedBean(new SelectAllFeature(this.column));\n this.selectAllFeature.setComp(this);\n };\n HeaderCellCtrl.prototype.getSelectAllGui = function () {\n return this.selectAllFeature.getCheckboxGui();\n };\n HeaderCellCtrl.prototype.handleKeyDown = function (e) {\n _super.prototype.handleKeyDown.call(this, e);\n if (e.key === KeyCode.SPACE) {\n this.selectAllFeature.onSpaceKeyPressed(e);\n }\n if (e.key === KeyCode.ENTER) {\n this.onEnterKeyPressed(e);\n }\n };\n HeaderCellCtrl.prototype.onEnterKeyPressed = function (e) {\n /// THIS IS BAD - we are assuming the header is not a user provided comp\n var headerComp = this.comp.getUserCompInstance();\n if (!headerComp) {\n return;\n }\n if (e.ctrlKey || e.metaKey) {\n if (this.menuEnabled && headerComp.showMenu) {\n e.preventDefault();\n headerComp.showMenu();\n }\n }\n else if (this.sortable) {\n var multiSort = e.shiftKey;\n this.sortController.progressSort(this.column, multiSort, \"uiColumnSorted\");\n }\n };\n HeaderCellCtrl.prototype.isMenuEnabled = function () {\n return this.menuEnabled;\n };\n HeaderCellCtrl.prototype.onFocusIn = function (e) {\n if (!this.getGui().contains(e.relatedTarget)) {\n var rowIndex = this.getRowIndex();\n this.focusService.setFocusedHeader(rowIndex, this.column);\n }\n this.setActiveHeader(true);\n };\n HeaderCellCtrl.prototype.onFocusOut = function (e) {\n if (this.getGui().contains(e.relatedTarget)) {\n return;\n }\n this.setActiveHeader(false);\n };\n HeaderCellCtrl.prototype.setupTooltip = function () {\n var _this = this;\n var tooltipCtrl = {\n getColumn: function () { return _this.column; },\n getColDef: function () { return _this.column.getColDef(); },\n getGui: function () { return _this.eGui; },\n getLocation: function () { return 'header'; },\n getTooltipValue: function () {\n var res = _this.column.getColDef().headerTooltip;\n return res;\n },\n };\n var tooltipFeature = this.createManagedBean(new TooltipFeature(tooltipCtrl, this.beans));\n tooltipFeature.setComp(this.comp);\n this.refreshFunctions.push(function () { return tooltipFeature.refreshToolTip(); });\n };\n HeaderCellCtrl.prototype.setupClassesFromColDef = function () {\n var _this = this;\n var refreshHeaderClasses = function () {\n var colDef = _this.column.getColDef();\n var goa = _this.gridOptionsWrapper;\n var classes = CssClassApplier.getHeaderClassesFromColDef(colDef, goa, _this.column, null);\n var oldClasses = _this.userHeaderClasses;\n _this.userHeaderClasses = new Set(classes);\n classes.forEach(function (c) {\n if (oldClasses.has(c)) {\n // class already added, no need to apply it, but remove from old set\n oldClasses.delete(c);\n }\n else {\n // class new since last time, so apply it\n _this.comp.addOrRemoveCssClass(c, true);\n }\n });\n // now old set only has classes that were applied last time, but not this time, so remove them\n oldClasses.forEach(function (c) { return _this.comp.addOrRemoveCssClass(c, false); });\n };\n this.refreshFunctions.push(refreshHeaderClasses);\n refreshHeaderClasses();\n };\n HeaderCellCtrl.prototype.setDragSource = function (eSource) {\n var _this = this;\n this.dragSourceElement = eSource;\n this.removeDragSource();\n if (!eSource) {\n return;\n }\n if (!this.draggable) {\n return;\n }\n var hideColumnOnExit = !this.gridOptionsWrapper.isSuppressDragLeaveHidesColumns();\n this.moveDragSource = {\n type: DragSourceType.HeaderCell,\n eElement: eSource,\n defaultIconName: hideColumnOnExit ? DragAndDropService.ICON_HIDE : DragAndDropService.ICON_NOT_ALLOWED,\n getDragItem: function () { return _this.createDragItem(); },\n dragItemName: this.displayName,\n onDragStarted: function () { return _this.column.setMoving(true, \"uiColumnMoved\"); },\n onDragStopped: function () { return _this.column.setMoving(false, \"uiColumnMoved\"); },\n onGridEnter: function (dragItem) {\n var _a, _b;\n if (hideColumnOnExit) {\n var unlockedColumns = ((_b = (_a = dragItem) === null || _a === void 0 ? void 0 : _a.columns) === null || _b === void 0 ? void 0 : _b.filter(function (col) { return !col.getColDef().lockVisible; })) || [];\n _this.columnModel.setColumnsVisible(unlockedColumns, true, \"uiColumnMoved\");\n }\n },\n onGridExit: function (dragItem) {\n var _a, _b;\n if (hideColumnOnExit) {\n var unlockedColumns = ((_b = (_a = dragItem) === null || _a === void 0 ? void 0 : _a.columns) === null || _b === void 0 ? void 0 : _b.filter(function (col) { return !col.getColDef().lockVisible; })) || [];\n _this.columnModel.setColumnsVisible(unlockedColumns, false, \"uiColumnMoved\");\n }\n },\n };\n this.dragAndDropService.addDragSource(this.moveDragSource, true);\n };\n HeaderCellCtrl.prototype.createDragItem = function () {\n var visibleState = {};\n visibleState[this.column.getId()] = this.column.isVisible();\n return {\n columns: [this.column],\n visibleState: visibleState\n };\n };\n HeaderCellCtrl.prototype.removeDragSource = function () {\n if (this.moveDragSource) {\n this.dragAndDropService.removeDragSource(this.moveDragSource);\n this.moveDragSource = undefined;\n }\n };\n HeaderCellCtrl.prototype.onColDefChanged = function () {\n this.refresh();\n };\n HeaderCellCtrl.prototype.updateState = function () {\n var colDef = this.column.getColDef();\n this.menuEnabled = this.menuFactory.isMenuEnabled(this.column) && !colDef.suppressMenu;\n this.sortable = colDef.sortable;\n this.displayName = this.calculateDisplayName();\n this.draggable = this.workOutDraggable();\n };\n HeaderCellCtrl.prototype.addRefreshFunction = function (func) {\n this.refreshFunctions.push(func);\n };\n HeaderCellCtrl.prototype.refresh = function () {\n this.updateState();\n this.refreshHeaderComp();\n this.refreshAria();\n this.refreshFunctions.forEach(function (f) { return f(); });\n };\n HeaderCellCtrl.prototype.refreshHeaderComp = function () {\n var newCompDetails = this.lookupUserCompDetails();\n var compInstance = this.comp.getUserCompInstance();\n // only try refresh if old comp exists adn it is the correct type\n var attemptRefresh = compInstance != null && this.userCompDetails.componentClass == newCompDetails.componentClass;\n var headerCompRefreshed = attemptRefresh ? this.attemptHeaderCompRefresh(newCompDetails.params) : false;\n if (headerCompRefreshed) {\n // we do this as a refresh happens after colDefs change, and it's possible the column has had it's\n // draggable property toggled. no need to call this if not refreshing, as setDragSource is done\n // as part of appendHeaderComp\n this.setDragSource(this.dragSourceElement);\n }\n else {\n this.setCompDetails(newCompDetails);\n }\n };\n HeaderCellCtrl.prototype.attemptHeaderCompRefresh = function (params) {\n var headerComp = this.comp.getUserCompInstance();\n if (!headerComp) {\n return false;\n }\n // if no refresh method, then we want to replace the headerComp\n if (!headerComp.refresh) {\n return false;\n }\n var res = headerComp.refresh(params);\n return res;\n };\n HeaderCellCtrl.prototype.calculateDisplayName = function () {\n return this.columnModel.getDisplayNameForColumn(this.column, 'header', true);\n };\n HeaderCellCtrl.prototype.checkDisplayName = function () {\n // display name can change if aggFunc different, eg sum(Gold) is now max(Gold)\n if (this.displayName !== this.calculateDisplayName()) {\n this.refresh();\n }\n };\n HeaderCellCtrl.prototype.workOutDraggable = function () {\n var colDef = this.column.getColDef();\n var isSuppressMovableColumns = this.gridOptionsWrapper.isSuppressMovableColumns();\n var colCanMove = !isSuppressMovableColumns && !colDef.suppressMovable && !colDef.lockPosition;\n // we should still be allowed drag the column, even if it can't be moved, if the column\n // can be dragged to a rowGroup or pivot drop zone\n return !!colCanMove || !!colDef.enableRowGroup || !!colDef.enablePivot;\n };\n HeaderCellCtrl.prototype.onColumnRowGroupChanged = function () {\n this.checkDisplayName();\n };\n HeaderCellCtrl.prototype.onColumnPivotChanged = function () {\n this.checkDisplayName();\n };\n HeaderCellCtrl.prototype.onColumnValueChanged = function () {\n this.checkDisplayName();\n };\n HeaderCellCtrl.prototype.setupWidth = function () {\n var _this = this;\n var listener = function () {\n _this.comp.setWidth(_this.column.getActualWidth() + 'px');\n };\n this.addManagedListener(this.column, Column.EVENT_WIDTH_CHANGED, listener);\n listener();\n };\n HeaderCellCtrl.prototype.setupMovingCss = function () {\n var _this = this;\n var listener = function () {\n // this is what makes the header go dark when it is been moved (gives impression to\n // user that the column was picked up).\n _this.comp.addOrRemoveCssClass('ag-header-cell-moving', _this.column.isMoving());\n };\n this.addManagedListener(this.column, Column.EVENT_MOVING_CHANGED, listener);\n listener();\n };\n HeaderCellCtrl.prototype.setupMenuClass = function () {\n var _this = this;\n var listener = function () {\n _this.comp.addOrRemoveCssClass('ag-column-menu-visible', _this.column.isMenuVisible());\n };\n this.addManagedListener(this.column, Column.EVENT_MENU_VISIBLE_CHANGED, listener);\n listener();\n };\n HeaderCellCtrl.prototype.setupSortableClass = function () {\n var _this = this;\n var updateSortableCssClass = function () {\n _this.comp.addOrRemoveCssClass('ag-header-cell-sortable', !!_this.sortable);\n };\n updateSortableCssClass();\n this.addRefreshFunction(updateSortableCssClass);\n this.addManagedListener(this.column, Column.EVENT_SORT_CHANGED, this.refreshAriaSort.bind(this));\n };\n HeaderCellCtrl.prototype.setupWrapTextClass = function () {\n var _this = this;\n var listener = function () {\n var wrapText = !!_this.column.getColDef().wrapHeaderText;\n _this.comp.addOrRemoveCssClass('ag-header-cell-wrap-text', wrapText);\n };\n listener();\n this.addRefreshFunction(listener);\n };\n HeaderCellCtrl.prototype.setupAutoHeight = function (wrapperElement) {\n var _this = this;\n var measureHeight = function (timesCalled) {\n if (!_this.isAlive()) {\n return;\n }\n var _a = getElementSize(_this.getGui()), paddingTop = _a.paddingTop, paddingBottom = _a.paddingBottom;\n var wrapperHeight = wrapperElement.offsetHeight;\n var autoHeight = wrapperHeight + paddingTop + paddingBottom;\n if (timesCalled < 5) {\n // if not in doc yet, means framework not yet inserted, so wait for next VM turn,\n // maybe it will be ready next VM turn\n var doc = _this.beans.gridOptionsWrapper.getDocument();\n var notYetInDom = !doc || !doc.contains(wrapperElement);\n // this happens in React, where React hasn't put any content in. we say 'possibly'\n // as a) may not be React and b) the cell could be empty anyway\n var possiblyNoContentYet = autoHeight == 0;\n if (notYetInDom || possiblyNoContentYet) {\n _this.beans.frameworkOverrides.setTimeout(function () { return measureHeight(timesCalled + 1); }, 0);\n return;\n }\n }\n _this.columnModel.setColumnHeaderHeight(_this.column, autoHeight);\n };\n var isMeasuring = false;\n var stopResizeObserver;\n var checkMeasuring = function () {\n var newValue = _this.column.isAutoHeaderHeight();\n if (newValue && !isMeasuring) {\n startMeasuring();\n }\n if (!newValue && isMeasuring) {\n stopMeasuring();\n }\n };\n var startMeasuring = function () {\n isMeasuring = true;\n measureHeight(0);\n stopResizeObserver = _this.resizeObserverService.observeResize(wrapperElement, function () { return measureHeight(0); });\n };\n var stopMeasuring = function () {\n isMeasuring = false;\n stopResizeObserver && stopResizeObserver();\n stopResizeObserver = undefined;\n };\n checkMeasuring();\n this.addDestroyFunc(function () { return stopMeasuring(); });\n // In theory we could rely on the resize observer for everything - but since it's debounced\n // it can be a little janky for smooth movement. in this case its better to react to our own events\n // And unfortunately we cant _just_ rely on our own events, since custom components can change whenever\n this.addManagedListener(this.column, Column.EVENT_WIDTH_CHANGED, function () { return isMeasuring && measureHeight(0); });\n // Displaying the sort icon changes the available area for text, so sort changes can affect height\n this.addManagedListener(this.column, Column.EVENT_SORT_CHANGED, function () {\n // Rendering changes for sort, happen after the event... not ideal\n isMeasuring && _this.beans.frameworkOverrides.setTimeout(function () { return measureHeight(0); });\n });\n this.addRefreshFunction(checkMeasuring);\n };\n HeaderCellCtrl.prototype.refreshAriaSort = function () {\n if (this.sortable) {\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n this.comp.setAriaSort(getAriaSortState(this.column));\n this.setAriaDescriptionProperty('sort', translate('ariaSortableColumn', 'Press ENTER to sort.'));\n }\n else {\n this.comp.setAriaSort();\n this.setAriaDescriptionProperty('sort', null);\n }\n };\n HeaderCellCtrl.prototype.refreshAriaMenu = function () {\n if (this.menuEnabled) {\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n this.setAriaDescriptionProperty('menu', translate('ariaMenuColumn', 'Press CTRL ENTER to open column menu.'));\n }\n else {\n this.setAriaDescriptionProperty('menu', null);\n }\n };\n HeaderCellCtrl.prototype.setAriaDescriptionProperty = function (property, value) {\n if (value != null) {\n this.ariaDescriptionProperties.set(property, value);\n }\n else {\n this.ariaDescriptionProperties.delete(property);\n }\n };\n HeaderCellCtrl.prototype.refreshAriaDescription = function () {\n var descriptionArray = Array.from(this.ariaDescriptionProperties.values());\n this.comp.setAriaDescription(descriptionArray.length ? descriptionArray.join(' ') : undefined);\n };\n HeaderCellCtrl.prototype.refreshAria = function () {\n this.refreshAriaSort();\n this.refreshAriaMenu();\n this.refreshAriaDescription();\n };\n HeaderCellCtrl.prototype.addColumnHoverListener = function () {\n var _this = this;\n var listener = function () {\n if (!_this.gridOptionsWrapper.isColumnHoverHighlight()) {\n return;\n }\n var isHovered = _this.columnHoverService.isHovered(_this.column);\n _this.comp.addOrRemoveCssClass('ag-column-hover', isHovered);\n };\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_HOVER_CHANGED, listener);\n listener();\n };\n HeaderCellCtrl.prototype.setupFilterCss = function () {\n var _this = this;\n var listener = function () {\n _this.comp.addOrRemoveCssClass('ag-header-cell-filtered', _this.column.isFilterActive());\n };\n this.addManagedListener(this.column, Column.EVENT_FILTER_ACTIVE_CHANGED, listener);\n listener();\n };\n HeaderCellCtrl.prototype.setupColId = function () {\n this.comp.setColId(this.column.getColId());\n };\n HeaderCellCtrl.prototype.addActiveHeaderMouseListeners = function () {\n var _this = this;\n var listener = function (e) { return _this.setActiveHeader(e.type === 'mouseenter'); };\n this.addManagedListener(this.getGui(), 'mouseenter', listener);\n this.addManagedListener(this.getGui(), 'mouseleave', listener);\n };\n HeaderCellCtrl.prototype.setActiveHeader = function (active) {\n this.comp.addOrRemoveCssClass('ag-header-active', active);\n };\n __decorate([\n Autowired('columnModel')\n ], HeaderCellCtrl.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('columnHoverService')\n ], HeaderCellCtrl.prototype, \"columnHoverService\", void 0);\n __decorate([\n Autowired('sortController')\n ], HeaderCellCtrl.prototype, \"sortController\", void 0);\n __decorate([\n Autowired('menuFactory')\n ], HeaderCellCtrl.prototype, \"menuFactory\", void 0);\n __decorate([\n Autowired('dragAndDropService')\n ], HeaderCellCtrl.prototype, \"dragAndDropService\", void 0);\n __decorate([\n Autowired('resizeObserverService')\n ], HeaderCellCtrl.prototype, \"resizeObserverService\", void 0);\n __decorate([\n Autowired('gridApi')\n ], HeaderCellCtrl.prototype, \"gridApi\", void 0);\n __decorate([\n Autowired('columnApi')\n ], HeaderCellCtrl.prototype, \"columnApi\", void 0);\n __decorate([\n PreDestroy\n ], HeaderCellCtrl.prototype, \"removeDragSource\", null);\n return HeaderCellCtrl;\n}(AbstractHeaderCellCtrl));\nexport { HeaderCellCtrl };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Constants } from \"../../../constants/constants\";\nimport { BeanStub } from \"../../../context/beanStub\";\nimport { Autowired, PostConstruct } from \"../../../context/context\";\nvar GroupResizeFeature = /** @class */ (function (_super) {\n __extends(GroupResizeFeature, _super);\n function GroupResizeFeature(comp, eResize, pinned, columnGroup) {\n var _this = _super.call(this) || this;\n _this.eResize = eResize;\n _this.comp = comp;\n _this.pinned = pinned;\n _this.columnGroup = columnGroup;\n return _this;\n }\n GroupResizeFeature.prototype.postConstruct = function () {\n var _this = this;\n if (!this.columnGroup.isResizable()) {\n this.comp.addOrRemoveResizableCssClass('ag-hidden', true);\n return;\n }\n var finishedWithResizeFunc = this.horizontalResizeService.addResizeBar({\n eResizeBar: this.eResize,\n onResizeStart: this.onResizeStart.bind(this),\n onResizing: this.onResizing.bind(this, false),\n onResizeEnd: this.onResizing.bind(this, true)\n });\n this.addDestroyFunc(finishedWithResizeFunc);\n if (!this.gridOptionsWrapper.isSuppressAutoSize()) {\n var skipHeaderOnAutoSize_1 = this.gridOptionsWrapper.isSkipHeaderOnAutoSize();\n this.eResize.addEventListener('dblclick', function () {\n // get list of all the column keys we are responsible for\n var keys = [];\n var leafCols = _this.columnGroup.getDisplayedLeafColumns();\n leafCols.forEach(function (column) {\n // not all cols in the group may be participating with auto-resize\n if (!column.getColDef().suppressAutoSize) {\n keys.push(column.getColId());\n }\n });\n if (keys.length > 0) {\n _this.columnModel.autoSizeColumns({\n columns: keys,\n skipHeader: skipHeaderOnAutoSize_1,\n stopAtGroup: _this.columnGroup,\n source: 'uiColumnResized'\n });\n }\n _this.resizeLeafColumnsToFit();\n });\n }\n };\n GroupResizeFeature.prototype.onResizeStart = function (shiftKey) {\n var _this = this;\n this.calculateInitialValues();\n var takeFromGroup = null;\n if (shiftKey) {\n takeFromGroup = this.columnModel.getDisplayedGroupAfter(this.columnGroup);\n }\n if (takeFromGroup) {\n var takeFromLeafCols = takeFromGroup.getDisplayedLeafColumns();\n this.resizeTakeFromCols = takeFromLeafCols.filter(function (col) { return col.isResizable(); });\n this.resizeTakeFromStartWidth = 0;\n this.resizeTakeFromCols.forEach(function (col) { return _this.resizeTakeFromStartWidth += col.getActualWidth(); });\n this.resizeTakeFromRatios = [];\n this.resizeTakeFromCols.forEach(function (col) { return _this.resizeTakeFromRatios.push(col.getActualWidth() / _this.resizeTakeFromStartWidth); });\n }\n else {\n this.resizeTakeFromCols = null;\n this.resizeTakeFromStartWidth = null;\n this.resizeTakeFromRatios = null;\n }\n this.comp.addOrRemoveCssClass('ag-column-resizing', true);\n };\n GroupResizeFeature.prototype.onResizing = function (finished, resizeAmount) {\n var resizeAmountNormalised = this.normaliseDragChange(resizeAmount);\n var width = this.resizeStartWidth + resizeAmountNormalised;\n this.resizeColumns(width, finished);\n };\n GroupResizeFeature.prototype.resizeLeafColumnsToFit = function () {\n var preferredSize = this.autoWidthCalculator.getPreferredWidthForColumnGroup(this.columnGroup);\n this.calculateInitialValues();\n if (preferredSize > this.resizeStartWidth) {\n this.resizeColumns(preferredSize, true);\n }\n };\n GroupResizeFeature.prototype.resizeColumns = function (totalWidth, finished) {\n if (finished === void 0) { finished = true; }\n var resizeSets = [];\n resizeSets.push({\n columns: this.resizeCols,\n ratios: this.resizeRatios,\n width: totalWidth\n });\n if (this.resizeTakeFromCols) {\n var diff = totalWidth - this.resizeStartWidth;\n resizeSets.push({\n columns: this.resizeTakeFromCols,\n ratios: this.resizeTakeFromRatios,\n width: this.resizeTakeFromStartWidth - diff\n });\n }\n this.columnModel.resizeColumnSets({\n resizeSets: resizeSets,\n finished: finished,\n source: 'uiColumnDragged'\n });\n if (finished) {\n this.comp.addOrRemoveCssClass('ag-column-resizing', false);\n }\n };\n GroupResizeFeature.prototype.calculateInitialValues = function () {\n var _this = this;\n var leafCols = this.columnGroup.getDisplayedLeafColumns();\n this.resizeCols = leafCols.filter(function (col) { return col.isResizable(); });\n this.resizeStartWidth = 0;\n this.resizeCols.forEach(function (col) { return _this.resizeStartWidth += col.getActualWidth(); });\n this.resizeRatios = [];\n this.resizeCols.forEach(function (col) { return _this.resizeRatios.push(col.getActualWidth() / _this.resizeStartWidth); });\n };\n // optionally inverts the drag, depending on pinned and RTL\n // note - this method is duplicated in RenderedHeaderCell - should refactor out?\n GroupResizeFeature.prototype.normaliseDragChange = function (dragChange) {\n var result = dragChange;\n if (this.gridOptionsWrapper.isEnableRtl()) {\n // for RTL, dragging left makes the col bigger, except when pinning left\n if (this.pinned !== Constants.PINNED_LEFT) {\n result *= -1;\n }\n }\n else if (this.pinned === Constants.PINNED_RIGHT) {\n // for LTR (ie normal), dragging left makes the col smaller, except when pinning right\n result *= -1;\n }\n return result;\n };\n __decorate([\n Autowired('horizontalResizeService')\n ], GroupResizeFeature.prototype, \"horizontalResizeService\", void 0);\n __decorate([\n Autowired('autoWidthCalculator')\n ], GroupResizeFeature.prototype, \"autoWidthCalculator\", void 0);\n __decorate([\n Autowired('columnModel')\n ], GroupResizeFeature.prototype, \"columnModel\", void 0);\n __decorate([\n PostConstruct\n ], GroupResizeFeature.prototype, \"postConstruct\", null);\n return GroupResizeFeature;\n}(BeanStub));\nexport { GroupResizeFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../../context/beanStub\";\nimport { PostConstruct } from \"../../../context/context\";\nimport { Column } from \"../../../entities/column\";\nimport { ColumnGroup } from \"../../../entities/columnGroup\";\nvar GroupWidthFeature = /** @class */ (function (_super) {\n __extends(GroupWidthFeature, _super);\n function GroupWidthFeature(comp, columnGroup) {\n var _this = _super.call(this) || this;\n // the children can change, we keep destroy functions related to listening to the children here\n _this.removeChildListenersFuncs = [];\n _this.columnGroup = columnGroup;\n _this.comp = comp;\n return _this;\n }\n GroupWidthFeature.prototype.postConstruct = function () {\n // we need to listen to changes in child columns, as they impact our width\n this.addListenersToChildrenColumns();\n // the children belonging to this group can change, so we need to add and remove listeners as they change\n this.addManagedListener(this.columnGroup, ColumnGroup.EVENT_DISPLAYED_CHILDREN_CHANGED, this.onDisplayedChildrenChanged.bind(this));\n this.onWidthChanged();\n // the child listeners are not tied to this components life-cycle, as children can get added and removed\n // to the group - hence they are on a different life-cycle. so we must make sure the existing children\n // listeners are removed when we finally get destroyed\n this.addDestroyFunc(this.removeListenersOnChildrenColumns.bind(this));\n };\n GroupWidthFeature.prototype.addListenersToChildrenColumns = function () {\n var _this = this;\n // first destroy any old listeners\n this.removeListenersOnChildrenColumns();\n // now add new listeners to the new set of children\n var widthChangedListener = this.onWidthChanged.bind(this);\n this.columnGroup.getLeafColumns().forEach(function (column) {\n column.addEventListener(Column.EVENT_WIDTH_CHANGED, widthChangedListener);\n column.addEventListener(Column.EVENT_VISIBLE_CHANGED, widthChangedListener);\n _this.removeChildListenersFuncs.push(function () {\n column.removeEventListener(Column.EVENT_WIDTH_CHANGED, widthChangedListener);\n column.removeEventListener(Column.EVENT_VISIBLE_CHANGED, widthChangedListener);\n });\n });\n };\n GroupWidthFeature.prototype.removeListenersOnChildrenColumns = function () {\n this.removeChildListenersFuncs.forEach(function (func) { return func(); });\n this.removeChildListenersFuncs = [];\n };\n GroupWidthFeature.prototype.onDisplayedChildrenChanged = function () {\n this.addListenersToChildrenColumns();\n this.onWidthChanged();\n };\n GroupWidthFeature.prototype.onWidthChanged = function () {\n this.comp.setWidth(this.columnGroup.getActualWidth() + 'px');\n };\n __decorate([\n PostConstruct\n ], GroupWidthFeature.prototype, \"postConstruct\", null);\n return GroupWidthFeature;\n}(BeanStub));\nexport { GroupWidthFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { KeyCode } from '../../../constants/keyCode';\nimport { Autowired } from \"../../../context/context\";\nimport { DragAndDropService, DragSourceType } from \"../../../dragAndDrop/dragAndDropService\";\nimport { Column } from \"../../../entities/column\";\nimport { ProvidedColumnGroup } from \"../../../entities/providedColumnGroup\";\nimport { SetLeftFeature } from \"../../../rendering/features/setLeftFeature\";\nimport { removeFromArray } from \"../../../utils/array\";\nimport { ManagedFocusFeature } from \"../../../widgets/managedFocusFeature\";\nimport { TooltipFeature } from \"../../../widgets/tooltipFeature\";\nimport { AbstractHeaderCellCtrl } from \"../abstractCell/abstractHeaderCellCtrl\";\nimport { CssClassApplier } from \"../cssClassApplier\";\nimport { HoverFeature } from \"../hoverFeature\";\nimport { GroupResizeFeature } from \"./groupResizeFeature\";\nimport { GroupWidthFeature } from \"./groupWidthFeature\";\nvar HeaderGroupCellCtrl = /** @class */ (function (_super) {\n __extends(HeaderGroupCellCtrl, _super);\n function HeaderGroupCellCtrl(columnGroup, parentRowCtrl) {\n var _this = _super.call(this, columnGroup, parentRowCtrl) || this;\n _this.columnGroup = columnGroup;\n return _this;\n }\n HeaderGroupCellCtrl.prototype.setComp = function (comp, eGui, eResize) {\n _super.prototype.setGui.call(this, eGui);\n this.comp = comp;\n this.displayName = this.columnModel.getDisplayNameForColumnGroup(this.columnGroup, 'header');\n this.addClasses();\n this.addAttributes();\n this.setupMovingCss();\n this.setupExpandable();\n this.setupTooltip();\n this.setupUserComp();\n var pinned = this.getParentRowCtrl().getPinned();\n var leafCols = this.columnGroup.getProvidedColumnGroup().getLeafColumns();\n this.createManagedBean(new HoverFeature(leafCols, eGui));\n this.createManagedBean(new SetLeftFeature(this.columnGroup, eGui, this.beans));\n this.createManagedBean(new GroupWidthFeature(comp, this.columnGroup));\n this.groupResizeFeature = this.createManagedBean(new GroupResizeFeature(comp, eResize, pinned, this.columnGroup));\n this.createManagedBean(new ManagedFocusFeature(eGui, {\n shouldStopEventPropagation: this.shouldStopEventPropagation.bind(this),\n onTabKeyDown: function () { return undefined; },\n handleKeyDown: this.handleKeyDown.bind(this),\n onFocusIn: this.onFocusIn.bind(this)\n }));\n };\n HeaderGroupCellCtrl.prototype.resizeLeafColumnsToFit = function () {\n this.groupResizeFeature.onResizeStart(false);\n this.groupResizeFeature.resizeLeafColumnsToFit();\n };\n HeaderGroupCellCtrl.prototype.setupUserComp = function () {\n var _this = this;\n var displayName = this.displayName;\n var params = {\n displayName: this.displayName,\n columnGroup: this.columnGroup,\n setExpanded: function (expanded) {\n _this.columnModel.setColumnGroupOpened(_this.columnGroup.getProvidedColumnGroup(), expanded, \"gridInitializing\");\n },\n api: this.gridApi,\n columnApi: this.columnApi,\n context: this.gridOptionsWrapper.getContext()\n };\n if (!displayName) {\n var columnGroup = this.columnGroup;\n var leafCols = columnGroup.getLeafColumns();\n // find the top most column group that represents the same columns. so if we are dragging a group, we also\n // want to visually show the parent groups dragging for the same column set. for example imaging 5 levels\n // of grouping, with each group only containing the next group, and the last group containing three columns,\n // then when you move any group (even the lowest level group) you are in-fact moving all the groups, as all\n // the groups represent the same column set.\n while (columnGroup.getParent() && columnGroup.getParent().getLeafColumns().length === leafCols.length) {\n columnGroup = columnGroup.getParent();\n }\n var colGroupDef = columnGroup.getColGroupDef();\n if (colGroupDef) {\n displayName = colGroupDef.headerName;\n }\n if (!displayName) {\n displayName = leafCols ? this.columnModel.getDisplayNameForColumn(leafCols[0], 'header', true) : '';\n }\n }\n var compDetails = this.userComponentFactory.getHeaderGroupCompDetails(params);\n this.comp.setUserCompDetails(compDetails);\n };\n HeaderGroupCellCtrl.prototype.setupTooltip = function () {\n var _this = this;\n var colGroupDef = this.columnGroup.getColGroupDef();\n var tooltipCtrl = {\n getColumn: function () { return _this.columnGroup; },\n getGui: function () { return _this.eGui; },\n getLocation: function () { return 'headerGroup'; },\n getTooltipValue: function () { return colGroupDef && colGroupDef.headerTooltip; }\n };\n if (colGroupDef) {\n tooltipCtrl.getColDef = function () { return colGroupDef; };\n }\n var tooltipFeature = this.createManagedBean(new TooltipFeature(tooltipCtrl, this.beans));\n tooltipFeature.setComp(this.comp);\n };\n HeaderGroupCellCtrl.prototype.setupExpandable = function () {\n var providedColGroup = this.columnGroup.getProvidedColumnGroup();\n this.refreshExpanded();\n this.addManagedListener(providedColGroup, ProvidedColumnGroup.EVENT_EXPANDABLE_CHANGED, this.refreshExpanded.bind(this));\n this.addManagedListener(providedColGroup, ProvidedColumnGroup.EVENT_EXPANDED_CHANGED, this.refreshExpanded.bind(this));\n };\n HeaderGroupCellCtrl.prototype.refreshExpanded = function () {\n var column = this.columnGroup;\n this.expandable = column.isExpandable();\n var expanded = column.isExpanded();\n if (this.expandable) {\n this.comp.setAriaExpanded(expanded ? 'true' : 'false');\n }\n else {\n this.comp.setAriaExpanded(undefined);\n }\n };\n HeaderGroupCellCtrl.prototype.addAttributes = function () {\n this.comp.setColId(this.columnGroup.getUniqueId());\n };\n HeaderGroupCellCtrl.prototype.addClasses = function () {\n var _this = this;\n var colGroupDef = this.columnGroup.getColGroupDef();\n var classes = CssClassApplier.getHeaderClassesFromColDef(colGroupDef, this.gridOptionsWrapper, null, this.columnGroup);\n // having different classes below allows the style to not have a bottom border\n // on the group header, if no group is specified\n classes.push(this.columnGroup.isPadding() ? \"ag-header-group-cell-no-group\" : \"ag-header-group-cell-with-group\");\n classes.forEach(function (c) { return _this.comp.addOrRemoveCssClass(c, true); });\n };\n HeaderGroupCellCtrl.prototype.setupMovingCss = function () {\n var _this = this;\n var providedColumnGroup = this.columnGroup.getProvidedColumnGroup();\n var leafColumns = providedColumnGroup.getLeafColumns();\n // this function adds or removes the moving css, based on if the col is moving.\n // this is what makes the header go dark when it is been moved (gives impression to\n // user that the column was picked up).\n var listener = function () { return _this.comp.addOrRemoveCssClass('ag-header-cell-moving', _this.columnGroup.isMoving()); };\n leafColumns.forEach(function (col) {\n _this.addManagedListener(col, Column.EVENT_MOVING_CHANGED, listener);\n });\n listener();\n };\n HeaderGroupCellCtrl.prototype.onFocusIn = function (e) {\n if (!this.eGui.contains(e.relatedTarget)) {\n var rowIndex = this.getRowIndex();\n this.beans.focusService.setFocusedHeader(rowIndex, this.columnGroup);\n }\n };\n HeaderGroupCellCtrl.prototype.handleKeyDown = function (e) {\n _super.prototype.handleKeyDown.call(this, e);\n var wrapperHasFocus = this.getWrapperHasFocus();\n if (!this.expandable || !wrapperHasFocus) {\n return;\n }\n if (e.key === KeyCode.ENTER) {\n var column = this.columnGroup;\n var newExpandedValue = !column.isExpanded();\n this.columnModel.setColumnGroupOpened(column.getProvidedColumnGroup(), newExpandedValue, \"uiColumnExpanded\");\n }\n };\n // unlike columns, this will only get called once, as we don't react on props on column groups\n // (we will always destroy and recreate this comp if something changes)\n HeaderGroupCellCtrl.prototype.setDragSource = function (eHeaderGroup) {\n var _this = this;\n if (this.isSuppressMoving()) {\n return;\n }\n var allLeafColumns = this.columnGroup.getProvidedColumnGroup().getLeafColumns();\n var hideColumnOnExit = !this.gridOptionsWrapper.isSuppressDragLeaveHidesColumns();\n var dragSource = {\n type: DragSourceType.HeaderCell,\n eElement: eHeaderGroup,\n defaultIconName: hideColumnOnExit ? DragAndDropService.ICON_HIDE : DragAndDropService.ICON_NOT_ALLOWED,\n dragItemName: this.displayName,\n // we add in the original group leaf columns, so we move both visible and non-visible items\n getDragItem: this.getDragItemForGroup.bind(this),\n onDragStarted: function () { return allLeafColumns.forEach(function (col) { return col.setMoving(true, \"uiColumnDragged\"); }); },\n onDragStopped: function () { return allLeafColumns.forEach(function (col) { return col.setMoving(false, \"uiColumnDragged\"); }); },\n onGridEnter: function (dragItem) {\n var _a, _b;\n if (hideColumnOnExit) {\n var unlockedColumns = ((_b = (_a = dragItem) === null || _a === void 0 ? void 0 : _a.columns) === null || _b === void 0 ? void 0 : _b.filter(function (col) { return !col.getColDef().lockVisible; })) || [];\n _this.columnModel.setColumnsVisible(unlockedColumns, true, \"uiColumnMoved\");\n }\n },\n onGridExit: function (dragItem) {\n var _a, _b;\n if (hideColumnOnExit) {\n var unlockedColumns = ((_b = (_a = dragItem) === null || _a === void 0 ? void 0 : _a.columns) === null || _b === void 0 ? void 0 : _b.filter(function (col) { return !col.getColDef().lockVisible; })) || [];\n _this.columnModel.setColumnsVisible(unlockedColumns, false, \"uiColumnMoved\");\n }\n },\n };\n this.dragAndDropService.addDragSource(dragSource, true);\n this.addDestroyFunc(function () { return _this.dragAndDropService.removeDragSource(dragSource); });\n };\n // when moving the columns, we want to move all the columns (contained within the DragItem) in this group in one go,\n // and in the order they are currently in the screen.\n HeaderGroupCellCtrl.prototype.getDragItemForGroup = function () {\n var allColumnsOriginalOrder = this.columnGroup.getProvidedColumnGroup().getLeafColumns();\n // capture visible state, used when re-entering grid to dictate which columns should be visible\n var visibleState = {};\n allColumnsOriginalOrder.forEach(function (column) { return visibleState[column.getId()] = column.isVisible(); });\n var allColumnsCurrentOrder = [];\n this.columnModel.getAllDisplayedColumns().forEach(function (column) {\n if (allColumnsOriginalOrder.indexOf(column) >= 0) {\n allColumnsCurrentOrder.push(column);\n removeFromArray(allColumnsOriginalOrder, column);\n }\n });\n // we are left with non-visible columns, stick these in at the end\n allColumnsOriginalOrder.forEach(function (column) { return allColumnsCurrentOrder.push(column); });\n // create and return dragItem\n return {\n columns: allColumnsCurrentOrder,\n visibleState: visibleState\n };\n };\n HeaderGroupCellCtrl.prototype.isSuppressMoving = function () {\n // if any child is fixed, then don't allow moving\n var childSuppressesMoving = false;\n this.columnGroup.getLeafColumns().forEach(function (column) {\n if (column.getColDef().suppressMovable || column.getColDef().lockPosition) {\n childSuppressesMoving = true;\n }\n });\n var result = childSuppressesMoving || this.gridOptionsWrapper.isSuppressMovableColumns();\n return result;\n };\n __decorate([\n Autowired('columnModel')\n ], HeaderGroupCellCtrl.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('dragAndDropService')\n ], HeaderGroupCellCtrl.prototype, \"dragAndDropService\", void 0);\n __decorate([\n Autowired('gridApi')\n ], HeaderGroupCellCtrl.prototype, \"gridApi\", void 0);\n __decorate([\n Autowired('columnApi')\n ], HeaderGroupCellCtrl.prototype, \"columnApi\", void 0);\n return HeaderGroupCellCtrl;\n}(AbstractHeaderCellCtrl));\nexport { HeaderGroupCellCtrl };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Constants } from \"../../constants/constants\";\nimport { BeanStub } from \"../../context/beanStub\";\nimport { Autowired, PreDestroy } from \"../../context/context\";\nimport { Events } from \"../../eventKeys\";\nimport { GridOptionsWrapper } from \"../../gridOptionsWrapper\";\nimport { isBrowserSafari } from \"../../utils/browser\";\nimport { getAllValuesInObject, iterateObject } from \"../../utils/object\";\nimport { HeaderFilterCellCtrl } from \"../cells/floatingFilter/headerFilterCellCtrl\";\nimport { HeaderCellCtrl } from \"../cells/column/headerCellCtrl\";\nimport { HeaderGroupCellCtrl } from \"../cells/columnGroup/headerGroupCellCtrl\";\nimport { HeaderRowType } from \"./headerRowComp\";\nimport { values } from \"../../utils/generic\";\nvar instanceIdSequence = 0;\nvar HeaderRowCtrl = /** @class */ (function (_super) {\n __extends(HeaderRowCtrl, _super);\n function HeaderRowCtrl(rowIndex, pinned, type) {\n var _this = _super.call(this) || this;\n _this.instanceId = instanceIdSequence++;\n _this.headerCellCtrls = {};\n _this.rowIndex = rowIndex;\n _this.pinned = pinned;\n _this.type = type;\n return _this;\n }\n HeaderRowCtrl.prototype.getInstanceId = function () {\n return this.instanceId;\n };\n HeaderRowCtrl.prototype.setComp = function (comp) {\n this.comp = comp;\n this.onRowHeightChanged();\n this.onVirtualColumnsChanged();\n this.setWidth();\n this.addEventListeners();\n if (isBrowserSafari()) {\n // fix for a Safari rendering bug that caused the header to flicker above chart panels\n // as you move the mouse over the header\n this.comp.setTransform('translateZ(0)');\n }\n comp.setAriaRowIndex(this.rowIndex + 1);\n };\n HeaderRowCtrl.prototype.addEventListeners = function () {\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_RESIZED, this.onColumnResized.bind(this));\n // when print layout changes, it changes what columns are in what section\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_DOM_LAYOUT, this.onDisplayedColumnsChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_VIRTUAL_COLUMNS_CHANGED, this.onVirtualColumnsChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_HEADER_HEIGHT_CHANGED, this.onRowHeightChanged.bind(this));\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_HEADER_HEIGHT, this.onRowHeightChanged.bind(this));\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_PIVOT_HEADER_HEIGHT, this.onRowHeightChanged.bind(this));\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_GROUP_HEADER_HEIGHT, this.onRowHeightChanged.bind(this));\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_PIVOT_GROUP_HEADER_HEIGHT, this.onRowHeightChanged.bind(this));\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_FLOATING_FILTERS_HEIGHT, this.onRowHeightChanged.bind(this));\n };\n HeaderRowCtrl.prototype.getHeaderCellCtrl = function (column) {\n return values(this.headerCellCtrls).find(function (cellCtrl) { return cellCtrl.getColumnGroupChild() === column; });\n };\n HeaderRowCtrl.prototype.onDisplayedColumnsChanged = function () {\n this.onVirtualColumnsChanged();\n this.setWidth();\n this.onRowHeightChanged();\n };\n HeaderRowCtrl.prototype.getType = function () {\n return this.type;\n };\n HeaderRowCtrl.prototype.onColumnResized = function () {\n this.setWidth();\n };\n HeaderRowCtrl.prototype.setWidth = function () {\n var width = this.getWidthForRow();\n this.comp.setWidth(width + \"px\");\n };\n HeaderRowCtrl.prototype.getWidthForRow = function () {\n var printLayout = this.gridOptionsWrapper.getDomLayout() === Constants.DOM_LAYOUT_PRINT;\n if (printLayout) {\n var pinned = this.pinned != null;\n if (pinned) {\n return 0;\n }\n return this.columnModel.getContainerWidth(Constants.PINNED_RIGHT)\n + this.columnModel.getContainerWidth(Constants.PINNED_LEFT)\n + this.columnModel.getContainerWidth(null);\n }\n // if not printing, just return the width as normal\n return this.columnModel.getContainerWidth(this.pinned);\n };\n HeaderRowCtrl.prototype.onRowHeightChanged = function () {\n var headerRowCount = this.columnModel.getHeaderRowCount();\n var sizes = [];\n var numberOfFloating = 0;\n if (this.columnModel.hasFloatingFilters()) {\n headerRowCount++;\n numberOfFloating = 1;\n }\n var groupHeight = this.columnModel.getColumnGroupHeaderRowHeight();\n var headerHeight = this.columnModel.getColumnHeaderRowHeight();\n var numberOfNonGroups = 1 + numberOfFloating;\n var numberOfGroups = headerRowCount - numberOfNonGroups;\n for (var i = 0; i < numberOfGroups; i++) {\n sizes.push(groupHeight);\n }\n sizes.push(headerHeight);\n for (var i = 0; i < numberOfFloating; i++) {\n sizes.push(this.gridOptionsWrapper.getFloatingFiltersHeight());\n }\n var topOffset = 0;\n for (var i = 0; i < this.rowIndex; i++) {\n topOffset += sizes[i];\n }\n var thisRowHeight = sizes[this.rowIndex] + 'px';\n this.comp.setTop(topOffset + 'px');\n this.comp.setHeight(thisRowHeight);\n };\n HeaderRowCtrl.prototype.getPinned = function () {\n return this.pinned;\n };\n HeaderRowCtrl.prototype.getRowIndex = function () {\n return this.rowIndex;\n };\n HeaderRowCtrl.prototype.onVirtualColumnsChanged = function () {\n var _this = this;\n var oldCtrls = this.headerCellCtrls;\n this.headerCellCtrls = {};\n var columns = this.getColumnsInViewport();\n columns.forEach(function (child) {\n // skip groups that have no displayed children. this can happen when the group is broken,\n // and this section happens to have nothing to display for the open / closed state.\n // (a broken group is one that is split, ie columns in the group have a non-group column\n // in between them)\n if (child.isEmptyGroup()) {\n return;\n }\n var idOfChild = child.getUniqueId();\n // if we already have this cell rendered, do nothing\n var headerCtrl = oldCtrls[idOfChild];\n delete oldCtrls[idOfChild];\n // it's possible there is a new Column with the same ID, but it's for a different Column.\n // this is common with pivoting, where the pivot cols change, but the id's are still pivot_0,\n // pivot_1 etc. so if new col but same ID, need to remove the old col here first as we are\n // about to replace it in the this.headerComps map.\n var forOldColumn = headerCtrl && headerCtrl.getColumnGroupChild() != child;\n if (forOldColumn) {\n _this.destroyBean(headerCtrl);\n headerCtrl = undefined;\n }\n if (headerCtrl == null) {\n switch (_this.type) {\n case HeaderRowType.FLOATING_FILTER:\n headerCtrl = _this.createBean(new HeaderFilterCellCtrl(child, _this));\n break;\n case HeaderRowType.COLUMN_GROUP:\n headerCtrl = _this.createBean(new HeaderGroupCellCtrl(child, _this));\n break;\n default:\n headerCtrl = _this.createBean(new HeaderCellCtrl(child, _this));\n break;\n }\n }\n _this.headerCellCtrls[idOfChild] = headerCtrl;\n });\n // we want to keep columns that are focused, otherwise keyboard navigation breaks\n var isFocusedAndDisplayed = function (ctrl) {\n var isFocused = _this.focusService.isHeaderWrapperFocused(ctrl);\n if (!isFocused) {\n return false;\n }\n var isDisplayed = _this.columnModel.isDisplayed(ctrl.getColumnGroupChild());\n return isDisplayed;\n };\n iterateObject(oldCtrls, function (id, oldCtrl) {\n var keepCtrl = isFocusedAndDisplayed(oldCtrl);\n if (keepCtrl) {\n _this.headerCellCtrls[id] = oldCtrl;\n }\n else {\n _this.destroyBean(oldCtrl);\n }\n });\n var ctrlsToDisplay = getAllValuesInObject(this.headerCellCtrls);\n this.comp.setHeaderCtrls(ctrlsToDisplay);\n };\n HeaderRowCtrl.prototype.destroyCtrls = function () {\n var _this = this;\n iterateObject(this.headerCellCtrls, function (key, ctrl) {\n _this.destroyBean(ctrl);\n });\n this.headerCellCtrls = {};\n };\n HeaderRowCtrl.prototype.getColumnsInViewport = function () {\n var printLayout = this.gridOptionsWrapper.getDomLayout() === Constants.DOM_LAYOUT_PRINT;\n return printLayout ? this.getColumnsInViewportPrintLayout() : this.getColumnsInViewportNormalLayout();\n };\n HeaderRowCtrl.prototype.getColumnsInViewportPrintLayout = function () {\n var _this = this;\n // for print layout, we add all columns into the center\n if (this.pinned != null) {\n return [];\n }\n var viewportColumns = [];\n var actualDepth = this.getActualDepth();\n [Constants.PINNED_LEFT, null, Constants.PINNED_RIGHT].forEach(function (pinned) {\n var items = _this.columnModel.getVirtualHeaderGroupRow(pinned, actualDepth);\n viewportColumns = viewportColumns.concat(items);\n });\n return viewportColumns;\n };\n HeaderRowCtrl.prototype.getActualDepth = function () {\n return this.type == HeaderRowType.FLOATING_FILTER ? this.rowIndex - 1 : this.rowIndex;\n };\n HeaderRowCtrl.prototype.getColumnsInViewportNormalLayout = function () {\n // when in normal layout, we add the columns for that container only\n return this.columnModel.getVirtualHeaderGroupRow(this.pinned, this.getActualDepth());\n };\n HeaderRowCtrl.prototype.focusHeader = function (column, event) {\n var allCtrls = getAllValuesInObject(this.headerCellCtrls);\n var ctrl = allCtrls.find(function (ctrl) { return ctrl.getColumnGroupChild() == column; });\n if (!ctrl) {\n return false;\n }\n ctrl.focus(event);\n return true;\n };\n __decorate([\n Autowired('columnModel')\n ], HeaderRowCtrl.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('focusService')\n ], HeaderRowCtrl.prototype, \"focusService\", void 0);\n __decorate([\n PreDestroy\n ], HeaderRowCtrl.prototype, \"destroyCtrls\", null);\n return HeaderRowCtrl;\n}(BeanStub));\nexport { HeaderRowCtrl };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nimport { Constants } from \"../../constants/constants\";\nimport { BeanStub } from \"../../context/beanStub\";\nimport { Autowired } from \"../../context/context\";\nimport { Column } from \"../../entities/column\";\nimport { Events } from \"../../eventKeys\";\nimport { CenterWidthFeature } from \"../../gridBodyComp/centerWidthFeature\";\nimport { NumberSequence } from \"../../utils\";\nimport { BodyDropTarget } from \"../columnDrag/bodyDropTarget\";\nimport { HeaderRowType } from \"../row/headerRowComp\";\nimport { HeaderRowCtrl } from \"../row/headerRowCtrl\";\nvar HeaderRowContainerCtrl = /** @class */ (function (_super) {\n __extends(HeaderRowContainerCtrl, _super);\n function HeaderRowContainerCtrl(pinned) {\n var _this = _super.call(this) || this;\n _this.groupsRowCtrls = [];\n _this.pinned = pinned;\n return _this;\n }\n HeaderRowContainerCtrl.prototype.setComp = function (comp, eGui) {\n this.comp = comp;\n this.eViewport = eGui;\n this.setupCenterWidth();\n this.setupPinnedWidth();\n this.setupDragAndDrop(this.eViewport);\n this.addManagedListener(this.eventService, Events.EVENT_GRID_COLUMNS_CHANGED, this.onGridColumnsChanged.bind(this));\n this.addManagedListener(this.eViewport, 'scroll', this.resetScrollLeft.bind(this));\n this.ctrlsService.registerHeaderContainer(this, this.pinned);\n if (this.columnModel.isReady()) {\n this.refresh();\n }\n };\n HeaderRowContainerCtrl.prototype.setupDragAndDrop = function (dropContainer) {\n var bodyDropTarget = new BodyDropTarget(this.pinned, dropContainer);\n this.createManagedBean(bodyDropTarget);\n };\n HeaderRowContainerCtrl.prototype.refresh = function (keepColumns) {\n var _this = this;\n if (keepColumns === void 0) { keepColumns = false; }\n var sequence = new NumberSequence();\n var focusedHeaderPosition = this.focusService.getFocusHeaderToUseAfterRefresh();\n var refreshColumnGroups = function () {\n var groupRowCount = _this.columnModel.getHeaderRowCount() - 1;\n _this.groupsRowCtrls = _this.destroyBeans(_this.groupsRowCtrls);\n for (var i = 0; i < groupRowCount; i++) {\n var ctrl = _this.createBean(new HeaderRowCtrl(sequence.next(), _this.pinned, HeaderRowType.COLUMN_GROUP));\n _this.groupsRowCtrls.push(ctrl);\n }\n };\n var refreshColumns = function () {\n var rowIndex = sequence.next();\n var needNewInstance = _this.columnsRowCtrl == null || !keepColumns || _this.columnsRowCtrl.getRowIndex() !== rowIndex;\n if (needNewInstance) {\n _this.destroyBean(_this.columnsRowCtrl);\n _this.columnsRowCtrl = _this.createBean(new HeaderRowCtrl(rowIndex, _this.pinned, HeaderRowType.COLUMN));\n }\n };\n var refreshFilters = function () {\n var includeFloatingFilter = _this.columnModel.hasFloatingFilters();\n var destroyPreviousComp = function () {\n _this.filtersRowCtrl = _this.destroyBean(_this.filtersRowCtrl);\n };\n if (!includeFloatingFilter) {\n destroyPreviousComp();\n return;\n }\n var rowIndex = sequence.next();\n if (_this.filtersRowCtrl) {\n var rowIndexMismatch = _this.filtersRowCtrl.getRowIndex() !== rowIndex;\n if (!keepColumns || rowIndexMismatch) {\n destroyPreviousComp();\n }\n }\n if (!_this.filtersRowCtrl) {\n _this.filtersRowCtrl = _this.createBean(new HeaderRowCtrl(rowIndex, _this.pinned, HeaderRowType.FLOATING_FILTER));\n }\n };\n refreshColumnGroups();\n refreshColumns();\n refreshFilters();\n var allCtrls = this.getAllCtrls();\n this.comp.setCtrls(allCtrls);\n this.restoreFocusOnHeader(focusedHeaderPosition);\n };\n HeaderRowContainerCtrl.prototype.restoreFocusOnHeader = function (position) {\n if (position == null || position.column.getPinned() != this.pinned) {\n return;\n }\n this.focusService.focusHeaderPosition({ headerPosition: position });\n };\n HeaderRowContainerCtrl.prototype.getAllCtrls = function () {\n var res = __spread(this.groupsRowCtrls, [this.columnsRowCtrl]);\n if (this.filtersRowCtrl) {\n res.push(this.filtersRowCtrl);\n }\n return res;\n };\n // grid cols have changed - this also means the number of rows in the header can have\n // changed. so we remove all the old rows and insert new ones for a complete refresh\n HeaderRowContainerCtrl.prototype.onGridColumnsChanged = function () {\n this.refresh(true);\n };\n HeaderRowContainerCtrl.prototype.setupCenterWidth = function () {\n var _this = this;\n if (this.pinned != null) {\n return;\n }\n this.createManagedBean(new CenterWidthFeature(function (width) { return _this.comp.setCenterWidth(width + \"px\"); }));\n };\n HeaderRowContainerCtrl.prototype.setHorizontalScroll = function (offset) {\n this.comp.setContainerTransform(\"translateX(\" + offset + \"px)\");\n };\n HeaderRowContainerCtrl.prototype.resetScrollLeft = function () {\n this.eViewport.scrollLeft = 0;\n };\n HeaderRowContainerCtrl.prototype.setupPinnedWidth = function () {\n var _this = this;\n if (this.pinned == null) {\n return;\n }\n var pinningLeft = this.pinned === Constants.PINNED_LEFT;\n var pinningRight = this.pinned === Constants.PINNED_RIGHT;\n var listener = function () {\n var width = pinningLeft ? _this.pinnedWidthService.getPinnedLeftWidth() : _this.pinnedWidthService.getPinnedRightWidth();\n if (width == null) {\n return;\n } // can happen at initialisation, width not yet set\n var hidden = width == 0;\n var isRtl = _this.gridOptionsWrapper.isEnableRtl();\n var scrollbarWidth = _this.gridOptionsWrapper.getScrollbarWidth();\n // if there is a scroll showing (and taking up space, so Windows, and not iOS)\n // in the body, then we add extra space to keep header aligned with the body,\n // as body width fits the cols and the scrollbar\n var addPaddingForScrollbar = _this.scrollVisibleService.isVerticalScrollShowing() && ((isRtl && pinningLeft) || (!isRtl && pinningRight));\n var widthWithPadding = addPaddingForScrollbar ? width + scrollbarWidth : width;\n _this.comp.setPinnedContainerWidth(widthWithPadding + 'px');\n _this.comp.addOrRemoveCssClass('ag-hidden', hidden);\n };\n this.addManagedListener(this.eventService, Events.EVENT_LEFT_PINNED_WIDTH_CHANGED, listener);\n this.addManagedListener(this.eventService, Events.EVENT_RIGHT_PINNED_WIDTH_CHANGED, listener);\n this.addManagedListener(this.eventService, Events.EVENT_SCROLL_VISIBILITY_CHANGED, listener);\n this.addManagedListener(this.eventService, Events.EVENT_SCROLLBAR_WIDTH_CHANGED, listener);\n };\n HeaderRowContainerCtrl.prototype.getHeaderCtrlForColumn = function (column) {\n if (column instanceof Column) {\n if (!this.columnsRowCtrl) {\n return;\n }\n return this.columnsRowCtrl.getHeaderCellCtrl(column);\n }\n if (this.groupsRowCtrls.length === 0) {\n return;\n }\n for (var i = 0; i < this.groupsRowCtrls.length; i++) {\n var ctrl = this.groupsRowCtrls[i].getHeaderCellCtrl(column);\n if (ctrl) {\n return ctrl;\n }\n }\n };\n HeaderRowContainerCtrl.prototype.getHtmlElementForColumnHeader = function (column) {\n /* tslint:enable */\n var cellCtrl = this.getHeaderCtrlForColumn(column);\n if (!cellCtrl) {\n return null;\n }\n return cellCtrl.getGui();\n };\n HeaderRowContainerCtrl.prototype.getRowType = function (rowIndex) {\n var allCtrls = this.getAllCtrls();\n var ctrl = allCtrls[rowIndex];\n return ctrl ? ctrl.getType() : undefined;\n };\n HeaderRowContainerCtrl.prototype.focusHeader = function (rowIndex, column, event) {\n var allCtrls = this.getAllCtrls();\n var ctrl = allCtrls[rowIndex];\n if (!ctrl) {\n return false;\n }\n return ctrl.focusHeader(column, event);\n };\n HeaderRowContainerCtrl.prototype.getRowCount = function () {\n return this.getAllCtrls().length;\n };\n __decorate([\n Autowired('ctrlsService')\n ], HeaderRowContainerCtrl.prototype, \"ctrlsService\", void 0);\n __decorate([\n Autowired('scrollVisibleService')\n ], HeaderRowContainerCtrl.prototype, \"scrollVisibleService\", void 0);\n __decorate([\n Autowired('pinnedWidthService')\n ], HeaderRowContainerCtrl.prototype, \"pinnedWidthService\", void 0);\n __decorate([\n Autowired('columnModel')\n ], HeaderRowContainerCtrl.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('focusService')\n ], HeaderRowContainerCtrl.prototype, \"focusService\", void 0);\n return HeaderRowContainerCtrl;\n}(BeanStub));\nexport { HeaderRowContainerCtrl };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Constants } from '../../constants/constants';\nimport { PostConstruct, PreDestroy } from '../../context/context';\nimport { ensureDomOrder } from '../../utils/dom';\nimport { getAllValuesInObject } from '../../utils/object';\nimport { Component } from '../../widgets/component';\nimport { RefSelector } from '../../widgets/componentAnnotations';\nimport { HeaderRowComp } from '../row/headerRowComp';\nimport { HeaderRowContainerCtrl } from './headerRowContainerCtrl';\nvar HeaderRowContainerComp = /** @class */ (function (_super) {\n __extends(HeaderRowContainerComp, _super);\n function HeaderRowContainerComp(pinned) {\n var _this = _super.call(this) || this;\n _this.headerRowComps = {};\n _this.rowCompsList = [];\n _this.pinned = pinned;\n return _this;\n }\n HeaderRowContainerComp.prototype.init = function () {\n var _this = this;\n this.selectAndSetTemplate();\n var compProxy = {\n addOrRemoveCssClass: function (cssClassName, on) { return _this.addOrRemoveCssClass(cssClassName, on); },\n setCtrls: function (ctrls) { return _this.setCtrls(ctrls); },\n // only gets called for center section\n setCenterWidth: function (width) { return _this.eCenterContainer.style.width = width; },\n setContainerTransform: function (transform) { return _this.eCenterContainer.style.transform = transform; },\n // only gets called for pinned sections\n setPinnedContainerWidth: function (width) {\n var eGui = _this.getGui();\n eGui.style.width = width;\n eGui.style.maxWidth = width;\n eGui.style.minWidth = width;\n }\n };\n var ctrl = this.createManagedBean(new HeaderRowContainerCtrl(this.pinned));\n ctrl.setComp(compProxy, this.getGui());\n };\n HeaderRowContainerComp.prototype.selectAndSetTemplate = function () {\n var pinnedLeft = this.pinned == Constants.PINNED_LEFT;\n var pinnedRight = this.pinned == Constants.PINNED_RIGHT;\n var template = pinnedLeft ? HeaderRowContainerComp.PINNED_LEFT_TEMPLATE :\n pinnedRight ? HeaderRowContainerComp.PINNED_RIGHT_TEMPLATE : HeaderRowContainerComp.CENTER_TEMPLATE;\n this.setTemplate(template);\n // for left and right, we add rows directly to the root element,\n // but for center container we add elements to the child container.\n this.eRowContainer = this.eCenterContainer ? this.eCenterContainer : this.getGui();\n };\n HeaderRowContainerComp.prototype.destroyRowComps = function () {\n this.setCtrls([]);\n };\n HeaderRowContainerComp.prototype.destroyRowComp = function (rowComp) {\n this.destroyBean(rowComp);\n this.eRowContainer.removeChild(rowComp.getGui());\n };\n HeaderRowContainerComp.prototype.setCtrls = function (ctrls) {\n var _this = this;\n var oldRowComps = this.headerRowComps;\n this.headerRowComps = {};\n this.rowCompsList = [];\n var prevGui;\n var appendEnsuringDomOrder = function (rowComp) {\n var eGui = rowComp.getGui();\n var notAlreadyIn = eGui.parentElement != _this.eRowContainer;\n if (notAlreadyIn) {\n _this.eRowContainer.appendChild(eGui);\n }\n if (prevGui) {\n ensureDomOrder(_this.eRowContainer, eGui, prevGui);\n }\n prevGui = eGui;\n };\n ctrls.forEach(function (ctrl) {\n var ctrlId = ctrl.getInstanceId();\n var existingComp = oldRowComps[ctrlId];\n delete oldRowComps[ctrlId];\n var rowComp = existingComp ? existingComp : _this.createBean(new HeaderRowComp(ctrl));\n _this.headerRowComps[ctrlId] = rowComp;\n _this.rowCompsList.push(rowComp);\n appendEnsuringDomOrder(rowComp);\n });\n getAllValuesInObject(oldRowComps).forEach(function (c) { return _this.destroyRowComp(c); });\n };\n HeaderRowContainerComp.PINNED_LEFT_TEMPLATE = \"
\";\n HeaderRowContainerComp.PINNED_RIGHT_TEMPLATE = \"
\";\n HeaderRowContainerComp.CENTER_TEMPLATE = \"
\\n
\\n
\";\n __decorate([\n RefSelector('eCenterContainer')\n ], HeaderRowContainerComp.prototype, \"eCenterContainer\", void 0);\n __decorate([\n PostConstruct\n ], HeaderRowContainerComp.prototype, \"init\", null);\n __decorate([\n PreDestroy\n ], HeaderRowContainerComp.prototype, \"destroyRowComps\", null);\n return HeaderRowContainerComp;\n}(Component));\nexport { HeaderRowContainerComp };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub\";\nimport { Autowired, Bean, PostConstruct } from \"../../context/context\";\nimport { ColumnGroup } from \"../../entities/columnGroup\";\nimport { last } from \"../../utils/array\";\nimport { HeaderRowType } from \"../row/headerRowComp\";\nexport var HeaderNavigationDirection;\n(function (HeaderNavigationDirection) {\n HeaderNavigationDirection[HeaderNavigationDirection[\"UP\"] = 0] = \"UP\";\n HeaderNavigationDirection[HeaderNavigationDirection[\"DOWN\"] = 1] = \"DOWN\";\n HeaderNavigationDirection[HeaderNavigationDirection[\"LEFT\"] = 2] = \"LEFT\";\n HeaderNavigationDirection[HeaderNavigationDirection[\"RIGHT\"] = 3] = \"RIGHT\";\n})(HeaderNavigationDirection || (HeaderNavigationDirection = {}));\nvar HeaderNavigationService = /** @class */ (function (_super) {\n __extends(HeaderNavigationService, _super);\n function HeaderNavigationService() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n HeaderNavigationService.prototype.postConstruct = function () {\n var _this = this;\n this.ctrlsService.whenReady(function (p) {\n _this.gridBodyCon = p.gridBodyCtrl;\n });\n };\n HeaderNavigationService.prototype.getHeaderRowCount = function () {\n var centerHeaderContainer = this.ctrlsService.getHeaderRowContainerCtrl();\n return centerHeaderContainer ? centerHeaderContainer.getRowCount() : 0;\n };\n HeaderNavigationService.prototype.getHeaderRowType = function (rowIndex) {\n var centerHeaderContainer = this.ctrlsService.getHeaderRowContainerCtrl();\n if (centerHeaderContainer) {\n return centerHeaderContainer.getRowType(rowIndex);\n }\n };\n /*\n * This method navigates grid header vertically\n * @return {boolean} true to preventDefault on the event that caused this navigation.\n */\n HeaderNavigationService.prototype.navigateVertically = function (direction, fromHeader, event) {\n if (!fromHeader) {\n fromHeader = this.focusService.getFocusedHeader();\n }\n if (!fromHeader) {\n return false;\n }\n var headerRowIndex = fromHeader.headerRowIndex, column = fromHeader.column;\n var rowLen = this.getHeaderRowCount();\n var isUp = direction === HeaderNavigationDirection.UP;\n var nextRow = isUp ? headerRowIndex - 1 : headerRowIndex + 1;\n var nextFocusColumn = null;\n var skipColumn = false;\n if (nextRow < 0) {\n nextRow = 0;\n nextFocusColumn = column;\n skipColumn = true;\n }\n if (nextRow >= rowLen) {\n nextRow = -1; // -1 indicates the focus should move to grid rows.\n }\n var currentRowType = this.getHeaderRowType(headerRowIndex);\n if (!skipColumn) {\n if (currentRowType === HeaderRowType.COLUMN_GROUP) {\n var currentColumn = column;\n nextFocusColumn = isUp ? column.getParent() : currentColumn.getDisplayedChildren()[0];\n }\n else if (currentRowType === HeaderRowType.FLOATING_FILTER) {\n nextFocusColumn = column;\n }\n else {\n var currentColumn = column;\n nextFocusColumn = isUp ? currentColumn.getParent() : currentColumn;\n }\n if (!nextFocusColumn) {\n return false;\n }\n }\n return this.focusService.focusHeaderPosition({\n headerPosition: { headerRowIndex: nextRow, column: nextFocusColumn },\n allowUserOverride: true,\n event: event\n });\n };\n /*\n * This method navigates grid header horizontally\n * @return {boolean} true to preventDefault on the event that caused this navigation.\n */\n HeaderNavigationService.prototype.navigateHorizontally = function (direction, fromTab, event) {\n if (fromTab === void 0) { fromTab = false; }\n var focusedHeader = this.focusService.getFocusedHeader();\n var isLeft = direction === HeaderNavigationDirection.LEFT;\n var isRtl = this.gridOptionsWrapper.isEnableRtl();\n var nextHeader;\n var normalisedDirection;\n // either navigating to the left or isRtl (cannot be both)\n if (isLeft !== isRtl) {\n normalisedDirection = 'Before';\n nextHeader = this.headerPositionUtils.findHeader(focusedHeader, normalisedDirection);\n }\n else {\n normalisedDirection = 'After';\n nextHeader = this.headerPositionUtils.findHeader(focusedHeader, normalisedDirection);\n }\n if (nextHeader || !fromTab) {\n return this.focusService.focusHeaderPosition({\n headerPosition: nextHeader,\n direction: normalisedDirection,\n fromTab: fromTab,\n allowUserOverride: true,\n event: event\n });\n }\n return this.focusNextHeaderRow(focusedHeader, normalisedDirection, event);\n };\n HeaderNavigationService.prototype.focusNextHeaderRow = function (focusedHeader, direction, event) {\n var currentIndex = focusedHeader.headerRowIndex;\n var nextPosition = null;\n var nextRowIndex;\n if (direction === 'Before') {\n if (currentIndex > 0) {\n nextRowIndex = currentIndex - 1;\n nextPosition = this.headerPositionUtils.findColAtEdgeForHeaderRow(nextRowIndex, 'end');\n }\n }\n else {\n nextRowIndex = currentIndex + 1;\n nextPosition = this.headerPositionUtils.findColAtEdgeForHeaderRow(nextRowIndex, 'start');\n }\n return this.focusService.focusHeaderPosition({\n headerPosition: nextPosition,\n direction: direction,\n fromTab: true,\n allowUserOverride: true,\n event: event\n });\n };\n HeaderNavigationService.prototype.scrollToColumn = function (column, direction) {\n if (direction === void 0) { direction = 'After'; }\n if (column.getPinned()) {\n return;\n }\n var columnToScrollTo;\n if (column instanceof ColumnGroup) {\n var columns = column.getDisplayedLeafColumns();\n columnToScrollTo = direction === 'Before' ? last(columns) : columns[0];\n }\n else {\n columnToScrollTo = column;\n }\n this.gridBodyCon.getScrollFeature().ensureColumnVisible(columnToScrollTo);\n };\n __decorate([\n Autowired('focusService')\n ], HeaderNavigationService.prototype, \"focusService\", void 0);\n __decorate([\n Autowired('headerPositionUtils')\n ], HeaderNavigationService.prototype, \"headerPositionUtils\", void 0);\n __decorate([\n Autowired('animationFrameService')\n ], HeaderNavigationService.prototype, \"animationFrameService\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], HeaderNavigationService.prototype, \"ctrlsService\", void 0);\n __decorate([\n PostConstruct\n ], HeaderNavigationService.prototype, \"postConstruct\", null);\n HeaderNavigationService = __decorate([\n Bean('headerNavigationService')\n ], HeaderNavigationService);\n return HeaderNavigationService;\n}(BeanStub));\nexport { HeaderNavigationService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { KeyCode } from \"../constants/keyCode\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { Autowired } from \"../context/context\";\nimport { Events } from \"../eventKeys\";\nimport { GridOptionsWrapper } from \"../gridOptionsWrapper\";\nimport { exists } from \"../utils/generic\";\nimport { ManagedFocusFeature } from \"../widgets/managedFocusFeature\";\nimport { HeaderNavigationDirection } from \"./common/headerNavigationService\";\nvar GridHeaderCtrl = /** @class */ (function (_super) {\n __extends(GridHeaderCtrl, _super);\n function GridHeaderCtrl() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n GridHeaderCtrl.prototype.setComp = function (comp, eGui, eFocusableElement) {\n this.comp = comp;\n this.eGui = eGui;\n this.createManagedBean(new ManagedFocusFeature(eFocusableElement, {\n onTabKeyDown: this.onTabKeyDown.bind(this),\n handleKeyDown: this.handleKeyDown.bind(this),\n onFocusOut: this.onFocusOut.bind(this)\n }));\n // for setting ag-pivot-on / ag-pivot-off CSS classes\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PIVOT_MODE_CHANGED, this.onPivotModeChanged.bind(this));\n this.onPivotModeChanged();\n this.setupHeaderHeight();\n this.ctrlsService.registerGridHeaderCtrl(this);\n };\n GridHeaderCtrl.prototype.setupHeaderHeight = function () {\n var listener = this.setHeaderHeight.bind(this);\n listener();\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_HEADER_HEIGHT, listener);\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_PIVOT_HEADER_HEIGHT, listener);\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_GROUP_HEADER_HEIGHT, listener);\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_PIVOT_GROUP_HEADER_HEIGHT, listener);\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_FLOATING_FILTERS_HEIGHT, listener);\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, listener);\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_HEADER_HEIGHT_CHANGED, listener);\n };\n GridHeaderCtrl.prototype.getHeaderHeight = function () {\n return this.headerHeight;\n };\n GridHeaderCtrl.prototype.setHeaderHeight = function () {\n var _a = this, columnModel = _a.columnModel, gridOptionsWrapper = _a.gridOptionsWrapper;\n var numberOfFloating = 0;\n var headerRowCount = columnModel.getHeaderRowCount();\n var totalHeaderHeight;\n var hasFloatingFilters = columnModel.hasFloatingFilters();\n if (hasFloatingFilters) {\n headerRowCount++;\n numberOfFloating = 1;\n }\n var groupHeight = this.columnModel.getColumnGroupHeaderRowHeight();\n var headerHeight = this.columnModel.getColumnHeaderRowHeight();\n var numberOfNonGroups = 1 + numberOfFloating;\n var numberOfGroups = headerRowCount - numberOfNonGroups;\n totalHeaderHeight = numberOfFloating * gridOptionsWrapper.getFloatingFiltersHeight();\n totalHeaderHeight += numberOfGroups * groupHeight;\n totalHeaderHeight += headerHeight;\n if (this.headerHeight === totalHeaderHeight) {\n return;\n }\n this.headerHeight = totalHeaderHeight;\n // one extra pixel is needed here to account for the\n // height of the border\n var px = totalHeaderHeight + 1 + \"px\";\n this.comp.setHeightAndMinHeight(px);\n this.eventService.dispatchEvent({\n type: Events.EVENT_HEADER_HEIGHT_CHANGED\n });\n };\n GridHeaderCtrl.prototype.onPivotModeChanged = function () {\n var pivotMode = this.columnModel.isPivotMode();\n this.comp.addOrRemoveCssClass('ag-pivot-on', pivotMode);\n this.comp.addOrRemoveCssClass('ag-pivot-off', !pivotMode);\n };\n GridHeaderCtrl.prototype.onTabKeyDown = function (e) {\n var isRtl = this.gridOptionsWrapper.isEnableRtl();\n var direction = e.shiftKey !== isRtl\n ? HeaderNavigationDirection.LEFT\n : HeaderNavigationDirection.RIGHT;\n if (this.headerNavigationService.navigateHorizontally(direction, true, e) ||\n this.focusService.focusNextGridCoreContainer(e.shiftKey)) {\n e.preventDefault();\n }\n };\n GridHeaderCtrl.prototype.handleKeyDown = function (e) {\n var direction = null;\n switch (e.key) {\n case KeyCode.LEFT:\n direction = HeaderNavigationDirection.LEFT;\n case KeyCode.RIGHT:\n if (!exists(direction)) {\n direction = HeaderNavigationDirection.RIGHT;\n }\n this.headerNavigationService.navigateHorizontally(direction, false, e);\n break;\n case KeyCode.UP:\n direction = HeaderNavigationDirection.UP;\n case KeyCode.DOWN:\n if (!exists(direction)) {\n direction = HeaderNavigationDirection.DOWN;\n }\n if (this.headerNavigationService.navigateVertically(direction, null, e)) {\n e.preventDefault();\n }\n break;\n default:\n return;\n }\n };\n GridHeaderCtrl.prototype.onFocusOut = function (e) {\n var eDocument = this.gridOptionsWrapper.getDocument();\n var relatedTarget = e.relatedTarget;\n if (!relatedTarget && this.eGui.contains(eDocument.activeElement)) {\n return;\n }\n if (!this.eGui.contains(relatedTarget)) {\n this.focusService.clearFocusedHeader();\n }\n };\n __decorate([\n Autowired('headerNavigationService')\n ], GridHeaderCtrl.prototype, \"headerNavigationService\", void 0);\n __decorate([\n Autowired('focusService')\n ], GridHeaderCtrl.prototype, \"focusService\", void 0);\n __decorate([\n Autowired('columnModel')\n ], GridHeaderCtrl.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], GridHeaderCtrl.prototype, \"ctrlsService\", void 0);\n return GridHeaderCtrl;\n}(BeanStub));\nexport { GridHeaderCtrl };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Constants } from '../constants/constants';\nimport { PostConstruct } from '../context/context';\nimport { Component } from '../widgets/component';\nimport { GridHeaderCtrl } from './gridHeaderCtrl';\nimport { HeaderRowContainerComp } from './rowContainer/headerRowContainerComp';\nvar GridHeaderComp = /** @class */ (function (_super) {\n __extends(GridHeaderComp, _super);\n function GridHeaderComp() {\n return _super.call(this, GridHeaderComp.TEMPLATE) || this;\n }\n GridHeaderComp.prototype.postConstruct = function () {\n var _this = this;\n var compProxy = {\n addOrRemoveCssClass: function (cssClassName, on) { return _this.addOrRemoveCssClass(cssClassName, on); },\n setHeightAndMinHeight: function (height) {\n _this.getGui().style.height = height;\n _this.getGui().style.minHeight = height;\n }\n };\n var ctrl = this.createManagedBean(new GridHeaderCtrl());\n ctrl.setComp(compProxy, this.getGui(), this.getFocusableElement());\n var addContainer = function (container) {\n _this.createManagedBean(container);\n _this.appendChild(container);\n };\n addContainer(new HeaderRowContainerComp(Constants.PINNED_LEFT));\n addContainer(new HeaderRowContainerComp(null));\n addContainer(new HeaderRowContainerComp(Constants.PINNED_RIGHT));\n };\n GridHeaderComp.TEMPLATE = \"
\";\n __decorate([\n PostConstruct\n ], GridHeaderComp.prototype, \"postConstruct\", null);\n return GridHeaderComp;\n}(Component));\nexport { GridHeaderComp };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean } from \"../../context/context\";\nimport { BeanStub } from \"../../context/beanStub\";\nvar HorizontalResizeService = /** @class */ (function (_super) {\n __extends(HorizontalResizeService, _super);\n function HorizontalResizeService() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n HorizontalResizeService.prototype.addResizeBar = function (params) {\n var _this = this;\n var dragSource = {\n dragStartPixels: params.dragStartPixels || 0,\n eElement: params.eResizeBar,\n onDragStart: this.onDragStart.bind(this, params),\n onDragStop: this.onDragStop.bind(this, params),\n onDragging: this.onDragging.bind(this, params)\n };\n this.dragService.addDragSource(dragSource, true);\n // we pass remove func back to the caller, so call can tell us when they\n // are finished, and then we remove the listener from the drag source\n var finishedWithResizeFunc = function () { return _this.dragService.removeDragSource(dragSource); };\n return finishedWithResizeFunc;\n };\n HorizontalResizeService.prototype.onDragStart = function (params, mouseEvent) {\n this.dragStartX = mouseEvent.clientX;\n this.setResizeIcons();\n var shiftKey = mouseEvent instanceof MouseEvent && mouseEvent.shiftKey === true;\n params.onResizeStart(shiftKey);\n };\n HorizontalResizeService.prototype.setResizeIcons = function () {\n var ctrl = this.ctrlsService.getGridCtrl();\n // change the body cursor, so when drag moves out of the drag bar, the cursor is still 'resize' (or 'move'\n ctrl.setResizeCursor(true);\n // we don't want text selection outside the grid (otherwise it looks weird as text highlights when we move)\n ctrl.disableUserSelect(true);\n };\n HorizontalResizeService.prototype.onDragStop = function (params, mouseEvent) {\n params.onResizeEnd(this.resizeAmount);\n this.resetIcons();\n };\n HorizontalResizeService.prototype.resetIcons = function () {\n var ctrl = this.ctrlsService.getGridCtrl();\n ctrl.setResizeCursor(false);\n ctrl.disableUserSelect(false);\n };\n HorizontalResizeService.prototype.onDragging = function (params, mouseEvent) {\n this.resizeAmount = mouseEvent.clientX - this.dragStartX;\n params.onResizing(this.resizeAmount);\n };\n __decorate([\n Autowired('dragService')\n ], HorizontalResizeService.prototype, \"dragService\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], HorizontalResizeService.prototype, \"ctrlsService\", void 0);\n HorizontalResizeService = __decorate([\n Bean('horizontalResizeService')\n ], HorizontalResizeService);\n return HorizontalResizeService;\n}(BeanStub));\nexport { HorizontalResizeService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean } from '../../../context/context';\nimport { BeanStub } from \"../../../context/beanStub\";\nimport { isVisible } from '../../../utils/dom';\nimport { KeyCode } from '../../../constants/keyCode';\nimport { setAriaRole } from '../../../utils/aria';\nvar StandardMenuFactory = /** @class */ (function (_super) {\n __extends(StandardMenuFactory, _super);\n function StandardMenuFactory() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n StandardMenuFactory.prototype.hideActiveMenu = function () {\n if (this.hidePopup) {\n this.hidePopup();\n }\n };\n StandardMenuFactory.prototype.showMenuAfterMouseEvent = function (column, mouseEvent) {\n var _this = this;\n this.showPopup(column, function (eMenu) {\n _this.popupService.positionPopupUnderMouseEvent({\n column: column,\n type: 'columnMenu',\n mouseEvent: mouseEvent,\n ePopup: eMenu\n });\n }, mouseEvent.target);\n };\n StandardMenuFactory.prototype.showMenuAfterButtonClick = function (column, eventSource, containerType) {\n var _this = this;\n this.showPopup(column, function (eMenu) {\n _this.popupService.positionPopupUnderComponent({\n type: containerType,\n eventSource: eventSource,\n ePopup: eMenu,\n keepWithinBounds: true,\n column: column\n });\n }, eventSource);\n };\n StandardMenuFactory.prototype.showPopup = function (column, positionCallback, eventSource) {\n var _this = this;\n var filterWrapper = this.filterManager.getOrCreateFilterWrapper(column, 'COLUMN_MENU');\n if (!filterWrapper) {\n throw new Error('AG Grid - unable to show popup filter, filter instantiation failed');\n }\n var eMenu = document.createElement('div');\n setAriaRole(eMenu, 'presentation');\n eMenu.classList.add('ag-menu');\n this.tabListener = this.addManagedListener(eMenu, 'keydown', function (e) { return _this.trapFocusWithin(e, eMenu); });\n filterWrapper.guiPromise.then(function (gui) { return eMenu.appendChild(gui); });\n var hidePopup;\n var anchorToElement = eventSource || this.ctrlsService.getGridBodyCtrl().getGui();\n var closedCallback = function (e) {\n column.setMenuVisible(false, 'contextMenu');\n var isKeyboardEvent = e instanceof KeyboardEvent;\n if (_this.tabListener) {\n _this.tabListener = _this.tabListener();\n }\n if (isKeyboardEvent && eventSource && isVisible(eventSource)) {\n var focusableEl = _this.focusService.findTabbableParent(eventSource);\n if (focusableEl) {\n focusableEl.focus();\n }\n }\n };\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n var addPopupRes = this.popupService.addPopup({\n modal: true,\n eChild: eMenu,\n closeOnEsc: true,\n closedCallback: closedCallback,\n positionCallback: function () { return positionCallback(eMenu); },\n anchorToElement: anchorToElement,\n ariaLabel: translate('ariaLabelColumnMenu', 'Column Menu')\n });\n if (addPopupRes) {\n this.hidePopup = hidePopup = addPopupRes.hideFunc;\n }\n filterWrapper.filterPromise.then(function (filter) {\n // need to make sure the filter is present before positioning, as only\n // after filter it is visible can we find out what the width of it is\n positionCallback(eMenu);\n if (filter.afterGuiAttached) {\n filter.afterGuiAttached({ container: 'columnMenu', hidePopup: hidePopup });\n }\n });\n column.setMenuVisible(true, 'contextMenu');\n };\n StandardMenuFactory.prototype.trapFocusWithin = function (e, menu) {\n if (e.key !== KeyCode.TAB ||\n e.defaultPrevented ||\n this.focusService.findNextFocusableElement(menu, false, e.shiftKey)) {\n return;\n }\n e.preventDefault();\n this.focusService.focusInto(menu, e.shiftKey);\n };\n StandardMenuFactory.prototype.isMenuEnabled = function (column) {\n // for standard, we show menu if filter is enabled, and the menu is not suppressed\n return column.isFilterAllowed();\n };\n __decorate([\n Autowired('filterManager')\n ], StandardMenuFactory.prototype, \"filterManager\", void 0);\n __decorate([\n Autowired('popupService')\n ], StandardMenuFactory.prototype, \"popupService\", void 0);\n __decorate([\n Autowired('focusService')\n ], StandardMenuFactory.prototype, \"focusService\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], StandardMenuFactory.prototype, \"ctrlsService\", void 0);\n StandardMenuFactory = __decorate([\n Bean('menuFactory')\n ], StandardMenuFactory);\n return StandardMenuFactory;\n}(BeanStub));\nexport { StandardMenuFactory };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { RefSelector } from '../widgets/componentAnnotations';\nimport { ManagedFocusFeature } from '../widgets/managedFocusFeature';\nimport { clearElement } from '../utils/dom';\nimport { setAriaLabel, setAriaRole } from '../utils/aria';\nimport { callIfPresent } from '../utils/function';\nimport { KeyCode } from '../constants/keyCode';\nimport { Component } from '../widgets/component';\nimport { PostConstruct, Autowired } from '../context/context';\nvar TabbedLayout = /** @class */ (function (_super) {\n __extends(TabbedLayout, _super);\n function TabbedLayout(params) {\n var _this = _super.call(this, TabbedLayout.getTemplate(params.cssClass)) || this;\n _this.items = [];\n _this.tabbedItemScrollMap = new Map();\n _this.params = params;\n if (params.items) {\n params.items.forEach(function (item) { return _this.addItem(item); });\n }\n return _this;\n }\n TabbedLayout.prototype.postConstruct = function () {\n this.createManagedBean(new ManagedFocusFeature(this.getFocusableElement(), {\n onTabKeyDown: this.onTabKeyDown.bind(this),\n handleKeyDown: this.handleKeyDown.bind(this)\n }));\n };\n TabbedLayout.getTemplate = function (cssClass) {\n return /* html */ \"
\\n
\\n
\\n
\";\n };\n TabbedLayout.prototype.handleKeyDown = function (e) {\n var eDocument = this.gridOptionsWrapper.getDocument();\n switch (e.key) {\n case KeyCode.RIGHT:\n case KeyCode.LEFT:\n if (!this.eHeader.contains(eDocument.activeElement)) {\n return;\n }\n var isRightKey = e.key === KeyCode.RIGHT;\n var isRtl = this.gridOptionsWrapper.isEnableRtl();\n var currentPosition = this.items.indexOf(this.activeItem);\n var nextPosition = isRightKey !== isRtl ? Math.min(currentPosition + 1, this.items.length - 1) : Math.max(currentPosition - 1, 0);\n if (currentPosition === nextPosition) {\n return;\n }\n e.preventDefault();\n var nextItem = this.items[nextPosition];\n this.showItemWrapper(nextItem);\n nextItem.eHeaderButton.focus();\n break;\n case KeyCode.UP:\n case KeyCode.DOWN:\n e.stopPropagation();\n break;\n }\n };\n TabbedLayout.prototype.onTabKeyDown = function (e) {\n if (e.defaultPrevented) {\n return;\n }\n var _a = this, focusService = _a.focusService, eHeader = _a.eHeader, eBody = _a.eBody, activeItem = _a.activeItem;\n var eDocument = this.gridOptionsWrapper.getDocument();\n var activeElement = eDocument.activeElement;\n e.preventDefault();\n if (eHeader.contains(activeElement)) {\n // focus is in header, move into body of popup\n focusService.focusInto(eBody, e.shiftKey);\n }\n else {\n // focus is in body, establish if it should return to header\n if (focusService.isFocusUnderManagedComponent(eBody)) {\n // focus was in a managed focus component and has now left, so we can return to the header\n activeItem.eHeaderButton.focus();\n }\n else {\n var nextEl = focusService.findNextFocusableElement(eBody, false, e.shiftKey);\n if (nextEl) {\n // if another element exists in the body that can be focussed, go to that\n nextEl.focus();\n }\n else {\n // otherwise return to the header\n activeItem.eHeaderButton.focus();\n }\n }\n }\n };\n TabbedLayout.prototype.setAfterAttachedParams = function (params) {\n this.afterAttachedParams = params;\n };\n TabbedLayout.prototype.showFirstItem = function () {\n if (this.items.length > 0) {\n this.showItemWrapper(this.items[0]);\n }\n };\n TabbedLayout.prototype.addItem = function (item) {\n var eHeaderButton = document.createElement('span');\n setAriaRole(eHeaderButton, 'tab');\n eHeaderButton.setAttribute('tabIndex', '-1');\n eHeaderButton.appendChild(item.title);\n eHeaderButton.classList.add('ag-tab');\n this.eHeader.appendChild(eHeaderButton);\n setAriaLabel(eHeaderButton, item.titleLabel);\n var wrapper = {\n tabbedItem: item,\n eHeaderButton: eHeaderButton\n };\n this.items.push(wrapper);\n eHeaderButton.addEventListener('click', this.showItemWrapper.bind(this, wrapper));\n };\n TabbedLayout.prototype.showItem = function (tabbedItem) {\n var itemWrapper = this.items.find(function (wrapper) { return wrapper.tabbedItem === tabbedItem; });\n if (itemWrapper) {\n this.showItemWrapper(itemWrapper);\n }\n };\n TabbedLayout.prototype.showItemWrapper = function (wrapper) {\n var _this = this;\n var tabbedItem = wrapper.tabbedItem, eHeaderButton = wrapper.eHeaderButton;\n if (this.params.onItemClicked) {\n this.params.onItemClicked({ item: tabbedItem });\n }\n if (this.activeItem === wrapper) {\n callIfPresent(this.params.onActiveItemClicked);\n return;\n }\n if (this.lastScrollListener) {\n this.lastScrollListener = this.lastScrollListener();\n }\n clearElement(this.eBody);\n tabbedItem.bodyPromise.then(function (body) {\n _this.eBody.appendChild(body);\n var onlyUnmanaged = !_this.focusService.isKeyboardMode();\n _this.focusService.focusInto(_this.eBody, false, onlyUnmanaged);\n if (tabbedItem.afterAttachedCallback) {\n tabbedItem.afterAttachedCallback(_this.afterAttachedParams);\n }\n if (_this.params.keepScrollPosition) {\n var scrollableContainer_1 = (tabbedItem.getScrollableContainer && tabbedItem.getScrollableContainer()) || body;\n _this.lastScrollListener = _this.addManagedListener(scrollableContainer_1, 'scroll', function () {\n _this.tabbedItemScrollMap.set(tabbedItem.name, scrollableContainer_1.scrollTop);\n });\n var scrollPosition_1 = _this.tabbedItemScrollMap.get(tabbedItem.name);\n if (scrollPosition_1 !== undefined) {\n // Safari needs a small timeout or it will fire a scroll event to position 0\n setTimeout(function () {\n scrollableContainer_1.scrollTop = scrollPosition_1;\n }, 0);\n }\n }\n });\n if (this.activeItem) {\n this.activeItem.eHeaderButton.classList.remove('ag-tab-selected');\n }\n eHeaderButton.classList.add('ag-tab-selected');\n this.activeItem = wrapper;\n };\n __decorate([\n Autowired('focusService')\n ], TabbedLayout.prototype, \"focusService\", void 0);\n __decorate([\n RefSelector('eHeader')\n ], TabbedLayout.prototype, \"eHeader\", void 0);\n __decorate([\n RefSelector('eBody')\n ], TabbedLayout.prototype, \"eBody\", void 0);\n __decorate([\n PostConstruct\n ], TabbedLayout.prototype, \"postConstruct\", null);\n return TabbedLayout;\n}(Component));\nexport { TabbedLayout };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { debounce } from \"../utils/function\";\nimport { offsetHeight, offsetWidth } from \"../utils/dom\";\nvar DEBOUNCE_DELAY = 50;\nvar ResizeObserverService = /** @class */ (function (_super) {\n __extends(ResizeObserverService, _super);\n function ResizeObserverService() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.polyfillFunctions = [];\n return _this;\n }\n ResizeObserverService.prototype.observeResize = function (element, callback) {\n var _this = this;\n var eDocument = this.gridOptionsWrapper.getDocument();\n var win = (eDocument.defaultView || window);\n // this gets fired too often and might cause some relayout issues\n // so we add a debounce to the callback here to avoid the flashing effect.\n var debouncedCallback = debounce(callback, DEBOUNCE_DELAY);\n var useBrowserResizeObserver = function () {\n var resizeObserver = new win.ResizeObserver(debouncedCallback);\n resizeObserver.observe(element);\n return function () { return resizeObserver.disconnect(); };\n };\n var usePolyfill = function () {\n // initialise to the current width and height, so first call will have no changes\n var widthLastTime = offsetWidth(element);\n var heightLastTime = offsetHeight(element);\n // when finished, this gets turned to false.\n var running = true;\n var periodicallyCheckWidthAndHeight = function () {\n if (running) {\n var newWidth = offsetWidth(element);\n var newHeight = offsetHeight(element);\n var changed = newWidth !== widthLastTime || newHeight !== heightLastTime;\n if (changed) {\n widthLastTime = newWidth;\n heightLastTime = newHeight;\n callback();\n }\n _this.doNextPolyfillTurn(periodicallyCheckWidthAndHeight);\n }\n };\n periodicallyCheckWidthAndHeight();\n // the callback function we return sets running to false\n return function () { return running = false; };\n };\n var suppressResize = this.gridOptionsWrapper.isSuppressBrowserResizeObserver();\n var resizeObserverExists = !!win.ResizeObserver;\n if (resizeObserverExists && !suppressResize) {\n return useBrowserResizeObserver();\n }\n return usePolyfill();\n };\n ResizeObserverService.prototype.doNextPolyfillTurn = function (func) {\n this.polyfillFunctions.push(func);\n this.schedulePolyfill();\n };\n ResizeObserverService.prototype.schedulePolyfill = function () {\n var _this = this;\n if (this.polyfillScheduled) {\n return;\n }\n var executeAllFuncs = function () {\n var funcs = _this.polyfillFunctions;\n // make sure set scheduled to false and clear clear array\n // before executing the funcs, as the funcs could add more funcs\n _this.polyfillScheduled = false;\n _this.polyfillFunctions = [];\n funcs.forEach(function (f) { return f(); });\n };\n this.polyfillScheduled = true;\n this.getFrameworkOverrides().setTimeout(executeAllFuncs, DEBOUNCE_DELAY);\n };\n ResizeObserverService = __decorate([\n Bean('resizeObserverService')\n ], ResizeObserverService);\n return ResizeObserverService;\n}(BeanStub));\nexport { ResizeObserverService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, PostConstruct } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nvar AnimationFrameService = /** @class */ (function (_super) {\n __extends(AnimationFrameService, _super);\n function AnimationFrameService() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n // p1 and p2 are create tasks are to do with row and cell creation.\n // for them we want to execute according to row order, so we use\n // TaskItem so we know what index the item is for.\n _this.createTasksP1 = { list: [], sorted: false }; // eg drawing back-ground of rows\n _this.createTasksP2 = { list: [], sorted: false }; // eg cell renderers, adding hover functionality\n // destroy tasks are to do with row removal. they are done after row creation as the user will need to see new\n // rows first (as blank is scrolled into view), when we remove the old rows (no longer in view) is not as\n // important.\n _this.destroyTasks = [];\n _this.ticking = false;\n // we need to know direction of scroll, to build up rows in the direction of\n // the scroll. eg if user scrolls down, we extend the rows by building down.\n _this.scrollGoingDown = true;\n _this.lastScrollTop = 0;\n _this.taskCount = 0;\n _this.cancelledTasks = new Set();\n return _this;\n }\n AnimationFrameService.prototype.setScrollTop = function (scrollTop) {\n this.scrollGoingDown = scrollTop > this.lastScrollTop;\n this.lastScrollTop = scrollTop;\n };\n AnimationFrameService.prototype.init = function () {\n this.useAnimationFrame = !this.gridOptionsWrapper.isSuppressAnimationFrame();\n };\n AnimationFrameService.prototype.isOn = function () {\n return this.useAnimationFrame;\n };\n // this method is for our AG Grid sanity only - if animation frames are turned off,\n // then no place in the code should be looking to add any work to be done in animation\n // frames. this stops bugs - where some code is asking for a frame to be executed\n // when it should not.\n AnimationFrameService.prototype.verifyAnimationFrameOn = function (methodName) {\n if (this.useAnimationFrame === false) {\n console.warn(\"AG Grid: AnimationFrameService.\" + methodName + \" called but animation frames are off\");\n }\n };\n AnimationFrameService.prototype.createTask = function (task, index, list) {\n this.verifyAnimationFrameOn(list);\n var taskItem = { task: task, index: index, createOrder: ++this.taskCount };\n this.addTaskToList(this[list], taskItem);\n this.schedule();\n };\n AnimationFrameService.prototype.cancelTask = function (task) {\n this.cancelledTasks.add(task);\n };\n AnimationFrameService.prototype.addTaskToList = function (taskList, task) {\n taskList.list.push(task);\n taskList.sorted = false;\n };\n AnimationFrameService.prototype.sortTaskList = function (taskList) {\n if (taskList.sorted) {\n return;\n }\n var sortDirection = this.scrollGoingDown ? 1 : -1;\n // sort first by row index (taking into account scroll direction), then by\n // order of task creation (always ascending, so cells will render left-to-right)\n taskList.list.sort(function (a, b) { return a.index !== b.index ? sortDirection * (b.index - a.index) : b.createOrder - a.createOrder; });\n taskList.sorted = true;\n };\n AnimationFrameService.prototype.addDestroyTask = function (task) {\n this.verifyAnimationFrameOn('createTasksP3');\n this.destroyTasks.push(task);\n this.schedule();\n };\n AnimationFrameService.prototype.executeFrame = function (millis) {\n this.verifyAnimationFrameOn('executeFrame');\n var p1TaskList = this.createTasksP1;\n var p1Tasks = p1TaskList.list;\n var p2TaskList = this.createTasksP2;\n var p2Tasks = p2TaskList.list;\n var destroyTasks = this.destroyTasks;\n var frameStart = new Date().getTime();\n var duration = (new Date().getTime()) - frameStart;\n // 16ms is 60 fps\n var noMaxMillis = millis <= 0;\n var gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n while (noMaxMillis || duration < millis) {\n var gridBodyDidSomething = gridBodyCon.getScrollFeature().executeAnimationFrameScroll();\n if (!gridBodyDidSomething) {\n var task = void 0;\n if (p1Tasks.length) {\n this.sortTaskList(p1TaskList);\n task = p1Tasks.pop().task;\n }\n else if (p2Tasks.length) {\n this.sortTaskList(p2TaskList);\n task = p2Tasks.pop().task;\n }\n else if (destroyTasks.length) {\n task = destroyTasks.pop();\n }\n else {\n this.cancelledTasks.clear();\n break;\n }\n if (!this.cancelledTasks.has(task)) {\n task();\n }\n }\n duration = (new Date().getTime()) - frameStart;\n }\n if (p1Tasks.length || p2Tasks.length || destroyTasks.length) {\n this.requestFrame();\n }\n else {\n this.stopTicking();\n }\n };\n AnimationFrameService.prototype.stopTicking = function () {\n this.ticking = false;\n };\n AnimationFrameService.prototype.flushAllFrames = function () {\n if (!this.useAnimationFrame) {\n return;\n }\n this.executeFrame(-1);\n };\n AnimationFrameService.prototype.schedule = function () {\n if (!this.useAnimationFrame) {\n return;\n }\n if (!this.ticking) {\n this.ticking = true;\n this.requestFrame();\n }\n };\n AnimationFrameService.prototype.requestFrame = function () {\n // check for the existence of requestAnimationFrame, and if\n // it's missing, then we polyfill it with setTimeout()\n var callback = this.executeFrame.bind(this, 60);\n var eDocument = this.gridOptionsWrapper.getDocument();\n var win = (eDocument.defaultView || window);\n if (win.requestAnimationFrame) {\n win.requestAnimationFrame(callback);\n }\n else if (win.webkitRequestAnimationFrame) {\n win.webkitRequestAnimationFrame(callback);\n }\n else {\n win.setTimeout(callback, 0);\n }\n };\n AnimationFrameService.prototype.isQueueEmpty = function () {\n return !this.ticking;\n };\n // a debounce utility used for parts of the app involved with rendering.\n // the advantage over normal debounce is the client can call flushAllFrames()\n // to make sure all rendering is complete. we don't wait any milliseconds,\n // as this is intended to batch calls in one VM turn.\n AnimationFrameService.prototype.debounce = function (func) {\n var _this = this;\n var pending = false;\n return function () {\n if (!_this.isOn()) {\n _this.getFrameworkOverrides().setTimeout(func, 0);\n return;\n }\n if (pending) {\n return;\n }\n pending = true;\n _this.addDestroyTask(function () {\n pending = false;\n func();\n });\n };\n };\n __decorate([\n Autowired('ctrlsService')\n ], AnimationFrameService.prototype, \"ctrlsService\", void 0);\n __decorate([\n PostConstruct\n ], AnimationFrameService.prototype, \"init\", null);\n AnimationFrameService = __decorate([\n Bean('animationFrameService')\n ], AnimationFrameService);\n return AnimationFrameService;\n}(BeanStub));\nexport { AnimationFrameService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub\";\nimport { Autowired } from \"../../context/context\";\nimport { getAbsoluteHeight, getAbsoluteWidth, setFixedHeight, setFixedWidth } from \"../../utils/dom\";\nvar RESIZE_CONTAINER_STYLE = 'ag-resizer-wrapper';\nvar RESIZE_TEMPLATE = /* html */ \"
\\n
\\n
\\n
\\n
\\n
\\n
\\n
\\n
\\n
\";\nvar PositionableFeature = /** @class */ (function (_super) {\n __extends(PositionableFeature, _super);\n function PositionableFeature(element, config) {\n var _this = _super.call(this) || this;\n _this.element = element;\n _this.dragStartPosition = {\n x: 0,\n y: 0\n };\n _this.position = {\n x: 0,\n y: 0\n };\n _this.lastSize = {\n width: -1,\n height: -1\n };\n _this.positioned = false;\n _this.resizersAdded = false;\n _this.resizeListeners = [];\n _this.boundaryEl = null;\n _this.isResizing = false;\n _this.isMoving = false;\n _this.resizable = {};\n _this.movable = false;\n _this.currentResizer = null;\n _this.config = Object.assign({}, { popup: false }, config);\n return _this;\n }\n PositionableFeature.prototype.center = function () {\n var _a = this.offsetParent, clientHeight = _a.clientHeight, clientWidth = _a.clientWidth;\n var x = (clientWidth / 2) - (this.getWidth() / 2);\n var y = (clientHeight / 2) - (this.getHeight() / 2);\n this.offsetElement(x, y);\n };\n PositionableFeature.prototype.initialisePosition = function () {\n var _a = this.config, centered = _a.centered, forcePopupParentAsOffsetParent = _a.forcePopupParentAsOffsetParent, minWidth = _a.minWidth, width = _a.width, minHeight = _a.minHeight, height = _a.height, x = _a.x, y = _a.y;\n if (!this.offsetParent) {\n this.setOffsetParent();\n }\n var computedMinHeight = 0;\n var computedMinWidth = 0;\n // here we don't use the main offset parent but the element's offsetParent\n // in order to calculated the minWidth and minHeight correctly\n var isVisible = !!this.element.offsetParent;\n if (isVisible) {\n var boundaryEl = this.findBoundaryElement();\n var offsetParentComputedStyles = window.getComputedStyle(boundaryEl);\n if (offsetParentComputedStyles.minWidth != null) {\n var paddingWidth = boundaryEl.offsetWidth - this.element.offsetWidth;\n computedMinWidth = parseInt(offsetParentComputedStyles.minWidth, 10) - paddingWidth;\n }\n if (offsetParentComputedStyles.minHeight != null) {\n var paddingHeight = boundaryEl.offsetHeight - this.element.offsetHeight;\n computedMinHeight = parseInt(offsetParentComputedStyles.minHeight, 10) - paddingHeight;\n }\n }\n this.minHeight = minHeight || computedMinHeight;\n this.minWidth = minWidth || computedMinWidth;\n if (width) {\n this.setWidth(width);\n }\n if (height) {\n this.setHeight(height);\n }\n if (!width || !height) {\n this.refreshSize();\n }\n if (centered) {\n this.center();\n }\n else if (x || y) {\n this.offsetElement(x, y);\n }\n else if (isVisible && forcePopupParentAsOffsetParent && this.boundaryEl) {\n var top_1 = parseFloat(this.boundaryEl.style.top);\n var left = parseFloat(this.boundaryEl.style.left);\n this.offsetElement(isNaN(left) ? 0 : left, isNaN(top_1) ? 0 : top_1);\n }\n this.positioned = !!this.offsetParent;\n };\n PositionableFeature.prototype.isPositioned = function () {\n return this.positioned;\n };\n PositionableFeature.prototype.getPosition = function () {\n return this.position;\n };\n PositionableFeature.prototype.setMovable = function (movable, moveElement) {\n if (!this.config.popup || movable === this.movable) {\n return;\n }\n this.movable = movable;\n var params = this.moveElementDragListener || {\n eElement: moveElement,\n onDragStart: this.onMoveStart.bind(this),\n onDragging: this.onMove.bind(this),\n onDragStop: this.onMoveEnd.bind(this)\n };\n if (movable) {\n this.dragService.addDragSource(params);\n this.moveElementDragListener = params;\n }\n else {\n this.dragService.removeDragSource(params);\n this.moveElementDragListener = undefined;\n }\n };\n PositionableFeature.prototype.setResizable = function (resizable) {\n var _this = this;\n this.clearResizeListeners();\n if (resizable) {\n this.addResizers();\n }\n else {\n this.removeResizers();\n }\n if (typeof resizable === 'boolean') {\n if (resizable === false) {\n return;\n }\n resizable = {\n topLeft: resizable,\n top: resizable,\n topRight: resizable,\n right: resizable,\n bottomRight: resizable,\n bottom: resizable,\n bottomLeft: resizable,\n left: resizable\n };\n }\n Object.keys(resizable).forEach(function (side) {\n var resizableStructure = resizable;\n var val = !!resizableStructure[side];\n var resizerEl = _this.getResizerElement(side);\n var params = {\n dragStartPixels: 0,\n eElement: resizerEl,\n onDragStart: function (e) { return _this.onResizeStart(e, side); },\n onDragging: _this.onResize.bind(_this),\n onDragStop: function (e) { return _this.onResizeEnd(e, side); },\n };\n if (!!_this.resizable[side] !== val || (!_this.isAlive() && !val)) {\n if (val) {\n _this.dragService.addDragSource(params);\n _this.resizeListeners.push(params);\n resizerEl.style.pointerEvents = 'all';\n }\n else {\n resizerEl.style.pointerEvents = 'none';\n }\n }\n });\n };\n PositionableFeature.prototype.removeSizeFromEl = function () {\n this.element.style.removeProperty('height');\n this.element.style.removeProperty('width');\n this.element.style.removeProperty('flex');\n };\n PositionableFeature.prototype.restoreLastSize = function () {\n this.element.style.flex = '0 0 auto';\n var _a = this.lastSize, height = _a.height, width = _a.width;\n if (width !== -1) {\n this.element.style.width = width + \"px\";\n }\n if (height !== -1) {\n this.element.style.height = height + \"px\";\n }\n };\n PositionableFeature.prototype.getHeight = function () {\n return this.element.offsetHeight;\n };\n PositionableFeature.prototype.setHeight = function (height) {\n var popup = this.config.popup;\n var eGui = this.element;\n var isPercent = false;\n if (typeof height === 'string' && height.indexOf('%') !== -1) {\n setFixedHeight(eGui, height);\n height = getAbsoluteHeight(eGui);\n isPercent = true;\n }\n else if (this.positioned) {\n var elRect = this.element.getBoundingClientRect();\n var parentRect = this.offsetParent.getBoundingClientRect();\n height = Math.max(this.minHeight, height);\n var clientHeight = this.offsetParent.clientHeight;\n var yPosition = popup ? this.position.y : elRect.top;\n var parentTop = popup ? 0 : parentRect.top;\n if (clientHeight && (height + yPosition > clientHeight + parentTop)) {\n height = clientHeight - yPosition;\n }\n }\n if (this.getHeight() === height) {\n return;\n }\n if (!isPercent) {\n if (popup) {\n setFixedHeight(eGui, height);\n }\n else {\n eGui.style.height = height + \"px\";\n eGui.style.flex = '0 0 auto';\n this.lastSize.height = typeof height === 'number' ? height : parseFloat(height);\n }\n }\n else {\n eGui.style.maxHeight = 'unset';\n eGui.style.minHeight = 'unset';\n }\n };\n PositionableFeature.prototype.getWidth = function () {\n return this.element.offsetWidth;\n };\n PositionableFeature.prototype.setWidth = function (width) {\n var eGui = this.element;\n var popup = this.config.popup;\n var isPercent = false;\n if (typeof width === 'string' && width.indexOf('%') !== -1) {\n setFixedWidth(eGui, width);\n width = getAbsoluteWidth(eGui);\n isPercent = true;\n }\n else if (this.positioned) {\n width = Math.max(this.minWidth, width);\n var clientWidth = this.offsetParent.clientWidth;\n var xPosition = popup ? this.position.x : this.element.getBoundingClientRect().left;\n if (clientWidth && (width + xPosition > clientWidth)) {\n width = clientWidth - xPosition;\n }\n }\n if (this.getWidth() === width) {\n return;\n }\n if (!isPercent) {\n if (this.config.popup) {\n setFixedWidth(eGui, width);\n }\n else {\n eGui.style.width = width + \"px\";\n eGui.style.flex = ' unset';\n this.lastSize.width = typeof width === 'number' ? width : parseFloat(width);\n }\n }\n else {\n eGui.style.maxWidth = 'unset';\n eGui.style.minWidth = 'unset';\n }\n };\n PositionableFeature.prototype.offsetElement = function (x, y) {\n if (x === void 0) { x = 0; }\n if (y === void 0) { y = 0; }\n var ePopup = this.config.forcePopupParentAsOffsetParent ? this.boundaryEl : this.element;\n this.popupService.positionPopup({\n ePopup: ePopup,\n x: x,\n y: y,\n keepWithinBounds: true\n });\n this.setPosition(parseFloat(ePopup.style.left), parseFloat(ePopup.style.top));\n };\n PositionableFeature.prototype.setPosition = function (x, y) {\n this.position.x = x;\n this.position.y = y;\n };\n PositionableFeature.prototype.updateDragStartPosition = function (x, y) {\n this.dragStartPosition = { x: x, y: y };\n };\n PositionableFeature.prototype.calculateMouseMovement = function (params) {\n var e = params.e, isLeft = params.isLeft, isTop = params.isTop, anywhereWithin = params.anywhereWithin, topBuffer = params.topBuffer;\n var xDiff = e.clientX - this.dragStartPosition.x;\n var yDiff = e.clientY - this.dragStartPosition.y;\n var movementX = this.shouldSkipX(e, !!isLeft, !!anywhereWithin, xDiff) ? 0 : xDiff;\n var movementY = this.shouldSkipY(e, !!isTop, topBuffer, yDiff) ? 0 : yDiff;\n return { movementX: movementX, movementY: movementY };\n };\n PositionableFeature.prototype.shouldSkipX = function (e, isLeft, anywhereWithin, diff) {\n var elRect = this.element.getBoundingClientRect();\n var parentRect = this.offsetParent.getBoundingClientRect();\n var boundaryElRect = this.boundaryEl.getBoundingClientRect();\n var xPosition = this.config.popup ? this.position.x : elRect.left;\n // skip if cursor is outside of popupParent horizontally\n var skipX = ((xPosition <= 0 && parentRect.left >= e.clientX) ||\n (parentRect.right <= e.clientX && parentRect.right <= boundaryElRect.right));\n if (skipX) {\n return true;\n }\n if (isLeft) {\n skipX = (\n // skip if we are moving to the left and the cursor\n // is positioned to the right of the left side anchor\n (diff < 0 && e.clientX > xPosition + parentRect.left) ||\n // skip if we are moving to the right and the cursor\n // is positioned to the left of the dialog\n (diff > 0 && e.clientX < xPosition + parentRect.left));\n }\n else {\n if (anywhereWithin) {\n // if anywhereWithin is true, we allow to move\n // as long as the cursor is within the dialog\n skipX = ((diff < 0 && e.clientX > boundaryElRect.right) ||\n (diff > 0 && e.clientX < xPosition + parentRect.left));\n }\n else {\n skipX = (\n // if the movement is bound to the right side of the dialog\n // we skip if we are moving to the left and the cursor\n // is to the right of the dialog\n (diff < 0 && e.clientX > boundaryElRect.right) ||\n // or skip if we are moving to the right and the cursor\n // is to the left of the right side anchor\n (diff > 0 && e.clientX < boundaryElRect.right));\n }\n }\n return skipX;\n };\n PositionableFeature.prototype.shouldSkipY = function (e, isTop, topBuffer, diff) {\n if (topBuffer === void 0) { topBuffer = 0; }\n var elRect = this.element.getBoundingClientRect();\n var parentRect = this.offsetParent.getBoundingClientRect();\n var boundaryElRect = this.boundaryEl.getBoundingClientRect();\n var yPosition = this.config.popup ? this.position.y : elRect.top;\n // skip if cursor is outside of popupParent vertically\n var skipY = ((yPosition <= 0 && parentRect.top >= e.clientY) ||\n (parentRect.bottom <= e.clientY && parentRect.bottom <= boundaryElRect.bottom));\n if (skipY) {\n return true;\n }\n if (isTop) {\n skipY = (\n // skip if we are moving to towards top and the cursor is\n // below the top anchor + topBuffer\n // note: topBuffer is used when moving the dialog using the title bar\n (diff < 0 && e.clientY > yPosition + parentRect.top + topBuffer) ||\n // skip if we are moving to the bottom and the cursor is\n // above the top anchor\n (diff > 0 && e.clientY < yPosition + parentRect.top));\n }\n else {\n skipY = (\n // skip if we are moving towards the top and the cursor\n // is below the bottom anchor\n (diff < 0 && e.clientY > boundaryElRect.bottom) ||\n // skip if we are moving towards the bottom and the cursor\n // is above the bottom anchor\n (diff > 0 && e.clientY < boundaryElRect.bottom));\n }\n return skipY;\n };\n PositionableFeature.prototype.createResizeMap = function () {\n var eGui = this.element;\n this.resizerMap = {\n topLeft: { element: eGui.querySelector('[ref=eTopLeftResizer]') },\n top: { element: eGui.querySelector('[ref=eTopResizer]') },\n topRight: { element: eGui.querySelector('[ref=eTopRightResizer]') },\n right: { element: eGui.querySelector('[ref=eRightResizer]') },\n bottomRight: { element: eGui.querySelector('[ref=eBottomRightResizer]') },\n bottom: { element: eGui.querySelector('[ref=eBottomResizer]') },\n bottomLeft: { element: eGui.querySelector('[ref=eBottomLeftResizer]') },\n left: { element: eGui.querySelector('[ref=eLeftResizer]') }\n };\n };\n PositionableFeature.prototype.addResizers = function () {\n if (this.resizersAdded) {\n return;\n }\n var eGui = this.element;\n if (!eGui) {\n return;\n }\n var parser = new DOMParser();\n var resizers = parser.parseFromString(RESIZE_TEMPLATE, 'text/html').body;\n eGui.appendChild(resizers.firstChild);\n this.createResizeMap();\n this.resizersAdded = true;\n };\n PositionableFeature.prototype.removeResizers = function () {\n this.resizerMap = undefined;\n var resizerEl = this.element.querySelector(\".\" + RESIZE_CONTAINER_STYLE);\n if (resizerEl) {\n this.element.removeChild(resizerEl);\n }\n this.resizersAdded = false;\n };\n PositionableFeature.prototype.getResizerElement = function (side) {\n return this.resizerMap[side].element;\n };\n PositionableFeature.prototype.onResizeStart = function (e, side) {\n this.boundaryEl = this.findBoundaryElement();\n if (!this.positioned) {\n this.initialisePosition();\n }\n this.currentResizer = {\n isTop: !!side.match(/top/i),\n isRight: !!side.match(/right/i),\n isBottom: !!side.match(/bottom/i),\n isLeft: !!side.match(/left/i),\n };\n this.element.classList.add('ag-resizing');\n this.resizerMap[side].element.classList.add('ag-active');\n var _a = this.config, popup = _a.popup, forcePopupParentAsOffsetParent = _a.forcePopupParentAsOffsetParent;\n if (!popup && !forcePopupParentAsOffsetParent) {\n this.applySizeToSiblings(this.currentResizer.isBottom || this.currentResizer.isTop);\n }\n this.isResizing = true;\n this.updateDragStartPosition(e.clientX, e.clientY);\n };\n PositionableFeature.prototype.getSiblings = function () {\n var element = this.element;\n var parent = element.parentElement;\n if (!parent) {\n return null;\n }\n return Array.prototype.slice.call(parent.children).filter(function (el) { return !el.classList.contains('ag-hidden'); });\n };\n PositionableFeature.prototype.getMinSizeOfSiblings = function () {\n var siblings = this.getSiblings() || [];\n var height = 0;\n var width = 0;\n for (var i = 0; i < siblings.length; i++) {\n var currentEl = siblings[i];\n var isFlex = !!currentEl.style.flex && currentEl.style.flex !== '0 0 auto';\n if (currentEl === this.element) {\n continue;\n }\n var nextHeight = this.minHeight || 0;\n var nextWidth = this.minWidth || 0;\n if (isFlex) {\n var computedStyle = window.getComputedStyle(currentEl);\n if (computedStyle.minHeight) {\n nextHeight = parseInt(computedStyle.minHeight, 10);\n }\n if (computedStyle.minWidth) {\n nextWidth = parseInt(computedStyle.minWidth, 10);\n }\n }\n else {\n nextHeight = currentEl.offsetHeight;\n nextWidth = currentEl.offsetWidth;\n }\n height += nextHeight;\n width += nextWidth;\n }\n return { height: height, width: width };\n };\n PositionableFeature.prototype.applySizeToSiblings = function (vertical) {\n var containerToFlex = null;\n var siblings = this.getSiblings();\n if (!siblings) {\n return;\n }\n for (var i = 0; i < siblings.length; i++) {\n var el = siblings[i];\n if (el === containerToFlex) {\n continue;\n }\n if (vertical) {\n el.style.height = el.offsetHeight + \"px\";\n }\n else {\n el.style.width = el.offsetWidth + \"px\";\n }\n el.style.flex = '0 0 auto';\n if (el === this.element) {\n containerToFlex = siblings[i + 1];\n }\n }\n if (containerToFlex) {\n containerToFlex.style.removeProperty('height');\n containerToFlex.style.removeProperty('min-height');\n containerToFlex.style.removeProperty('max-height');\n containerToFlex.style.flex = '1 1 auto';\n }\n };\n PositionableFeature.prototype.onResize = function (e) {\n if (!this.isResizing || !this.currentResizer) {\n return;\n }\n var _a = this.config, popup = _a.popup, forcePopupParentAsOffsetParent = _a.forcePopupParentAsOffsetParent;\n var _b = this.currentResizer, isTop = _b.isTop, isRight = _b.isRight, isBottom = _b.isBottom, isLeft = _b.isLeft;\n var isHorizontal = isRight || isLeft;\n var isVertical = isBottom || isTop;\n var _c = this.calculateMouseMovement({ e: e, isLeft: isLeft, isTop: isTop }), movementX = _c.movementX, movementY = _c.movementY;\n var xPosition = this.position.x;\n var yPosition = this.position.y;\n var offsetLeft = 0;\n var offsetTop = 0;\n if (isHorizontal && movementX) {\n var direction = isLeft ? -1 : 1;\n var oldWidth = this.getWidth();\n var newWidth = oldWidth + (movementX * direction);\n var skipWidth = false;\n if (isLeft) {\n offsetLeft = oldWidth - newWidth;\n if (xPosition + offsetLeft <= 0 || newWidth <= this.minWidth) {\n skipWidth = true;\n offsetLeft = 0;\n }\n }\n if (!skipWidth) {\n this.setWidth(newWidth);\n }\n }\n if (isVertical && movementY) {\n var direction = isTop ? -1 : 1;\n var oldHeight = this.getHeight();\n var newHeight = oldHeight + (movementY * direction);\n var skipHeight = false;\n if (isTop) {\n offsetTop = oldHeight - newHeight;\n if (yPosition + offsetTop <= 0 || newHeight <= this.minHeight) {\n skipHeight = true;\n offsetTop = 0;\n }\n }\n else {\n // do not let the size of all siblings be higher than the parent container\n if (!this.config.popup &&\n !this.config.forcePopupParentAsOffsetParent &&\n oldHeight < newHeight &&\n (this.getMinSizeOfSiblings().height + newHeight) > this.element.parentElement.offsetHeight) {\n skipHeight = true;\n }\n }\n if (!skipHeight) {\n this.setHeight(newHeight);\n }\n }\n this.updateDragStartPosition(e.clientX, e.clientY);\n if ((popup || forcePopupParentAsOffsetParent) && offsetLeft || offsetTop) {\n this.offsetElement(xPosition + offsetLeft, yPosition + offsetTop);\n }\n };\n PositionableFeature.prototype.onResizeEnd = function (e, side) {\n this.isResizing = false;\n this.currentResizer = null;\n this.boundaryEl = null;\n var params = {\n type: 'resize',\n api: this.gridOptionsWrapper.getApi(),\n columnApi: this.gridOptionsWrapper.getColumnApi()\n };\n this.element.classList.remove('ag-resizing');\n this.resizerMap[side].element.classList.remove('ag-active');\n this.dispatchEvent(params);\n };\n PositionableFeature.prototype.refreshSize = function () {\n var eGui = this.element;\n if (this.config.popup) {\n if (!this.config.width) {\n this.setWidth(eGui.offsetWidth);\n }\n if (!this.config.height) {\n this.setHeight(eGui.offsetHeight);\n }\n }\n };\n PositionableFeature.prototype.onMoveStart = function (e) {\n this.boundaryEl = this.findBoundaryElement();\n if (!this.positioned) {\n this.initialisePosition();\n }\n this.isMoving = true;\n this.element.classList.add('ag-moving');\n this.updateDragStartPosition(e.clientX, e.clientY);\n };\n PositionableFeature.prototype.onMove = function (e) {\n if (!this.isMoving) {\n return;\n }\n var _a = this.position, x = _a.x, y = _a.y;\n var topBuffer;\n if (this.config.calculateTopBuffer) {\n topBuffer = this.config.calculateTopBuffer();\n }\n var _b = this.calculateMouseMovement({\n e: e,\n isTop: true,\n anywhereWithin: true,\n topBuffer: topBuffer\n }), movementX = _b.movementX, movementY = _b.movementY;\n this.offsetElement(x + movementX, y + movementY);\n this.updateDragStartPosition(e.clientX, e.clientY);\n };\n PositionableFeature.prototype.onMoveEnd = function () {\n this.isMoving = false;\n this.boundaryEl = null;\n this.element.classList.remove('ag-moving');\n };\n PositionableFeature.prototype.setOffsetParent = function () {\n if (this.config.forcePopupParentAsOffsetParent) {\n this.offsetParent = this.popupService.getPopupParent();\n }\n else {\n this.offsetParent = this.element.offsetParent;\n }\n };\n PositionableFeature.prototype.findBoundaryElement = function () {\n var el = this.element;\n while (el) {\n if (window.getComputedStyle(el).position !== 'static') {\n return el;\n }\n el = el.parentElement;\n }\n return this.element;\n };\n PositionableFeature.prototype.clearResizeListeners = function () {\n while (this.resizeListeners.length) {\n var params = this.resizeListeners.pop();\n this.dragService.removeDragSource(params);\n }\n };\n PositionableFeature.prototype.destroy = function () {\n _super.prototype.destroy.call(this);\n if (this.moveElementDragListener) {\n this.dragService.removeDragSource(this.moveElementDragListener);\n }\n this.clearResizeListeners();\n this.removeResizers();\n };\n __decorate([\n Autowired('popupService')\n ], PositionableFeature.prototype, \"popupService\", void 0);\n __decorate([\n Autowired('dragService')\n ], PositionableFeature.prototype, \"dragService\", void 0);\n return PositionableFeature;\n}(BeanStub));\nexport { PositionableFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, PostConstruct } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nvar AutoWidthCalculator = /** @class */ (function (_super) {\n __extends(AutoWidthCalculator, _super);\n function AutoWidthCalculator() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n AutoWidthCalculator.prototype.postConstruct = function () {\n var _this = this;\n this.ctrlsService.whenReady(function (p) {\n _this.centerRowContainerCtrl = p.centerRowContainerCtrl;\n });\n };\n // this is the trick: we create a dummy container and clone all the cells\n // into the dummy, then check the dummy's width. then destroy the dummy\n // as we don't need it any more.\n // drawback: only the cells visible on the screen are considered\n AutoWidthCalculator.prototype.getPreferredWidthForColumn = function (column, skipHeader) {\n var eHeaderCell = this.getHeaderCellForColumn(column);\n // cell isn't visible\n if (!eHeaderCell) {\n return -1;\n }\n var elements = this.rowRenderer.getAllCellsForColumn(column);\n if (!skipHeader) {\n // we only consider the lowest level cell, not the group cell. in 99% of the time, this\n // will be enough. if we consider groups, then it gets too complicated for what it's worth,\n // as the groups can span columns and this class only considers one column at a time.\n elements.push(eHeaderCell);\n }\n return this.addElementsToContainerAndGetWidth(elements);\n };\n AutoWidthCalculator.prototype.getPreferredWidthForColumnGroup = function (columnGroup) {\n var eHeaderCell = this.getHeaderCellForColumn(columnGroup);\n if (!eHeaderCell) {\n return -1;\n }\n return this.addElementsToContainerAndGetWidth([eHeaderCell]);\n };\n AutoWidthCalculator.prototype.addElementsToContainerAndGetWidth = function (elements) {\n var _this = this;\n var eDummyContainer = document.createElement('span');\n // position fixed, so it isn't restricted to the boundaries of the parent\n eDummyContainer.style.position = 'fixed';\n // we put the dummy into the body container, so it will inherit all the\n // css styles that the real cells are inheriting\n var eBodyContainer = this.centerRowContainerCtrl.getContainerElement();\n eBodyContainer.appendChild(eDummyContainer);\n elements.forEach(function (el) { return _this.cloneItemIntoDummy(el, eDummyContainer); });\n // at this point, all the clones are lined up vertically with natural widths. the dummy\n // container will have a width wide enough just to fit the largest.\n var dummyContainerWidth = eDummyContainer.offsetWidth;\n // we are finished with the dummy container, so get rid of it\n eBodyContainer.removeChild(eDummyContainer);\n // we add padding as I found sometimes the gui still put '...' after some of the texts. so the\n // user can configure the grid to add a few more pixels after the calculated width\n var autoSizePadding = this.gridOptionsWrapper.getAutoSizePadding();\n return dummyContainerWidth + autoSizePadding;\n };\n AutoWidthCalculator.prototype.getHeaderCellForColumn = function (column) {\n /* tslint:enable */\n var element = null;\n this.ctrlsService.getHeaderRowContainerCtrls().forEach(function (container) {\n var res = container.getHtmlElementForColumnHeader(column);\n if (res != null) {\n element = res;\n }\n });\n return element;\n };\n AutoWidthCalculator.prototype.cloneItemIntoDummy = function (eCell, eDummyContainer) {\n // make a deep clone of the cell\n var eCellClone = eCell.cloneNode(true);\n // the original has a fixed width, we remove this to allow the natural width based on content\n eCellClone.style.width = '';\n // the original has position = absolute, we need to remove this so it's positioned normally\n eCellClone.style.position = 'static';\n eCellClone.style.left = '';\n // we put the cell into a containing div, as otherwise the cells would just line up\n // on the same line, standard flow layout, by putting them into divs, they are laid\n // out one per line\n var eCloneParent = document.createElement('div');\n var eCloneParentClassList = eCloneParent.classList;\n var isHeader = ['ag-header-cell', 'ag-header-group-cell'].some(function (cls) { return eCellClone.classList.contains(cls); });\n if (isHeader) {\n eCloneParentClassList.add('ag-header', 'ag-header-row');\n eCloneParent.style.position = 'static';\n }\n else {\n eCloneParentClassList.add('ag-row');\n }\n // find parent using classes (headers have ag-header-cell, rows have ag-row), and copy classes from it.\n // if we didn't do this, things like ag-row-level-2 would be missing if present, which sets indents\n // onto group items.\n var pointer = eCell.parentElement;\n while (pointer) {\n var isRow = ['ag-header-row', 'ag-row'].some(function (cls) { return pointer.classList.contains(cls); });\n if (isRow) {\n for (var i = 0; i < pointer.classList.length; i++) {\n var item = pointer.classList[i];\n // we skip ag-row-position-absolute, as this has structural CSS applied that stops the\n // element from fitting into it's parent, and we need the element to stretch the parent\n // as we are measuring the parents width\n if (item != 'ag-row-position-absolute') {\n eCloneParentClassList.add(item);\n }\n }\n break;\n }\n pointer = pointer.parentElement;\n }\n // the twig on the branch, the branch on the tree, the tree in the hole,\n // the hole in the bog, the bog in the clone, the clone in the parent,\n // the parent in the dummy, and the dummy down in the vall-e-ooo, OOOOOOOOO! Oh row the rattling bog....\n eCloneParent.appendChild(eCellClone);\n eDummyContainer.appendChild(eCloneParent);\n };\n __decorate([\n Autowired('rowRenderer')\n ], AutoWidthCalculator.prototype, \"rowRenderer\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], AutoWidthCalculator.prototype, \"ctrlsService\", void 0);\n __decorate([\n Autowired('rowCssClassCalculator')\n ], AutoWidthCalculator.prototype, \"rowCssClassCalculator\", void 0);\n __decorate([\n PostConstruct\n ], AutoWidthCalculator.prototype, \"postConstruct\", null);\n AutoWidthCalculator = __decorate([\n Bean('autoWidthCalculator')\n ], AutoWidthCalculator);\n return AutoWidthCalculator;\n}(BeanStub));\nexport { AutoWidthCalculator };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __values = (this && this.__values) || function(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nimport { BeanStub } from \"../../context/beanStub\";\nimport { Autowired, PostConstruct } from \"../../context/context\";\nimport { last } from \"../../utils/array\";\nvar StickyRowFeature = /** @class */ (function (_super) {\n __extends(StickyRowFeature, _super);\n function StickyRowFeature(createRowCon, destroyRowCtrls) {\n var _this = _super.call(this) || this;\n _this.createRowCon = createRowCon;\n _this.destroyRowCtrls = destroyRowCtrls;\n _this.stickyRowCtrls = [];\n _this.containerHeight = 0;\n return _this;\n }\n StickyRowFeature.prototype.postConstruct = function () {\n var _this = this;\n this.ctrlsService.whenReady(function (params) {\n _this.gridBodyCtrl = params.gridBodyCtrl;\n });\n };\n StickyRowFeature.prototype.getStickyRowCtrls = function () {\n return this.stickyRowCtrls;\n };\n StickyRowFeature.prototype.checkStickyRows = function () {\n var height = 0;\n if (!this.gridOptionsWrapper.isGroupRowsSticky()) {\n this.refreshNodesAndContainerHeight([], height);\n return;\n }\n var stickyRows = [];\n var firstPixel = this.rowRenderer.getFirstVisibleVerticalPixel();\n var addStickyRow = function (stickyRow) {\n stickyRows.push(stickyRow);\n var lastAncester = stickyRow;\n while (lastAncester.expanded) {\n lastAncester = last(lastAncester.childrenAfterSort);\n }\n var lastChildBottom = lastAncester.rowTop + lastAncester.rowHeight;\n var stickRowBottom = firstPixel + height + stickyRow.rowHeight;\n if (lastChildBottom < stickRowBottom) {\n stickyRow.stickyRowTop = height + (lastChildBottom - stickRowBottom);\n }\n else {\n stickyRow.stickyRowTop = height;\n }\n height = 0;\n stickyRows.forEach(function (rowNode) {\n var thisRowLastPx = rowNode.stickyRowTop + rowNode.rowHeight;\n if (height < thisRowLastPx) {\n height = thisRowLastPx;\n }\n });\n };\n while (true) {\n var firstPixelAfterStickyRows = firstPixel + height;\n var firstIndex = this.rowModel.getRowIndexAtPixel(firstPixelAfterStickyRows);\n var firstRow = this.rowModel.getRow(firstIndex);\n if (firstRow == null) {\n break;\n }\n // only happens when pivoting, and we are showing root node\n if (firstRow.level < 0) {\n break;\n }\n var parents = [];\n var p = firstRow.parent;\n while (p.level >= 0) {\n parents.push(p);\n p = p.parent;\n }\n var firstMissingParent = parents.reverse().find(function (parent) { return stickyRows.indexOf(parent) < 0 && parent.displayed; });\n if (firstMissingParent) {\n addStickyRow(firstMissingParent);\n continue;\n }\n // if first row is an open group, and practically shown, it needs\n // to be stuck\n if (firstRow.group && firstRow.expanded && !firstRow.footer && firstRow.rowTop < firstPixelAfterStickyRows) {\n addStickyRow(firstRow);\n continue;\n }\n break;\n }\n this.refreshNodesAndContainerHeight(stickyRows, height);\n };\n StickyRowFeature.prototype.refreshNodesAndContainerHeight = function (allStickyNodes, height) {\n var e_1, _a, _b;\n var _this = this;\n var removedCtrls = this.stickyRowCtrls.filter(function (ctrl) { return allStickyNodes.indexOf(ctrl.getRowNode()) === -1; });\n var addedNodes = allStickyNodes.filter(function (rowNode) { return _this.stickyRowCtrls.findIndex(function (ctrl) { return ctrl.getRowNode() === rowNode; }) === -1; });\n var ctrlsToDestroy = {};\n removedCtrls.forEach(function (removedCtrl) {\n ctrlsToDestroy[removedCtrl.getRowNode().id] = removedCtrl;\n _this.stickyRowCtrls = _this.stickyRowCtrls.filter(function (ctrl) { return ctrl !== removedCtrl; });\n });\n try {\n for (var _c = __values(Object.values(ctrlsToDestroy)), _d = _c.next(); !_d.done; _d = _c.next()) {\n var ctrl = _d.value;\n ctrl.getRowNode().sticky = false;\n }\n }\n catch (e_1_1) { e_1 = { error: e_1_1 }; }\n finally {\n try {\n if (_d && !_d.done && (_a = _c.return)) _a.call(_c);\n }\n finally { if (e_1) throw e_1.error; }\n }\n this.destroyRowCtrls(ctrlsToDestroy, false);\n var newCtrls = addedNodes.map(function (rowNode) {\n rowNode.sticky = true;\n return _this.createRowCon(rowNode, false, false);\n });\n (_b = this.stickyRowCtrls).push.apply(_b, __spread(newCtrls));\n this.stickyRowCtrls.forEach(function (ctrl) { return ctrl.setRowTop(ctrl.getRowNode().stickyRowTop); });\n this.stickyRowCtrls.sort(function (a, b) { return b.getRowNode().rowIndex - a.getRowNode().rowIndex; });\n if (this.containerHeight !== height) {\n this.containerHeight = height;\n this.gridBodyCtrl.setStickyTopHeight(height);\n }\n };\n __decorate([\n Autowired(\"rowModel\")\n ], StickyRowFeature.prototype, \"rowModel\", void 0);\n __decorate([\n Autowired(\"rowRenderer\")\n ], StickyRowFeature.prototype, \"rowRenderer\", void 0);\n __decorate([\n Autowired(\"ctrlsService\")\n ], StickyRowFeature.prototype, \"ctrlsService\", void 0);\n __decorate([\n PostConstruct\n ], StickyRowFeature.prototype, \"postConstruct\", null);\n return StickyRowFeature;\n}(BeanStub));\nexport { StickyRowFeature };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nimport { GridOptionsWrapper } from \"../gridOptionsWrapper\";\nimport { RowCtrl } from \"./row/rowCtrl\";\nimport { Column } from \"../entities/column\";\nimport { Events } from \"../events\";\nimport { Constants } from \"../constants/constants\";\nimport { Autowired, Bean, PostConstruct } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { exists, missing } from \"../utils/generic\";\nimport { getAllValuesInObject, iterateObject } from \"../utils/object\";\nimport { createArrayOfNumbers } from \"../utils/number\";\nimport { doOnce, executeInAWhile } from \"../utils/function\";\nimport { CellCtrl } from \"./cell/cellCtrl\";\nimport { removeFromArray } from \"../utils/array\";\nimport { StickyRowFeature } from \"./features/stickyRowFeature\";\nimport { browserSupportsPreventScroll } from \"../utils/browser\";\nvar RowRenderer = /** @class */ (function (_super) {\n __extends(RowRenderer, _super);\n function RowRenderer() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.destroyFuncsForColumnListeners = [];\n // map of row ids to row objects. keeps track of which elements\n // are rendered for which rows in the dom.\n _this.rowCtrlsByRowIndex = {};\n _this.zombieRowCtrls = {};\n _this.allRowCtrls = [];\n _this.topRowCtrls = [];\n _this.bottomRowCtrls = [];\n // we only allow one refresh at a time, otherwise the internal memory structure here\n // will get messed up. this can happen if the user has a cellRenderer, and inside the\n // renderer they call an API method that results in another pass of the refresh,\n // then it will be trying to draw rows in the middle of a refresh.\n _this.refreshInProgress = false;\n _this.dataFirstRenderedFired = false;\n return _this;\n }\n RowRenderer.prototype.postConstruct = function () {\n var _this = this;\n this.ctrlsService.whenReady(function () {\n _this.gridBodyCtrl = _this.ctrlsService.getGridBodyCtrl();\n _this.initialise();\n });\n };\n RowRenderer.prototype.initialise = function () {\n this.addManagedListener(this.eventService, Events.EVENT_PAGINATION_CHANGED, this.onPageLoaded.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_PINNED_ROW_DATA_CHANGED, this.onPinnedRowDataChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_BODY_SCROLL, this.redrawAfterScroll.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_BODY_HEIGHT_CHANGED, this.redrawAfterScroll.bind(this));\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_DOM_LAYOUT, this.onDomLayoutChanged.bind(this));\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_ROW_CLASS, this.redrawRows.bind(this));\n if (this.gridOptionsWrapper.isGroupRowsSticky()) {\n if (this.rowModel.getType() != Constants.ROW_MODEL_TYPE_CLIENT_SIDE) {\n doOnce(function () { return console.warn('AG Grid: The feature Sticky Row Groups only works with the Client Side Row Model'); }, 'rowRenderer.stickyWorksWithCsrmOnly');\n }\n else if (this.gridOptionsWrapper.isTreeData()) {\n doOnce(function () { return console.warn('AG Grid: The feature Sticky Row Groups does not work with Tree Data.'); }, 'rowRenderer.stickyDoesNotWorkWithTreeData');\n }\n else {\n this.stickyRowFeature = this.createManagedBean(new StickyRowFeature(this.createRowCon.bind(this), this.destroyRowCtrls.bind(this)));\n }\n }\n this.registerCellEventListeners();\n this.initialiseCache();\n this.printLayout = this.gridOptionsWrapper.getDomLayout() === Constants.DOM_LAYOUT_PRINT;\n this.embedFullWidthRows = this.printLayout || this.gridOptionsWrapper.isEmbedFullWidthRows();\n this.redrawAfterModelUpdate();\n };\n RowRenderer.prototype.initialiseCache = function () {\n if (this.gridOptionsWrapper.isKeepDetailRows()) {\n var countProp = this.gridOptionsWrapper.getKeepDetailRowsCount();\n var count = countProp != null ? countProp : 3;\n this.cachedRowCtrls = new RowCtrlCache(count);\n }\n };\n RowRenderer.prototype.getRowCtrls = function () {\n return this.allRowCtrls;\n };\n RowRenderer.prototype.getStickyTopRowCtrls = function () {\n if (!this.stickyRowFeature) {\n return [];\n }\n return this.stickyRowFeature.getStickyRowCtrls();\n };\n RowRenderer.prototype.updateAllRowCtrls = function () {\n var liveList = getAllValuesInObject(this.rowCtrlsByRowIndex);\n if (this.gridOptionsWrapper.isEnsureDomOrder()) {\n liveList.sort(function (a, b) { return a.getRowNode().rowIndex - b.getRowNode.rowIndex; });\n }\n var zombieList = getAllValuesInObject(this.zombieRowCtrls);\n var cachedList = this.cachedRowCtrls ? this.cachedRowCtrls.getEntries() : [];\n this.allRowCtrls = __spread(liveList, zombieList, cachedList);\n };\n // in a clean design, each cell would register for each of these events. however when scrolling, all the cells\n // registering and de-registering for events is a performance bottleneck. so we register here once and inform\n // all active cells.\n RowRenderer.prototype.registerCellEventListeners = function () {\n var _this = this;\n this.addManagedListener(this.eventService, Events.EVENT_CELL_FOCUSED, function (event) {\n _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.onCellFocused(event); });\n _this.getFullWidthRowCtrls().forEach(function (rowCtrl) {\n rowCtrl.onFullWidthRowFocused(event);\n });\n });\n this.addManagedListener(this.eventService, Events.EVENT_FLASH_CELLS, function (event) {\n _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.onFlashCells(event); });\n });\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_HOVER_CHANGED, function () {\n _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.onColumnHover(); });\n });\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, function () {\n _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.onDisplayedColumnsChanged(); });\n });\n // only for printLayout - because we are rendering all the cells in the same row, regardless of pinned state,\n // then changing the width of the containers will impact left position. eg the center cols all have their\n // left position adjusted by the width of the left pinned column, so if the pinned left column width changes,\n // all the center cols need to be shifted to accommodate this. when in normal layout, the pinned cols are\n // in different containers so doesn't impact.\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, function () {\n if (_this.printLayout) {\n _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.onLeftChanged(); });\n }\n });\n var rangeSelectionEnabled = this.gridOptionsWrapper.isEnableRangeSelection();\n if (rangeSelectionEnabled) {\n this.addManagedListener(this.eventService, Events.EVENT_RANGE_SELECTION_CHANGED, function () {\n _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.onRangeSelectionChanged(); });\n });\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_MOVED, function () {\n _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.updateRangeBordersIfRangeCount(); });\n });\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PINNED, function () {\n _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.updateRangeBordersIfRangeCount(); });\n });\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_VISIBLE, function () {\n _this.getAllCellCtrls().forEach(function (cellCtrl) { return cellCtrl.updateRangeBordersIfRangeCount(); });\n });\n }\n // add listeners to the grid columns\n this.refreshListenersToColumnsForCellComps();\n // if the grid columns change, then refresh the listeners again\n this.addManagedListener(this.eventService, Events.EVENT_GRID_COLUMNS_CHANGED, this.refreshListenersToColumnsForCellComps.bind(this));\n this.addDestroyFunc(this.removeGridColumnListeners.bind(this));\n };\n // executes all functions in destroyFuncsForColumnListeners and then clears the list\n RowRenderer.prototype.removeGridColumnListeners = function () {\n this.destroyFuncsForColumnListeners.forEach(function (func) { return func(); });\n this.destroyFuncsForColumnListeners.length = 0;\n };\n // this function adds listeners onto all the grid columns, which are the column that we could have cellComps for.\n // when the grid columns change, we add listeners again. in an ideal design, each CellComp would just register to\n // the column it belongs to on creation, however this was a bottleneck with the number of cells, so do it here\n // once instead.\n RowRenderer.prototype.refreshListenersToColumnsForCellComps = function () {\n var _this = this;\n this.removeGridColumnListeners();\n var cols = this.columnModel.getAllGridColumns();\n if (!cols) {\n return;\n }\n cols.forEach(function (col) {\n var forEachCellWithThisCol = function (callback) {\n _this.getAllCellCtrls().forEach(function (cellCtrl) {\n if (cellCtrl.getColumn() === col) {\n callback(cellCtrl);\n }\n });\n };\n var leftChangedListener = function () {\n forEachCellWithThisCol(function (cellCtrl) { return cellCtrl.onLeftChanged(); });\n };\n var widthChangedListener = function () {\n forEachCellWithThisCol(function (cellCtrl) { return cellCtrl.onWidthChanged(); });\n };\n var firstRightPinnedChangedListener = function () {\n forEachCellWithThisCol(function (cellCtrl) { return cellCtrl.onFirstRightPinnedChanged(); });\n };\n var lastLeftPinnedChangedListener = function () {\n forEachCellWithThisCol(function (cellCtrl) { return cellCtrl.onLastLeftPinnedChanged(); });\n };\n var colDefChangedListener = function () {\n forEachCellWithThisCol(function (cellCtrl) { return cellCtrl.onColDefChanged(); });\n };\n col.addEventListener(Column.EVENT_LEFT_CHANGED, leftChangedListener);\n col.addEventListener(Column.EVENT_WIDTH_CHANGED, widthChangedListener);\n col.addEventListener(Column.EVENT_FIRST_RIGHT_PINNED_CHANGED, firstRightPinnedChangedListener);\n col.addEventListener(Column.EVENT_LAST_LEFT_PINNED_CHANGED, lastLeftPinnedChangedListener);\n col.addEventListener(Column.EVENT_COL_DEF_CHANGED, colDefChangedListener);\n _this.destroyFuncsForColumnListeners.push(function () {\n col.removeEventListener(Column.EVENT_LEFT_CHANGED, leftChangedListener);\n col.removeEventListener(Column.EVENT_WIDTH_CHANGED, widthChangedListener);\n col.removeEventListener(Column.EVENT_FIRST_RIGHT_PINNED_CHANGED, firstRightPinnedChangedListener);\n col.removeEventListener(Column.EVENT_LAST_LEFT_PINNED_CHANGED, lastLeftPinnedChangedListener);\n col.removeEventListener(Column.EVENT_COL_DEF_CHANGED, colDefChangedListener);\n });\n });\n };\n RowRenderer.prototype.onDomLayoutChanged = function () {\n var printLayout = this.gridOptionsWrapper.getDomLayout() === Constants.DOM_LAYOUT_PRINT;\n var embedFullWidthRows = printLayout || this.gridOptionsWrapper.isEmbedFullWidthRows();\n // if moving towards or away from print layout, means we need to destroy all rows, as rows are not laid\n // out using absolute positioning when doing print layout\n var destroyRows = embedFullWidthRows !== this.embedFullWidthRows || this.printLayout !== printLayout;\n this.printLayout = printLayout;\n this.embedFullWidthRows = embedFullWidthRows;\n if (destroyRows) {\n this.redrawAfterModelUpdate();\n }\n };\n // for row models that have datasources, when we update the datasource, we need to force the rowRenderer\n // to redraw all rows. otherwise the old rows from the old datasource will stay displayed.\n RowRenderer.prototype.datasourceChanged = function () {\n this.firstRenderedRow = 0;\n this.lastRenderedRow = -1;\n var rowIndexesToRemove = Object.keys(this.rowCtrlsByRowIndex);\n this.removeRowCtrls(rowIndexesToRemove);\n };\n RowRenderer.prototype.onPageLoaded = function (event) {\n var params = {\n recycleRows: event.keepRenderedRows,\n animate: event.animate,\n newData: event.newData,\n newPage: event.newPage,\n // because this is a model updated event (not pinned rows), we\n // can skip updating the pinned rows. this is needed so that if user\n // is doing transaction updates, the pinned rows are not getting constantly\n // trashed - or editing cells in pinned rows are not refreshed and put into read mode\n onlyBody: true\n };\n this.redrawAfterModelUpdate(params);\n };\n RowRenderer.prototype.getAllCellsForColumn = function (column) {\n var res = [];\n this.getAllRowCtrls().forEach(function (rowCtrl) {\n var eCell = rowCtrl.getCellElement(column);\n if (eCell) {\n res.push(eCell);\n }\n });\n return res;\n };\n RowRenderer.prototype.refreshFloatingRowComps = function () {\n this.refreshFloatingRows(this.topRowCtrls, this.pinnedRowModel.getPinnedTopRowData());\n this.refreshFloatingRows(this.bottomRowCtrls, this.pinnedRowModel.getPinnedBottomRowData());\n };\n RowRenderer.prototype.getTopRowCtrls = function () {\n return this.topRowCtrls;\n };\n RowRenderer.prototype.getBottomRowCtrls = function () {\n return this.bottomRowCtrls;\n };\n RowRenderer.prototype.refreshFloatingRows = function (rowComps, rowNodes) {\n var _this = this;\n rowComps.forEach(function (row) {\n row.destroyFirstPass();\n row.destroySecondPass();\n });\n rowComps.length = 0;\n if (!rowNodes) {\n return;\n }\n rowNodes.forEach(function (rowNode) {\n var rowCtrl = new RowCtrl(rowNode, _this.beans, false, false, _this.printLayout);\n rowComps.push(rowCtrl);\n });\n };\n RowRenderer.prototype.onPinnedRowDataChanged = function () {\n // recycling rows in order to ensure cell editing is not cancelled\n var params = {\n recycleRows: true\n };\n this.redrawAfterModelUpdate(params);\n };\n // if the row nodes are not rendered, no index is returned\n RowRenderer.prototype.getRenderedIndexesForRowNodes = function (rowNodes) {\n var result = [];\n if (missing(rowNodes)) {\n return result;\n }\n iterateObject(this.rowCtrlsByRowIndex, function (index, renderedRow) {\n var rowNode = renderedRow.getRowNode();\n if (rowNodes.indexOf(rowNode) >= 0) {\n result.push(index);\n }\n });\n return result;\n };\n RowRenderer.prototype.redrawRows = function (rowNodes) {\n // if no row nodes provided, then refresh everything\n var partialRefresh = rowNodes != null && rowNodes.length > 0;\n if (partialRefresh) {\n var indexesToRemove = this.getRenderedIndexesForRowNodes(rowNodes);\n // remove the rows\n this.removeRowCtrls(indexesToRemove);\n }\n // add draw them again\n this.redrawAfterModelUpdate({\n recycleRows: partialRefresh\n });\n };\n RowRenderer.prototype.getCellToRestoreFocusToAfterRefresh = function (params) {\n var _a;\n var focusedCell = ((_a = params) === null || _a === void 0 ? void 0 : _a.suppressKeepFocus) ? null : this.focusService.getFocusCellToUseAfterRefresh();\n if (focusedCell == null) {\n return null;\n }\n // if the dom is not actually focused on a cell, then we don't try to refocus. the problem this\n // solves is with editing - if the user is editing, eg focus is on a text field, and not on the\n // cell itself, then the cell can be registered as having focus, however it's the text field that\n // has the focus and not the cell div. therefore, when the refresh is finished, the grid will focus\n // the cell, and not the textfield. that means if the user is in a text field, and the grid refreshes,\n // the focus is lost from the text field. we do not want this.\n var eDocument = this.gridOptionsWrapper.getDocument();\n var activeElement = eDocument.activeElement;\n var cellDomData = this.gridOptionsWrapper.getDomData(activeElement, CellCtrl.DOM_DATA_KEY_CELL_CTRL);\n var rowDomData = this.gridOptionsWrapper.getDomData(activeElement, RowCtrl.DOM_DATA_KEY_ROW_CTRL);\n var gridElementFocused = cellDomData || rowDomData;\n return gridElementFocused ? focusedCell : null;\n };\n // gets called from:\n // +) initialisation (in registerGridComp) params = null\n // +) onDomLayoutChanged, params = null\n // +) onPageLoaded, recycleRows, animate, newData, newPage from event, onlyBody=true\n // +) onPinnedRowDataChanged, recycleRows = true\n // +) redrawRows (from Grid API), recycleRows = true/false\n RowRenderer.prototype.redrawAfterModelUpdate = function (params) {\n if (params === void 0) { params = {}; }\n this.getLockOnRefresh();\n var focusedCell = this.getCellToRestoreFocusToAfterRefresh(params);\n this.updateContainerHeights();\n this.scrollToTopIfNewData(params);\n // never recycle rows when print layout, we draw each row again from scratch. this is because print layout\n // uses normal dom layout to put cells into dom - it doesn't allow reordering rows.\n var recycleRows = !this.printLayout && !!params.recycleRows;\n var animate = params.animate && this.gridOptionsWrapper.isAnimateRows();\n // after modelUpdate, row indexes can change, so we clear out the rowsByIndex map,\n // however we can reuse the rows, so we keep them but index by rowNode.id\n var rowsToRecycle = recycleRows ? this.recycleRows() : null;\n if (!recycleRows) {\n this.removeAllRowComps();\n }\n var isFocusedCellGettingRecycled = function () {\n if (focusedCell == null || rowsToRecycle == null) {\n return false;\n }\n var res = false;\n iterateObject(rowsToRecycle, function (key, rowComp) {\n var rowNode = rowComp.getRowNode();\n var rowIndexEqual = rowNode.rowIndex == focusedCell.rowIndex;\n var pinnedEqual = rowNode.rowPinned == focusedCell.rowPinned;\n if (rowIndexEqual && pinnedEqual) {\n res = true;\n }\n });\n return res;\n };\n var focusedCellRecycled = isFocusedCellGettingRecycled();\n this.redraw(rowsToRecycle, animate);\n this.gridBodyCtrl.updateRowCount();\n if (!params.onlyBody) {\n this.refreshFloatingRowComps();\n }\n this.dispatchDisplayedRowsChanged();\n // if we focus a cell that's already focused, then we get an unnecessary 'cellFocused' event fired.\n // this was happening when user clicked 'expand' on a rowGroup, then cellFocused was getting fired twice.\n if (!focusedCellRecycled) {\n this.restoreFocusedCell(focusedCell);\n }\n this.releaseLockOnRefresh();\n };\n RowRenderer.prototype.scrollToTopIfNewData = function (params) {\n var scrollToTop = params.newData || params.newPage;\n var suppressScrollToTop = this.gridOptionsWrapper.isSuppressScrollOnNewData();\n if (scrollToTop && !suppressScrollToTop) {\n this.gridBodyCtrl.getScrollFeature().scrollToTop();\n }\n };\n RowRenderer.prototype.updateContainerHeights = function () {\n // when doing print layout, we don't explicitly set height on the containers\n if (this.printLayout) {\n this.rowContainerHeightService.setModelHeight(null);\n return;\n }\n var containerHeight = this.paginationProxy.getCurrentPageHeight();\n // we need at least 1 pixel for the horizontal scroll to work. so if there are now rows,\n // we still want the scroll to be present, otherwise there would be no way to scroll the header\n // which might be needed us user wants to access columns\n // on the RHS - and if that was where the filter was that cause no rows to be presented, there\n // is no way to remove the filter.\n if (containerHeight === 0) {\n containerHeight = 1;\n }\n this.rowContainerHeightService.setModelHeight(containerHeight);\n };\n RowRenderer.prototype.getLockOnRefresh = function () {\n if (this.refreshInProgress) {\n throw new Error(\"AG Grid: cannot get grid to draw rows when it is in the middle of drawing rows. \" +\n \"Your code probably called a grid API method while the grid was in the render stage. To overcome \" +\n \"this, put the API call into a timeout, e.g. instead of api.redrawRows(), \" +\n \"call setTimeout(function() { api.redrawRows(); }, 0). To see what part of your code \" +\n \"that caused the refresh check this stacktrace.\");\n }\n this.refreshInProgress = true;\n };\n RowRenderer.prototype.releaseLockOnRefresh = function () {\n this.refreshInProgress = false;\n };\n RowRenderer.prototype.isRefreshInProgress = function () {\n return this.refreshInProgress;\n };\n // sets the focus to the provided cell, if the cell is provided. this way, the user can call refresh without\n // worry about the focus been lost. this is important when the user is using keyboard navigation to do edits\n // and the cellEditor is calling 'refresh' to get other cells to update (as other cells might depend on the\n // edited cell).\n RowRenderer.prototype.restoreFocusedCell = function (cellPosition) {\n if (cellPosition) {\n this.focusService.setFocusedCell({\n rowIndex: cellPosition.rowIndex,\n column: cellPosition.column,\n rowPinned: cellPosition.rowPinned,\n forceBrowserFocus: true,\n preventScrollOnBrowserFocus: true\n });\n }\n };\n RowRenderer.prototype.stopEditing = function (cancel) {\n if (cancel === void 0) { cancel = false; }\n this.getAllRowCtrls().forEach(function (rowCtrl) {\n rowCtrl.stopEditing(cancel);\n });\n };\n RowRenderer.prototype.getAllCellCtrls = function () {\n var res = [];\n this.getAllRowCtrls().forEach(function (rowCtrl) { return res = res.concat(rowCtrl.getAllCellCtrls()); });\n return res;\n };\n RowRenderer.prototype.getAllRowCtrls = function () {\n var _this = this;\n var stickyRowCtrls = (this.stickyRowFeature && this.stickyRowFeature.getStickyRowCtrls()) || [];\n var res = __spread(this.topRowCtrls, this.bottomRowCtrls, stickyRowCtrls);\n Object.keys(this.rowCtrlsByRowIndex).forEach(function (key) { return res.push(_this.rowCtrlsByRowIndex[key]); });\n return res;\n };\n RowRenderer.prototype.addRenderedRowListener = function (eventName, rowIndex, callback) {\n var rowComp = this.rowCtrlsByRowIndex[rowIndex];\n if (rowComp) {\n rowComp.addEventListener(eventName, callback);\n }\n };\n RowRenderer.prototype.flashCells = function (params) {\n if (params === void 0) { params = {}; }\n var flashDelay = params.flashDelay, fadeDelay = params.fadeDelay;\n this.getCellCtrls(params.rowNodes, params.columns)\n .forEach(function (cellCtrl) { return cellCtrl.flashCell({ flashDelay: flashDelay, fadeDelay: fadeDelay }); });\n };\n RowRenderer.prototype.refreshCells = function (params) {\n if (params === void 0) { params = {}; }\n var refreshCellParams = {\n forceRefresh: params.force,\n newData: false,\n suppressFlash: params.suppressFlash\n };\n this.getCellCtrls(params.rowNodes, params.columns)\n .forEach(function (cellCtrl) {\n if (cellCtrl.refreshShouldDestroy()) {\n var rowCtrl = cellCtrl.getRowCtrl();\n if (rowCtrl) {\n rowCtrl.refreshCell(cellCtrl);\n }\n }\n else {\n cellCtrl.refreshCell(refreshCellParams);\n }\n });\n this.getFullWidthRowCtrls(params.rowNodes).forEach(function (fullWidthRowCtrl) {\n fullWidthRowCtrl.refreshFullWidth();\n });\n };\n RowRenderer.prototype.getCellRendererInstances = function (params) {\n var res = this.getCellCtrls(params.rowNodes, params.columns)\n .map(function (cellCtrl) { return cellCtrl.getCellRenderer(); })\n .filter(function (renderer) { return renderer != null; });\n return res;\n };\n RowRenderer.prototype.getCellEditorInstances = function (params) {\n var res = [];\n this.getCellCtrls(params.rowNodes, params.columns).forEach(function (cellCtrl) {\n var cellEditor = cellCtrl.getCellEditor();\n if (cellEditor) {\n res.push(cellEditor);\n }\n });\n return res;\n };\n RowRenderer.prototype.getEditingCells = function () {\n var res = [];\n this.getAllCellCtrls().forEach(function (cellCtrl) {\n if (cellCtrl.isEditing()) {\n var cellPosition = cellCtrl.getCellPosition();\n res.push(cellPosition);\n }\n });\n return res;\n };\n RowRenderer.prototype.mapRowNodes = function (rowNodes) {\n if (!rowNodes) {\n return;\n }\n var res = {\n top: {},\n bottom: {},\n normal: {}\n };\n rowNodes.forEach(function (rowNode) {\n var id = rowNode.id;\n if (rowNode.rowPinned === Constants.PINNED_TOP) {\n res.top[id] = rowNode;\n }\n else if (rowNode.rowPinned === Constants.PINNED_BOTTOM) {\n res.bottom[id] = rowNode;\n }\n else {\n res.normal[id] = rowNode;\n }\n });\n return res;\n };\n RowRenderer.prototype.isRowInMap = function (rowNode, rowIdsMap) {\n // skip this row if it is missing from the provided list\n var id = rowNode.id;\n var floating = rowNode.rowPinned;\n if (floating === Constants.PINNED_BOTTOM) {\n return rowIdsMap.bottom[id] != null;\n }\n if (floating === Constants.PINNED_TOP) {\n return rowIdsMap.top[id] != null;\n }\n return rowIdsMap.normal[id] != null;\n };\n // returns CellCtrl's that match the provided rowNodes and columns. eg if one row node\n // and two columns provided, that identifies 4 cells, so 4 CellCtrl's returned.\n RowRenderer.prototype.getCellCtrls = function (rowNodes, columns) {\n var _this = this;\n var rowIdsMap = this.mapRowNodes(rowNodes);\n var res = [];\n var colIdsMap;\n if (exists(columns)) {\n colIdsMap = {};\n columns.forEach(function (colKey) {\n var column = _this.columnModel.getGridColumn(colKey);\n if (exists(column)) {\n colIdsMap[column.getId()] = true;\n }\n });\n }\n var processRow = function (rowComp) {\n var rowNode = rowComp.getRowNode();\n // skip this row if it is missing from the provided list\n if (rowIdsMap != null && !_this.isRowInMap(rowNode, rowIdsMap)) {\n return;\n }\n rowComp.getAllCellCtrls().forEach(function (cellCtrl) {\n var colId = cellCtrl.getColumn().getId();\n var excludeColFromRefresh = colIdsMap && !colIdsMap[colId];\n if (excludeColFromRefresh) {\n return;\n }\n res.push(cellCtrl);\n });\n };\n iterateObject(this.rowCtrlsByRowIndex, function (index, rowComp) {\n processRow(rowComp);\n });\n if (this.topRowCtrls) {\n this.topRowCtrls.forEach(processRow);\n }\n if (this.bottomRowCtrls) {\n this.bottomRowCtrls.forEach(processRow);\n }\n return res;\n };\n RowRenderer.prototype.destroy = function () {\n this.removeAllRowComps();\n _super.prototype.destroy.call(this);\n };\n RowRenderer.prototype.removeAllRowComps = function () {\n var rowIndexesToRemove = Object.keys(this.rowCtrlsByRowIndex);\n this.removeRowCtrls(rowIndexesToRemove);\n };\n RowRenderer.prototype.recycleRows = function () {\n // remove all stub nodes, they can't be reused, as no rowNode id\n var stubNodeIndexes = [];\n iterateObject(this.rowCtrlsByRowIndex, function (index, rowComp) {\n var stubNode = rowComp.getRowNode().id == null;\n if (stubNode) {\n stubNodeIndexes.push(index);\n }\n });\n this.removeRowCtrls(stubNodeIndexes);\n // then clear out rowCompsByIndex, but before that take a copy, but index by id, not rowIndex\n var ctrlsByIdMap = {};\n iterateObject(this.rowCtrlsByRowIndex, function (index, rowComp) {\n var rowNode = rowComp.getRowNode();\n ctrlsByIdMap[rowNode.id] = rowComp;\n });\n this.rowCtrlsByRowIndex = {};\n return ctrlsByIdMap;\n };\n // takes array of row indexes\n RowRenderer.prototype.removeRowCtrls = function (rowsToRemove) {\n var _this = this;\n // if no fromIndex then set to -1, which will refresh everything\n // let realFromIndex = -1;\n rowsToRemove.forEach(function (indexToRemove) {\n var rowCtrl = _this.rowCtrlsByRowIndex[indexToRemove];\n if (rowCtrl) {\n rowCtrl.destroyFirstPass();\n rowCtrl.destroySecondPass();\n }\n delete _this.rowCtrlsByRowIndex[indexToRemove];\n });\n };\n // gets called when rows don't change, but viewport does, so after:\n // 1) height of grid body changes, ie number of displayed rows has changed\n // 2) grid scrolled to new position\n // 3) ensure index visible (which is a scroll)\n RowRenderer.prototype.redrawAfterScroll = function () {\n var cellFocused;\n // only try to refocus cells shifting in and out of sticky container\n // if the browser supports focus ({ preventScroll })\n if (this.stickyRowFeature && browserSupportsPreventScroll()) {\n cellFocused = this.getCellToRestoreFocusToAfterRefresh() || undefined;\n }\n this.getLockOnRefresh();\n this.redraw(null, false, true);\n this.releaseLockOnRefresh();\n this.dispatchDisplayedRowsChanged();\n if (cellFocused != null) {\n var newFocusedCell = this.getCellToRestoreFocusToAfterRefresh();\n if (cellFocused != null && newFocusedCell == null) {\n this.animationFrameService.flushAllFrames();\n this.restoreFocusedCell(cellFocused);\n }\n }\n };\n RowRenderer.prototype.removeRowCompsNotToDraw = function (indexesToDraw) {\n // for speedy lookup, dump into map\n var indexesToDrawMap = {};\n indexesToDraw.forEach(function (index) { return (indexesToDrawMap[index] = true); });\n var existingIndexes = Object.keys(this.rowCtrlsByRowIndex);\n var indexesNotToDraw = existingIndexes.filter(function (index) { return !indexesToDrawMap[index]; });\n this.removeRowCtrls(indexesNotToDraw);\n };\n RowRenderer.prototype.calculateIndexesToDraw = function (rowsToRecycle) {\n var _this = this;\n // all in all indexes in the viewport\n var indexesToDraw = createArrayOfNumbers(this.firstRenderedRow, this.lastRenderedRow);\n var checkRowToDraw = function (indexStr, rowComp) {\n var index = rowComp.getRowNode().rowIndex;\n if (index == null) {\n return;\n }\n if (index < _this.firstRenderedRow || index > _this.lastRenderedRow) {\n if (_this.doNotUnVirtualiseRow(rowComp)) {\n indexesToDraw.push(index);\n }\n }\n };\n // if we are redrawing due to scrolling change, then old rows are in this.rowCompsByIndex\n iterateObject(this.rowCtrlsByRowIndex, checkRowToDraw);\n // if we are redrawing due to model update, then old rows are in rowsToRecycle\n iterateObject(rowsToRecycle, checkRowToDraw);\n indexesToDraw.sort(function (a, b) { return a - b; });\n indexesToDraw = indexesToDraw.filter(function (index) {\n var rowNode = _this.paginationProxy.getRow(index);\n return rowNode && !rowNode.sticky;\n });\n return indexesToDraw;\n };\n RowRenderer.prototype.redraw = function (rowsToRecycle, animate, afterScroll) {\n var _this = this;\n if (animate === void 0) { animate = false; }\n if (afterScroll === void 0) { afterScroll = false; }\n this.rowContainerHeightService.updateOffset();\n this.workOutFirstAndLastRowsToRender();\n if (this.stickyRowFeature) {\n this.stickyRowFeature.checkStickyRows();\n }\n // the row can already exist and be in the following:\n // rowsToRecycle -> if model change, then the index may be different, however row may\n // exist here from previous time (mapped by id).\n // this.rowCompsByIndex -> if just a scroll, then this will contain what is currently in the viewport\n // this is all the indexes we want, including those that already exist, so this method\n // will end up going through each index and drawing only if the row doesn't already exist\n var indexesToDraw = this.calculateIndexesToDraw(rowsToRecycle);\n this.removeRowCompsNotToDraw(indexesToDraw);\n // never animate when doing print layout - as we want to get things ready to print as quickly as possible,\n // otherwise we risk the printer printing a row that's half faded (half way through fading in)\n if (this.printLayout) {\n animate = false;\n }\n // add in new rows\n var rowCtrls = [];\n indexesToDraw.forEach(function (rowIndex) {\n var rowCtrl = _this.createOrUpdateRowCtrl(rowIndex, rowsToRecycle, animate, afterScroll);\n if (exists(rowCtrl)) {\n rowCtrls.push(rowCtrl);\n }\n });\n if (rowsToRecycle) {\n var useAnimationFrame = afterScroll && !this.gridOptionsWrapper.isSuppressAnimationFrame() && !this.printLayout;\n if (useAnimationFrame) {\n this.beans.animationFrameService.addDestroyTask(function () {\n _this.destroyRowCtrls(rowsToRecycle, animate);\n _this.updateAllRowCtrls();\n _this.dispatchDisplayedRowsChanged();\n });\n }\n else {\n this.destroyRowCtrls(rowsToRecycle, animate);\n }\n }\n this.updateAllRowCtrls();\n };\n RowRenderer.prototype.dispatchDisplayedRowsChanged = function () {\n var event = { type: Events.EVENT_DISPLAYED_ROWS_CHANGED };\n this.eventService.dispatchEvent(event);\n };\n RowRenderer.prototype.onDisplayedColumnsChanged = function () {\n var pinningLeft = this.columnModel.isPinningLeft();\n var pinningRight = this.columnModel.isPinningRight();\n var atLeastOneChanged = this.pinningLeft !== pinningLeft || pinningRight !== this.pinningRight;\n if (atLeastOneChanged) {\n this.pinningLeft = pinningLeft;\n this.pinningRight = pinningRight;\n if (this.embedFullWidthRows) {\n this.redrawFullWidthEmbeddedRows();\n }\n }\n };\n // when embedding, what gets showed in each section depends on what is pinned. eg if embedding group expand / collapse,\n // then it should go into the pinned left area if pinning left, or the center area if not pinning.\n RowRenderer.prototype.redrawFullWidthEmbeddedRows = function () {\n // if either of the pinned panels has shown / hidden, then need to redraw the fullWidth bits when\n // embedded, as what appears in each section depends on whether we are pinned or not\n var rowsToRemove = [];\n this.getFullWidthRowCtrls().forEach(function (fullWidthCtrl) {\n var rowIndex = fullWidthCtrl.getRowNode().rowIndex;\n rowsToRemove.push(rowIndex.toString());\n });\n this.refreshFloatingRowComps();\n this.removeRowCtrls(rowsToRemove);\n this.redrawAfterScroll();\n };\n RowRenderer.prototype.getFullWidthRowCtrls = function (rowNodes) {\n var _this = this;\n var rowNodesMap = this.mapRowNodes(rowNodes);\n return getAllValuesInObject(this.rowCtrlsByRowIndex).filter(function (rowCtrl) {\n // include just full width\n if (!rowCtrl.isFullWidth()) {\n return false;\n }\n // if Row Nodes provided, we exclude where Row Node is missing\n var rowNode = rowCtrl.getRowNode();\n if (rowNodesMap != null && !_this.isRowInMap(rowNode, rowNodesMap)) {\n return false;\n }\n return true;\n });\n };\n RowRenderer.prototype.refreshFullWidthRows = function (rowNodesToRefresh) {\n var rowsToRemove = [];\n var selectivelyRefreshing = !!rowNodesToRefresh;\n var idsToRefresh = selectivelyRefreshing ? {} : undefined;\n if (selectivelyRefreshing && idsToRefresh) {\n rowNodesToRefresh.forEach(function (r) { return idsToRefresh[r.id] = true; });\n }\n this.getFullWidthRowCtrls().forEach(function (fullWidthRowCtrl) {\n var rowNode = fullWidthRowCtrl.getRowNode();\n if (selectivelyRefreshing && idsToRefresh) {\n // we refresh if a) this node is present or b) this parents nodes is present. checking parent\n // node is important for master/detail, as we want detail to refresh on changes to parent node.\n // it's also possible, if user is provider their own fullWidth, that details panels contain\n // some info on the parent, eg if in tree data and child row shows some data from parent row also.\n var parentId = (rowNode.level > 0 && rowNode.parent) ? rowNode.parent.id : undefined;\n var skipThisNode = !idsToRefresh[rowNode.id] && !idsToRefresh[parentId];\n if (skipThisNode) {\n return;\n }\n }\n var fullWidthRowsRefreshed = fullWidthRowCtrl.refreshFullWidth();\n if (!fullWidthRowsRefreshed) {\n var rowIndex = fullWidthRowCtrl.getRowNode().rowIndex;\n rowsToRemove.push(rowIndex.toString());\n }\n });\n this.removeRowCtrls(rowsToRemove);\n this.redrawAfterScroll();\n };\n RowRenderer.prototype.createOrUpdateRowCtrl = function (rowIndex, rowsToRecycle, animate, afterScroll) {\n var rowNode;\n var rowCtrl = this.rowCtrlsByRowIndex[rowIndex];\n // if no row comp, see if we can get it from the previous rowComps\n if (!rowCtrl) {\n rowNode = this.paginationProxy.getRow(rowIndex);\n if (exists(rowNode) && exists(rowsToRecycle) && rowsToRecycle[rowNode.id] && rowNode.alreadyRendered) {\n rowCtrl = rowsToRecycle[rowNode.id];\n rowsToRecycle[rowNode.id] = null;\n }\n }\n var creatingNewRowCtrl = !rowCtrl;\n if (creatingNewRowCtrl) {\n // create a new one\n if (!rowNode) {\n rowNode = this.paginationProxy.getRow(rowIndex);\n }\n if (exists(rowNode)) {\n rowCtrl = this.createRowCon(rowNode, animate, afterScroll);\n }\n else {\n // this should never happen - if somehow we are trying to create\n // a row for a rowNode that does not exist.\n return;\n }\n }\n if (rowNode) {\n // set node as 'alreadyRendered' to ensure we only recycle rowComps that have been rendered, this ensures\n // we don't reuse rowComps that have been removed and then re-added in the same batch transaction.\n rowNode.alreadyRendered = true;\n }\n this.rowCtrlsByRowIndex[rowIndex] = rowCtrl;\n return rowCtrl;\n };\n RowRenderer.prototype.destroyRowCtrls = function (rowCtrlsMap, animate) {\n var _this = this;\n var executeInAWhileFuncs = [];\n iterateObject(rowCtrlsMap, function (nodeId, rowCtrl) {\n // if row was used, then it's null\n if (!rowCtrl) {\n return;\n }\n if (_this.cachedRowCtrls && rowCtrl.isCacheable()) {\n _this.cachedRowCtrls.addRow(rowCtrl);\n return;\n }\n rowCtrl.destroyFirstPass();\n if (animate) {\n _this.zombieRowCtrls[rowCtrl.getInstanceId()] = rowCtrl;\n executeInAWhileFuncs.push(function () {\n rowCtrl.destroySecondPass();\n delete _this.zombieRowCtrls[rowCtrl.getInstanceId()];\n });\n }\n else {\n rowCtrl.destroySecondPass();\n }\n });\n if (animate) {\n // this ensures we fire displayedRowsChanged AFTER all the 'executeInAWhileFuncs' get\n // executed, as we added it to the end of the list.\n executeInAWhileFuncs.push(function () {\n _this.updateAllRowCtrls();\n _this.dispatchDisplayedRowsChanged();\n });\n executeInAWhile(executeInAWhileFuncs);\n }\n };\n RowRenderer.prototype.workOutFirstAndLastRowsToRender = function () {\n var newFirst;\n var newLast;\n if (!this.paginationProxy.isRowsToRender()) {\n newFirst = 0;\n newLast = -1; // setting to -1 means nothing in range\n }\n else if (this.printLayout) {\n newFirst = this.paginationProxy.getPageFirstRow();\n newLast = this.paginationProxy.getPageLastRow();\n }\n else {\n var bufferPixels = this.gridOptionsWrapper.getRowBufferInPixels();\n var gridBodyCtrl = this.ctrlsService.getGridBodyCtrl();\n var suppressRowVirtualisation = this.gridOptionsWrapper.isSuppressRowVirtualisation();\n var rowHeightsChanged = false;\n var firstPixel = void 0;\n var lastPixel = void 0;\n do {\n var paginationOffset = this.paginationProxy.getPixelOffset();\n var _a = this.paginationProxy.getCurrentPagePixelRange(), pageFirstPixel = _a.pageFirstPixel, pageLastPixel = _a.pageLastPixel;\n var divStretchOffset = this.rowContainerHeightService.getDivStretchOffset();\n var bodyVRange = gridBodyCtrl.getScrollFeature().getVScrollPosition();\n var bodyTopPixel = bodyVRange.top;\n var bodyBottomPixel = bodyVRange.bottom;\n if (suppressRowVirtualisation) {\n firstPixel = pageFirstPixel + divStretchOffset;\n lastPixel = pageLastPixel + divStretchOffset;\n }\n else {\n firstPixel = Math.max(bodyTopPixel + paginationOffset - bufferPixels, pageFirstPixel) + divStretchOffset;\n lastPixel = Math.min(bodyBottomPixel + paginationOffset + bufferPixels, pageLastPixel) + divStretchOffset;\n }\n this.firstVisibleVPixel = Math.max(bodyTopPixel + paginationOffset, pageFirstPixel) + divStretchOffset;\n // if the rows we are about to display get their heights changed, then that upsets the calcs from above.\n rowHeightsChanged = this.ensureAllRowsInRangeHaveHeightsCalculated(firstPixel, lastPixel);\n } while (rowHeightsChanged);\n var firstRowIndex = this.paginationProxy.getRowIndexAtPixel(firstPixel);\n var lastRowIndex = this.paginationProxy.getRowIndexAtPixel(lastPixel);\n var pageFirstRow = this.paginationProxy.getPageFirstRow();\n var pageLastRow = this.paginationProxy.getPageLastRow();\n // adjust, in case buffer extended actual size\n if (firstRowIndex < pageFirstRow) {\n firstRowIndex = pageFirstRow;\n }\n if (lastRowIndex > pageLastRow) {\n lastRowIndex = pageLastRow;\n }\n newFirst = firstRowIndex;\n newLast = lastRowIndex;\n }\n // sometimes user doesn't set CSS right and ends up with grid with no height and grid ends up\n // trying to render all the rows, eg 10,000+ rows. this will kill the browser. so instead of\n // killing the browser, we limit the number of rows. just in case some use case we didn't think\n // of, we also have a property to not do this operation.\n var rowLayoutNormal = this.gridOptionsWrapper.getDomLayout() === Constants.DOM_LAYOUT_NORMAL;\n var suppressRowCountRestriction = this.gridOptionsWrapper.isSuppressMaxRenderedRowRestriction();\n var rowBufferMaxSize = Math.max(this.gridOptionsWrapper.getRowBuffer(), 500);\n if (rowLayoutNormal && !suppressRowCountRestriction) {\n if (newLast - newFirst > rowBufferMaxSize) {\n newLast = newFirst + rowBufferMaxSize;\n }\n }\n var firstDiffers = newFirst !== this.firstRenderedRow;\n var lastDiffers = newLast !== this.lastRenderedRow;\n if (firstDiffers || lastDiffers) {\n this.firstRenderedRow = newFirst;\n this.lastRenderedRow = newLast;\n var event_1 = {\n type: Events.EVENT_VIEWPORT_CHANGED,\n firstRow: newFirst,\n lastRow: newLast\n };\n this.eventService.dispatchEvent(event_1);\n }\n };\n /**\n * This event will only be fired once, and is queued until after the browser next renders.\n * This allows us to fire an event during the start of the render cycle, when we first see data being rendered\n * but not execute the event until all of the data has finished being rendered to the dom.\n */\n RowRenderer.prototype.dispatchFirstDataRenderedEvent = function () {\n var _this = this;\n if (this.dataFirstRenderedFired) {\n return;\n }\n this.dataFirstRenderedFired = true;\n var event = {\n type: Events.EVENT_FIRST_DATA_RENDERED,\n firstRow: this.firstRenderedRow,\n lastRow: this.lastRenderedRow,\n };\n // See AG-7018\n window.requestAnimationFrame(function () {\n _this.beans.eventService.dispatchEvent(event);\n });\n };\n RowRenderer.prototype.ensureAllRowsInRangeHaveHeightsCalculated = function (topPixel, bottomPixel) {\n // ensureRowHeightsVisible only works with CSRM, as it's the only row model that allows lazy row height calcs.\n // all the other row models just hard code so the method just returns back false\n var res = this.paginationProxy.ensureRowHeightsValid(topPixel, bottomPixel, -1, -1);\n if (res) {\n this.updateContainerHeights();\n }\n return res;\n };\n RowRenderer.prototype.getFirstVisibleVerticalPixel = function () {\n return this.firstVisibleVPixel;\n };\n RowRenderer.prototype.getFirstVirtualRenderedRow = function () {\n return this.firstRenderedRow;\n };\n RowRenderer.prototype.getLastVirtualRenderedRow = function () {\n return this.lastRenderedRow;\n };\n // check that none of the rows to remove are editing or focused as:\n // a) if editing, we want to keep them, otherwise the user will loose the context of the edit,\n // eg user starts editing, enters some text, then scrolls down and then up, next time row rendered\n // the edit is reset - so we want to keep it rendered.\n // b) if focused, we want ot keep keyboard focus, so if user ctrl+c, it goes to clipboard,\n // otherwise the user can range select and drag (with focus cell going out of the viewport)\n // and then ctrl+c, nothing will happen if cell is removed from dom.\n // c) if detail record of master detail, as users complained that the context of detail rows\n // was getting lost when detail row out of view. eg user expands to show detail row,\n // then manipulates the detail panel (eg sorts the detail grid), then context is lost\n // after detail panel is scrolled out of / into view.\n RowRenderer.prototype.doNotUnVirtualiseRow = function (rowComp) {\n var REMOVE_ROW = false;\n var KEEP_ROW = true;\n var rowNode = rowComp.getRowNode();\n var rowHasFocus = this.focusService.isRowNodeFocused(rowNode);\n var rowIsEditing = rowComp.isEditing();\n var rowIsDetail = rowNode.detail;\n var mightWantToKeepRow = rowHasFocus || rowIsEditing || rowIsDetail;\n // if we deffo don't want to keep it,\n if (!mightWantToKeepRow) {\n return REMOVE_ROW;\n }\n // editing row, only remove if it is no longer rendered, eg filtered out or new data set.\n // the reason we want to keep is if user is scrolling up and down, we don't want to loose\n // the context of the editing in process.\n var rowNodePresent = this.paginationProxy.isRowPresent(rowNode);\n return rowNodePresent ? KEEP_ROW : REMOVE_ROW;\n };\n RowRenderer.prototype.createRowCon = function (rowNode, animate, afterScroll) {\n var rowCtrlFromCache = this.cachedRowCtrls ? this.cachedRowCtrls.getRow(rowNode) : null;\n if (rowCtrlFromCache) {\n return rowCtrlFromCache;\n }\n // we don't use animations frames for printing, so the user can put the grid into print mode\n // and immediately print - otherwise the user would have to wait for the rows to draw in the background\n // (via the animation frames) which is awkward to do from code.\n // we only do the animation frames after scrolling, as this is where we want the smooth user experience.\n // having animation frames for other times makes the grid look 'jumpy'.\n var suppressAnimationFrame = this.gridOptionsWrapper.isSuppressAnimationFrame();\n var useAnimationFrameForCreate = afterScroll && !suppressAnimationFrame && !this.printLayout;\n var res = new RowCtrl(rowNode, this.beans, animate, useAnimationFrameForCreate, this.printLayout);\n return res;\n };\n RowRenderer.prototype.getRenderedNodes = function () {\n var renderedRows = this.rowCtrlsByRowIndex;\n return Object.keys(renderedRows).map(function (key) { return renderedRows[key].getRowNode(); });\n };\n RowRenderer.prototype.getRowByPosition = function (rowPosition) {\n var rowCtrl;\n var rowIndex = rowPosition.rowIndex;\n switch (rowPosition.rowPinned) {\n case Constants.PINNED_TOP:\n rowCtrl = this.topRowCtrls[rowIndex];\n break;\n case Constants.PINNED_BOTTOM:\n rowCtrl = this.bottomRowCtrls[rowIndex];\n break;\n default:\n rowCtrl = this.rowCtrlsByRowIndex[rowIndex];\n if (!rowCtrl) {\n rowCtrl = this.getStickyTopRowCtrls().find(function (ctrl) { return ctrl.getRowNode().rowIndex === rowIndex; }) || null;\n }\n break;\n }\n return rowCtrl;\n };\n RowRenderer.prototype.getRowNode = function (gridRow) {\n switch (gridRow.rowPinned) {\n case Constants.PINNED_TOP:\n return this.pinnedRowModel.getPinnedTopRowData()[gridRow.rowIndex];\n case Constants.PINNED_BOTTOM:\n return this.pinnedRowModel.getPinnedBottomRowData()[gridRow.rowIndex];\n default:\n return this.rowModel.getRow(gridRow.rowIndex);\n }\n };\n // returns true if any row between startIndex and endIndex is rendered. used by\n // SSRM or IRM, as they don't want to purge visible blocks from cache.\n RowRenderer.prototype.isRangeInRenderedViewport = function (startIndex, endIndex) {\n // parent closed means the parent node is not expanded, thus these blocks are not visible\n var parentClosed = startIndex == null || endIndex == null;\n if (parentClosed) {\n return false;\n }\n var blockAfterViewport = startIndex > this.lastRenderedRow;\n var blockBeforeViewport = endIndex < this.firstRenderedRow;\n var blockInsideViewport = !blockBeforeViewport && !blockAfterViewport;\n return blockInsideViewport;\n };\n __decorate([\n Autowired(\"animationFrameService\")\n ], RowRenderer.prototype, \"animationFrameService\", void 0);\n __decorate([\n Autowired(\"paginationProxy\")\n ], RowRenderer.prototype, \"paginationProxy\", void 0);\n __decorate([\n Autowired(\"columnModel\")\n ], RowRenderer.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired(\"pinnedRowModel\")\n ], RowRenderer.prototype, \"pinnedRowModel\", void 0);\n __decorate([\n Autowired(\"rowModel\")\n ], RowRenderer.prototype, \"rowModel\", void 0);\n __decorate([\n Autowired(\"focusService\")\n ], RowRenderer.prototype, \"focusService\", void 0);\n __decorate([\n Autowired(\"beans\")\n ], RowRenderer.prototype, \"beans\", void 0);\n __decorate([\n Autowired(\"rowContainerHeightService\")\n ], RowRenderer.prototype, \"rowContainerHeightService\", void 0);\n __decorate([\n Autowired(\"ctrlsService\")\n ], RowRenderer.prototype, \"ctrlsService\", void 0);\n __decorate([\n PostConstruct\n ], RowRenderer.prototype, \"postConstruct\", null);\n RowRenderer = __decorate([\n Bean(\"rowRenderer\")\n ], RowRenderer);\n return RowRenderer;\n}(BeanStub));\nexport { RowRenderer };\nvar RowCtrlCache = /** @class */ (function () {\n function RowCtrlCache(maxCount) {\n // map for fast access\n this.entriesMap = {};\n // list for keeping order\n this.entriesList = [];\n this.maxCount = maxCount;\n }\n RowCtrlCache.prototype.addRow = function (rowCtrl) {\n this.entriesMap[rowCtrl.getRowNode().id] = rowCtrl;\n this.entriesList.push(rowCtrl);\n rowCtrl.setCached(true);\n if (this.entriesList.length > this.maxCount) {\n var rowCtrlToDestroy = this.entriesList[0];\n rowCtrlToDestroy.destroyFirstPass();\n rowCtrlToDestroy.destroySecondPass();\n this.removeFromCache(rowCtrlToDestroy);\n }\n };\n RowCtrlCache.prototype.getRow = function (rowNode) {\n if (rowNode == null || rowNode.id == null) {\n return null;\n }\n var res = this.entriesMap[rowNode.id];\n if (!res) {\n return null;\n }\n this.removeFromCache(res);\n res.setCached(false);\n // this can happen if user reloads data, and a new RowNode is reusing\n // the same ID as the old one\n var rowNodeMismatch = res.getRowNode() != rowNode;\n return rowNodeMismatch ? null : res;\n };\n RowCtrlCache.prototype.removeFromCache = function (rowCtrl) {\n var rowNodeId = rowCtrl.getRowNode().id;\n delete this.entriesMap[rowNodeId];\n removeFromArray(this.entriesList, rowCtrl);\n };\n RowCtrlCache.prototype.getEntries = function () {\n return this.entriesList;\n };\n return RowCtrlCache;\n}());\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean, Autowired } from '../context/context';\nimport { BeanStub } from \"../context/beanStub\";\nvar ValueFormatterService = /** @class */ (function (_super) {\n __extends(ValueFormatterService, _super);\n function ValueFormatterService() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n ValueFormatterService.prototype.formatValue = function (column, node, value, suppliedFormatter, useFormatterFromColumn) {\n if (useFormatterFromColumn === void 0) { useFormatterFromColumn = true; }\n var result = null;\n var formatter;\n var colDef = column.getColDef();\n if (suppliedFormatter) {\n // use supplied formatter if provided, e.g. set filter items can have their own value formatters\n formatter = suppliedFormatter;\n }\n else if (useFormatterFromColumn) {\n // if row is pinned, give preference to the pinned formatter\n formatter = node && node.rowPinned && colDef.pinnedRowValueFormatter ?\n colDef.pinnedRowValueFormatter : colDef.valueFormatter;\n }\n if (formatter) {\n var params = {\n value: value,\n node: node,\n data: node ? node.data : null,\n colDef: colDef,\n column: column,\n api: this.gridOptionsWrapper.getApi(),\n columnApi: this.gridOptionsWrapper.getColumnApi(),\n context: this.gridOptionsWrapper.getContext()\n };\n result = this.expressionService.evaluate(formatter, params);\n }\n else if (colDef.refData) {\n return colDef.refData[value] || '';\n }\n // if we don't do this, then arrays get displayed as 1,2,3, but we want 1, 2, 3 (i.e. with spaces)\n if (result == null && Array.isArray(value)) {\n result = value.join(', ');\n }\n return result;\n };\n __decorate([\n Autowired('expressionService')\n ], ValueFormatterService.prototype, \"expressionService\", void 0);\n ValueFormatterService = __decorate([\n Bean('valueFormatterService')\n ], ValueFormatterService);\n return ValueFormatterService;\n}(BeanStub));\nexport { ValueFormatterService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { RowNode } from \"../entities/rowNode\";\nimport { Autowired, Bean, PostConstruct } from \"../context/context\";\nimport { Events } from \"../events\";\nimport { Constants } from \"../constants/constants\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { missingOrEmpty } from \"../utils/generic\";\nimport { last } from \"../utils/array\";\nvar PinnedRowModel = /** @class */ (function (_super) {\n __extends(PinnedRowModel, _super);\n function PinnedRowModel() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n PinnedRowModel.prototype.init = function () {\n this.setPinnedTopRowData(this.gridOptionsWrapper.getPinnedTopRowData());\n this.setPinnedBottomRowData(this.gridOptionsWrapper.getPinnedBottomRowData());\n };\n PinnedRowModel.prototype.isEmpty = function (floating) {\n var rows = floating === Constants.PINNED_TOP ? this.pinnedTopRows : this.pinnedBottomRows;\n return missingOrEmpty(rows);\n };\n PinnedRowModel.prototype.isRowsToRender = function (floating) {\n return !this.isEmpty(floating);\n };\n PinnedRowModel.prototype.getRowAtPixel = function (pixel, floating) {\n var rows = floating === Constants.PINNED_TOP ? this.pinnedTopRows : this.pinnedBottomRows;\n if (missingOrEmpty(rows)) {\n return 0; // this should never happen, just in case, 0 is graceful failure\n }\n for (var i = 0; i < rows.length; i++) {\n var rowNode = rows[i];\n var rowTopPixel = rowNode.rowTop + rowNode.rowHeight - 1;\n // only need to range check against the top pixel, as we are going through the list\n // in order, first row to hit the pixel wins\n if (rowTopPixel >= pixel) {\n return i;\n }\n }\n return rows.length - 1;\n };\n PinnedRowModel.prototype.setPinnedTopRowData = function (rowData) {\n this.pinnedTopRows = this.createNodesFromData(rowData, true);\n var event = {\n type: Events.EVENT_PINNED_ROW_DATA_CHANGED\n };\n this.eventService.dispatchEvent(event);\n };\n PinnedRowModel.prototype.setPinnedBottomRowData = function (rowData) {\n this.pinnedBottomRows = this.createNodesFromData(rowData, false);\n var event = {\n type: Events.EVENT_PINNED_ROW_DATA_CHANGED\n };\n this.eventService.dispatchEvent(event);\n };\n PinnedRowModel.prototype.createNodesFromData = function (allData, isTop) {\n var _this = this;\n var rowNodes = [];\n if (allData) {\n var nextRowTop_1 = 0;\n allData.forEach(function (dataItem, index) {\n var rowNode = new RowNode(_this.beans);\n rowNode.data = dataItem;\n var idPrefix = isTop ? RowNode.ID_PREFIX_TOP_PINNED : RowNode.ID_PREFIX_BOTTOM_PINNED;\n rowNode.id = idPrefix + index;\n rowNode.rowPinned = isTop ? Constants.PINNED_TOP : Constants.PINNED_BOTTOM;\n rowNode.setRowTop(nextRowTop_1);\n rowNode.setRowHeight(_this.gridOptionsWrapper.getRowHeightForNode(rowNode).height);\n rowNode.setRowIndex(index);\n nextRowTop_1 += rowNode.rowHeight;\n rowNodes.push(rowNode);\n });\n }\n return rowNodes;\n };\n PinnedRowModel.prototype.getPinnedTopRowData = function () {\n return this.pinnedTopRows;\n };\n PinnedRowModel.prototype.getPinnedBottomRowData = function () {\n return this.pinnedBottomRows;\n };\n PinnedRowModel.prototype.getPinnedTopTotalHeight = function () {\n return this.getTotalHeight(this.pinnedTopRows);\n };\n PinnedRowModel.prototype.getPinnedTopRowCount = function () {\n return this.pinnedTopRows ? this.pinnedTopRows.length : 0;\n };\n PinnedRowModel.prototype.getPinnedBottomRowCount = function () {\n return this.pinnedBottomRows ? this.pinnedBottomRows.length : 0;\n };\n PinnedRowModel.prototype.getPinnedTopRow = function (index) {\n return this.pinnedTopRows[index];\n };\n PinnedRowModel.prototype.getPinnedBottomRow = function (index) {\n return this.pinnedBottomRows[index];\n };\n PinnedRowModel.prototype.forEachPinnedTopRow = function (callback) {\n if (missingOrEmpty(this.pinnedTopRows)) {\n return;\n }\n this.pinnedTopRows.forEach(callback);\n };\n PinnedRowModel.prototype.forEachPinnedBottomRow = function (callback) {\n if (missingOrEmpty(this.pinnedBottomRows)) {\n return;\n }\n this.pinnedBottomRows.forEach(callback);\n };\n PinnedRowModel.prototype.getPinnedBottomTotalHeight = function () {\n return this.getTotalHeight(this.pinnedBottomRows);\n };\n PinnedRowModel.prototype.getTotalHeight = function (rowNodes) {\n if (!rowNodes || rowNodes.length === 0) {\n return 0;\n }\n var lastNode = last(rowNodes);\n return lastNode.rowTop + lastNode.rowHeight;\n };\n __decorate([\n Autowired('beans')\n ], PinnedRowModel.prototype, \"beans\", void 0);\n __decorate([\n PostConstruct\n ], PinnedRowModel.prototype, \"init\", null);\n PinnedRowModel = __decorate([\n Bean('pinnedRowModel')\n ], PinnedRowModel);\n return PinnedRowModel;\n}(BeanStub));\nexport { PinnedRowModel };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nexport var ServerSideTransactionResultStatus;\n(function (ServerSideTransactionResultStatus) {\n /** Transaction was successfully applied */\n ServerSideTransactionResultStatus[\"Applied\"] = \"Applied\";\n /**\n * Store was not found, transaction not applied.\n * Either invalid route, or the parent row has not yet been expanded.\n */\n ServerSideTransactionResultStatus[\"StoreNotFound\"] = \"StoreNotFound\";\n /**\n * Store is loading, transaction not applied.\n */\n ServerSideTransactionResultStatus[\"StoreLoading\"] = \"StoreLoading\";\n /**\n * Store is loading (as max loads exceeded), transaction not applied.\n */\n ServerSideTransactionResultStatus[\"StoreWaitingToLoad\"] = \"StoreWaitingToLoad\";\n /**\n * Store load attempt failed, transaction not applied.\n */\n ServerSideTransactionResultStatus[\"StoreLoadingFailed\"] = \"StoreLoadingFailed\";\n /**\n * Store is type Partial, which doesn't accept transactions\n */\n ServerSideTransactionResultStatus[\"StoreWrongType\"] = \"StoreWrongType\";\n /**\n * Transaction was cancelled, due to grid.\n * Callback isApplyServerSideTransaction() returning false\n */\n ServerSideTransactionResultStatus[\"Cancelled\"] = \"Cancelled\";\n})(ServerSideTransactionResultStatus || (ServerSideTransactionResultStatus = {}));\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\n// when doing transactions, or change detection, and grouping is present\n// in the data, there is no need for the ClientSideRowModel to update each\n// group after an update, ony parts that were impacted by the change.\n// this class keeps track of all groups that were impacted by a transaction.\n// the the different CSRM operations (filter, sort etc) use the forEach method\n// to visit each group that was changed.\nvar ChangedPath = /** @class */ (function () {\n function ChangedPath(keepingColumns, rootNode) {\n // whether changed path is active of not. it is active when a) doing\n // a transaction update or b) doing change detection. if we are doing\n // a CSRM refresh for other reasons (after sort or filter, or user calling\n // setRowData() without delta mode) then we are not active. we are also\n // marked as not active if secondary columns change in pivot (as this impacts\n // aggregations)\n this.active = true;\n // for each node in the change path, we also store which columns need\n // to be re-aggregated.\n this.nodeIdsToColumns = {};\n // for quick lookup, all items in the change path are mapped by nodeId\n this.mapToItems = {};\n this.keepingColumns = keepingColumns;\n this.pathRoot = {\n rowNode: rootNode,\n children: null\n };\n this.mapToItems[rootNode.id] = this.pathRoot;\n }\n // can be set inactive by:\n // a) ClientSideRowModel, if no transactions or\n // b) PivotService, if secondary columns changed\n ChangedPath.prototype.setInactive = function () {\n this.active = false;\n };\n ChangedPath.prototype.isActive = function () {\n return this.active;\n };\n ChangedPath.prototype.depthFirstSearchChangedPath = function (pathItem, callback) {\n if (pathItem.children) {\n for (var i = 0; i < pathItem.children.length; i++) {\n this.depthFirstSearchChangedPath(pathItem.children[i], callback);\n }\n }\n callback(pathItem.rowNode);\n };\n ChangedPath.prototype.depthFirstSearchEverything = function (rowNode, callback, traverseEverything) {\n if (rowNode.childrenAfterGroup) {\n for (var i = 0; i < rowNode.childrenAfterGroup.length; i++) {\n var childNode = rowNode.childrenAfterGroup[i];\n if (childNode.childrenAfterGroup) {\n this.depthFirstSearchEverything(rowNode.childrenAfterGroup[i], callback, traverseEverything);\n }\n else if (traverseEverything) {\n callback(childNode);\n }\n }\n }\n callback(rowNode);\n };\n // traverseLeafNodes -> used when NOT doing changed path, ie traversing everything. the callback\n // will be called for child nodes in addition to parent nodes.\n ChangedPath.prototype.forEachChangedNodeDepthFirst = function (callback, traverseLeafNodes) {\n if (traverseLeafNodes === void 0) { traverseLeafNodes = false; }\n if (this.active) {\n // if we are active, then use the change path to callback\n // only for updated groups\n this.depthFirstSearchChangedPath(this.pathRoot, callback);\n }\n else {\n // we are not active, so callback for everything, walk the entire path\n this.depthFirstSearchEverything(this.pathRoot.rowNode, callback, traverseLeafNodes);\n }\n };\n ChangedPath.prototype.executeFromRootNode = function (callback) {\n callback(this.pathRoot.rowNode);\n };\n ChangedPath.prototype.createPathItems = function (rowNode) {\n var pointer = rowNode;\n var newEntryCount = 0;\n while (!this.mapToItems[pointer.id]) {\n var newEntry = {\n rowNode: pointer,\n children: null\n };\n this.mapToItems[pointer.id] = newEntry;\n newEntryCount++;\n pointer = pointer.parent;\n }\n return newEntryCount;\n };\n ChangedPath.prototype.populateColumnsMap = function (rowNode, columns) {\n var _this = this;\n if (!this.keepingColumns || !columns) {\n return;\n }\n var pointer = rowNode;\n while (pointer) {\n // if columns, add the columns in all the way to parent, merging\n // in any other columns that might be there already\n if (!this.nodeIdsToColumns[pointer.id]) {\n this.nodeIdsToColumns[pointer.id] = {};\n }\n columns.forEach(function (col) { return _this.nodeIdsToColumns[pointer.id][col.getId()] = true; });\n pointer = pointer.parent;\n }\n };\n ChangedPath.prototype.linkPathItems = function (rowNode, newEntryCount) {\n var pointer = rowNode;\n for (var i = 0; i < newEntryCount; i++) {\n var thisItem = this.mapToItems[pointer.id];\n var parentItem = this.mapToItems[pointer.parent.id];\n if (!parentItem.children) {\n parentItem.children = [];\n }\n parentItem.children.push(thisItem);\n pointer = pointer.parent;\n }\n };\n // called by\n // 1) change detection (provides cols) and\n // 2) groupStage if doing transaction update (doesn't provide cols)\n ChangedPath.prototype.addParentNode = function (rowNode, columns) {\n if (!rowNode || rowNode.isRowPinned()) {\n return;\n }\n // we cannot do both steps below in the same loop as\n // the second loop has a dependency on the first loop.\n // ie the hierarchy cannot be stitched up yet because\n // we don't have it built yet\n // create the new PathItem objects.\n var newEntryCount = this.createPathItems(rowNode);\n // link in the node items\n this.linkPathItems(rowNode, newEntryCount);\n // update columns\n this.populateColumnsMap(rowNode, columns);\n };\n ChangedPath.prototype.canSkip = function (rowNode) {\n return this.active && !this.mapToItems[rowNode.id];\n };\n ChangedPath.prototype.getValueColumnsForNode = function (rowNode, valueColumns) {\n if (!this.keepingColumns) {\n return valueColumns;\n }\n var colsForThisNode = this.nodeIdsToColumns[rowNode.id];\n var result = valueColumns.filter(function (col) { return colsForThisNode[col.getId()]; });\n return result;\n };\n ChangedPath.prototype.getNotValueColumnsForNode = function (rowNode, valueColumns) {\n if (!this.keepingColumns) {\n return null;\n }\n var colsForThisNode = this.nodeIdsToColumns[rowNode.id];\n var result = valueColumns.filter(function (col) { return !colsForThisNode[col.getId()]; });\n return result;\n };\n return ChangedPath;\n}());\nexport { ChangedPath };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { BeanStub } from \"../context/beanStub\";\nvar RowNodeBlock = /** @class */ (function (_super) {\n __extends(RowNodeBlock, _super);\n function RowNodeBlock(id) {\n var _this = _super.call(this) || this;\n _this.state = RowNodeBlock.STATE_WAITING_TO_LOAD;\n _this.version = 0;\n _this.id = id;\n return _this;\n }\n RowNodeBlock.prototype.getId = function () {\n return this.id;\n };\n RowNodeBlock.prototype.load = function () {\n this.state = RowNodeBlock.STATE_LOADING;\n this.loadFromDatasource();\n };\n RowNodeBlock.prototype.getVersion = function () {\n return this.version;\n };\n RowNodeBlock.prototype.setStateWaitingToLoad = function () {\n // in case any current loads in progress, this will have their results ignored\n this.version++;\n this.state = RowNodeBlock.STATE_WAITING_TO_LOAD;\n };\n RowNodeBlock.prototype.getState = function () {\n return this.state;\n };\n RowNodeBlock.prototype.pageLoadFailed = function (version) {\n var requestMostRecentAndLive = this.isRequestMostRecentAndLive(version);\n if (requestMostRecentAndLive) {\n this.state = RowNodeBlock.STATE_FAILED;\n this.processServerFail();\n }\n this.dispatchLoadCompleted(false);\n };\n RowNodeBlock.prototype.success = function (version, params) {\n this.successCommon(version, params);\n };\n RowNodeBlock.prototype.pageLoaded = function (version, rows, lastRow) {\n this.successCommon(version, { rowData: rows, rowCount: lastRow });\n };\n RowNodeBlock.prototype.isRequestMostRecentAndLive = function (version) {\n // thisIsMostRecentRequest - if block was refreshed, then another request\n // could of been sent after this one.\n var thisIsMostRecentRequest = version === this.version;\n // weAreNotDestroyed - if InfiniteStore is purged, then blocks are destroyed\n // and new blocks created. so data loads of old blocks are discarded.\n var weAreNotDestroyed = this.isAlive();\n return thisIsMostRecentRequest && weAreNotDestroyed;\n };\n RowNodeBlock.prototype.successCommon = function (version, params) {\n // need to dispatch load complete before processing the data, as PaginationComp checks\n // RowNodeBlockLoader to see if it is still loading, so the RowNodeBlockLoader needs to\n // be updated first (via LoadComplete event) before PaginationComp updates (via processServerResult method)\n this.dispatchLoadCompleted();\n var requestMostRecentAndLive = this.isRequestMostRecentAndLive(version);\n if (requestMostRecentAndLive) {\n this.state = RowNodeBlock.STATE_LOADED;\n this.processServerResult(params);\n }\n };\n RowNodeBlock.prototype.dispatchLoadCompleted = function (success) {\n if (success === void 0) { success = true; }\n // we fire event regardless of processing data or now, as we want\n // the concurrentLoadRequests count to be reduced in BlockLoader\n var event = {\n type: RowNodeBlock.EVENT_LOAD_COMPLETE,\n success: success,\n block: this\n };\n this.dispatchEvent(event);\n };\n RowNodeBlock.EVENT_LOAD_COMPLETE = 'loadComplete';\n RowNodeBlock.STATE_WAITING_TO_LOAD = 'needsLoading';\n RowNodeBlock.STATE_LOADING = 'loading';\n RowNodeBlock.STATE_LOADED = 'loaded';\n RowNodeBlock.STATE_FAILED = 'failed';\n return RowNodeBlock;\n}(BeanStub));\nexport { RowNodeBlock };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n};\nimport { RowNodeBlock } from \"./rowNodeBlock\";\nimport { Bean, PostConstruct, Qualifier } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { _ } from \"../utils\";\nvar RowNodeBlockLoader = /** @class */ (function (_super) {\n __extends(RowNodeBlockLoader, _super);\n function RowNodeBlockLoader() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.activeBlockLoadsCount = 0;\n _this.blocks = [];\n _this.active = true;\n return _this;\n }\n RowNodeBlockLoader_1 = RowNodeBlockLoader;\n RowNodeBlockLoader.prototype.postConstruct = function () {\n this.maxConcurrentRequests = this.gridOptionsWrapper.getMaxConcurrentDatasourceRequests();\n var blockLoadDebounceMillis = this.gridOptionsWrapper.getBlockLoadDebounceMillis();\n if (blockLoadDebounceMillis && blockLoadDebounceMillis > 0) {\n this.checkBlockToLoadDebounce = _.debounce(this.performCheckBlocksToLoad.bind(this), blockLoadDebounceMillis);\n }\n };\n RowNodeBlockLoader.prototype.setBeans = function (loggerFactory) {\n this.logger = loggerFactory.create('RowNodeBlockLoader');\n };\n RowNodeBlockLoader.prototype.addBlock = function (block) {\n this.blocks.push(block);\n // note that we do not remove this listener when removing the block. this is because the\n // cache can get destroyed (and containing blocks) when a block is loading. however the loading block\n // is still counted as an active loading block and we must decrement activeBlockLoadsCount when it finishes.\n block.addEventListener(RowNodeBlock.EVENT_LOAD_COMPLETE, this.loadComplete.bind(this));\n this.checkBlockToLoad();\n };\n RowNodeBlockLoader.prototype.removeBlock = function (block) {\n _.removeFromArray(this.blocks, block);\n };\n RowNodeBlockLoader.prototype.destroy = function () {\n _super.prototype.destroy.call(this);\n this.active = false;\n };\n RowNodeBlockLoader.prototype.loadComplete = function () {\n this.activeBlockLoadsCount--;\n this.checkBlockToLoad();\n if (this.activeBlockLoadsCount == 0) {\n this.dispatchEvent({ type: RowNodeBlockLoader_1.BLOCK_LOADER_FINISHED_EVENT });\n }\n };\n RowNodeBlockLoader.prototype.checkBlockToLoad = function () {\n if (this.checkBlockToLoadDebounce) {\n this.checkBlockToLoadDebounce();\n }\n else {\n this.performCheckBlocksToLoad();\n }\n };\n RowNodeBlockLoader.prototype.performCheckBlocksToLoad = function () {\n if (!this.active) {\n return;\n }\n this.printCacheStatus();\n if (this.maxConcurrentRequests != null && this.activeBlockLoadsCount >= this.maxConcurrentRequests) {\n this.logger.log(\"checkBlockToLoad: max loads exceeded\");\n return;\n }\n var loadAvailability = this.maxConcurrentRequests !== undefined ? this.maxConcurrentRequests - this.activeBlockLoadsCount : undefined;\n var blocksToLoad = this.blocks.filter(function (block) { return (block.getState() === RowNodeBlock.STATE_WAITING_TO_LOAD); }).slice(0, loadAvailability);\n this.activeBlockLoadsCount += blocksToLoad.length;\n blocksToLoad.forEach(function (block) { return block.load(); });\n this.printCacheStatus();\n };\n RowNodeBlockLoader.prototype.getBlockState = function () {\n var result = {};\n this.blocks.forEach(function (block) {\n var _a = block.getBlockStateJson(), id = _a.id, state = _a.state;\n result[id] = state;\n });\n return result;\n };\n RowNodeBlockLoader.prototype.printCacheStatus = function () {\n if (this.logger.isLogging()) {\n this.logger.log(\"printCacheStatus: activePageLoadsCount = \" + this.activeBlockLoadsCount + \",\"\n + (\" blocks = \" + JSON.stringify(this.getBlockState())));\n }\n };\n RowNodeBlockLoader.prototype.isLoading = function () {\n return this.activeBlockLoadsCount > 0;\n };\n var RowNodeBlockLoader_1;\n RowNodeBlockLoader.BLOCK_LOADER_FINISHED_EVENT = 'blockLoaderFinished';\n __decorate([\n PostConstruct\n ], RowNodeBlockLoader.prototype, \"postConstruct\", null);\n __decorate([\n __param(0, Qualifier('loggerFactory'))\n ], RowNodeBlockLoader.prototype, \"setBeans\", null);\n RowNodeBlockLoader = RowNodeBlockLoader_1 = __decorate([\n Bean('rowNodeBlockLoader')\n ], RowNodeBlockLoader);\n return RowNodeBlockLoader;\n}(BeanStub));\nexport { RowNodeBlockLoader };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../context/beanStub\";\nimport { Events } from \"../events\";\nimport { Autowired, Bean, PostConstruct } from \"../context/context\";\nimport { missing, exists } from \"../utils/generic\";\nimport { isNumeric } from \"../utils/number\";\nvar PaginationProxy = /** @class */ (function (_super) {\n __extends(PaginationProxy, _super);\n function PaginationProxy() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.currentPage = 0;\n _this.topDisplayedRowIndex = 0;\n _this.bottomDisplayedRowIndex = 0;\n _this.pixelOffset = 0;\n _this.masterRowCount = 0;\n return _this;\n }\n PaginationProxy.prototype.postConstruct = function () {\n this.active = this.gridOptionsWrapper.isPagination();\n this.paginateChildRows = this.gridOptionsWrapper.isPaginateChildRows();\n this.addManagedListener(this.eventService, Events.EVENT_MODEL_UPDATED, this.onModelUpdated.bind(this));\n this.addManagedListener(this.gridOptionsWrapper, 'paginationPageSize', this.onPaginationPageSizeChanged.bind(this));\n this.onModelUpdated();\n };\n PaginationProxy.prototype.ensureRowHeightsValid = function (startPixel, endPixel, startLimitIndex, endLimitIndex) {\n var res = this.rowModel.ensureRowHeightsValid(startPixel, endPixel, this.getPageFirstRow(), this.getPageLastRow());\n if (res) {\n this.calculatePages();\n }\n return res;\n };\n PaginationProxy.prototype.onModelUpdated = function (modelUpdatedEvent) {\n this.calculatePages();\n var paginationChangedEvent = {\n type: Events.EVENT_PAGINATION_CHANGED,\n animate: modelUpdatedEvent ? modelUpdatedEvent.animate : false,\n newData: modelUpdatedEvent ? modelUpdatedEvent.newData : false,\n newPage: modelUpdatedEvent ? modelUpdatedEvent.newPage : false,\n keepRenderedRows: modelUpdatedEvent ? modelUpdatedEvent.keepRenderedRows : false\n };\n this.eventService.dispatchEvent(paginationChangedEvent);\n };\n PaginationProxy.prototype.onPaginationPageSizeChanged = function () {\n this.calculatePages();\n var paginationChangedEvent = {\n type: Events.EVENT_PAGINATION_CHANGED,\n animate: false,\n newData: false,\n newPage: false,\n // important to keep rendered rows, otherwise every time grid is resized,\n // we would destroy all the rows.\n keepRenderedRows: true\n };\n this.eventService.dispatchEvent(paginationChangedEvent);\n };\n PaginationProxy.prototype.goToPage = function (page) {\n if (!this.active || this.currentPage === page) {\n return;\n }\n this.currentPage = page;\n var event = {\n type: Events.EVENT_MODEL_UPDATED,\n animate: false,\n keepRenderedRows: false,\n newData: false,\n newPage: true\n };\n this.onModelUpdated(event);\n };\n PaginationProxy.prototype.getPixelOffset = function () {\n return this.pixelOffset;\n };\n PaginationProxy.prototype.getRow = function (index) {\n return this.rowModel.getRow(index);\n };\n PaginationProxy.prototype.getRowNode = function (id) {\n return this.rowModel.getRowNode(id);\n };\n PaginationProxy.prototype.getRowIndexAtPixel = function (pixel) {\n return this.rowModel.getRowIndexAtPixel(pixel);\n };\n PaginationProxy.prototype.getCurrentPageHeight = function () {\n if (missing(this.topRowBounds) || missing(this.bottomRowBounds)) {\n return 0;\n }\n return Math.max(this.bottomRowBounds.rowTop + this.bottomRowBounds.rowHeight - this.topRowBounds.rowTop, 0);\n };\n PaginationProxy.prototype.getCurrentPagePixelRange = function () {\n var pageFirstPixel = this.topRowBounds ? this.topRowBounds.rowTop : 0;\n var pageLastPixel = this.bottomRowBounds ? this.bottomRowBounds.rowTop + this.bottomRowBounds.rowHeight : 0;\n return { pageFirstPixel: pageFirstPixel, pageLastPixel: pageLastPixel };\n };\n PaginationProxy.prototype.isRowPresent = function (rowNode) {\n if (!this.rowModel.isRowPresent(rowNode)) {\n return false;\n }\n var nodeIsInPage = rowNode.rowIndex >= this.topDisplayedRowIndex && rowNode.rowIndex <= this.bottomDisplayedRowIndex;\n return nodeIsInPage;\n };\n PaginationProxy.prototype.isEmpty = function () {\n return this.rowModel.isEmpty();\n };\n PaginationProxy.prototype.isRowsToRender = function () {\n return this.rowModel.isRowsToRender();\n };\n PaginationProxy.prototype.getNodesInRangeForSelection = function (firstInRange, lastInRange) {\n return this.rowModel.getNodesInRangeForSelection(firstInRange, lastInRange);\n };\n PaginationProxy.prototype.forEachNode = function (callback) {\n return this.rowModel.forEachNode(callback);\n };\n PaginationProxy.prototype.getType = function () {\n return this.rowModel.getType();\n };\n PaginationProxy.prototype.getRowBounds = function (index) {\n var res = this.rowModel.getRowBounds(index);\n res.rowIndex = index;\n return res;\n };\n PaginationProxy.prototype.getPageFirstRow = function () {\n return this.topRowBounds ? this.topRowBounds.rowIndex : -1;\n };\n PaginationProxy.prototype.getPageLastRow = function () {\n return this.bottomRowBounds ? this.bottomRowBounds.rowIndex : -1;\n };\n PaginationProxy.prototype.getRowCount = function () {\n return this.rowModel.getRowCount();\n };\n PaginationProxy.prototype.getPageForIndex = function (index) {\n return Math.floor(index / this.pageSize);\n };\n PaginationProxy.prototype.goToPageWithIndex = function (index) {\n if (!this.active) {\n return;\n }\n var pageNumber = this.getPageForIndex(index);\n this.goToPage(pageNumber);\n };\n PaginationProxy.prototype.isRowInPage = function (row) {\n if (!this.active) {\n return true;\n }\n var rowPage = this.getPageForIndex(row.rowIndex);\n return rowPage === this.currentPage;\n };\n PaginationProxy.prototype.isLastPageFound = function () {\n return this.rowModel.isLastRowIndexKnown();\n };\n PaginationProxy.prototype.getCurrentPage = function () {\n return this.currentPage;\n };\n PaginationProxy.prototype.goToNextPage = function () {\n this.goToPage(this.currentPage + 1);\n };\n PaginationProxy.prototype.goToPreviousPage = function () {\n this.goToPage(this.currentPage - 1);\n };\n PaginationProxy.prototype.goToFirstPage = function () {\n this.goToPage(0);\n };\n PaginationProxy.prototype.goToLastPage = function () {\n var rowCount = this.rowModel.getRowCount();\n var lastPage = Math.floor(rowCount / this.pageSize);\n this.goToPage(lastPage);\n };\n PaginationProxy.prototype.getPageSize = function () {\n return this.pageSize;\n };\n PaginationProxy.prototype.getTotalPages = function () {\n return this.totalPages;\n };\n PaginationProxy.prototype.setPageSize = function () {\n // show put this into super class\n this.pageSize = this.gridOptionsWrapper.getPaginationPageSize();\n if (this.pageSize == null || this.pageSize < 1) {\n this.pageSize = 100;\n }\n };\n PaginationProxy.prototype.calculatePages = function () {\n if (this.active) {\n this.setPageSize();\n if (this.paginateChildRows) {\n this.calculatePagesAllRows();\n }\n else {\n this.calculatePagesMasterRowsOnly();\n }\n }\n else {\n this.calculatedPagesNotActive();\n }\n this.topRowBounds = this.rowModel.getRowBounds(this.topDisplayedRowIndex);\n if (this.topRowBounds) {\n this.topRowBounds.rowIndex = this.topDisplayedRowIndex;\n }\n this.bottomRowBounds = this.rowModel.getRowBounds(this.bottomDisplayedRowIndex);\n if (this.bottomRowBounds) {\n this.bottomRowBounds.rowIndex = this.bottomDisplayedRowIndex;\n }\n this.setPixelOffset(exists(this.topRowBounds) ? this.topRowBounds.rowTop : 0);\n };\n PaginationProxy.prototype.setPixelOffset = function (value) {\n if (this.pixelOffset === value) {\n return;\n }\n this.pixelOffset = value;\n this.eventService.dispatchEvent({ type: Events.EVENT_PAGINATION_PIXEL_OFFSET_CHANGED });\n };\n PaginationProxy.prototype.setZeroRows = function () {\n this.masterRowCount = 0;\n this.topDisplayedRowIndex = 0;\n this.bottomDisplayedRowIndex = -1;\n this.currentPage = 0;\n this.totalPages = 0;\n };\n PaginationProxy.prototype.calculatePagesMasterRowsOnly = function () {\n // const csrm = this.rowModel;\n // const rootNode = csrm.getRootNode();\n // const masterRows = rootNode.childrenAfterSort;\n this.masterRowCount = this.rowModel.getTopLevelRowCount();\n // we say <=0 (rather than =0) as viewport returns -1 when no rows\n if (this.masterRowCount <= 0) {\n this.setZeroRows();\n return;\n }\n var masterLastRowIndex = this.masterRowCount - 1;\n this.totalPages = Math.floor((masterLastRowIndex) / this.pageSize) + 1;\n if (this.currentPage >= this.totalPages) {\n this.currentPage = this.totalPages - 1;\n }\n if (!isNumeric(this.currentPage) || this.currentPage < 0) {\n this.currentPage = 0;\n }\n var masterPageStartIndex = this.pageSize * this.currentPage;\n var masterPageEndIndex = (this.pageSize * (this.currentPage + 1)) - 1;\n if (masterPageEndIndex > masterLastRowIndex) {\n masterPageEndIndex = masterLastRowIndex;\n }\n this.topDisplayedRowIndex = this.rowModel.getTopLevelRowDisplayedIndex(masterPageStartIndex);\n // masterRows[masterPageStartIndex].rowIndex;\n if (masterPageEndIndex === masterLastRowIndex) {\n // if showing the last master row, then we want to show the very last row of the model\n this.bottomDisplayedRowIndex = this.rowModel.getRowCount() - 1;\n }\n else {\n var firstIndexNotToShow = this.rowModel.getTopLevelRowDisplayedIndex(masterPageEndIndex + 1);\n //masterRows[masterPageEndIndex + 1].rowIndex;\n // this gets the index of the last child - eg current row is open, we want to display all children,\n // the index of the last child is one less than the index of the next parent row.\n this.bottomDisplayedRowIndex = firstIndexNotToShow - 1;\n }\n };\n PaginationProxy.prototype.getMasterRowCount = function () {\n return this.masterRowCount;\n };\n PaginationProxy.prototype.calculatePagesAllRows = function () {\n this.masterRowCount = this.rowModel.getRowCount();\n if (this.masterRowCount === 0) {\n this.setZeroRows();\n return;\n }\n var maxRowIndex = this.masterRowCount - 1;\n this.totalPages = Math.floor((maxRowIndex) / this.pageSize) + 1;\n if (this.currentPage >= this.totalPages) {\n this.currentPage = this.totalPages - 1;\n }\n if (!isNumeric(this.currentPage) || this.currentPage < 0) {\n this.currentPage = 0;\n }\n this.topDisplayedRowIndex = this.pageSize * this.currentPage;\n this.bottomDisplayedRowIndex = (this.pageSize * (this.currentPage + 1)) - 1;\n if (this.bottomDisplayedRowIndex > maxRowIndex) {\n this.bottomDisplayedRowIndex = maxRowIndex;\n }\n };\n PaginationProxy.prototype.calculatedPagesNotActive = function () {\n this.pageSize = this.rowModel.getRowCount();\n this.totalPages = 1;\n this.currentPage = 0;\n this.topDisplayedRowIndex = 0;\n this.bottomDisplayedRowIndex = this.rowModel.getRowCount() - 1;\n };\n __decorate([\n Autowired('rowModel')\n ], PaginationProxy.prototype, \"rowModel\", void 0);\n __decorate([\n PostConstruct\n ], PaginationProxy.prototype, \"postConstruct\", null);\n PaginationProxy = __decorate([\n Bean('paginationProxy')\n ], PaginationProxy);\n return PaginationProxy;\n}(BeanStub));\nexport { PaginationProxy };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nvar StylingService = /** @class */ (function (_super) {\n __extends(StylingService, _super);\n function StylingService() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n StylingService.prototype.processAllCellClasses = function (colDef, params, onApplicableClass, onNotApplicableClass) {\n this.processClassRules(colDef.cellClassRules, params, onApplicableClass, onNotApplicableClass);\n this.processStaticCellClasses(colDef, params, onApplicableClass);\n };\n StylingService.prototype.processClassRules = function (classRules, params, onApplicableClass, onNotApplicableClass) {\n if (classRules == null) {\n return;\n }\n var classNames = Object.keys(classRules);\n var classesToApply = {};\n var classesToRemove = {};\n var _loop_1 = function (i) {\n var className = classNames[i];\n var rule = classRules[className];\n var resultOfRule;\n if (typeof rule === 'string') {\n resultOfRule = this_1.expressionService.evaluate(rule, params);\n }\n else if (typeof rule === 'function') {\n resultOfRule = rule(params);\n }\n // in case className = 'my-class1 my-class2', we need to split into individual class names\n className.split(' ').forEach(function (singleClass) {\n if (singleClass == null || singleClass.trim() == '') {\n return;\n }\n resultOfRule ? classesToApply[singleClass] = true : classesToRemove[singleClass] = true;\n });\n };\n var this_1 = this;\n for (var i = 0; i < classNames.length; i++) {\n _loop_1(i);\n }\n // we remove all classes first, then add all classes second,\n // in case a class appears in more than one rule, this means it will be added\n // if appears in at least one truthy rule\n if (onNotApplicableClass) {\n Object.keys(classesToRemove).forEach(onNotApplicableClass);\n }\n Object.keys(classesToApply).forEach(onApplicableClass);\n };\n StylingService.prototype.getStaticCellClasses = function (colDef, params) {\n var cellClass = colDef.cellClass;\n if (!cellClass) {\n return [];\n }\n var classOrClasses;\n if (typeof cellClass === 'function') {\n var cellClassFunc = cellClass;\n classOrClasses = cellClassFunc(params);\n }\n else {\n classOrClasses = cellClass;\n }\n if (typeof classOrClasses === 'string') {\n classOrClasses = [classOrClasses];\n }\n return classOrClasses || [];\n };\n StylingService.prototype.processStaticCellClasses = function (colDef, params, onApplicableClass) {\n var classOrClasses = this.getStaticCellClasses(colDef, params);\n classOrClasses.forEach(function (cssClassItem) {\n onApplicableClass(cssClassItem);\n });\n };\n __decorate([\n Autowired('expressionService')\n ], StylingService.prototype, \"expressionService\", void 0);\n StylingService = __decorate([\n Bean('stylingService')\n ], StylingService);\n return StylingService;\n}(BeanStub));\nexport { StylingService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { AgCheckbox } from './agCheckbox';\nimport { Events } from '../eventKeys';\nvar AgRadioButton = /** @class */ (function (_super) {\n __extends(AgRadioButton, _super);\n function AgRadioButton(config) {\n return _super.call(this, config, 'ag-radio-button', 'radio') || this;\n }\n AgRadioButton.prototype.isSelected = function () {\n return this.eInput.checked;\n };\n AgRadioButton.prototype.toggle = function () {\n if (this.eInput.disabled) {\n return;\n }\n // do not allow an active radio button to be deselected\n if (!this.isSelected()) {\n this.setValue(true);\n }\n };\n AgRadioButton.prototype.addInputListeners = function () {\n _super.prototype.addInputListeners.call(this);\n this.addManagedListener(this.eventService, Events.EVENT_CHECKBOX_CHANGED, this.onChange.bind(this));\n };\n /**\n * This ensures that if another radio button in the same named group is selected, we deselect this radio button.\n * By default the browser does this for you, but we are managing classes ourselves in order to ensure input\n * elements are styled correctly in IE11, and the DOM 'changed' event is only fired when a button is selected,\n * not deselected, so we need to use our own event.\n */\n AgRadioButton.prototype.onChange = function (event) {\n if (event.selected &&\n event.name &&\n this.eInput.name &&\n this.eInput.name === event.name &&\n event.id &&\n this.eInput.id !== event.id) {\n this.setValue(false, true);\n }\n };\n return AgRadioButton;\n}(AgCheckbox));\nexport { AgRadioButton };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { AgCheckbox } from './agCheckbox';\nvar AgToggleButton = /** @class */ (function (_super) {\n __extends(AgToggleButton, _super);\n function AgToggleButton(config) {\n return _super.call(this, config, 'ag-toggle-button') || this;\n }\n AgToggleButton.prototype.setValue = function (value, silent) {\n _super.prototype.setValue.call(this, value, silent);\n this.addOrRemoveCssClass('ag-selected', this.getValue());\n return this;\n };\n return AgToggleButton;\n}(AgCheckbox));\nexport { AgToggleButton };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { AgAbstractInputField } from './agAbstractInputField';\nimport { exists } from '../utils/generic';\nvar AgInputTextField = /** @class */ (function (_super) {\n __extends(AgInputTextField, _super);\n function AgInputTextField(config, className, inputType) {\n if (className === void 0) { className = 'ag-text-field'; }\n if (inputType === void 0) { inputType = 'text'; }\n return _super.call(this, config, className, inputType) || this;\n }\n AgInputTextField.prototype.postConstruct = function () {\n _super.prototype.postConstruct.call(this);\n if (this.config.allowedCharPattern) {\n this.preventDisallowedCharacters();\n }\n };\n AgInputTextField.prototype.setValue = function (value, silent) {\n var ret = _super.prototype.setValue.call(this, value, silent);\n if (this.eInput.value !== value) {\n this.eInput.value = exists(value) ? value : '';\n }\n return ret;\n };\n AgInputTextField.prototype.preventDisallowedCharacters = function () {\n var pattern = new RegExp(\"[\" + this.config.allowedCharPattern + \"]\");\n var preventDisallowedCharacters = function (event) {\n if (event.key && !pattern.test(event.key)) {\n event.preventDefault();\n }\n };\n this.addManagedListener(this.eInput, 'keypress', preventDisallowedCharacters);\n this.addManagedListener(this.eInput, 'paste', function (e) {\n var _a;\n var text = (_a = e.clipboardData) === null || _a === void 0 ? void 0 : _a.getData('text');\n if (text && text.split('').some(function (c) { return !pattern.test(c); })) {\n e.preventDefault();\n }\n });\n };\n return AgInputTextField;\n}(AgAbstractInputField));\nexport { AgInputTextField };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { AgAbstractInputField } from \"./agAbstractInputField\";\nvar AgInputTextArea = /** @class */ (function (_super) {\n __extends(AgInputTextArea, _super);\n function AgInputTextArea(config) {\n return _super.call(this, config, 'ag-text-area', null, 'textarea') || this;\n }\n AgInputTextArea.prototype.setValue = function (value, silent) {\n var ret = _super.prototype.setValue.call(this, value, silent);\n this.eInput.value = value;\n return ret;\n };\n AgInputTextArea.prototype.setCols = function (cols) {\n this.eInput.cols = cols;\n return this;\n };\n AgInputTextArea.prototype.setRows = function (rows) {\n this.eInput.rows = rows;\n return this;\n };\n return AgInputTextArea;\n}(AgAbstractInputField));\nexport { AgInputTextArea };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { AgInputTextField } from \"./agInputTextField\";\nimport { addOrRemoveAttribute } from '../utils/dom';\nvar AgInputNumberField = /** @class */ (function (_super) {\n __extends(AgInputNumberField, _super);\n function AgInputNumberField(config) {\n return _super.call(this, config, 'ag-number-field', 'number') || this;\n }\n AgInputNumberField.prototype.postConstruct = function () {\n var _this = this;\n _super.prototype.postConstruct.call(this);\n this.addManagedListener(this.eInput, 'blur', function () {\n var floatedValue = parseFloat(_this.eInput.value);\n var value = isNaN(floatedValue) ? '' : _this.normalizeValue(floatedValue.toString());\n if (_this.value !== value) {\n _this.setValue(value);\n }\n });\n this.addManagedListener(this.eInput, 'wheel', this.onWheel.bind(this));\n this.eInput.step = 'any';\n };\n AgInputNumberField.prototype.onWheel = function (e) {\n // Prevent default scroll events from incrementing / decrementing the input, since its inconsistent between browsers\n if (document.activeElement === this.eInput) {\n e.preventDefault();\n }\n };\n AgInputNumberField.prototype.normalizeValue = function (value) {\n if (value === '') {\n return '';\n }\n if (this.precision) {\n value = this.adjustPrecision(value);\n }\n var val = parseFloat(value);\n if (this.min != null && val < this.min) {\n value = this.min.toString();\n }\n else if (this.max != null && val > this.max) {\n value = this.max.toString();\n }\n return value;\n };\n AgInputNumberField.prototype.adjustPrecision = function (value) {\n if (this.precision) {\n var floatString = parseFloat(value).toFixed(this.precision);\n value = parseFloat(floatString).toString();\n }\n return value;\n };\n AgInputNumberField.prototype.setMin = function (min) {\n if (this.min === min) {\n return this;\n }\n this.min = min;\n addOrRemoveAttribute(this.eInput, 'min', min);\n return this;\n };\n AgInputNumberField.prototype.setMax = function (max) {\n if (this.max === max) {\n return this;\n }\n this.max = max;\n addOrRemoveAttribute(this.eInput, 'max', max);\n return this;\n };\n AgInputNumberField.prototype.setPrecision = function (precision) {\n this.precision = precision;\n return this;\n };\n AgInputNumberField.prototype.setStep = function (step) {\n if (this.step === step) {\n return this;\n }\n this.step = step;\n addOrRemoveAttribute(this.eInput, 'step', step);\n return this;\n };\n AgInputNumberField.prototype.setValue = function (value, silent) {\n value = this.adjustPrecision(value);\n var normalizedValue = this.normalizeValue(value);\n if (value != normalizedValue) {\n return this;\n }\n return _super.prototype.setValue.call(this, value, silent);\n };\n return AgInputNumberField;\n}(AgInputTextField));\nexport { AgInputNumberField };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { AgAbstractInputField } from \"./agAbstractInputField\";\nvar AgInputRange = /** @class */ (function (_super) {\n __extends(AgInputRange, _super);\n function AgInputRange(config) {\n return _super.call(this, config, 'ag-range-field', 'range') || this;\n }\n AgInputRange.prototype.postConstruct = function () {\n _super.prototype.postConstruct.call(this);\n var _a = this.config, min = _a.min, max = _a.max, step = _a.step;\n if (min != null) {\n this.setMinValue(min);\n }\n if (max != null) {\n this.setMaxValue(max);\n }\n this.setStep(step || 1);\n };\n AgInputRange.prototype.addInputListeners = function () {\n var _this = this;\n this.addManagedListener(this.eInput, 'input', function (e) {\n var value = e.target.value;\n _this.setValue(value);\n });\n };\n AgInputRange.prototype.setMinValue = function (value) {\n this.min = value;\n this.eInput.setAttribute('min', value.toString());\n return this;\n };\n AgInputRange.prototype.setMaxValue = function (value) {\n this.max = value;\n this.eInput.setAttribute('max', value.toString());\n return this;\n };\n AgInputRange.prototype.setStep = function (value) {\n this.eInput.setAttribute('step', value.toString());\n return this;\n };\n AgInputRange.prototype.setValue = function (value, silent) {\n if (this.min != null) {\n value = Math.max(parseFloat(value), this.min).toString();\n }\n if (this.max != null) {\n value = Math.min(parseFloat(value), this.max).toString();\n }\n var ret = _super.prototype.setValue.call(this, value, silent);\n this.eInput.value = value;\n return ret;\n };\n return AgInputRange;\n}(AgAbstractInputField));\nexport { AgInputRange };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { RefSelector } from \"./componentAnnotations\";\nimport { AgAbstractLabel } from \"./agAbstractLabel\";\nimport { AgAbstractField } from \"./agAbstractField\";\nimport { PostConstruct } from \"../context/context\";\nvar AgSlider = /** @class */ (function (_super) {\n __extends(AgSlider, _super);\n function AgSlider(config) {\n var _this = _super.call(this, config, AgSlider.TEMPLATE) || this;\n _this.labelAlignment = 'top';\n return _this;\n }\n AgSlider.prototype.init = function () {\n this.eSlider.addCssClass('ag-slider-field');\n };\n AgSlider.prototype.onValueChange = function (callbackFn) {\n var _this = this;\n var eventChanged = AgAbstractField.EVENT_CHANGED;\n this.addManagedListener(this.eText, eventChanged, function () {\n var textValue = parseFloat(_this.eText.getValue());\n _this.eSlider.setValue(textValue.toString(), true);\n callbackFn(textValue || 0);\n });\n this.addManagedListener(this.eSlider, eventChanged, function () {\n var sliderValue = _this.eSlider.getValue();\n _this.eText.setValue(sliderValue, true);\n callbackFn(parseFloat(sliderValue));\n });\n return this;\n };\n AgSlider.prototype.setSliderWidth = function (width) {\n this.eSlider.setWidth(width);\n return this;\n };\n AgSlider.prototype.setTextFieldWidth = function (width) {\n this.eText.setWidth(width);\n return this;\n };\n AgSlider.prototype.setMinValue = function (minValue) {\n this.eSlider.setMinValue(minValue);\n this.eText.setMin(minValue);\n return this;\n };\n AgSlider.prototype.setMaxValue = function (maxValue) {\n this.eSlider.setMaxValue(maxValue);\n this.eText.setMax(maxValue);\n return this;\n };\n AgSlider.prototype.getValue = function () {\n return this.eText.getValue();\n };\n AgSlider.prototype.setValue = function (value) {\n if (this.getValue() === value) {\n return this;\n }\n this.eText.setValue(value, true);\n this.eSlider.setValue(value, true);\n this.dispatchEvent({ type: AgAbstractField.EVENT_CHANGED });\n return this;\n };\n AgSlider.prototype.setStep = function (step) {\n this.eSlider.setStep(step);\n this.eText.setStep(step);\n return this;\n };\n AgSlider.TEMPLATE = \"
\\n \\n
\\n \\n \\n
\\n
\";\n __decorate([\n RefSelector('eLabel')\n ], AgSlider.prototype, \"eLabel\", void 0);\n __decorate([\n RefSelector('eSlider')\n ], AgSlider.prototype, \"eSlider\", void 0);\n __decorate([\n RefSelector('eText')\n ], AgSlider.prototype, \"eText\", void 0);\n __decorate([\n PostConstruct\n ], AgSlider.prototype, \"init\", null);\n return AgSlider;\n}(AgAbstractLabel));\nexport { AgSlider };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { AgAbstractLabel } from \"./agAbstractLabel\";\nimport { RefSelector } from \"./componentAnnotations\";\nimport { Autowired } from \"../context/context\";\nimport { AgAbstractField } from \"./agAbstractField\";\nimport { exists } from \"../utils/generic\";\nimport { setFixedWidth } from \"../utils/dom\";\nvar AgAngleSelect = /** @class */ (function (_super) {\n __extends(AgAngleSelect, _super);\n function AgAngleSelect(config) {\n var _this = _super.call(this, config, AgAngleSelect.TEMPLATE) || this;\n _this.radius = 0;\n _this.offsetX = 0;\n _this.offsetY = 0;\n return _this;\n }\n AgAngleSelect.prototype.postConstruct = function () {\n var _this = this;\n _super.prototype.postConstruct.call(this);\n this.dragListener = {\n eElement: this.eParentCircle,\n dragStartPixels: 0,\n onDragStart: function (e) {\n _this.parentCircleRect = _this.eParentCircle.getBoundingClientRect();\n },\n onDragging: function (e) { return _this.calculateAngleDrag(e); },\n onDragStop: function () { }\n };\n this.dragService.addDragSource(this.dragListener);\n this.eAngleValue\n .setLabel('')\n .setLabelWidth(5)\n .setInputWidth(45)\n .setMin(0)\n .setMax(360)\n .setValue(\"\" + this.degrees)\n .onValueChange(function (value) {\n if (value == null || value === '') {\n value = '0';\n }\n value = _this.eAngleValue.normalizeValue(value);\n var floatValue = parseFloat(value);\n if (floatValue > 180) {\n floatValue = floatValue - 360;\n }\n _this.setValue(floatValue);\n });\n this.updateNumberInput();\n if (exists(this.getValue())) {\n this.eAngleValue.setValue(this.normalizeNegativeValue(this.getValue()).toString());\n }\n this.addManagedListener(this, AgAbstractField.EVENT_CHANGED, function () {\n var eDocument = _this.gridOptionsWrapper.getDocument();\n if (_this.eAngleValue.getInputElement().contains(eDocument.activeElement)) {\n return;\n }\n _this.updateNumberInput();\n });\n };\n AgAngleSelect.prototype.updateNumberInput = function () {\n var normalizedValue = this.normalizeNegativeValue(this.getValue());\n this.eAngleValue.setValue(normalizedValue.toString());\n };\n AgAngleSelect.prototype.positionChildCircle = function (radians) {\n var rect = this.parentCircleRect || { width: 24, height: 24 };\n var eChildCircle = this.eChildCircle;\n var centerX = rect.width / 2;\n var centerY = rect.height / 2;\n eChildCircle.style.left = centerX + Math.cos(radians) * 8 + \"px\";\n eChildCircle.style.top = centerY + Math.sin(radians) * 8 + \"px\";\n };\n AgAngleSelect.prototype.calculatePolar = function () {\n var x = this.offsetX;\n var y = this.offsetY;\n var radians = Math.atan2(y, x);\n this.degrees = this.toDegrees(radians);\n this.radius = Math.sqrt((x * x) + (y * y));\n this.positionChildCircle(radians);\n };\n AgAngleSelect.prototype.calculateCartesian = function () {\n var radians = this.toRadians(this.getValue());\n var radius = this.getRadius();\n this\n .setOffsetX(Math.cos(radians) * radius)\n .setOffsetY(Math.sin(radians) * radius);\n };\n AgAngleSelect.prototype.setOffsetX = function (offset) {\n if (this.offsetX !== offset) {\n this.offsetX = offset;\n this.calculatePolar();\n }\n return this;\n };\n AgAngleSelect.prototype.setOffsetY = function (offset) {\n if (this.offsetY !== offset) {\n this.offsetY = offset;\n this.calculatePolar();\n }\n return this;\n };\n AgAngleSelect.prototype.calculateAngleDrag = function (e) {\n var rect = this.parentCircleRect;\n var centerX = rect.width / 2;\n var centerY = rect.height / 2;\n var x = e.clientX - rect.left;\n var y = e.clientY - rect.top;\n var dx = x - centerX;\n var dy = y - centerY;\n var radians = Math.atan2(dy, dx);\n this.setValue(radians, true);\n };\n AgAngleSelect.prototype.toDegrees = function (radians) {\n return radians / Math.PI * 180;\n };\n AgAngleSelect.prototype.toRadians = function (degrees) {\n return degrees / 180 * Math.PI;\n };\n AgAngleSelect.prototype.normalizeNegativeValue = function (degrees) {\n return degrees < 0 ? 360 + degrees : degrees;\n };\n AgAngleSelect.prototype.normalizeAngle180 = function (radians) {\n radians %= Math.PI * 2;\n if (radians < -Math.PI) {\n radians += Math.PI * 2;\n }\n else if (radians >= Math.PI) {\n radians -= Math.PI * 2;\n }\n return radians;\n };\n AgAngleSelect.prototype.getRadius = function () {\n return this.radius;\n };\n AgAngleSelect.prototype.setRadius = function (r) {\n if (this.radius === r) {\n return this;\n }\n this.radius = r;\n this.calculateCartesian();\n return this;\n };\n AgAngleSelect.prototype.onValueChange = function (callbackFn) {\n var _this = this;\n this.addManagedListener(this, AgAbstractField.EVENT_CHANGED, function () {\n callbackFn(_this.degrees);\n });\n return this;\n };\n AgAngleSelect.prototype.getValue = function (radians) {\n return radians ? this.toRadians(this.degrees) : this.degrees;\n };\n AgAngleSelect.prototype.setValue = function (degrees, radians) {\n var radiansValue;\n if (!radians) {\n radiansValue = this.normalizeAngle180(this.toRadians(degrees));\n }\n else {\n radiansValue = degrees;\n }\n degrees = this.toDegrees(radiansValue);\n if (this.degrees !== degrees) {\n this.degrees = Math.floor(degrees);\n this.calculateCartesian();\n this.positionChildCircle(radiansValue);\n this.dispatchEvent({ type: AgAbstractField.EVENT_CHANGED });\n }\n return this;\n };\n AgAngleSelect.prototype.setWidth = function (width) {\n setFixedWidth(this.getGui(), width);\n return this;\n };\n AgAngleSelect.prototype.setDisabled = function (disabled) {\n _super.prototype.setDisabled.call(this, disabled);\n this.eAngleValue.setDisabled(disabled);\n return this;\n };\n AgAngleSelect.prototype.destroy = function () {\n this.dragService.removeDragSource(this.dragListener);\n _super.prototype.destroy.call(this);\n };\n AgAngleSelect.TEMPLATE = \"
\\n
\\n
\\n
\\n
\\n
\\n
\\n
\\n \\n
\\n
\";\n __decorate([\n RefSelector('eLabel')\n ], AgAngleSelect.prototype, \"eLabel\", void 0);\n __decorate([\n RefSelector('eParentCircle')\n ], AgAngleSelect.prototype, \"eParentCircle\", void 0);\n __decorate([\n RefSelector('eChildCircle')\n ], AgAngleSelect.prototype, \"eChildCircle\", void 0);\n __decorate([\n RefSelector('eAngleValue')\n ], AgAngleSelect.prototype, \"eAngleValue\", void 0);\n __decorate([\n Autowired('dragService')\n ], AgAngleSelect.prototype, \"dragService\", void 0);\n return AgAngleSelect;\n}(AgAbstractLabel));\nexport { AgAngleSelect };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nimport { Component } from \"./component\";\nimport { Color } from \"../utils\";\nimport { RefSelector } from \"./componentAnnotations\";\nimport { PostConstruct } from \"../context/context\";\nimport { exists } from \"../utils/generic\";\nvar AgColorPanel = /** @class */ (function (_super) {\n __extends(AgColorPanel, _super);\n function AgColorPanel(config) {\n var _this = _super.call(this, AgColorPanel.TEMPLATE) || this;\n _this.H = 1; // in the [0, 1] range\n _this.S = 1; // in the [0, 1] range\n _this.B = 1; // in the [0, 1] range\n _this.A = 1; // in the [0, 1] range\n _this.isSpectrumDragging = false;\n _this.isSpectrumHueDragging = false;\n _this.isSpectrumAlphaDragging = false;\n _this.colorChanged = false;\n _this.picker = config.picker;\n return _this;\n }\n AgColorPanel.prototype.postConstruct = function () {\n var eGui = this.getGui();\n this.initRecentColors();\n this.addManagedListener(this.spectrumVal, 'mousedown', this.onSpectrumDraggerDown.bind(this));\n this.addManagedListener(eGui, 'mousemove', this.onSpectrumDraggerMove.bind(this));\n this.addManagedListener(this.spectrumHue, 'mousedown', this.onSpectrumHueDown.bind(this));\n this.addManagedListener(eGui, 'mousemove', this.onSpectrumHueMove.bind(this));\n this.addManagedListener(this.spectrumAlpha, 'mousedown', this.onSpectrumAlphaDown.bind(this));\n this.addManagedListener(eGui, 'mousemove', this.onSpectrumAlphaMove.bind(this));\n // Listening to `mouseup` on the document on purpose. The user might release the mouse button\n // outside the UI control. When the mouse returns back to the control's area, the dragging\n // of the thumb is not expected and seen as a bug.\n this.addManagedListener(document, 'mouseup', this.onMouseUp.bind(this));\n this.addManagedListener(this.recentColors, 'click', this.onRecentColorClick.bind(this));\n };\n AgColorPanel.prototype.refreshSpectrumRect = function () {\n return this.spectrumValRect = this.spectrumVal.getBoundingClientRect();\n };\n AgColorPanel.prototype.refreshHueRect = function () {\n return this.spectrumHueRect = this.spectrumHue.getBoundingClientRect();\n };\n AgColorPanel.prototype.refreshAlphaRect = function () {\n return this.spectrumAlphaRect = this.spectrumAlpha.getBoundingClientRect();\n };\n AgColorPanel.prototype.onSpectrumDraggerDown = function (e) {\n this.refreshSpectrumRect();\n this.isSpectrumDragging = true;\n this.moveDragger(e);\n };\n AgColorPanel.prototype.onSpectrumDraggerMove = function (e) {\n if (this.isSpectrumDragging) {\n this.moveDragger(e);\n }\n };\n AgColorPanel.prototype.onSpectrumHueDown = function (e) {\n this.refreshHueRect();\n this.isSpectrumHueDragging = true;\n this.moveHueSlider(e);\n };\n AgColorPanel.prototype.onSpectrumHueMove = function (e) {\n if (this.isSpectrumHueDragging) {\n this.moveHueSlider(e);\n }\n };\n AgColorPanel.prototype.onSpectrumAlphaDown = function (e) {\n this.refreshAlphaRect();\n this.isSpectrumAlphaDragging = true;\n this.moveAlphaSlider(e);\n };\n AgColorPanel.prototype.onSpectrumAlphaMove = function (e) {\n if (this.isSpectrumAlphaDragging) {\n this.moveAlphaSlider(e);\n }\n };\n AgColorPanel.prototype.onMouseUp = function () {\n this.isSpectrumDragging = false;\n this.isSpectrumHueDragging = false;\n this.isSpectrumAlphaDragging = false;\n };\n AgColorPanel.prototype.moveDragger = function (e) {\n var valRect = this.spectrumValRect;\n if (valRect) {\n var x = e.clientX - valRect.left;\n var y = e.clientY - valRect.top;\n x = Math.max(x, 0);\n x = Math.min(x, valRect.width);\n y = Math.max(y, 0);\n y = Math.min(y, valRect.height);\n this.setSpectrumValue(x / valRect.width, 1 - y / valRect.height);\n }\n };\n AgColorPanel.prototype.moveHueSlider = function (e) {\n var hueRect = this.spectrumHueRect;\n if (hueRect) {\n var slider = this.spectrumHueSlider;\n var sliderRect = slider.getBoundingClientRect();\n var x = e.clientX - hueRect.left;\n x = Math.max(x, 0);\n x = Math.min(x, hueRect.width);\n this.H = 1 - x / hueRect.width;\n slider.style.left = (x + sliderRect.width / 2) + 'px';\n this.update();\n }\n };\n AgColorPanel.prototype.moveAlphaSlider = function (e) {\n var alphaRect = this.spectrumAlphaRect;\n if (alphaRect) {\n var slider = this.spectrumAlphaSlider;\n var sliderRect = slider.getBoundingClientRect();\n var x = e.clientX - alphaRect.left;\n x = Math.max(x, 0);\n x = Math.min(x, alphaRect.width);\n this.A = x / alphaRect.width;\n slider.style.left = (x + sliderRect.width / 2) + 'px';\n this.update();\n }\n };\n AgColorPanel.prototype.update = function () {\n var color = Color.fromHSB(this.H * 360, this.S, this.B, this.A);\n var spectrumColor = Color.fromHSB(this.H * 360, 1, 1);\n var rgbaColor = color.toRgbaString();\n // the recent color list needs to know color has actually changed\n var colorPicker = this.picker;\n var existingColor = Color.fromString(colorPicker.getValue());\n if (existingColor.toRgbaString() !== rgbaColor) {\n this.colorChanged = true;\n }\n colorPicker.setValue(rgbaColor);\n this.spectrumColor.style.backgroundColor = spectrumColor.toRgbaString();\n this.spectrumDragger.style.backgroundColor = rgbaColor;\n };\n /**\n * @param saturation In the [0, 1] interval.\n * @param brightness In the [0, 1] interval.\n */\n AgColorPanel.prototype.setSpectrumValue = function (saturation, brightness) {\n var valRect = this.spectrumValRect || this.refreshSpectrumRect();\n if (valRect) {\n var dragger = this.spectrumDragger;\n var draggerRect = dragger.getBoundingClientRect();\n saturation = Math.max(0, saturation);\n saturation = Math.min(1, saturation);\n brightness = Math.max(0, brightness);\n brightness = Math.min(1, brightness);\n this.S = saturation;\n this.B = brightness;\n dragger.style.left = (saturation * valRect.width - draggerRect.width / 2) + 'px';\n dragger.style.top = ((1 - brightness) * valRect.height - draggerRect.height / 2) + 'px';\n this.update();\n }\n };\n AgColorPanel.prototype.initRecentColors = function () {\n var recentColors = AgColorPanel.recentColors;\n var innerHtml = recentColors.map(function (color, index) {\n return \"
\";\n });\n this.recentColors.innerHTML = innerHtml.join('');\n };\n AgColorPanel.prototype.setValue = function (val) {\n var color = Color.fromString(val);\n var _a = __read(color.toHSB(), 3), h = _a[0], s = _a[1], b = _a[2];\n this.H = (isNaN(h) ? 0 : h) / 360;\n this.A = color.a;\n var spectrumHueRect = this.spectrumHueRect || this.refreshHueRect();\n var spectrumAlphaRect = this.spectrumAlphaRect || this.refreshAlphaRect();\n this.spectrumHueSlider.style.left = ((this.H - 1) * -spectrumHueRect.width) + \"px\";\n this.spectrumAlphaSlider.style.left = (this.A * spectrumAlphaRect.width) + \"px\";\n this.setSpectrumValue(s, b);\n };\n AgColorPanel.prototype.onRecentColorClick = function (e) {\n var target = e.target;\n if (!exists(target.id)) {\n return;\n }\n var id = parseInt(target.id, 10);\n this.setValue(AgColorPanel.recentColors[id]);\n this.destroy();\n };\n AgColorPanel.prototype.addRecentColor = function () {\n var color = Color.fromHSB(this.H * 360, this.S, this.B, this.A);\n var rgbaColor = color.toRgbaString();\n var recentColors = AgColorPanel.recentColors;\n if (!this.colorChanged || recentColors[0] === rgbaColor) {\n return;\n }\n // remove duplicate color\n recentColors = recentColors.filter(function (currentColor) { return currentColor != rgbaColor; });\n // add color to head\n recentColors = [rgbaColor].concat(recentColors);\n // ensure we don't exceed max number of recent colors\n if (recentColors.length > AgColorPanel.maxRecentColors) {\n recentColors = recentColors.slice(0, AgColorPanel.maxRecentColors);\n }\n AgColorPanel.recentColors = recentColors;\n };\n AgColorPanel.prototype.destroy = function () {\n this.addRecentColor();\n _super.prototype.destroy.call(this);\n };\n AgColorPanel.maxRecentColors = 8;\n AgColorPanel.recentColors = [];\n AgColorPanel.TEMPLATE = \"
\\n
\\n
\\n
\\n
\\n
\\n
\\n
\\n
\\n
\\n
\\n
\\n
\\n
\\n
\\n
\\n
\\n
\\n
\\n
\";\n __decorate([\n RefSelector('spectrumColor')\n ], AgColorPanel.prototype, \"spectrumColor\", void 0);\n __decorate([\n RefSelector('spectrumVal')\n ], AgColorPanel.prototype, \"spectrumVal\", void 0);\n __decorate([\n RefSelector('spectrumDragger')\n ], AgColorPanel.prototype, \"spectrumDragger\", void 0);\n __decorate([\n RefSelector('spectrumHue')\n ], AgColorPanel.prototype, \"spectrumHue\", void 0);\n __decorate([\n RefSelector('spectrumHueSlider')\n ], AgColorPanel.prototype, \"spectrumHueSlider\", void 0);\n __decorate([\n RefSelector('spectrumAlpha')\n ], AgColorPanel.prototype, \"spectrumAlpha\", void 0);\n __decorate([\n RefSelector('spectrumAlphaSlider')\n ], AgColorPanel.prototype, \"spectrumAlphaSlider\", void 0);\n __decorate([\n RefSelector('recentColors')\n ], AgColorPanel.prototype, \"recentColors\", void 0);\n __decorate([\n PostConstruct\n ], AgColorPanel.prototype, \"postConstruct\", null);\n return AgColorPanel;\n}(Component));\nexport { AgColorPanel };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { RefSelector } from \"./componentAnnotations\";\nimport { PostConstruct } from \"../context/context\";\nimport { Component } from \"./component\";\nimport { getInnerHeight, getInnerWidth } from \"../utils/dom\";\nimport { createIconNoSpan } from \"../utils/icon\";\nimport { PositionableFeature } from \"../rendering/features/positionableFeature\";\nvar AgPanel = /** @class */ (function (_super) {\n __extends(AgPanel, _super);\n function AgPanel(config) {\n var _this = _super.call(this, AgPanel.getTemplate(config)) || this;\n _this.closable = true;\n _this.config = config;\n return _this;\n }\n AgPanel.getTemplate = function (config) {\n var cssIdentifier = (config && config.cssIdentifier) || 'default';\n return /* html */ \"
\\n
\\n \\n
\\n
\\n
\\n
\";\n };\n AgPanel.prototype.postConstruct = function () {\n var _this = this;\n var _a = this.config, component = _a.component, closable = _a.closable, hideTitleBar = _a.hideTitleBar, title = _a.title, _b = _a.minWidth, minWidth = _b === void 0 ? 250 : _b, width = _a.width, _c = _a.minHeight, minHeight = _c === void 0 ? 250 : _c, height = _a.height, centered = _a.centered, popup = _a.popup, x = _a.x, y = _a.y;\n this.positionableFeature = new PositionableFeature(this.getGui(), {\n minWidth: minWidth, width: width, minHeight: minHeight, height: height, centered: centered, x: x, y: y, popup: popup,\n calculateTopBuffer: function () { return _this.positionableFeature.getHeight() - _this.getBodyHeight(); }\n });\n this.createManagedBean(this.positionableFeature);\n var eGui = this.getGui();\n if (component) {\n this.setBodyComponent(component);\n }\n if (!hideTitleBar) {\n if (title) {\n this.setTitle(title);\n }\n this.setClosable(closable != null ? closable : this.closable);\n }\n else {\n this.eTitleBar.classList.add('ag-hidden');\n }\n this.addManagedListener(this.eTitleBar, 'mousedown', function (e) {\n var eDocument = _this.gridOptionsWrapper.getDocument();\n if (eGui.contains(e.relatedTarget) ||\n eGui.contains(eDocument.activeElement) ||\n _this.eTitleBarButtons.contains(e.target)) {\n e.preventDefault();\n return;\n }\n var focusEl = _this.eContentWrapper.querySelector('button, [href], input, select, textarea, [tabindex]');\n if (focusEl) {\n focusEl.focus();\n }\n });\n if (popup && this.positionableFeature.isPositioned()) {\n return;\n }\n if (this.renderComponent) {\n this.renderComponent();\n }\n this.positionableFeature.initialisePosition();\n this.eContentWrapper.style.height = '0';\n };\n AgPanel.prototype.renderComponent = function () {\n var _this = this;\n var eGui = this.getGui();\n eGui.focus();\n this.close = function () {\n eGui.parentElement.removeChild(eGui);\n _this.destroy();\n };\n };\n AgPanel.prototype.getHeight = function () {\n return this.positionableFeature.getHeight();\n };\n AgPanel.prototype.setHeight = function (height) {\n this.positionableFeature.setHeight(height);\n };\n AgPanel.prototype.getWidth = function () {\n return this.positionableFeature.getWidth();\n };\n AgPanel.prototype.setWidth = function (width) {\n this.positionableFeature.setWidth(width);\n };\n AgPanel.prototype.setClosable = function (closable) {\n if (closable !== this.closable) {\n this.closable = closable;\n }\n if (closable) {\n var closeButtonComp = this.closeButtonComp = new Component(AgPanel.CLOSE_BTN_TEMPLATE);\n this.getContext().createBean(closeButtonComp);\n var eGui = closeButtonComp.getGui();\n var child = createIconNoSpan('close', this.gridOptionsWrapper);\n child.classList.add('ag-panel-title-bar-button-icon');\n eGui.appendChild(child);\n this.addTitleBarButton(closeButtonComp);\n closeButtonComp.addManagedListener(eGui, 'click', this.onBtClose.bind(this));\n }\n else if (this.closeButtonComp) {\n var eGui = this.closeButtonComp.getGui();\n eGui.parentElement.removeChild(eGui);\n this.closeButtonComp = this.destroyBean(this.closeButtonComp);\n }\n };\n AgPanel.prototype.setBodyComponent = function (bodyComponent) {\n bodyComponent.setParentComponent(this);\n this.eContentWrapper.appendChild(bodyComponent.getGui());\n };\n AgPanel.prototype.addTitleBarButton = function (button, position) {\n var eTitleBarButtons = this.eTitleBarButtons;\n var buttons = eTitleBarButtons.children;\n var len = buttons.length;\n if (position == null) {\n position = len;\n }\n position = Math.max(0, Math.min(position, len));\n button.addCssClass('ag-panel-title-bar-button');\n var eGui = button.getGui();\n if (position === 0) {\n eTitleBarButtons.insertAdjacentElement('afterbegin', eGui);\n }\n else if (position === len) {\n eTitleBarButtons.insertAdjacentElement('beforeend', eGui);\n }\n else {\n buttons[position - 1].insertAdjacentElement('afterend', eGui);\n }\n button.setParentComponent(this);\n };\n AgPanel.prototype.getBodyHeight = function () {\n return getInnerHeight(this.eContentWrapper);\n };\n AgPanel.prototype.getBodyWidth = function () {\n return getInnerWidth(this.eContentWrapper);\n };\n AgPanel.prototype.setTitle = function (title) {\n this.eTitle.innerText = title;\n };\n // called when user hits the 'x' in the top right\n AgPanel.prototype.onBtClose = function () {\n this.close();\n };\n AgPanel.prototype.destroy = function () {\n if (this.closeButtonComp) {\n this.closeButtonComp = this.destroyBean(this.closeButtonComp);\n }\n var eGui = this.getGui();\n if (eGui && eGui.offsetParent) {\n this.close();\n }\n _super.prototype.destroy.call(this);\n };\n AgPanel.CLOSE_BTN_TEMPLATE = \"
\";\n __decorate([\n RefSelector('eContentWrapper')\n ], AgPanel.prototype, \"eContentWrapper\", void 0);\n __decorate([\n RefSelector('eTitleBar')\n ], AgPanel.prototype, \"eTitleBar\", void 0);\n __decorate([\n RefSelector('eTitleBarButtons')\n ], AgPanel.prototype, \"eTitleBarButtons\", void 0);\n __decorate([\n RefSelector('eTitle')\n ], AgPanel.prototype, \"eTitle\", void 0);\n __decorate([\n PostConstruct\n ], AgPanel.prototype, \"postConstruct\", null);\n return AgPanel;\n}(Component));\nexport { AgPanel };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired } from \"../context/context\";\nimport { AgPanel } from \"./agPanel\";\nimport { Component } from \"./component\";\nimport { setDisplayed } from \"../utils/dom\";\nimport { createIconNoSpan } from \"../utils/icon\";\nvar AgDialog = /** @class */ (function (_super) {\n __extends(AgDialog, _super);\n function AgDialog(config) {\n var _this = _super.call(this, __assign(__assign({}, config), { popup: true })) || this;\n _this.isMaximizable = false;\n _this.isMaximized = false;\n _this.maximizeListeners = [];\n _this.resizeListenerDestroy = null;\n _this.lastPosition = {\n x: 0,\n y: 0,\n width: 0,\n height: 0\n };\n return _this;\n }\n AgDialog.prototype.postConstruct = function () {\n var _this = this;\n var eGui = this.getGui();\n var _a = this.config, movable = _a.movable, resizable = _a.resizable, maximizable = _a.maximizable;\n this.addCssClass('ag-dialog');\n _super.prototype.postConstruct.call(this);\n this.addManagedListener(eGui, 'focusin', function (e) {\n if (eGui.contains(e.relatedTarget)) {\n return;\n }\n _this.popupService.bringPopupToFront(eGui);\n });\n if (movable) {\n this.setMovable(movable);\n }\n if (maximizable) {\n this.setMaximizable(maximizable);\n }\n if (resizable) {\n this.setResizable(resizable);\n }\n };\n AgDialog.prototype.renderComponent = function () {\n var eGui = this.getGui();\n var _a = this.config, alwaysOnTop = _a.alwaysOnTop, modal = _a.modal, title = _a.title;\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n var addPopupRes = this.popupService.addPopup({\n modal: modal,\n eChild: eGui,\n closeOnEsc: true,\n closedCallback: this.destroy.bind(this),\n alwaysOnTop: alwaysOnTop,\n ariaLabel: title || translate('ariaLabelDialog', 'Dialog')\n });\n if (addPopupRes) {\n this.close = addPopupRes.hideFunc;\n }\n };\n AgDialog.prototype.toggleMaximize = function () {\n var position = this.positionableFeature.getPosition();\n if (this.isMaximized) {\n var _a = this.lastPosition, x = _a.x, y = _a.y, width = _a.width, height = _a.height;\n this.setWidth(width);\n this.setHeight(height);\n this.positionableFeature.offsetElement(x, y);\n }\n else {\n this.lastPosition.width = this.getWidth();\n this.lastPosition.height = this.getHeight();\n this.lastPosition.x = position.x;\n this.lastPosition.y = position.y;\n this.positionableFeature.offsetElement(0, 0);\n this.setHeight('100%');\n this.setWidth('100%');\n }\n this.isMaximized = !this.isMaximized;\n this.refreshMaximizeIcon();\n };\n AgDialog.prototype.refreshMaximizeIcon = function () {\n setDisplayed(this.maximizeIcon, !this.isMaximized);\n setDisplayed(this.minimizeIcon, this.isMaximized);\n };\n AgDialog.prototype.clearMaximizebleListeners = function () {\n if (this.maximizeListeners.length) {\n this.maximizeListeners.forEach(function (destroyListener) { return destroyListener(); });\n this.maximizeListeners.length = 0;\n }\n if (this.resizeListenerDestroy) {\n this.resizeListenerDestroy();\n this.resizeListenerDestroy = null;\n }\n };\n AgDialog.prototype.destroy = function () {\n this.maximizeButtonComp = this.destroyBean(this.maximizeButtonComp);\n this.clearMaximizebleListeners();\n _super.prototype.destroy.call(this);\n };\n AgDialog.prototype.setResizable = function (resizable) {\n this.positionableFeature.setResizable(resizable);\n };\n AgDialog.prototype.setMovable = function (movable) {\n this.positionableFeature.setMovable(movable, this.eTitleBar);\n };\n AgDialog.prototype.setMaximizable = function (maximizable) {\n var _this = this;\n if (!maximizable) {\n this.clearMaximizebleListeners();\n if (this.maximizeButtonComp) {\n this.destroyBean(this.maximizeButtonComp);\n this.maximizeButtonComp = this.maximizeIcon = this.minimizeIcon = undefined;\n }\n return;\n }\n var eTitleBar = this.eTitleBar;\n if (!eTitleBar || maximizable === this.isMaximizable) {\n return;\n }\n var maximizeButtonComp = this.maximizeButtonComp =\n this.createBean(new Component(/* html */ \"
\"));\n var eGui = maximizeButtonComp.getGui();\n eGui.appendChild(this.maximizeIcon = createIconNoSpan('maximize', this.gridOptionsWrapper));\n this.maximizeIcon.classList.add('ag-panel-title-bar-button-icon');\n eGui.appendChild(this.minimizeIcon = createIconNoSpan('minimize', this.gridOptionsWrapper));\n this.minimizeIcon.classList.add('ag-panel-title-bar-button-icon', 'ag-hidden');\n maximizeButtonComp.addManagedListener(eGui, 'click', this.toggleMaximize.bind(this));\n this.addTitleBarButton(maximizeButtonComp, 0);\n this.maximizeListeners.push(this.addManagedListener(eTitleBar, 'dblclick', this.toggleMaximize.bind(this)));\n this.resizeListenerDestroy = this.addManagedListener(this, 'resize', function () {\n _this.isMaximized = false;\n _this.refreshMaximizeIcon();\n });\n };\n __decorate([\n Autowired('popupService')\n ], AgDialog.prototype, \"popupService\", void 0);\n return AgDialog;\n}(AgPanel));\nexport { AgDialog };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nimport { AgColorPanel } from \"./agColorPanel\";\nimport { AgDialog } from \"./agDialog\";\nimport { AgPickerField } from \"./agPickerField\";\nimport { setAriaExpanded } from \"../utils/aria\";\nvar AgColorPicker = /** @class */ (function (_super) {\n __extends(AgColorPicker, _super);\n function AgColorPicker(config) {\n var _this = _super.call(this, config, 'ag-color-picker', 'colorPicker') || this;\n if (config && config.color) {\n _this.value = config.color;\n }\n return _this;\n }\n AgColorPicker.prototype.postConstruct = function () {\n _super.prototype.postConstruct.call(this);\n if (this.value) {\n this.setValue(this.value);\n }\n };\n AgColorPicker.prototype.showPicker = function () {\n var _this = this;\n var eGuiRect = this.getGui().getBoundingClientRect();\n var colorDialog = this.createBean(new AgDialog({\n closable: false,\n modal: true,\n hideTitleBar: true,\n minWidth: 190,\n width: 190,\n height: 250,\n x: eGuiRect.right - 190,\n y: eGuiRect.top - 250\n }));\n this.isPickerDisplayed = true;\n colorDialog.addCssClass('ag-color-dialog');\n setAriaExpanded(this.eWrapper, true);\n var colorPanel = this.createBean(new AgColorPanel({ picker: this }));\n colorPanel.addDestroyFunc(function () {\n if (colorDialog.isAlive()) {\n _this.destroyBean(colorDialog);\n }\n });\n colorDialog.setParentComponent(this);\n colorDialog.setBodyComponent(colorPanel);\n colorPanel.setValue(this.getValue());\n colorDialog.addDestroyFunc(function () {\n // here we check if the picker was already being\n // destroyed to avoid a stack overflow\n if (!_this.isDestroyingPicker) {\n _this.isDestroyingPicker = true;\n if (colorPanel.isAlive()) {\n _this.destroyBean(colorPanel);\n }\n }\n else {\n _this.isDestroyingPicker = false;\n }\n if (_this.isAlive()) {\n setAriaExpanded(_this.eWrapper, false);\n _this.getFocusableElement().focus();\n }\n _this.isPickerDisplayed = false;\n });\n return colorDialog;\n };\n AgColorPicker.prototype.setValue = function (color) {\n if (this.value === color) {\n return this;\n }\n this.eDisplayField.style.backgroundColor = color;\n return _super.prototype.setValue.call(this, color);\n };\n AgColorPicker.prototype.getValue = function () {\n return this.value;\n };\n return AgColorPicker;\n}(AgPickerField));\nexport { AgColorPicker };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from './component';\nimport { RefSelector } from './componentAnnotations';\nimport { PostConstruct } from '../context/context';\nimport { createIcon } from '../utils/icon';\nimport { setDisplayed } from '../utils/dom';\nimport { KeyCode } from '../constants/keyCode';\nimport { setAriaExpanded } from '../utils/aria';\nvar AgGroupComponent = /** @class */ (function (_super) {\n __extends(AgGroupComponent, _super);\n function AgGroupComponent(params) {\n if (params === void 0) { params = {}; }\n var _this = _super.call(this, AgGroupComponent.getTemplate(params)) || this;\n _this.suppressEnabledCheckbox = true;\n _this.suppressOpenCloseIcons = false;\n var title = params.title, enabled = params.enabled, items = params.items, suppressEnabledCheckbox = params.suppressEnabledCheckbox, suppressOpenCloseIcons = params.suppressOpenCloseIcons;\n _this.title = title;\n _this.cssIdentifier = params.cssIdentifier || 'default';\n _this.enabled = enabled != null ? enabled : true;\n _this.items = items || [];\n _this.alignItems = params.alignItems || 'center';\n if (suppressEnabledCheckbox != null) {\n _this.suppressEnabledCheckbox = suppressEnabledCheckbox;\n }\n if (suppressOpenCloseIcons != null) {\n _this.suppressOpenCloseIcons = suppressOpenCloseIcons;\n }\n return _this;\n }\n AgGroupComponent.getTemplate = function (params) {\n var cssIdentifier = params.cssIdentifier || 'default';\n var direction = params.direction || 'vertical';\n return /* html */ \"
\\n
\\n \\n \\n \\n
\\n
\\n \\n
\\n
\\n
\";\n };\n AgGroupComponent.prototype.postConstruct = function () {\n if (this.items.length) {\n var initialItems = this.items;\n this.items = [];\n this.addItems(initialItems);\n }\n var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();\n this.cbGroupEnabled.setLabel(localeTextFunc('enabled', 'Enabled'));\n if (this.title) {\n this.setTitle(this.title);\n }\n if (this.enabled) {\n this.setEnabled(this.enabled);\n }\n this.setAlignItems(this.alignItems);\n this.hideEnabledCheckbox(this.suppressEnabledCheckbox);\n this.hideOpenCloseIcons(this.suppressOpenCloseIcons);\n this.setupExpandContract();\n this.refreshAriaStatus();\n this.refreshChildDisplay();\n };\n AgGroupComponent.prototype.setupExpandContract = function () {\n var _this = this;\n this.eGroupClosedIcon.appendChild(createIcon('columnSelectClosed', this.gridOptionsWrapper, null));\n this.eGroupOpenedIcon.appendChild(createIcon('columnSelectOpen', this.gridOptionsWrapper, null));\n this.addManagedListener(this.eTitleBar, 'click', function () { return _this.toggleGroupExpand(); });\n this.addManagedListener(this.eTitleBar, 'keydown', function (e) {\n switch (e.key) {\n case KeyCode.ENTER:\n case KeyCode.SPACE:\n e.preventDefault();\n _this.toggleGroupExpand();\n break;\n case KeyCode.RIGHT:\n case KeyCode.LEFT:\n e.preventDefault();\n _this.toggleGroupExpand(e.key === KeyCode.RIGHT);\n break;\n }\n });\n };\n AgGroupComponent.prototype.refreshAriaStatus = function () {\n if (!this.suppressOpenCloseIcons) {\n setAriaExpanded(this.eTitleBar, this.expanded);\n }\n };\n AgGroupComponent.prototype.refreshChildDisplay = function () {\n var showIcon = !this.suppressOpenCloseIcons;\n setDisplayed(this.eToolbar, this.expanded && !this.suppressEnabledCheckbox);\n setDisplayed(this.eGroupOpenedIcon, showIcon && this.expanded);\n setDisplayed(this.eGroupClosedIcon, showIcon && !this.expanded);\n };\n AgGroupComponent.prototype.isExpanded = function () {\n return this.expanded;\n };\n AgGroupComponent.prototype.setAlignItems = function (alignment) {\n if (this.alignItems !== alignment) {\n this.removeCssClass(\"ag-group-item-alignment-\" + this.alignItems);\n }\n this.alignItems = alignment;\n var newCls = \"ag-group-item-alignment-\" + this.alignItems;\n this.addCssClass(newCls);\n return this;\n };\n AgGroupComponent.prototype.toggleGroupExpand = function (expanded) {\n if (this.suppressOpenCloseIcons) {\n this.expanded = true;\n this.refreshChildDisplay();\n setDisplayed(this.eContainer, true);\n return this;\n }\n expanded = expanded != null ? expanded : !this.expanded;\n if (this.expanded === expanded) {\n return this;\n }\n this.expanded = expanded;\n this.refreshAriaStatus();\n this.refreshChildDisplay();\n setDisplayed(this.eContainer, expanded);\n this.dispatchEvent({ type: this.expanded ? AgGroupComponent.EVENT_EXPANDED : AgGroupComponent.EVENT_COLLAPSED });\n return this;\n };\n AgGroupComponent.prototype.addItems = function (items) {\n var _this = this;\n items.forEach(function (item) { return _this.addItem(item); });\n };\n AgGroupComponent.prototype.addItem = function (item) {\n var container = this.eContainer;\n var el = item instanceof Component ? item.getGui() : item;\n el.classList.add('ag-group-item', \"ag-\" + this.cssIdentifier + \"-group-item\");\n container.appendChild(el);\n this.items.push(el);\n };\n AgGroupComponent.prototype.hideItem = function (hide, index) {\n var itemToHide = this.items[index];\n itemToHide.classList.toggle('ag-hidden', hide);\n };\n AgGroupComponent.prototype.setTitle = function (title) {\n this.eTitle.innerText = title;\n return this;\n };\n AgGroupComponent.prototype.addCssClassToTitleBar = function (cssClass) {\n this.eTitleBar.classList.add(cssClass);\n };\n AgGroupComponent.prototype.setEnabled = function (enabled, skipToggle) {\n this.enabled = enabled;\n this.refreshDisabledStyles();\n this.toggleGroupExpand(enabled);\n if (!skipToggle) {\n this.cbGroupEnabled.setValue(enabled);\n }\n return this;\n };\n AgGroupComponent.prototype.isEnabled = function () {\n return this.enabled;\n };\n AgGroupComponent.prototype.onEnableChange = function (callbackFn) {\n var _this = this;\n this.cbGroupEnabled.onValueChange(function (newSelection) {\n _this.setEnabled(newSelection, true);\n callbackFn(newSelection);\n });\n return this;\n };\n AgGroupComponent.prototype.hideEnabledCheckbox = function (hide) {\n this.suppressEnabledCheckbox = hide;\n this.refreshChildDisplay();\n this.refreshDisabledStyles();\n return this;\n };\n AgGroupComponent.prototype.hideOpenCloseIcons = function (hide) {\n this.suppressOpenCloseIcons = hide;\n if (hide) {\n this.toggleGroupExpand(true);\n }\n return this;\n };\n AgGroupComponent.prototype.refreshDisabledStyles = function () {\n this.addOrRemoveCssClass('ag-disabled', !this.enabled);\n if (this.suppressEnabledCheckbox && !this.enabled) {\n this.eTitleBar.classList.add('ag-disabled-group-title-bar');\n this.eTitleBar.removeAttribute('tabindex');\n }\n else {\n this.eTitleBar.classList.remove('ag-disabled-group-title-bar');\n this.eTitleBar.setAttribute('tabindex', '0');\n }\n this.eContainer.classList.toggle('ag-disabled-group-container', !this.enabled);\n };\n AgGroupComponent.EVENT_EXPANDED = 'expanded';\n AgGroupComponent.EVENT_COLLAPSED = 'collapsed';\n __decorate([\n RefSelector('eTitleBar')\n ], AgGroupComponent.prototype, \"eTitleBar\", void 0);\n __decorate([\n RefSelector('eGroupOpenedIcon')\n ], AgGroupComponent.prototype, \"eGroupOpenedIcon\", void 0);\n __decorate([\n RefSelector('eGroupClosedIcon')\n ], AgGroupComponent.prototype, \"eGroupClosedIcon\", void 0);\n __decorate([\n RefSelector('eToolbar')\n ], AgGroupComponent.prototype, \"eToolbar\", void 0);\n __decorate([\n RefSelector('cbGroupEnabled')\n ], AgGroupComponent.prototype, \"cbGroupEnabled\", void 0);\n __decorate([\n RefSelector('eTitle')\n ], AgGroupComponent.prototype, \"eTitle\", void 0);\n __decorate([\n RefSelector('eContainer')\n ], AgGroupComponent.prototype, \"eContainer\", void 0);\n __decorate([\n PostConstruct\n ], AgGroupComponent.prototype, \"postConstruct\", null);\n return AgGroupComponent;\n}(Component));\nexport { AgGroupComponent };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../context/beanStub\";\nimport { Autowired, PostConstruct } from \"../context/context\";\nimport { ManagedFocusFeature } from \"./managedFocusFeature\";\nvar TabGuardCtrl = /** @class */ (function (_super) {\n __extends(TabGuardCtrl, _super);\n function TabGuardCtrl(params) {\n var _this = _super.call(this) || this;\n _this.skipTabGuardFocus = false;\n var comp = params.comp, eTopGuard = params.eTopGuard, eBottomGuard = params.eBottomGuard, focusInnerElement = params.focusInnerElement, onFocusIn = params.onFocusIn, onFocusOut = params.onFocusOut, shouldStopEventPropagation = params.shouldStopEventPropagation, onTabKeyDown = params.onTabKeyDown, handleKeyDown = params.handleKeyDown, eFocusableElement = params.eFocusableElement;\n _this.comp = comp;\n _this.eTopGuard = eTopGuard;\n _this.eBottomGuard = eBottomGuard;\n _this.providedFocusInnerElement = focusInnerElement;\n _this.eFocusableElement = eFocusableElement;\n _this.providedFocusIn = onFocusIn;\n _this.providedFocusOut = onFocusOut;\n _this.providedShouldStopEventPropagation = shouldStopEventPropagation;\n _this.providedOnTabKeyDown = onTabKeyDown;\n _this.providedHandleKeyDown = handleKeyDown;\n return _this;\n }\n TabGuardCtrl.prototype.postConstruct = function () {\n var _this = this;\n this.createManagedBean(new ManagedFocusFeature(this.eFocusableElement, {\n shouldStopEventPropagation: function () { return _this.shouldStopEventPropagation(); },\n onTabKeyDown: function (e) { return _this.onTabKeyDown(e); },\n handleKeyDown: function (e) { return _this.handleKeyDown(e); },\n onFocusIn: function (e) { return _this.onFocusIn(e); },\n onFocusOut: function (e) { return _this.onFocusOut(e); }\n }));\n this.activateTabGuards();\n [this.eTopGuard, this.eBottomGuard].forEach(function (guard) { return _this.addManagedListener(guard, 'focus', _this.onFocus.bind(_this)); });\n };\n TabGuardCtrl.prototype.handleKeyDown = function (e) {\n if (this.providedHandleKeyDown) {\n this.providedHandleKeyDown(e);\n }\n };\n TabGuardCtrl.prototype.tabGuardsAreActive = function () {\n return !!this.eTopGuard && this.eTopGuard.hasAttribute('tabIndex');\n };\n TabGuardCtrl.prototype.shouldStopEventPropagation = function () {\n if (this.providedShouldStopEventPropagation) {\n return this.providedShouldStopEventPropagation();\n }\n return false;\n };\n TabGuardCtrl.prototype.activateTabGuards = function () {\n this.comp.setTabIndex(this.getGridTabIndex());\n };\n TabGuardCtrl.prototype.deactivateTabGuards = function () {\n this.comp.setTabIndex();\n };\n TabGuardCtrl.prototype.onFocus = function (e) {\n if (this.skipTabGuardFocus) {\n this.skipTabGuardFocus = false;\n return;\n }\n var fromBottom = e.target === this.eBottomGuard;\n if (this.providedFocusInnerElement) {\n this.providedFocusInnerElement(fromBottom);\n }\n else {\n this.focusInnerElement(fromBottom);\n }\n };\n TabGuardCtrl.prototype.onFocusIn = function (e) {\n if (this.providedFocusIn && this.providedFocusIn(e)) {\n return;\n }\n this.deactivateTabGuards();\n };\n TabGuardCtrl.prototype.onFocusOut = function (e) {\n if (this.providedFocusOut && this.providedFocusOut(e)) {\n return;\n }\n if (!this.eFocusableElement.contains(e.relatedTarget)) {\n this.activateTabGuards();\n }\n };\n TabGuardCtrl.prototype.onTabKeyDown = function (e) {\n var _this = this;\n if (this.providedOnTabKeyDown) {\n this.providedOnTabKeyDown(e);\n return;\n }\n if (e.defaultPrevented) {\n return;\n }\n var tabGuardsAreActive = this.tabGuardsAreActive();\n if (tabGuardsAreActive) {\n this.deactivateTabGuards();\n }\n var nextRoot = this.getNextFocusableElement(e.shiftKey);\n if (tabGuardsAreActive) {\n // ensure the tab guards are only re-instated once the event has finished processing, to avoid the browser\n // tabbing to the tab guard from inside the component\n setTimeout(function () { return _this.activateTabGuards(); }, 0);\n }\n if (!nextRoot) {\n return;\n }\n nextRoot.focus();\n e.preventDefault();\n };\n TabGuardCtrl.prototype.getGridTabIndex = function () {\n return this.gridOptionsWrapper.getGridTabIndex();\n };\n TabGuardCtrl.prototype.focusInnerElement = function (fromBottom) {\n if (fromBottom === void 0) { fromBottom = false; }\n var focusable = this.focusService.findFocusableElements(this.eFocusableElement);\n if (this.tabGuardsAreActive()) {\n // remove tab guards from this component from list of focusable elements\n focusable.splice(0, 1);\n focusable.splice(focusable.length - 1, 1);\n }\n if (!focusable.length) {\n return;\n }\n focusable[fromBottom ? focusable.length - 1 : 0].focus();\n };\n TabGuardCtrl.prototype.getNextFocusableElement = function (backwards) {\n return this.focusService.findNextFocusableElement(this.eFocusableElement, false, backwards);\n };\n TabGuardCtrl.prototype.forceFocusOutOfContainer = function (up) {\n if (up === void 0) { up = false; }\n var tabGuardToFocus = up ? this.eTopGuard : this.eBottomGuard;\n this.activateTabGuards();\n this.skipTabGuardFocus = true;\n tabGuardToFocus.focus();\n };\n __decorate([\n Autowired('focusService')\n ], TabGuardCtrl.prototype, \"focusService\", void 0);\n __decorate([\n PostConstruct\n ], TabGuardCtrl.prototype, \"postConstruct\", null);\n return TabGuardCtrl;\n}(BeanStub));\nexport { TabGuardCtrl };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nimport { Component } from \"./component\";\nimport { isNodeOrElement, clearElement } from \"../utils/dom\";\nimport { TabGuardCtrl } from \"./tabGuardCtrl\";\nimport { setAriaRole } from \"../utils/aria\";\nvar TabGuardComp = /** @class */ (function (_super) {\n __extends(TabGuardComp, _super);\n function TabGuardComp() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n TabGuardComp.prototype.initialiseTabGuard = function (params) {\n this.eTopGuard = this.createTabGuard('top');\n this.eBottomGuard = this.createTabGuard('bottom');\n this.eFocusableElement = this.getFocusableElement();\n var tabGuards = [this.eTopGuard, this.eBottomGuard];\n var compProxy = {\n setTabIndex: function (tabIndex) {\n tabGuards.forEach(function (tabGuard) { return tabIndex != null ? tabGuard.setAttribute('tabIndex', tabIndex) : tabGuard.removeAttribute('tabIndex'); });\n }\n };\n this.addTabGuards(this.eTopGuard, this.eBottomGuard);\n this.tabGuardCtrl = this.createManagedBean(new TabGuardCtrl({\n comp: compProxy,\n eTopGuard: this.eTopGuard,\n eBottomGuard: this.eBottomGuard,\n eFocusableElement: this.eFocusableElement,\n onFocusIn: params.onFocusIn,\n onFocusOut: params.onFocusOut,\n focusInnerElement: params.focusInnerElement,\n handleKeyDown: params.handleKeyDown,\n onTabKeyDown: params.onTabKeyDown,\n shouldStopEventPropagation: params.shouldStopEventPropagation\n }));\n };\n TabGuardComp.prototype.createTabGuard = function (side) {\n var tabGuard = document.createElement('div');\n tabGuard.classList.add('ag-tab-guard', \"ag-tab-guard-\" + side);\n setAriaRole(tabGuard, 'presentation');\n return tabGuard;\n };\n TabGuardComp.prototype.addTabGuards = function (topTabGuard, bottomTabGuard) {\n this.eFocusableElement.insertAdjacentElement('afterbegin', topTabGuard);\n this.eFocusableElement.insertAdjacentElement('beforeend', bottomTabGuard);\n };\n TabGuardComp.prototype.removeAllChildrenExceptTabGuards = function () {\n var tabGuards = [this.eTopGuard, this.eBottomGuard];\n clearElement(this.getFocusableElement());\n this.addTabGuards.apply(this, __spread(tabGuards));\n };\n TabGuardComp.prototype.forceFocusOutOfContainer = function (up) {\n if (up === void 0) { up = false; }\n this.tabGuardCtrl.forceFocusOutOfContainer(up);\n };\n TabGuardComp.prototype.appendChild = function (newChild, container) {\n if (!isNodeOrElement(newChild)) {\n newChild = newChild.getGui();\n }\n var bottomTabGuard = this.eBottomGuard;\n if (bottomTabGuard) {\n bottomTabGuard.insertAdjacentElement('beforebegin', newChild);\n }\n else {\n _super.prototype.appendChild.call(this, newChild, container);\n }\n };\n return TabGuardComp;\n}(Component));\nexport { TabGuardComp };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from \"../context/context\";\nimport { AgMenuItemComponent } from \"./agMenuItemComponent\";\nimport { TabGuardComp } from \"./tabGuardComp\";\nimport { KeyCode } from \"../constants/keyCode\";\nimport { loadTemplate } from \"../utils/dom\";\nimport { last } from \"../utils/array\";\nimport { setAriaLevel } from \"../utils/aria\";\nvar AgMenuList = /** @class */ (function (_super) {\n __extends(AgMenuList, _super);\n function AgMenuList(level) {\n if (level === void 0) { level = 1; }\n var _this = _super.call(this, /* html */ \"
\") || this;\n _this.level = level;\n _this.menuItems = [];\n return _this;\n }\n AgMenuList.prototype.postConstruct = function () {\n var _this = this;\n this.initialiseTabGuard({\n onTabKeyDown: function (e) { return _this.onTabKeyDown(e); },\n handleKeyDown: function (e) { return _this.handleKeyDown(e); }\n });\n };\n AgMenuList.prototype.onTabKeyDown = function (e) {\n var parent = this.getParentComponent();\n var parentGui = parent && parent.getGui();\n var isManaged = parentGui && parentGui.classList.contains('ag-focus-managed');\n if (!isManaged) {\n e.preventDefault();\n }\n if (e.shiftKey) {\n this.closeIfIsChild(e);\n }\n };\n AgMenuList.prototype.handleKeyDown = function (e) {\n switch (e.key) {\n case KeyCode.UP:\n case KeyCode.RIGHT:\n case KeyCode.DOWN:\n case KeyCode.LEFT:\n e.preventDefault();\n this.handleNavKey(e.key);\n break;\n case KeyCode.ESCAPE:\n var topMenu = this.findTopMenu();\n if (topMenu) {\n this.focusService.focusInto(topMenu.getGui());\n }\n break;\n }\n };\n AgMenuList.prototype.clearActiveItem = function () {\n if (this.activeMenuItem) {\n this.activeMenuItem.deactivate();\n this.activeMenuItem = null;\n }\n };\n AgMenuList.prototype.addMenuItems = function (menuItems) {\n var _this = this;\n if (menuItems == null) {\n return;\n }\n menuItems.forEach(function (menuItemOrString) {\n if (menuItemOrString === 'separator') {\n _this.addSeparator();\n }\n else if (typeof menuItemOrString === 'string') {\n console.warn(\"AG Grid: unrecognised menu item \" + menuItemOrString);\n }\n else {\n _this.addItem(menuItemOrString);\n }\n });\n };\n AgMenuList.prototype.addItem = function (menuItemDef) {\n var _this = this;\n var menuItem = this.createManagedBean(new AgMenuItemComponent(__assign(__assign({}, menuItemDef), { isAnotherSubMenuOpen: function () { return _this.menuItems.some(function (m) { return m.isSubMenuOpen(); }); } })));\n menuItem.setParentComponent(this);\n setAriaLevel(menuItem.getGui(), this.level);\n this.menuItems.push(menuItem);\n this.appendChild(menuItem.getGui());\n this.addManagedListener(menuItem, AgMenuItemComponent.EVENT_MENU_ITEM_SELECTED, function (event) {\n _this.dispatchEvent(event);\n });\n this.addManagedListener(menuItem, AgMenuItemComponent.EVENT_MENU_ITEM_ACTIVATED, function (event) {\n if (_this.activeMenuItem && _this.activeMenuItem !== event.menuItem) {\n _this.activeMenuItem.deactivate();\n }\n _this.activeMenuItem = event.menuItem;\n });\n };\n AgMenuList.prototype.activateFirstItem = function () {\n var item = this.menuItems.filter(function (currentItem) { return !currentItem.isDisabled(); })[0];\n if (!item) {\n return;\n }\n item.activate();\n };\n AgMenuList.prototype.addSeparator = function () {\n var separatorHtml = /* html */ \"\\n
\\n
\\n
\\n
\\n
\\n
\";\n this.appendChild(loadTemplate(separatorHtml));\n };\n AgMenuList.prototype.findTopMenu = function () {\n var parent = this.getParentComponent();\n if (!parent && this instanceof AgMenuList) {\n return this;\n }\n while (true) {\n var nextParent = parent && parent.getParentComponent && parent.getParentComponent();\n if (!nextParent || (!(nextParent instanceof AgMenuList || nextParent instanceof AgMenuItemComponent))) {\n break;\n }\n parent = nextParent;\n }\n return parent instanceof AgMenuList ? parent : undefined;\n };\n AgMenuList.prototype.handleNavKey = function (key) {\n switch (key) {\n case KeyCode.UP:\n case KeyCode.DOWN:\n var nextItem = this.findNextItem(key === KeyCode.UP);\n if (nextItem && nextItem !== this.activeMenuItem) {\n nextItem.activate();\n }\n return;\n }\n var left = this.gridOptionsWrapper.isEnableRtl() ? KeyCode.RIGHT : KeyCode.LEFT;\n if (key === left) {\n this.closeIfIsChild();\n }\n else {\n this.openChild();\n }\n };\n AgMenuList.prototype.closeIfIsChild = function (e) {\n var parentItem = this.getParentComponent();\n if (parentItem && parentItem instanceof AgMenuItemComponent) {\n if (e) {\n e.preventDefault();\n }\n parentItem.closeSubMenu();\n parentItem.getGui().focus();\n }\n };\n AgMenuList.prototype.openChild = function () {\n if (this.activeMenuItem) {\n this.activeMenuItem.openSubMenu(true);\n }\n };\n AgMenuList.prototype.findNextItem = function (up) {\n var items = this.menuItems.filter(function (item) { return !item.isDisabled(); });\n if (!items.length) {\n return;\n }\n if (!this.activeMenuItem) {\n return up ? last(items) : items[0];\n }\n if (up) {\n items.reverse();\n }\n var nextItem;\n var foundCurrent = false;\n for (var i = 0; i < items.length; i++) {\n var item = items[i];\n if (!foundCurrent) {\n if (item === this.activeMenuItem) {\n foundCurrent = true;\n }\n continue;\n }\n nextItem = item;\n break;\n }\n return nextItem || this.activeMenuItem;\n };\n AgMenuList.prototype.destroy = function () {\n this.clearActiveItem();\n _super.prototype.destroy.call(this);\n };\n __decorate([\n Autowired('focusService')\n ], AgMenuList.prototype, \"focusService\", void 0);\n __decorate([\n PostConstruct\n ], AgMenuList.prototype, \"postConstruct\", null);\n return AgMenuList;\n}(TabGuardComp));\nexport { AgMenuList };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PostConstruct } from '../context/context';\nimport { KeyCode } from '../constants/keyCode';\nimport { TabGuardComp } from './tabGuardComp';\nvar AgMenuPanel = /** @class */ (function (_super) {\n __extends(AgMenuPanel, _super);\n function AgMenuPanel(wrappedComponent) {\n var _this = _super.call(this) || this;\n _this.wrappedComponent = wrappedComponent;\n _this.setTemplateFromElement(wrappedComponent.getGui());\n return _this;\n }\n AgMenuPanel.prototype.postConstruct = function () {\n var _this = this;\n this.initialiseTabGuard({\n onTabKeyDown: function (e) { return _this.onTabKeyDown(e); },\n handleKeyDown: function (e) { return _this.handleKeyDown(e); }\n });\n };\n AgMenuPanel.prototype.handleKeyDown = function (e) {\n if (e.key === KeyCode.ESCAPE) {\n this.closePanel();\n }\n };\n AgMenuPanel.prototype.onTabKeyDown = function (e) {\n if (e.defaultPrevented) {\n return;\n }\n this.closePanel();\n e.preventDefault();\n };\n AgMenuPanel.prototype.closePanel = function () {\n var menuItem = this.parentComponent;\n menuItem.closeSubMenu();\n setTimeout(function () { return menuItem.getGui().focus(); }, 0);\n };\n __decorate([\n PostConstruct\n ], AgMenuPanel.prototype, \"postConstruct\", null);\n return AgMenuPanel;\n}(TabGuardComp));\nexport { AgMenuPanel };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired } from '../context/context';\nimport { AgMenuList } from './agMenuList';\nimport { AgMenuPanel } from './agMenuPanel';\nimport { Component } from './component';\nimport { KeyCode } from '../constants/keyCode';\nimport { PostConstruct } from '../context/context';\nimport { createIconNoSpan } from '../utils/icon';\nimport { isNodeOrElement, loadTemplate } from '../utils/dom';\nimport { CustomTooltipFeature } from './customTooltipFeature';\nimport { getAriaLevel, setAriaDisabled, setAriaExpanded } from '../utils/aria';\nvar AgMenuItemComponent = /** @class */ (function (_super) {\n __extends(AgMenuItemComponent, _super);\n function AgMenuItemComponent(params) {\n var _this = _super.call(this) || this;\n _this.params = params;\n _this.isActive = false;\n _this.subMenuIsOpen = false;\n _this.setTemplate(/* html */ \"
\");\n return _this;\n }\n AgMenuItemComponent.prototype.init = function () {\n var _this = this;\n this.addIcon();\n this.addName();\n this.addShortcut();\n this.addSubMenu();\n this.addTooltip();\n var eGui = this.getGui();\n if (this.params.disabled) {\n this.addCssClass(this.getClassName('disabled'));\n setAriaDisabled(eGui, true);\n }\n else {\n this.addGuiEventListener('click', function (e) { return _this.onItemSelected(e); });\n this.addGuiEventListener('keydown', function (e) {\n if (e.key === KeyCode.ENTER || e.key === KeyCode.SPACE) {\n e.preventDefault();\n _this.onItemSelected(e);\n }\n });\n this.addGuiEventListener('mousedown', function (e) {\n // Prevent event bubbling to other event handlers such as PopupService triggering\n // premature closing of any open sub-menu popup.\n e.stopPropagation();\n e.preventDefault();\n });\n this.addGuiEventListener('mouseenter', function () { return _this.onMouseEnter(); });\n this.addGuiEventListener('mouseleave', function () { return _this.onMouseLeave(); });\n }\n if (this.params.cssClasses) {\n this.params.cssClasses.forEach(function (it) { return _this.addCssClass(it); });\n }\n };\n AgMenuItemComponent.prototype.isDisabled = function () {\n return !!this.params.disabled;\n };\n AgMenuItemComponent.prototype.openSubMenu = function (activateFirstItem) {\n var _this = this;\n if (activateFirstItem === void 0) { activateFirstItem = false; }\n this.closeSubMenu();\n if (!this.params.subMenu) {\n return;\n }\n var ePopup = loadTemplate(/* html */ \"
\");\n var destroySubMenu;\n if (this.params.subMenu instanceof Array) {\n var currentLevel = getAriaLevel(this.getGui());\n var nextLevel = isNaN(currentLevel) ? 1 : (currentLevel + 1);\n var childMenu_1 = this.createBean(new AgMenuList(nextLevel));\n childMenu_1.setParentComponent(this);\n childMenu_1.addMenuItems(this.params.subMenu);\n ePopup.appendChild(childMenu_1.getGui());\n // bubble menu item selected events\n this.addManagedListener(childMenu_1, AgMenuItemComponent.EVENT_MENU_ITEM_SELECTED, function (e) { return _this.dispatchEvent(e); });\n childMenu_1.addGuiEventListener('mouseenter', function () { return _this.cancelDeactivate(); });\n destroySubMenu = function () { return _this.destroyBean(childMenu_1); };\n if (activateFirstItem) {\n setTimeout(function () { return childMenu_1.activateFirstItem(); }, 0);\n }\n }\n else {\n var subMenu_1 = this.params.subMenu;\n var menuPanel = this.createBean(new AgMenuPanel(subMenu_1));\n menuPanel.setParentComponent(this);\n var subMenuGui_1 = menuPanel.getGui();\n var mouseEvent_1 = 'mouseenter';\n var mouseEnterListener_1 = function () { return _this.cancelDeactivate(); };\n subMenuGui_1.addEventListener(mouseEvent_1, mouseEnterListener_1);\n destroySubMenu = function () { return subMenuGui_1.removeEventListener(mouseEvent_1, mouseEnterListener_1); };\n ePopup.appendChild(subMenuGui_1);\n if (subMenu_1.afterGuiAttached) {\n setTimeout(function () { return subMenu_1.afterGuiAttached(); }, 0);\n }\n }\n var eGui = this.getGui();\n var positionCallback = this.popupService.positionPopupForMenu.bind(this.popupService, { eventSource: eGui, ePopup: ePopup });\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n var addPopupRes = this.popupService.addPopup({\n modal: true,\n eChild: ePopup,\n positionCallback: positionCallback,\n anchorToElement: eGui,\n ariaLabel: translate('ariaLabelSubMenu', 'SubMenu')\n });\n this.subMenuIsOpen = true;\n setAriaExpanded(eGui, true);\n this.hideSubMenu = function () {\n if (addPopupRes) {\n addPopupRes.hideFunc();\n }\n _this.subMenuIsOpen = false;\n setAriaExpanded(eGui, false);\n destroySubMenu();\n };\n };\n AgMenuItemComponent.prototype.closeSubMenu = function () {\n if (!this.hideSubMenu) {\n return;\n }\n this.hideSubMenu();\n this.hideSubMenu = null;\n setAriaExpanded(this.getGui(), false);\n };\n AgMenuItemComponent.prototype.isSubMenuOpen = function () {\n return this.subMenuIsOpen;\n };\n AgMenuItemComponent.prototype.activate = function (openSubMenu) {\n var _this = this;\n this.cancelActivate();\n if (this.params.disabled) {\n return;\n }\n this.isActive = true;\n this.addCssClass(this.getClassName('active'));\n this.getGui().focus();\n if (openSubMenu && this.params.subMenu) {\n window.setTimeout(function () {\n if (_this.isAlive() && _this.isActive) {\n _this.openSubMenu();\n }\n }, 300);\n }\n this.onItemActivated();\n };\n AgMenuItemComponent.prototype.deactivate = function () {\n this.cancelDeactivate();\n this.removeCssClass(this.getClassName('active'));\n this.isActive = false;\n if (this.subMenuIsOpen) {\n this.hideSubMenu();\n }\n };\n AgMenuItemComponent.prototype.addIcon = function () {\n if (!this.params.checked && !this.params.icon && this.params.isCompact) {\n return;\n }\n var icon = loadTemplate(/* html */ \"\");\n if (this.params.checked) {\n icon.appendChild(createIconNoSpan('check', this.gridOptionsWrapper));\n }\n else if (this.params.icon) {\n if (isNodeOrElement(this.params.icon)) {\n icon.appendChild(this.params.icon);\n }\n else if (typeof this.params.icon === 'string') {\n icon.innerHTML = this.params.icon;\n }\n else {\n console.warn('AG Grid: menu item icon must be DOM node or string');\n }\n }\n this.getGui().appendChild(icon);\n };\n AgMenuItemComponent.prototype.addName = function () {\n if (!this.params.name && this.params.isCompact) {\n return;\n }\n var name = loadTemplate(/* html */ \"\" + (this.params.name || '') + \"\");\n this.getGui().appendChild(name);\n };\n AgMenuItemComponent.prototype.addTooltip = function () {\n if (!this.params.tooltip) {\n return;\n }\n this.tooltip = this.params.tooltip;\n if (this.gridOptionsWrapper.isEnableBrowserTooltips()) {\n this.getGui().setAttribute('title', this.tooltip);\n }\n else {\n this.createManagedBean(new CustomTooltipFeature(this));\n }\n };\n AgMenuItemComponent.prototype.getTooltipParams = function () {\n return {\n location: 'menu',\n value: this.tooltip\n };\n };\n AgMenuItemComponent.prototype.addShortcut = function () {\n if (!this.params.shortcut && this.params.isCompact) {\n return;\n }\n var shortcut = loadTemplate(/* html */ \"\" + (this.params.shortcut || '') + \"\");\n this.getGui().appendChild(shortcut);\n };\n AgMenuItemComponent.prototype.addSubMenu = function () {\n if (!this.params.subMenu && this.params.isCompact) {\n return;\n }\n var pointer = loadTemplate(/* html */ \"\");\n var eGui = this.getGui();\n if (this.params.subMenu) {\n var iconName = this.gridOptionsWrapper.isEnableRtl() ? 'smallLeft' : 'smallRight';\n setAriaExpanded(eGui, false);\n pointer.appendChild(createIconNoSpan(iconName, this.gridOptionsWrapper));\n }\n eGui.appendChild(pointer);\n };\n AgMenuItemComponent.prototype.onItemSelected = function (event) {\n if (this.params.action) {\n this.params.action();\n }\n else {\n this.openSubMenu(event && event.type === 'keydown');\n }\n if (this.params.subMenu && !this.params.action) {\n return;\n }\n var e = {\n type: AgMenuItemComponent.EVENT_MENU_ITEM_SELECTED,\n action: this.params.action,\n checked: this.params.checked,\n cssClasses: this.params.cssClasses,\n disabled: this.params.disabled,\n icon: this.params.icon,\n name: this.params.name,\n shortcut: this.params.shortcut,\n subMenu: this.params.subMenu,\n tooltip: this.params.tooltip,\n event: event\n };\n this.dispatchEvent(e);\n };\n AgMenuItemComponent.prototype.onItemActivated = function () {\n var event = {\n type: AgMenuItemComponent.EVENT_MENU_ITEM_ACTIVATED,\n menuItem: this,\n };\n this.dispatchEvent(event);\n };\n AgMenuItemComponent.prototype.cancelActivate = function () {\n if (this.activateTimeoutId) {\n window.clearTimeout(this.activateTimeoutId);\n this.activateTimeoutId = 0;\n }\n };\n AgMenuItemComponent.prototype.cancelDeactivate = function () {\n if (this.deactivateTimeoutId) {\n window.clearTimeout(this.deactivateTimeoutId);\n this.deactivateTimeoutId = 0;\n }\n };\n AgMenuItemComponent.prototype.onMouseEnter = function () {\n var _this = this;\n this.cancelDeactivate();\n if (this.params.isAnotherSubMenuOpen()) {\n // wait to see if the user enters the open sub-menu\n this.activateTimeoutId = window.setTimeout(function () { return _this.activate(true); }, AgMenuItemComponent.ACTIVATION_DELAY);\n }\n else {\n // activate immediately\n this.activate(true);\n }\n };\n AgMenuItemComponent.prototype.onMouseLeave = function () {\n var _this = this;\n this.cancelActivate();\n if (this.isSubMenuOpen()) {\n // wait to see if the user enters the sub-menu\n this.deactivateTimeoutId = window.setTimeout(function () { return _this.deactivate(); }, AgMenuItemComponent.ACTIVATION_DELAY);\n }\n else {\n // de-activate immediately\n this.deactivate();\n }\n };\n AgMenuItemComponent.prototype.getClassName = function (suffix) {\n var prefix = this.params.isCompact ? 'ag-compact-menu-option' : 'ag-menu-option';\n return suffix ? prefix + \"-\" + suffix : prefix;\n };\n AgMenuItemComponent.EVENT_MENU_ITEM_SELECTED = 'menuItemSelected';\n AgMenuItemComponent.EVENT_MENU_ITEM_ACTIVATED = 'menuItemActivated';\n AgMenuItemComponent.ACTIVATION_DELAY = 80;\n __decorate([\n Autowired('popupService')\n ], AgMenuItemComponent.prototype, \"popupService\", void 0);\n __decorate([\n PostConstruct\n ], AgMenuItemComponent.prototype, \"init\", null);\n return AgMenuItemComponent;\n}(Component));\nexport { AgMenuItemComponent };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nimport { Autowired, Bean, Optional, PostConstruct } from \"./context/context\";\nimport { BeanStub } from \"./context/beanStub\";\nimport { Events } from \"./events\";\nimport { ManagedFocusFeature } from \"./widgets/managedFocusFeature\";\nimport { getTabIndex } from './utils/browser';\nimport { makeNull } from './utils/generic';\nimport { Constants } from \"./constants/constants\";\nimport { RowCtrl } from \"./rendering/row/rowCtrl\";\nimport { AbstractHeaderCellCtrl } from \"./headerRendering/cells/abstractCell/abstractHeaderCellCtrl\";\nimport { last } from \"./utils/array\";\nvar FocusService = /** @class */ (function (_super) {\n __extends(FocusService, _super);\n function FocusService() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n FocusService_1 = FocusService;\n /**\n * Adds a gridCore to the list of the gridCores monitoring Keyboard Mode\n * in a specific HTMLDocument.\n *\n * @param doc {Document} - The Document containing the gridCore.\n * @param gridCore {GridComp} - The GridCore to be monitored.\n */\n FocusService.addKeyboardModeEvents = function (doc, controller) {\n var docControllers = FocusService_1.instancesMonitored.get(doc);\n if (docControllers && docControllers.length > 0) {\n if (docControllers.indexOf(controller) === -1) {\n docControllers.push(controller);\n }\n }\n else {\n FocusService_1.instancesMonitored.set(doc, [controller]);\n doc.addEventListener('keydown', FocusService_1.toggleKeyboardMode);\n doc.addEventListener('mousedown', FocusService_1.toggleKeyboardMode);\n }\n };\n /**\n * Removes a gridCore from the list of the gridCores monitoring Keyboard Mode\n * in a specific HTMLDocument.\n *\n * @param doc {Document} - The Document containing the gridCore.\n * @param gridCore {GridComp} - The GridCore to be removed.\n */\n FocusService.removeKeyboardModeEvents = function (doc, controller) {\n var docControllers = FocusService_1.instancesMonitored.get(doc);\n var newControllers = [];\n if (docControllers && docControllers.length) {\n newControllers = __spread(docControllers).filter(function (currentGridCore) { return currentGridCore !== controller; });\n FocusService_1.instancesMonitored.set(doc, newControllers);\n }\n if (newControllers.length === 0) {\n doc.removeEventListener('keydown', FocusService_1.toggleKeyboardMode);\n doc.removeEventListener('mousedown', FocusService_1.toggleKeyboardMode);\n }\n };\n /**\n * This method will be called by `keydown` and `mousedown` events on all Documents monitoring\n * KeyboardMode. It will then fire a KEYBOARD_FOCUS, MOUSE_FOCUS on each gridCore present in\n * the Document allowing each gridCore to maintain a state for KeyboardMode.\n *\n * @param event {KeyboardEvent | MouseEvent | TouchEvent} - The event triggered.\n */\n FocusService.toggleKeyboardMode = function (event) {\n var isKeyboardActive = FocusService_1.keyboardModeActive;\n var isKeyboardEvent = event.type === 'keydown';\n if (isKeyboardEvent) {\n // the following keys should not toggle keyboard mode.\n if (event.ctrlKey || event.metaKey || event.altKey) {\n return;\n }\n }\n if (isKeyboardActive && isKeyboardEvent || !isKeyboardActive && !isKeyboardEvent) {\n return;\n }\n FocusService_1.keyboardModeActive = isKeyboardEvent;\n var doc = event.target.ownerDocument;\n if (!doc) {\n return;\n }\n var controllersForDoc = FocusService_1.instancesMonitored.get(doc);\n if (controllersForDoc) {\n controllersForDoc.forEach(function (controller) {\n controller.dispatchEvent({ type: isKeyboardEvent ? Events.EVENT_KEYBOARD_FOCUS : Events.EVENT_MOUSE_FOCUS });\n });\n }\n };\n FocusService.prototype.init = function () {\n var _this = this;\n var clearFocusedCellListener = this.clearFocusedCell.bind(this);\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PIVOT_MODE_CHANGED, clearFocusedCellListener);\n this.addManagedListener(this.eventService, Events.EVENT_NEW_COLUMNS_LOADED, this.onColumnEverythingChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_GROUP_OPENED, clearFocusedCellListener);\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, clearFocusedCellListener);\n this.ctrlsService.whenReady(function (p) {\n _this.gridCtrl = p.gridCtrl;\n var doc = _this.gridOptionsWrapper.getDocument();\n FocusService_1.addKeyboardModeEvents(doc, _this.gridCtrl);\n _this.addDestroyFunc(function () { return _this.unregisterGridCompController(_this.gridCtrl); });\n });\n };\n FocusService.prototype.unregisterGridCompController = function (gridCompController) {\n var doc = this.gridOptionsWrapper.getDocument();\n FocusService_1.removeKeyboardModeEvents(doc, gridCompController);\n };\n FocusService.prototype.onColumnEverythingChanged = function () {\n // if the columns change, check and see if this column still exists. if it does, then\n // we can keep the focused cell. if it doesn't, then we need to drop the focused cell.\n if (!this.focusedCellPosition) {\n return;\n }\n var col = this.focusedCellPosition.column;\n var colFromColumnModel = this.columnModel.getGridColumn(col.getId());\n if (col !== colFromColumnModel) {\n this.clearFocusedCell();\n }\n };\n FocusService.prototype.isKeyboardMode = function () {\n return FocusService_1.keyboardModeActive;\n };\n // we check if the browser is focusing something, and if it is, and\n // it's the cell we think is focused, then return the cell. so this\n // methods returns the cell if a) we think it has focus and b) the\n // browser thinks it has focus. this then returns nothing if we\n // first focus a cell, then second click outside the grid, as then the\n // grid cell will still be focused as far as the grid is concerned,\n // however the browser focus will have moved somewhere else.\n FocusService.prototype.getFocusCellToUseAfterRefresh = function () {\n var eDocument = this.gridOptionsWrapper.getDocument();\n if (this.gridOptionsWrapper.isSuppressFocusAfterRefresh() || !this.focusedCellPosition) {\n return null;\n }\n // we check that the browser is actually focusing on the grid, if it is not, then\n // we have nothing to worry about. we check for ROW data, as this covers both focused Rows (for Full Width Rows)\n // and Cells (covers cells as cells live in rows)\n if (this.isDomDataMissingInHierarchy(eDocument.activeElement, RowCtrl.DOM_DATA_KEY_ROW_CTRL)) {\n return null;\n }\n return this.focusedCellPosition;\n };\n FocusService.prototype.getFocusHeaderToUseAfterRefresh = function () {\n var eDocument = this.gridOptionsWrapper.getDocument();\n if (this.gridOptionsWrapper.isSuppressFocusAfterRefresh() || !this.focusedHeaderPosition) {\n return null;\n }\n // we check that the browser is actually focusing on the grid, if it is not, then\n // we have nothing to worry about\n if (this.isDomDataMissingInHierarchy(eDocument.activeElement, AbstractHeaderCellCtrl.DOM_DATA_KEY_HEADER_CTRL)) {\n return null;\n }\n return this.focusedHeaderPosition;\n };\n FocusService.prototype.isDomDataMissingInHierarchy = function (eBrowserCell, key) {\n var ePointer = eBrowserCell;\n while (ePointer) {\n var data = this.gridOptionsWrapper.getDomData(ePointer, key);\n if (data) {\n return false;\n }\n ePointer = ePointer.parentNode;\n }\n return true;\n };\n FocusService.prototype.clearFocusedCell = function () {\n this.focusedCellPosition = null;\n this.onCellFocused(false, false);\n };\n FocusService.prototype.getFocusedCell = function () {\n return this.focusedCellPosition;\n };\n FocusService.prototype.setFocusedCell = function (params) {\n var column = params.column, rowIndex = params.rowIndex, rowPinned = params.rowPinned, _a = params.forceBrowserFocus, forceBrowserFocus = _a === void 0 ? false : _a, _b = params.preventScrollOnBrowserFocus, preventScrollOnBrowserFocus = _b === void 0 ? false : _b;\n var gridColumn = this.columnModel.getGridColumn(column);\n // if column doesn't exist, then blank the focused cell and return. this can happen when user sets new columns,\n // and the focused cell is in a column that no longer exists. after columns change, the grid refreshes and tries\n // to re-focus the focused cell.\n if (!gridColumn) {\n this.focusedCellPosition = null;\n return;\n }\n this.focusedCellPosition = gridColumn ? {\n rowIndex: rowIndex,\n rowPinned: makeNull(rowPinned),\n column: gridColumn\n } : null;\n this.onCellFocused(forceBrowserFocus, preventScrollOnBrowserFocus);\n };\n FocusService.prototype.isCellFocused = function (cellPosition) {\n if (this.focusedCellPosition == null) {\n return false;\n }\n return this.focusedCellPosition.column === cellPosition.column &&\n this.isRowFocused(cellPosition.rowIndex, cellPosition.rowPinned);\n };\n FocusService.prototype.isRowNodeFocused = function (rowNode) {\n return this.isRowFocused(rowNode.rowIndex, rowNode.rowPinned);\n };\n FocusService.prototype.isHeaderWrapperFocused = function (headerCtrl) {\n if (this.focusedHeaderPosition == null) {\n return false;\n }\n var column = headerCtrl.getColumnGroupChild();\n var headerRowIndex = headerCtrl.getRowIndex();\n var pinned = headerCtrl.getPinned();\n var _a = this.focusedHeaderPosition, focusedColumn = _a.column, focusedHeaderRowIndex = _a.headerRowIndex;\n return column === focusedColumn &&\n headerRowIndex === focusedHeaderRowIndex &&\n pinned == focusedColumn.getPinned();\n };\n FocusService.prototype.clearFocusedHeader = function () {\n this.focusedHeaderPosition = null;\n };\n FocusService.prototype.getFocusedHeader = function () {\n return this.focusedHeaderPosition;\n };\n FocusService.prototype.setFocusedHeader = function (headerRowIndex, column) {\n this.focusedHeaderPosition = { headerRowIndex: headerRowIndex, column: column };\n };\n FocusService.prototype.focusHeaderPosition = function (params) {\n var direction = params.direction, fromTab = params.fromTab, allowUserOverride = params.allowUserOverride, event = params.event;\n var headerPosition = params.headerPosition;\n if (allowUserOverride) {\n var gridOptionsWrapper = this.gridOptionsWrapper;\n var currentPosition = this.getFocusedHeader();\n var headerRowCount = this.headerNavigationService.getHeaderRowCount();\n if (fromTab) {\n var userFunc = gridOptionsWrapper.getTabToNextHeaderFunc();\n if (userFunc) {\n var params_1 = {\n backwards: direction === 'Before',\n previousHeaderPosition: currentPosition,\n nextHeaderPosition: headerPosition,\n headerRowCount: headerRowCount,\n };\n headerPosition = userFunc(params_1);\n }\n }\n else {\n var userFunc = gridOptionsWrapper.getNavigateToNextHeaderFunc();\n if (userFunc && event) {\n var params_2 = {\n key: event.key,\n previousHeaderPosition: currentPosition,\n nextHeaderPosition: headerPosition,\n headerRowCount: headerRowCount,\n event: event,\n };\n headerPosition = userFunc(params_2);\n }\n }\n }\n if (!headerPosition) {\n return false;\n }\n if (headerPosition.headerRowIndex === -1) {\n return this.focusGridView(headerPosition.column);\n }\n this.headerNavigationService.scrollToColumn(headerPosition.column, direction);\n var headerRowContainerCtrl = this.ctrlsService.getHeaderRowContainerCtrl(headerPosition.column.getPinned());\n // this will automatically call the setFocusedHeader method above\n var focusSuccess = headerRowContainerCtrl.focusHeader(headerPosition.headerRowIndex, headerPosition.column, event);\n return focusSuccess;\n };\n FocusService.prototype.focusFirstHeader = function () {\n var firstColumn = this.columnModel.getAllDisplayedColumns()[0];\n if (!firstColumn) {\n return false;\n }\n if (firstColumn.getParent()) {\n firstColumn = this.columnModel.getColumnGroupAtLevel(firstColumn, 0);\n }\n return this.focusHeaderPosition({\n headerPosition: { headerRowIndex: 0, column: firstColumn }\n });\n };\n FocusService.prototype.focusLastHeader = function (event) {\n var headerRowIndex = this.headerNavigationService.getHeaderRowCount() - 1;\n var column = last(this.columnModel.getAllDisplayedColumns());\n return this.focusHeaderPosition({\n headerPosition: { headerRowIndex: headerRowIndex, column: column },\n event: event\n });\n };\n FocusService.prototype.isAnyCellFocused = function () {\n return !!this.focusedCellPosition;\n };\n FocusService.prototype.isRowFocused = function (rowIndex, floating) {\n if (this.focusedCellPosition == null) {\n return false;\n }\n return this.focusedCellPosition.rowIndex === rowIndex && this.focusedCellPosition.rowPinned === makeNull(floating);\n };\n FocusService.prototype.findFocusableElements = function (rootNode, exclude, onlyUnmanaged) {\n if (onlyUnmanaged === void 0) { onlyUnmanaged = false; }\n var focusableString = Constants.FOCUSABLE_SELECTOR;\n var excludeString = Constants.FOCUSABLE_EXCLUDE;\n if (exclude) {\n excludeString += ', ' + exclude;\n }\n if (onlyUnmanaged) {\n excludeString += ', [tabindex=\"-1\"]';\n }\n var nodes = Array.prototype.slice.apply(rootNode.querySelectorAll(focusableString));\n var excludeNodes = Array.prototype.slice.apply(rootNode.querySelectorAll(excludeString));\n if (!excludeNodes.length) {\n return nodes;\n }\n var diff = function (a, b) { return a.filter(function (element) { return b.indexOf(element) === -1; }); };\n return diff(nodes, excludeNodes);\n };\n FocusService.prototype.focusInto = function (rootNode, up, onlyUnmanaged) {\n if (up === void 0) { up = false; }\n if (onlyUnmanaged === void 0) { onlyUnmanaged = false; }\n var focusableElements = this.findFocusableElements(rootNode, null, onlyUnmanaged);\n var toFocus = up ? last(focusableElements) : focusableElements[0];\n if (toFocus) {\n toFocus.focus();\n return true;\n }\n return false;\n };\n FocusService.prototype.findNextFocusableElement = function (rootNode, onlyManaged, backwards) {\n if (rootNode === void 0) { rootNode = this.eGridDiv; }\n var focusable = this.findFocusableElements(rootNode, onlyManaged ? ':not([tabindex=\"-1\"])' : null);\n var eDocument = this.gridOptionsWrapper.getDocument();\n var activeEl = eDocument.activeElement;\n var currentIndex;\n if (onlyManaged) {\n currentIndex = focusable.findIndex(function (el) { return el.contains(activeEl); });\n }\n else {\n currentIndex = focusable.indexOf(activeEl);\n }\n var nextIndex = currentIndex + (backwards ? -1 : 1);\n if (nextIndex < 0 || nextIndex >= focusable.length) {\n return null;\n }\n return focusable[nextIndex];\n };\n FocusService.prototype.isFocusUnderManagedComponent = function (rootNode) {\n var eDocument = this.gridOptionsWrapper.getDocument();\n var managedContainers = rootNode.querySelectorAll(\".\" + ManagedFocusFeature.FOCUS_MANAGED_CLASS);\n if (!managedContainers.length) {\n return false;\n }\n for (var i = 0; i < managedContainers.length; i++) {\n if (managedContainers[i].contains(eDocument.activeElement)) {\n return true;\n }\n }\n return false;\n };\n FocusService.prototype.findTabbableParent = function (node, limit) {\n if (limit === void 0) { limit = 5; }\n var counter = 0;\n while (node && getTabIndex(node) === null && ++counter <= limit) {\n node = node.parentElement;\n }\n if (getTabIndex(node) === null) {\n return null;\n }\n return node;\n };\n FocusService.prototype.onCellFocused = function (forceBrowserFocus, preventScrollOnBrowserFocus) {\n var event = {\n type: Events.EVENT_CELL_FOCUSED,\n forceBrowserFocus: forceBrowserFocus,\n preventScrollOnBrowserFocus: preventScrollOnBrowserFocus,\n rowIndex: null,\n column: null,\n floating: null,\n rowPinned: null,\n isFullWidthCell: false\n };\n if (this.focusedCellPosition) {\n var rowIndex = event.rowIndex = this.focusedCellPosition.rowIndex;\n var rowPinned = event.rowPinned = this.focusedCellPosition.rowPinned;\n event.column = this.focusedCellPosition.column;\n var rowCtrl = this.rowRenderer.getRowByPosition({ rowIndex: rowIndex, rowPinned: rowPinned });\n if (rowCtrl) {\n event.isFullWidthCell = rowCtrl.isFullWidth();\n }\n }\n this.eventService.dispatchEvent(event);\n };\n FocusService.prototype.focusGridView = function (column, backwards) {\n // if suppressCellFocus is `true`, it means the user does not want to\n // navigate between the cells using tab. Instead, we put focus on either\n // the header or after the grid, depending on whether tab or shift-tab was pressed.\n if (this.gridOptionsWrapper.isSuppressCellFocus()) {\n if (backwards) {\n return this.focusLastHeader();\n }\n return this.focusNextGridCoreContainer(false);\n }\n var nextRow = backwards\n ? this.rowPositionUtils.getLastRow()\n : this.rowPositionUtils.getFirstRow();\n if (!nextRow) {\n return false;\n }\n var rowIndex = nextRow.rowIndex, rowPinned = nextRow.rowPinned;\n var focusedHeader = this.getFocusedHeader();\n if (!column && focusedHeader) {\n column = focusedHeader.column;\n }\n if (rowIndex == null || !column) {\n return false;\n }\n this.navigationService.ensureCellVisible({ rowIndex: rowIndex, column: column, rowPinned: rowPinned });\n this.setFocusedCell({\n rowIndex: rowIndex,\n column: column,\n rowPinned: makeNull(rowPinned),\n forceBrowserFocus: true\n });\n if (this.rangeService) {\n var cellPosition = { rowIndex: rowIndex, rowPinned: rowPinned, column: column };\n this.rangeService.setRangeToCell(cellPosition);\n }\n return true;\n };\n FocusService.prototype.focusNextGridCoreContainer = function (backwards) {\n if (this.gridCtrl.focusNextInnerContainer(backwards)) {\n return true;\n }\n if (!backwards && !this.gridCtrl.isDetailGrid()) {\n this.gridCtrl.forceFocusOutOfContainer();\n }\n return false;\n };\n var FocusService_1;\n FocusService.AG_KEYBOARD_FOCUS = 'ag-keyboard-focus';\n FocusService.keyboardModeActive = false;\n FocusService.instancesMonitored = new Map();\n __decorate([\n Autowired('eGridDiv')\n ], FocusService.prototype, \"eGridDiv\", void 0);\n __decorate([\n Autowired('columnModel')\n ], FocusService.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('headerNavigationService')\n ], FocusService.prototype, \"headerNavigationService\", void 0);\n __decorate([\n Autowired('rowRenderer')\n ], FocusService.prototype, \"rowRenderer\", void 0);\n __decorate([\n Autowired('rowPositionUtils')\n ], FocusService.prototype, \"rowPositionUtils\", void 0);\n __decorate([\n Optional('rangeService')\n ], FocusService.prototype, \"rangeService\", void 0);\n __decorate([\n Autowired('navigationService')\n ], FocusService.prototype, \"navigationService\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], FocusService.prototype, \"ctrlsService\", void 0);\n __decorate([\n PostConstruct\n ], FocusService.prototype, \"init\", null);\n FocusService = FocusService_1 = __decorate([\n Bean('focusService')\n ], FocusService);\n return FocusService;\n}(BeanStub));\nexport { FocusService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nimport { Autowired, Bean, PostConstruct } from \"../context/context\";\nimport { Events } from '../events';\nimport { BeanStub } from \"../context/beanStub\";\nimport { getAbsoluteHeight, getAbsoluteWidth } from '../utils/dom';\nimport { last } from '../utils/array';\nimport { isElementInEventPath } from '../utils/event';\nimport { KeyCode } from '../constants/keyCode';\nimport { FocusService } from \"../focusService\";\nimport { AgPromise } from \"../utils\";\nimport { setAriaLabel, setAriaRole } from \"../utils/aria\";\nvar DIRECTION;\n(function (DIRECTION) {\n DIRECTION[DIRECTION[\"vertical\"] = 0] = \"vertical\";\n DIRECTION[DIRECTION[\"horizontal\"] = 1] = \"horizontal\";\n})(DIRECTION || (DIRECTION = {}));\nvar instanceIdSeq = 0;\nvar PopupService = /** @class */ (function (_super) {\n __extends(PopupService, _super);\n function PopupService() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.popupList = [];\n return _this;\n }\n PopupService.prototype.postConstruct = function () {\n var _this = this;\n this.ctrlsService.whenReady(function (p) {\n _this.gridCtrl = p.gridCtrl;\n _this.addManagedListener(_this.gridCtrl, Events.EVENT_KEYBOARD_FOCUS, function () {\n _this.popupList.forEach(function (popup) { return popup.element.classList.add(FocusService.AG_KEYBOARD_FOCUS); });\n });\n _this.addManagedListener(_this.gridCtrl, Events.EVENT_MOUSE_FOCUS, function () {\n _this.popupList.forEach(function (popup) { return popup.element.classList.remove(FocusService.AG_KEYBOARD_FOCUS); });\n });\n });\n };\n PopupService.prototype.getPopupParent = function () {\n var ePopupParent = this.gridOptionsWrapper.getPopupParent();\n if (ePopupParent) {\n return ePopupParent;\n }\n return this.gridCtrl.getGui();\n };\n PopupService.prototype.positionPopupForMenu = function (params) {\n var sourceRect = params.eventSource.getBoundingClientRect();\n var parentRect = this.getParentRect();\n var y = this.keepXYWithinBounds(params.ePopup, sourceRect.top - parentRect.top, DIRECTION.vertical);\n var minWidth = (params.ePopup.clientWidth > 0) ? params.ePopup.clientWidth : 200;\n params.ePopup.style.minWidth = minWidth + \"px\";\n var widthOfParent = parentRect.right - parentRect.left;\n var maxX = widthOfParent - minWidth;\n // the x position of the popup depends on RTL or LTR. for normal cases, LTR, we put the child popup\n // to the right, unless it doesn't fit and we then put it to the left. for RTL it's the other way around,\n // we try place it first to the left, and then if not to the right.\n var x;\n if (this.gridOptionsWrapper.isEnableRtl()) {\n // for RTL, try left first\n x = xLeftPosition();\n if (x < 0) {\n x = xRightPosition();\n }\n if (x > maxX) {\n x = 0;\n }\n }\n else {\n // for LTR, try right first\n x = xRightPosition();\n if (x > maxX) {\n x = xLeftPosition();\n }\n if (x < 0) {\n x = 0;\n }\n }\n params.ePopup.style.left = x + \"px\";\n params.ePopup.style.top = y + \"px\";\n function xRightPosition() {\n return sourceRect.right - parentRect.left - 2;\n }\n function xLeftPosition() {\n return sourceRect.left - parentRect.left - minWidth;\n }\n };\n PopupService.prototype.positionPopupUnderMouseEvent = function (params) {\n var ePopup = params.ePopup, nudgeX = params.nudgeX, nudgeY = params.nudgeY;\n var _a = this.calculatePointerAlign(params.mouseEvent), x = _a.x, y = _a.y;\n this.positionPopup({\n ePopup: ePopup,\n x: x,\n y: y,\n nudgeX: nudgeX,\n nudgeY: nudgeY,\n keepWithinBounds: true\n });\n this.callPostProcessPopup(params.type, params.ePopup, null, params.mouseEvent, params.column, params.rowNode);\n };\n PopupService.prototype.calculatePointerAlign = function (e) {\n var parentRect = this.getParentRect();\n return {\n x: e.clientX - parentRect.left,\n y: e.clientY - parentRect.top\n };\n };\n PopupService.prototype.positionPopupUnderComponent = function (params) {\n var sourceRect = params.eventSource.getBoundingClientRect();\n var alignSide = params.alignSide || 'left';\n var parentRect = this.getParentRect();\n var x = sourceRect.left - parentRect.left;\n if (alignSide === 'right') {\n x -= (params.ePopup.offsetWidth - sourceRect.width);\n }\n this.positionPopup({\n ePopup: params.ePopup,\n nudgeX: params.nudgeX,\n nudgeY: params.nudgeY,\n x: x,\n y: sourceRect.top - parentRect.top + sourceRect.height,\n keepWithinBounds: params.keepWithinBounds\n });\n this.callPostProcessPopup(params.type, params.ePopup, params.eventSource, null, params.column, params.rowNode);\n };\n PopupService.prototype.positionPopupOverComponent = function (params) {\n var sourceRect = params.eventSource.getBoundingClientRect();\n var parentRect = this.getParentRect();\n this.positionPopup({\n ePopup: params.ePopup,\n nudgeX: params.nudgeX,\n nudgeY: params.nudgeY,\n x: sourceRect.left - parentRect.left,\n y: sourceRect.top - parentRect.top,\n keepWithinBounds: params.keepWithinBounds\n });\n this.callPostProcessPopup(params.type, params.ePopup, params.eventSource, null, params.column, params.rowNode);\n };\n PopupService.prototype.callPostProcessPopup = function (type, ePopup, eventSource, mouseEvent, column, rowNode) {\n var callback = this.gridOptionsWrapper.getPostProcessPopupFunc();\n if (callback) {\n var params = {\n column: column,\n rowNode: rowNode,\n ePopup: ePopup,\n type: type,\n eventSource: eventSource,\n mouseEvent: mouseEvent\n };\n callback(params);\n }\n };\n PopupService.prototype.positionPopup = function (params) {\n var ePopup = params.ePopup, keepWithinBounds = params.keepWithinBounds, nudgeX = params.nudgeX, nudgeY = params.nudgeY;\n var x = params.x, y = params.y;\n if (nudgeX) {\n x += nudgeX;\n }\n if (nudgeY) {\n y += nudgeY;\n }\n // if popup is overflowing to the bottom, move it up\n if (keepWithinBounds) {\n x = this.keepXYWithinBounds(ePopup, x, DIRECTION.horizontal);\n y = this.keepXYWithinBounds(ePopup, y, DIRECTION.vertical);\n }\n ePopup.style.left = x + \"px\";\n ePopup.style.top = y + \"px\";\n };\n PopupService.prototype.getActivePopups = function () {\n return this.popupList.map(function (popup) { return popup.element; });\n };\n PopupService.prototype.getPopupList = function () {\n return this.popupList;\n };\n PopupService.prototype.getParentRect = function () {\n // subtract the popup parent borders, because popupParent.getBoundingClientRect\n // returns the rect outside the borders, but the 0,0 coordinate for absolute\n // positioning is inside the border, leading the popup to be off by the width\n // of the border\n var eDocument = this.gridOptionsWrapper.getDocument();\n var popupParent = this.getPopupParent();\n if (popupParent === eDocument.body) {\n popupParent = eDocument.documentElement;\n }\n else if (getComputedStyle(popupParent).position === 'static') {\n popupParent = popupParent.offsetParent;\n }\n var style = getComputedStyle(popupParent);\n var bounds = popupParent.getBoundingClientRect();\n return {\n top: bounds.top + parseFloat(style.borderTopWidth) || 0,\n left: bounds.left + parseFloat(style.borderLeftWidth) || 0,\n right: bounds.right + parseFloat(style.borderRightWidth) || 0,\n bottom: bounds.bottom + parseFloat(style.borderBottomWidth) || 0,\n };\n };\n PopupService.prototype.keepXYWithinBounds = function (ePopup, position, direction) {\n var isVertical = direction === DIRECTION.vertical;\n var sizeProperty = isVertical ? 'clientHeight' : 'clientWidth';\n var anchorProperty = isVertical ? 'top' : 'left';\n var offsetProperty = isVertical ? 'offsetHeight' : 'offsetWidth';\n var scrollPositionProperty = isVertical ? 'scrollTop' : 'scrollLeft';\n var eDocument = this.gridOptionsWrapper.getDocument();\n var docElement = eDocument.documentElement;\n var popupParent = this.getPopupParent();\n var parentRect = popupParent.getBoundingClientRect();\n var documentRect = eDocument.documentElement.getBoundingClientRect();\n var isBody = popupParent === eDocument.body;\n var offsetSize = ePopup[offsetProperty];\n var getSize = isVertical ? getAbsoluteHeight : getAbsoluteWidth;\n var sizeOfParent = isBody ? (getSize(docElement) + docElement[scrollPositionProperty]) : popupParent[sizeProperty];\n if (isBody) {\n sizeOfParent -= Math.abs(documentRect[anchorProperty] - parentRect[anchorProperty]);\n }\n var max = sizeOfParent - offsetSize;\n return Math.min(Math.max(position, 0), Math.abs(max));\n };\n PopupService.prototype.keepPopupPositionedRelativeTo = function (params) {\n var _this = this;\n var eParent = this.getPopupParent();\n var parentRect = eParent.getBoundingClientRect();\n var sourceRect = params.element.getBoundingClientRect();\n var initialDiffTop = parentRect.top - sourceRect.top;\n var initialDiffLeft = parentRect.left - sourceRect.left;\n var lastDiffTop = initialDiffTop;\n var lastDiffLeft = initialDiffLeft;\n var topPx = params.ePopup.style.top;\n var top = parseInt(topPx.substring(0, topPx.length - 1), 10);\n var leftPx = params.ePopup.style.left;\n var left = parseInt(leftPx.substring(0, leftPx.length - 1), 10);\n return new AgPromise(function (resolve) {\n _this.getFrameworkOverrides().setInterval(function () {\n var pRect = eParent.getBoundingClientRect();\n var sRect = params.element.getBoundingClientRect();\n var elementNotInDom = sRect.top == 0 && sRect.left == 0 && sRect.height == 0 && sRect.width == 0;\n if (elementNotInDom) {\n params.hidePopup();\n return;\n }\n var currentDiffTop = pRect.top - sRect.top;\n if (currentDiffTop != lastDiffTop) {\n var newTop = _this.keepXYWithinBounds(params.ePopup, top + initialDiffTop - currentDiffTop, DIRECTION.vertical);\n params.ePopup.style.top = newTop + \"px\";\n }\n lastDiffTop = currentDiffTop;\n var currentDiffLeft = pRect.left - sRect.left;\n if (currentDiffLeft != lastDiffLeft) {\n var newLeft = _this.keepXYWithinBounds(params.ePopup, left + initialDiffLeft - currentDiffLeft, DIRECTION.horizontal);\n params.ePopup.style.left = newLeft + \"px\";\n }\n lastDiffLeft = currentDiffLeft;\n }, 200).then(function (intervalId) {\n var result = function () {\n if (intervalId != null) {\n window.clearInterval(intervalId);\n }\n };\n resolve(result);\n });\n });\n };\n PopupService.prototype.addPopup = function (params) {\n var _a;\n var _this = this;\n var modal = params.modal, eChild = params.eChild, closeOnEsc = params.closeOnEsc, closedCallback = params.closedCallback, click = params.click, alwaysOnTop = params.alwaysOnTop, afterGuiAttached = params.afterGuiAttached, positionCallback = params.positionCallback, anchorToElement = params.anchorToElement, ariaLabel = params.ariaLabel;\n var eDocument = this.gridOptionsWrapper.getDocument();\n var destroyPositionTracker = new AgPromise(function (resolve) { return resolve(function () { }); });\n if (!eDocument) {\n console.warn('ag-grid: could not find the document, document is empty');\n return { hideFunc: function () { }, stopAnchoringPromise: destroyPositionTracker };\n }\n var pos = this.popupList.findIndex(function (popup) { return popup.element === eChild; });\n if (pos !== -1) {\n var popup = this.popupList[pos];\n return { hideFunc: popup.hideFunc, stopAnchoringPromise: popup.stopAnchoringPromise };\n }\n var ePopupParent = this.getPopupParent();\n if (eChild.style.top == null) {\n eChild.style.top = '0px';\n }\n if (eChild.style.left == null) {\n eChild.style.left = '0px';\n }\n // add env CSS class to child, in case user provided a popup parent, which means\n // theme class may be missing\n var eWrapper = document.createElement('div');\n var allThemes = this.environment.getTheme().allThemes;\n if (allThemes.length) {\n (_a = eWrapper.classList).add.apply(_a, __spread(allThemes));\n }\n eWrapper.classList.add('ag-popup');\n eChild.classList.add(this.gridOptionsWrapper.isEnableRtl() ? 'ag-rtl' : 'ag-ltr', 'ag-popup-child');\n if (!eChild.hasAttribute('role')) {\n setAriaRole(eChild, 'dialog');\n }\n setAriaLabel(eChild, ariaLabel);\n if (this.focusService.isKeyboardMode()) {\n eChild.classList.add(FocusService.AG_KEYBOARD_FOCUS);\n }\n eWrapper.appendChild(eChild);\n ePopupParent.appendChild(eWrapper);\n if (alwaysOnTop) {\n this.setAlwaysOnTop(eWrapper, true);\n }\n else {\n this.bringPopupToFront(eWrapper);\n }\n var popupHidden = false;\n var hidePopupOnKeyboardEvent = function (event) {\n if (!eWrapper.contains(eDocument.activeElement)) {\n return;\n }\n var key = event.key;\n if (key === KeyCode.ESCAPE) {\n hidePopup({ keyboardEvent: event });\n }\n };\n var hidePopupOnMouseEvent = function (event) { return hidePopup({ mouseEvent: event }); };\n var hidePopupOnTouchEvent = function (event) { return hidePopup({ touchEvent: event }); };\n var hidePopup = function (popupParams) {\n if (popupParams === void 0) { popupParams = {}; }\n var mouseEvent = popupParams.mouseEvent, touchEvent = popupParams.touchEvent, keyboardEvent = popupParams.keyboardEvent;\n if (\n // we don't hide popup if the event was on the child, or any\n // children of this child\n _this.isEventFromCurrentPopup({ mouseEvent: mouseEvent, touchEvent: touchEvent }, eChild) ||\n // if the event to close is actually the open event, then ignore it\n _this.isEventSameChainAsOriginalEvent({ originalMouseEvent: click, mouseEvent: mouseEvent, touchEvent: touchEvent }) ||\n // this method should only be called once. the client can have different\n // paths, each one wanting to close, so this method may be called multiple times.\n popupHidden) {\n return;\n }\n popupHidden = true;\n ePopupParent.removeChild(eWrapper);\n eDocument.removeEventListener('keydown', hidePopupOnKeyboardEvent);\n eDocument.removeEventListener('mousedown', hidePopupOnMouseEvent);\n eDocument.removeEventListener('touchstart', hidePopupOnTouchEvent);\n eDocument.removeEventListener('contextmenu', hidePopupOnMouseEvent);\n _this.eventService.removeEventListener(Events.EVENT_DRAG_STARTED, hidePopupOnMouseEvent);\n if (closedCallback) {\n closedCallback(mouseEvent || touchEvent || keyboardEvent);\n }\n _this.popupList = _this.popupList.filter(function (popup) { return popup.element !== eChild; });\n if (destroyPositionTracker) {\n destroyPositionTracker.then(function (destroyFunc) { return destroyFunc && destroyFunc(); });\n }\n };\n if (afterGuiAttached) {\n afterGuiAttached({ hidePopup: hidePopup });\n }\n // if we add these listeners now, then the current mouse\n // click will be included, which we don't want\n window.setTimeout(function () {\n if (closeOnEsc) {\n eDocument.addEventListener('keydown', hidePopupOnKeyboardEvent);\n }\n if (modal) {\n eDocument.addEventListener('mousedown', hidePopupOnMouseEvent);\n _this.eventService.addEventListener(Events.EVENT_DRAG_STARTED, hidePopupOnMouseEvent);\n eDocument.addEventListener('touchstart', hidePopupOnTouchEvent);\n eDocument.addEventListener('contextmenu', hidePopupOnMouseEvent);\n }\n }, 0);\n if (positionCallback) {\n positionCallback();\n }\n if (anchorToElement) {\n // keeps popup positioned under created, eg if context menu, if user scrolls\n // using touchpad and the cell moves, it moves the popup to keep it with the cell.\n destroyPositionTracker = this.keepPopupPositionedRelativeTo({\n element: anchorToElement,\n ePopup: eChild,\n hidePopup: hidePopup\n });\n }\n this.popupList.push({\n element: eChild,\n wrapper: eWrapper,\n hideFunc: hidePopup,\n stopAnchoringPromise: destroyPositionTracker,\n instanceId: instanceIdSeq++,\n isAnchored: !!anchorToElement\n });\n return {\n hideFunc: hidePopup,\n stopAnchoringPromise: destroyPositionTracker\n };\n };\n PopupService.prototype.hasAnchoredPopup = function () {\n return this.popupList.some(function (popup) { return popup.isAnchored; });\n };\n PopupService.prototype.isEventFromCurrentPopup = function (params, target) {\n var mouseEvent = params.mouseEvent, touchEvent = params.touchEvent;\n var event = mouseEvent ? mouseEvent : touchEvent;\n if (!event) {\n return false;\n }\n var indexOfThisChild = this.popupList.findIndex(function (popup) { return popup.element === target; });\n if (indexOfThisChild === -1) {\n return false;\n }\n for (var i = indexOfThisChild; i < this.popupList.length; i++) {\n var popup = this.popupList[i];\n if (isElementInEventPath(popup.element, event)) {\n return true;\n }\n }\n // if the user did not write their own Custom Element to be rendered as popup\n // and this component has an additional popup element, they should have the\n // `ag-custom-component-popup` class to be detected as part of the Custom Component\n return this.isElementWithinCustomPopup(event.target);\n };\n PopupService.prototype.isElementWithinCustomPopup = function (el) {\n var eDocument = this.gridOptionsWrapper.getDocument();\n while (el && el !== eDocument.body) {\n if (el.classList.contains('ag-custom-component-popup') || el.parentElement === null) {\n return true;\n }\n el = el.parentElement;\n }\n return false;\n };\n // in some browsers, the context menu event can be fired before the click event, which means\n // the context menu event could open the popup, but then the click event closes it straight away.\n PopupService.prototype.isEventSameChainAsOriginalEvent = function (params) {\n var originalMouseEvent = params.originalMouseEvent, mouseEvent = params.mouseEvent, touchEvent = params.touchEvent;\n // we check the coordinates of the event, to see if it's the same event. there is a 1 / 1000 chance that\n // the event is a different event, however that is an edge case that is not very relevant (the user clicking\n // twice on the same location isn't a normal path).\n // event could be mouse event or touch event.\n var mouseEventOrTouch = null;\n if (mouseEvent) {\n // mouse event can be used direction, it has coordinates\n mouseEventOrTouch = mouseEvent;\n }\n else if (touchEvent) {\n // touch event doesn't have coordinates, need it's touch object\n mouseEventOrTouch = touchEvent.touches[0];\n }\n if (mouseEventOrTouch && originalMouseEvent) {\n // for x, allow 4px margin, to cover iPads, where touch (which opens menu) is followed\n // by browser click (when you finger up, touch is interrupted as click in browser)\n var screenX_1 = mouseEvent ? mouseEvent.screenX : 0;\n var screenY_1 = mouseEvent ? mouseEvent.screenY : 0;\n var xMatch = Math.abs(originalMouseEvent.screenX - screenX_1) < 5;\n var yMatch = Math.abs(originalMouseEvent.screenY - screenY_1) < 5;\n if (xMatch && yMatch) {\n return true;\n }\n }\n return false;\n };\n PopupService.prototype.getWrapper = function (ePopup) {\n while (!ePopup.classList.contains('ag-popup') && ePopup.parentElement) {\n ePopup = ePopup.parentElement;\n }\n return ePopup.classList.contains('ag-popup') ? ePopup : null;\n };\n PopupService.prototype.setAlwaysOnTop = function (ePopup, alwaysOnTop) {\n var eWrapper = this.getWrapper(ePopup);\n if (!eWrapper) {\n return;\n }\n eWrapper.classList.toggle('ag-always-on-top', !!alwaysOnTop);\n if (alwaysOnTop) {\n this.bringPopupToFront(eWrapper);\n }\n };\n PopupService.prototype.bringPopupToFront = function (ePopup) {\n var parent = this.getPopupParent();\n var popupList = Array.prototype.slice.call(parent.querySelectorAll('.ag-popup'));\n var popupLen = popupList.length;\n var alwaysOnTopList = Array.prototype.slice.call(parent.querySelectorAll('.ag-popup.ag-always-on-top'));\n var onTopLength = alwaysOnTopList.length;\n var eWrapper = this.getWrapper(ePopup);\n if (!eWrapper || popupLen <= 1 || !parent.contains(ePopup)) {\n return;\n }\n var pos = popupList.indexOf(eWrapper);\n var innerEls = eWrapper.querySelectorAll('div');\n var innerElsScrollMap = [];\n innerEls.forEach(function (el) {\n if (el.scrollTop !== 0) {\n innerElsScrollMap.push([el, el.scrollTop]);\n }\n });\n if (onTopLength) {\n var isPopupAlwaysOnTop = eWrapper.classList.contains('ag-always-on-top');\n if (isPopupAlwaysOnTop) {\n if (pos !== popupLen - 1) {\n last(alwaysOnTopList).insertAdjacentElement('afterend', eWrapper);\n }\n }\n else if (pos !== popupLen - onTopLength - 1) {\n alwaysOnTopList[0].insertAdjacentElement('beforebegin', eWrapper);\n }\n }\n else if (pos !== popupLen - 1) {\n last(popupList).insertAdjacentElement('afterend', eWrapper);\n }\n while (innerElsScrollMap.length) {\n var currentEl = innerElsScrollMap.pop();\n currentEl[0].scrollTop = currentEl[1];\n }\n var params = {\n type: 'popupToFront',\n api: this.gridOptionsWrapper.getApi(),\n columnApi: this.gridOptionsWrapper.getColumnApi(),\n eWrapper: eWrapper\n };\n this.eventService.dispatchEvent(params);\n };\n __decorate([\n Autowired('environment')\n ], PopupService.prototype, \"environment\", void 0);\n __decorate([\n Autowired('focusService')\n ], PopupService.prototype, \"focusService\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], PopupService.prototype, \"ctrlsService\", void 0);\n __decorate([\n PostConstruct\n ], PopupService.prototype, \"postConstruct\", null);\n PopupService = __decorate([\n Bean('popupService')\n ], PopupService);\n return PopupService;\n}(BeanStub));\nexport { PopupService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from '../context/context';\nimport { RefSelector } from './componentAnnotations';\nimport { getAriaPosInSet, setAriaSetSize, setAriaPosInSet, setAriaSelected, setAriaChecked, setAriaRole, setAriaLabel } from '../utils/aria';\nimport { KeyCode } from '../constants/keyCode';\nimport { waitUntil } from '../utils/function';\nimport { TabGuardComp } from './tabGuardComp';\nvar VirtualList = /** @class */ (function (_super) {\n __extends(VirtualList, _super);\n function VirtualList(cssIdentifier, ariaRole, listName) {\n if (cssIdentifier === void 0) { cssIdentifier = 'default'; }\n if (ariaRole === void 0) { ariaRole = 'listbox'; }\n var _this = _super.call(this, VirtualList.getTemplate(cssIdentifier)) || this;\n _this.cssIdentifier = cssIdentifier;\n _this.ariaRole = ariaRole;\n _this.listName = listName;\n _this.renderedRows = new Map();\n _this.rowHeight = 20;\n _this.isDestroyed = false;\n return _this;\n }\n VirtualList.prototype.postConstruct = function () {\n var _this = this;\n this.addScrollListener();\n this.rowHeight = this.getItemHeight();\n this.addResizeObserver();\n this.initialiseTabGuard({\n onFocusIn: function (e) { return _this.onFocusIn(e); },\n onFocusOut: function (e) { return _this.onFocusOut(e); },\n focusInnerElement: function (fromBottom) { return _this.focusInnerElement(fromBottom); },\n onTabKeyDown: function (e) { return _this.onTabKeyDown(e); },\n handleKeyDown: function (e) { return _this.handleKeyDown(e); }\n });\n this.setAriaProperties();\n };\n VirtualList.prototype.setAriaProperties = function () {\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n var listName = translate('ariaDefaultListName', this.listName || 'List');\n var ariaEl = this.eContainer;\n setAriaRole(ariaEl, this.ariaRole);\n setAriaLabel(ariaEl, listName);\n };\n VirtualList.prototype.addResizeObserver = function () {\n var listener = this.drawVirtualRows.bind(this);\n var destroyObserver = this.resizeObserverService.observeResize(this.getGui(), listener);\n this.addDestroyFunc(destroyObserver);\n };\n VirtualList.prototype.focusInnerElement = function (fromBottom) {\n this.focusRow(fromBottom ? this.model.getRowCount() - 1 : 0);\n };\n VirtualList.prototype.onFocusIn = function (e) {\n var target = e.target;\n if (target.classList.contains('ag-virtual-list-item')) {\n this.lastFocusedRowIndex = getAriaPosInSet(target) - 1;\n }\n return false;\n };\n VirtualList.prototype.onFocusOut = function (e) {\n if (!this.getFocusableElement().contains(e.relatedTarget)) {\n this.lastFocusedRowIndex = null;\n }\n return false;\n };\n VirtualList.prototype.handleKeyDown = function (e) {\n switch (e.key) {\n case KeyCode.UP:\n case KeyCode.DOWN:\n if (this.navigate(e.key === KeyCode.UP)) {\n e.preventDefault();\n }\n break;\n }\n };\n VirtualList.prototype.onTabKeyDown = function (e) {\n if (this.navigate(e.shiftKey)) {\n e.preventDefault();\n }\n else {\n // focus on the first or last focusable element to ensure that any other handlers start from there\n this.focusService.focusInto(this.getGui(), !e.shiftKey);\n }\n };\n VirtualList.prototype.navigate = function (up) {\n if (this.lastFocusedRowIndex == null) {\n return false;\n }\n var nextRow = this.lastFocusedRowIndex + (up ? -1 : 1);\n if (nextRow < 0 || nextRow >= this.model.getRowCount()) {\n return false;\n }\n this.focusRow(nextRow);\n return true;\n };\n VirtualList.prototype.getLastFocusedRow = function () {\n return this.lastFocusedRowIndex;\n };\n VirtualList.prototype.focusRow = function (rowNumber) {\n var _this = this;\n this.ensureIndexVisible(rowNumber);\n window.setTimeout(function () {\n var renderedRow = _this.renderedRows.get(rowNumber);\n if (renderedRow) {\n renderedRow.eDiv.focus();\n }\n }, 10);\n };\n VirtualList.prototype.getComponentAt = function (rowIndex) {\n var comp = this.renderedRows.get(rowIndex);\n return comp && comp.rowComponent;\n };\n VirtualList.prototype.forEachRenderedRow = function (func) {\n this.renderedRows.forEach(function (value, key) { return func(value.rowComponent, key); });\n };\n VirtualList.getTemplate = function (cssIdentifier) {\n return /* html */ \"\\n
\\n
\\n
\";\n };\n VirtualList.prototype.getItemHeight = function () {\n return this.gridOptionsWrapper.getListItemHeight();\n };\n VirtualList.prototype.ensureIndexVisible = function (index) {\n var lastRow = this.model.getRowCount();\n if (typeof index !== 'number' || index < 0 || index >= lastRow) {\n console.warn('AG Grid: invalid row index for ensureIndexVisible: ' + index);\n return;\n }\n var rowTopPixel = index * this.rowHeight;\n var rowBottomPixel = rowTopPixel + this.rowHeight;\n var eGui = this.getGui();\n var viewportTopPixel = eGui.scrollTop;\n var viewportHeight = eGui.offsetHeight;\n var viewportBottomPixel = viewportTopPixel + viewportHeight;\n var viewportScrolledPastRow = viewportTopPixel > rowTopPixel;\n var viewportScrolledBeforeRow = viewportBottomPixel < rowBottomPixel;\n if (viewportScrolledPastRow) {\n // if row is before, scroll up with row at top\n eGui.scrollTop = rowTopPixel;\n }\n else if (viewportScrolledBeforeRow) {\n // if row is below, scroll down with row at bottom\n var newScrollPosition = rowBottomPixel - viewportHeight;\n eGui.scrollTop = newScrollPosition;\n }\n };\n VirtualList.prototype.setComponentCreator = function (componentCreator) {\n this.componentCreator = componentCreator;\n };\n VirtualList.prototype.getRowHeight = function () {\n return this.rowHeight;\n };\n VirtualList.prototype.getScrollTop = function () {\n return this.getGui().scrollTop;\n };\n VirtualList.prototype.setRowHeight = function (rowHeight) {\n this.rowHeight = rowHeight;\n this.refresh();\n };\n VirtualList.prototype.refresh = function () {\n var _this = this;\n if (this.model == null || this.isDestroyed) {\n return;\n }\n var rowCount = this.model.getRowCount();\n this.eContainer.style.height = rowCount * this.rowHeight + \"px\";\n // ensure height is applied before attempting to redraw rows\n waitUntil(function () { return _this.eContainer.clientHeight >= rowCount * _this.rowHeight; }, function () {\n if (_this.isDestroyed) {\n return;\n }\n _this.clearVirtualRows();\n _this.drawVirtualRows();\n });\n };\n VirtualList.prototype.clearVirtualRows = function () {\n var _this = this;\n this.renderedRows.forEach(function (_, rowIndex) { return _this.removeRow(rowIndex); });\n };\n VirtualList.prototype.drawVirtualRows = function () {\n if (!this.isAlive()) {\n return;\n }\n var gui = this.getGui();\n var topPixel = gui.scrollTop;\n var bottomPixel = topPixel + gui.offsetHeight;\n var firstRow = Math.floor(topPixel / this.rowHeight);\n var lastRow = Math.floor(bottomPixel / this.rowHeight);\n this.ensureRowsRendered(firstRow, lastRow);\n };\n VirtualList.prototype.ensureRowsRendered = function (start, finish) {\n var _this = this;\n // remove any rows that are no longer required\n this.renderedRows.forEach(function (_, rowIndex) {\n if ((rowIndex < start || rowIndex > finish) && rowIndex !== _this.lastFocusedRowIndex) {\n _this.removeRow(rowIndex);\n }\n });\n // insert any required new rows\n for (var rowIndex = start; rowIndex <= finish; rowIndex++) {\n if (this.renderedRows.has(rowIndex)) {\n continue;\n }\n // check this row actually exists (in case overflow buffer window exceeds real data)\n if (rowIndex < this.model.getRowCount()) {\n this.insertRow(rowIndex);\n }\n }\n };\n VirtualList.prototype.insertRow = function (rowIndex) {\n var _this = this;\n var value = this.model.getRow(rowIndex);\n var eDiv = document.createElement('div');\n eDiv.classList.add('ag-virtual-list-item', \"ag-\" + this.cssIdentifier + \"-virtual-list-item\");\n setAriaRole(eDiv, this.ariaRole === 'tree' ? 'treeitem' : 'option');\n setAriaSetSize(eDiv, this.model.getRowCount());\n setAriaPosInSet(eDiv, rowIndex + 1);\n eDiv.setAttribute('tabindex', '-1');\n if (typeof this.model.isRowSelected === 'function') {\n var isSelected = this.model.isRowSelected(rowIndex);\n setAriaSelected(eDiv, !!isSelected);\n setAriaChecked(eDiv, isSelected);\n }\n eDiv.style.height = this.rowHeight + \"px\";\n eDiv.style.top = this.rowHeight * rowIndex + \"px\";\n var rowComponent = this.componentCreator(value, eDiv);\n rowComponent.addGuiEventListener('focusin', function () { return _this.lastFocusedRowIndex = rowIndex; });\n eDiv.appendChild(rowComponent.getGui());\n // keep the DOM order consistent with the order of the rows\n if (this.renderedRows.has(rowIndex - 1)) {\n this.renderedRows.get(rowIndex - 1).eDiv.insertAdjacentElement('afterend', eDiv);\n }\n else if (this.renderedRows.has(rowIndex + 1)) {\n this.renderedRows.get(rowIndex + 1).eDiv.insertAdjacentElement('beforebegin', eDiv);\n }\n else {\n this.eContainer.appendChild(eDiv);\n }\n this.renderedRows.set(rowIndex, { rowComponent: rowComponent, eDiv: eDiv });\n };\n VirtualList.prototype.removeRow = function (rowIndex) {\n var component = this.renderedRows.get(rowIndex);\n this.eContainer.removeChild(component.eDiv);\n this.destroyBean(component.rowComponent);\n this.renderedRows.delete(rowIndex);\n };\n VirtualList.prototype.addScrollListener = function () {\n var _this = this;\n this.addGuiEventListener('scroll', function () { return _this.drawVirtualRows(); });\n };\n VirtualList.prototype.setModel = function (model) {\n this.model = model;\n };\n VirtualList.prototype.destroy = function () {\n if (this.isDestroyed) {\n return;\n }\n this.clearVirtualRows();\n this.isDestroyed = true;\n _super.prototype.destroy.call(this);\n };\n __decorate([\n Autowired('resizeObserverService')\n ], VirtualList.prototype, \"resizeObserverService\", void 0);\n __decorate([\n Autowired('focusService')\n ], VirtualList.prototype, \"focusService\", void 0);\n __decorate([\n RefSelector('eContainer')\n ], VirtualList.prototype, \"eContainer\", void 0);\n __decorate([\n PostConstruct\n ], VirtualList.prototype, \"postConstruct\", null);\n return VirtualList;\n}(TabGuardComp));\nexport { VirtualList };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nimport { includes } from \"./utils/array\";\nimport { AgPromise } from \"./utils\";\nvar OUTSIDE_ANGULAR_EVENTS = ['mouseover', 'mouseout', 'mouseenter', 'mouseleave'];\nvar PASSIVE_EVENTS = ['touchstart', 'touchend', 'touchmove', 'touchcancel'];\n/** The base frameworks, eg React & Angular, override this bean with implementations specific to their requirement. */\nvar VanillaFrameworkOverrides = /** @class */ (function () {\n function VanillaFrameworkOverrides() {\n this.isOutsideAngular = function (eventType) { return includes(OUTSIDE_ANGULAR_EVENTS, eventType); };\n }\n // for Vanilla JS, we use simple timeout\n VanillaFrameworkOverrides.prototype.setTimeout = function (action, timeout) {\n window.setTimeout(action, timeout);\n };\n VanillaFrameworkOverrides.prototype.setInterval = function (action, timeout) {\n return new AgPromise(function (resolve) {\n resolve(window.setInterval(action, timeout));\n });\n };\n // for Vanilla JS, we just add the event to the element\n VanillaFrameworkOverrides.prototype.addEventListener = function (element, type, listener, useCapture) {\n var isPassive = includes(PASSIVE_EVENTS, type);\n element.addEventListener(type, listener, { capture: !!useCapture, passive: isPassive });\n };\n // for Vanilla JS, we just execute the listener\n VanillaFrameworkOverrides.prototype.dispatchEvent = function (eventType, listener, global) {\n if (global === void 0) { global = false; }\n listener();\n };\n VanillaFrameworkOverrides.prototype.frameworkComponent = function (name) {\n return null;\n };\n VanillaFrameworkOverrides.prototype.isFrameworkComponent = function (comp) {\n return false;\n };\n return VanillaFrameworkOverrides;\n}());\nexport { VanillaFrameworkOverrides };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nimport { Autowired, Bean } from \"./context/context\";\nimport { BeanStub } from \"./context/beanStub\";\nimport { Constants } from \"./constants/constants\";\nimport { missing } from \"./utils/generic\";\nimport { last } from \"./utils/array\";\nimport { KeyCode } from './constants/keyCode';\nvar CellNavigationService = /** @class */ (function (_super) {\n __extends(CellNavigationService, _super);\n function CellNavigationService() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n // returns null if no cell to focus on, ie at the end of the grid\n CellNavigationService.prototype.getNextCellToFocus = function (key, focusedCell, ctrlPressed) {\n if (ctrlPressed === void 0) { ctrlPressed = false; }\n if (ctrlPressed) {\n return this.getNextCellToFocusWithCtrlPressed(key, focusedCell);\n }\n return this.getNextCellToFocusWithoutCtrlPressed(key, focusedCell);\n };\n CellNavigationService.prototype.getNextCellToFocusWithCtrlPressed = function (key, focusedCell) {\n var upKey = key === KeyCode.UP;\n var downKey = key === KeyCode.DOWN;\n var leftKey = key === KeyCode.LEFT;\n var column;\n var rowIndex;\n if (upKey || downKey) {\n rowIndex = upKey ? this.paginationProxy.getPageFirstRow() : this.paginationProxy.getPageLastRow();\n column = focusedCell.column;\n }\n else {\n var allColumns = this.columnModel.getAllDisplayedColumns();\n var isRtl = this.gridOptionsWrapper.isEnableRtl();\n rowIndex = focusedCell.rowIndex;\n column = leftKey !== isRtl ? allColumns[0] : last(allColumns);\n }\n return {\n rowIndex: rowIndex,\n rowPinned: null,\n column: column\n };\n };\n CellNavigationService.prototype.getNextCellToFocusWithoutCtrlPressed = function (key, focusedCell) {\n // starting with the provided cell, we keep moving until we find a cell we can\n // focus on.\n var pointer = focusedCell;\n var finished = false;\n // finished will be true when either:\n // a) cell found that we can focus on\n // b) run out of cells (ie the method returns null)\n while (!finished) {\n switch (key) {\n case KeyCode.UP:\n pointer = this.getCellAbove(pointer);\n break;\n case KeyCode.DOWN:\n pointer = this.getCellBelow(pointer);\n break;\n case KeyCode.RIGHT:\n if (this.gridOptionsWrapper.isEnableRtl()) {\n pointer = this.getCellToLeft(pointer);\n }\n else {\n pointer = this.getCellToRight(pointer);\n }\n break;\n case KeyCode.LEFT:\n if (this.gridOptionsWrapper.isEnableRtl()) {\n pointer = this.getCellToRight(pointer);\n }\n else {\n pointer = this.getCellToLeft(pointer);\n }\n break;\n default:\n pointer = null;\n console.warn('AG Grid: unknown key for navigation ' + key);\n break;\n }\n if (pointer) {\n finished = this.isCellGoodToFocusOn(pointer);\n }\n else {\n finished = true;\n }\n }\n return pointer;\n };\n CellNavigationService.prototype.isCellGoodToFocusOn = function (gridCell) {\n var column = gridCell.column;\n var rowNode;\n switch (gridCell.rowPinned) {\n case Constants.PINNED_TOP:\n rowNode = this.pinnedRowModel.getPinnedTopRow(gridCell.rowIndex);\n break;\n case Constants.PINNED_BOTTOM:\n rowNode = this.pinnedRowModel.getPinnedBottomRow(gridCell.rowIndex);\n break;\n default:\n rowNode = this.rowModel.getRow(gridCell.rowIndex);\n break;\n }\n if (!rowNode) {\n return false;\n }\n var suppressNavigable = column.isSuppressNavigable(rowNode);\n return !suppressNavigable;\n };\n CellNavigationService.prototype.getCellToLeft = function (lastCell) {\n if (!lastCell) {\n return null;\n }\n var colToLeft = this.columnModel.getDisplayedColBefore(lastCell.column);\n if (!colToLeft) {\n return null;\n }\n return {\n rowIndex: lastCell.rowIndex,\n column: colToLeft,\n rowPinned: lastCell.rowPinned\n };\n };\n CellNavigationService.prototype.getCellToRight = function (lastCell) {\n if (!lastCell) {\n return null;\n }\n var colToRight = this.columnModel.getDisplayedColAfter(lastCell.column);\n // if already on right, do nothing\n if (!colToRight) {\n return null;\n }\n return {\n rowIndex: lastCell.rowIndex,\n column: colToRight,\n rowPinned: lastCell.rowPinned\n };\n };\n CellNavigationService.prototype.getRowBelow = function (rowPosition) {\n // if already on top row, do nothing\n var index = rowPosition.rowIndex;\n var pinned = rowPosition.rowPinned;\n if (this.isLastRowInContainer(rowPosition)) {\n switch (pinned) {\n case Constants.PINNED_BOTTOM:\n // never any rows after pinned bottom\n return null;\n case Constants.PINNED_TOP:\n // if on last row of pinned top, then next row is main body (if rows exist),\n // otherwise it's the pinned bottom\n if (this.rowModel.isRowsToRender()) {\n return { rowIndex: this.paginationProxy.getPageFirstRow(), rowPinned: null };\n }\n if (this.pinnedRowModel.isRowsToRender(Constants.PINNED_BOTTOM)) {\n return { rowIndex: 0, rowPinned: Constants.PINNED_BOTTOM };\n }\n return null;\n default:\n // if in the main body, then try pinned bottom, otherwise return nothing\n if (this.pinnedRowModel.isRowsToRender(Constants.PINNED_BOTTOM)) {\n return { rowIndex: 0, rowPinned: Constants.PINNED_BOTTOM };\n }\n return null;\n }\n }\n var rowNode = this.rowModel.getRow(rowPosition.rowIndex);\n var nextStickyPosition = this.getNextStickyPosition(rowNode);\n if (nextStickyPosition) {\n return nextStickyPosition;\n }\n return { rowIndex: index + 1, rowPinned: pinned };\n };\n CellNavigationService.prototype.getNextStickyPosition = function (rowNode, up) {\n if (!this.gridOptionsWrapper.isGroupRowsSticky() || !rowNode || !rowNode.sticky) {\n return;\n }\n var stickyRowCtrls = __spread(this.rowRenderer.getStickyTopRowCtrls()).sort(function (a, b) { return a.getRowNode().rowIndex - b.getRowNode().rowIndex; });\n var diff = up ? -1 : 1;\n var idx = stickyRowCtrls.findIndex(function (ctrl) { return ctrl.getRowNode().rowIndex === rowNode.rowIndex; });\n var nextCtrl = stickyRowCtrls[idx + diff];\n if (nextCtrl) {\n return { rowIndex: nextCtrl.getRowNode().rowIndex, rowPinned: null };\n }\n };\n CellNavigationService.prototype.getCellBelow = function (lastCell) {\n if (!lastCell) {\n return null;\n }\n var rowBelow = this.getRowBelow(lastCell);\n if (rowBelow) {\n return {\n rowIndex: rowBelow.rowIndex,\n column: lastCell.column,\n rowPinned: rowBelow.rowPinned\n };\n }\n return null;\n };\n CellNavigationService.prototype.isLastRowInContainer = function (rowPosition) {\n var pinned = rowPosition.rowPinned;\n var index = rowPosition.rowIndex;\n if (pinned === Constants.PINNED_TOP) {\n var lastTopIndex = this.pinnedRowModel.getPinnedTopRowData().length - 1;\n return lastTopIndex <= index;\n }\n if (pinned === Constants.PINNED_BOTTOM) {\n var lastBottomIndex = this.pinnedRowModel.getPinnedBottomRowData().length - 1;\n return lastBottomIndex <= index;\n }\n var lastBodyIndex = this.paginationProxy.getPageLastRow();\n return lastBodyIndex <= index;\n };\n CellNavigationService.prototype.getRowAbove = function (rowPosition) {\n // if already on top row, do nothing\n var index = rowPosition.rowIndex;\n var pinned = rowPosition.rowPinned;\n var isFirstRow = pinned ? index === 0 : index === this.paginationProxy.getPageFirstRow();\n // if already on top row, do nothing\n if (isFirstRow) {\n if (pinned === Constants.PINNED_TOP) {\n return null;\n }\n if (!pinned) {\n if (this.pinnedRowModel.isRowsToRender(Constants.PINNED_TOP)) {\n return this.getLastFloatingTopRow();\n }\n return null;\n }\n // last floating bottom\n if (this.rowModel.isRowsToRender()) {\n return this.getLastBodyCell();\n }\n if (this.pinnedRowModel.isRowsToRender(Constants.PINNED_TOP)) {\n return this.getLastFloatingTopRow();\n }\n return null;\n }\n var rowNode = this.rowModel.getRow(rowPosition.rowIndex);\n var nextStickyPosition = this.getNextStickyPosition(rowNode, true);\n if (nextStickyPosition) {\n return nextStickyPosition;\n }\n return { rowIndex: index - 1, rowPinned: pinned };\n };\n CellNavigationService.prototype.getCellAbove = function (lastCell) {\n if (!lastCell) {\n return null;\n }\n var rowAbove = this.getRowAbove({ rowIndex: lastCell.rowIndex, rowPinned: lastCell.rowPinned });\n if (rowAbove) {\n return {\n rowIndex: rowAbove.rowIndex,\n column: lastCell.column,\n rowPinned: rowAbove.rowPinned\n };\n }\n return null;\n };\n CellNavigationService.prototype.getLastBodyCell = function () {\n var lastBodyRow = this.paginationProxy.getPageLastRow();\n return { rowIndex: lastBodyRow, rowPinned: null };\n };\n CellNavigationService.prototype.getLastFloatingTopRow = function () {\n var lastFloatingRow = this.pinnedRowModel.getPinnedTopRowData().length - 1;\n return { rowIndex: lastFloatingRow, rowPinned: Constants.PINNED_TOP };\n };\n CellNavigationService.prototype.getNextTabbedCell = function (gridCell, backwards) {\n if (backwards) {\n return this.getNextTabbedCellBackwards(gridCell);\n }\n return this.getNextTabbedCellForwards(gridCell);\n };\n CellNavigationService.prototype.getNextTabbedCellForwards = function (gridCell) {\n var displayedColumns = this.columnModel.getAllDisplayedColumns();\n var newRowIndex = gridCell.rowIndex;\n var newFloating = gridCell.rowPinned;\n // move along to the next cell\n var newColumn = this.columnModel.getDisplayedColAfter(gridCell.column);\n // check if end of the row, and if so, go forward a row\n if (!newColumn) {\n newColumn = displayedColumns[0];\n var rowBelow = this.getRowBelow(gridCell);\n if (missing(rowBelow)) {\n return null;\n }\n // If we are tabbing and there is a paging panel present, tabbing should go\n // to the paging panel instead of loading the next page.\n if (!rowBelow.rowPinned && !this.paginationProxy.isRowInPage(rowBelow)) {\n return null;\n }\n newRowIndex = rowBelow ? rowBelow.rowIndex : null;\n newFloating = rowBelow ? rowBelow.rowPinned : null;\n }\n return { rowIndex: newRowIndex, column: newColumn, rowPinned: newFloating };\n };\n CellNavigationService.prototype.getNextTabbedCellBackwards = function (gridCell) {\n var displayedColumns = this.columnModel.getAllDisplayedColumns();\n var newRowIndex = gridCell.rowIndex;\n var newFloating = gridCell.rowPinned;\n // move along to the next cell\n var newColumn = this.columnModel.getDisplayedColBefore(gridCell.column);\n // check if end of the row, and if so, go forward a row\n if (!newColumn) {\n newColumn = last(displayedColumns);\n var rowAbove = this.getRowAbove({ rowIndex: gridCell.rowIndex, rowPinned: gridCell.rowPinned });\n if (missing(rowAbove)) {\n return null;\n }\n // If we are tabbing and there is a paging panel present, tabbing should go\n // to the paging panel instead of loading the next page.\n if (!rowAbove.rowPinned && !this.paginationProxy.isRowInPage(rowAbove)) {\n return null;\n }\n newRowIndex = rowAbove ? rowAbove.rowIndex : null;\n newFloating = rowAbove ? rowAbove.rowPinned : null;\n }\n return { rowIndex: newRowIndex, column: newColumn, rowPinned: newFloating };\n };\n __decorate([\n Autowired('columnModel')\n ], CellNavigationService.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('rowModel')\n ], CellNavigationService.prototype, \"rowModel\", void 0);\n __decorate([\n Autowired('rowRenderer')\n ], CellNavigationService.prototype, \"rowRenderer\", void 0);\n __decorate([\n Autowired('pinnedRowModel')\n ], CellNavigationService.prototype, \"pinnedRowModel\", void 0);\n __decorate([\n Autowired('paginationProxy')\n ], CellNavigationService.prototype, \"paginationProxy\", void 0);\n CellNavigationService = __decorate([\n Bean('cellNavigationService')\n ], CellNavigationService);\n return CellNavigationService;\n}(BeanStub));\nexport { CellNavigationService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n};\nimport { Events } from \"./events\";\nimport { Bean } from \"./context/context\";\nimport { Qualifier } from \"./context/context\";\nimport { Autowired } from \"./context/context\";\nimport { PostConstruct } from \"./context/context\";\nimport { BeanStub } from \"./context/beanStub\";\nvar AlignedGridsService = /** @class */ (function (_super) {\n __extends(AlignedGridsService, _super);\n function AlignedGridsService() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n // flag to mark if we are consuming. to avoid cyclic events (ie other grid firing back to master\n // while processing a master event) we mark this if consuming an event, and if we are, then\n // we don't fire back any events.\n _this.consuming = false;\n return _this;\n }\n AlignedGridsService.prototype.setBeans = function (loggerFactory) {\n this.logger = loggerFactory.create('AlignedGridsService');\n };\n AlignedGridsService.prototype.init = function () {\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_MOVED, this.fireColumnEvent.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_VISIBLE, this.fireColumnEvent.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PINNED, this.fireColumnEvent.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_GROUP_OPENED, this.fireColumnEvent.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_RESIZED, this.fireColumnEvent.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_BODY_SCROLL, this.fireScrollEvent.bind(this));\n };\n // common logic across all the fire methods\n AlignedGridsService.prototype.fireEvent = function (callback) {\n // if we are already consuming, then we are acting on an event from a master,\n // so we don't cause a cyclic firing of events\n if (this.consuming) {\n return;\n }\n // iterate through the aligned grids, and pass each aligned grid service to the callback\n var otherGrids = this.gridOptionsWrapper.getAlignedGrids();\n if (otherGrids) {\n otherGrids.forEach(function (otherGridOptions) {\n if (otherGridOptions.api) {\n var alignedGridService = otherGridOptions.api.__getAlignedGridService();\n callback(alignedGridService);\n }\n });\n }\n };\n // common logic across all consume methods. very little common logic, however extracting\n // guarantees consistency across the methods.\n AlignedGridsService.prototype.onEvent = function (callback) {\n this.consuming = true;\n callback();\n this.consuming = false;\n };\n AlignedGridsService.prototype.fireColumnEvent = function (event) {\n this.fireEvent(function (alignedGridsService) {\n alignedGridsService.onColumnEvent(event);\n });\n };\n AlignedGridsService.prototype.fireScrollEvent = function (event) {\n if (event.direction !== 'horizontal') {\n return;\n }\n this.fireEvent(function (alignedGridsService) {\n alignedGridsService.onScrollEvent(event);\n });\n };\n AlignedGridsService.prototype.onScrollEvent = function (event) {\n var _this = this;\n this.onEvent(function () {\n var gridBodyCon = _this.ctrlsService.getGridBodyCtrl();\n gridBodyCon.getScrollFeature().setHorizontalScrollPosition(event.left);\n });\n };\n AlignedGridsService.prototype.getMasterColumns = function (event) {\n var result = [];\n if (event.columns) {\n event.columns.forEach(function (column) {\n result.push(column);\n });\n }\n else if (event.column) {\n result.push(event.column);\n }\n return result;\n };\n AlignedGridsService.prototype.getColumnIds = function (event) {\n var result = [];\n if (event.columns) {\n event.columns.forEach(function (column) {\n result.push(column.getColId());\n });\n }\n else if (event.column) {\n result.push(event.column.getColId());\n }\n return result;\n };\n AlignedGridsService.prototype.onColumnEvent = function (event) {\n var _this = this;\n this.onEvent(function () {\n switch (event.type) {\n case Events.EVENT_COLUMN_MOVED:\n case Events.EVENT_COLUMN_VISIBLE:\n case Events.EVENT_COLUMN_PINNED:\n case Events.EVENT_COLUMN_RESIZED:\n var colEvent = event;\n _this.processColumnEvent(colEvent);\n break;\n case Events.EVENT_COLUMN_GROUP_OPENED:\n var groupOpenedEvent = event;\n _this.processGroupOpenedEvent(groupOpenedEvent);\n break;\n case Events.EVENT_COLUMN_PIVOT_CHANGED:\n // we cannot support pivoting with aligned grids as the columns will be out of sync as the\n // grids will have columns created based on the row data of the grid.\n console.warn('AG Grid: pivoting is not supported with aligned grids. ' +\n 'You can only use one of these features at a time in a grid.');\n break;\n }\n });\n };\n AlignedGridsService.prototype.processGroupOpenedEvent = function (groupOpenedEvent) {\n // likewise for column group\n var masterColumnGroup = groupOpenedEvent.columnGroup;\n var otherColumnGroup = null;\n if (masterColumnGroup) {\n var groupId = masterColumnGroup.getGroupId();\n otherColumnGroup = this.columnModel.getProvidedColumnGroup(groupId);\n }\n if (masterColumnGroup && !otherColumnGroup) {\n return;\n }\n this.logger.log('onColumnEvent-> processing ' + groupOpenedEvent + ' expanded = ' + masterColumnGroup.isExpanded());\n this.columnModel.setColumnGroupOpened(otherColumnGroup, masterColumnGroup.isExpanded(), \"alignedGridChanged\");\n };\n AlignedGridsService.prototype.processColumnEvent = function (colEvent) {\n var _this = this;\n var _a;\n // the column in the event is from the master grid. need to\n // look up the equivalent from this (other) grid\n var masterColumn = colEvent.column;\n var otherColumn = null;\n if (masterColumn) {\n otherColumn = this.columnModel.getPrimaryColumn(masterColumn.getColId());\n }\n // if event was with respect to a master column, that is not present in this\n // grid, then we ignore the event\n if (masterColumn && !otherColumn) {\n return;\n }\n // in time, all the methods below should use the column ids, it's a more generic way\n // of handling columns, and also allows for single or multi column events\n var masterColumns = this.getMasterColumns(colEvent);\n switch (colEvent.type) {\n case Events.EVENT_COLUMN_MOVED:\n // when the user moves columns via setColumnState, we can't depend on moving specific columns\n // to an index, as there maybe be many indexes columns moved to (as wasn't result of a mouse drag).\n // so only way to be sure is match the order of all columns using Column State.\n {\n var movedEvent = colEvent;\n var srcColState = colEvent.columnApi.getColumnState();\n var destColState = srcColState.map(function (s) { return ({ colId: s.colId }); });\n this.columnModel.applyColumnState({ state: destColState, applyOrder: true }, \"alignedGridChanged\");\n this.logger.log(\"onColumnEvent-> processing \" + colEvent.type + \" toIndex = \" + movedEvent.toIndex);\n }\n break;\n case Events.EVENT_COLUMN_VISIBLE:\n // when the user changes visibility via setColumnState, we can't depend on visibility flag in event\n // as there maybe be mix of true/false (as wasn't result of a mouse click to set visiblity).\n // so only way to be sure is match the visibility of all columns using Column State.\n {\n var visibleEvent = colEvent;\n var srcColState = colEvent.columnApi.getColumnState();\n var destColState = srcColState.map(function (s) { return ({ colId: s.colId, hide: s.hide }); });\n this.columnModel.applyColumnState({ state: destColState }, \"alignedGridChanged\");\n this.logger.log(\"onColumnEvent-> processing \" + colEvent.type + \" visible = \" + visibleEvent.visible);\n }\n break;\n case Events.EVENT_COLUMN_PINNED:\n {\n var pinnedEvent = colEvent;\n var srcColState = colEvent.columnApi.getColumnState();\n var destColState = srcColState.map(function (s) { return ({ colId: s.colId, pinned: s.pinned }); });\n this.columnModel.applyColumnState({ state: destColState }, \"alignedGridChanged\");\n this.logger.log(\"onColumnEvent-> processing \" + colEvent.type + \" pinned = \" + pinnedEvent.pinned);\n }\n break;\n case Events.EVENT_COLUMN_RESIZED:\n var resizedEvent = colEvent;\n var columnWidths_1 = {};\n masterColumns.forEach(function (column) {\n _this.logger.log(\"onColumnEvent-> processing \" + colEvent.type + \" actualWidth = \" + column.getActualWidth());\n columnWidths_1[column.getId()] = { key: column.getColId(), newWidth: column.getActualWidth() };\n });\n // don't set flex columns width\n (_a = resizedEvent.flexColumns) === null || _a === void 0 ? void 0 : _a.forEach(function (col) {\n if (columnWidths_1[col.getId()]) {\n delete columnWidths_1[col.getId()];\n }\n });\n this.columnModel.setColumnWidths(Object.values(columnWidths_1), false, resizedEvent.finished, \"alignedGridChanged\");\n break;\n }\n var gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n var isVerticalScrollShowing = gridBodyCon.isVerticalScrollShowing();\n var alignedGrids = this.gridOptionsWrapper.getAlignedGrids();\n if (alignedGrids) {\n alignedGrids.forEach(function (grid) {\n if (grid.api) {\n grid.api.setAlwaysShowVerticalScroll(isVerticalScrollShowing);\n }\n });\n }\n };\n __decorate([\n Autowired('columnModel')\n ], AlignedGridsService.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], AlignedGridsService.prototype, \"ctrlsService\", void 0);\n __decorate([\n __param(0, Qualifier('loggerFactory'))\n ], AlignedGridsService.prototype, \"setBeans\", null);\n __decorate([\n PostConstruct\n ], AlignedGridsService.prototype, \"init\", null);\n AlignedGridsService = __decorate([\n Bean('alignedGridsService')\n ], AlignedGridsService);\n return AlignedGridsService;\n}(BeanStub));\nexport { AlignedGridsService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n};\nimport { Bean } from \"./context/context\";\nimport { BeanStub } from \"./context/beanStub\";\nimport { Qualifier } from \"./context/context\";\nimport { Events } from \"./events\";\nimport { Autowired } from \"./context/context\";\nimport { PostConstruct } from \"./context/context\";\nimport { Constants } from \"./constants/constants\";\nimport { ChangedPath } from \"./utils/changedPath\";\nimport { iterateObject } from \"./utils/object\";\nimport { exists } from \"./utils/generic\";\nvar SelectionService = /** @class */ (function (_super) {\n __extends(SelectionService, _super);\n function SelectionService() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n SelectionService.prototype.setBeans = function (loggerFactory) {\n this.logger = loggerFactory.create('selectionService');\n this.reset();\n };\n SelectionService.prototype.init = function () {\n this.groupSelectsChildren = this.gridOptionsWrapper.isGroupSelectsChildren();\n this.addManagedListener(this.eventService, Events.EVENT_ROW_SELECTED, this.onRowSelected.bind(this));\n };\n SelectionService.prototype.setLastSelectedNode = function (rowNode) {\n this.lastSelectedNode = rowNode;\n };\n SelectionService.prototype.getLastSelectedNode = function () {\n return this.lastSelectedNode;\n };\n SelectionService.prototype.getSelectedNodes = function () {\n var selectedNodes = [];\n iterateObject(this.selectedNodes, function (key, rowNode) {\n if (rowNode) {\n selectedNodes.push(rowNode);\n }\n });\n return selectedNodes;\n };\n SelectionService.prototype.getSelectedRows = function () {\n var selectedRows = [];\n iterateObject(this.selectedNodes, function (key, rowNode) {\n if (rowNode && rowNode.data) {\n selectedRows.push(rowNode.data);\n }\n });\n return selectedRows;\n };\n SelectionService.prototype.removeGroupsFromSelection = function () {\n var _this = this;\n iterateObject(this.selectedNodes, function (key, rowNode) {\n if (rowNode && rowNode.group) {\n _this.selectedNodes[rowNode.id] = undefined;\n }\n });\n };\n // should only be called if groupSelectsChildren=true\n SelectionService.prototype.updateGroupsFromChildrenSelections = function (changedPath) {\n // we only do this when group selection state depends on selected children\n if (!this.gridOptionsWrapper.isGroupSelectsChildren()) {\n return;\n }\n // also only do it if CSRM (code should never allow this anyway)\n if (this.rowModel.getType() !== Constants.ROW_MODEL_TYPE_CLIENT_SIDE) {\n return;\n }\n var clientSideRowModel = this.rowModel;\n var rootNode = clientSideRowModel.getRootNode();\n if (!changedPath) {\n changedPath = new ChangedPath(true, rootNode);\n changedPath.setInactive();\n }\n changedPath.forEachChangedNodeDepthFirst(function (rowNode) {\n if (rowNode !== rootNode) {\n var selected = rowNode.calculateSelectedFromChildren();\n rowNode.selectThisNode(selected === null ? false : selected);\n }\n });\n // clientSideRowModel.getTopLevelNodes()!.forEach((rowNode: RowNode) => {\n // rowNode.depthFirstSearch((node) => {\n // if (node.group) {\n // }\n // });\n // });\n };\n SelectionService.prototype.getNodeForIdIfSelected = function (id) {\n return this.selectedNodes[id];\n };\n SelectionService.prototype.clearOtherNodes = function (rowNodeToKeepSelected) {\n var _this = this;\n var groupsToRefresh = {};\n var updatedCount = 0;\n iterateObject(this.selectedNodes, function (key, otherRowNode) {\n if (otherRowNode && otherRowNode.id !== rowNodeToKeepSelected.id) {\n var rowNode = _this.selectedNodes[otherRowNode.id];\n updatedCount += rowNode.setSelectedParams({\n newValue: false,\n clearSelection: false,\n suppressFinishActions: true\n });\n if (_this.groupSelectsChildren && otherRowNode.parent) {\n groupsToRefresh[otherRowNode.parent.id] = otherRowNode.parent;\n }\n }\n });\n iterateObject(groupsToRefresh, function (key, group) {\n var selected = group.calculateSelectedFromChildren();\n group.selectThisNode(selected === null ? false : selected);\n });\n return updatedCount;\n };\n SelectionService.prototype.onRowSelected = function (event) {\n var rowNode = event.node;\n // we do not store the group rows when the groups select children\n if (this.groupSelectsChildren && rowNode.group) {\n return;\n }\n if (rowNode.isSelected()) {\n this.selectedNodes[rowNode.id] = rowNode;\n }\n else {\n this.selectedNodes[rowNode.id] = undefined;\n }\n };\n SelectionService.prototype.syncInRowNode = function (rowNode, oldNode) {\n this.syncInOldRowNode(rowNode, oldNode);\n this.syncInNewRowNode(rowNode);\n };\n // if the id has changed for the node, then this means the rowNode\n // is getting used for a different data item, which breaks\n // our selectedNodes, as the node now is mapped by the old id\n // which is inconsistent. so to keep the old node as selected,\n // we swap in the clone (with the old id and old data). this means\n // the oldNode is effectively a daemon we keep a reference to,\n // so if client calls api.getSelectedNodes(), it gets the daemon\n // in the result. when the client un-selects, the reference to the\n // daemon is removed. the daemon, because it's an oldNode, is not\n // used by the grid for rendering, it's a copy of what the node used\n // to be like before the id was changed.\n SelectionService.prototype.syncInOldRowNode = function (rowNode, oldNode) {\n var oldNodeHasDifferentId = exists(oldNode) && (rowNode.id !== oldNode.id);\n if (oldNodeHasDifferentId && oldNode) {\n var id = oldNode.id;\n var oldNodeSelected = this.selectedNodes[id] == rowNode;\n if (oldNodeSelected) {\n this.selectedNodes[oldNode.id] = oldNode;\n }\n }\n };\n SelectionService.prototype.syncInNewRowNode = function (rowNode) {\n if (exists(this.selectedNodes[rowNode.id])) {\n rowNode.setSelectedInitialValue(true);\n this.selectedNodes[rowNode.id] = rowNode;\n }\n else {\n rowNode.setSelectedInitialValue(false);\n }\n };\n SelectionService.prototype.reset = function () {\n this.logger.log('reset');\n this.selectedNodes = {};\n this.lastSelectedNode = null;\n };\n // returns a list of all nodes at 'best cost' - a feature to be used\n // with groups / trees. if a group has all it's children selected,\n // then the group appears in the result, but not the children.\n // Designed for use with 'children' as the group selection type,\n // where groups don't actually appear in the selection normally.\n SelectionService.prototype.getBestCostNodeSelection = function () {\n if (this.rowModel.getType() !== Constants.ROW_MODEL_TYPE_CLIENT_SIDE) {\n console.warn('AG Grid: `getBestCostNodeSelection` is only available when using normal row model');\n return;\n }\n var clientSideRowModel = this.rowModel;\n var topLevelNodes = clientSideRowModel.getTopLevelNodes();\n if (topLevelNodes === null) {\n console.warn('AG Grid: `selectAll` not available doing `rowModel=virtual`');\n return;\n }\n var result = [];\n // recursive function, to find the selected nodes\n function traverse(nodes) {\n for (var i = 0, l = nodes.length; i < l; i++) {\n var node = nodes[i];\n if (node.isSelected()) {\n result.push(node);\n }\n else {\n // if not selected, then if it's a group, and the group\n // has children, continue to search for selections\n var maybeGroup = node;\n if (maybeGroup.group && maybeGroup.children) {\n traverse(maybeGroup.children);\n }\n }\n }\n }\n traverse(topLevelNodes);\n return result;\n };\n SelectionService.prototype.setRowModel = function (rowModel) {\n this.rowModel = rowModel;\n };\n SelectionService.prototype.isEmpty = function () {\n var count = 0;\n iterateObject(this.selectedNodes, function (nodeId, rowNode) {\n if (rowNode) {\n count++;\n }\n });\n return count === 0;\n };\n SelectionService.prototype.deselectAllRowNodes = function (justFiltered) {\n if (justFiltered === void 0) { justFiltered = false; }\n var callback = function (rowNode) { return rowNode.selectThisNode(false); };\n var rowModelClientSide = this.rowModel.getType() === Constants.ROW_MODEL_TYPE_CLIENT_SIDE;\n if (justFiltered) {\n if (!rowModelClientSide) {\n console.error('AG Grid: selecting just filtered only works with In Memory Row Model');\n return;\n }\n var clientSideRowModel = this.rowModel;\n clientSideRowModel.forEachNodeAfterFilter(callback);\n }\n else {\n iterateObject(this.selectedNodes, function (id, rowNode) {\n // remember the reference can be to null, as we never 'delete' from the map\n if (rowNode) {\n callback(rowNode);\n }\n });\n // this clears down the map (whereas above only sets the items in map to 'undefined')\n this.reset();\n }\n // the above does not clean up the parent rows if they are selected\n if (rowModelClientSide && this.groupSelectsChildren) {\n this.updateGroupsFromChildrenSelections();\n }\n var event = {\n type: Events.EVENT_SELECTION_CHANGED,\n };\n this.eventService.dispatchEvent(event);\n };\n SelectionService.prototype.selectAllRowNodes = function (justFiltered) {\n if (justFiltered === void 0) { justFiltered = false; }\n if (this.rowModel.getType() !== Constants.ROW_MODEL_TYPE_CLIENT_SIDE) {\n throw new Error(\"selectAll only available with normal row model, ie not \" + this.rowModel.getType());\n }\n var clientSideRowModel = this.rowModel;\n var callback = function (rowNode) { return rowNode.selectThisNode(true); };\n if (justFiltered) {\n clientSideRowModel.forEachNodeAfterFilter(callback);\n }\n else {\n clientSideRowModel.forEachNode(callback);\n }\n // the above does not clean up the parent rows if they are selected\n if (this.rowModel.getType() === Constants.ROW_MODEL_TYPE_CLIENT_SIDE && this.groupSelectsChildren) {\n this.updateGroupsFromChildrenSelections();\n }\n var event = {\n type: Events.EVENT_SELECTION_CHANGED,\n };\n this.eventService.dispatchEvent(event);\n };\n /**\n * @method\n * @deprecated\n */\n SelectionService.prototype.selectNode = function (rowNode, tryMulti) {\n if (rowNode) {\n rowNode.setSelectedParams({ newValue: true, clearSelection: !tryMulti });\n }\n };\n /**\n * @method\n * @deprecated\n */\n SelectionService.prototype.deselectIndex = function (rowIndex) {\n var node = this.rowModel.getRow(rowIndex);\n this.deselectNode(node);\n };\n /**\n * @method\n * @deprecated\n */\n SelectionService.prototype.deselectNode = function (rowNode) {\n if (rowNode) {\n rowNode.setSelectedParams({ newValue: false, clearSelection: false });\n }\n };\n /**\n * @method\n * @deprecated\n */\n SelectionService.prototype.selectIndex = function (index, tryMulti) {\n var node = this.rowModel.getRow(index);\n this.selectNode(node, tryMulti);\n };\n __decorate([\n Autowired('rowModel')\n ], SelectionService.prototype, \"rowModel\", void 0);\n __decorate([\n __param(0, Qualifier('loggerFactory'))\n ], SelectionService.prototype, \"setBeans\", null);\n __decorate([\n PostConstruct\n ], SelectionService.prototype, \"init\", null);\n SelectionService = __decorate([\n Bean('selectionService')\n ], SelectionService);\n return SelectionService;\n}(BeanStub));\nexport { SelectionService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, PreDestroy } from \"../context/context\";\nimport { _ } from \"../utils\";\nvar ColumnApi = /** @class */ (function () {\n function ColumnApi() {\n }\n /** Gets the grid to size the columns to the specified width in pixels, e.g. `sizeColumnsToFit(900)`. To have the grid fit the columns to the grid's width, use the Grid API `gridApi.sizeColumnsToFit()` instead. */\n ColumnApi.prototype.sizeColumnsToFit = function (gridWidth) {\n // AG-3403 validate that gridWidth is provided because this method has the same name as\n // a method on the grid API that takes no arguments, and it's easy to confuse the two\n if (typeof gridWidth === \"undefined\") {\n console.error('AG Grid: missing parameter to columnApi.sizeColumnsToFit(gridWidth)');\n }\n this.columnModel.sizeColumnsToFit(gridWidth, 'api');\n };\n /** Call this if you want to open or close a column group. */\n ColumnApi.prototype.setColumnGroupOpened = function (group, newValue) { this.columnModel.setColumnGroupOpened(group, newValue, 'api'); };\n /** Returns the column group with the given name. */\n ColumnApi.prototype.getColumnGroup = function (name, instanceId) { return this.columnModel.getColumnGroup(name, instanceId); };\n /** Returns the provided column group with the given name. */\n ColumnApi.prototype.getProvidedColumnGroup = function (name) { return this.columnModel.getProvidedColumnGroup(name); };\n /** Returns the display name for a column. Useful if you are doing your own header rendering and want the grid to work out if `headerValueGetter` is used, or if you are doing your own column management GUI, to know what to show as the column name. */\n ColumnApi.prototype.getDisplayNameForColumn = function (column, location) { return this.columnModel.getDisplayNameForColumn(column, location) || ''; };\n /** Returns the display name for a column group (when grouping columns). */\n ColumnApi.prototype.getDisplayNameForColumnGroup = function (columnGroup, location) { return this.columnModel.getDisplayNameForColumnGroup(columnGroup, location) || ''; };\n /** Returns the column with the given `colKey`, which can either be the `colId` (a string) or the `colDef` (an object). */\n ColumnApi.prototype.getColumn = function (key) { return this.columnModel.getPrimaryColumn(key); };\n /** Returns all the columns, regardless of visible or not. */\n ColumnApi.prototype.getColumns = function () { return this.columnModel.getAllPrimaryColumns(); };\n /** Applies the state of the columns from a previous state. Returns `false` if one or more columns could not be found. */\n ColumnApi.prototype.applyColumnState = function (params) { return this.columnModel.applyColumnState(params, 'api'); };\n /** Gets the state of the columns. Typically used when saving column state. */\n ColumnApi.prototype.getColumnState = function () { return this.columnModel.getColumnState(); };\n /** Sets the state back to match the originally provided column definitions. */\n ColumnApi.prototype.resetColumnState = function () { this.columnModel.resetColumnState('api'); };\n /** Gets the state of the column groups. Typically used when saving column group state. */\n ColumnApi.prototype.getColumnGroupState = function () { return this.columnModel.getColumnGroupState(); };\n /** Sets the state of the column group state from a previous state. */\n ColumnApi.prototype.setColumnGroupState = function (stateItems) { this.columnModel.setColumnGroupState(stateItems, 'api'); };\n /** Sets the state back to match the originally provided column definitions. */\n ColumnApi.prototype.resetColumnGroupState = function () { this.columnModel.resetColumnGroupState('api'); };\n /** Returns `true` if pinning left or right, otherwise `false`. */\n ColumnApi.prototype.isPinning = function () { return this.columnModel.isPinningLeft() || this.columnModel.isPinningRight(); };\n /** Returns `true` if pinning left, otherwise `false`. */\n ColumnApi.prototype.isPinningLeft = function () { return this.columnModel.isPinningLeft(); };\n /** Returns `true` if pinning right, otherwise `false`. */\n ColumnApi.prototype.isPinningRight = function () { return this.columnModel.isPinningRight(); };\n /** Returns the column to the right of the provided column, taking into consideration open / closed column groups and visible columns. This is useful if you need to know what column is beside yours e.g. if implementing your own cell navigation. */\n ColumnApi.prototype.getDisplayedColAfter = function (col) { return this.columnModel.getDisplayedColAfter(col); };\n /** Same as `getVisibleColAfter` except gives column to the left. */\n ColumnApi.prototype.getDisplayedColBefore = function (col) { return this.columnModel.getDisplayedColBefore(col); };\n /** Sets the visibility of a column. Key can be the column ID or `Column` object. */\n ColumnApi.prototype.setColumnVisible = function (key, visible) { this.columnModel.setColumnVisible(key, visible, 'api'); };\n /** Same as `setColumnVisible`, but provide a list of column keys. */\n ColumnApi.prototype.setColumnsVisible = function (keys, visible) { this.columnModel.setColumnsVisible(keys, visible, 'api'); };\n /** Sets the column pinned / unpinned. Key can be the column ID, field, `ColDef` object or `Column` object. */\n ColumnApi.prototype.setColumnPinned = function (key, pinned) { this.columnModel.setColumnPinned(key, pinned, 'api'); };\n /** Same as `setColumnPinned`, but provide a list of column keys. */\n ColumnApi.prototype.setColumnsPinned = function (keys, pinned) { this.columnModel.setColumnsPinned(keys, pinned, 'api'); };\n /**\n * Returns all the grid columns, same as `getColumns()`, except\n *\n * a) it has the order of the columns that are presented in the grid\n *\n * b) it's after the 'pivot' step, so if pivoting, has the value columns for the pivot.\n */\n ColumnApi.prototype.getAllGridColumns = function () { return this.columnModel.getAllGridColumns(); };\n /** Same as `getAllDisplayedColumns` but just for the pinned left portion of the grid. */\n ColumnApi.prototype.getDisplayedLeftColumns = function () { return this.columnModel.getDisplayedLeftColumns(); };\n /** Same as `getAllDisplayedColumns` but just for the center portion of the grid. */\n ColumnApi.prototype.getDisplayedCenterColumns = function () { return this.columnModel.getDisplayedCenterColumns(); };\n /** Same as `getAllDisplayedColumns` but just for the pinned right portion of the grid. */\n ColumnApi.prototype.getDisplayedRightColumns = function () { return this.columnModel.getDisplayedRightColumns(); };\n /** Returns all columns currently displayed (e.g. are visible and if in a group, the group is showing the columns) for the pinned left, centre and pinned right portions of the grid. */\n ColumnApi.prototype.getAllDisplayedColumns = function () { return this.columnModel.getAllDisplayedColumns(); };\n /** Same as `getAllGridColumns()`, except only returns rendered columns, i.e. columns that are not within the viewport and therefore not rendered, due to column virtualisation, are not displayed. */\n ColumnApi.prototype.getAllDisplayedVirtualColumns = function () { return this.columnModel.getViewportColumns(); };\n /** Moves a column to `toIndex`. The column is first removed, then added at the `toIndex` location, thus index locations will change to the right of the column after the removal. */\n ColumnApi.prototype.moveColumn = function (key, toIndex) {\n if (typeof key === 'number') {\n // moveColumn used to take indexes, so this is advising user who hasn't moved to new method name\n console.warn('AG Grid: you are using moveColumn(fromIndex, toIndex) - moveColumn takes a column key and a destination index, not two indexes, to move with indexes use moveColumnByIndex(from,to) instead');\n this.columnModel.moveColumnByIndex(key, toIndex, 'api');\n }\n else {\n this.columnModel.moveColumn(key, toIndex, 'api');\n }\n };\n /** Same as `moveColumn` but works on index locations. */\n ColumnApi.prototype.moveColumnByIndex = function (fromIndex, toIndex) { this.columnModel.moveColumnByIndex(fromIndex, toIndex, 'api'); };\n /** Same as `moveColumn` but works on list. */\n ColumnApi.prototype.moveColumns = function (columnsToMoveKeys, toIndex) { this.columnModel.moveColumns(columnsToMoveKeys, toIndex, 'api'); };\n /** Move the column to a new position in the row grouping order. */\n ColumnApi.prototype.moveRowGroupColumn = function (fromIndex, toIndex) { this.columnModel.moveRowGroupColumn(fromIndex, toIndex); };\n /** Sets the agg function for a column. `aggFunc` can be one of `'min' | 'max' | 'sum'`. */\n ColumnApi.prototype.setColumnAggFunc = function (key, aggFunc) { this.columnModel.setColumnAggFunc(key, aggFunc); };\n /** Sets the column width on a single column. The finished flag gets included in the resulting event and not used internally by the grid. The finished flag is intended for dragging, where a dragging action will produce many `columnWidth` events, so the consumer of events knows when it receives the last event in a stream. The finished parameter is optional, and defaults to `true`. */\n ColumnApi.prototype.setColumnWidth = function (key, newWidth, finished, source) {\n if (finished === void 0) { finished = true; }\n this.columnModel.setColumnWidths([{ key: key, newWidth: newWidth }], false, finished, source);\n };\n /** Sets the column widths on multiple columns. This method offers better performance than calling `setColumnWidth` multiple times. The finished flag gets included in the resulting event and not used internally by the grid. The finished flag is intended for dragging, where a dragging action will produce many `columnWidth` events, so the consumer of events knows when it receives the last event in a stream. The finished parameter is optional, and defaults to `true`. */\n ColumnApi.prototype.setColumnWidths = function (columnWidths, finished, source) {\n if (finished === void 0) { finished = true; }\n this.columnModel.setColumnWidths(columnWidths, false, finished, source);\n };\n /** Set the pivot mode. */\n ColumnApi.prototype.setPivotMode = function (pivotMode) { this.columnModel.setPivotMode(pivotMode); };\n /** Get the pivot mode. */\n ColumnApi.prototype.isPivotMode = function () { return this.columnModel.isPivotMode(); };\n /** @deprecated Use `getPivotResultColumn` instead */\n ColumnApi.prototype.getSecondaryPivotColumn = function (pivotKeys, valueColKey) {\n console.warn('AG Grid: since version 28.0.x getSecondaryPivotColumn has been renamed, please use getPivotResultColumn instead');\n return this.getPivotResultColumn(pivotKeys, valueColKey);\n };\n /** Returns the pivot result column for the given `pivotKeys` and `valueColId`. Useful to then call operations on the pivot column. */\n ColumnApi.prototype.getPivotResultColumn = function (pivotKeys, valueColKey) { return this.columnModel.getSecondaryPivotColumn(pivotKeys, valueColKey); };\n /** Set the value columns. */\n ColumnApi.prototype.setValueColumns = function (colKeys) { this.columnModel.setValueColumns(colKeys, 'api'); };\n /** Get value columns. */\n ColumnApi.prototype.getValueColumns = function () { return this.columnModel.getValueColumns(); };\n /** Remove a value column. */\n ColumnApi.prototype.removeValueColumn = function (colKey) { this.columnModel.removeValueColumn(colKey, 'api'); };\n /** Same as `removeValueColumns` but provide a list. */\n ColumnApi.prototype.removeValueColumns = function (colKeys) { this.columnModel.removeValueColumns(colKeys, 'api'); };\n /** Add a value column. */\n ColumnApi.prototype.addValueColumn = function (colKey) { this.columnModel.addValueColumn(colKey, 'api'); };\n /** Same as `addValueColumn` but provide a list. */\n ColumnApi.prototype.addValueColumns = function (colKeys) { this.columnModel.addValueColumns(colKeys, 'api'); };\n /** Set the row group columns. */\n ColumnApi.prototype.setRowGroupColumns = function (colKeys) { this.columnModel.setRowGroupColumns(colKeys, 'api'); };\n /** Remove a column from the row groups. */\n ColumnApi.prototype.removeRowGroupColumn = function (colKey) { this.columnModel.removeRowGroupColumn(colKey, 'api'); };\n /** Same as `removeRowGroupColumn` but provide a list of columns. */\n ColumnApi.prototype.removeRowGroupColumns = function (colKeys) { this.columnModel.removeRowGroupColumns(colKeys, 'api'); };\n /** Add a column to the row groups. */\n ColumnApi.prototype.addRowGroupColumn = function (colKey) { this.columnModel.addRowGroupColumn(colKey, 'api'); };\n /** Same as `addRowGroupColumn` but provide a list of columns. */\n ColumnApi.prototype.addRowGroupColumns = function (colKeys) { this.columnModel.addRowGroupColumns(colKeys, 'api'); };\n /** Get row group columns. */\n ColumnApi.prototype.getRowGroupColumns = function () { return this.columnModel.getRowGroupColumns(); };\n /** Set the pivot columns. */\n ColumnApi.prototype.setPivotColumns = function (colKeys) { this.columnModel.setPivotColumns(colKeys, 'api'); };\n /** Remove a pivot column. */\n ColumnApi.prototype.removePivotColumn = function (colKey) { this.columnModel.removePivotColumn(colKey, 'api'); };\n /** Same as `removePivotColumn` but provide a list of columns. */\n ColumnApi.prototype.removePivotColumns = function (colKeys) { this.columnModel.removePivotColumns(colKeys, 'api'); };\n /** Add a pivot column. */\n ColumnApi.prototype.addPivotColumn = function (colKey) { this.columnModel.addPivotColumn(colKey, 'api'); };\n /** Same as `addPivotColumn` but provide a list of columns. */\n ColumnApi.prototype.addPivotColumns = function (colKeys) { this.columnModel.addPivotColumns(colKeys, 'api'); };\n /** Get the pivot columns. */\n ColumnApi.prototype.getPivotColumns = function () { return this.columnModel.getPivotColumns(); };\n /** Same as `getAllDisplayedColumnGroups` but just for the pinned left portion of the grid. */\n ColumnApi.prototype.getLeftDisplayedColumnGroups = function () { return this.columnModel.getDisplayedTreeLeft(); };\n /** Same as `getAllDisplayedColumnGroups` but just for the center portion of the grid. */\n ColumnApi.prototype.getCenterDisplayedColumnGroups = function () { return this.columnModel.getDisplayedTreeCentre(); };\n /** Same as `getAllDisplayedColumnGroups` but just for the pinned right portion of the grid. */\n ColumnApi.prototype.getRightDisplayedColumnGroups = function () { return this.columnModel.getDisplayedTreeRight(); };\n /** Returns all 'root' column headers. If you are not grouping columns, these return the columns. If you are grouping, these return the top level groups - you can navigate down through each one to get the other lower level headers and finally the columns at the bottom. */\n ColumnApi.prototype.getAllDisplayedColumnGroups = function () { return this.columnModel.getAllDisplayedTrees(); };\n /** Auto-sizes a column based on its contents. */\n ColumnApi.prototype.autoSizeColumn = function (key, skipHeader) { return this.columnModel.autoSizeColumn(key, skipHeader, 'api'); };\n /** Same as `autoSizeColumn`, but provide a list of column keys. */\n ColumnApi.prototype.autoSizeColumns = function (keys, skipHeader) {\n this.columnModel.autoSizeColumns({ columns: keys, skipHeader: skipHeader });\n };\n /** Calls `autoSizeColumns` on all displayed columns. */\n ColumnApi.prototype.autoSizeAllColumns = function (skipHeader) { this.columnModel.autoSizeAllColumns(skipHeader, 'api'); };\n /** @deprecated Use `setPivotResultColumns` instead. */\n ColumnApi.prototype.setSecondaryColumns = function (colDefs) {\n console.warn('AG Grid: since version 28.0.x setSecondaryColumns has been renamed, please use setPivotResultColumns instead');\n this.setPivotResultColumns(colDefs);\n };\n /** Set the pivot result columns. */\n ColumnApi.prototype.setPivotResultColumns = function (colDefs) { this.columnModel.setSecondaryColumns(colDefs, 'api'); };\n /** @deprecated Use `getPivotResultColumns` instead. */\n ColumnApi.prototype.getSecondaryColumns = function () {\n console.warn('AG Grid: since version 28.0.x getSecondaryColumns has been renamed, please use getPivotResultColumns instead');\n return this.getPivotResultColumns();\n };\n /** Returns the grid's pivot result columns. */\n ColumnApi.prototype.getPivotResultColumns = function () { return this.columnModel.getSecondaryColumns(); };\n /** @deprecated Use `getColumns` instead. */\n ColumnApi.prototype.getPrimaryColumns = function () {\n console.warn('AG Grid: since version 28.0.x getPrimaryColumns has been renamed, please use getColumns instead');\n return this.getColumns();\n };\n ColumnApi.prototype.cleanDownReferencesToAvoidMemoryLeakInCaseApplicationIsKeepingReferenceToDestroyedGrid = function () {\n // some users were raising support issues with regards memory leaks. the problem was the customers applications\n // were keeping references to the API. trying to educate them all would be difficult, easier to just remove\n // all references in the API so at least the core grid can be garbage collected.\n //\n // wait about 100ms before clearing down the references, in case user has some cleanup to do,\n // and needs to deference the API first\n setTimeout(_.removeAllReferences.bind(window, this, 'Column API'), 100);\n };\n // below goes through deprecated items, prints message to user, then calls the new version of the same method\n // public getColumnDefs(): (ColDef | ColGroupDef)[] {\n // this.setColumnGroupOpened(group, newValue);\n // return null;\n // }\n /** @deprecated Use `getColumns` instead */\n ColumnApi.prototype.getAllColumns = function () {\n console.warn('AG Grid: since version 28.0.x getAllColumns has been renamed, please use getColumns instead');\n return this.getColumns();\n };\n /** @deprecated columnGroupOpened no longer exists, use setColumnGroupOpened */\n ColumnApi.prototype.columnGroupOpened = function (group, newValue) {\n console.error('AG Grid: columnGroupOpened no longer exists, use setColumnGroupOpened');\n this.setColumnGroupOpened(group, newValue);\n };\n /** @deprecated hideColumns is deprecated, use setColumnsVisible */\n ColumnApi.prototype.hideColumns = function (colIds, hide) {\n console.error('AG Grid: hideColumns is deprecated, use setColumnsVisible');\n this.columnModel.setColumnsVisible(colIds, !hide, 'api');\n };\n /** @deprecated hideColumn is deprecated, use setColumnVisible */\n ColumnApi.prototype.hideColumn = function (colId, hide) {\n console.error('AG Grid: hideColumn is deprecated, use setColumnVisible');\n this.columnModel.setColumnVisible(colId, !hide, 'api');\n };\n /** @deprecated setState is deprecated, use setColumnState */\n ColumnApi.prototype.setState = function (columnState) {\n console.error('AG Grid: setState is deprecated, use setColumnState');\n return this.setColumnState(columnState);\n };\n /** @deprecated getState is deprecated, use getColumnState */\n ColumnApi.prototype.getState = function () {\n console.error('AG Grid: getState is deprecated, use getColumnState');\n return this.getColumnState();\n };\n /** @deprecated resetState is deprecated, use resetColumnState */\n ColumnApi.prototype.resetState = function () {\n console.error('AG Grid: resetState is deprecated, use resetColumnState');\n this.resetColumnState();\n };\n /** @deprecated getAggregationColumns is deprecated, use getValueColumns */\n ColumnApi.prototype.getAggregationColumns = function () {\n console.error('AG Grid: getAggregationColumns is deprecated, use getValueColumns');\n return this.columnModel.getValueColumns();\n };\n /** @deprecated removeAggregationColumn is deprecated, use removeValueColumn */\n ColumnApi.prototype.removeAggregationColumn = function (colKey) {\n console.error('AG Grid: removeAggregationColumn is deprecated, use removeValueColumn');\n this.columnModel.removeValueColumn(colKey, 'api');\n };\n /** @deprecated removeAggregationColumns is deprecated, use removeValueColumns */\n ColumnApi.prototype.removeAggregationColumns = function (colKeys) {\n console.error('AG Grid: removeAggregationColumns is deprecated, use removeValueColumns');\n this.columnModel.removeValueColumns(colKeys, 'api');\n };\n /** @deprecated addAggregationColumn is deprecated, use addValueColumn */\n ColumnApi.prototype.addAggregationColumn = function (colKey) {\n console.error('AG Grid: addAggregationColumn is deprecated, use addValueColumn');\n this.columnModel.addValueColumn(colKey, 'api');\n };\n /** @deprecated addAggregationColumns is deprecated, use addValueColumns */\n ColumnApi.prototype.addAggregationColumns = function (colKeys) {\n console.error('AG Grid: addAggregationColumns is deprecated, use addValueColumns');\n this.columnModel.addValueColumns(colKeys, 'api');\n };\n /** @deprecated setColumnAggFunction is deprecated, use setColumnAggFunc */\n ColumnApi.prototype.setColumnAggFunction = function (column, aggFunc) {\n console.error('AG Grid: setColumnAggFunction is deprecated, use setColumnAggFunc');\n this.columnModel.setColumnAggFunc(column, aggFunc, 'api');\n };\n /** @deprecated getDisplayNameForCol is deprecated, use getDisplayNameForColumn */\n ColumnApi.prototype.getDisplayNameForCol = function (column) {\n console.error('AG Grid: getDisplayNameForCol is deprecated, use getDisplayNameForColumn');\n return this.getDisplayNameForColumn(column, null);\n };\n /** @deprecated setColumnState is deprecated, use applyColumnState. */\n ColumnApi.prototype.setColumnState = function (columnState) {\n console.error('AG Grid: setColumnState is deprecated, use applyColumnState');\n return this.columnModel.applyColumnState({ state: columnState, applyOrder: true }, 'api');\n };\n /** @deprecated getOriginalColumnGroup is deprecated, use getProvidedColumnGroup. */\n ColumnApi.prototype.getOriginalColumnGroup = function (name) {\n console.error('AG Grid: getOriginalColumnGroup is deprecated, use getProvidedColumnGroup');\n return this.columnModel.getProvidedColumnGroup(name);\n };\n __decorate([\n Autowired('columnModel')\n ], ColumnApi.prototype, \"columnModel\", void 0);\n __decorate([\n PreDestroy\n ], ColumnApi.prototype, \"cleanDownReferencesToAvoidMemoryLeakInCaseApplicationIsKeepingReferenceToDestroyedGrid\", null);\n ColumnApi = __decorate([\n Bean('columnApi')\n ], ColumnApi);\n return ColumnApi;\n}());\nexport { ColumnApi };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, PostConstruct } from \"../context/context\";\nimport { Events } from \"../events\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { getValueUsingField } from \"../utils/object\";\nimport { missing, exists } from \"../utils/generic\";\nimport { doOnce } from \"../utils/function\";\nvar ValueService = /** @class */ (function (_super) {\n __extends(ValueService, _super);\n function ValueService() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.initialised = false;\n return _this;\n }\n ValueService.prototype.init = function () {\n var _this = this;\n this.cellExpressions = this.gridOptionsWrapper.isEnableCellExpressions();\n this.initialised = true;\n // We listen to our own event and use it to call the columnSpecific callback,\n // this way the handler calls are correctly interleaved with other global events\n this.eventService.addEventListener(Events.EVENT_CELL_VALUE_CHANGED, function (event) { return _this.callColumnCellValueChangedHandler(event); }, this.gridOptionsWrapper.useAsyncEvents());\n };\n ValueService.prototype.getValue = function (column, rowNode, forFilter, ignoreAggData) {\n if (forFilter === void 0) { forFilter = false; }\n if (ignoreAggData === void 0) { ignoreAggData = false; }\n // hack - the grid is getting refreshed before this bean gets initialised, race condition.\n // really should have a way so they get initialised in the right order???\n if (!this.initialised) {\n this.init();\n }\n if (!rowNode) {\n return;\n }\n // pull these out to make code below easier to read\n var colDef = column.getColDef();\n var field = colDef.field;\n var colId = column.getId();\n var data = rowNode.data;\n var result;\n // if there is a value getter, this gets precedence over a field\n var groupDataExists = rowNode.groupData && rowNode.groupData[colId] !== undefined;\n var aggDataExists = !ignoreAggData && rowNode.aggData && rowNode.aggData[colId] !== undefined;\n if (forFilter && colDef.filterValueGetter) {\n result = this.executeFilterValueGetter(colDef.filterValueGetter, data, column, rowNode);\n }\n else if (this.gridOptionsWrapper.isTreeData() && aggDataExists) {\n result = rowNode.aggData[colId];\n }\n else if (this.gridOptionsWrapper.isTreeData() && colDef.valueGetter) {\n result = this.executeValueGetter(colDef.valueGetter, data, column, rowNode);\n }\n else if (this.gridOptionsWrapper.isTreeData() && (field && data)) {\n result = getValueUsingField(data, field, column.isFieldContainsDots());\n }\n else if (groupDataExists) {\n result = rowNode.groupData[colId];\n }\n else if (aggDataExists) {\n result = rowNode.aggData[colId];\n }\n else if (colDef.valueGetter) {\n result = this.executeValueGetter(colDef.valueGetter, data, column, rowNode);\n }\n else if (field && data) {\n result = getValueUsingField(data, field, column.isFieldContainsDots());\n }\n // the result could be an expression itself, if we are allowing cell values to be expressions\n if (this.cellExpressions && (typeof result === 'string') && result.indexOf('=') === 0) {\n var cellValueGetter = result.substring(1);\n result = this.executeValueGetter(cellValueGetter, data, column, rowNode);\n }\n if (result == null) {\n var openedGroup = this.getOpenedGroup(rowNode, column);\n if (openedGroup != null) {\n return openedGroup;\n }\n }\n return result;\n };\n ValueService.prototype.getOpenedGroup = function (rowNode, column) {\n if (!this.gridOptionsWrapper.isShowOpenedGroup()) {\n return;\n }\n var colDef = column.getColDef();\n if (!colDef.showRowGroup) {\n return;\n }\n var showRowGroup = column.getColDef().showRowGroup;\n var pointer = rowNode.parent;\n while (pointer != null) {\n if (pointer.rowGroupColumn && (showRowGroup === true || showRowGroup === pointer.rowGroupColumn.getId())) {\n return pointer.key;\n }\n pointer = pointer.parent;\n }\n return undefined;\n };\n /**\n * Sets the value of a GridCell\n * @param rowNode The `RowNode` to be updated\n * @param colKey The `Column` to be updated\n * @param newValue The new value to be set\n * @param eventSource The event source\n * @returns `True` if the value has been updated, otherwise`False`.\n */\n ValueService.prototype.setValue = function (rowNode, colKey, newValue, eventSource) {\n var column = this.columnModel.getPrimaryColumn(colKey);\n if (!rowNode || !column) {\n return false;\n }\n // this will only happen if user is trying to paste into a group row, which doesn't make sense\n // the user should not be trying to paste into group rows\n if (missing(rowNode.data)) {\n rowNode.data = {};\n }\n // for backwards compatibility we are also retrieving the newValueHandler as well as the valueSetter\n var _a = column.getColDef(), field = _a.field, newValueHandler = _a.newValueHandler, valueSetter = _a.valueSetter;\n // need either a field or a newValueHandler for this to work\n if (missing(field) && missing(newValueHandler) && missing(valueSetter)) {\n // we don't tell user about newValueHandler, as that is deprecated\n console.warn(\"AG Grid: you need either field or valueSetter set on colDef for editing to work\");\n return false;\n }\n var params = {\n node: rowNode,\n data: rowNode.data,\n oldValue: this.getValue(column, rowNode),\n newValue: newValue,\n colDef: column.getColDef(),\n column: column,\n api: this.gridOptionsWrapper.getApi(),\n columnApi: this.gridOptionsWrapper.getColumnApi(),\n context: this.gridOptionsWrapper.getContext()\n };\n params.newValue = newValue;\n var valueWasDifferent;\n if (newValueHandler && exists(newValueHandler)) {\n valueWasDifferent = newValueHandler(params);\n }\n else if (exists(valueSetter)) {\n valueWasDifferent = this.expressionService.evaluate(valueSetter, params);\n }\n else {\n valueWasDifferent = this.setValueUsingField(rowNode.data, field, newValue, column.isFieldContainsDots());\n }\n // in case user forgot to return something (possible if they are not using TypeScript\n // and just forgot, or using an old newValueHandler we didn't always expect a return\n // value here), we default the return value to true, so we always refresh.\n if (valueWasDifferent === undefined) {\n valueWasDifferent = true;\n }\n // if no change to the value, then no need to do the updating, or notifying via events.\n // otherwise the user could be tabbing around the grid, and cellValueChange would get called\n // all the time.\n if (!valueWasDifferent) {\n return false;\n }\n // reset quick filter on this row\n rowNode.resetQuickFilterAggregateText();\n this.valueCache.onDataChanged();\n params.newValue = this.getValue(column, rowNode);\n var event = {\n type: Events.EVENT_CELL_VALUE_CHANGED,\n event: null,\n rowIndex: rowNode.rowIndex,\n rowPinned: rowNode.rowPinned,\n column: params.column,\n api: params.api,\n columnApi: params.columnApi,\n colDef: params.colDef,\n context: params.context,\n data: rowNode.data,\n node: rowNode,\n oldValue: params.oldValue,\n newValue: params.newValue,\n value: params.newValue,\n source: eventSource\n };\n this.eventService.dispatchEvent(event);\n return true;\n };\n ValueService.prototype.callColumnCellValueChangedHandler = function (event) {\n var onCellValueChanged = event.colDef.onCellValueChanged;\n if (typeof onCellValueChanged === 'function') {\n onCellValueChanged({\n node: event.node,\n data: event.data,\n oldValue: event.oldValue,\n newValue: event.newValue,\n colDef: event.colDef,\n column: event.column,\n api: event.api,\n columnApi: event.columnApi,\n context: event.context\n });\n }\n };\n ValueService.prototype.setValueUsingField = function (data, field, newValue, isFieldContainsDots) {\n if (!field) {\n return false;\n }\n // if no '.', then it's not a deep value\n var valuesAreSame = false;\n if (!isFieldContainsDots) {\n // soft comparison to match strings and numbers\n valuesAreSame = data[field] == newValue;\n if (!valuesAreSame) {\n data[field] = newValue;\n }\n }\n else {\n // otherwise it is a deep value, so need to dig for it\n var fieldPieces = field.split('.');\n var currentObject = data;\n while (fieldPieces.length > 0 && currentObject) {\n var fieldPiece = fieldPieces.shift();\n if (fieldPieces.length === 0) {\n // soft comparison to match strings and numbers\n valuesAreSame = currentObject[fieldPiece] == newValue;\n if (!valuesAreSame) {\n currentObject[fieldPiece] = newValue;\n }\n }\n else {\n currentObject = currentObject[fieldPiece];\n }\n }\n }\n return !valuesAreSame;\n };\n ValueService.prototype.executeFilterValueGetter = function (valueGetter, data, column, rowNode) {\n var params = {\n data: data,\n node: rowNode,\n column: column,\n colDef: column.getColDef(),\n api: this.gridOptionsWrapper.getApi(),\n columnApi: this.gridOptionsWrapper.getColumnApi(),\n context: this.gridOptionsWrapper.getContext(),\n getValue: this.getValueCallback.bind(this, rowNode)\n };\n return this.expressionService.evaluate(valueGetter, params);\n };\n ValueService.prototype.executeValueGetter = function (valueGetter, data, column, rowNode) {\n var colId = column.getId();\n // if inside the same turn, just return back the value we got last time\n var valueFromCache = this.valueCache.getValue(rowNode, colId);\n if (valueFromCache !== undefined) {\n return valueFromCache;\n }\n var params = {\n data: data,\n node: rowNode,\n column: column,\n colDef: column.getColDef(),\n api: this.gridOptionsWrapper.getApi(),\n columnApi: this.gridOptionsWrapper.getColumnApi(),\n context: this.gridOptionsWrapper.getContext(),\n getValue: this.getValueCallback.bind(this, rowNode)\n };\n var result = this.expressionService.evaluate(valueGetter, params);\n // if a turn is active, store the value in case the grid asks for it again\n this.valueCache.setValue(rowNode, colId, result);\n return result;\n };\n ValueService.prototype.getValueCallback = function (node, field) {\n var otherColumn = this.columnModel.getPrimaryColumn(field);\n if (otherColumn) {\n return this.getValue(otherColumn, node);\n }\n return null;\n };\n // used by row grouping and pivot, to get key for a row. col can be a pivot col or a row grouping col\n ValueService.prototype.getKeyForNode = function (col, rowNode) {\n var value = this.getValue(col, rowNode);\n var keyCreator = col.getColDef().keyCreator;\n var result = value;\n if (keyCreator) {\n var keyParams = {\n value: value,\n colDef: col.getColDef(),\n column: col,\n node: rowNode,\n data: rowNode.data,\n api: this.gridOptionsWrapper.getApi(),\n columnApi: this.gridOptionsWrapper.getColumnApi(),\n context: this.gridOptionsWrapper.getContext()\n };\n result = keyCreator(keyParams);\n }\n // if already a string, or missing, just return it\n if (typeof result === 'string' || result == null) {\n return result;\n }\n result = String(result);\n if (result === '[object Object]') {\n doOnce(function () {\n console.warn('AG Grid: a column you are grouping or pivoting by has objects as values. If you want to group by complex objects then either a) use a colDef.keyCreator (se AG Grid docs) or b) to toString() on the object to return a key');\n }, 'getKeyForNode - warn about [object,object]');\n }\n return result;\n };\n __decorate([\n Autowired('expressionService')\n ], ValueService.prototype, \"expressionService\", void 0);\n __decorate([\n Autowired('columnModel')\n ], ValueService.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('valueCache')\n ], ValueService.prototype, \"valueCache\", void 0);\n __decorate([\n PostConstruct\n ], ValueService.prototype, \"init\", null);\n ValueService = __decorate([\n Bean('valueService')\n ], ValueService);\n return ValueService;\n}(BeanStub));\nexport { ValueService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n};\nimport { Bean } from \"../context/context\";\nimport { Qualifier } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nvar ExpressionService = /** @class */ (function (_super) {\n __extends(ExpressionService, _super);\n function ExpressionService() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.expressionToFunctionCache = {};\n return _this;\n }\n ExpressionService.prototype.setBeans = function (loggerFactory) {\n this.logger = loggerFactory.create('ExpressionService');\n };\n ExpressionService.prototype.evaluate = function (expressionOrFunc, params) {\n if (typeof expressionOrFunc === 'function') {\n // valueGetter is a function, so just call it\n var func = expressionOrFunc;\n return func(params);\n }\n else if (typeof expressionOrFunc === 'string') {\n // valueGetter is an expression, so execute the expression\n var expression = expressionOrFunc;\n return this.evaluateExpression(expression, params);\n }\n else {\n console.error('AG Grid: value should be either a string or a function', expressionOrFunc);\n }\n };\n ExpressionService.prototype.evaluateExpression = function (expression, params) {\n try {\n var javaScriptFunction = this.createExpressionFunction(expression);\n // the params don't have all these values, rather we add every possible\n // value a params can have, which makes whatever is in the params available.\n var result = javaScriptFunction(params.value, params.context, params.oldValue, params.newValue, params.value, params.node, params.data, params.colDef, params.rowIndex, params.api, params.columnApi, params.getValue, params.column, params.columnGroup);\n return result;\n }\n catch (e) {\n // the expression failed, which can happen, as it's the client that\n // provides the expression. so print a nice message\n // tslint:disable-next-line\n console.log('Processing of the expression failed');\n // tslint:disable-next-line\n console.log('Expression = ' + expression);\n // tslint:disable-next-line\n console.log('Params =', params);\n // tslint:disable-next-line\n console.log('Exception = ' + e);\n return null;\n }\n };\n ExpressionService.prototype.createExpressionFunction = function (expression) {\n // check cache first\n if (this.expressionToFunctionCache[expression]) {\n return this.expressionToFunctionCache[expression];\n }\n // if not found in cache, return the function\n var functionBody = this.createFunctionBody(expression);\n var theFunction = new Function('x, ctx, oldValue, newValue, value, node, data, colDef, rowIndex, api, columnApi, getValue, column, columnGroup', functionBody);\n // store in cache\n this.expressionToFunctionCache[expression] = theFunction;\n return theFunction;\n };\n ExpressionService.prototype.createFunctionBody = function (expression) {\n // if the expression has the 'return' word in it, then use as is,\n // if not, then wrap it with return and ';' to make a function\n if (expression.indexOf('return') >= 0) {\n return expression;\n }\n else {\n return 'return ' + expression + ';';\n }\n };\n __decorate([\n __param(0, Qualifier('loggerFactory'))\n ], ExpressionService.prototype, \"setBeans\", null);\n ExpressionService = __decorate([\n Bean('expressionService')\n ], ExpressionService);\n return ExpressionService;\n}(BeanStub));\nexport { ExpressionService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean } from \"./context/context\";\nimport { BeanStub } from \"./context/beanStub\";\nvar TemplateService = /** @class */ (function (_super) {\n __extends(TemplateService, _super);\n function TemplateService() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.templateCache = {};\n _this.waitingCallbacks = {};\n return _this;\n }\n // returns the template if it is loaded, or null if it is not loaded\n // but will call the callback when it is loaded\n TemplateService.prototype.getTemplate = function (url, callback) {\n var templateFromCache = this.templateCache[url];\n if (templateFromCache) {\n return templateFromCache;\n }\n var callbackList = this.waitingCallbacks[url];\n var that = this;\n if (!callbackList) {\n // first time this was called, so need a new list for callbacks\n callbackList = [];\n this.waitingCallbacks[url] = callbackList;\n // and also need to do the http request\n var client = new XMLHttpRequest();\n client.onload = function () {\n that.handleHttpResult(this, url);\n };\n client.open(\"GET\", url);\n client.send();\n }\n // add this callback\n if (callback) {\n callbackList.push(callback);\n }\n // caller needs to wait for template to load, so return null\n return null;\n };\n TemplateService.prototype.handleHttpResult = function (httpResult, url) {\n if (httpResult.status !== 200 || httpResult.response === null) {\n console.warn(\"AG Grid: Unable to get template error \" + httpResult.status + \" - \" + url);\n return;\n }\n // response success, so process it\n // in IE9 the response is in - responseText\n this.templateCache[url] = httpResult.response || httpResult.responseText;\n // inform all listeners that this is now in the cache\n var callbacks = this.waitingCallbacks[url];\n for (var i = 0; i < callbacks.length; i++) {\n var callback = callbacks[i];\n // we could pass the callback the response, however we know the client of this code\n // is the cell renderer, and it passes the 'cellRefresh' method in as the callback\n // which doesn't take any parameters.\n callback();\n }\n };\n TemplateService = __decorate([\n Bean('templateService')\n ], TemplateService);\n return TemplateService;\n}(BeanStub));\nexport { TemplateService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n};\nimport { Bean } from \"./context/context\";\nimport { Qualifier } from \"./context/context\";\nimport { BeanStub } from \"./context/beanStub\";\nvar LoggerFactory = /** @class */ (function (_super) {\n __extends(LoggerFactory, _super);\n function LoggerFactory() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n LoggerFactory.prototype.setBeans = function (gridOptionsWrapper) {\n this.logging = gridOptionsWrapper.isDebug();\n };\n LoggerFactory.prototype.create = function (name) {\n return new Logger(name, this.isLogging.bind(this));\n };\n LoggerFactory.prototype.isLogging = function () {\n return this.logging;\n };\n __decorate([\n __param(0, Qualifier('gridOptionsWrapper'))\n ], LoggerFactory.prototype, \"setBeans\", null);\n LoggerFactory = __decorate([\n Bean('loggerFactory')\n ], LoggerFactory);\n return LoggerFactory;\n}(BeanStub));\nexport { LoggerFactory };\nvar Logger = /** @class */ (function () {\n function Logger(name, isLoggingFunc) {\n this.name = name;\n this.isLoggingFunc = isLoggingFunc;\n }\n Logger.prototype.isLogging = function () {\n return this.isLoggingFunc();\n };\n Logger.prototype.log = function (message) {\n if (this.isLoggingFunc()) {\n // tslint:disable-next-line\n console.log('AG Grid.' + this.name + ': ' + message);\n }\n };\n return Logger;\n}());\nexport { Logger };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { ModuleRegistry } from \"../modules/moduleRegistry\";\nimport { ModuleNames } from \"../modules/moduleNames\";\nimport { LayoutFeature } from \"../styling/layoutFeature\";\nimport { Events } from \"../eventKeys\";\nimport { last } from \"../utils/array\";\nimport { DragAndDropService, DragSourceType } from \"../dragAndDrop/dragAndDropService\";\nvar GridCtrl = /** @class */ (function (_super) {\n __extends(GridCtrl, _super);\n function GridCtrl() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n GridCtrl.prototype.setComp = function (view, eGridDiv, eGui) {\n var _this = this;\n this.view = view;\n this.eGridHostDiv = eGridDiv;\n this.eGui = eGui;\n // this drop target is just used to see if the drop event is inside the grid\n this.dragAndDropService.addDropTarget({\n getContainer: function () { return _this.eGui; },\n isInterestedIn: function (type) { return type === DragSourceType.HeaderCell || type === DragSourceType.ToolPanel; },\n getIconName: function () { return DragAndDropService.ICON_NOT_ALLOWED; },\n });\n this.mouseEventService.stampTopLevelGridCompWithGridInstance(eGridDiv);\n this.createManagedBean(new LayoutFeature(this.view));\n // important to set rtl before doLayout, as setting the RTL class impacts the scroll position,\n // which doLayout indirectly depends on\n this.addRtlSupport();\n this.addManagedListener(this, Events.EVENT_KEYBOARD_FOCUS, function () {\n _this.view.addOrRemoveKeyboardFocusClass(true);\n });\n this.addManagedListener(this, Events.EVENT_MOUSE_FOCUS, function () {\n _this.view.addOrRemoveKeyboardFocusClass(false);\n });\n var unsubscribeFromResize = this.resizeObserverService.observeResize(this.eGridHostDiv, this.onGridSizeChanged.bind(this));\n this.addDestroyFunc(function () { return unsubscribeFromResize(); });\n this.ctrlsService.registerGridCtrl(this);\n };\n GridCtrl.prototype.isDetailGrid = function () {\n var _a, _b;\n var el = this.focusService.findTabbableParent(this.getGui());\n return ((_b = (_a = el) === null || _a === void 0 ? void 0 : _a.getAttribute('row-id')) === null || _b === void 0 ? void 0 : _b.startsWith('detail')) || false;\n };\n GridCtrl.prototype.showDropZones = function () {\n return ModuleRegistry.isRegistered(ModuleNames.RowGroupingModule);\n };\n GridCtrl.prototype.showSideBar = function () {\n return ModuleRegistry.isRegistered(ModuleNames.SideBarModule);\n };\n GridCtrl.prototype.showStatusBar = function () {\n return ModuleRegistry.isRegistered(ModuleNames.StatusBarModule);\n };\n GridCtrl.prototype.showWatermark = function () {\n return ModuleRegistry.isRegistered(ModuleNames.EnterpriseCoreModule);\n };\n GridCtrl.prototype.onGridSizeChanged = function () {\n var event = {\n type: Events.EVENT_GRID_SIZE_CHANGED,\n clientWidth: this.eGridHostDiv.clientWidth,\n clientHeight: this.eGridHostDiv.clientHeight\n };\n this.eventService.dispatchEvent(event);\n };\n GridCtrl.prototype.addRtlSupport = function () {\n var cssClass = this.gridOptionsWrapper.isEnableRtl() ? 'ag-rtl' : 'ag-ltr';\n this.view.setRtlClass(cssClass);\n };\n GridCtrl.prototype.destroyGridUi = function () {\n this.view.destroyGridUi();\n };\n GridCtrl.prototype.getGui = function () {\n return this.eGui;\n };\n GridCtrl.prototype.setResizeCursor = function (on) {\n this.view.setCursor(on ? 'ew-resize' : null);\n };\n GridCtrl.prototype.disableUserSelect = function (on) {\n this.view.setUserSelect(on ? 'none' : null);\n };\n GridCtrl.prototype.focusNextInnerContainer = function (backwards) {\n var eDocument = this.gridOptionsWrapper.getDocument();\n var focusableContainers = this.view.getFocusableContainers();\n var idxWithFocus = focusableContainers.findIndex(function (container) { return container.contains(eDocument.activeElement); });\n var nextIdx = idxWithFocus + (backwards ? -1 : 1);\n if (nextIdx <= 0 || nextIdx >= focusableContainers.length) {\n return false;\n }\n return this.focusService.focusInto(focusableContainers[nextIdx]);\n };\n GridCtrl.prototype.focusInnerElement = function (fromBottom) {\n var focusableContainers = this.view.getFocusableContainers();\n if (fromBottom) {\n if (focusableContainers.length > 1) {\n return this.focusService.focusInto(last(focusableContainers), true);\n }\n var lastColumn = last(this.columnModel.getAllDisplayedColumns());\n if (this.focusService.focusGridView(lastColumn, true)) {\n return true;\n }\n }\n return this.focusService.focusFirstHeader();\n };\n GridCtrl.prototype.forceFocusOutOfContainer = function (up) {\n if (up === void 0) { up = false; }\n this.view.forceFocusOutOfContainer(up);\n };\n __decorate([\n Autowired('focusService')\n ], GridCtrl.prototype, \"focusService\", void 0);\n __decorate([\n Autowired('resizeObserverService')\n ], GridCtrl.prototype, \"resizeObserverService\", void 0);\n __decorate([\n Autowired('columnModel')\n ], GridCtrl.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], GridCtrl.prototype, \"ctrlsService\", void 0);\n __decorate([\n Autowired('mouseEventService')\n ], GridCtrl.prototype, \"mouseEventService\", void 0);\n __decorate([\n Autowired('dragAndDropService')\n ], GridCtrl.prototype, \"dragAndDropService\", void 0);\n return GridCtrl;\n}(BeanStub));\nexport { GridCtrl };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from \"../context/context\";\nimport { RefSelector } from \"../widgets/componentAnnotations\";\nimport { isVisible } from \"../utils/dom\";\nimport { FocusService } from \"../focusService\";\nimport { GridCtrl } from \"./gridCtrl\";\nimport { LayoutCssClasses } from \"../styling/layoutFeature\";\nimport { TabGuardComp } from \"../widgets/tabGuardComp\";\nvar GridComp = /** @class */ (function (_super) {\n __extends(GridComp, _super);\n function GridComp(eGridDiv) {\n var _this = _super.call(this, undefined) || this;\n _this.eGridDiv = eGridDiv;\n return _this;\n }\n GridComp.prototype.postConstruct = function () {\n var _this = this;\n this.logger = this.loggerFactory.create('GridComp');\n var compProxy = {\n destroyGridUi: function () { return _this.destroyBean(_this); },\n setRtlClass: function (cssClass) { return _this.addCssClass(cssClass); },\n addOrRemoveKeyboardFocusClass: function (addOrRemove) { return _this.addOrRemoveCssClass(FocusService.AG_KEYBOARD_FOCUS, addOrRemove); },\n forceFocusOutOfContainer: this.forceFocusOutOfContainer.bind(this),\n updateLayoutClasses: this.updateLayoutClasses.bind(this),\n getFocusableContainers: this.getFocusableContainers.bind(this),\n setUserSelect: function (value) {\n _this.getGui().style.userSelect = value != null ? value : '';\n _this.getGui().style.webkitUserSelect = value != null ? value : '';\n },\n setCursor: function (value) {\n _this.getGui().style.cursor = value != null ? value : '';\n }\n };\n this.ctrl = this.createManagedBean(new GridCtrl());\n var template = this.createTemplate();\n this.setTemplate(template);\n this.ctrl.setComp(compProxy, this.eGridDiv, this.getGui());\n this.insertGridIntoDom();\n this.initialiseTabGuard({\n // we want to override the default behaviour to do nothing for onTabKeyDown\n onTabKeyDown: function () { return undefined; },\n focusInnerElement: function (fromBottom) { return _this.ctrl.focusInnerElement(fromBottom); }\n });\n };\n GridComp.prototype.insertGridIntoDom = function () {\n var _this = this;\n var eGui = this.getGui();\n this.eGridDiv.appendChild(eGui);\n this.addDestroyFunc(function () {\n _this.eGridDiv.removeChild(eGui);\n _this.logger.log('Grid removed from DOM');\n });\n };\n GridComp.prototype.updateLayoutClasses = function (cssClass, params) {\n var eRootWrapperBodyClassList = this.eRootWrapperBody.classList;\n eRootWrapperBodyClassList.toggle(LayoutCssClasses.AUTO_HEIGHT, params.autoHeight);\n eRootWrapperBodyClassList.toggle(LayoutCssClasses.NORMAL, params.normal);\n eRootWrapperBodyClassList.toggle(LayoutCssClasses.PRINT, params.print);\n this.addOrRemoveCssClass(LayoutCssClasses.AUTO_HEIGHT, params.autoHeight);\n this.addOrRemoveCssClass(LayoutCssClasses.NORMAL, params.normal);\n this.addOrRemoveCssClass(LayoutCssClasses.PRINT, params.print);\n };\n GridComp.prototype.createTemplate = function () {\n var dropZones = this.ctrl.showDropZones() ? '' : '';\n var sideBar = this.ctrl.showSideBar() ? '' : '';\n var statusBar = this.ctrl.showStatusBar() ? '' : '';\n var watermark = this.ctrl.showWatermark() ? '' : '';\n var template = /* html */ \"
\\n \" + dropZones + \"\\n
\\n \\n \" + sideBar + \"\\n
\\n \" + statusBar + \"\\n \\n \" + watermark + \"\\n
\";\n return template;\n };\n GridComp.prototype.getFocusableElement = function () {\n return this.eRootWrapperBody;\n };\n GridComp.prototype.getFocusableContainers = function () {\n var focusableContainers = [\n this.gridBodyComp.getGui()\n ];\n if (this.sideBarComp) {\n focusableContainers.push(this.sideBarComp.getGui());\n }\n return focusableContainers.filter(function (el) { return isVisible(el); });\n };\n __decorate([\n Autowired('loggerFactory')\n ], GridComp.prototype, \"loggerFactory\", void 0);\n __decorate([\n RefSelector('gridBody')\n ], GridComp.prototype, \"gridBodyComp\", void 0);\n __decorate([\n RefSelector('sideBar')\n ], GridComp.prototype, \"sideBarComp\", void 0);\n __decorate([\n RefSelector('rootWrapperBody')\n ], GridComp.prototype, \"eRootWrapperBody\", void 0);\n __decorate([\n PostConstruct\n ], GridComp.prototype, \"postConstruct\", null);\n return GridComp;\n}(TabGuardComp));\nexport { GridComp };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nimport { Autowired, Bean } from \"./context/context\";\nimport { BeanStub } from \"./context/beanStub\";\nimport { Constants } from \"./constants/constants\";\nimport { Events } from \"./events\";\nvar SortController = /** @class */ (function (_super) {\n __extends(SortController, _super);\n function SortController() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n SortController_1 = SortController;\n SortController.prototype.progressSort = function (column, multiSort, source) {\n var nextDirection = this.getNextSortDirection(column);\n this.setSortForColumn(column, nextDirection, multiSort, source);\n };\n SortController.prototype.setSortForColumn = function (column, sort, multiSort, source) {\n var _a;\n // auto correct - if sort not legal value, then set it to 'no sort' (which is null)\n if (sort !== Constants.SORT_ASC && sort !== Constants.SORT_DESC) {\n sort = null;\n }\n var isColumnsSortingCoupledToGroup = this.gridOptionsWrapper.isColumnsSortingCoupledToGroup();\n var columnsToUpdate = [column];\n if (isColumnsSortingCoupledToGroup) {\n if (column.getColDef().showRowGroup) {\n var rowGroupColumns = this.columnModel.getSourceColumnsForGroupColumn(column);\n var sortableRowGroupColumns = (_a = rowGroupColumns) === null || _a === void 0 ? void 0 : _a.filter(function (col) { return col.getColDef().sortable; });\n if (sortableRowGroupColumns) {\n columnsToUpdate = __spread([column], sortableRowGroupColumns);\n }\n }\n }\n columnsToUpdate.forEach(function (col) { return col.setSort(sort, source); });\n var doingMultiSort = (multiSort || this.gridOptionsWrapper.isAlwaysMultiSort()) && !this.gridOptionsWrapper.isSuppressMultiSort();\n // clear sort on all columns except those changed, and update the icons\n if (!doingMultiSort) {\n this.clearSortBarTheseColumns(columnsToUpdate, source);\n }\n // sortIndex used for knowing order of cols when multi-col sort\n this.updateSortIndex(column);\n this.dispatchSortChangedEvents(source);\n };\n SortController.prototype.updateSortIndex = function (lastColToChange) {\n var isCoupled = this.gridOptionsWrapper.isColumnsSortingCoupledToGroup();\n var groupParent = this.columnModel.getGroupDisplayColumnForGroup(lastColToChange.getId());\n var lastSortIndexCol = isCoupled ? groupParent || lastColToChange : lastColToChange;\n var allSortedCols = this.getIndexableColumnsOrdered();\n // reset sort index on everything\n this.columnModel.getPrimaryAndSecondaryAndAutoColumns().forEach(function (col) { return col.setSortIndex(null); });\n var allSortedColsWithoutChanges = allSortedCols.filter(function (col) { return col !== lastSortIndexCol; });\n var sortedColsWithIndices = !!lastSortIndexCol.getSort() ? __spread(allSortedColsWithoutChanges, [lastSortIndexCol]) : allSortedColsWithoutChanges;\n sortedColsWithIndices.forEach(function (col, idx) { return (col.setSortIndex(idx)); });\n };\n // gets called by API, so if data changes, use can call this, which will end up\n // working out the sort order again of the rows.\n SortController.prototype.onSortChanged = function (source) {\n this.dispatchSortChangedEvents(source);\n };\n SortController.prototype.isSortActive = function () {\n // pull out all the columns that have sorting set\n var allCols = this.columnModel.getPrimaryAndSecondaryAndAutoColumns();\n var sortedCols = allCols.filter(function (column) { return !!column.getSort(); });\n return sortedCols && sortedCols.length > 0;\n };\n SortController.prototype.dispatchSortChangedEvents = function (source) {\n var event = {\n type: Events.EVENT_SORT_CHANGED,\n source: source\n };\n this.eventService.dispatchEvent(event);\n };\n SortController.prototype.clearSortBarTheseColumns = function (columnsToSkip, source) {\n this.columnModel.getPrimaryAndSecondaryAndAutoColumns().forEach(function (columnToClear) {\n // Do not clear if either holding shift, or if column in question was clicked\n if (!columnsToSkip.includes(columnToClear)) {\n // setting to 'undefined' as null means 'none' rather than cleared, otherwise issue will arise\n // if sort order is: ['desc', null , 'asc'], as it will start at null rather than 'desc'.\n columnToClear.setSort(undefined, source);\n }\n });\n };\n SortController.prototype.getNextSortDirection = function (column) {\n var sortingOrder;\n if (column.getColDef().sortingOrder) {\n sortingOrder = column.getColDef().sortingOrder;\n }\n else if (this.gridOptionsWrapper.getSortingOrder()) {\n sortingOrder = this.gridOptionsWrapper.getSortingOrder();\n }\n else {\n sortingOrder = SortController_1.DEFAULT_SORTING_ORDER;\n }\n if (!Array.isArray(sortingOrder) || sortingOrder.length <= 0) {\n console.warn(\"AG Grid: sortingOrder must be an array with at least one element, currently it's \" + sortingOrder);\n return null;\n }\n var currentIndex = sortingOrder.indexOf(column.getSort());\n var notInArray = currentIndex < 0;\n var lastItemInArray = currentIndex == sortingOrder.length - 1;\n var result;\n if (notInArray || lastItemInArray) {\n result = sortingOrder[0];\n }\n else {\n result = sortingOrder[currentIndex + 1];\n }\n // verify the sort type exists, as the user could provide the sortingOrder, need to make sure it's valid\n if (SortController_1.DEFAULT_SORTING_ORDER.indexOf(result) < 0) {\n console.warn('AG Grid: invalid sort type ' + result);\n return null;\n }\n return result;\n };\n SortController.prototype.getColumnsOrderedForSort = function () {\n // pull out all the columns that have sorting set\n var allColumnsIncludingAuto = this.columnModel.getPrimaryAndSecondaryAndAutoColumns();\n // when both cols are missing sortIndex, we use the position of the col in all cols list.\n // this means if colDefs only have sort, but no sortIndex, we deterministically pick which\n // cols is sorted by first.\n var allColsIndexes = {};\n allColumnsIncludingAuto.forEach(function (col, index) { return allColsIndexes[col.getId()] = index; });\n // put the columns in order of which one got sorted first\n allColumnsIncludingAuto.sort(function (a, b) {\n var iA = a.getSortIndex();\n var iB = b.getSortIndex();\n if (iA != null && iB != null) {\n return iA - iB; // both present, normal comparison\n }\n else if (iA == null && iB == null) {\n // both missing, compare using column positions\n var posA = allColsIndexes[a.getId()];\n var posB = allColsIndexes[b.getId()];\n return posA > posB ? 1 : -1;\n }\n else if (iB == null) {\n return -1; // iB missing\n }\n else {\n return 1; // iA missing\n }\n });\n return allColumnsIncludingAuto;\n };\n SortController.prototype.getIndexableColumnsOrdered = function () {\n var _this = this;\n { }\n if (!this.gridOptionsWrapper.isColumnsSortingCoupledToGroup()) {\n return this.getColumnsWithSortingOrdered();\n }\n return this.getColumnsOrderedForSort()\n .filter(function (col) {\n var _a;\n if (!!col.getColDef().showRowGroup) {\n if (col.getColDef().field && col.getSort()) {\n return true;\n }\n var sourceCols = _this.columnModel.getSourceColumnsForGroupColumn(col);\n return (_a = sourceCols) === null || _a === void 0 ? void 0 : _a.some(function (col) { return !!col.getSort(); });\n }\n return !!col.getSort();\n });\n };\n SortController.prototype.getColumnsWithSortingOrdered = function () {\n // pull out all the columns that have sorting set\n var orderedColumns = this.getColumnsOrderedForSort();\n return orderedColumns.filter(function (column) { return !!column.getSort(); });\n };\n // used by server side row models, to sent sort to server\n SortController.prototype.getSortModel = function () {\n return this.getColumnsWithSortingOrdered().map(function (column) { return ({\n sort: column.getSort(),\n colId: column.getId()\n }); });\n };\n SortController.prototype.getSortOptions = function () {\n return this.getColumnsWithSortingOrdered().map(function (column) { return ({\n sort: column.getSort(),\n column: column\n }); });\n };\n SortController.prototype.canColumnDisplayMixedSort = function (column) {\n var isColumnSortCouplingActive = this.gridOptionsWrapper.isColumnsSortingCoupledToGroup();\n var isGroupDisplayColumn = !!column.getColDef().showRowGroup;\n return isColumnSortCouplingActive && isGroupDisplayColumn;\n };\n SortController.prototype.getDisplaySortForColumn = function (column) {\n var _a;\n var linkedColumns = this.columnModel.getSourceColumnsForGroupColumn(column);\n if (!this.canColumnDisplayMixedSort(column) || !((_a = linkedColumns) === null || _a === void 0 ? void 0 : _a.length)) {\n return column.getSort();\n }\n // if column has unique data, its sorting is independent - but can still be mixed\n var columnHasUniqueData = !!column.getColDef().field;\n var sortableColumns = columnHasUniqueData ? __spread([column], linkedColumns) : linkedColumns;\n var firstSort = sortableColumns[0].getSort();\n // the == is intentional, as null and undefined both represent no sort, which means they are equivalent\n var allMatch = sortableColumns.every(function (col) { return col.getSort() == firstSort; });\n if (!allMatch) {\n return 'mixed';\n }\n return firstSort;\n };\n SortController.prototype.getDisplaySortIndexForColumn = function (column) {\n var _this = this;\n var isColumnSortCouplingActive = this.gridOptionsWrapper.isColumnsSortingCoupledToGroup();\n if (!isColumnSortCouplingActive) {\n return this.getColumnsWithSortingOrdered().indexOf(column);\n }\n var displayColumn = this.columnModel.getGroupDisplayColumnForGroup(column.getId());\n if (displayColumn) {\n if (!!column.getSort()) {\n return this.getDisplaySortIndexForColumn(displayColumn);\n }\n return null;\n }\n var allSortedCols = this.getIndexableColumnsOrdered()\n .filter(function (col) { return !_this.columnModel.getGroupDisplayColumnForGroup(col.getId()); });\n return allSortedCols.indexOf(column);\n };\n var SortController_1;\n SortController.DEFAULT_SORTING_ORDER = [Constants.SORT_ASC, Constants.SORT_DESC, null];\n __decorate([\n Autowired('columnModel')\n ], SortController.prototype, \"columnModel\", void 0);\n SortController = SortController_1 = __decorate([\n Bean('sortController')\n ], SortController);\n return SortController;\n}(BeanStub));\nexport { SortController };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../context/beanStub\";\nimport { Bean } from \"../context/context\";\nimport { Events } from \"../events\";\nvar ColumnHoverService = /** @class */ (function (_super) {\n __extends(ColumnHoverService, _super);\n function ColumnHoverService() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n ColumnHoverService.prototype.setMouseOver = function (columns) {\n this.selectedColumns = columns;\n var event = {\n type: Events.EVENT_COLUMN_HOVER_CHANGED\n };\n this.eventService.dispatchEvent(event);\n };\n ColumnHoverService.prototype.clearMouseOver = function () {\n this.selectedColumns = null;\n var event = {\n type: Events.EVENT_COLUMN_HOVER_CHANGED\n };\n this.eventService.dispatchEvent(event);\n };\n ColumnHoverService.prototype.isHovered = function (column) {\n return !!this.selectedColumns && this.selectedColumns.indexOf(column) >= 0;\n };\n ColumnHoverService = __decorate([\n Bean('columnHoverService')\n ], ColumnHoverService);\n return ColumnHoverService;\n}(BeanStub));\nexport { ColumnHoverService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, PostConstruct } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nvar ColumnAnimationService = /** @class */ (function (_super) {\n __extends(ColumnAnimationService, _super);\n function ColumnAnimationService() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.executeNextFuncs = [];\n _this.executeLaterFuncs = [];\n _this.active = false;\n _this.animationThreadCount = 0;\n return _this;\n }\n ColumnAnimationService.prototype.postConstruct = function () {\n var _this = this;\n this.ctrlsService.whenReady(function (p) { return _this.gridBodyCtrl = p.gridBodyCtrl; });\n };\n ColumnAnimationService.prototype.isActive = function () {\n return this.active;\n };\n ColumnAnimationService.prototype.start = function () {\n if (this.active) {\n return;\n }\n if (this.gridOptionsWrapper.isSuppressColumnMoveAnimation()) {\n return;\n }\n // if doing RTL, we don't animate open / close as due to how the pixels are inverted,\n // the animation moves all the row the the right rather than to the left (ie it's the static\n // columns that actually get their coordinates updated)\n if (this.gridOptionsWrapper.isEnableRtl()) {\n return;\n }\n this.ensureAnimationCssClassPresent();\n this.active = true;\n };\n ColumnAnimationService.prototype.finish = function () {\n if (!this.active) {\n return;\n }\n this.flush();\n this.active = false;\n };\n ColumnAnimationService.prototype.executeNextVMTurn = function (func) {\n if (this.active) {\n this.executeNextFuncs.push(func);\n }\n else {\n func();\n }\n };\n ColumnAnimationService.prototype.executeLaterVMTurn = function (func) {\n if (this.active) {\n this.executeLaterFuncs.push(func);\n }\n else {\n func();\n }\n };\n ColumnAnimationService.prototype.ensureAnimationCssClassPresent = function () {\n var _this = this;\n // up the count, so we can tell if someone else has updated the count\n // by the time the 'wait' func executes\n this.animationThreadCount++;\n var animationThreadCountCopy = this.animationThreadCount;\n this.gridBodyCtrl.setColumnMovingCss(true);\n this.executeLaterFuncs.push(function () {\n // only remove the class if this thread was the last one to update it\n if (_this.animationThreadCount === animationThreadCountCopy) {\n _this.gridBodyCtrl.setColumnMovingCss(false);\n }\n });\n };\n ColumnAnimationService.prototype.flush = function () {\n var nowFuncs = this.executeNextFuncs;\n this.executeNextFuncs = [];\n var waitFuncs = this.executeLaterFuncs;\n this.executeLaterFuncs = [];\n if (nowFuncs.length === 0 && waitFuncs.length === 0) {\n return;\n }\n window.setTimeout(function () { return nowFuncs.forEach(function (func) { return func(); }); }, 0);\n window.setTimeout(function () { return waitFuncs.forEach(function (func) { return func(); }); }, 300);\n };\n __decorate([\n Autowired('ctrlsService')\n ], ColumnAnimationService.prototype, \"ctrlsService\", void 0);\n __decorate([\n PostConstruct\n ], ColumnAnimationService.prototype, \"postConstruct\", null);\n ColumnAnimationService = __decorate([\n Bean('columnAnimationService')\n ], ColumnAnimationService);\n return ColumnAnimationService;\n}(BeanStub));\nexport { ColumnAnimationService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean } from \"../context/context\";\nimport { Column } from \"../entities/column\";\nimport { Constants } from \"../constants/constants\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { mergeDeep } from \"../utils/object\";\nimport { missing } from \"../utils/generic\";\nvar AutoGroupColService = /** @class */ (function (_super) {\n __extends(AutoGroupColService, _super);\n function AutoGroupColService() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n AutoGroupColService_1 = AutoGroupColService;\n AutoGroupColService.prototype.createAutoGroupColumns = function (existingCols, rowGroupColumns) {\n var _this = this;\n var groupAutoColumns = [];\n var doingTreeData = this.gridOptionsWrapper.isTreeData();\n var doingMultiAutoColumn = this.gridOptionsWrapper.isGroupMultiAutoColumn();\n if (doingTreeData && doingMultiAutoColumn) {\n console.warn('AG Grid: you cannot mix groupMultiAutoColumn with treeData, only one column can be used to display groups when doing tree data');\n doingMultiAutoColumn = false;\n }\n // if doing groupMultiAutoColumn, then we call the method multiple times, once\n // for each column we are grouping by\n if (doingMultiAutoColumn) {\n rowGroupColumns.forEach(function (rowGroupCol, index) {\n groupAutoColumns.push(_this.createOneAutoGroupColumn(existingCols, rowGroupCol, index));\n });\n }\n else {\n groupAutoColumns.push(this.createOneAutoGroupColumn(existingCols));\n }\n return groupAutoColumns;\n };\n // rowGroupCol and index are missing if groupMultiAutoColumn=false\n AutoGroupColService.prototype.createOneAutoGroupColumn = function (existingCols, rowGroupCol, index) {\n // if one provided by user, use it, otherwise create one\n var defaultAutoColDef = this.generateDefaultColDef(rowGroupCol);\n // if doing multi, set the field\n var colId;\n if (rowGroupCol) {\n colId = Constants.GROUP_AUTO_COLUMN_ID + \"-\" + rowGroupCol.getId();\n }\n else {\n colId = AutoGroupColService_1.GROUP_AUTO_COLUMN_BUNDLE_ID;\n }\n var userAutoColDef = this.gridOptionsWrapper.getAutoGroupColumnDef();\n mergeDeep(defaultAutoColDef, userAutoColDef);\n defaultAutoColDef = this.columnFactory.mergeColDefs(defaultAutoColDef);\n defaultAutoColDef.colId = colId;\n // For tree data the filter is always allowed\n if (!this.gridOptionsWrapper.isTreeData()) {\n // we would only allow filter if the user has provided field or value getter. otherwise the filter\n // would not be able to work.\n var noFieldOrValueGetter = missing(defaultAutoColDef.field) && missing(defaultAutoColDef.valueGetter) && missing(defaultAutoColDef.filterValueGetter);\n if (noFieldOrValueGetter) {\n defaultAutoColDef.filter = false;\n }\n }\n // if showing many cols, we don't want to show more than one with a checkbox for selection\n if (index && index > 0) {\n defaultAutoColDef.headerCheckboxSelection = false;\n }\n var existingCol = existingCols.find(function (col) { return col.getId() == colId; });\n if (existingCol) {\n existingCol.setColDef(defaultAutoColDef, null);\n this.columnFactory.applyColumnState(existingCol, defaultAutoColDef);\n return existingCol;\n }\n var newCol = new Column(defaultAutoColDef, null, colId, true);\n this.context.createBean(newCol);\n return newCol;\n };\n AutoGroupColService.prototype.generateDefaultColDef = function (rowGroupCol) {\n var userDef = this.gridOptionsWrapper.getAutoGroupColumnDef();\n var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();\n var res = {\n headerName: localeTextFunc('group', 'Group')\n };\n var userHasProvidedGroupCellRenderer = userDef &&\n (userDef.cellRenderer || userDef.cellRendererFramework || userDef.cellRendererSelector);\n // only add the default group cell renderer if user hasn't provided one\n if (!userHasProvidedGroupCellRenderer) {\n res.cellRenderer = 'agGroupCellRenderer';\n }\n // we never allow moving the group column\n // defaultAutoColDef.suppressMovable = true;\n if (rowGroupCol) {\n var colDef = rowGroupCol.getColDef();\n Object.assign(res, {\n // cellRendererParams.groupKey: colDefToCopy.field;\n headerName: this.columnModel.getDisplayNameForColumn(rowGroupCol, 'header'),\n headerValueGetter: colDef.headerValueGetter\n });\n if (colDef.cellRenderer || colDef.cellRendererFramework) {\n Object.assign(res, {\n cellRendererParams: {\n innerRenderer: colDef.cellRenderer,\n innerRendererFramework: colDef.cellRendererFramework,\n innerRendererParams: colDef.cellRendererParams\n }\n });\n }\n res.showRowGroup = rowGroupCol.getColId();\n }\n else {\n res.showRowGroup = true;\n }\n return res;\n };\n var AutoGroupColService_1;\n AutoGroupColService.GROUP_AUTO_COLUMN_BUNDLE_ID = Constants.GROUP_AUTO_COLUMN_ID;\n __decorate([\n Autowired('columnModel')\n ], AutoGroupColService.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('columnFactory')\n ], AutoGroupColService.prototype, \"columnFactory\", void 0);\n AutoGroupColService = AutoGroupColService_1 = __decorate([\n Bean('autoGroupColService')\n ], AutoGroupColService);\n return AutoGroupColService;\n}(BeanStub));\nexport { AutoGroupColService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../context/beanStub\";\nimport { Events } from \"../events\";\nimport { Autowired, Bean, PostConstruct } from \"../context/context\";\nvar PaginationAutoPageSizeService = /** @class */ (function (_super) {\n __extends(PaginationAutoPageSizeService, _super);\n function PaginationAutoPageSizeService() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n PaginationAutoPageSizeService.prototype.postConstruct = function () {\n var _this = this;\n this.ctrlsService.whenReady(function (p) {\n _this.centerRowContainerCon = p.centerRowContainerCtrl;\n _this.addManagedListener(_this.eventService, Events.EVENT_BODY_HEIGHT_CHANGED, _this.onBodyHeightChanged.bind(_this));\n _this.addManagedListener(_this.eventService, Events.EVENT_SCROLL_VISIBILITY_CHANGED, _this.onScrollVisibilityChanged.bind(_this));\n _this.checkPageSize();\n });\n };\n PaginationAutoPageSizeService.prototype.notActive = function () {\n return !this.gridOptionsWrapper.isPaginationAutoPageSize();\n };\n PaginationAutoPageSizeService.prototype.onScrollVisibilityChanged = function () {\n this.checkPageSize();\n };\n PaginationAutoPageSizeService.prototype.onBodyHeightChanged = function () {\n this.checkPageSize();\n };\n PaginationAutoPageSizeService.prototype.checkPageSize = function () {\n if (this.notActive()) {\n return;\n }\n var rowHeight = this.gridOptionsWrapper.getRowHeightAsNumber();\n var bodyHeight = this.centerRowContainerCon.getViewportSizeFeature().getBodyHeight();\n if (bodyHeight > 0) {\n var newPageSize = Math.floor(bodyHeight / rowHeight);\n this.gridOptionsWrapper.setProperty('paginationPageSize', newPageSize);\n }\n };\n __decorate([\n Autowired('ctrlsService')\n ], PaginationAutoPageSizeService.prototype, \"ctrlsService\", void 0);\n __decorate([\n PostConstruct\n ], PaginationAutoPageSizeService.prototype, \"postConstruct\", null);\n PaginationAutoPageSizeService = __decorate([\n Bean('paginationAutoPageSizeService')\n ], PaginationAutoPageSizeService);\n return PaginationAutoPageSizeService;\n}(BeanStub));\nexport { PaginationAutoPageSizeService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean, PostConstruct } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nvar ValueCache = /** @class */ (function (_super) {\n __extends(ValueCache, _super);\n function ValueCache() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.cacheVersion = 0;\n return _this;\n }\n ValueCache.prototype.init = function () {\n this.active = this.gridOptionsWrapper.isValueCache();\n this.neverExpires = this.gridOptionsWrapper.isValueCacheNeverExpires();\n };\n ValueCache.prototype.onDataChanged = function () {\n if (this.neverExpires) {\n return;\n }\n this.expire();\n };\n ValueCache.prototype.expire = function () {\n this.cacheVersion++;\n };\n ValueCache.prototype.setValue = function (rowNode, colId, value) {\n if (this.active) {\n if (rowNode.__cacheVersion !== this.cacheVersion) {\n rowNode.__cacheVersion = this.cacheVersion;\n rowNode.__cacheData = {};\n }\n rowNode.__cacheData[colId] = value;\n }\n };\n ValueCache.prototype.getValue = function (rowNode, colId) {\n if (!this.active || rowNode.__cacheVersion !== this.cacheVersion) {\n return undefined;\n }\n return rowNode.__cacheData[colId];\n };\n __decorate([\n PostConstruct\n ], ValueCache.prototype, \"init\", null);\n ValueCache = __decorate([\n Bean('valueCache')\n ], ValueCache);\n return ValueCache;\n}(BeanStub));\nexport { ValueCache };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../context/beanStub\";\nimport { Autowired, Bean, PostConstruct } from \"../context/context\";\nimport { ChangedPath } from \"../utils/changedPath\";\nimport { Constants } from \"../constants/constants\";\nimport { Events } from \"../events\";\nvar ChangeDetectionService = /** @class */ (function (_super) {\n __extends(ChangeDetectionService, _super);\n function ChangeDetectionService() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n ChangeDetectionService.prototype.init = function () {\n if (this.rowModel.getType() === Constants.ROW_MODEL_TYPE_CLIENT_SIDE) {\n this.clientSideRowModel = this.rowModel;\n }\n this.addManagedListener(this.eventService, Events.EVENT_CELL_VALUE_CHANGED, this.onCellValueChanged.bind(this));\n };\n ChangeDetectionService.prototype.onCellValueChanged = function (event) {\n // Clipboard service manages its own change detection, so no need to do it here.\n // The clipboard manages its own as otherwise this would happen once for every cell\n // that got updated as part of a paste operation, so e.g. if 100 cells in a paste operation,\n // this doChangeDetection would get called 100 times (once for each cell), instead clipboard\n // service executes the logic we have here once (in essence batching up all cell changes\n // into one change detection).\n if (event.source === Constants.SOURCE_PASTE) {\n return;\n }\n this.doChangeDetection(event.node, event.column);\n };\n ChangeDetectionService.prototype.doChangeDetection = function (rowNode, column) {\n if (this.gridOptionsWrapper.isSuppressChangeDetection()) {\n return;\n }\n // step 1 of change detection is to update the aggregated values\n if (this.clientSideRowModel && !rowNode.isRowPinned()) {\n var onlyChangedColumns = this.gridOptionsWrapper.isAggregateOnlyChangedColumns();\n var changedPath = new ChangedPath(onlyChangedColumns, this.clientSideRowModel.getRootNode());\n changedPath.addParentNode(rowNode.parent, [column]);\n this.clientSideRowModel.doAggregate(changedPath);\n }\n // step 2 of change detection is to refresh the cells\n this.rowRenderer.refreshCells();\n };\n __decorate([\n Autowired('rowModel')\n ], ChangeDetectionService.prototype, \"rowModel\", void 0);\n __decorate([\n Autowired('rowRenderer')\n ], ChangeDetectionService.prototype, \"rowRenderer\", void 0);\n __decorate([\n PostConstruct\n ], ChangeDetectionService.prototype, \"init\", null);\n ChangeDetectionService = __decorate([\n Bean('changeDetectionService')\n ], ChangeDetectionService);\n return ChangeDetectionService;\n}(BeanStub));\nexport { ChangeDetectionService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean } from \"../../context/context\";\nimport { BeanStub } from \"../../context/beanStub\";\nimport { loadTemplate } from \"../../utils/dom\";\nvar AgComponentUtils = /** @class */ (function (_super) {\n __extends(AgComponentUtils, _super);\n function AgComponentUtils() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n AgComponentUtils.prototype.adaptFunction = function (propertyName, jsCompFunc) {\n var metadata = this.componentMetadataProvider.retrieve(propertyName);\n if (metadata && metadata.functionAdapter) {\n return metadata.functionAdapter(jsCompFunc);\n }\n return null;\n };\n AgComponentUtils.prototype.adaptCellRendererFunction = function (callback) {\n var Adapter = /** @class */ (function () {\n function Adapter() {\n }\n Adapter.prototype.refresh = function (params) {\n return false;\n };\n Adapter.prototype.getGui = function () {\n return this.eGui;\n };\n Adapter.prototype.init = function (params) {\n var callbackResult = callback(params);\n var type = typeof callbackResult;\n if (type === 'string' || type === 'number' || type === 'boolean') {\n this.eGui = loadTemplate('' + callbackResult + '');\n return;\n }\n if (callbackResult == null) {\n this.eGui = loadTemplate('');\n return;\n }\n this.eGui = callbackResult;\n };\n return Adapter;\n }());\n return Adapter;\n };\n AgComponentUtils.prototype.doesImplementIComponent = function (candidate) {\n if (!candidate) {\n return false;\n }\n return candidate.prototype && 'getGui' in candidate.prototype;\n };\n __decorate([\n Autowired(\"componentMetadataProvider\")\n ], AgComponentUtils.prototype, \"componentMetadataProvider\", void 0);\n AgComponentUtils = __decorate([\n Bean(\"agComponentUtils\")\n ], AgComponentUtils);\n return AgComponentUtils;\n}(BeanStub));\nexport { AgComponentUtils };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, PostConstruct } from \"../../context/context\";\nimport { BeanStub } from \"../../context/beanStub\";\nvar ComponentMetadataProvider = /** @class */ (function (_super) {\n __extends(ComponentMetadataProvider, _super);\n function ComponentMetadataProvider() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n ComponentMetadataProvider.prototype.postConstruct = function () {\n this.componentMetaData = {\n dateComponent: {\n mandatoryMethodList: ['getDate', 'setDate'],\n optionalMethodList: ['afterGuiAttached', 'setInputPlaceholder', 'setInputAriaLabel']\n },\n detailCellRenderer: {\n mandatoryMethodList: [],\n optionalMethodList: ['refresh'],\n functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)\n },\n headerComponent: {\n mandatoryMethodList: [],\n optionalMethodList: ['refresh']\n },\n headerGroupComponent: {\n mandatoryMethodList: [],\n optionalMethodList: []\n },\n loadingCellRenderer: {\n mandatoryMethodList: [],\n optionalMethodList: []\n },\n loadingOverlayComponent: {\n mandatoryMethodList: [],\n optionalMethodList: []\n },\n noRowsOverlayComponent: {\n mandatoryMethodList: [],\n optionalMethodList: []\n },\n floatingFilterComponent: {\n mandatoryMethodList: ['onParentModelChanged'],\n optionalMethodList: ['afterGuiAttached']\n },\n floatingFilterWrapperComponent: {\n mandatoryMethodList: [],\n optionalMethodList: []\n },\n cellRenderer: {\n mandatoryMethodList: [],\n optionalMethodList: ['refresh', 'afterGuiAttached'],\n functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)\n },\n cellEditor: {\n mandatoryMethodList: ['getValue'],\n optionalMethodList: ['isPopup', 'isCancelBeforeStart', 'isCancelAfterEnd', 'getPopupPosition', 'focusIn', 'focusOut', 'afterGuiAttached']\n },\n innerRenderer: {\n mandatoryMethodList: [],\n optionalMethodList: ['afterGuiAttached'],\n functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)\n },\n fullWidthCellRenderer: {\n mandatoryMethodList: [],\n optionalMethodList: ['refresh', 'afterGuiAttached'],\n functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)\n },\n pinnedRowCellRenderer: {\n mandatoryMethodList: [],\n optionalMethodList: ['refresh', 'afterGuiAttached'],\n functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)\n },\n groupRowRenderer: {\n mandatoryMethodList: [],\n optionalMethodList: ['afterGuiAttached'],\n functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)\n },\n filter: {\n mandatoryMethodList: ['isFilterActive', 'doesFilterPass', 'getModel', 'setModel'],\n optionalMethodList: ['afterGuiAttached', 'onNewRowsLoaded', 'getModelAsString', 'onFloatingFilterChanged']\n },\n filterComponent: {\n mandatoryMethodList: ['isFilterActive', 'doesFilterPass', 'getModel', 'setModel'],\n optionalMethodList: ['afterGuiAttached', 'onNewRowsLoaded', 'getModelAsString', 'onFloatingFilterChanged']\n },\n statusPanel: {\n mandatoryMethodList: [],\n optionalMethodList: ['afterGuiAttached'],\n },\n toolPanel: {\n mandatoryMethodList: [],\n optionalMethodList: ['refresh', 'afterGuiAttached']\n },\n tooltipComponent: {\n mandatoryMethodList: [],\n optionalMethodList: []\n }\n };\n };\n ComponentMetadataProvider.prototype.retrieve = function (name) {\n return this.componentMetaData[name];\n };\n __decorate([\n Autowired(\"agComponentUtils\")\n ], ComponentMetadataProvider.prototype, \"agComponentUtils\", void 0);\n __decorate([\n PostConstruct\n ], ComponentMetadataProvider.prototype, \"postConstruct\", null);\n ComponentMetadataProvider = __decorate([\n Bean(\"componentMetadataProvider\")\n ], ComponentMetadataProvider);\n return ComponentMetadataProvider;\n}(BeanStub));\nexport { ComponentMetadataProvider };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean, Autowired } from './context/context';\nimport { BeanStub } from \"./context/beanStub\";\nimport { doOnce } from './utils/function';\nvar MAT_GRID_SIZE = 8;\nvar BASE_GRID_SIZE = 4;\nvar BALHAM_GRID_SIZE = 4;\nvar ALPINE_GRID_SIZE = 6;\nvar HARD_CODED_SIZES = {\n // this item is required for custom themes\n 'ag-theme-custom': {\n headerHeight: 25,\n headerCellMinWidth: 24,\n listItemHeight: BASE_GRID_SIZE * 5,\n rowHeight: 25,\n chartMenuPanelWidth: 220\n },\n 'ag-theme-material': {\n headerHeight: MAT_GRID_SIZE * 7,\n headerCellMinWidth: 48,\n listItemHeight: MAT_GRID_SIZE * 4,\n rowHeight: MAT_GRID_SIZE * 6,\n chartMenuPanelWidth: 240\n },\n 'ag-theme-balham': {\n headerHeight: BALHAM_GRID_SIZE * 8,\n headerCellMinWidth: 24,\n listItemHeight: BALHAM_GRID_SIZE * 6,\n rowHeight: BALHAM_GRID_SIZE * 7,\n chartMenuPanelWidth: 220\n },\n 'ag-theme-alpine': {\n headerHeight: ALPINE_GRID_SIZE * 8,\n headerCellMinWidth: 36,\n listItemHeight: ALPINE_GRID_SIZE * 4,\n rowHeight: ALPINE_GRID_SIZE * 7,\n chartMenuPanelWidth: 240\n }\n};\n/**\n * this object contains a list of Sass variables and an array\n * of CSS styles required to get the correct value.\n * eg. $virtual-item-height requires a structure, so we can get its height.\n *
\n *
\n *
\n *
\n *
\n */\nvar SASS_PROPERTY_BUILDER = {\n headerHeight: ['ag-header-row'],\n headerCellMinWidth: ['ag-header-cell'],\n listItemHeight: ['ag-virtual-list-item'],\n rowHeight: ['ag-row'],\n chartMenuPanelWidth: ['ag-chart-docked-container']\n};\nvar CALCULATED_SIZES = {};\nvar Environment = /** @class */ (function (_super) {\n __extends(Environment, _super);\n function Environment() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n Environment.prototype.getSassVariable = function (theme, key) {\n var useTheme = 'ag-theme-' + (theme.match('material') ? 'material' : theme.match('balham') ? 'balham' : theme.match('alpine') ? 'alpine' : 'custom');\n var defaultValue = HARD_CODED_SIZES[useTheme][key];\n var calculatedValue = 0;\n if (!CALCULATED_SIZES[theme]) {\n CALCULATED_SIZES[theme] = {};\n }\n var size = CALCULATED_SIZES[theme][key];\n if (size != null) {\n return size;\n }\n if (SASS_PROPERTY_BUILDER[key]) {\n var classList = SASS_PROPERTY_BUILDER[key];\n var div = document.createElement('div');\n div.classList.add(theme);\n div.style.position = 'absolute';\n var el = classList.reduce(function (prevEl, currentClass) {\n var currentDiv = document.createElement('div');\n currentDiv.style.position = 'static';\n currentDiv.classList.add(currentClass);\n prevEl.appendChild(currentDiv);\n return currentDiv;\n }, div);\n if (document.body) {\n document.body.appendChild(div);\n var sizeName = key.toLowerCase().indexOf('height') !== -1 ? 'height' : 'width';\n calculatedValue = parseInt(window.getComputedStyle(el)[sizeName], 10);\n document.body.removeChild(div);\n }\n }\n CALCULATED_SIZES[theme][key] = calculatedValue || defaultValue;\n return CALCULATED_SIZES[theme][key];\n };\n Environment.prototype.isThemeDark = function () {\n var theme = this.getTheme().theme;\n return !!theme && theme.indexOf('dark') >= 0;\n };\n Environment.prototype.chartMenuPanelWidth = function () {\n var theme = this.getTheme().themeFamily;\n return this.getSassVariable(theme, 'chartMenuPanelWidth');\n };\n Environment.prototype.getTheme = function () {\n var reg = /\\bag-(material|(?:theme-([\\w\\-]*)))\\b/g;\n var el = this.eGridDiv;\n var themeMatch = null;\n var allThemes = [];\n while (el) {\n themeMatch = reg.exec(el.className);\n if (!themeMatch) {\n el = el.parentElement || undefined;\n }\n else {\n var matched = el.className.match(reg);\n if (matched) {\n allThemes = matched;\n }\n break;\n }\n }\n if (!themeMatch) {\n return { allThemes: allThemes };\n }\n var theme = themeMatch[0];\n var usingOldTheme = themeMatch[2] === undefined;\n if (usingOldTheme) {\n var newTheme_1 = theme.replace('ag-', 'ag-theme-');\n doOnce(function () { return console.warn(\"AG Grid: As of v19 old theme are no longer provided. Please replace \" + theme + \" with \" + newTheme_1 + \".\"); }, 'using-old-theme');\n }\n return { theme: theme, el: el, themeFamily: theme.replace(/-dark$/, ''), allThemes: allThemes };\n };\n __decorate([\n Autowired('eGridDiv')\n ], Environment.prototype, \"eGridDiv\", void 0);\n Environment = __decorate([\n Bean('environment')\n ], Environment);\n return Environment;\n}(BeanStub));\nexport { Environment };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n};\nimport { BeanStub } from \"../context/beanStub\";\nimport { Autowired, Bean, PostConstruct, Qualifier } from \"../context/context\";\nimport { Events } from \"../eventKeys\";\nimport { getMaxDivHeight } from \"../utils/browser\";\n/**\n * This class solves the 'max height' problem, where the user might want to show more data than\n * the max div height actually allows.\n */\nvar RowContainerHeightService = /** @class */ (function (_super) {\n __extends(RowContainerHeightService, _super);\n function RowContainerHeightService() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n // the scrollY position\n _this.scrollY = 0;\n // how tall the body is\n _this.uiBodyHeight = 0;\n return _this;\n }\n RowContainerHeightService.prototype.agWire = function (loggerFactory) {\n this.logger = loggerFactory.create(\"RowContainerHeightService\");\n };\n RowContainerHeightService.prototype.postConstruct = function () {\n this.addManagedListener(this.eventService, Events.EVENT_BODY_HEIGHT_CHANGED, this.updateOffset.bind(this));\n this.maxDivHeight = getMaxDivHeight();\n this.logger.log('maxDivHeight = ' + this.maxDivHeight);\n };\n RowContainerHeightService.prototype.isStretching = function () {\n return this.stretching;\n };\n RowContainerHeightService.prototype.getDivStretchOffset = function () {\n return this.divStretchOffset;\n };\n RowContainerHeightService.prototype.updateOffset = function () {\n if (!this.stretching) {\n return;\n }\n var gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n var newScrollY = gridBodyCon.getScrollFeature().getVScrollPosition().top;\n var newBodyHeight = this.getUiBodyHeight();\n var atLeastOneChanged = newScrollY !== this.scrollY || newBodyHeight !== this.uiBodyHeight;\n if (atLeastOneChanged) {\n this.scrollY = newScrollY;\n this.uiBodyHeight = newBodyHeight;\n this.calculateOffset();\n }\n };\n RowContainerHeightService.prototype.calculateOffset = function () {\n this.setUiContainerHeight(this.maxDivHeight);\n this.pixelsToShave = this.modelHeight - this.uiContainerHeight;\n this.maxScrollY = this.uiContainerHeight - this.uiBodyHeight;\n var scrollPercent = this.scrollY / this.maxScrollY;\n var divStretchOffset = scrollPercent * this.pixelsToShave;\n this.logger.log(\"Div Stretch Offset = \" + divStretchOffset + \" (\" + this.pixelsToShave + \" * \" + scrollPercent + \")\");\n this.setDivStretchOffset(divStretchOffset);\n };\n RowContainerHeightService.prototype.setUiContainerHeight = function (height) {\n if (height !== this.uiContainerHeight) {\n this.uiContainerHeight = height;\n this.eventService.dispatchEvent({ type: Events.EVENT_ROW_CONTAINER_HEIGHT_CHANGED });\n }\n };\n RowContainerHeightService.prototype.clearOffset = function () {\n this.setUiContainerHeight(this.modelHeight);\n this.pixelsToShave = 0;\n this.setDivStretchOffset(0);\n };\n RowContainerHeightService.prototype.setDivStretchOffset = function (newOffset) {\n // because we are talking pixels, no point in confusing things with half numbers\n var newOffsetFloor = typeof newOffset === 'number' ? Math.floor(newOffset) : null;\n if (this.divStretchOffset === newOffsetFloor) {\n return;\n }\n this.divStretchOffset = newOffsetFloor;\n this.eventService.dispatchEvent({ type: Events.EVENT_HEIGHT_SCALE_CHANGED });\n };\n RowContainerHeightService.prototype.setModelHeight = function (modelHeight) {\n this.modelHeight = modelHeight;\n this.stretching = modelHeight != null // null happens when in print layout\n && this.maxDivHeight > 0\n && modelHeight > this.maxDivHeight;\n if (this.stretching) {\n this.calculateOffset();\n }\n else {\n this.clearOffset();\n }\n };\n RowContainerHeightService.prototype.getUiContainerHeight = function () {\n return this.uiContainerHeight;\n };\n RowContainerHeightService.prototype.getRealPixelPosition = function (modelPixel) {\n return modelPixel - this.divStretchOffset;\n };\n RowContainerHeightService.prototype.getUiBodyHeight = function () {\n var gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n var pos = gridBodyCon.getScrollFeature().getVScrollPosition();\n return pos.bottom - pos.top;\n };\n RowContainerHeightService.prototype.getScrollPositionForPixel = function (rowTop) {\n if (this.pixelsToShave <= 0) {\n return rowTop;\n }\n var modelMaxScroll = this.modelHeight - this.getUiBodyHeight();\n var scrollPercent = rowTop / modelMaxScroll;\n var scrollPixel = this.maxScrollY * scrollPercent;\n return scrollPixel;\n };\n __decorate([\n Autowired('ctrlsService')\n ], RowContainerHeightService.prototype, \"ctrlsService\", void 0);\n __decorate([\n __param(0, Qualifier(\"loggerFactory\"))\n ], RowContainerHeightService.prototype, \"agWire\", null);\n __decorate([\n PostConstruct\n ], RowContainerHeightService.prototype, \"postConstruct\", null);\n RowContainerHeightService = __decorate([\n Bean('rowContainerHeightService')\n ], RowContainerHeightService);\n return RowContainerHeightService;\n}(BeanStub));\nexport { RowContainerHeightService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean, PostConstruct } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { exists } from \"../utils/generic\";\nvar SelectableService = /** @class */ (function (_super) {\n __extends(SelectableService, _super);\n function SelectableService() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n SelectableService.prototype.init = function () {\n this.groupSelectsChildren = this.gridOptionsWrapper.isGroupSelectsChildren();\n this.isRowSelectableFunc = this.gridOptionsWrapper.getIsRowSelectableFunc();\n };\n SelectableService.prototype.updateSelectableAfterGrouping = function (rowNode) {\n if (this.isRowSelectableFunc) {\n var nextChildrenFunc = function (node) { return node.childrenAfterGroup; };\n this.recurseDown(rowNode.childrenAfterGroup, nextChildrenFunc);\n }\n };\n SelectableService.prototype.recurseDown = function (children, nextChildrenFunc) {\n var _this = this;\n if (!children) {\n return;\n }\n children.forEach(function (child) {\n if (!child.group) {\n return;\n } // only interested in groups\n if (child.hasChildren()) {\n _this.recurseDown(nextChildrenFunc(child), nextChildrenFunc);\n }\n var rowSelectable;\n if (_this.groupSelectsChildren) {\n // have this group selectable if at least one direct child is selectable\n var firstSelectable = (nextChildrenFunc(child) || []).find(function (rowNode) { return rowNode.selectable === true; });\n rowSelectable = exists(firstSelectable);\n }\n else {\n // directly retrieve selectable value from user callback\n rowSelectable = _this.isRowSelectableFunc ? _this.isRowSelectableFunc(child) : false;\n }\n child.setRowSelectable(rowSelectable);\n });\n };\n __decorate([\n PostConstruct\n ], SelectableService.prototype, \"init\", null);\n SelectableService = __decorate([\n Bean('selectableService')\n ], SelectableService);\n return SelectableService;\n}(BeanStub));\nexport { SelectableService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from \"../widgets/component\";\nimport { Autowired, PostConstruct } from \"../context/context\";\nimport { RefSelector } from \"../widgets/componentAnnotations\";\nimport { Events } from \"../events\";\nimport { createIconNoSpan } from \"../utils/icon\";\nimport { formatNumberCommas } from \"../utils/number\";\nimport { setAriaDisabled } from \"../utils/aria\";\nimport { KeyCode } from '../constants/keyCode';\nvar PaginationComp = /** @class */ (function (_super) {\n __extends(PaginationComp, _super);\n function PaginationComp() {\n var _this = _super.call(this) || this;\n _this.previousAndFirstButtonsDisabled = false;\n _this.nextButtonDisabled = false;\n _this.lastButtonDisabled = false;\n return _this;\n }\n PaginationComp.prototype.postConstruct = function () {\n var _this = this;\n var isRtl = this.gridOptionsWrapper.isEnableRtl();\n this.setTemplate(this.getTemplate());\n this.btFirst.insertAdjacentElement('afterbegin', createIconNoSpan(isRtl ? 'last' : 'first', this.gridOptionsWrapper));\n this.btPrevious.insertAdjacentElement('afterbegin', createIconNoSpan(isRtl ? 'next' : 'previous', this.gridOptionsWrapper));\n this.btNext.insertAdjacentElement('afterbegin', createIconNoSpan(isRtl ? 'previous' : 'next', this.gridOptionsWrapper));\n this.btLast.insertAdjacentElement('afterbegin', createIconNoSpan(isRtl ? 'first' : 'last', this.gridOptionsWrapper));\n var isPaging = this.gridOptionsWrapper.isPagination();\n var paginationPanelEnabled = isPaging && !this.gridOptionsWrapper.isSuppressPaginationPanel();\n if (!paginationPanelEnabled) {\n this.setDisplayed(false);\n return;\n }\n this.addManagedListener(this.eventService, Events.EVENT_PAGINATION_CHANGED, this.onPaginationChanged.bind(this));\n [\n { el: this.btFirst, fn: this.onBtFirst.bind(this) },\n { el: this.btPrevious, fn: this.onBtPrevious.bind(this) },\n { el: this.btNext, fn: this.onBtNext.bind(this) },\n { el: this.btLast, fn: this.onBtLast.bind(this) }\n ].forEach(function (item) {\n var el = item.el, fn = item.fn;\n _this.addManagedListener(el, 'click', fn);\n _this.addManagedListener(el, 'keydown', function (e) {\n if (e.key === KeyCode.ENTER || e.key === KeyCode.SPACE) {\n e.preventDefault();\n fn();\n }\n });\n });\n this.onPaginationChanged();\n };\n PaginationComp.prototype.onPaginationChanged = function () {\n this.enableOrDisableButtons();\n this.updateRowLabels();\n this.setCurrentPageLabel();\n this.setTotalLabels();\n };\n PaginationComp.prototype.onBtFirst = function () {\n if (!this.previousAndFirstButtonsDisabled) {\n this.paginationProxy.goToFirstPage();\n }\n };\n PaginationComp.prototype.setCurrentPageLabel = function () {\n var pagesExist = this.paginationProxy.getTotalPages() > 0;\n var currentPage = this.paginationProxy.getCurrentPage();\n var toDisplay = pagesExist ? currentPage + 1 : 0;\n this.lbCurrent.innerHTML = this.formatNumber(toDisplay);\n };\n PaginationComp.prototype.formatNumber = function (value) {\n var userFunc = this.gridOptionsWrapper.getPaginationNumberFormatterFunc();\n if (userFunc) {\n var params = { value: value };\n return userFunc(params);\n }\n var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();\n var thousandSeparator = localeTextFunc('thousandSeparator', ',');\n var decimalSeparator = localeTextFunc('decimalSeparator', '.');\n return formatNumberCommas(value, thousandSeparator, decimalSeparator);\n };\n PaginationComp.prototype.getTemplate = function () {\n var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();\n var strPage = localeTextFunc('page', 'Page');\n var strTo = localeTextFunc('to', 'to');\n var strOf = localeTextFunc('of', 'of');\n var strFirst = localeTextFunc('firstPage', 'First Page');\n var strPrevious = localeTextFunc('previousPage', 'Previous Page');\n var strNext = localeTextFunc('nextPage', 'Next Page');\n var strLast = localeTextFunc('lastPage', 'Last Page');\n var compId = this.getCompId();\n return /* html */ \"
\\n \\n \\n \" + strTo + \"\\n \\n \" + strOf + \"\\n \\n \\n \\n
\\n
\\n \\n \" + strPage + \"\\n \\n \" + strOf + \"\\n \\n \\n
\\n
\\n
\\n
\";\n };\n PaginationComp.prototype.onBtNext = function () {\n if (!this.nextButtonDisabled) {\n this.paginationProxy.goToNextPage();\n }\n };\n PaginationComp.prototype.onBtPrevious = function () {\n if (!this.previousAndFirstButtonsDisabled) {\n this.paginationProxy.goToPreviousPage();\n }\n };\n PaginationComp.prototype.onBtLast = function () {\n if (!this.lastButtonDisabled) {\n this.paginationProxy.goToLastPage();\n }\n };\n PaginationComp.prototype.enableOrDisableButtons = function () {\n var currentPage = this.paginationProxy.getCurrentPage();\n var maxRowFound = this.paginationProxy.isLastPageFound();\n var totalPages = this.paginationProxy.getTotalPages();\n this.previousAndFirstButtonsDisabled = currentPage === 0;\n this.toggleButtonDisabled(this.btFirst, this.previousAndFirstButtonsDisabled);\n this.toggleButtonDisabled(this.btPrevious, this.previousAndFirstButtonsDisabled);\n var zeroPagesToDisplay = this.isZeroPagesToDisplay();\n var onLastPage = maxRowFound && currentPage === (totalPages - 1);\n this.nextButtonDisabled = onLastPage || zeroPagesToDisplay;\n this.lastButtonDisabled = !maxRowFound || zeroPagesToDisplay || currentPage === (totalPages - 1);\n this.toggleButtonDisabled(this.btNext, this.nextButtonDisabled);\n this.toggleButtonDisabled(this.btLast, this.lastButtonDisabled);\n };\n PaginationComp.prototype.toggleButtonDisabled = function (button, disabled) {\n setAriaDisabled(button, disabled);\n button.classList.toggle('ag-disabled', disabled);\n if (disabled) {\n button.removeAttribute('tabindex');\n }\n else {\n button.setAttribute('tabindex', '0');\n }\n };\n PaginationComp.prototype.updateRowLabels = function () {\n var currentPage = this.paginationProxy.getCurrentPage();\n var pageSize = this.paginationProxy.getPageSize();\n var maxRowFound = this.paginationProxy.isLastPageFound();\n var rowCount = this.paginationProxy.isLastPageFound() ?\n this.paginationProxy.getMasterRowCount() : null;\n var startRow;\n var endRow;\n if (this.isZeroPagesToDisplay()) {\n startRow = endRow = 0;\n }\n else {\n startRow = (pageSize * currentPage) + 1;\n endRow = startRow + pageSize - 1;\n if (maxRowFound && endRow > rowCount) {\n endRow = rowCount;\n }\n }\n this.lbFirstRowOnPage.innerHTML = this.formatNumber(startRow);\n if (this.rowNodeBlockLoader.isLoading()) {\n this.lbLastRowOnPage.innerHTML = '?';\n }\n else {\n this.lbLastRowOnPage.innerHTML = this.formatNumber(endRow);\n }\n };\n PaginationComp.prototype.isZeroPagesToDisplay = function () {\n var maxRowFound = this.paginationProxy.isLastPageFound();\n var totalPages = this.paginationProxy.getTotalPages();\n return maxRowFound && totalPages === 0;\n };\n PaginationComp.prototype.setTotalLabels = function () {\n var lastPageFound = this.paginationProxy.isLastPageFound();\n var totalPages = this.paginationProxy.getTotalPages();\n var rowCount = lastPageFound ? this.paginationProxy.getMasterRowCount() : null;\n // When `pivotMode=true` and no grouping or value columns exist, a single 'hidden' group row (root node) is in\n // the grid and the pagination totals will correctly display total = 1. However this is confusing to users as\n // they can't see it. To address this UX issue we simply set the totals to zero in the pagination panel.\n if (rowCount === 1) {\n var firstRow = this.paginationProxy.getRow(0);\n // a group node with no group or agg data will not be visible to users\n var hiddenGroupRow = firstRow && firstRow.group && !(firstRow.groupData || firstRow.aggData);\n if (hiddenGroupRow) {\n this.setTotalLabelsToZero();\n return;\n }\n }\n if (lastPageFound) {\n this.lbTotal.innerHTML = this.formatNumber(totalPages);\n this.lbRecordCount.innerHTML = this.formatNumber(rowCount);\n }\n else {\n var moreText = this.gridOptionsWrapper.getLocaleTextFunc()('more', 'more');\n this.lbTotal.innerHTML = moreText;\n this.lbRecordCount.innerHTML = moreText;\n }\n };\n PaginationComp.prototype.setTotalLabelsToZero = function () {\n this.lbFirstRowOnPage.innerHTML = this.formatNumber(0);\n this.lbCurrent.innerHTML = this.formatNumber(0);\n this.lbLastRowOnPage.innerHTML = this.formatNumber(0);\n this.lbTotal.innerHTML = this.formatNumber(0);\n this.lbRecordCount.innerHTML = this.formatNumber(0);\n };\n __decorate([\n Autowired('paginationProxy')\n ], PaginationComp.prototype, \"paginationProxy\", void 0);\n __decorate([\n Autowired('rowNodeBlockLoader')\n ], PaginationComp.prototype, \"rowNodeBlockLoader\", void 0);\n __decorate([\n RefSelector('btFirst')\n ], PaginationComp.prototype, \"btFirst\", void 0);\n __decorate([\n RefSelector('btPrevious')\n ], PaginationComp.prototype, \"btPrevious\", void 0);\n __decorate([\n RefSelector('btNext')\n ], PaginationComp.prototype, \"btNext\", void 0);\n __decorate([\n RefSelector('btLast')\n ], PaginationComp.prototype, \"btLast\", void 0);\n __decorate([\n RefSelector('lbRecordCount')\n ], PaginationComp.prototype, \"lbRecordCount\", void 0);\n __decorate([\n RefSelector('lbFirstRowOnPage')\n ], PaginationComp.prototype, \"lbFirstRowOnPage\", void 0);\n __decorate([\n RefSelector('lbLastRowOnPage')\n ], PaginationComp.prototype, \"lbLastRowOnPage\", void 0);\n __decorate([\n RefSelector('lbCurrent')\n ], PaginationComp.prototype, \"lbCurrent\", void 0);\n __decorate([\n RefSelector('lbTotal')\n ], PaginationComp.prototype, \"lbTotal\", void 0);\n __decorate([\n PostConstruct\n ], PaginationComp.prototype, \"postConstruct\", null);\n return PaginationComp;\n}(Component));\nexport { PaginationComp };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from '../../context/context';\nimport { Component } from '../../widgets/component';\nimport { RefSelector } from '../../widgets/componentAnnotations';\nimport { clearElement } from '../../utils/dom';\nimport { LayoutCssClasses, LayoutFeature } from \"../../styling/layoutFeature\";\nimport { Events } from \"../../eventKeys\";\nvar LoadingType;\n(function (LoadingType) {\n LoadingType[LoadingType[\"Loading\"] = 0] = \"Loading\";\n LoadingType[LoadingType[\"NoRows\"] = 1] = \"NoRows\";\n})(LoadingType || (LoadingType = {}));\nvar OverlayWrapperComponent = /** @class */ (function (_super) {\n __extends(OverlayWrapperComponent, _super);\n function OverlayWrapperComponent() {\n var _this = _super.call(this, OverlayWrapperComponent.TEMPLATE) || this;\n _this.inProgress = false;\n _this.destroyRequested = false;\n _this.manuallyDisplayed = false;\n return _this;\n }\n OverlayWrapperComponent.prototype.updateLayoutClasses = function (cssClass, params) {\n var overlayWrapperClassList = this.eOverlayWrapper.classList;\n overlayWrapperClassList.toggle(LayoutCssClasses.AUTO_HEIGHT, params.autoHeight);\n overlayWrapperClassList.toggle(LayoutCssClasses.NORMAL, params.normal);\n overlayWrapperClassList.toggle(LayoutCssClasses.PRINT, params.print);\n };\n OverlayWrapperComponent.prototype.postConstruct = function () {\n this.createManagedBean(new LayoutFeature(this));\n this.setDisplayed(false);\n this.addManagedListener(this.eventService, Events.EVENT_ROW_DATA_UPDATED, this.onRowDataUpdated.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_NEW_COLUMNS_LOADED, this.onNewColumnsLoaded.bind(this));\n if (this.gridOptionsWrapper.isRowModelDefault() && !this.gridOptionsWrapper.getRowData()) {\n this.showLoadingOverlay();\n }\n this.gridApi.registerOverlayWrapperComp(this);\n };\n OverlayWrapperComponent.prototype.setWrapperTypeClass = function (loadingType) {\n var overlayWrapperClassList = this.eOverlayWrapper.classList;\n overlayWrapperClassList.toggle('ag-overlay-loading-wrapper', loadingType === LoadingType.Loading);\n overlayWrapperClassList.toggle('ag-overlay-no-rows-wrapper', loadingType === LoadingType.NoRows);\n };\n OverlayWrapperComponent.prototype.showLoadingOverlay = function () {\n if (this.gridOptionsWrapper.isSuppressLoadingOverlay()) {\n return;\n }\n var params = {};\n var compDetails = this.userComponentFactory.getLoadingOverlayCompDetails(params);\n var promise = compDetails.newAgStackInstance();\n this.showOverlay(promise, LoadingType.Loading);\n };\n OverlayWrapperComponent.prototype.showNoRowsOverlay = function () {\n if (this.gridOptionsWrapper.isSuppressNoRowsOverlay()) {\n return;\n }\n var params = {};\n var compDetails = this.userComponentFactory.getNoRowsOverlayCompDetails(params);\n var promise = compDetails.newAgStackInstance();\n this.showOverlay(promise, LoadingType.NoRows);\n };\n OverlayWrapperComponent.prototype.showOverlay = function (workItem, type) {\n var _this = this;\n if (this.inProgress) {\n return;\n }\n this.setWrapperTypeClass(type);\n this.destroyActiveOverlay();\n this.inProgress = true;\n if (workItem) {\n workItem.then(function (comp) {\n _this.inProgress = false;\n _this.eOverlayWrapper.appendChild(comp.getGui());\n _this.activeOverlay = comp;\n if (_this.destroyRequested) {\n _this.destroyRequested = false;\n _this.destroyActiveOverlay();\n }\n });\n }\n this.manuallyDisplayed = this.columnModel.isReady() && !this.paginationProxy.isEmpty();\n this.setDisplayed(true);\n };\n OverlayWrapperComponent.prototype.destroyActiveOverlay = function () {\n if (this.inProgress) {\n this.destroyRequested = true;\n return;\n }\n if (!this.activeOverlay) {\n return;\n }\n this.activeOverlay = this.getContext().destroyBean(this.activeOverlay);\n clearElement(this.eOverlayWrapper);\n };\n OverlayWrapperComponent.prototype.hideOverlay = function () {\n this.manuallyDisplayed = false;\n this.destroyActiveOverlay();\n this.setDisplayed(false);\n };\n OverlayWrapperComponent.prototype.destroy = function () {\n this.destroyActiveOverlay();\n _super.prototype.destroy.call(this);\n };\n OverlayWrapperComponent.prototype.showOrHideOverlay = function () {\n var isEmpty = this.paginationProxy.isEmpty();\n var isSuppressNoRowsOverlay = this.gridOptionsWrapper.isSuppressNoRowsOverlay();\n if (isEmpty && !isSuppressNoRowsOverlay) {\n this.showNoRowsOverlay();\n }\n else {\n this.hideOverlay();\n }\n };\n OverlayWrapperComponent.prototype.onRowDataUpdated = function () {\n this.showOrHideOverlay();\n };\n OverlayWrapperComponent.prototype.onNewColumnsLoaded = function () {\n // hide overlay if columns and rows exist, this can happen if columns are loaded after data.\n // this problem exists before of the race condition between the services (column controller in this case)\n // and the view (grid panel). if the model beans were all initialised first, and then the view beans second,\n // this race condition would not happen.\n if (this.columnModel.isReady() && !this.paginationProxy.isEmpty() && !this.manuallyDisplayed) {\n this.hideOverlay();\n }\n };\n // wrapping in outer div, and wrapper, is needed to center the loading icon\n // The idea for centering came from here: http://www.vanseodesign.com/css/vertical-centering/\n OverlayWrapperComponent.TEMPLATE = \"\\n
\\n
\\n
\\n
\\n
\";\n __decorate([\n Autowired('userComponentFactory')\n ], OverlayWrapperComponent.prototype, \"userComponentFactory\", void 0);\n __decorate([\n Autowired('paginationProxy')\n ], OverlayWrapperComponent.prototype, \"paginationProxy\", void 0);\n __decorate([\n Autowired('gridApi')\n ], OverlayWrapperComponent.prototype, \"gridApi\", void 0);\n __decorate([\n Autowired('columnModel')\n ], OverlayWrapperComponent.prototype, \"columnModel\", void 0);\n __decorate([\n RefSelector('eOverlayWrapper')\n ], OverlayWrapperComponent.prototype, \"eOverlayWrapper\", void 0);\n __decorate([\n PostConstruct\n ], OverlayWrapperComponent.prototype, \"postConstruct\", null);\n return OverlayWrapperComponent;\n}(Component));\nexport { OverlayWrapperComponent };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { Constants } from \"../constants/constants\";\nimport { exists } from \"../utils/generic\";\nvar RowPositionUtils = /** @class */ (function (_super) {\n __extends(RowPositionUtils, _super);\n function RowPositionUtils() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n RowPositionUtils.prototype.getFirstRow = function () {\n var rowIndex = 0;\n var rowPinned;\n if (this.pinnedRowModel.getPinnedTopRowCount()) {\n rowPinned = Constants.PINNED_TOP;\n }\n else if (this.rowModel.getRowCount()) {\n rowPinned = null;\n rowIndex = this.paginationProxy.getPageFirstRow();\n }\n else if (this.pinnedRowModel.getPinnedBottomRowCount()) {\n rowPinned = Constants.PINNED_BOTTOM;\n }\n return rowPinned === undefined ? null : { rowIndex: rowIndex, rowPinned: rowPinned };\n };\n RowPositionUtils.prototype.getLastRow = function () {\n var rowIndex;\n var rowPinned = null;\n var pinnedBottomCount = this.pinnedRowModel.getPinnedBottomRowCount();\n var pinnedTopCount = this.pinnedRowModel.getPinnedTopRowCount();\n if (pinnedBottomCount) {\n rowPinned = Constants.PINNED_BOTTOM;\n rowIndex = pinnedBottomCount - 1;\n }\n else if (this.rowModel.getRowCount()) {\n rowPinned = null;\n rowIndex = this.paginationProxy.getPageLastRow();\n }\n else if (pinnedTopCount) {\n rowPinned = Constants.PINNED_TOP;\n rowIndex = pinnedTopCount - 1;\n }\n return rowIndex === undefined ? null : { rowIndex: rowIndex, rowPinned: rowPinned };\n };\n RowPositionUtils.prototype.getRowNode = function (gridRow) {\n switch (gridRow.rowPinned) {\n case Constants.PINNED_TOP:\n return this.pinnedRowModel.getPinnedTopRowData()[gridRow.rowIndex];\n case Constants.PINNED_BOTTOM:\n return this.pinnedRowModel.getPinnedBottomRowData()[gridRow.rowIndex];\n default:\n return this.rowModel.getRow(gridRow.rowIndex);\n }\n };\n RowPositionUtils.prototype.sameRow = function (rowA, rowB) {\n // if both missing\n if (!rowA && !rowB) {\n return true;\n }\n // if only one missing\n if ((rowA && !rowB) || (!rowA && rowB)) {\n return false;\n }\n // otherwise compare (use == to compare rowPinned because it can be null or undefined)\n return rowA.rowIndex === rowB.rowIndex && rowA.rowPinned == rowB.rowPinned;\n };\n // tests if this row selection is before the other row selection\n RowPositionUtils.prototype.before = function (rowA, rowB) {\n switch (rowA.rowPinned) {\n case Constants.PINNED_TOP:\n // we we are floating top, and other isn't, then we are always before\n if (rowB.rowPinned !== Constants.PINNED_TOP) {\n return true;\n }\n break;\n case Constants.PINNED_BOTTOM:\n // if we are floating bottom, and the other isn't, then we are never before\n if (rowB.rowPinned !== Constants.PINNED_BOTTOM) {\n return false;\n }\n break;\n default:\n // if we are not floating, but the other one is floating...\n if (exists(rowB.rowPinned)) {\n return rowB.rowPinned !== Constants.PINNED_TOP;\n }\n break;\n }\n return rowA.rowIndex < rowB.rowIndex;\n };\n RowPositionUtils.prototype.rowMax = function (rows) {\n var _this = this;\n var max;\n rows.forEach(function (row) {\n if (max === undefined || _this.before(max, row)) {\n max = row;\n }\n });\n return max;\n };\n RowPositionUtils.prototype.rowMin = function (rows) {\n var _this = this;\n var min;\n rows.forEach(function (row) {\n if (min === undefined || _this.before(row, min)) {\n min = row;\n }\n });\n return min;\n };\n __decorate([\n Autowired('rowModel')\n ], RowPositionUtils.prototype, \"rowModel\", void 0);\n __decorate([\n Autowired('pinnedRowModel')\n ], RowPositionUtils.prototype, \"pinnedRowModel\", void 0);\n __decorate([\n Autowired('paginationProxy')\n ], RowPositionUtils.prototype, \"paginationProxy\", void 0);\n RowPositionUtils = __decorate([\n Bean('rowPositionUtils')\n ], RowPositionUtils);\n return RowPositionUtils;\n}(BeanStub));\nexport { RowPositionUtils };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean } from \"../context/context\";\nimport { BeanStub } from \"../context/beanStub\";\nvar CellPositionUtils = /** @class */ (function (_super) {\n __extends(CellPositionUtils, _super);\n function CellPositionUtils() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n CellPositionUtils.prototype.createId = function (cellPosition) {\n var rowIndex = cellPosition.rowIndex, rowPinned = cellPosition.rowPinned, column = cellPosition.column;\n return this.createIdFromValues(rowIndex, column, rowPinned);\n };\n CellPositionUtils.prototype.createIdFromValues = function (rowIndex, column, rowPinned) {\n return rowIndex + \".\" + (rowPinned == null ? 'null' : rowPinned) + \".\" + column.getId();\n };\n CellPositionUtils.prototype.equals = function (cellA, cellB) {\n var colsMatch = cellA.column === cellB.column;\n var floatingMatch = cellA.rowPinned === cellB.rowPinned;\n var indexMatch = cellA.rowIndex === cellB.rowIndex;\n return colsMatch && floatingMatch && indexMatch;\n };\n CellPositionUtils = __decorate([\n Bean('cellPositionUtils')\n ], CellPositionUtils);\n return CellPositionUtils;\n}(BeanStub));\nexport { CellPositionUtils };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar UndoRedoAction = /** @class */ (function () {\n function UndoRedoAction(cellValueChanges) {\n this.cellValueChanges = cellValueChanges;\n }\n return UndoRedoAction;\n}());\nexport { UndoRedoAction };\nvar FillUndoRedoAction = /** @class */ (function (_super) {\n __extends(FillUndoRedoAction, _super);\n function FillUndoRedoAction(cellValueChanges, initialRange, finalRange) {\n var _this = _super.call(this, cellValueChanges) || this;\n _this.initialRange = initialRange;\n _this.finalRange = finalRange;\n return _this;\n }\n return FillUndoRedoAction;\n}(UndoRedoAction));\nexport { FillUndoRedoAction };\nvar UndoRedoStack = /** @class */ (function () {\n function UndoRedoStack(maxStackSize) {\n this.actionStack = [];\n this.maxStackSize = maxStackSize ? maxStackSize : UndoRedoStack.DEFAULT_STACK_SIZE;\n this.actionStack = new Array(this.maxStackSize);\n }\n UndoRedoStack.prototype.pop = function () {\n return this.actionStack.pop();\n };\n UndoRedoStack.prototype.push = function (item) {\n var shouldAddActions = item.cellValueChanges && item.cellValueChanges.length > 0;\n if (!shouldAddActions) {\n return;\n }\n if (this.actionStack.length === this.maxStackSize) {\n this.actionStack.shift();\n }\n this.actionStack.push(item);\n };\n UndoRedoStack.prototype.clear = function () {\n this.actionStack = [];\n };\n UndoRedoStack.prototype.getCurrentStackSize = function () {\n return this.actionStack.length;\n };\n UndoRedoStack.DEFAULT_STACK_SIZE = 10;\n return UndoRedoStack;\n}());\nexport { UndoRedoStack };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, PostConstruct } from \"../context/context\";\nimport { Events } from \"../eventKeys\";\nimport { FillUndoRedoAction, UndoRedoAction, UndoRedoStack } from \"./undoRedoStack\";\nimport { Constants } from \"../constants/constants\";\nimport { ModuleNames } from \"../modules/moduleNames\";\nimport { ModuleRegistry } from \"../modules/moduleRegistry\";\nimport { BeanStub } from \"../context/beanStub\";\nvar UndoRedoService = /** @class */ (function (_super) {\n __extends(UndoRedoService, _super);\n function UndoRedoService() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.cellValueChanges = [];\n _this.activeCellEdit = null;\n _this.activeRowEdit = null;\n _this.isPasting = false;\n _this.isFilling = false;\n _this.onCellValueChanged = function (event) {\n var eventCell = { column: event.column, rowIndex: event.rowIndex, rowPinned: event.rowPinned };\n var isCellEditing = _this.activeCellEdit !== null && _this.cellPositionUtils.equals(_this.activeCellEdit, eventCell);\n var isRowEditing = _this.activeRowEdit !== null && _this.rowPositionUtils.sameRow(_this.activeRowEdit, eventCell);\n var shouldCaptureAction = isCellEditing || isRowEditing || _this.isPasting || _this.isFilling;\n if (!shouldCaptureAction) {\n return;\n }\n var rowPinned = event.rowPinned, rowIndex = event.rowIndex, column = event.column, oldValue = event.oldValue, value = event.value;\n var cellValueChange = {\n rowPinned: rowPinned,\n rowIndex: rowIndex,\n columnId: column.getColId(),\n newValue: value,\n oldValue: oldValue\n };\n _this.cellValueChanges.push(cellValueChange);\n };\n _this.clearStacks = function () {\n _this.undoStack.clear();\n _this.redoStack.clear();\n };\n return _this;\n }\n UndoRedoService.prototype.init = function () {\n var _this = this;\n if (!this.gridOptionsWrapper.isUndoRedoCellEditing()) {\n return;\n }\n var undoRedoLimit = this.gridOptionsWrapper.getUndoRedoCellEditingLimit();\n if (undoRedoLimit <= 0) {\n return;\n }\n this.undoStack = new UndoRedoStack(undoRedoLimit);\n this.redoStack = new UndoRedoStack(undoRedoLimit);\n this.addRowEditingListeners();\n this.addCellEditingListeners();\n this.addPasteListeners();\n this.addFillListeners();\n this.addManagedListener(this.eventService, Events.EVENT_CELL_VALUE_CHANGED, this.onCellValueChanged);\n // undo / redo is restricted to actual editing so we clear the stacks when other operations are\n // performed that change the order of the row / cols.\n this.addManagedListener(this.eventService, Events.EVENT_MODEL_UPDATED, function (e) {\n if (!e.keepUndoRedoStack) {\n _this.clearStacks();\n }\n });\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PIVOT_MODE_CHANGED, this.clearStacks);\n this.addManagedListener(this.eventService, Events.EVENT_NEW_COLUMNS_LOADED, this.clearStacks);\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_GROUP_OPENED, this.clearStacks);\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, this.clearStacks);\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_MOVED, this.clearStacks);\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PINNED, this.clearStacks);\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_VISIBLE, this.clearStacks);\n this.addManagedListener(this.eventService, Events.EVENT_ROW_DRAG_END, this.clearStacks);\n };\n UndoRedoService.prototype.getCurrentUndoStackSize = function () {\n return this.undoStack ? this.undoStack.getCurrentStackSize() : 0;\n };\n UndoRedoService.prototype.getCurrentRedoStackSize = function () {\n return this.redoStack ? this.redoStack.getCurrentStackSize() : 0;\n };\n UndoRedoService.prototype.undo = function () {\n if (!this.undoStack) {\n return;\n }\n var undoAction = this.undoStack.pop();\n if (!undoAction || !undoAction.cellValueChanges) {\n return;\n }\n this.processAction(undoAction, function (cellValueChange) { return cellValueChange.oldValue; });\n if (undoAction instanceof FillUndoRedoAction) {\n this.processRangeAndCellFocus(undoAction.cellValueChanges, undoAction.initialRange);\n }\n else {\n this.processRangeAndCellFocus(undoAction.cellValueChanges);\n }\n this.redoStack.push(undoAction);\n };\n UndoRedoService.prototype.redo = function () {\n if (!this.redoStack) {\n return;\n }\n var redoAction = this.redoStack.pop();\n if (!redoAction || !redoAction.cellValueChanges) {\n return;\n }\n this.processAction(redoAction, function (cellValueChange) { return cellValueChange.newValue; });\n if (redoAction instanceof FillUndoRedoAction) {\n this.processRangeAndCellFocus(redoAction.cellValueChanges, redoAction.finalRange);\n }\n else {\n this.processRangeAndCellFocus(redoAction.cellValueChanges);\n }\n this.undoStack.push(redoAction);\n };\n UndoRedoService.prototype.processAction = function (action, valueExtractor) {\n var _this = this;\n action.cellValueChanges.forEach(function (cellValueChange) {\n var rowIndex = cellValueChange.rowIndex, rowPinned = cellValueChange.rowPinned, columnId = cellValueChange.columnId;\n var rowPosition = { rowIndex: rowIndex, rowPinned: rowPinned };\n var currentRow = _this.getRowNode(rowPosition);\n // checks if the row has been filtered out\n if (!currentRow.displayed) {\n return;\n }\n currentRow.setDataValue(columnId, valueExtractor(cellValueChange));\n });\n };\n UndoRedoService.prototype.processRangeAndCellFocus = function (cellValueChanges, range) {\n var lastFocusedCell;\n if (range) {\n var startRow = range.startRow;\n var endRow = range.endRow;\n lastFocusedCell = {\n rowPinned: startRow.rowPinned,\n rowIndex: startRow.rowIndex,\n columnId: range.startColumn.getColId()\n };\n this.setLastFocusedCell(lastFocusedCell);\n var cellRangeParams = {\n rowStartIndex: startRow.rowIndex,\n rowStartPinned: startRow.rowPinned,\n rowEndIndex: endRow.rowIndex,\n rowEndPinned: endRow.rowPinned,\n columnStart: range.startColumn,\n columns: range.columns\n };\n this.gridApi.addCellRange(cellRangeParams);\n return;\n }\n var cellValueChange = cellValueChanges[0];\n var rowIndex = cellValueChange.rowIndex, rowPinned = cellValueChange.rowPinned;\n var rowPosition = { rowIndex: rowIndex, rowPinned: rowPinned };\n var row = this.getRowNode(rowPosition);\n lastFocusedCell = {\n rowPinned: cellValueChange.rowPinned,\n rowIndex: row.rowIndex,\n columnId: cellValueChange.columnId\n };\n this.setLastFocusedCell(lastFocusedCell);\n };\n UndoRedoService.prototype.setLastFocusedCell = function (lastFocusedCell) {\n var rowIndex = lastFocusedCell.rowIndex, columnId = lastFocusedCell.columnId, rowPinned = lastFocusedCell.rowPinned;\n this.gridApi.ensureIndexVisible(rowIndex);\n this.gridApi.ensureColumnVisible(columnId);\n if (ModuleRegistry.isRegistered(ModuleNames.RangeSelectionModule)) {\n this.gridApi.clearRangeSelection();\n }\n this.focusService.setFocusedCell({ rowIndex: rowIndex, column: columnId, rowPinned: rowPinned, forceBrowserFocus: true });\n };\n UndoRedoService.prototype.addRowEditingListeners = function () {\n var _this = this;\n this.addManagedListener(this.eventService, Events.EVENT_ROW_EDITING_STARTED, function (e) {\n _this.activeRowEdit = { rowIndex: e.rowIndex, rowPinned: e.rowPinned };\n });\n this.addManagedListener(this.eventService, Events.EVENT_ROW_EDITING_STOPPED, function () {\n var action = new UndoRedoAction(_this.cellValueChanges);\n _this.pushActionsToUndoStack(action);\n _this.activeRowEdit = null;\n });\n };\n UndoRedoService.prototype.addCellEditingListeners = function () {\n var _this = this;\n this.addManagedListener(this.eventService, Events.EVENT_CELL_EDITING_STARTED, function (e) {\n _this.activeCellEdit = { column: e.column, rowIndex: e.rowIndex, rowPinned: e.rowPinned };\n });\n this.addManagedListener(this.eventService, Events.EVENT_CELL_EDITING_STOPPED, function () {\n _this.activeCellEdit = null;\n var shouldPushAction = !_this.activeRowEdit && !_this.isPasting && !_this.isFilling;\n if (shouldPushAction) {\n var action = new UndoRedoAction(_this.cellValueChanges);\n _this.pushActionsToUndoStack(action);\n }\n });\n };\n UndoRedoService.prototype.addPasteListeners = function () {\n var _this = this;\n this.addManagedListener(this.eventService, Events.EVENT_PASTE_START, function () {\n _this.isPasting = true;\n });\n this.addManagedListener(this.eventService, Events.EVENT_PASTE_END, function () {\n var action = new UndoRedoAction(_this.cellValueChanges);\n _this.pushActionsToUndoStack(action);\n _this.isPasting = false;\n });\n };\n UndoRedoService.prototype.addFillListeners = function () {\n var _this = this;\n this.addManagedListener(this.eventService, Events.EVENT_FILL_START, function () {\n _this.isFilling = true;\n });\n this.addManagedListener(this.eventService, Events.EVENT_FILL_END, function (event) {\n var action = new FillUndoRedoAction(_this.cellValueChanges, event.initialRange, event.finalRange);\n _this.pushActionsToUndoStack(action);\n _this.isFilling = false;\n });\n };\n UndoRedoService.prototype.pushActionsToUndoStack = function (action) {\n this.undoStack.push(action);\n this.cellValueChanges = [];\n this.redoStack.clear();\n };\n UndoRedoService.prototype.getRowNode = function (gridRow) {\n switch (gridRow.rowPinned) {\n case Constants.PINNED_TOP:\n return this.pinnedRowModel.getPinnedTopRowData()[gridRow.rowIndex];\n case Constants.PINNED_BOTTOM:\n return this.pinnedRowModel.getPinnedBottomRowData()[gridRow.rowIndex];\n default:\n return this.rowModel.getRow(gridRow.rowIndex);\n }\n };\n __decorate([\n Autowired('focusService')\n ], UndoRedoService.prototype, \"focusService\", void 0);\n __decorate([\n Autowired('gridApi')\n ], UndoRedoService.prototype, \"gridApi\", void 0);\n __decorate([\n Autowired('rowModel')\n ], UndoRedoService.prototype, \"rowModel\", void 0);\n __decorate([\n Autowired('pinnedRowModel')\n ], UndoRedoService.prototype, \"pinnedRowModel\", void 0);\n __decorate([\n Autowired('cellPositionUtils')\n ], UndoRedoService.prototype, \"cellPositionUtils\", void 0);\n __decorate([\n Autowired('rowPositionUtils')\n ], UndoRedoService.prototype, \"rowPositionUtils\", void 0);\n __decorate([\n PostConstruct\n ], UndoRedoService.prototype, \"init\", null);\n UndoRedoService = __decorate([\n Bean('undoRedoService')\n ], UndoRedoService);\n return UndoRedoService;\n}(BeanStub));\nexport { UndoRedoService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub\";\nimport { Autowired, Bean } from \"../../context/context\";\nimport { ColumnGroup } from \"../../entities/columnGroup\";\nimport { HeaderRowType } from \"../row/headerRowComp\";\nvar HeaderPositionUtils = /** @class */ (function (_super) {\n __extends(HeaderPositionUtils, _super);\n function HeaderPositionUtils() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n HeaderPositionUtils.prototype.findHeader = function (focusedHeader, direction) {\n var nextColumn;\n var getGroupMethod;\n var getColMethod;\n if (focusedHeader.column instanceof ColumnGroup) {\n getGroupMethod = \"getDisplayedGroup\" + direction;\n nextColumn = this.columnModel[getGroupMethod](focusedHeader.column);\n }\n else {\n getColMethod = \"getDisplayedCol\" + direction;\n nextColumn = this.columnModel[getColMethod](focusedHeader.column);\n }\n if (nextColumn) {\n return {\n column: nextColumn,\n headerRowIndex: focusedHeader.headerRowIndex\n };\n }\n };\n HeaderPositionUtils.prototype.findColAtEdgeForHeaderRow = function (level, position) {\n var displayedColumns = this.columnModel.getAllDisplayedColumns();\n var column = displayedColumns[position === 'start' ? 0 : displayedColumns.length - 1];\n if (!column) {\n return;\n }\n var childContainer = this.ctrlsService.getHeaderRowContainerCtrl(column.getPinned());\n var type = childContainer.getRowType(level);\n if (type == HeaderRowType.COLUMN_GROUP) {\n var columnGroup = this.columnModel.getColumnGroupAtLevel(column, level);\n return {\n headerRowIndex: level,\n column: columnGroup\n };\n }\n return {\n // if type==null, means the header level didn't exist\n headerRowIndex: type == null ? -1 : level,\n column: column\n };\n };\n __decorate([\n Autowired('columnModel')\n ], HeaderPositionUtils.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], HeaderPositionUtils.prototype, \"ctrlsService\", void 0);\n HeaderPositionUtils = __decorate([\n Bean('headerPositionUtils')\n ], HeaderPositionUtils);\n return HeaderPositionUtils;\n}(BeanStub));\nexport { HeaderPositionUtils };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean } from \"../context/context\";\nimport { deepCloneDefinition } from \"../utils/object\";\nvar ColumnDefFactory = /** @class */ (function () {\n function ColumnDefFactory() {\n }\n ColumnDefFactory.prototype.buildColumnDefs = function (cols, rowGroupColumns, pivotColumns) {\n var _this = this;\n var res = [];\n var colGroupDefs = {};\n cols.forEach(function (col) {\n var colDef = _this.createDefFromColumn(col, rowGroupColumns, pivotColumns);\n var addToResult = true;\n var childDef = colDef;\n var pointer = col.getOriginalParent();\n while (pointer) {\n var parentDef = null;\n // we don't include padding groups, as the column groups provided\n // by application didn't have these. the whole point of padding groups\n // is to balance the column tree that the user provided.\n if (pointer.isPadding()) {\n pointer = pointer.getOriginalParent();\n continue;\n }\n // if colDef for this group already exists, use it\n var existingParentDef = colGroupDefs[pointer.getGroupId()];\n if (existingParentDef) {\n existingParentDef.children.push(childDef);\n // if we added to result, it would be the second time we did it\n addToResult = false;\n // we don't want to continue up the tree, as it has already been\n // done for this group\n break;\n }\n parentDef = _this.createDefFromGroup(pointer);\n if (parentDef) {\n parentDef.children = [childDef];\n colGroupDefs[parentDef.groupId] = parentDef;\n childDef = parentDef;\n pointer = pointer.getOriginalParent();\n }\n }\n if (addToResult) {\n res.push(childDef);\n }\n });\n return res;\n };\n ColumnDefFactory.prototype.createDefFromGroup = function (group) {\n var defCloned = deepCloneDefinition(group.getColGroupDef(), ['children']);\n if (defCloned) {\n defCloned.groupId = group.getGroupId();\n }\n return defCloned;\n };\n ColumnDefFactory.prototype.createDefFromColumn = function (col, rowGroupColumns, pivotColumns) {\n var colDefCloned = deepCloneDefinition(col.getColDef());\n colDefCloned.colId = col.getColId();\n colDefCloned.width = col.getActualWidth();\n colDefCloned.rowGroup = col.isRowGroupActive();\n colDefCloned.rowGroupIndex = col.isRowGroupActive() ? rowGroupColumns.indexOf(col) : null;\n colDefCloned.pivot = col.isPivotActive();\n colDefCloned.pivotIndex = col.isPivotActive() ? pivotColumns.indexOf(col) : null;\n colDefCloned.aggFunc = col.isValueActive() ? col.getAggFunc() : null;\n colDefCloned.hide = col.isVisible() ? undefined : true;\n colDefCloned.pinned = col.isPinned() ? col.getPinned() : null;\n colDefCloned.sort = col.getSort() ? col.getSort() : null;\n colDefCloned.sortIndex = col.getSortIndex() != null ? col.getSortIndex() : null;\n return colDefCloned;\n };\n ColumnDefFactory = __decorate([\n Bean('columnDefFactory')\n ], ColumnDefFactory);\n return ColumnDefFactory;\n}());\nexport { ColumnDefFactory };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { exists } from \"../../utils/generic\";\nimport { pushAll } from \"../../utils/array\";\nimport { Autowired, Bean } from \"../../context/context\";\nimport { Constants } from \"../../constants/constants\";\nvar RowCssClassCalculator = /** @class */ (function () {\n function RowCssClassCalculator() {\n }\n RowCssClassCalculator.prototype.getInitialRowClasses = function (params) {\n var classes = [];\n if (exists(params.extraCssClass)) {\n classes.push(params.extraCssClass);\n }\n classes.push('ag-row');\n classes.push(params.rowFocused ? 'ag-row-focus' : 'ag-row-no-focus');\n if (params.fadeRowIn) {\n classes.push('ag-opacity-zero');\n }\n classes.push(params.rowIsEven ? 'ag-row-even' : 'ag-row-odd');\n if (params.rowNode.isRowPinned()) {\n classes.push('ag-row-pinned');\n }\n if (params.rowNode.isSelected()) {\n classes.push('ag-row-selected');\n }\n if (params.rowNode.footer) {\n classes.push('ag-row-footer');\n }\n classes.push('ag-row-level-' + params.rowLevel);\n if (params.rowNode.stub) {\n classes.push('ag-row-loading');\n }\n if (params.fullWidthRow) {\n classes.push('ag-full-width-row');\n }\n if (params.expandable) {\n classes.push('ag-row-group');\n classes.push(params.rowNode.expanded ? 'ag-row-group-expanded' : 'ag-row-group-contracted');\n }\n if (params.rowNode.dragging) {\n classes.push('ag-row-dragging');\n }\n pushAll(classes, this.processClassesFromGridOptions(params.rowNode));\n pushAll(classes, this.preProcessRowClassRules(params.rowNode));\n // we use absolute position unless we are doing print layout\n classes.push(params.printLayout ? 'ag-row-position-relative' : 'ag-row-position-absolute');\n if (params.firstRowOnPage) {\n classes.push('ag-row-first');\n }\n if (params.lastRowOnPage) {\n classes.push('ag-row-last');\n }\n if (params.fullWidthRow) {\n if (params.pinned === Constants.PINNED_LEFT) {\n classes.push('ag-cell-last-left-pinned');\n }\n if (params.pinned === Constants.PINNED_RIGHT) {\n classes.push('ag-cell-first-right-pinned');\n }\n }\n return classes;\n };\n RowCssClassCalculator.prototype.processClassesFromGridOptions = function (rowNode) {\n var res = [];\n var process = function (rowCls) {\n if (typeof rowCls === 'string') {\n res.push(rowCls);\n }\n else if (Array.isArray(rowCls)) {\n rowCls.forEach(function (e) { return res.push(e); });\n }\n };\n // part 1 - rowClass\n var rowClass = this.gridOptionsWrapper.getRowClass();\n if (rowClass) {\n if (typeof rowClass === 'function') {\n console.warn('AG Grid: rowClass should not be a function, please use getRowClass instead');\n return [];\n }\n process(rowClass);\n }\n // part 2 - rowClassFunc\n var rowClassFunc = this.gridOptionsWrapper.getRowClassFunc();\n if (rowClassFunc) {\n var params = {\n data: rowNode.data,\n node: rowNode,\n rowIndex: rowNode.rowIndex\n };\n var rowClassFuncResult = rowClassFunc(params);\n process(rowClassFuncResult);\n }\n return res;\n };\n RowCssClassCalculator.prototype.preProcessRowClassRules = function (rowNode) {\n var res = [];\n this.processRowClassRules(rowNode, function (className) {\n res.push(className);\n }, function (className) {\n // not catered for, if creating, no need\n // to remove class as it was never there\n });\n return res;\n };\n RowCssClassCalculator.prototype.processRowClassRules = function (rowNode, onApplicableClass, onNotApplicableClass) {\n var rowClassParams = {\n data: rowNode.data,\n node: rowNode,\n rowIndex: rowNode.rowIndex,\n api: this.gridOptionsWrapper.getApi(),\n columnApi: this.gridOptionsWrapper.getColumnApi(),\n context: this.gridOptionsWrapper.getContext()\n };\n this.stylingService.processClassRules(this.gridOptionsWrapper.rowClassRules(), rowClassParams, onApplicableClass, onNotApplicableClass);\n };\n RowCssClassCalculator.prototype.calculateRowLevel = function (rowNode) {\n if (rowNode.group) {\n return rowNode.level;\n }\n // if a leaf, and a parent exists, put a level of the parent, else put level of 0 for top level item\n return rowNode.parent ? (rowNode.parent.level + 1) : 0;\n };\n __decorate([\n Autowired('stylingService')\n ], RowCssClassCalculator.prototype, \"stylingService\", void 0);\n __decorate([\n Autowired('gridOptionsWrapper')\n ], RowCssClassCalculator.prototype, \"gridOptionsWrapper\", void 0);\n RowCssClassCalculator = __decorate([\n Bean('rowCssClassCalculator')\n ], RowCssClassCalculator);\n return RowCssClassCalculator;\n}());\nexport { RowCssClassCalculator };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean } from \"../context/context\";\nimport { _ } from \"../utils\";\nimport { Constants } from \"../constants/constants\";\n// this logic is used by both SSRM and CSRM\nvar RowNodeSorter = /** @class */ (function () {\n function RowNodeSorter() {\n }\n RowNodeSorter.prototype.doFullSort = function (rowNodes, sortOptions) {\n var mapper = function (rowNode, pos) { return ({ currentPos: pos, rowNode: rowNode }); };\n var sortedRowNodes = rowNodes.map(mapper);\n sortedRowNodes.sort(this.compareRowNodes.bind(this, sortOptions));\n return sortedRowNodes.map(function (item) { return item.rowNode; });\n };\n RowNodeSorter.prototype.compareRowNodes = function (sortOptions, sortedNodeA, sortedNodeB) {\n var nodeA = sortedNodeA.rowNode;\n var nodeB = sortedNodeB.rowNode;\n // Iterate columns, return the first that doesn't match\n for (var i = 0, len = sortOptions.length; i < len; i++) {\n var sortOption = sortOptions[i];\n var isDescending = sortOption.sort === Constants.SORT_DESC;\n var valueA = this.getValue(nodeA, sortOption.column);\n var valueB = this.getValue(nodeB, sortOption.column);\n var comparatorResult = void 0;\n var providedComparator = this.getComparator(sortOption, nodeA);\n if (providedComparator) {\n //if comparator provided, use it\n comparatorResult = providedComparator(valueA, valueB, nodeA, nodeB, isDescending);\n }\n else {\n //otherwise do our own comparison\n comparatorResult = _.defaultComparator(valueA, valueB, this.gridOptionsWrapper.isAccentedSort());\n }\n // user provided comparators can return 'NaN' if they don't correctly handle 'undefined' values, this\n // typically occurs when the comparator is used on a group row\n var validResult = !isNaN(comparatorResult);\n if (validResult && comparatorResult !== 0) {\n return sortOption.sort === Constants.SORT_ASC ? comparatorResult : comparatorResult * -1;\n }\n }\n // All matched, we make is so that the original sort order is kept:\n return sortedNodeA.currentPos - sortedNodeB.currentPos;\n };\n RowNodeSorter.prototype.getComparator = function (sortOption, rowNode) {\n var column = sortOption.column;\n // comparator on col get preference over everything else\n var comparatorOnCol = column.getColDef().comparator;\n if (comparatorOnCol != null) {\n return comparatorOnCol;\n }\n if (!column.getColDef().showRowGroup) {\n return;\n }\n // if a 'field' is supplied on the autoGroupColumnDef we need to use the associated column comparator\n var groupLeafField = !rowNode.group && column.getColDef().field;\n if (!groupLeafField) {\n return;\n }\n var primaryColumn = this.columnModel.getPrimaryColumn(groupLeafField);\n if (!primaryColumn) {\n return;\n }\n return primaryColumn.getColDef().comparator;\n };\n RowNodeSorter.prototype.getValue = function (node, column) {\n var _a, _b;\n var primaryColumnsSortGroups = this.gridOptionsWrapper.isColumnsSortingCoupledToGroup();\n if (!primaryColumnsSortGroups) {\n return this.valueService.getValue(column, node, false, false);\n }\n var isNodeGroupedAtLevel = node.rowGroupColumn === column;\n if (isNodeGroupedAtLevel) {\n var isGroupRows = this.gridOptionsWrapper.isGroupUseEntireRow(this.columnModel.isPivotActive());\n if (isGroupRows) {\n // if the column has a provided a keyCreator, we have to use the key, as the group could be\n // irrelevant to the column value\n var keyCreator = column.getColDef().keyCreator;\n if (keyCreator) {\n return node.key;\n }\n // if the group was generated from the column data, all the leaf children should return the same\n // value\n var leafChild = (_a = node.allLeafChildren) === null || _a === void 0 ? void 0 : _a[0];\n if (leafChild) {\n return this.valueService.getValue(column, leafChild, false, false);\n }\n return undefined;\n }\n var displayCol = this.columnModel.getGroupDisplayColumnForGroup(column.getId());\n if (!displayCol) {\n return undefined;\n }\n return (_b = node.groupData) === null || _b === void 0 ? void 0 : _b[displayCol.getId()];\n }\n if (node.group && column.getColDef().showRowGroup) {\n return undefined;\n }\n return this.valueService.getValue(column, node, false, false);\n };\n __decorate([\n Autowired('gridOptionsWrapper')\n ], RowNodeSorter.prototype, \"gridOptionsWrapper\", void 0);\n __decorate([\n Autowired('valueService')\n ], RowNodeSorter.prototype, \"valueService\", void 0);\n __decorate([\n Autowired('columnModel')\n ], RowNodeSorter.prototype, \"columnModel\", void 0);\n RowNodeSorter = __decorate([\n Bean('rowNodeSorter')\n ], RowNodeSorter);\n return RowNodeSorter;\n}());\nexport { RowNodeSorter };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean } from \"./context/context\";\nimport { BeanStub } from \"./context/beanStub\";\nimport { Constants } from \"./constants/constants\";\nvar CtrlsService = /** @class */ (function (_super) {\n __extends(CtrlsService, _super);\n function CtrlsService() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.ready = false;\n _this.readyCallbacks = [];\n return _this;\n }\n CtrlsService_1 = CtrlsService;\n CtrlsService.prototype.checkReady = function () {\n this.ready =\n this.gridCtrl != null\n && this.gridBodyCtrl != null\n && this.centerRowContainerCtrl != null\n && this.leftRowContainerCtrl != null\n && this.rightRowContainerCtrl != null\n && this.bottomCenterRowContainerCtrl != null\n && this.bottomLeftRowContainerCtrl != null\n && this.bottomRightRowContainerCtrl != null\n && this.topCenterRowContainerCtrl != null\n && this.topLeftRowContainerCtrl != null\n && this.topRightRowContainerCtrl != null\n && this.stickyTopCenterRowContainerCtrl != null\n && this.stickyTopLeftRowContainerCtrl != null\n && this.stickyTopRightRowContainerCtrl != null\n && this.centerHeaderRowContainerCtrl != null\n && this.leftHeaderRowContainerCtrl != null\n && this.rightHeaderRowContainerCtrl != null\n && this.fakeHScrollCtrl != null\n && this.gridHeaderCtrl != null;\n if (this.ready) {\n var p_1 = this.createReadyParams();\n this.readyCallbacks.forEach(function (c) { return c(p_1); });\n this.readyCallbacks.length = 0;\n }\n };\n CtrlsService.prototype.whenReady = function (callback) {\n if (this.ready) {\n callback(this.createReadyParams());\n }\n else {\n this.readyCallbacks.push(callback);\n }\n };\n CtrlsService.prototype.createReadyParams = function () {\n return {\n centerRowContainerCtrl: this.centerRowContainerCtrl,\n leftRowContainerCtrl: this.leftRowContainerCtrl,\n rightRowContainerCtrl: this.rightRowContainerCtrl,\n bottomCenterRowContainerCtrl: this.bottomCenterRowContainerCtrl,\n bottomLeftRowContainerCtrl: this.bottomLeftRowContainerCtrl,\n bottomRightRowContainerCtrl: this.bottomRightRowContainerCtrl,\n topCenterRowContainerCtrl: this.topCenterRowContainerCtrl,\n topLeftRowContainerCtrl: this.topLeftRowContainerCtrl,\n topRightRowContainerCtrl: this.topRightRowContainerCtrl,\n stickyTopCenterRowContainerCtrl: this.stickyTopCenterRowContainerCtrl,\n stickyTopLeftRowContainerCtrl: this.stickyTopLeftRowContainerCtrl,\n stickyTopRightRowContainerCtrl: this.stickyTopRightRowContainerCtrl,\n centerHeaderRowContainerCtrl: this.centerHeaderRowContainerCtrl,\n leftHeaderRowContainerCtrl: this.leftHeaderRowContainerCtrl,\n rightHeaderRowContainerCtrl: this.rightHeaderRowContainerCtrl,\n fakeHScrollCtrl: this.fakeHScrollCtrl,\n gridBodyCtrl: this.gridBodyCtrl,\n gridCtrl: this.gridCtrl,\n gridHeaderCtrl: this.gridHeaderCtrl,\n };\n };\n CtrlsService.prototype.registerFakeHScrollCtrl = function (ctrl) {\n this.fakeHScrollCtrl = ctrl;\n this.checkReady();\n };\n CtrlsService.prototype.registerGridHeaderCtrl = function (gridHeaderCtrl) {\n this.gridHeaderCtrl = gridHeaderCtrl;\n this.checkReady();\n };\n CtrlsService.prototype.registerCenterRowContainerCtrl = function (ctrl) {\n this.centerRowContainerCtrl = ctrl;\n this.checkReady();\n };\n CtrlsService.prototype.registerLeftRowContainerCtrl = function (ctrl) {\n this.leftRowContainerCtrl = ctrl;\n this.checkReady();\n };\n CtrlsService.prototype.registerRightRowContainerCtrl = function (ctrl) {\n this.rightRowContainerCtrl = ctrl;\n this.checkReady();\n };\n CtrlsService.prototype.registerTopCenterRowContainerCtrl = function (ctrl) {\n this.topCenterRowContainerCtrl = ctrl;\n this.checkReady();\n };\n CtrlsService.prototype.registerTopLeftRowContainerCon = function (ctrl) {\n this.topLeftRowContainerCtrl = ctrl;\n this.checkReady();\n };\n CtrlsService.prototype.registerTopRightRowContainerCtrl = function (ctrl) {\n this.topRightRowContainerCtrl = ctrl;\n this.checkReady();\n };\n CtrlsService.prototype.registerStickyTopCenterRowContainerCtrl = function (ctrl) {\n this.stickyTopCenterRowContainerCtrl = ctrl;\n this.checkReady();\n };\n CtrlsService.prototype.registerStickyTopLeftRowContainerCon = function (ctrl) {\n this.stickyTopLeftRowContainerCtrl = ctrl;\n this.checkReady();\n };\n CtrlsService.prototype.registerStickyTopRightRowContainerCtrl = function (ctrl) {\n this.stickyTopRightRowContainerCtrl = ctrl;\n this.checkReady();\n };\n CtrlsService.prototype.registerBottomCenterRowContainerCtrl = function (ctrl) {\n this.bottomCenterRowContainerCtrl = ctrl;\n this.checkReady();\n };\n CtrlsService.prototype.registerBottomLeftRowContainerCtrl = function (ctrl) {\n this.bottomLeftRowContainerCtrl = ctrl;\n this.checkReady();\n };\n CtrlsService.prototype.registerBottomRightRowContainerCtrl = function (ctrl) {\n this.bottomRightRowContainerCtrl = ctrl;\n this.checkReady();\n };\n CtrlsService.prototype.registerHeaderContainer = function (ctrl, pinned) {\n switch (pinned) {\n case Constants.PINNED_LEFT:\n this.leftHeaderRowContainerCtrl = ctrl;\n break;\n case Constants.PINNED_RIGHT:\n this.rightHeaderRowContainerCtrl = ctrl;\n break;\n default:\n this.centerHeaderRowContainerCtrl = ctrl;\n break;\n }\n this.checkReady();\n };\n CtrlsService.prototype.registerGridBodyCtrl = function (ctrl) {\n this.gridBodyCtrl = ctrl;\n this.checkReady();\n };\n CtrlsService.prototype.registerGridCtrl = function (ctrl) {\n this.gridCtrl = ctrl;\n this.checkReady();\n };\n CtrlsService.prototype.getFakeHScrollCtrl = function () {\n return this.fakeHScrollCtrl;\n };\n CtrlsService.prototype.getGridHeaderCtrl = function () {\n return this.gridHeaderCtrl;\n };\n CtrlsService.prototype.getGridCtrl = function () {\n return this.gridCtrl;\n };\n CtrlsService.prototype.getCenterRowContainerCtrl = function () {\n return this.centerRowContainerCtrl;\n };\n CtrlsService.prototype.getTopCenterRowContainerCtrl = function () {\n return this.topCenterRowContainerCtrl;\n };\n CtrlsService.prototype.getBottomCenterRowContainerCtrl = function () {\n return this.bottomCenterRowContainerCtrl;\n };\n CtrlsService.prototype.getStickyTopCenterRowContainerCtrl = function () {\n return this.stickyTopCenterRowContainerCtrl;\n };\n CtrlsService.prototype.getGridBodyCtrl = function () {\n return this.gridBodyCtrl;\n };\n CtrlsService.prototype.getHeaderRowContainerCtrls = function () {\n return [this.leftHeaderRowContainerCtrl, this.rightHeaderRowContainerCtrl, this.centerHeaderRowContainerCtrl];\n };\n CtrlsService.prototype.getHeaderRowContainerCtrl = function (pinned) {\n switch (pinned) {\n case Constants.PINNED_LEFT: return this.leftHeaderRowContainerCtrl;\n case Constants.PINNED_RIGHT: return this.rightHeaderRowContainerCtrl;\n default: return this.centerHeaderRowContainerCtrl;\n }\n };\n var CtrlsService_1;\n CtrlsService.NAME = 'ctrlsService';\n CtrlsService = CtrlsService_1 = __decorate([\n Bean(CtrlsService_1.NAME)\n ], CtrlsService);\n return CtrlsService;\n}(BeanStub));\nexport { CtrlsService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"./context/beanStub\";\nimport { Bean } from \"./context/context\";\nvar CtrlsFactory = /** @class */ (function (_super) {\n __extends(CtrlsFactory, _super);\n function CtrlsFactory() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.registry = {};\n return _this;\n }\n CtrlsFactory.prototype.register = function (meta) {\n this.registry[meta.controllerName] = meta.controllerClass;\n };\n CtrlsFactory.prototype.getInstance = function (name) {\n var ControllerClass = this.registry[name];\n if (ControllerClass == null) {\n return undefined;\n }\n return new ControllerClass();\n };\n CtrlsFactory = __decorate([\n Bean('ctrlsFactory')\n ], CtrlsFactory);\n return CtrlsFactory;\n}(BeanStub));\nexport { CtrlsFactory };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../context/beanStub\";\nimport { isInvisibleScrollbar, isIOSUserAgent, isMacOsUserAgent } from \"../utils/browser\";\nimport { Autowired } from \"../context/context\";\nimport { Events } from \"../eventKeys\";\nimport { GridOptionsWrapper } from \"../gridOptionsWrapper\";\nvar FakeHScrollCtrl = /** @class */ (function (_super) {\n __extends(FakeHScrollCtrl, _super);\n function FakeHScrollCtrl() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n FakeHScrollCtrl.prototype.setComp = function (view, eGui, eViewport, eContainer) {\n this.view = view;\n this.eViewport = eViewport;\n this.eContainer = eContainer;\n this.eGui = eGui;\n this.addManagedListener(this.eventService, Events.EVENT_SCROLL_VISIBILITY_CHANGED, this.onScrollVisibilityChanged.bind(this));\n // When doing printing, this changes whether cols are pinned or not\n var spacerWidthsListener = this.setFakeHScrollSpacerWidths.bind(this);\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, spacerWidthsListener);\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, spacerWidthsListener);\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_DOM_LAYOUT, spacerWidthsListener);\n this.addManagedListener(this.eventService, Events.EVENT_PINNED_ROW_DATA_CHANGED, this.onPinnedRowDataChanged.bind(this));\n this.onScrollVisibilityChanged();\n this.ctrlsService.registerFakeHScrollCtrl(this);\n this.view.addOrRemoveCssClass('ag-apple-scrollbar', isMacOsUserAgent() || isIOSUserAgent());\n };\n FakeHScrollCtrl.prototype.addActiveListenerToggles = function () {\n var _this = this;\n var activateEvents = ['mouseenter', 'mousedown', 'touchstart'];\n var deactivateEvents = ['mouseleave', 'touchend'];\n activateEvents.forEach(function (eventName) { return _this.addManagedListener(_this.eGui, eventName, function () { return _this.view.addOrRemoveCssClass('ag-scrollbar-active', true); }); });\n deactivateEvents.forEach(function (eventName) { return _this.addManagedListener(_this.eGui, eventName, function () { return _this.view.addOrRemoveCssClass('ag-scrollbar-active', false); }); });\n };\n FakeHScrollCtrl.prototype.initialiseInvisibleScrollbar = function () {\n if (this.invisibleScrollbar !== undefined) {\n return;\n }\n this.enableRtl = this.gridOptionsWrapper.isEnableRtl();\n this.invisibleScrollbar = isInvisibleScrollbar();\n if (this.invisibleScrollbar) {\n this.hideAndShowInvisibleScrollAsNeeded();\n this.addActiveListenerToggles();\n this.refreshCompBottom();\n }\n };\n FakeHScrollCtrl.prototype.onPinnedRowDataChanged = function () {\n this.refreshCompBottom();\n };\n FakeHScrollCtrl.prototype.refreshCompBottom = function () {\n if (!this.invisibleScrollbar) {\n return;\n }\n var bottomPinnedHeight = this.pinnedRowModel.getPinnedBottomTotalHeight();\n this.view.setBottom(bottomPinnedHeight);\n };\n FakeHScrollCtrl.prototype.onScrollVisibilityChanged = function () {\n // initialiseInvisibleScrollbar should only be called once, but the reason\n // this can't be inside `setComp` or `PostConstruct` is the DOM might not\n // be ready, so we call it until eventually, it gets calculated.\n if (this.invisibleScrollbar === undefined) {\n this.initialiseInvisibleScrollbar();\n }\n this.setScrollVisible();\n this.setFakeHScrollSpacerWidths();\n };\n FakeHScrollCtrl.prototype.hideAndShowInvisibleScrollAsNeeded = function () {\n var _this = this;\n this.addManagedListener(this.eventService, Events.EVENT_BODY_SCROLL, function (params) {\n if (params.direction === 'horizontal') {\n _this.view.addOrRemoveCssClass('ag-scrollbar-scrolling', true);\n }\n });\n this.addManagedListener(this.eventService, Events.EVENT_BODY_SCROLL_END, function () { return _this.view.addOrRemoveCssClass('ag-scrollbar-scrolling', false); });\n };\n FakeHScrollCtrl.prototype.setFakeHScrollSpacerWidths = function () {\n var vScrollShowing = this.scrollVisibleService.isVerticalScrollShowing();\n // we pad the right based on a) if cols are pinned to the right and\n // b) if v scroll is showing on the right (normal position of scroll)\n var rightSpacing = this.columnModel.getDisplayedColumnsRightWidth();\n var scrollOnRight = !this.enableRtl && vScrollShowing;\n var scrollbarWidth = this.gridOptionsWrapper.getScrollbarWidth();\n if (scrollOnRight) {\n rightSpacing += scrollbarWidth;\n }\n this.view.setRightSpacerFixedWidth(rightSpacing);\n this.view.includeRightSpacerScrollerCss('ag-scroller-corner', rightSpacing <= scrollbarWidth);\n // we pad the left based on a) if cols are pinned to the left and\n // b) if v scroll is showing on the left (happens in LTR layout only)\n var leftSpacing = this.columnModel.getDisplayedColumnsLeftWidth();\n var scrollOnLeft = this.enableRtl && vScrollShowing;\n if (scrollOnLeft) {\n leftSpacing += scrollbarWidth;\n }\n this.view.setLeftSpacerFixedWidth(leftSpacing);\n this.view.includeLeftSpacerScrollerCss('ag-scroller-corner', leftSpacing <= scrollbarWidth);\n };\n FakeHScrollCtrl.prototype.setScrollVisible = function () {\n var hScrollShowing = this.scrollVisibleService.isHorizontalScrollShowing();\n var invisibleScrollbar = this.invisibleScrollbar;\n var isSuppressHorizontalScroll = this.gridOptionsWrapper.isSuppressHorizontalScroll();\n var scrollbarWidth = hScrollShowing ? (this.gridOptionsWrapper.getScrollbarWidth() || 0) : 0;\n var adjustedScrollbarWidth = (scrollbarWidth === 0 && invisibleScrollbar) ? 15 : scrollbarWidth;\n var scrollContainerSize = !isSuppressHorizontalScroll ? adjustedScrollbarWidth : 0;\n this.view.addOrRemoveCssClass('ag-scrollbar-invisible', invisibleScrollbar);\n this.view.setHeight(scrollContainerSize);\n this.view.setViewportHeight(scrollContainerSize);\n this.view.setContainerHeight(scrollContainerSize);\n };\n FakeHScrollCtrl.prototype.getViewport = function () {\n return this.eViewport;\n };\n FakeHScrollCtrl.prototype.getContainer = function () {\n return this.eContainer;\n };\n __decorate([\n Autowired('scrollVisibleService')\n ], FakeHScrollCtrl.prototype, \"scrollVisibleService\", void 0);\n __decorate([\n Autowired('columnModel')\n ], FakeHScrollCtrl.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('ctrlsService')\n ], FakeHScrollCtrl.prototype, \"ctrlsService\", void 0);\n __decorate([\n Autowired('pinnedRowModel')\n ], FakeHScrollCtrl.prototype, \"pinnedRowModel\", void 0);\n return FakeHScrollCtrl;\n}(BeanStub));\nexport { FakeHScrollCtrl };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from \"../widgets/component\";\nimport { RefSelector } from \"../widgets/componentAnnotations\";\nimport { PostConstruct } from \"../context/context\";\nimport { FakeHScrollCtrl } from \"./fakeHScrollCtrl\";\nimport { setFixedHeight, setFixedWidth } from \"../utils/dom\";\nimport { CenterWidthFeature } from \"./centerWidthFeature\";\nvar FakeHScrollComp = /** @class */ (function (_super) {\n __extends(FakeHScrollComp, _super);\n function FakeHScrollComp() {\n return _super.call(this, FakeHScrollComp.TEMPLATE) || this;\n }\n FakeHScrollComp.prototype.postConstruct = function () {\n var _this = this;\n var compProxy = {\n addOrRemoveCssClass: function (cssClassName, on) { return _this.addOrRemoveCssClass(cssClassName, on); },\n setHeight: function (height) { return setFixedHeight(_this.getGui(), height); },\n setBottom: function (bottom) { return _this.getGui().style.bottom = bottom + \"px\"; },\n setContainerHeight: function (height) { return setFixedHeight(_this.eContainer, height); },\n setViewportHeight: function (height) { return setFixedHeight(_this.eViewport, height); },\n setRightSpacerFixedWidth: function (width) { return setFixedWidth(_this.eRightSpacer, width); },\n setLeftSpacerFixedWidth: function (width) { return setFixedWidth(_this.eLeftSpacer, width); },\n includeLeftSpacerScrollerCss: function (cssClass, include) {\n return _this.eLeftSpacer.classList.toggle(cssClass, include);\n },\n includeRightSpacerScrollerCss: function (cssClass, include) {\n return _this.eRightSpacer.classList.toggle(cssClass, include);\n },\n };\n var ctrl = this.createManagedBean(new FakeHScrollCtrl());\n ctrl.setComp(compProxy, this.getGui(), this.eViewport, this.eContainer);\n this.createManagedBean(new CenterWidthFeature(function (width) { return _this.eContainer.style.width = width + \"px\"; }));\n };\n FakeHScrollComp.TEMPLATE = \"
\\n
\\n
\\n
\\n
\\n
\\n
\";\n __decorate([\n RefSelector('eLeftSpacer')\n ], FakeHScrollComp.prototype, \"eLeftSpacer\", void 0);\n __decorate([\n RefSelector('eRightSpacer')\n ], FakeHScrollComp.prototype, \"eRightSpacer\", void 0);\n __decorate([\n RefSelector('eViewport')\n ], FakeHScrollComp.prototype, \"eViewport\", void 0);\n __decorate([\n RefSelector('eContainer')\n ], FakeHScrollComp.prototype, \"eContainer\", void 0);\n __decorate([\n PostConstruct\n ], FakeHScrollComp.prototype, \"postConstruct\", null);\n return FakeHScrollComp;\n}(Component));\nexport { FakeHScrollComp };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../context/beanStub\";\nimport { Autowired, Bean, PostConstruct } from \"../context/context\";\nimport { GridOptionsWrapper } from \"../gridOptionsWrapper\";\nimport { Events } from \"../eventKeys\";\nimport { Constants } from \"../constants/constants\";\nvar PinnedWidthService = /** @class */ (function (_super) {\n __extends(PinnedWidthService, _super);\n function PinnedWidthService() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n PinnedWidthService.prototype.postConstruct = function () {\n var listener = this.checkContainerWidths.bind(this);\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, listener);\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, listener);\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_DOM_LAYOUT, listener);\n };\n PinnedWidthService.prototype.checkContainerWidths = function () {\n var printLayout = this.gridOptionsWrapper.getDomLayout() === Constants.DOM_LAYOUT_PRINT;\n var newLeftWidth = printLayout ? 0 : this.columnModel.getDisplayedColumnsLeftWidth();\n var newRightWidth = printLayout ? 0 : this.columnModel.getDisplayedColumnsRightWidth();\n if (newLeftWidth != this.leftWidth) {\n this.leftWidth = newLeftWidth;\n this.eventService.dispatchEvent({ type: Events.EVENT_LEFT_PINNED_WIDTH_CHANGED });\n }\n if (newRightWidth != this.rightWidth) {\n this.rightWidth = newRightWidth;\n this.eventService.dispatchEvent({ type: Events.EVENT_RIGHT_PINNED_WIDTH_CHANGED });\n }\n };\n PinnedWidthService.prototype.getPinnedRightWidth = function () {\n return this.rightWidth;\n };\n PinnedWidthService.prototype.getPinnedLeftWidth = function () {\n return this.leftWidth;\n };\n __decorate([\n Autowired('columnModel')\n ], PinnedWidthService.prototype, \"columnModel\", void 0);\n __decorate([\n PostConstruct\n ], PinnedWidthService.prototype, \"postConstruct\", null);\n PinnedWidthService = __decorate([\n Bean('pinnedWidthService')\n ], PinnedWidthService);\n return PinnedWidthService;\n}(BeanStub));\nexport { PinnedWidthService };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Constants } from \"../constants/constants\";\nimport { BeanStub } from \"../context/beanStub\";\nimport { Autowired, Bean, PostConstruct } from \"../context/context\";\nvar RowNodeEventThrottle = /** @class */ (function (_super) {\n __extends(RowNodeEventThrottle, _super);\n function RowNodeEventThrottle() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.events = [];\n return _this;\n }\n RowNodeEventThrottle.prototype.postConstruct = function () {\n if (this.rowModel.getType() == Constants.ROW_MODEL_TYPE_CLIENT_SIDE) {\n this.clientSideRowModel = this.rowModel;\n }\n };\n // because the user can call rowNode.setExpanded() many times in one VM turn,\n // we throttle the calls to ClientSideRowModel using animationFrameService. this means for 100\n // row nodes getting expanded, we only update the CSRM once, and then we fire all events after\n // CSRM has updated.\n //\n // if we did not do this, then the user could call setExpanded on 100+ rows, causing the grid\n // to re-render 100+ times, which would be a performance lag.\n //\n // we use animationFrameService\n // rather than _.debounce() so this will get done if anyone flushes the animationFrameService\n // (eg user calls api.ensureRowVisible(), which in turn flushes ).\n RowNodeEventThrottle.prototype.dispatchExpanded = function (event) {\n var _this = this;\n // if not using CSRM, we don't debounce. otherwise this breaks the SSRM.\n if (this.clientSideRowModel == null) {\n this.eventService.dispatchEvent(event);\n return;\n }\n this.events.push(event);\n var func = function () {\n if (_this.clientSideRowModel) {\n _this.clientSideRowModel.onRowGroupOpened();\n }\n _this.events.forEach(function (e) { return _this.eventService.dispatchEvent(e); });\n _this.events = [];\n };\n if (this.dispatchExpandedDebounced == null) {\n this.dispatchExpandedDebounced = this.animationFrameService.debounce(func);\n }\n this.dispatchExpandedDebounced();\n };\n __decorate([\n Autowired('animationFrameService')\n ], RowNodeEventThrottle.prototype, \"animationFrameService\", void 0);\n __decorate([\n Autowired('rowModel')\n ], RowNodeEventThrottle.prototype, \"rowModel\", void 0);\n __decorate([\n PostConstruct\n ], RowNodeEventThrottle.prototype, \"postConstruct\", null);\n RowNodeEventThrottle = __decorate([\n Bean('rowNodeEventThrottle')\n ], RowNodeEventThrottle);\n return RowNodeEventThrottle;\n}(BeanStub));\nexport { RowNodeEventThrottle };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nimport { GridOptionsWrapper } from \"./gridOptionsWrapper\";\nimport { SelectionService } from \"./selectionService\";\nimport { ColumnApi } from \"./columns/columnApi\";\nimport { ColumnModel } from \"./columns/columnModel\";\nimport { RowRenderer } from \"./rendering/rowRenderer\";\nimport { GridHeaderComp } from \"./headerRendering/gridHeaderComp\";\nimport { FilterManager } from \"./filter/filterManager\";\nimport { ValueService } from \"./valueService/valueService\";\nimport { EventService } from \"./eventService\";\nimport { GridBodyComp } from \"./gridBodyComp/gridBodyComp\";\nimport { GridApi } from \"./gridApi\";\nimport { ColumnFactory } from \"./columns/columnFactory\";\nimport { DisplayedGroupCreator } from \"./columns/displayedGroupCreator\";\nimport { ExpressionService } from \"./valueService/expressionService\";\nimport { TemplateService } from \"./templateService\";\nimport { PopupService } from \"./widgets/popupService\";\nimport { Logger, LoggerFactory } from \"./logger\";\nimport { ColumnUtils } from \"./columns/columnUtils\";\nimport { AutoWidthCalculator } from \"./rendering/autoWidthCalculator\";\nimport { HorizontalResizeService } from \"./headerRendering/common/horizontalResizeService\";\nimport { Context } from \"./context/context\";\nimport { GridComp } from \"./gridComp/gridComp\";\nimport { DragAndDropService } from \"./dragAndDrop/dragAndDropService\";\nimport { DragService } from \"./dragAndDrop/dragService\";\nimport { SortController } from \"./sortController\";\nimport { FocusService } from \"./focusService\";\nimport { MouseEventService } from \"./gridBodyComp/mouseEventService\";\nimport { CellNavigationService } from \"./cellNavigationService\";\nimport { Events } from \"./events\";\nimport { ValueFormatterService } from \"./rendering/valueFormatterService\";\nimport { AgCheckbox } from \"./widgets/agCheckbox\";\nimport { AgRadioButton } from \"./widgets/agRadioButton\";\nimport { VanillaFrameworkOverrides } from \"./vanillaFrameworkOverrides\";\nimport { ScrollVisibleService } from \"./gridBodyComp/scrollVisibleService\";\nimport { StylingService } from \"./styling/stylingService\";\nimport { ColumnHoverService } from \"./rendering/columnHoverService\";\nimport { ColumnAnimationService } from \"./rendering/columnAnimationService\";\nimport { AutoGroupColService } from \"./columns/autoGroupColService\";\nimport { PaginationProxy } from \"./pagination/paginationProxy\";\nimport { PaginationAutoPageSizeService } from \"./pagination/paginationAutoPageSizeService\";\nimport { Constants } from \"./constants/constants\";\nimport { ValueCache } from \"./valueService/valueCache\";\nimport { ChangeDetectionService } from \"./valueService/changeDetectionService\";\nimport { AlignedGridsService } from \"./alignedGridsService\";\nimport { UserComponentFactory } from \"./components/framework/userComponentFactory\";\nimport { UserComponentRegistry } from \"./components/framework/userComponentRegistry\";\nimport { AgComponentUtils } from \"./components/framework/agComponentUtils\";\nimport { ComponentMetadataProvider } from \"./components/framework/componentMetadataProvider\";\nimport { Beans } from \"./rendering/beans\";\nimport { Environment } from \"./environment\";\nimport { AnimationFrameService } from \"./misc/animationFrameService\";\nimport { NavigationService } from \"./gridBodyComp/navigationService\";\nimport { RowContainerHeightService } from \"./rendering/rowContainerHeightService\";\nimport { SelectableService } from \"./rowNodes/selectableService\";\nimport { PaginationComp } from \"./pagination/paginationComp\";\nimport { ResizeObserverService } from \"./misc/resizeObserverService\";\nimport { OverlayWrapperComponent } from \"./rendering/overlays/overlayWrapperComponent\";\nimport { AgGroupComponent } from \"./widgets/agGroupComponent\";\nimport { AgDialog } from \"./widgets/agDialog\";\nimport { AgPanel } from \"./widgets/agPanel\";\nimport { AgInputTextField } from \"./widgets/agInputTextField\";\nimport { AgInputTextArea } from \"./widgets/agInputTextArea\";\nimport { AgSlider } from \"./widgets/agSlider\";\nimport { AgColorPicker } from \"./widgets/agColorPicker\";\nimport { AgInputNumberField } from \"./widgets/agInputNumberField\";\nimport { AgInputRange } from \"./widgets/agInputRange\";\nimport { AgSelect } from \"./widgets/agSelect\";\nimport { AgAngleSelect } from \"./widgets/agAngleSelect\";\nimport { AgToggleButton } from \"./widgets/agToggleButton\";\nimport { RowPositionUtils } from \"./entities/rowPosition\";\nimport { CellPositionUtils } from \"./entities/cellPosition\";\nimport { PinnedRowModel } from \"./pinnedRowModel/pinnedRowModel\";\nimport { ModuleRegistry } from \"./modules/moduleRegistry\";\nimport { ModuleNames } from \"./modules/moduleNames\";\nimport { UndoRedoService } from \"./undoRedo/undoRedoService\";\nimport { AgStackComponentsRegistry } from \"./components/agStackComponentsRegistry\";\nimport { HeaderPositionUtils } from \"./headerRendering/common/headerPosition\";\nimport { HeaderNavigationService } from \"./headerRendering/common/headerNavigationService\";\nimport { exists, missing } from \"./utils/generic\";\nimport { iterateObject } from \"./utils/object\";\nimport { ColumnDefFactory } from \"./columns/columnDefFactory\";\nimport { RowCssClassCalculator } from \"./rendering/row/rowCssClassCalculator\";\nimport { RowNodeBlockLoader } from \"./rowNodeCache/rowNodeBlockLoader\";\nimport { RowNodeSorter } from \"./rowNodes/rowNodeSorter\";\nimport { CtrlsService } from \"./ctrlsService\";\nimport { CtrlsFactory } from \"./ctrlsFactory\";\nimport { FakeHScrollComp } from \"./gridBodyComp/fakeHScrollComp\";\nimport { PinnedWidthService } from \"./gridBodyComp/pinnedWidthService\";\nimport { RowContainerComp } from \"./gridBodyComp/rowContainer/rowContainerComp\";\nimport { RowNodeEventThrottle } from \"./entities/rowNodeEventThrottle\";\nimport { StandardMenuFactory } from \"./headerRendering/cells/column/standardMenu\";\nimport { SortIndicatorComp } from \"./headerRendering/cells/column/sortIndicatorComp\";\n// creates JavaScript vanilla Grid, including JavaScript (ag-stack) components, which can\n// be wrapped by the framework wrappers\nvar Grid = /** @class */ (function () {\n function Grid(eGridDiv, gridOptions, params) {\n if (!gridOptions) {\n console.error('AG Grid: no gridOptions provided to the grid');\n return;\n }\n this.gridOptions = gridOptions;\n new GridCoreCreator().create(eGridDiv, gridOptions, function (context) {\n var gridComp = new GridComp(eGridDiv);\n context.createBean(gridComp);\n }, undefined, params);\n }\n Grid.prototype.destroy = function () {\n if (this.gridOptions && this.gridOptions.api) {\n this.gridOptions.api.destroy();\n }\n };\n return Grid;\n}());\nexport { Grid };\n// created services of grid only, no UI, so frameworks can use this if providing\n// their own UI\nvar GridCoreCreator = /** @class */ (function () {\n function GridCoreCreator() {\n }\n GridCoreCreator.prototype.create = function (eGridDiv, gridOptions, createUi, acceptChanges, params) {\n var _this = this;\n var debug = !!gridOptions.debug;\n var registeredModules = this.getRegisteredModules(params);\n var beanClasses = this.createBeansList(gridOptions.rowModelType, registeredModules);\n var providedBeanInstances = this.createProvidedBeans(eGridDiv, gridOptions, params);\n if (!beanClasses) {\n return;\n } // happens when no row model found\n var contextParams = {\n providedBeanInstances: providedBeanInstances,\n beanClasses: beanClasses,\n debug: debug\n };\n var logger = new Logger('AG Grid', function () { return gridOptions.debug; });\n var contextLogger = new Logger('Context', function () { return contextParams.debug; });\n var context = new Context(contextParams, contextLogger);\n var beans = context.getBean('beans');\n this.registerModuleUserComponents(beans, registeredModules);\n this.registerStackComponents(beans, registeredModules);\n this.registerControllers(beans, registeredModules);\n createUi(context);\n // we wait until the UI has finished initialising before setting in columns and rows\n beans.ctrlsService.whenReady(function () {\n _this.setColumnsAndData(beans);\n _this.dispatchGridReadyEvent(beans);\n var isEnterprise = ModuleRegistry.isRegistered(ModuleNames.EnterpriseCoreModule);\n logger.log(\"initialised successfully, enterprise = \" + isEnterprise);\n });\n if (acceptChanges) {\n acceptChanges(context);\n }\n };\n GridCoreCreator.prototype.registerControllers = function (beans, registeredModules) {\n registeredModules.forEach(function (module) {\n if (module.controllers) {\n module.controllers.forEach(function (meta) { return beans.ctrlsFactory.register(meta); });\n }\n });\n };\n GridCoreCreator.prototype.registerStackComponents = function (beans, registeredModules) {\n var agStackComponents = this.createAgStackComponentsList(registeredModules);\n beans.agStackComponentsRegistry.setupComponents(agStackComponents);\n };\n GridCoreCreator.prototype.getRegisteredModules = function (params) {\n var passedViaConstructor = params ? params.modules : null;\n var registered = ModuleRegistry.getRegisteredModules();\n var allModules = [];\n var mapNames = {};\n // adds to list and removes duplicates\n function addModule(moduleBased, mod) {\n function addIndividualModule(currentModule) {\n if (!mapNames[currentModule.moduleName]) {\n mapNames[currentModule.moduleName] = true;\n allModules.push(currentModule);\n ModuleRegistry.register(currentModule, moduleBased);\n }\n }\n addIndividualModule(mod);\n if (mod.dependantModules) {\n mod.dependantModules.forEach(addModule.bind(null, moduleBased));\n }\n }\n if (passedViaConstructor) {\n passedViaConstructor.forEach(addModule.bind(null, true));\n }\n if (registered) {\n registered.forEach(addModule.bind(null, !ModuleRegistry.isPackageBased()));\n }\n return allModules;\n };\n GridCoreCreator.prototype.registerModuleUserComponents = function (beans, registeredModules) {\n var moduleUserComps = this.extractModuleEntity(registeredModules, function (module) { return module.userComponents ? module.userComponents : []; });\n moduleUserComps.forEach(function (compMeta) {\n beans.userComponentRegistry.registerDefaultComponent(compMeta.componentName, compMeta.componentClass);\n });\n };\n GridCoreCreator.prototype.createProvidedBeans = function (eGridDiv, gridOptions, params) {\n var frameworkOverrides = params ? params.frameworkOverrides : null;\n if (missing(frameworkOverrides)) {\n frameworkOverrides = new VanillaFrameworkOverrides();\n }\n var seed = {\n gridOptions: gridOptions,\n eGridDiv: eGridDiv,\n globalEventListener: params ? params.globalEventListener : null,\n frameworkOverrides: frameworkOverrides\n };\n if (params && params.providedBeanInstances) {\n Object.assign(seed, params.providedBeanInstances);\n }\n return seed;\n };\n GridCoreCreator.prototype.createAgStackComponentsList = function (registeredModules) {\n var components = [\n { componentName: 'AgCheckbox', componentClass: AgCheckbox },\n { componentName: 'AgRadioButton', componentClass: AgRadioButton },\n { componentName: 'AgToggleButton', componentClass: AgToggleButton },\n { componentName: 'AgInputTextField', componentClass: AgInputTextField },\n { componentName: 'AgInputTextArea', componentClass: AgInputTextArea },\n { componentName: 'AgInputNumberField', componentClass: AgInputNumberField },\n { componentName: 'AgInputRange', componentClass: AgInputRange },\n { componentName: 'AgSelect', componentClass: AgSelect },\n { componentName: 'AgSlider', componentClass: AgSlider },\n { componentName: 'AgAngleSelect', componentClass: AgAngleSelect },\n { componentName: 'AgColorPicker', componentClass: AgColorPicker },\n { componentName: 'AgGridBody', componentClass: GridBodyComp },\n { componentName: 'AgHeaderRoot', componentClass: GridHeaderComp },\n { componentName: 'AgSortIndicator', componentClass: SortIndicatorComp },\n { componentName: 'AgPagination', componentClass: PaginationComp },\n { componentName: 'AgOverlayWrapper', componentClass: OverlayWrapperComponent },\n { componentName: 'AgGroupComponent', componentClass: AgGroupComponent },\n { componentName: 'AgPanel', componentClass: AgPanel },\n { componentName: 'AgDialog', componentClass: AgDialog },\n { componentName: 'AgRowContainer', componentClass: RowContainerComp },\n { componentName: 'AgFakeHorizontalScroll', componentClass: FakeHScrollComp }\n ];\n var moduleAgStackComps = this.extractModuleEntity(registeredModules, function (module) { return module.agStackComponents ? module.agStackComponents : []; });\n components = components.concat(moduleAgStackComps);\n return components;\n };\n GridCoreCreator.prototype.createBeansList = function (rowModelType, registeredModules) {\n var rowModelClass = this.getRowModelClass(rowModelType, registeredModules);\n if (!rowModelClass) {\n return;\n }\n // beans should only contain SERVICES, it should NEVER contain COMPONENTS\n var beans = [\n rowModelClass, Beans, RowPositionUtils, CellPositionUtils, HeaderPositionUtils,\n PaginationAutoPageSizeService, GridApi, UserComponentRegistry, AgComponentUtils,\n ComponentMetadataProvider, ResizeObserverService, UserComponentFactory,\n RowContainerHeightService, HorizontalResizeService,\n PinnedRowModel, DragService, DisplayedGroupCreator, EventService, GridOptionsWrapper,\n PopupService, SelectionService, FilterManager, ColumnModel, HeaderNavigationService,\n PaginationProxy, RowRenderer, ExpressionService, ColumnFactory, TemplateService,\n AlignedGridsService, NavigationService, ValueCache, ValueService, LoggerFactory,\n ColumnUtils, AutoWidthCalculator, StandardMenuFactory, DragAndDropService, ColumnApi,\n FocusService, MouseEventService, Environment, CellNavigationService, ValueFormatterService,\n StylingService, ScrollVisibleService, SortController, ColumnHoverService, ColumnAnimationService,\n SelectableService, AutoGroupColService, ChangeDetectionService, AnimationFrameService,\n UndoRedoService, AgStackComponentsRegistry, ColumnDefFactory,\n RowCssClassCalculator, RowNodeBlockLoader, RowNodeSorter, CtrlsService,\n PinnedWidthService, RowNodeEventThrottle, CtrlsFactory\n ];\n var moduleBeans = this.extractModuleEntity(registeredModules, function (module) { return module.beans ? module.beans : []; });\n beans.push.apply(beans, __spread(moduleBeans));\n // check for duplicates, as different modules could include the same beans that\n // they depend on, eg ClientSideRowModel in enterprise, and ClientSideRowModel in community\n var beansNoDuplicates = [];\n beans.forEach(function (bean) {\n if (beansNoDuplicates.indexOf(bean) < 0) {\n beansNoDuplicates.push(bean);\n }\n });\n return beansNoDuplicates;\n };\n GridCoreCreator.prototype.extractModuleEntity = function (moduleEntities, extractor) {\n return [].concat.apply([], __spread(moduleEntities.map(extractor)));\n };\n GridCoreCreator.prototype.setColumnsAndData = function (beans) {\n var columnDefs = beans.gridOptionsWrapper.getColumnDefs();\n beans.columnModel.setColumnDefs(columnDefs || [], \"gridInitializing\");\n beans.rowModel.start();\n };\n GridCoreCreator.prototype.dispatchGridReadyEvent = function (beans) {\n var readyEvent = {\n type: Events.EVENT_GRID_READY,\n };\n beans.eventService.dispatchEvent(readyEvent);\n };\n GridCoreCreator.prototype.getRowModelClass = function (rowModelType, registeredModules) {\n // default to client side\n if (!rowModelType) {\n rowModelType = Constants.ROW_MODEL_TYPE_CLIENT_SIDE;\n }\n var rowModelClasses = {};\n registeredModules.forEach(function (module) {\n iterateObject(module.rowModels, function (key, value) {\n rowModelClasses[key] = value;\n });\n });\n var rowModelClass = rowModelClasses[rowModelType];\n if (exists(rowModelClass)) {\n return rowModelClass;\n }\n if (ModuleRegistry.isPackageBased()) {\n if ([Constants.ROW_MODEL_TYPE_VIEWPORT, Constants.ROW_MODEL_TYPE_SERVER_SIDE].includes(rowModelType)) {\n // If package based only the enterprise row models could be missing.\n console.error(\"AG Grid: Row Model \\\"\" + rowModelType + \"\\\" not found. Please ensure the package 'ag-grid-enterprise' is imported. Please see: https://www.ag-grid.com/javascript-grid/packages/\");\n }\n else {\n console.error('AG Grid: could not find row model for rowModelType ' + rowModelType);\n }\n }\n else {\n if (rowModelType === Constants.ROW_MODEL_TYPE_INFINITE) {\n console.error(\"AG Grid: Row Model \\\"Infinite\\\" not found. Please ensure the \" + ModuleNames.InfiniteRowModelModule + \" module is registered. Please see: https://www.ag-grid.com/javascript-grid/modules/\");\n }\n else if (rowModelType === Constants.ROW_MODEL_TYPE_VIEWPORT) {\n console.error(\"AG Grid: Row Model \\\"Viewport\\\" not found. Please ensure the AG Grid Enterprise Module \" + ModuleNames.ViewportRowModelModule + \" module is registered. Please see: https://www.ag-grid.com/javascript-grid/modules/\");\n }\n else if (rowModelType === Constants.ROW_MODEL_TYPE_SERVER_SIDE) {\n console.error(\"AG Grid: Row Model \\\"Server Side\\\" not found. Please ensure the AG Grid Enterprise Module \" + ModuleNames.ServerSideRowModelModule + \" module is registered. Please see: https://www.ag-grid.com/javascript-grid/modules/\");\n }\n else if (rowModelType === Constants.ROW_MODEL_TYPE_CLIENT_SIDE) {\n console.error(\"AG Grid: Row Model \\\"Client Side\\\" not found. Please ensure the \" + ModuleNames.ClientSideRowModelModule + \" module is registered. Please see: https://www.ag-grid.com/javascript-grid/modules/\");\n }\n else {\n console.error('AG Grid: could not find row model for rowModelType ' + rowModelType);\n }\n }\n };\n return GridCoreCreator;\n}());\nexport { GridCoreCreator };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar BaseComponentWrapper = /** @class */ (function () {\n function BaseComponentWrapper() {\n }\n BaseComponentWrapper.prototype.wrap = function (OriginalConstructor, mandatoryMethodList, optionalMethodList, componentType) {\n var _this = this;\n if (optionalMethodList === void 0) { optionalMethodList = []; }\n var wrapper = this.createWrapper(OriginalConstructor, componentType);\n mandatoryMethodList.forEach((function (methodName) {\n _this.createMethod(wrapper, methodName, true);\n }));\n optionalMethodList.forEach((function (methodName) {\n _this.createMethod(wrapper, methodName, false);\n }));\n return wrapper;\n };\n BaseComponentWrapper.prototype.unwrap = function (comp) {\n return comp;\n };\n BaseComponentWrapper.prototype.createMethod = function (wrapper, methodName, mandatory) {\n wrapper.addMethod(methodName, this.createMethodProxy(wrapper, methodName, mandatory));\n };\n BaseComponentWrapper.prototype.createMethodProxy = function (wrapper, methodName, mandatory) {\n return function () {\n if (wrapper.hasMethod(methodName)) {\n return wrapper.callMethod(methodName, arguments);\n }\n if (mandatory) {\n console.warn('AG Grid: Framework component is missing the method ' + methodName + '()');\n }\n return null;\n };\n };\n return BaseComponentWrapper;\n}());\nexport { BaseComponentWrapper };\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nexport var BarColumnLabelPlacement;\n(function (BarColumnLabelPlacement) {\n BarColumnLabelPlacement[\"InsideBase\"] = \"insideBase\";\n BarColumnLabelPlacement[\"InsideEnd\"] = \"insideEnd\";\n BarColumnLabelPlacement[\"Center\"] = \"center\";\n BarColumnLabelPlacement[\"OutsideEnd\"] = \"outsideEnd\";\n})(BarColumnLabelPlacement || (BarColumnLabelPlacement = {}));\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v28.1.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nvar globalObj = typeof global === 'undefined' ? {} : global;\nglobalObj.HTMLElement = typeof HTMLElement === 'undefined' ? {} : HTMLElement;\nglobalObj.HTMLButtonElement = typeof HTMLButtonElement === 'undefined' ? {} : HTMLButtonElement;\nglobalObj.HTMLSelectElement = typeof HTMLSelectElement === 'undefined' ? {} : HTMLSelectElement;\nglobalObj.HTMLInputElement = typeof HTMLInputElement === 'undefined' ? {} : HTMLInputElement;\nglobalObj.Node = typeof Node === 'undefined' ? {} : Node;\nglobalObj.MouseEvent = typeof MouseEvent === 'undefined' ? {} : MouseEvent;\n// columns\nexport { ColumnFactory } from \"./columns/columnFactory\";\nexport { ColumnModel } from \"./columns/columnModel\";\nexport { ColumnKeyCreator } from \"./columns/columnKeyCreator\";\nexport { ColumnUtils } from \"./columns/columnUtils\";\nexport { DisplayedGroupCreator } from \"./columns/displayedGroupCreator\";\nexport { GroupInstanceIdCreator } from \"./columns/groupInstanceIdCreator\";\n// components\nexport { ComponentUtil } from \"./components/componentUtil\";\nexport { AgStackComponentsRegistry } from \"./components/agStackComponentsRegistry\";\nexport { ColDefUtil } from \"./components/colDefUtil\";\nexport { UserComponentRegistry } from \"./components/framework/userComponentRegistry\";\nexport { UserComponentFactory } from \"./components/framework/userComponentFactory\";\n// context\nexport { BeanStub } from \"./context/beanStub\";\nexport { Context, Autowired, PostConstruct, PreConstruct, Optional, Bean, Qualifier, PreDestroy } from \"./context/context\";\nexport { QuerySelector, RefSelector } from \"./widgets/componentAnnotations\";\n// excel\nexport { ExcelFactoryMode } from \"./interfaces/iExcelCreator\";\n// dragAndDrop\nexport { DragAndDropService, DragSourceType, HorizontalDirection, VerticalDirection } from \"./dragAndDrop/dragAndDropService\";\nexport { DragService } from \"./dragAndDrop/dragService\";\n// entities\nexport { Column } from \"./entities/column\";\nexport { ColumnGroup } from \"./entities/columnGroup\";\nexport { ProvidedColumnGroup } from \"./entities/providedColumnGroup\";\nexport { RowNode, RowHighlightPosition } from \"./entities/rowNode\";\nexport { FilterManager } from \"./filter/filterManager\";\nexport { ProvidedFilter } from \"./filter/provided/providedFilter\";\nexport { SimpleFilter } from \"./filter/provided/simpleFilter\";\nexport { ScalarFilter } from \"./filter/provided/scalarFilter\";\nexport { NumberFilter } from \"./filter/provided/number/numberFilter\";\nexport { TextFilter } from \"./filter/provided/text/textFilter\";\nexport { DateFilter } from \"./filter/provided/date/dateFilter\";\nexport { TextFloatingFilter } from './filter/provided/text/textFloatingFilter';\nexport { HeaderFilterCellComp } from './headerRendering/cells/floatingFilter/headerFilterCellComp';\nexport { FloatingFilterMapper } from './filter/floating/floatingFilterMapper';\n// gridPanel\nexport { GridBodyComp } from \"./gridBodyComp/gridBodyComp\";\nexport { GridBodyCtrl, RowAnimationCssClasses } from \"./gridBodyComp/gridBodyCtrl\";\nexport { ScrollVisibleService } from \"./gridBodyComp/scrollVisibleService\";\nexport { MouseEventService } from \"./gridBodyComp/mouseEventService\";\nexport { NavigationService } from \"./gridBodyComp/navigationService\";\n// rowContainer\nexport { RowContainerComp } from \"./gridBodyComp/rowContainer/rowContainerComp\";\nexport { RowContainerName, RowContainerCtrl, RowContainerType, getRowContainerTypeForName } from \"./gridBodyComp/rowContainer/rowContainerCtrl\";\n// headerRendering\nexport { BodyDropPivotTarget } from \"./headerRendering/columnDrag/bodyDropPivotTarget\";\nexport { BodyDropTarget } from \"./headerRendering/columnDrag/bodyDropTarget\";\nexport { CssClassApplier } from \"./headerRendering/cells/cssClassApplier\";\nexport { HeaderRowContainerComp } from \"./headerRendering/rowContainer/headerRowContainerComp\";\nexport { GridHeaderComp } from \"./headerRendering/gridHeaderComp\";\nexport { GridHeaderCtrl } from \"./headerRendering/gridHeaderCtrl\";\nexport { HeaderRowComp, HeaderRowType } from \"./headerRendering/row/headerRowComp\";\nexport { HeaderRowCtrl } from \"./headerRendering/row/headerRowCtrl\";\nexport { HeaderCellCtrl } from \"./headerRendering/cells/column/headerCellCtrl\";\nexport { SortIndicatorComp } from \"./headerRendering/cells/column/sortIndicatorComp\";\nexport { HeaderFilterCellCtrl } from \"./headerRendering/cells/floatingFilter/headerFilterCellCtrl\";\nexport { HeaderGroupCellCtrl } from \"./headerRendering/cells/columnGroup/headerGroupCellCtrl\";\nexport { AbstractHeaderCellCtrl } from \"./headerRendering/cells/abstractCell/abstractHeaderCellCtrl\";\nexport { HeaderRowContainerCtrl } from \"./headerRendering/rowContainer/headerRowContainerCtrl\";\nexport { HorizontalResizeService } from \"./headerRendering/common/horizontalResizeService\";\nexport { MoveColumnFeature } from \"./headerRendering/columnDrag/moveColumnFeature\";\nexport { StandardMenuFactory } from \"./headerRendering/cells/column/standardMenu\";\n// layout\nexport { TabbedLayout } from \"./layout/tabbedLayout\";\n// misc\nexport { simpleHttpRequest } from \"./misc/simpleHttpRequest\";\nexport { ResizeObserverService } from \"./misc/resizeObserverService\";\nexport { AnimationFrameService } from \"./misc/animationFrameService\";\nexport { LargeTextCellEditor } from \"./rendering/cellEditors/largeTextCellEditor\";\nexport { PopupEditorWrapper } from \"./rendering/cellEditors/popupEditorWrapper\";\nexport { PopupSelectCellEditor } from \"./rendering/cellEditors/popupSelectCellEditor\";\nexport { PopupTextCellEditor } from \"./rendering/cellEditors/popupTextCellEditor\";\nexport { SelectCellEditor } from \"./rendering/cellEditors/selectCellEditor\";\nexport { TextCellEditor } from \"./rendering/cellEditors/textCellEditor\";\n// rendering / cellRenderers\nexport { Beans } from \"./rendering/beans\";\nexport { AnimateShowChangeCellRenderer } from \"./rendering/cellRenderers/animateShowChangeCellRenderer\";\nexport { AnimateSlideCellRenderer } from \"./rendering/cellRenderers/animateSlideCellRenderer\";\nexport { GroupCellRenderer, } from \"./rendering/cellRenderers/groupCellRenderer\";\nexport { GroupCellRendererCtrl } from \"./rendering/cellRenderers/groupCellRendererCtrl\";\n// features\nexport { SetLeftFeature } from \"./rendering/features/setLeftFeature\";\nexport { PositionableFeature } from \"./rendering/features/positionableFeature\";\n// rendering\nexport { AutoWidthCalculator } from \"./rendering/autoWidthCalculator\";\nexport { CheckboxSelectionComponent } from \"./rendering/checkboxSelectionComponent\";\nexport { CellComp } from \"./rendering/cell/cellComp\";\nexport { CellCtrl } from \"./rendering/cell/cellCtrl\";\nexport { RowCtrl } from \"./rendering/row/rowCtrl\";\nexport { RowRenderer } from \"./rendering/rowRenderer\";\nexport { ValueFormatterService } from \"./rendering/valueFormatterService\";\nexport { CssClassManager } from \"./rendering/cssClassManager\";\n// row models\nexport { PinnedRowModel } from \"./pinnedRowModel/pinnedRowModel\";\nexport { ServerSideTransactionResultStatus } from \"./interfaces/serverSideTransaction\";\nexport { ChangedPath } from \"./utils/changedPath\";\nexport { RowNodeBlock } from \"./rowNodeCache/rowNodeBlock\";\nexport { RowNodeBlockLoader } from \"./rowNodeCache/rowNodeBlockLoader\";\nexport { PaginationProxy } from \"./pagination/paginationProxy\";\nexport { ClientSideRowModelSteps } from \"./interfaces/iClientSideRowModel\";\n//styling\nexport { StylingService } from \"./styling/stylingService\";\nexport { LayoutCssClasses } from \"./styling/layoutFeature\";\n// widgets\nexport { AgAbstractField } from \"./widgets/agAbstractField\";\nexport { AgCheckbox } from \"./widgets/agCheckbox\";\nexport { AgRadioButton } from \"./widgets/agRadioButton\";\nexport { AgToggleButton } from \"./widgets/agToggleButton\";\nexport { AgInputTextField } from \"./widgets/agInputTextField\";\nexport { AgInputTextArea } from \"./widgets/agInputTextArea\";\nexport { AgInputNumberField } from \"./widgets/agInputNumberField\";\nexport { AgInputRange } from \"./widgets/agInputRange\";\nexport { AgSelect } from \"./widgets/agSelect\";\nexport { AgSlider } from \"./widgets/agSlider\";\nexport { AgAngleSelect } from \"./widgets/agAngleSelect\";\nexport { AgColorPicker } from \"./widgets/agColorPicker\";\nexport { AgGroupComponent } from \"./widgets/agGroupComponent\";\nexport { AgMenuItemComponent } from \"./widgets/agMenuItemComponent\";\nexport { AgMenuList } from \"./widgets/agMenuList\";\nexport { AgMenuPanel } from \"./widgets/agMenuPanel\";\nexport { AgDialog } from \"./widgets/agDialog\";\nexport { AgPanel } from \"./widgets/agPanel\";\nexport { Component } from \"./widgets/component\";\nexport { ManagedFocusFeature } from \"./widgets/managedFocusFeature\";\nexport { TabGuardComp } from \"./widgets/tabGuardComp\";\nexport { TabGuardCtrl } from \"./widgets/tabGuardCtrl\";\nexport { PopupComponent } from \"./widgets/popupComponent\";\nexport { PopupService } from \"./widgets/popupService\";\nexport { TouchListener } from \"./widgets/touchListener\";\nexport { VirtualList } from \"./widgets/virtualList\";\n// range\nexport { CellRangeType, SelectionHandleType } from \"./interfaces/IRangeService\";\n// root\nexport { AutoScrollService } from './autoScrollService';\nexport { VanillaFrameworkOverrides } from \"./vanillaFrameworkOverrides\";\nexport { CellNavigationService } from \"./cellNavigationService\";\nexport { AlignedGridsService } from \"./alignedGridsService\";\nexport { Constants } from \"./constants/constants\";\nexport { KeyCode } from \"./constants/keyCode\";\nexport { Grid, GridCoreCreator } from \"./grid\";\nexport { GridApi } from \"./gridApi\";\nexport { Events } from \"./eventKeys\";\nexport { FocusService } from \"./focusService\";\nexport { defaultGroupComparator } from \"./functions\";\nexport { GridOptionsWrapper } from \"./gridOptionsWrapper\";\nexport { EventService } from \"./eventService\";\nexport { SelectableService } from \"./rowNodes/selectableService\";\nexport { RowNodeSorter } from \"./rowNodes/rowNodeSorter\";\nexport { CtrlsService } from \"./ctrlsService\";\nexport { GridComp } from \"./gridComp/gridComp\";\nexport { GridCtrl } from \"./gridComp/gridCtrl\";\nexport { Logger, LoggerFactory } from \"./logger\";\nexport { SelectionService } from \"./selectionService\";\nexport { SortController } from \"./sortController\";\nexport { TemplateService } from \"./templateService\";\nexport * from \"./utils\";\nexport { ValueService } from \"./valueService/valueService\";\nexport { ValueCache } from \"./valueService/valueCache\";\nexport { ExpressionService } from \"./valueService/expressionService\";\nexport { CellPositionUtils } from \"./entities/cellPosition\";\nexport { RowPositionUtils } from \"./entities/rowPosition\";\nexport { HeaderPositionUtils } from \"./headerRendering/common/headerPosition\";\nexport { HeaderNavigationService, HeaderNavigationDirection } from \"./headerRendering/common/headerNavigationService\";\nexport * from \"./propertyKeys\";\nexport { ColumnApi } from \"./columns/columnApi\";\nexport { BaseComponentWrapper } from \"./components/framework/frameworkComponentWrapper\";\nexport { Environment } from \"./environment\";\nexport { CustomTooltipFeature } from \"./widgets/customTooltipFeature\";\n// sparklines\nexport * from \"./interfaces/iSparklineCellRendererParams\";\nexport { ModuleNames } from \"./modules/moduleNames\";\nexport { ModuleRegistry } from \"./modules/moduleRegistry\";\n// events\nexport * from \"./events\";\n","import Vue from 'vue';\nexport class VueComponentFactory {\n static getComponentType(parent, component) {\n if (typeof component === 'string') {\n const componentInstance = this.searchForComponentInstance(parent, component);\n if (!componentInstance) {\n console.error(`Could not find component with name of ${component}. Is it in Vue.components?`);\n return null;\n }\n return Vue.extend(componentInstance);\n }\n else {\n // assume a type\n return component;\n }\n }\n static createAndMountComponent(params, componentType, parent) {\n const details = {\n data: {\n params: Object.freeze(params),\n },\n parent,\n };\n if (parent.componentDependencies) {\n parent.componentDependencies.forEach((dependency) => details[dependency] = parent[dependency]);\n }\n const component = new componentType(details);\n component.$mount();\n return component;\n }\n static searchForComponentInstance(parent, component, maxDepth = 10, suppressError = false) {\n let componentInstance = null;\n let currentParent = parent.$parent;\n let depth = 0;\n while (!componentInstance &&\n currentParent &&\n currentParent.$options &&\n (++depth < maxDepth)) {\n componentInstance = currentParent.$options.components[component];\n currentParent = currentParent.$parent;\n }\n if (!componentInstance && !suppressError) {\n console.error(`Could not find component with name of ${component}. Is it in Vue.components?`);\n return null;\n }\n return componentInstance;\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BaseComponentWrapper, Bean } from '@ag-grid-community/core';\nimport { VueComponentFactory } from './VueComponentFactory';\nlet VueFrameworkComponentWrapper = class VueFrameworkComponentWrapper extends BaseComponentWrapper {\n constructor(parent) {\n super();\n this.parent = parent;\n }\n createWrapper(component) {\n const that = this;\n class DynamicComponent extends VueComponent {\n init(params) {\n super.init(params);\n }\n hasMethod(name) {\n return wrapper.getFrameworkComponentInstance()[name] != null;\n }\n callMethod(name, args) {\n const componentInstance = this.getFrameworkComponentInstance();\n const frameworkComponentInstance = wrapper.getFrameworkComponentInstance();\n return frameworkComponentInstance[name].apply(componentInstance, args);\n }\n addMethod(name, callback) {\n wrapper[name] = callback;\n }\n overrideProcessing(methodName) {\n return that.parent.autoParamsRefresh && methodName === 'refresh';\n }\n processMethod(methodName, args) {\n if (methodName === 'refresh') {\n this.getFrameworkComponentInstance().params = args[0];\n }\n if (this.hasMethod(methodName)) {\n return this.callMethod(methodName, args);\n }\n return methodName === 'refresh';\n }\n createComponent(params) {\n return that.createComponent(component, params);\n }\n }\n const wrapper = new DynamicComponent();\n return wrapper;\n }\n createComponent(component, params) {\n const componentType = VueComponentFactory.getComponentType(this.parent, component);\n if (!componentType) {\n return;\n }\n return VueComponentFactory.createAndMountComponent(params, componentType, this.parent);\n }\n createMethodProxy(wrapper, methodName, mandatory) {\n return function () {\n if (wrapper.overrideProcessing(methodName)) {\n return wrapper.processMethod(methodName, arguments);\n }\n if (wrapper.hasMethod(methodName)) {\n return wrapper.callMethod(methodName, arguments);\n }\n if (mandatory) {\n console.warn('AG Grid: Framework component is missing the method ' + methodName + '()');\n }\n return null;\n };\n }\n destroy() {\n this.parent = null;\n }\n};\nVueFrameworkComponentWrapper = __decorate([\n Bean('frameworkComponentWrapper')\n], VueFrameworkComponentWrapper);\nexport { VueFrameworkComponentWrapper };\nclass VueComponent {\n getGui() {\n return this.component.$el;\n }\n destroy() {\n if (this.getFrameworkComponentInstance() &&\n typeof this.getFrameworkComponentInstance().destroy === 'function') {\n this.getFrameworkComponentInstance().destroy();\n }\n this.component.$destroy();\n }\n getFrameworkComponentInstance() {\n return this.component;\n }\n init(params) {\n this.component = this.createComponent(params);\n }\n}\n","import { ComponentUtil } from '@ag-grid-community/core';\nexport const getAgGridProperties = () => {\n const props = {\n gridOptions: {\n default() {\n return {};\n },\n },\n rowDataModel: undefined,\n };\n const watch = {\n rowDataModel(currentValue, previousValue) {\n this.processChanges('rowData', currentValue, previousValue);\n },\n };\n ComponentUtil.ALL_PROPERTIES.forEach((propertyName) => {\n props[propertyName] = {};\n watch[propertyName] = function (currentValue, previousValue) {\n this.processChanges(propertyName, currentValue, previousValue);\n };\n });\n const model = {\n prop: 'rowDataModel',\n event: 'data-model-changed',\n };\n return [props, watch, model];\n};\n","import { ColDefUtil } from '@ag-grid-community/core';\nexport class AgGridColumn {\n static hasChildColumns(slots) {\n return slots && slots.default && slots.default.length > 0;\n }\n static mapChildColumnDefs(slots) {\n return slots.default.map((column) => {\n return AgGridColumn.toColDef(column);\n });\n }\n static toColDef(column) {\n const colDef = AgGridColumn.createColDefFromGridColumn(column);\n if (column.children && column.children.length > 0) {\n colDef.children = AgGridColumn.getChildColDefs(column.children);\n }\n return colDef;\n }\n static getChildColDefs(columnChildren) {\n return columnChildren.map((column) => {\n return AgGridColumn.createColDefFromGridColumn(column);\n });\n }\n static createColDefFromGridColumn(column) {\n const colDef = {};\n Object.assign(colDef, column.data.attrs);\n delete colDef.children;\n // booleans passed down just as is are here as property=\"\"\n // convert boolean props to a boolean here\n ColDefUtil.BOOLEAN_PROPERTIES.forEach((property) => {\n const colDefAsAny = colDef;\n if (colDefAsAny[property] === '') {\n colDefAsAny[property] = true;\n }\n });\n return colDef;\n }\n}\n","import { VanillaFrameworkOverrides } from '@ag-grid-community/core';\nimport { VueComponentFactory } from './VueComponentFactory';\nexport class VueFrameworkOverrides extends VanillaFrameworkOverrides {\n constructor(parent) {\n super();\n this.parent = parent;\n }\n /*\n * vue components are specified in the \"components\" part of the vue component - as such we need a way to determine\n * if a given component is within that context - this method provides this\n * Note: This is only really used/necessary with cellRendererSelectors\n */\n frameworkComponent(name, components) {\n let foundInstance = !!VueComponentFactory.searchForComponentInstance(this.parent, name, 10, true);\n let result = foundInstance ? name : null;\n if (!result && components && components[name]) {\n const indirectName = components[name];\n foundInstance = !!VueComponentFactory.searchForComponentInstance(this.parent, indirectName, 10, true);\n result = foundInstance ? indirectName : null;\n }\n return result;\n }\n isFrameworkComponent(comp) {\n return typeof comp === 'object';\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar AgGridVue_1;\nimport { Component, Prop, Vue } from 'vue-property-decorator';\nimport { Bean, ComponentUtil, Grid } from '@ag-grid-community/core';\nimport { VueFrameworkComponentWrapper } from './VueFrameworkComponentWrapper';\nimport { getAgGridProperties } from './Utils';\nimport { AgGridColumn } from './AgGridColumn';\nimport { VueFrameworkOverrides } from './VueFrameworkOverrides';\nconst [props, watch, model] = getAgGridProperties();\nlet AgGridVue = AgGridVue_1 = class AgGridVue extends Vue {\n constructor() {\n super(...arguments);\n this.gridCreated = false;\n this.isDestroyed = false;\n this.gridReadyFired = false;\n this.emitRowModel = null;\n }\n static kebabProperty(property) {\n return property.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();\n }\n // noinspection JSUnusedGlobalSymbols, JSMethodCanBeStatic\n render(h) {\n return h('div');\n }\n globalEventListener(eventType, event) {\n if (this.isDestroyed) {\n return;\n }\n if (eventType === 'gridReady') {\n this.gridReadyFired = true;\n }\n this.updateModelIfUsed(eventType);\n // only emit if someone is listening\n // we allow both kebab and camelCase event listeners, so check for both\n const kebabName = AgGridVue_1.kebabProperty(eventType);\n if (this.$listeners[kebabName]) {\n this.$emit(kebabName, event);\n }\n else if (this.$listeners[eventType]) {\n this.$emit(eventType, event);\n }\n }\n processChanges(propertyName, currentValue, previousValue) {\n if (this.gridCreated) {\n if (this.skipChange(propertyName, currentValue, previousValue)) {\n return;\n }\n const changes = {};\n changes[propertyName] = {\n currentValue,\n previousValue,\n };\n ComponentUtil.processOnChange(changes, this.gridOptions, this.gridOptions.api, this.gridOptions.columnApi);\n }\n }\n // noinspection JSUnusedGlobalSymbols\n mounted() {\n // we debounce the model update to prevent a flood of updates in the event there are many individual\n // cell/row updates\n this.emitRowModel = this.debounce(() => {\n this.$emit('data-model-changed', Object.freeze(this.getRowData()));\n }, 20);\n const frameworkComponentWrapper = new VueFrameworkComponentWrapper(this);\n const gridOptions = ComponentUtil.copyAttributesToGridOptions(this.gridOptions, this);\n this.checkForBindingConflicts();\n gridOptions.rowData = this.getRowDataBasedOnBindings();\n if (AgGridColumn.hasChildColumns(this.$slots)) {\n gridOptions.columnDefs = AgGridColumn.mapChildColumnDefs(this.$slots);\n }\n const gridParams = {\n globalEventListener: this.globalEventListener.bind(this),\n frameworkOverrides: new VueFrameworkOverrides(this),\n providedBeanInstances: {\n frameworkComponentWrapper,\n },\n modules: this.modules,\n };\n new Grid(this.$el, gridOptions, gridParams);\n this.gridCreated = true;\n }\n // noinspection JSUnusedGlobalSymbols\n destroyed() {\n if (this.gridCreated) {\n if (this.gridOptions.api) {\n this.gridOptions.api.destroy();\n }\n this.isDestroyed = true;\n }\n }\n checkForBindingConflicts() {\n const thisAsAny = this;\n if ((thisAsAny.rowData || this.gridOptions.rowData) &&\n thisAsAny.rowDataModel) {\n console.warn('AG Grid: Using both rowData and rowDataModel. rowData will be ignored.');\n }\n }\n getRowData() {\n const rowData = [];\n this.gridOptions.api.forEachNode((rowNode) => {\n rowData.push(rowNode.data);\n });\n return rowData;\n }\n updateModelIfUsed(eventType) {\n if (this.gridReadyFired &&\n this.$listeners['data-model-changed'] &&\n AgGridVue_1.ROW_DATA_EVENTS.indexOf(eventType) !== -1) {\n if (this.emitRowModel) {\n this.emitRowModel();\n }\n }\n }\n getRowDataBasedOnBindings() {\n const thisAsAny = this;\n const rowDataModel = thisAsAny.rowDataModel;\n return rowDataModel ? rowDataModel :\n thisAsAny.rowData ? thisAsAny.rowData : thisAsAny.gridOptions.rowData;\n }\n /*\n * Prevents an infinite loop when using v-model for the rowData\n */\n skipChange(propertyName, currentValue, previousValue) {\n if (this.gridReadyFired &&\n propertyName === 'rowData' &&\n this.$listeners['data-model-changed']) {\n if (currentValue === previousValue) {\n return true;\n }\n if (currentValue && previousValue) {\n const currentRowData = currentValue;\n const previousRowData = previousValue;\n if (currentRowData.length === previousRowData.length) {\n for (let i = 0; i < currentRowData.length; i++) {\n if (currentRowData[i] !== previousRowData[i]) {\n return false;\n }\n }\n return true;\n }\n }\n }\n return false;\n }\n debounce(func, delay) {\n let timeout;\n return () => {\n const later = function () {\n func();\n };\n window.clearTimeout(timeout);\n timeout = window.setTimeout(later, delay);\n };\n }\n};\nAgGridVue.ROW_DATA_EVENTS = ['rowDataChanged', 'rowDataUpdated', 'cellValueChanged', 'rowValueChanged'];\n__decorate([\n Prop(Boolean)\n], AgGridVue.prototype, \"autoParamsRefresh\", void 0);\n__decorate([\n Prop({ default: () => [] })\n], AgGridVue.prototype, \"componentDependencies\", void 0);\n__decorate([\n Prop({ default: () => [] })\n], AgGridVue.prototype, \"modules\", void 0);\nAgGridVue = AgGridVue_1 = __decorate([\n Bean('agGridVue'),\n Component({\n props,\n watch,\n model,\n })\n], AgGridVue);\nexport { AgGridVue };\n","\"use strict\";\nfunction __export(m) {\n for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];\n}\nObject.defineProperty(exports, \"__esModule\", { value: true });\n__export(require(\"./lib/AgGridVue\"));\n\n","var __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nimport { Events, RowNode, _ } from \"@ag-grid-community/core\";\nvar ClientSideNodeManager = /** @class */ (function () {\n function ClientSideNodeManager(rootNode, gridOptionsWrapper, eventService, columnModel, selectionService, beans) {\n this.nextId = 0;\n // when user is provide the id's, we also keep a map of ids to row nodes for convenience\n this.allNodesMap = {};\n this.rootNode = rootNode;\n this.gridOptionsWrapper = gridOptionsWrapper;\n this.eventService = eventService;\n this.columnModel = columnModel;\n this.beans = beans;\n this.selectionService = selectionService;\n this.rootNode.group = true;\n this.rootNode.level = -1;\n this.rootNode.id = ClientSideNodeManager.ROOT_NODE_ID;\n this.rootNode.allLeafChildren = [];\n this.rootNode.childrenAfterGroup = [];\n this.rootNode.childrenAfterSort = [];\n this.rootNode.childrenAfterAggFilter = [];\n this.rootNode.childrenAfterFilter = [];\n // if we make this class a bean, then can annotate postConstruct\n this.postConstruct();\n }\n // @PostConstruct - this is not a bean, so postConstruct called by constructor\n ClientSideNodeManager.prototype.postConstruct = function () {\n // func below doesn't have 'this' pointer, so need to pull out these bits\n this.suppressParentsInRowNodes = this.gridOptionsWrapper.isSuppressParentsInRowNodes();\n this.isRowMasterFunc = this.gridOptionsWrapper.getIsRowMasterFunc();\n this.doingTreeData = this.gridOptionsWrapper.isTreeData();\n this.doingMasterDetail = this.gridOptionsWrapper.isMasterDetail();\n };\n ClientSideNodeManager.prototype.getCopyOfNodesMap = function () {\n return _.cloneObject(this.allNodesMap);\n };\n ClientSideNodeManager.prototype.getRowNode = function (id) {\n return this.allNodesMap[id];\n };\n ClientSideNodeManager.prototype.setRowData = function (rowData) {\n var _this = this;\n if (typeof rowData === 'string') {\n console.warn('AG Grid: rowData must be an array, however you passed in a string. If you are loading JSON, make sure you convert the JSON string to JavaScript objects first');\n return;\n }\n var rootNode = this.rootNode;\n var sibling = this.rootNode.sibling;\n rootNode.childrenAfterFilter = null;\n rootNode.childrenAfterGroup = null;\n rootNode.childrenAfterAggFilter = null;\n rootNode.childrenAfterSort = null;\n rootNode.childrenMapped = null;\n rootNode.updateHasChildren();\n this.nextId = 0;\n this.allNodesMap = {};\n if (rowData) {\n // we use rootNode as the parent, however if using ag-grid-enterprise, the grouping stage\n // sets the parent node on each row (even if we are not grouping). so setting parent node\n // here is for benefit of ag-grid-community users\n rootNode.allLeafChildren = rowData.map(function (dataItem) { return _this.createNode(dataItem, _this.rootNode, ClientSideNodeManager.TOP_LEVEL); });\n }\n else {\n rootNode.allLeafChildren = [];\n rootNode.childrenAfterGroup = [];\n }\n if (sibling) {\n sibling.childrenAfterFilter = rootNode.childrenAfterFilter;\n sibling.childrenAfterGroup = rootNode.childrenAfterGroup;\n sibling.childrenAfterAggFilter = rootNode.childrenAfterAggFilter;\n sibling.childrenAfterSort = rootNode.childrenAfterSort;\n sibling.childrenMapped = rootNode.childrenMapped;\n sibling.allLeafChildren = rootNode.allLeafChildren;\n }\n };\n ClientSideNodeManager.prototype.updateRowData = function (rowDataTran, rowNodeOrder) {\n var rowNodeTransaction = {\n remove: [],\n update: [],\n add: []\n };\n var nodesToUnselect = [];\n this.executeRemove(rowDataTran, rowNodeTransaction, nodesToUnselect);\n this.executeUpdate(rowDataTran, rowNodeTransaction, nodesToUnselect);\n this.executeAdd(rowDataTran, rowNodeTransaction);\n this.updateSelection(nodesToUnselect);\n if (rowNodeOrder) {\n _.sortRowNodesByOrder(this.rootNode.allLeafChildren, rowNodeOrder);\n }\n return rowNodeTransaction;\n };\n ClientSideNodeManager.prototype.updateSelection = function (nodesToUnselect) {\n var selectionChanged = nodesToUnselect.length > 0;\n if (selectionChanged) {\n nodesToUnselect.forEach(function (rowNode) {\n rowNode.setSelected(false, false, true);\n });\n }\n // we do this regardless of nodes to unselect or not, as it's possible\n // a new node was inserted, so a parent that was previously selected (as all\n // children were selected) should not be tri-state (as new one unselected against\n // all other selected children).\n this.selectionService.updateGroupsFromChildrenSelections();\n if (selectionChanged) {\n var event_1 = {\n type: Events.EVENT_SELECTION_CHANGED\n };\n this.eventService.dispatchEvent(event_1);\n }\n };\n ClientSideNodeManager.prototype.executeAdd = function (rowDataTran, rowNodeTransaction) {\n var _this = this;\n var add = rowDataTran.add, addIndex = rowDataTran.addIndex;\n if (_.missingOrEmpty(add)) {\n return;\n }\n // create new row nodes for each data item\n var newNodes = add.map(function (item) { return _this.createNode(item, _this.rootNode, ClientSideNodeManager.TOP_LEVEL); });\n // add new row nodes to the root nodes 'allLeafChildren'\n var useIndex = typeof addIndex === 'number' && addIndex >= 0;\n var nodesBeforeIndex;\n var nodesAfterIndex;\n if (useIndex) {\n // new rows are inserted in one go by concatenating them in between the existing rows at the desired index.\n // this is much faster than splicing them individually into 'allLeafChildren' when there are large inserts.\n // allLeafChildren can be out of order, so we loop over all the Nodes to find the correct index that\n // represents the position `addIndex` intended to be.\n var allLeafChildren_1 = this.rootNode.allLeafChildren;\n // if addIndex is 0, it should always be added at the start of the array\n // there is no need to verify the order of node by nodeIndex.\n var normalizedAddIndex = addIndex === 0 ? 0 : (allLeafChildren_1.reduce(function (prevIdx, currNode, currIdx) {\n var _a;\n var rowIndex = currNode.rowIndex;\n var prevValueAtIndex = (_a = allLeafChildren_1[prevIdx]) === null || _a === void 0 ? void 0 : _a.rowIndex;\n var shouldUpdateIndex = rowIndex != null && prevValueAtIndex != null && rowIndex < addIndex && rowIndex > prevValueAtIndex;\n return shouldUpdateIndex ? currIdx : prevIdx;\n }, 0) + 1);\n nodesBeforeIndex = allLeafChildren_1.slice(0, normalizedAddIndex);\n nodesAfterIndex = allLeafChildren_1.slice(normalizedAddIndex, allLeafChildren_1.length);\n }\n else {\n nodesBeforeIndex = this.rootNode.allLeafChildren;\n nodesAfterIndex = [];\n }\n this.rootNode.allLeafChildren = __spread(nodesBeforeIndex, newNodes, nodesAfterIndex);\n if (this.rootNode.sibling) {\n this.rootNode.sibling.allLeafChildren = this.rootNode.allLeafChildren;\n }\n // add new row nodes to the transaction add items\n rowNodeTransaction.add = newNodes;\n };\n ClientSideNodeManager.prototype.executeRemove = function (rowDataTran, rowNodeTransaction, nodesToUnselect) {\n var _this = this;\n var remove = rowDataTran.remove;\n if (_.missingOrEmpty(remove)) {\n return;\n }\n var rowIdsRemoved = {};\n remove.forEach(function (item) {\n var rowNode = _this.lookupRowNode(item);\n if (!rowNode) {\n return;\n }\n // do delete - setting 'suppressFinishActions = true' to ensure EVENT_SELECTION_CHANGED is not raised for\n // each row node updated, instead it is raised once by the calling code if any selected nodes exist.\n if (rowNode.isSelected()) {\n nodesToUnselect.push(rowNode);\n }\n // so row renderer knows to fade row out (and not reposition it)\n rowNode.clearRowTopAndRowIndex();\n // NOTE: were we could remove from allLeaveChildren, however _.removeFromArray() is expensive, especially\n // if called multiple times (eg deleting lots of rows) and if allLeafChildren is a large list\n rowIdsRemoved[rowNode.id] = true;\n // _.removeFromArray(this.rootNode.allLeafChildren, rowNode);\n delete _this.allNodesMap[rowNode.id];\n rowNodeTransaction.remove.push(rowNode);\n });\n this.rootNode.allLeafChildren = this.rootNode.allLeafChildren.filter(function (rowNode) { return !rowIdsRemoved[rowNode.id]; });\n if (this.rootNode.sibling) {\n this.rootNode.sibling.allLeafChildren = this.rootNode.allLeafChildren;\n }\n };\n ClientSideNodeManager.prototype.executeUpdate = function (rowDataTran, rowNodeTransaction, nodesToUnselect) {\n var _this = this;\n var update = rowDataTran.update;\n if (_.missingOrEmpty(update)) {\n return;\n }\n update.forEach(function (item) {\n var rowNode = _this.lookupRowNode(item);\n if (!rowNode) {\n return;\n }\n rowNode.updateData(item);\n if (!rowNode.selectable && rowNode.isSelected()) {\n nodesToUnselect.push(rowNode);\n }\n _this.setMasterForRow(rowNode, item, ClientSideNodeManager.TOP_LEVEL, false);\n rowNodeTransaction.update.push(rowNode);\n });\n };\n ClientSideNodeManager.prototype.lookupRowNode = function (data) {\n var getRowIdFunc = this.gridOptionsWrapper.getRowIdFunc();\n var rowNode;\n if (getRowIdFunc) {\n // find rowNode using id\n var id = getRowIdFunc({ data: data, level: 0 });\n rowNode = this.allNodesMap[id];\n if (!rowNode) {\n console.error(\"AG Grid: could not find row id=\" + id + \", data item was not found for this id\");\n return null;\n }\n }\n else {\n // find rowNode using object references\n rowNode = this.rootNode.allLeafChildren.find(function (node) { return node.data === data; });\n if (!rowNode) {\n console.error(\"AG Grid: could not find data item as object was not found\", data);\n console.error(\"Consider using getRowId to help the Grid find matching row data\");\n return null;\n }\n }\n return rowNode || null;\n };\n ClientSideNodeManager.prototype.createNode = function (dataItem, parent, level) {\n var node = new RowNode(this.beans);\n node.group = false;\n this.setMasterForRow(node, dataItem, level, true);\n if (parent && !this.suppressParentsInRowNodes) {\n node.parent = parent;\n }\n node.level = level;\n node.setDataAndId(dataItem, this.nextId.toString());\n if (this.allNodesMap[node.id]) {\n console.warn(\"AG Grid: duplicate node id '\" + node.id + \"' detected from getRowId callback, this could cause issues in your grid.\");\n }\n this.allNodesMap[node.id] = node;\n this.nextId++;\n return node;\n };\n ClientSideNodeManager.prototype.setMasterForRow = function (rowNode, data, level, setExpanded) {\n if (this.doingTreeData) {\n rowNode.setMaster(false);\n if (setExpanded) {\n rowNode.expanded = false;\n }\n }\n else {\n // this is the default, for when doing grid data\n if (this.doingMasterDetail) {\n // if we are doing master detail, then the\n // default is that everything can be a Master Row.\n if (this.isRowMasterFunc) {\n rowNode.setMaster(this.isRowMasterFunc(data));\n }\n else {\n rowNode.setMaster(true);\n }\n }\n else {\n rowNode.setMaster(false);\n }\n if (setExpanded) {\n var rowGroupColumns = this.columnModel.getRowGroupColumns();\n var numRowGroupColumns = rowGroupColumns ? rowGroupColumns.length : 0;\n // need to take row group into account when determining level\n var masterRowLevel = level + numRowGroupColumns;\n rowNode.expanded = rowNode.master ? this.isExpanded(masterRowLevel) : false;\n }\n }\n };\n ClientSideNodeManager.prototype.isExpanded = function (level) {\n var expandByDefault = this.gridOptionsWrapper.getGroupDefaultExpanded();\n if (expandByDefault === -1) {\n return true;\n }\n return level < expandByDefault;\n };\n ClientSideNodeManager.TOP_LEVEL = 0;\n ClientSideNodeManager.ROOT_NODE_ID = 'ROOT_NODE_ID';\n return ClientSideNodeManager;\n}());\nexport { ClientSideNodeManager };\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { _, Autowired, Bean, BeanStub, ChangedPath, Constants, Events, GridOptionsWrapper, Optional, PostConstruct, ClientSideRowModelSteps, RowNode, RowHighlightPosition } from \"@ag-grid-community/core\";\nimport { ClientSideNodeManager } from \"./clientSideNodeManager\";\nvar RecursionType;\n(function (RecursionType) {\n RecursionType[RecursionType[\"Normal\"] = 0] = \"Normal\";\n RecursionType[RecursionType[\"AfterFilter\"] = 1] = \"AfterFilter\";\n RecursionType[RecursionType[\"AfterFilterAndSort\"] = 2] = \"AfterFilterAndSort\";\n RecursionType[RecursionType[\"PivotNodes\"] = 3] = \"PivotNodes\";\n})(RecursionType || (RecursionType = {}));\nvar ClientSideRowModel = /** @class */ (function (_super) {\n __extends(ClientSideRowModel, _super);\n function ClientSideRowModel() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.rowsToDisplay = []; // the rows mapped to rows to display\n return _this;\n }\n ClientSideRowModel.prototype.init = function () {\n var refreshEverythingFunc = this.refreshModel.bind(this, { step: ClientSideRowModelSteps.EVERYTHING });\n var animate = !this.gridOptionsWrapper.isSuppressAnimationFrame();\n var refreshEverythingAfterColsChangedFunc = this.refreshModel.bind(this, {\n step: ClientSideRowModelSteps.EVERYTHING,\n afterColumnsChanged: true,\n keepRenderedRows: true,\n animate: animate\n });\n this.addManagedListener(this.eventService, Events.EVENT_NEW_COLUMNS_LOADED, refreshEverythingAfterColsChangedFunc);\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, refreshEverythingFunc);\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_VALUE_CHANGED, this.onValueChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PIVOT_CHANGED, this.refreshModel.bind(this, { step: ClientSideRowModelSteps.PIVOT }));\n this.addManagedListener(this.eventService, Events.EVENT_FILTER_CHANGED, this.onFilterChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_SORT_CHANGED, this.onSortChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PIVOT_MODE_CHANGED, refreshEverythingFunc);\n var refreshMapListener = this.refreshModel.bind(this, {\n step: ClientSideRowModelSteps.MAP,\n keepRenderedRows: true,\n animate: animate\n });\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_GROUP_REMOVE_SINGLE_CHILDREN, refreshMapListener);\n this.addManagedListener(this.gridOptionsWrapper, GridOptionsWrapper.PROP_GROUP_REMOVE_LOWEST_SINGLE_CHILDREN, refreshMapListener);\n this.rootNode = new RowNode(this.beans);\n this.nodeManager = new ClientSideNodeManager(this.rootNode, this.gridOptionsWrapper, this.eventService, this.columnModel, this.selectionService, this.beans);\n };\n ClientSideRowModel.prototype.start = function () {\n var rowData = this.gridOptionsWrapper.getRowData();\n if (rowData) {\n this.setRowData(rowData);\n }\n };\n ClientSideRowModel.prototype.ensureRowHeightsValid = function (startPixel, endPixel, startLimitIndex, endLimitIndex) {\n var atLeastOneChange;\n var res = false;\n // we do this multiple times as changing the row heights can also change the first and last rows,\n // so the first pass can make lots of rows smaller, which means the second pass we end up changing\n // more rows.\n do {\n atLeastOneChange = false;\n var rowAtStartPixel = this.getRowIndexAtPixel(startPixel);\n var rowAtEndPixel = this.getRowIndexAtPixel(endPixel);\n // keep check to current page if doing pagination\n var firstRow = Math.max(rowAtStartPixel, startLimitIndex);\n var lastRow = Math.min(rowAtEndPixel, endLimitIndex);\n for (var rowIndex = firstRow; rowIndex <= lastRow; rowIndex++) {\n var rowNode = this.getRow(rowIndex);\n if (rowNode.rowHeightEstimated) {\n var rowHeight = this.gridOptionsWrapper.getRowHeightForNode(rowNode);\n rowNode.setRowHeight(rowHeight.height);\n atLeastOneChange = true;\n res = true;\n }\n }\n if (atLeastOneChange) {\n this.setRowTopAndRowIndex();\n }\n } while (atLeastOneChange);\n return res;\n };\n ClientSideRowModel.prototype.setRowTopAndRowIndex = function () {\n var defaultRowHeight = this.gridOptionsWrapper.getDefaultRowHeight();\n var nextRowTop = 0;\n // mapping displayed rows is not needed for this method, however it's used in\n // clearRowTopAndRowIndex(), and given we are looping through this.rowsToDisplay here,\n // we create the map here for performance reasons, so we don't loop a second time\n // in clearRowTopAndRowIndex()\n var displayedRowsMapped = new Set();\n // we don't estimate if doing fullHeight or autoHeight, as all rows get rendered all the time\n // with these two layouts.\n var allowEstimate = this.gridOptionsWrapper.getDomLayout() === Constants.DOM_LAYOUT_NORMAL;\n for (var i = 0; i < this.rowsToDisplay.length; i++) {\n var rowNode = this.rowsToDisplay[i];\n if (rowNode.id != null) {\n displayedRowsMapped.add(rowNode.id);\n }\n if (rowNode.rowHeight == null) {\n var rowHeight = this.gridOptionsWrapper.getRowHeightForNode(rowNode, allowEstimate, defaultRowHeight);\n rowNode.setRowHeight(rowHeight.height, rowHeight.estimated);\n }\n rowNode.setRowTop(nextRowTop);\n rowNode.setRowIndex(i);\n nextRowTop += rowNode.rowHeight;\n }\n return displayedRowsMapped;\n };\n ClientSideRowModel.prototype.clearRowTopAndRowIndex = function (changedPath, displayedRowsMapped) {\n var changedPathActive = changedPath.isActive();\n var clearIfNotDisplayed = function (rowNode) {\n if (rowNode && rowNode.id != null && !displayedRowsMapped.has(rowNode.id)) {\n rowNode.clearRowTopAndRowIndex();\n }\n };\n var recurse = function (rowNode) {\n clearIfNotDisplayed(rowNode);\n clearIfNotDisplayed(rowNode.detailNode);\n clearIfNotDisplayed(rowNode.sibling);\n if (rowNode.hasChildren()) {\n if (rowNode.childrenAfterGroup) {\n // if a changedPath is active, it means we are here because of a transaction update or\n // a change detection. neither of these impacts the open/closed state of groups. so if\n // a group is not open this time, it was not open last time. so we know all closed groups\n // already have their top positions cleared. so there is no need to traverse all the way\n // when changedPath is active and the rowNode is not expanded.\n var isRootNode = rowNode.level == -1; // we need to give special consideration for root node,\n // as expanded=undefined for root node\n var skipChildren = changedPathActive && !isRootNode && !rowNode.expanded;\n if (!skipChildren) {\n rowNode.childrenAfterGroup.forEach(recurse);\n }\n }\n }\n };\n recurse(this.rootNode);\n };\n // returns false if row was moved, otherwise true\n ClientSideRowModel.prototype.ensureRowsAtPixel = function (rowNodes, pixel, increment) {\n var _this = this;\n if (increment === void 0) { increment = 0; }\n var indexAtPixelNow = this.getRowIndexAtPixel(pixel);\n var rowNodeAtPixelNow = this.getRow(indexAtPixelNow);\n var animate = !this.gridOptionsWrapper.isSuppressAnimationFrame();\n if (rowNodeAtPixelNow === rowNodes[0]) {\n return false;\n }\n rowNodes.forEach(function (rowNode) {\n _.removeFromArray(_this.rootNode.allLeafChildren, rowNode);\n });\n rowNodes.forEach(function (rowNode, idx) {\n _.insertIntoArray(_this.rootNode.allLeafChildren, rowNode, Math.max(indexAtPixelNow + increment, 0) + idx);\n });\n this.refreshModel({\n step: ClientSideRowModelSteps.EVERYTHING,\n keepRenderedRows: true,\n keepEditingRows: true,\n animate: animate\n });\n return true;\n };\n ClientSideRowModel.prototype.highlightRowAtPixel = function (rowNode, pixel) {\n var indexAtPixelNow = pixel != null ? this.getRowIndexAtPixel(pixel) : null;\n var rowNodeAtPixelNow = indexAtPixelNow != null ? this.getRow(indexAtPixelNow) : null;\n if (!rowNodeAtPixelNow || !rowNode || rowNodeAtPixelNow === rowNode || pixel == null) {\n if (this.lastHighlightedRow) {\n this.lastHighlightedRow.setHighlighted(null);\n this.lastHighlightedRow = null;\n }\n return;\n }\n var highlight = this.getHighlightPosition(pixel, rowNodeAtPixelNow);\n if (this.lastHighlightedRow && this.lastHighlightedRow !== rowNodeAtPixelNow) {\n this.lastHighlightedRow.setHighlighted(null);\n this.lastHighlightedRow = null;\n }\n rowNodeAtPixelNow.setHighlighted(highlight);\n this.lastHighlightedRow = rowNodeAtPixelNow;\n };\n ClientSideRowModel.prototype.getHighlightPosition = function (pixel, rowNode) {\n if (!rowNode) {\n var index = this.getRowIndexAtPixel(pixel);\n rowNode = this.getRow(index || 0);\n if (!rowNode) {\n return RowHighlightPosition.Below;\n }\n }\n var rowTop = rowNode.rowTop, rowHeight = rowNode.rowHeight;\n return pixel - rowTop < rowHeight / 2 ? RowHighlightPosition.Above : RowHighlightPosition.Below;\n };\n ClientSideRowModel.prototype.getLastHighlightedRowNode = function () {\n return this.lastHighlightedRow;\n };\n ClientSideRowModel.prototype.isLastRowIndexKnown = function () {\n return true;\n };\n ClientSideRowModel.prototype.getRowCount = function () {\n if (this.rowsToDisplay) {\n return this.rowsToDisplay.length;\n }\n return 0;\n };\n ClientSideRowModel.prototype.getTopLevelRowCount = function () {\n var showingRootNode = this.rowsToDisplay && this.rowsToDisplay[0] === this.rootNode;\n if (showingRootNode) {\n return 1;\n }\n var filteredChildren = this.rootNode.childrenAfterAggFilter;\n return filteredChildren ? filteredChildren.length : 0;\n };\n ClientSideRowModel.prototype.getTopLevelRowDisplayedIndex = function (topLevelIndex) {\n var showingRootNode = this.rowsToDisplay && this.rowsToDisplay[0] === this.rootNode;\n if (showingRootNode) {\n return topLevelIndex;\n }\n var rowNode = this.rootNode.childrenAfterSort[topLevelIndex];\n if (this.gridOptionsWrapper.isGroupHideOpenParents()) {\n // if hideOpenParents, and this row open, then this row is now displayed at this index, first child is\n while (rowNode.expanded && rowNode.childrenAfterSort && rowNode.childrenAfterSort.length > 0) {\n rowNode = rowNode.childrenAfterSort[0];\n }\n }\n return rowNode.rowIndex;\n };\n ClientSideRowModel.prototype.getRowBounds = function (index) {\n if (_.missing(this.rowsToDisplay)) {\n return null;\n }\n var rowNode = this.rowsToDisplay[index];\n if (rowNode) {\n return {\n rowTop: rowNode.rowTop,\n rowHeight: rowNode.rowHeight\n };\n }\n return null;\n };\n ClientSideRowModel.prototype.onRowGroupOpened = function () {\n var animate = this.gridOptionsWrapper.isAnimateRows();\n this.refreshModel({ step: ClientSideRowModelSteps.MAP, keepRenderedRows: true, animate: animate });\n };\n ClientSideRowModel.prototype.onFilterChanged = function (event) {\n if (event.afterDataChange) {\n return;\n }\n var animate = this.gridOptionsWrapper.isAnimateRows();\n var primaryOrQuickFilterChanged = event.columns.length === 0 || event.columns.some(function (col) { return col.isPrimary(); });\n var step = primaryOrQuickFilterChanged ? ClientSideRowModelSteps.FILTER : ClientSideRowModelSteps.FILTER_AGGREGATES;\n this.refreshModel({ step: step, keepRenderedRows: true, animate: animate });\n };\n ClientSideRowModel.prototype.onSortChanged = function () {\n var animate = this.gridOptionsWrapper.isAnimateRows();\n this.refreshModel({ step: ClientSideRowModelSteps.SORT, keepRenderedRows: true, animate: animate, keepEditingRows: true });\n };\n ClientSideRowModel.prototype.getType = function () {\n return Constants.ROW_MODEL_TYPE_CLIENT_SIDE;\n };\n ClientSideRowModel.prototype.onValueChanged = function () {\n if (this.columnModel.isPivotActive()) {\n this.refreshModel({ step: ClientSideRowModelSteps.PIVOT });\n }\n else {\n this.refreshModel({ step: ClientSideRowModelSteps.AGGREGATE });\n }\n };\n ClientSideRowModel.prototype.createChangePath = function (rowNodeTransactions) {\n // for updates, if the row is updated at all, then we re-calc all the values\n // in that row. we could compare each value to each old value, however if we\n // did this, we would be calling the valueService twice, once on the old value\n // and once on the new value. so it's less valueGetter calls if we just assume\n // each column is different. that way the changedPath is used so that only\n // the impacted parent rows are recalculated, parents who's children have\n // not changed are not impacted.\n var noTransactions = _.missingOrEmpty(rowNodeTransactions);\n var changedPath = new ChangedPath(false, this.rootNode);\n if (noTransactions || this.gridOptionsWrapper.isTreeData()) {\n changedPath.setInactive();\n }\n return changedPath;\n };\n ClientSideRowModel.prototype.isSuppressModelUpdateAfterUpdateTransaction = function (params) {\n if (!this.gridOptionsWrapper.isSuppressModelUpdateAfterUpdateTransaction()) {\n return false;\n }\n // return true if we are only doing update transactions\n if (params.rowNodeTransactions == null) {\n return false;\n }\n var transWithAddsOrDeletes = params.rowNodeTransactions.filter(function (tx) {\n return (tx.add != null && tx.add.length > 0) || (tx.remove != null && tx.remove.length > 0);\n });\n var transactionsContainUpdatesOnly = transWithAddsOrDeletes == null || transWithAddsOrDeletes.length == 0;\n return transactionsContainUpdatesOnly;\n };\n ClientSideRowModel.prototype.refreshModel = function (params) {\n if (this.isSuppressModelUpdateAfterUpdateTransaction(params)) {\n return;\n }\n // this goes through the pipeline of stages. what's in my head is similar\n // to the diagram on this page:\n // http://commons.apache.org/sandbox/commons-pipeline/pipeline_basics.html\n // however we want to keep the results of each stage, hence we manually call\n // each step rather than have them chain each other.\n // fallthrough in below switch is on purpose,\n // eg if STEP_FILTER, then all steps below this\n // step get done\n // let start: number;\n // console.log('======= start =======');\n var changedPath = this.createChangePath(params.rowNodeTransactions);\n switch (params.step) {\n case ClientSideRowModelSteps.EVERYTHING:\n this.doRowGrouping(params.groupState, params.rowNodeTransactions, params.rowNodeOrder, changedPath, !!params.afterColumnsChanged);\n case ClientSideRowModelSteps.FILTER:\n this.doFilter(changedPath);\n case ClientSideRowModelSteps.PIVOT:\n this.doPivot(changedPath);\n case ClientSideRowModelSteps.AGGREGATE: // depends on agg fields\n this.doAggregate(changedPath);\n case ClientSideRowModelSteps.FILTER_AGGREGATES:\n this.doFilterAggregates(changedPath);\n case ClientSideRowModelSteps.SORT:\n this.doSort(params.rowNodeTransactions, changedPath);\n case ClientSideRowModelSteps.MAP:\n this.doRowsToDisplay();\n }\n // set all row tops to null, then set row tops on all visible rows. if we don't\n // do this, then the algorithm below only sets row tops, old row tops from old rows\n // will still lie around\n var displayedNodesMapped = this.setRowTopAndRowIndex();\n this.clearRowTopAndRowIndex(changedPath, displayedNodesMapped);\n var event = {\n type: Events.EVENT_MODEL_UPDATED,\n animate: params.animate,\n keepRenderedRows: params.keepRenderedRows,\n newData: params.newData,\n newPage: false,\n keepUndoRedoStack: params.keepUndoRedoStack\n };\n this.eventService.dispatchEvent(event);\n };\n ClientSideRowModel.prototype.isEmpty = function () {\n var rowsMissing = _.missing(this.rootNode.allLeafChildren) || this.rootNode.allLeafChildren.length === 0;\n return _.missing(this.rootNode) || rowsMissing || !this.columnModel.isReady();\n };\n ClientSideRowModel.prototype.isRowsToRender = function () {\n return _.exists(this.rowsToDisplay) && this.rowsToDisplay.length > 0;\n };\n ClientSideRowModel.prototype.getNodesInRangeForSelection = function (firstInRange, lastInRange) {\n // if lastSelectedNode is missing, we start at the first row\n var firstRowHit = !lastInRange;\n var lastRowHit = false;\n var lastRow;\n var result = [];\n var groupsSelectChildren = this.gridOptionsWrapper.isGroupSelectsChildren();\n this.forEachNodeAfterFilterAndSort(function (rowNode) {\n var lookingForLastRow = firstRowHit && !lastRowHit;\n // check if we need to flip the select switch\n if (!firstRowHit) {\n if (rowNode === lastInRange || rowNode === firstInRange) {\n firstRowHit = true;\n }\n }\n var skipThisGroupNode = rowNode.group && groupsSelectChildren;\n if (!skipThisGroupNode) {\n var inRange = firstRowHit && !lastRowHit;\n var childOfLastRow = rowNode.isParentOfNode(lastRow);\n if (inRange || childOfLastRow) {\n result.push(rowNode);\n }\n }\n if (lookingForLastRow) {\n if (rowNode === lastInRange || rowNode === firstInRange) {\n lastRowHit = true;\n if (rowNode === lastInRange) {\n lastRow = lastInRange;\n }\n else {\n lastRow = firstInRange;\n }\n }\n }\n });\n return result;\n };\n ClientSideRowModel.prototype.setDatasource = function (datasource) {\n console.error('AG Grid: should never call setDatasource on clientSideRowController');\n };\n ClientSideRowModel.prototype.getTopLevelNodes = function () {\n return this.rootNode ? this.rootNode.childrenAfterGroup : null;\n };\n ClientSideRowModel.prototype.getRootNode = function () {\n return this.rootNode;\n };\n ClientSideRowModel.prototype.getRow = function (index) {\n return this.rowsToDisplay[index];\n };\n ClientSideRowModel.prototype.isRowPresent = function (rowNode) {\n return this.rowsToDisplay.indexOf(rowNode) >= 0;\n };\n ClientSideRowModel.prototype.getRowIndexAtPixel = function (pixelToMatch) {\n if (this.isEmpty() || this.rowsToDisplay.length === 0) {\n return -1;\n }\n // do binary search of tree\n // http://oli.me.uk/2013/06/08/searching-javascript-arrays-with-a-binary-search/\n var bottomPointer = 0;\n var topPointer = this.rowsToDisplay.length - 1;\n // quick check, if the pixel is out of bounds, then return last row\n if (pixelToMatch <= 0) {\n // if pixel is less than or equal zero, it's always the first row\n return 0;\n }\n var lastNode = _.last(this.rowsToDisplay);\n if (lastNode.rowTop <= pixelToMatch) {\n return this.rowsToDisplay.length - 1;\n }\n var oldBottomPointer = -1;\n var oldTopPointer = -1;\n while (true) {\n var midPointer = Math.floor((bottomPointer + topPointer) / 2);\n var currentRowNode = this.rowsToDisplay[midPointer];\n if (this.isRowInPixel(currentRowNode, pixelToMatch)) {\n return midPointer;\n }\n if (currentRowNode.rowTop < pixelToMatch) {\n bottomPointer = midPointer + 1;\n }\n else if (currentRowNode.rowTop > pixelToMatch) {\n topPointer = midPointer - 1;\n }\n // infinite loops happen when there is space between rows. this can happen\n // when Auto Height is active, cos we re-calculate row tops asyncronously\n // when row heights change, which can temporarly result in gaps between rows.\n var caughtInInfiniteLoop = oldBottomPointer === bottomPointer\n && oldTopPointer === topPointer;\n if (caughtInInfiniteLoop) {\n return midPointer;\n }\n oldBottomPointer = bottomPointer;\n oldTopPointer = topPointer;\n }\n };\n ClientSideRowModel.prototype.isRowInPixel = function (rowNode, pixelToMatch) {\n var topPixel = rowNode.rowTop;\n var bottomPixel = rowNode.rowTop + rowNode.rowHeight;\n var pixelInRow = topPixel <= pixelToMatch && bottomPixel > pixelToMatch;\n return pixelInRow;\n };\n ClientSideRowModel.prototype.forEachLeafNode = function (callback) {\n if (this.rootNode.allLeafChildren) {\n this.rootNode.allLeafChildren.forEach(function (rowNode, index) { return callback(rowNode, index); });\n }\n };\n ClientSideRowModel.prototype.forEachNode = function (callback) {\n this.recursivelyWalkNodesAndCallback(this.rootNode.childrenAfterGroup, callback, RecursionType.Normal, 0);\n };\n ClientSideRowModel.prototype.forEachNodeAfterFilter = function (callback) {\n this.recursivelyWalkNodesAndCallback(this.rootNode.childrenAfterAggFilter, callback, RecursionType.AfterFilter, 0);\n };\n ClientSideRowModel.prototype.forEachNodeAfterFilterAndSort = function (callback) {\n this.recursivelyWalkNodesAndCallback(this.rootNode.childrenAfterSort, callback, RecursionType.AfterFilterAndSort, 0);\n };\n ClientSideRowModel.prototype.forEachPivotNode = function (callback) {\n this.recursivelyWalkNodesAndCallback([this.rootNode], callback, RecursionType.PivotNodes, 0);\n };\n // iterates through each item in memory, and calls the callback function\n // nodes - the rowNodes to traverse\n // callback - the user provided callback\n // recursion type - need this to know what child nodes to recurse, eg if looking at all nodes, or filtered notes etc\n // index - works similar to the index in forEach in javascript's array function\n ClientSideRowModel.prototype.recursivelyWalkNodesAndCallback = function (nodes, callback, recursionType, index) {\n if (!nodes) {\n return index;\n }\n for (var i = 0; i < nodes.length; i++) {\n var node = nodes[i];\n callback(node, index++);\n // go to the next level if it is a group\n if (node.hasChildren()) {\n // depending on the recursion type, we pick a difference set of children\n var nodeChildren = null;\n switch (recursionType) {\n case RecursionType.Normal:\n nodeChildren = node.childrenAfterGroup;\n break;\n case RecursionType.AfterFilter:\n nodeChildren = node.childrenAfterAggFilter;\n break;\n case RecursionType.AfterFilterAndSort:\n nodeChildren = node.childrenAfterSort;\n break;\n case RecursionType.PivotNodes:\n // for pivot, we don't go below leafGroup levels\n nodeChildren = !node.leafGroup ? node.childrenAfterSort : null;\n break;\n }\n if (nodeChildren) {\n index = this.recursivelyWalkNodesAndCallback(nodeChildren, callback, recursionType, index);\n }\n }\n }\n return index;\n };\n // it's possible to recompute the aggregate without doing the other parts\n // + gridApi.recomputeAggregates()\n ClientSideRowModel.prototype.doAggregate = function (changedPath) {\n if (this.aggregationStage) {\n this.aggregationStage.execute({ rowNode: this.rootNode, changedPath: changedPath });\n }\n };\n ClientSideRowModel.prototype.doFilterAggregates = function (changedPath) {\n if (this.filterAggregatesStage) {\n this.filterAggregatesStage.execute({ rowNode: this.rootNode, changedPath: changedPath });\n }\n else {\n // If filterAggregatesStage is undefined, then so is the grouping stage, so all children should be on the rootNode.\n this.rootNode.childrenAfterAggFilter = this.rootNode.childrenAfterFilter;\n }\n };\n // + gridApi.expandAll()\n // + gridApi.collapseAll()\n ClientSideRowModel.prototype.expandOrCollapseAll = function (expand) {\n var usingTreeData = this.gridOptionsWrapper.isTreeData();\n var usingPivotMode = this.columnModel.isPivotActive();\n var recursiveExpandOrCollapse = function (rowNodes) {\n if (!rowNodes) {\n return;\n }\n rowNodes.forEach(function (rowNode) {\n var actionRow = function () {\n rowNode.expanded = expand;\n recursiveExpandOrCollapse(rowNode.childrenAfterGroup);\n };\n if (usingTreeData) {\n var hasChildren = _.exists(rowNode.childrenAfterGroup);\n if (hasChildren) {\n actionRow();\n }\n return;\n }\n if (usingPivotMode) {\n var notLeafGroup = !rowNode.leafGroup;\n if (notLeafGroup) {\n actionRow();\n }\n return;\n }\n var isRowGroup = rowNode.group;\n if (isRowGroup) {\n actionRow();\n }\n });\n };\n if (this.rootNode) {\n recursiveExpandOrCollapse(this.rootNode.childrenAfterGroup);\n }\n this.refreshModel({ step: ClientSideRowModelSteps.MAP });\n var eventSource = expand ? 'expandAll' : 'collapseAll';\n var event = {\n type: Events.EVENT_EXPAND_COLLAPSE_ALL,\n source: eventSource\n };\n this.eventService.dispatchEvent(event);\n };\n ClientSideRowModel.prototype.doSort = function (rowNodeTransactions, changedPath) {\n this.sortStage.execute({\n rowNode: this.rootNode,\n rowNodeTransactions: rowNodeTransactions,\n changedPath: changedPath\n });\n };\n ClientSideRowModel.prototype.doRowGrouping = function (groupState, rowNodeTransactions, rowNodeOrder, changedPath, afterColumnsChanged) {\n if (this.groupStage) {\n if (rowNodeTransactions) {\n this.groupStage.execute({\n rowNode: this.rootNode,\n rowNodeTransactions: rowNodeTransactions,\n rowNodeOrder: rowNodeOrder,\n changedPath: changedPath\n });\n }\n else {\n this.groupStage.execute({\n rowNode: this.rootNode,\n changedPath: changedPath,\n afterColumnsChanged: afterColumnsChanged\n });\n // set open/closed state on groups\n this.restoreGroupState(groupState);\n }\n if (this.gridOptionsWrapper.isGroupSelectsChildren()) {\n this.selectionService.updateGroupsFromChildrenSelections(changedPath);\n }\n }\n else {\n this.rootNode.childrenAfterGroup = this.rootNode.allLeafChildren;\n if (this.rootNode.sibling) {\n this.rootNode.sibling.childrenAfterGroup = this.rootNode.childrenAfterGroup;\n }\n this.rootNode.updateHasChildren();\n }\n };\n ClientSideRowModel.prototype.restoreGroupState = function (groupState) {\n if (!groupState) {\n return;\n }\n _.traverseNodesWithKey(this.rootNode.childrenAfterGroup, function (node, key) {\n // if the group was open last time, then open it this time. however\n // if was not open last time, then don't touch the group, so the 'groupDefaultExpanded'\n // setting will take effect.\n if (typeof groupState[key] === 'boolean') {\n node.expanded = groupState[key];\n }\n });\n };\n ClientSideRowModel.prototype.doFilter = function (changedPath) {\n this.filterStage.execute({ rowNode: this.rootNode, changedPath: changedPath });\n };\n ClientSideRowModel.prototype.doPivot = function (changedPath) {\n if (this.pivotStage) {\n this.pivotStage.execute({ rowNode: this.rootNode, changedPath: changedPath });\n }\n };\n ClientSideRowModel.prototype.getGroupState = function () {\n if (!this.rootNode.childrenAfterGroup || !this.gridOptionsWrapper.isRememberGroupStateWhenNewData()) {\n return null;\n }\n var result = {};\n _.traverseNodesWithKey(this.rootNode.childrenAfterGroup, function (node, key) { return result[key] = node.expanded; });\n return result;\n };\n ClientSideRowModel.prototype.getCopyOfNodesMap = function () {\n return this.nodeManager.getCopyOfNodesMap();\n };\n ClientSideRowModel.prototype.getRowNode = function (id) {\n // although id is typed a string, this could be called by the user, and they could have passed a number\n var idIsGroup = typeof id == 'string' && id.indexOf(RowNode.ID_PREFIX_ROW_GROUP) == 0;\n if (idIsGroup) {\n // only one users complained about getRowNode not working for groups, after years of\n // this working for normal rows. so have done quick implementation. if users complain\n // about performance, then GroupStage should store / manage created groups in a map,\n // which is a chunk of work.\n var res_1 = undefined;\n this.forEachNode(function (node) {\n if (node.id === id) {\n res_1 = node;\n }\n });\n return res_1;\n }\n return this.nodeManager.getRowNode(id);\n };\n // rows: the rows to put into the model\n ClientSideRowModel.prototype.setRowData = function (rowData) {\n // no need to invalidate cache, as the cache is stored on the rowNode,\n // so new rowNodes means the cache is wiped anyway.\n // remember group state, so we can expand groups that should be expanded\n var groupState = this.getGroupState();\n this.nodeManager.setRowData(rowData);\n // - clears selection\n this.selectionService.reset();\n // - updates filters\n this.filterManager.onNewRowsLoaded('rowDataUpdated');\n // this event kicks off:\n // - shows 'no rows' overlay if needed\n var rowDataUpdatedEvent = {\n type: Events.EVENT_ROW_DATA_UPDATED\n };\n this.eventService.dispatchEvent(rowDataUpdatedEvent);\n this.refreshModel({\n step: ClientSideRowModelSteps.EVERYTHING,\n groupState: groupState,\n newData: true\n });\n };\n ClientSideRowModel.prototype.batchUpdateRowData = function (rowDataTransaction, callback) {\n var _this = this;\n if (this.applyAsyncTransactionsTimeout == null) {\n this.rowDataTransactionBatch = [];\n var waitMillis = this.gridOptionsWrapper.getAsyncTransactionWaitMillis();\n this.applyAsyncTransactionsTimeout = window.setTimeout(function () {\n _this.executeBatchUpdateRowData();\n }, waitMillis);\n }\n this.rowDataTransactionBatch.push({ rowDataTransaction: rowDataTransaction, callback: callback });\n };\n ClientSideRowModel.prototype.flushAsyncTransactions = function () {\n if (this.applyAsyncTransactionsTimeout != null) {\n clearTimeout(this.applyAsyncTransactionsTimeout);\n this.executeBatchUpdateRowData();\n }\n };\n ClientSideRowModel.prototype.executeBatchUpdateRowData = function () {\n var _this = this;\n this.valueCache.onDataChanged();\n var callbackFuncsBound = [];\n var rowNodeTrans = [];\n // The rowGroup stage uses rowNodeOrder if order was provided. if we didn't pass 'true' to\n // commonUpdateRowData, using addIndex would have no effect when grouping.\n var forceRowNodeOrder = false;\n if (this.rowDataTransactionBatch) {\n this.rowDataTransactionBatch.forEach(function (tranItem) {\n var rowNodeTran = _this.nodeManager.updateRowData(tranItem.rowDataTransaction, undefined);\n rowNodeTrans.push(rowNodeTran);\n if (tranItem.callback) {\n callbackFuncsBound.push(tranItem.callback.bind(null, rowNodeTran));\n }\n if (typeof tranItem.rowDataTransaction.addIndex === 'number') {\n forceRowNodeOrder = true;\n }\n });\n }\n this.commonUpdateRowData(rowNodeTrans, undefined, forceRowNodeOrder);\n // do callbacks in next VM turn so it's async\n if (callbackFuncsBound.length > 0) {\n window.setTimeout(function () {\n callbackFuncsBound.forEach(function (func) { return func(); });\n }, 0);\n }\n if (rowNodeTrans.length > 0) {\n var event_1 = {\n type: Events.EVENT_ASYNC_TRANSACTIONS_FLUSHED,\n results: rowNodeTrans\n };\n this.eventService.dispatchEvent(event_1);\n }\n this.rowDataTransactionBatch = null;\n this.applyAsyncTransactionsTimeout = undefined;\n };\n ClientSideRowModel.prototype.updateRowData = function (rowDataTran, rowNodeOrder) {\n this.valueCache.onDataChanged();\n var rowNodeTran = this.nodeManager.updateRowData(rowDataTran, rowNodeOrder);\n // if doing immutableData, addIndex is never present. however if doing standard transaction, and user\n // provided addIndex, then this is used in updateRowData. However if doing Enterprise, then the rowGroup\n // stage also uses the\n var forceRowNodeOrder = typeof rowDataTran.addIndex === 'number';\n this.commonUpdateRowData([rowNodeTran], rowNodeOrder, forceRowNodeOrder);\n return rowNodeTran;\n };\n ClientSideRowModel.prototype.createRowNodeOrder = function () {\n var suppressSortOrder = this.gridOptionsWrapper.isSuppressMaintainUnsortedOrder();\n if (suppressSortOrder) {\n return;\n }\n var orderMap = {};\n if (this.rootNode && this.rootNode.allLeafChildren) {\n for (var index = 0; index < this.rootNode.allLeafChildren.length; index++) {\n var node = this.rootNode.allLeafChildren[index];\n orderMap[node.id] = index;\n }\n }\n return orderMap;\n };\n // common to updateRowData and batchUpdateRowData\n ClientSideRowModel.prototype.commonUpdateRowData = function (rowNodeTrans, rowNodeOrder, forceRowNodeOrder) {\n var animate = !this.gridOptionsWrapper.isSuppressAnimationFrame();\n if (forceRowNodeOrder) {\n rowNodeOrder = this.createRowNodeOrder();\n }\n this.refreshModel({\n step: ClientSideRowModelSteps.EVERYTHING,\n rowNodeTransactions: rowNodeTrans,\n rowNodeOrder: rowNodeOrder,\n keepRenderedRows: true,\n keepEditingRows: true,\n animate: animate\n });\n // - updates filters\n this.filterManager.onNewRowsLoaded('rowDataUpdated');\n var event = {\n type: Events.EVENT_ROW_DATA_UPDATED\n };\n this.eventService.dispatchEvent(event);\n };\n ClientSideRowModel.prototype.doRowsToDisplay = function () {\n this.rowsToDisplay = this.flattenStage.execute({ rowNode: this.rootNode });\n };\n ClientSideRowModel.prototype.onRowHeightChanged = function () {\n this.refreshModel({ step: ClientSideRowModelSteps.MAP, keepRenderedRows: true, keepEditingRows: true, keepUndoRedoStack: true });\n };\n ClientSideRowModel.prototype.resetRowHeights = function () {\n var atLeastOne = false;\n this.forEachNode(function (rowNode) {\n rowNode.setRowHeight(rowNode.rowHeight, true);\n // we keep the height each row is at, however we set estimated=true rather than clear the height.\n // this means the grid will not reset the row heights back to defaults, rather it will re-calc\n // the height for each row as the row is displayed. otherwise the scroll will jump when heights are reset.\n var detailNode = rowNode.detailNode;\n if (detailNode) {\n detailNode.setRowHeight(detailNode.rowHeight, true);\n }\n atLeastOne = true;\n });\n if (atLeastOne) {\n this.onRowHeightChanged();\n }\n };\n __decorate([\n Autowired('columnModel')\n ], ClientSideRowModel.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('selectionService')\n ], ClientSideRowModel.prototype, \"selectionService\", void 0);\n __decorate([\n Autowired('filterManager')\n ], ClientSideRowModel.prototype, \"filterManager\", void 0);\n __decorate([\n Autowired('valueCache')\n ], ClientSideRowModel.prototype, \"valueCache\", void 0);\n __decorate([\n Autowired('beans')\n ], ClientSideRowModel.prototype, \"beans\", void 0);\n __decorate([\n Autowired('filterStage')\n ], ClientSideRowModel.prototype, \"filterStage\", void 0);\n __decorate([\n Autowired('sortStage')\n ], ClientSideRowModel.prototype, \"sortStage\", void 0);\n __decorate([\n Autowired('flattenStage')\n ], ClientSideRowModel.prototype, \"flattenStage\", void 0);\n __decorate([\n Optional('groupStage')\n ], ClientSideRowModel.prototype, \"groupStage\", void 0);\n __decorate([\n Optional('aggregationStage')\n ], ClientSideRowModel.prototype, \"aggregationStage\", void 0);\n __decorate([\n Optional('pivotStage')\n ], ClientSideRowModel.prototype, \"pivotStage\", void 0);\n __decorate([\n Optional('filterAggregatesStage')\n ], ClientSideRowModel.prototype, \"filterAggregatesStage\", void 0);\n __decorate([\n PostConstruct\n ], ClientSideRowModel.prototype, \"init\", null);\n ClientSideRowModel = __decorate([\n Bean('rowModel')\n ], ClientSideRowModel);\n return ClientSideRowModel;\n}(BeanStub));\nexport { ClientSideRowModel };\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, BeanStub } from \"@ag-grid-community/core\";\nvar FilterStage = /** @class */ (function (_super) {\n __extends(FilterStage, _super);\n function FilterStage() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n FilterStage.prototype.execute = function (params) {\n var changedPath = params.changedPath;\n this.filterService.filter(changedPath);\n };\n __decorate([\n Autowired('filterService')\n ], FilterStage.prototype, \"filterService\", void 0);\n FilterStage = __decorate([\n Bean('filterStage')\n ], FilterStage);\n return FilterStage;\n}(BeanStub));\nexport { FilterStage };\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { _, Autowired, Bean, BeanStub } from \"@ag-grid-community/core\";\nvar SortStage = /** @class */ (function (_super) {\n __extends(SortStage, _super);\n function SortStage() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n SortStage.prototype.execute = function (params) {\n var _this = this;\n var sortOptions = this.sortController.getSortOptions();\n var sortActive = _.exists(sortOptions) && sortOptions.length > 0;\n var deltaSort = sortActive\n && _.exists(params.rowNodeTransactions)\n // in time we can remove this check, so that delta sort is always\n // on if transactions are present. it's off for now so that we can\n // selectively turn it on and test it with some select users before\n // rolling out to everyone.\n && this.gridOptionsWrapper.isDeltaSort();\n var sortContainsGroupColumns = sortOptions.some(function (opt) { return !!_this.columnModel.getGroupDisplayColumnForGroup(opt.column.getId()); });\n this.sortService.sort(sortOptions, sortActive, deltaSort, params.rowNodeTransactions, params.changedPath, sortContainsGroupColumns);\n };\n __decorate([\n Autowired('sortService')\n ], SortStage.prototype, \"sortService\", void 0);\n __decorate([\n Autowired('sortController')\n ], SortStage.prototype, \"sortController\", void 0);\n __decorate([\n Autowired('columnModel')\n ], SortStage.prototype, \"columnModel\", void 0);\n SortStage = __decorate([\n Bean('sortStage')\n ], SortStage);\n return SortStage;\n}(BeanStub));\nexport { SortStage };\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { _, Autowired, Bean, BeanStub, RowNode } from \"@ag-grid-community/core\";\nvar FlattenStage = /** @class */ (function (_super) {\n __extends(FlattenStage, _super);\n function FlattenStage() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n FlattenStage.prototype.execute = function (params) {\n var rootNode = params.rowNode;\n // even if not doing grouping, we do the mapping, as the client might\n // of passed in data that already has a grouping in it somewhere\n var result = [];\n // putting value into a wrapper so it's passed by reference\n var nextRowTop = { value: 0 };\n var skipLeafNodes = this.columnModel.isPivotMode();\n // if we are reducing, and not grouping, then we want to show the root node, as that\n // is where the pivot values are\n var showRootNode = skipLeafNodes && rootNode.leafGroup;\n var topList = showRootNode ? [rootNode] : rootNode.childrenAfterSort;\n this.recursivelyAddToRowsToDisplay(topList, result, nextRowTop, skipLeafNodes, 0);\n // we do not want the footer total if the gris is empty\n var atLeastOneRowPresent = result.length > 0;\n var includeGroupTotalFooter = !showRootNode\n // don't show total footer when showRootNode is true (i.e. in pivot mode and no groups)\n && atLeastOneRowPresent\n && this.gridOptionsWrapper.isGroupIncludeTotalFooter();\n if (includeGroupTotalFooter) {\n this.ensureFooterNodeExists(rootNode);\n this.addRowNodeToRowsToDisplay(rootNode.sibling, result, nextRowTop, 0);\n }\n return result;\n };\n FlattenStage.prototype.recursivelyAddToRowsToDisplay = function (rowsToFlatten, result, nextRowTop, skipLeafNodes, uiLevel) {\n if (_.missingOrEmpty(rowsToFlatten)) {\n return;\n }\n var hideOpenParents = this.gridOptionsWrapper.isGroupHideOpenParents();\n // these two are mutually exclusive, so if first set, we don't set the second\n var groupRemoveSingleChildren = this.gridOptionsWrapper.isGroupRemoveSingleChildren();\n var groupRemoveLowestSingleChildren = !groupRemoveSingleChildren && this.gridOptionsWrapper.isGroupRemoveLowestSingleChildren();\n for (var i = 0; i < rowsToFlatten.length; i++) {\n var rowNode = rowsToFlatten[i];\n // check all these cases, for working out if this row should be included in the final mapped list\n var isParent = rowNode.hasChildren();\n var isSkippedLeafNode = skipLeafNodes && !isParent;\n var isRemovedSingleChildrenGroup = groupRemoveSingleChildren &&\n isParent &&\n rowNode.childrenAfterGroup.length === 1;\n var isRemovedLowestSingleChildrenGroup = groupRemoveLowestSingleChildren &&\n isParent &&\n rowNode.leafGroup &&\n rowNode.childrenAfterGroup.length === 1;\n // hide open parents means when group is open, we don't show it. we also need to make sure the\n // group is expandable in the first place (as leaf groups are not expandable if pivot mode is on).\n // the UI will never allow expanding leaf groups, however the user might via the API (or menu option 'expand all')\n var neverAllowToExpand = skipLeafNodes && rowNode.leafGroup;\n var isHiddenOpenParent = hideOpenParents && rowNode.expanded && !rowNode.master && (!neverAllowToExpand);\n var thisRowShouldBeRendered = !isSkippedLeafNode && !isHiddenOpenParent &&\n !isRemovedSingleChildrenGroup && !isRemovedLowestSingleChildrenGroup;\n if (thisRowShouldBeRendered) {\n this.addRowNodeToRowsToDisplay(rowNode, result, nextRowTop, uiLevel);\n }\n // if we are pivoting, we never map below the leaf group\n if (skipLeafNodes && rowNode.leafGroup) {\n continue;\n }\n if (isParent) {\n var excludedParent = isRemovedSingleChildrenGroup || isRemovedLowestSingleChildrenGroup;\n // we traverse the group if it is expended, however we always traverse if the parent node\n // was removed (as the group will never be opened if it is not displayed, we show the children instead)\n if (rowNode.expanded || excludedParent) {\n // if the parent was excluded, then ui level is that of the parent\n var uiLevelForChildren = excludedParent ? uiLevel : uiLevel + 1;\n this.recursivelyAddToRowsToDisplay(rowNode.childrenAfterSort, result, nextRowTop, skipLeafNodes, uiLevelForChildren);\n // put a footer in if user is looking for it\n if (this.gridOptionsWrapper.isGroupIncludeFooter()) {\n this.ensureFooterNodeExists(rowNode);\n this.addRowNodeToRowsToDisplay(rowNode.sibling, result, nextRowTop, uiLevel);\n }\n }\n }\n else if (rowNode.master && rowNode.expanded) {\n var detailNode = this.createDetailNode(rowNode);\n this.addRowNodeToRowsToDisplay(detailNode, result, nextRowTop, uiLevel);\n }\n }\n };\n // duplicated method, it's also in floatingRowModel\n FlattenStage.prototype.addRowNodeToRowsToDisplay = function (rowNode, result, nextRowTop, uiLevel) {\n var isGroupMultiAutoColumn = this.gridOptionsWrapper.isGroupMultiAutoColumn();\n result.push(rowNode);\n rowNode.setUiLevel(isGroupMultiAutoColumn ? 0 : uiLevel);\n };\n FlattenStage.prototype.ensureFooterNodeExists = function (groupNode) {\n // only create footer node once, otherwise we have daemons and\n // the animate screws up with the daemons hanging around\n if (_.exists(groupNode.sibling)) {\n return;\n }\n var footerNode = new RowNode(this.beans);\n Object.keys(groupNode).forEach(function (key) {\n footerNode[key] = groupNode[key];\n });\n footerNode.footer = true;\n footerNode.setRowTop(null);\n footerNode.setRowIndex(null);\n // manually set oldRowTop to null so we discard any\n // previous information about its position.\n footerNode.oldRowTop = null;\n if (_.exists(footerNode.id)) {\n footerNode.id = 'rowGroupFooter_' + footerNode.id;\n }\n // get both header and footer to reference each other as siblings. this is never undone,\n // only overwritten. so if a group is expanded, then contracted, it will have a ghost\n // sibling - but that's fine, as we can ignore this if the header is contracted.\n footerNode.sibling = groupNode;\n groupNode.sibling = footerNode;\n };\n FlattenStage.prototype.createDetailNode = function (masterNode) {\n if (_.exists(masterNode.detailNode)) {\n return masterNode.detailNode;\n }\n var detailNode = new RowNode(this.beans);\n detailNode.detail = true;\n detailNode.selectable = false;\n detailNode.parent = masterNode;\n if (_.exists(masterNode.id)) {\n detailNode.id = 'detail_' + masterNode.id;\n }\n detailNode.data = masterNode.data;\n detailNode.level = masterNode.level + 1;\n masterNode.detailNode = detailNode;\n return detailNode;\n };\n __decorate([\n Autowired('columnModel')\n ], FlattenStage.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('beans')\n ], FlattenStage.prototype, \"beans\", void 0);\n FlattenStage = __decorate([\n Bean('flattenStage')\n ], FlattenStage);\n return FlattenStage;\n}(BeanStub));\nexport { FlattenStage };\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { _, Autowired, Bean, PostConstruct, BeanStub } from \"@ag-grid-community/core\";\nvar SortService = /** @class */ (function (_super) {\n __extends(SortService, _super);\n function SortService() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n SortService.prototype.init = function () {\n this.postSortFunc = this.gridOptionsWrapper.getPostSortFunc();\n };\n SortService.prototype.sort = function (sortOptions, sortActive, useDeltaSort, rowNodeTransactions, changedPath, sortContainsGroupColumns) {\n var _this = this;\n var groupMaintainOrder = this.gridOptionsWrapper.isGroupMaintainOrder();\n var groupColumnsPresent = this.columnModel.getAllGridColumns().some(function (c) { return c.isRowGroupActive(); });\n var allDirtyNodes = {};\n if (useDeltaSort && rowNodeTransactions) {\n allDirtyNodes = this.calculateDirtyNodes(rowNodeTransactions);\n }\n var isPivotMode = this.columnModel.isPivotMode();\n var callback = function (rowNode) {\n // we clear out the 'pull down open parents' first, as the values mix up the sorting\n _this.pullDownGroupDataForHideOpenParents(rowNode.childrenAfterAggFilter, true);\n // It's pointless to sort rows which aren't being displayed. in pivot mode we don't need to sort the leaf group children.\n var skipSortingPivotLeafs = isPivotMode && rowNode.leafGroup;\n // Javascript sort is non deterministic when all the array items are equals, ie Comparator always returns 0,\n // so to ensure the array keeps its order, add an additional sorting condition manually, in this case we\n // are going to inspect the original array position. This is what sortedRowNodes is for.\n var skipSortingGroups = groupMaintainOrder && groupColumnsPresent && !rowNode.leafGroup && !sortContainsGroupColumns;\n if (!sortActive || skipSortingGroups || skipSortingPivotLeafs) {\n // when 'groupMaintainOrder' is enabled we skip sorting groups unless we are sorting on group columns\n var childrenToBeSorted = rowNode.childrenAfterAggFilter.slice(0);\n if (groupMaintainOrder && rowNode.childrenAfterSort) {\n var indexedOrders_1 = rowNode.childrenAfterSort.reduce(function (acc, row, idx) {\n acc[row.id] = idx;\n return acc;\n }, {});\n childrenToBeSorted.sort(function (row1, row2) { return (indexedOrders_1[row1.id] || 0) - (indexedOrders_1[row2.id] || 0); });\n }\n rowNode.childrenAfterSort = childrenToBeSorted;\n }\n else if (useDeltaSort) {\n rowNode.childrenAfterSort = _this.doDeltaSort(rowNode, allDirtyNodes, changedPath, sortOptions);\n }\n else {\n rowNode.childrenAfterSort = _this.rowNodeSorter.doFullSort(rowNode.childrenAfterAggFilter, sortOptions);\n }\n if (rowNode.sibling) {\n rowNode.sibling.childrenAfterSort = rowNode.childrenAfterSort;\n }\n _this.updateChildIndexes(rowNode);\n if (_this.postSortFunc) {\n var params = { nodes: rowNode.childrenAfterSort };\n _this.postSortFunc(params);\n }\n };\n if (changedPath) {\n changedPath.forEachChangedNodeDepthFirst(callback);\n }\n this.updateGroupDataForHideOpenParents(changedPath);\n };\n SortService.prototype.calculateDirtyNodes = function (rowNodeTransactions) {\n var dirtyNodes = {};\n var addNodesFunc = function (rowNodes) {\n if (rowNodes) {\n rowNodes.forEach(function (rowNode) { return dirtyNodes[rowNode.id] = true; });\n }\n };\n // all leaf level nodes in the transaction were impacted\n if (rowNodeTransactions) {\n rowNodeTransactions.forEach(function (tran) {\n addNodesFunc(tran.add);\n addNodesFunc(tran.update);\n addNodesFunc(tran.remove);\n });\n }\n return dirtyNodes;\n };\n SortService.prototype.doDeltaSort = function (rowNode, allTouchedNodes, changedPath, sortOptions) {\n var _this = this;\n var unsortedRows = rowNode.childrenAfterAggFilter;\n var oldSortedRows = rowNode.childrenAfterSort;\n if (!oldSortedRows) {\n return this.rowNodeSorter.doFullSort(unsortedRows, sortOptions);\n }\n var untouchedRowsMap = {};\n var touchedRows = [];\n unsortedRows.forEach(function (row) {\n if (allTouchedNodes[row.id] || !changedPath.canSkip(row)) {\n touchedRows.push(row);\n }\n else {\n untouchedRowsMap[row.id] = true;\n }\n });\n var sortedUntouchedRows = oldSortedRows.filter(function (child) { return untouchedRowsMap[child.id]; });\n var mapNodeToSortedNode = function (rowNode, pos) { return ({ currentPos: pos, rowNode: rowNode }); };\n var sortedChangedRows = touchedRows\n .map(mapNodeToSortedNode)\n .sort(function (a, b) { return _this.rowNodeSorter.compareRowNodes(sortOptions, a, b); });\n return this.mergeSortedArrays(sortOptions, sortedChangedRows, sortedUntouchedRows.map(mapNodeToSortedNode)).map(function (_a) {\n var rowNode = _a.rowNode;\n return rowNode;\n });\n };\n // Merge two sorted arrays into each other\n SortService.prototype.mergeSortedArrays = function (sortOptions, arr1, arr2) {\n var res = [];\n var i = 0;\n var j = 0;\n // Traverse both array, adding them in order\n while (i < arr1.length && j < arr2.length) {\n // Check if current element of first\n // array is smaller than current element\n // of second array. If yes, store first\n // array element and increment first array\n // index. Otherwise do same with second array\n var compareResult = this.rowNodeSorter.compareRowNodes(sortOptions, arr1[i], arr2[j]);\n if (compareResult < 0) {\n res.push(arr1[i++]);\n }\n else {\n res.push(arr2[j++]);\n }\n }\n // add remaining from arr1\n while (i < arr1.length) {\n res.push(arr1[i++]);\n }\n // add remaining from arr2\n while (j < arr2.length) {\n res.push(arr2[j++]);\n }\n return res;\n };\n SortService.prototype.updateChildIndexes = function (rowNode) {\n if (_.missing(rowNode.childrenAfterSort)) {\n return;\n }\n var listToSort = rowNode.childrenAfterSort;\n for (var i = 0; i < listToSort.length; i++) {\n var child = listToSort[i];\n var firstChild = i === 0;\n var lastChild = i === rowNode.childrenAfterSort.length - 1;\n child.setFirstChild(firstChild);\n child.setLastChild(lastChild);\n child.setChildIndex(i);\n }\n };\n SortService.prototype.updateGroupDataForHideOpenParents = function (changedPath) {\n var _this = this;\n if (!this.gridOptionsWrapper.isGroupHideOpenParents()) {\n return;\n }\n if (this.gridOptionsWrapper.isTreeData()) {\n var msg_1 = \"AG Grid: The property hideOpenParents dose not work with Tree Data. This is because Tree Data has values at the group level, it doesn't make sense to hide them (as opposed to Row Grouping, which only has Aggregated Values at the group level).\";\n _.doOnce(function () { return console.warn(msg_1); }, 'sortService.hideOpenParentsWithTreeData');\n return false;\n }\n // recurse breadth first over group nodes after sort to 'pull down' group data to child groups\n var callback = function (rowNode) {\n _this.pullDownGroupDataForHideOpenParents(rowNode.childrenAfterSort, false);\n rowNode.childrenAfterSort.forEach(function (child) {\n if (child.hasChildren()) {\n callback(child);\n }\n });\n };\n if (changedPath) {\n changedPath.executeFromRootNode(function (rowNode) { return callback(rowNode); });\n }\n };\n SortService.prototype.pullDownGroupDataForHideOpenParents = function (rowNodes, clearOperation) {\n var _this = this;\n if (!this.gridOptionsWrapper.isGroupHideOpenParents() || _.missing(rowNodes)) {\n return;\n }\n rowNodes.forEach(function (childRowNode) {\n var groupDisplayCols = _this.columnModel.getGroupDisplayColumns();\n groupDisplayCols.forEach(function (groupDisplayCol) {\n var showRowGroup = groupDisplayCol.getColDef().showRowGroup;\n if (typeof showRowGroup !== 'string') {\n console.error('AG Grid: groupHideOpenParents only works when specifying specific columns for colDef.showRowGroup');\n return;\n }\n var displayingGroupKey = showRowGroup;\n var rowGroupColumn = _this.columnModel.getPrimaryColumn(displayingGroupKey);\n var thisRowNodeMatches = rowGroupColumn === childRowNode.rowGroupColumn;\n if (thisRowNodeMatches) {\n return;\n }\n if (clearOperation) {\n // if doing a clear operation, we clear down the value for every possible group column\n childRowNode.setGroupValue(groupDisplayCol.getId(), undefined);\n }\n else {\n // if doing a set operation, we set only where the pull down is to occur\n var parentToStealFrom = childRowNode.getFirstChildOfFirstChild(rowGroupColumn);\n if (parentToStealFrom) {\n childRowNode.setGroupValue(groupDisplayCol.getId(), parentToStealFrom.key);\n }\n }\n });\n });\n };\n __decorate([\n Autowired('columnModel')\n ], SortService.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('rowNodeSorter')\n ], SortService.prototype, \"rowNodeSorter\", void 0);\n __decorate([\n PostConstruct\n ], SortService.prototype, \"init\", null);\n SortService = __decorate([\n Bean('sortService')\n ], SortService);\n return SortService;\n}(BeanStub));\nexport { SortService };\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, BeanStub } from \"@ag-grid-community/core\";\nvar FilterService = /** @class */ (function (_super) {\n __extends(FilterService, _super);\n function FilterService() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n FilterService.prototype.filter = function (changedPath) {\n var filterActive = this.filterManager.isColumnFilterPresent()\n || this.filterManager.isQuickFilterPresent()\n || this.filterManager.isExternalFilterPresent();\n this.filterNodes(filterActive, changedPath);\n };\n FilterService.prototype.filterNodes = function (filterActive, changedPath) {\n var _this = this;\n var filterCallback = function (rowNode, includeChildNodes) {\n // recursively get all children that are groups to also filter\n if (rowNode.hasChildren()) {\n // result of filter for this node. when filtering tree data, includeChildNodes = true when parent passes\n if (filterActive && !includeChildNodes) {\n rowNode.childrenAfterFilter = rowNode.childrenAfterGroup.filter(function (childNode) {\n // a group is included in the result if it has any children of it's own.\n // by this stage, the child groups are already filtered\n var passBecauseChildren = childNode.childrenAfterFilter && childNode.childrenAfterFilter.length > 0;\n // both leaf level nodes and tree data nodes have data. these get added if\n // the data passes the filter\n var passBecauseDataPasses = childNode.data\n && _this.filterManager.doesRowPassFilter({ rowNode: childNode });\n // note - tree data nodes pass either if a) they pass themselves or b) any children of that node pass\n return passBecauseChildren || passBecauseDataPasses;\n });\n }\n else {\n // if not filtering, the result is the original list\n rowNode.childrenAfterFilter = rowNode.childrenAfterGroup;\n }\n }\n else {\n rowNode.childrenAfterFilter = rowNode.childrenAfterGroup;\n }\n if (rowNode.sibling) {\n rowNode.sibling.childrenAfterFilter = rowNode.childrenAfterFilter;\n }\n };\n if (this.doingTreeDataFiltering()) {\n var treeDataDepthFirstFilter_1 = function (rowNode, alreadyFoundInParent) {\n // tree data filter traverses the hierarchy depth first and includes child nodes if parent passes\n // filter, and parent nodes will be include if any children exist.\n if (rowNode.childrenAfterGroup) {\n for (var i = 0; i < rowNode.childrenAfterGroup.length; i++) {\n var childNode = rowNode.childrenAfterGroup[i];\n // first check if current node passes filter before invoking child nodes\n var foundInParent = alreadyFoundInParent\n || _this.filterManager.doesRowPassFilter({ rowNode: childNode });\n if (childNode.childrenAfterGroup) {\n treeDataDepthFirstFilter_1(rowNode.childrenAfterGroup[i], foundInParent);\n }\n else {\n filterCallback(childNode, foundInParent);\n }\n }\n }\n filterCallback(rowNode, alreadyFoundInParent);\n };\n var treeDataFilterCallback = function (rowNode) { return treeDataDepthFirstFilter_1(rowNode, false); };\n changedPath.executeFromRootNode(treeDataFilterCallback);\n }\n else {\n var defaultFilterCallback = function (rowNode) { return filterCallback(rowNode, false); };\n changedPath.forEachChangedNodeDepthFirst(defaultFilterCallback, true);\n }\n };\n FilterService.prototype.doingTreeDataFiltering = function () {\n return this.gridOptionsWrapper.isTreeData() && !this.gridOptionsWrapper.isExcludeChildrenWhenTreeDataFiltering();\n };\n __decorate([\n Autowired('filterManager')\n ], FilterService.prototype, \"filterManager\", void 0);\n FilterService = __decorate([\n Bean(\"filterService\")\n ], FilterService);\n return FilterService;\n}(BeanStub));\nexport { FilterService };\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nimport { Autowired, Bean, BeanStub, Constants, PostConstruct, _ } from \"@ag-grid-community/core\";\nvar ImmutableService = /** @class */ (function (_super) {\n __extends(ImmutableService, _super);\n function ImmutableService() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n ImmutableService.prototype.postConstruct = function () {\n if (this.rowModel.getType() === Constants.ROW_MODEL_TYPE_CLIENT_SIDE) {\n this.clientSideRowModel = this.rowModel;\n }\n };\n ImmutableService.prototype.isActive = function () {\n return this.gridOptionsWrapper.isImmutableData();\n };\n ImmutableService.prototype.setRowData = function (rowData) {\n var transactionAndMap = this.createTransactionForRowData(rowData);\n if (!transactionAndMap) {\n return;\n }\n var _a = __read(transactionAndMap, 2), transaction = _a[0], orderIdMap = _a[1];\n var nodeTransaction = this.clientSideRowModel.updateRowData(transaction, orderIdMap);\n // need to force updating of full width rows - note this wouldn't be necessary the full width cell comp listened\n // to the data change event on the row node and refreshed itself.\n if (nodeTransaction) {\n this.rowRenderer.refreshFullWidthRows(nodeTransaction.update);\n }\n };\n // converts the setRowData() command to a transaction\n ImmutableService.prototype.createTransactionForRowData = function (rowData) {\n if (_.missing(this.clientSideRowModel)) {\n console.error('AG Grid: ImmutableService only works with ClientSideRowModel');\n return;\n }\n var getRowIdFunc = this.gridOptionsWrapper.getRowIdFunc();\n if (getRowIdFunc == null) {\n console.error('AG Grid: ImmutableService requires getRowId() callback to be implemented, your row data needs IDs!');\n return;\n }\n // convert the data into a transaction object by working out adds, removes and updates\n var transaction = {\n remove: [],\n update: [],\n add: []\n };\n var existingNodesMap = this.clientSideRowModel.getCopyOfNodesMap();\n var suppressSortOrder = this.gridOptionsWrapper.isSuppressMaintainUnsortedOrder();\n var orderMap = suppressSortOrder ? undefined : {};\n if (_.exists(rowData)) {\n // split all the new data in the following:\n // if new, push to 'add'\n // if update, push to 'update'\n // if not changed, do not include in the transaction\n rowData.forEach(function (data, index) {\n var id = getRowIdFunc({ data: data, level: 0 });\n var existingNode = existingNodesMap[id];\n if (orderMap) {\n orderMap[id] = index;\n }\n if (existingNode) {\n var dataHasChanged = existingNode.data !== data;\n if (dataHasChanged) {\n transaction.update.push(data);\n }\n // otherwise, if data not changed, we just don't include it anywhere, as it's not a delta\n // remove from list, so we know the item is not to be removed\n existingNodesMap[id] = undefined;\n }\n else {\n transaction.add.push(data);\n }\n });\n }\n // at this point, all rows that are left, should be removed\n _.iterateObject(existingNodesMap, function (id, rowNode) {\n if (rowNode) {\n transaction.remove.push(rowNode.data);\n }\n });\n return [transaction, orderMap];\n };\n __decorate([\n Autowired('rowModel')\n ], ImmutableService.prototype, \"rowModel\", void 0);\n __decorate([\n Autowired('rowRenderer')\n ], ImmutableService.prototype, \"rowRenderer\", void 0);\n __decorate([\n Autowired('columnApi')\n ], ImmutableService.prototype, \"columnApi\", void 0);\n __decorate([\n Autowired('gridApi')\n ], ImmutableService.prototype, \"gridApi\", void 0);\n __decorate([\n Autowired('filterManager')\n ], ImmutableService.prototype, \"filterManager\", void 0);\n __decorate([\n PostConstruct\n ], ImmutableService.prototype, \"postConstruct\", null);\n ImmutableService = __decorate([\n Bean('immutableService')\n ], ImmutableService);\n return ImmutableService;\n}(BeanStub));\nexport { ImmutableService };\n","import { ModuleNames } from \"@ag-grid-community/core\";\nimport { ClientSideRowModel } from \"./clientSideRowModel/clientSideRowModel\";\nimport { FilterStage } from \"./clientSideRowModel/filterStage\";\nimport { SortStage } from \"./clientSideRowModel/sortStage\";\nimport { FlattenStage } from \"./clientSideRowModel/flattenStage\";\nimport { SortService } from \"./clientSideRowModel/sortService\";\nimport { FilterService } from \"./clientSideRowModel/filterService\";\nimport { ImmutableService } from \"./clientSideRowModel/immutableService\";\nexport var ClientSideRowModelModule = {\n moduleName: ModuleNames.ClientSideRowModelModule,\n beans: [FilterStage, SortStage, FlattenStage, SortService, FilterService, ImmutableService],\n rowModels: { clientSide: ClientSideRowModel }\n};\n","import type { VNode } from \"vue\";\nimport Vue, { h } from \"vue\";\n\nexport const BmGridCellRendererWrapper = Vue.extend({\n name: \"BmGridCellRendererWrapper\",\n render(): VNode | undefined {\n const params = (this as any).params;\n\n // If we're an aggregated cell, attempt to render the aggregated value\n if (!params.data && params.node.group) {\n const colId = params.colDef.colId;\n const aggregatedValue = params.node.aggData?.[colId];\n\n if (aggregatedValue === undefined) {\n return undefined;\n }\n\n // We could render DataCellBoolean here, but the old grouped grid\n // doesn't render anything.\n if (typeof aggregatedValue === \"boolean\") {\n return undefined;\n }\n\n let formattedValue = params.context.value.formatter(aggregatedValue);\n\n if (params.context.value.rendererMetadata.suffixExtractor) {\n const items = params.context.items;\n\n if (!items.length) {\n return;\n }\n\n const suffix = params.context.value.rendererMetadata.suffixExtractor(\n params.context.items[0]\n );\n\n formattedValue = `${formattedValue} ${suffix}`;\n }\n\n return h(\"div\", formattedValue);\n }\n\n return (this as any).params.context.value.renderer(\n h,\n params.context.value.extractAndFormat(params.data),\n params.data,\n params.context.value\n );\n },\n});\n","import { onBeforeUnmount, onMounted } from \"vue\";\n\nexport function useMediaPrintingEvents(\n beforePrint: (ev: Event) => any,\n afterPrint: (ev: Event) => any\n) {\n onMounted(() => {\n window.addEventListener(\"beforeprint\", beforePrint);\n window.addEventListener(\"afterprint\", afterPrint);\n });\n\n onBeforeUnmount(() => {\n window.removeEventListener(\"beforeprint\", beforePrint);\n window.removeEventListener(\"afterprint\", afterPrint);\n });\n}\n","// Vuetify goTo doesn't correctly identify the first scrollable parent so this can be handy to do so and pass into the\n// 'container' property of the GoToOptions object.\n\nimport { computed } from \"vue\";\nimport type VueRouter from \"vue-router\";\nimport errorLoggerService from \"@/app/errors/errorLoggerService\";\nimport appStore from \"@/store/modules/appStore\";\n\n// Lifted from: https://stackoverflow.com/questions/35939886/find-first-scrollable-parent#42543908\nexport function getScrollParent(\n element: Element,\n includeHidden: boolean\n): HTMLElement {\n let style = getComputedStyle(element);\n let excludeStaticParent = style.position === \"absolute\";\n let overflowRegex = includeHidden ? /(auto|scroll|hidden)/ : /(auto|scroll)/;\n\n if (style.position === \"fixed\") {\n return document.scrollingElement as HTMLElement;\n }\n\n for (\n let parent: Element | null = element;\n (parent = parent.parentElement);\n\n ) {\n style = getComputedStyle(parent);\n if (excludeStaticParent && style.position === \"static\") {\n continue;\n }\n if (\n overflowRegex.test(\n (style.overflow || \"\") +\n (style.overflowY || \"\") +\n (style.overflowX || \"\")\n )\n ) {\n return parent as HTMLElement;\n }\n }\n\n return document.scrollingElement as HTMLElement;\n}\n\nexport function isRunningEndToEndTests(): boolean {\n return !!(window as any).Cypress;\n}\n\nexport const isMacOs = computed(\n () => navigator.userAgent.toLowerCase().indexOf(\"mac os x\") > -1\n);\n\nexport function detectBrowser() {\n if (\n (navigator.userAgent.indexOf(\"Opera\") ||\n navigator.userAgent.indexOf(\"OPR\")) != -1\n ) {\n return \"Opera\";\n } else if (navigator.userAgent.indexOf(\"Chrome\") != -1) {\n return \"Chrome\";\n } else if (navigator.userAgent.indexOf(\"Safari\") != -1) {\n return \"Safari\";\n } else if (navigator.userAgent.indexOf(\"Firefox\") != -1) {\n return \"Firefox\";\n } else if (navigator.userAgent.indexOf(\"MSIE\") != -1) {\n return \"IE\";\n } else {\n return \"Unknown\";\n }\n}\n\n/**\n * Opening a window after an async call causes browsers to lose trust in the action, causing pop-up blockers to activate\n * Here we open a window before the async call and update it once the async resources have been fetched/created\n *\n * @param fn Fetches/Creates async dependancies and injects name/params/querys into a router.resolve\n */\nexport async function windowOpenAsync(\n fn: () => Promise>\n): Promise {\n const newWindow = window.open(\"\", \"_blank\");\n\n // If our fetch fails, close the new window\n try {\n const resolvedRoute = await fn();\n newWindow?.open(resolvedRoute.href, \"_self\");\n } catch (e: any) {\n newWindow?.close();\n errorLoggerService.logError(\"Error opening window\", e);\n appStore.showError(e);\n }\n}\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nimport { _, Autowired, Bean, BeanStub, PreConstruct } from '@ag-grid-community/core';\nvar LicenseManager = /** @class */ (function (_super) {\n __extends(LicenseManager, _super);\n function LicenseManager() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.watermarkMessage = undefined;\n return _this;\n }\n LicenseManager_1 = LicenseManager;\n LicenseManager.prototype.validateLicense = function () {\n if (_.missingOrEmpty(LicenseManager_1.licenseKey)) {\n this.outputMissingLicenseKey();\n }\n else if (LicenseManager_1.licenseKey.length > 32) {\n var _a = LicenseManager_1.extractLicenseComponents(LicenseManager_1.licenseKey), md5 = _a.md5, license = _a.license, version = _a.version, isTrial = _a.isTrial;\n if (md5 === this.md5.md5(license)) {\n if (_.exists(version) && version) {\n this.validateLicenseKeyForVersion(version, !!isTrial, license);\n }\n else {\n this.validateLegacyKey(license);\n }\n }\n else {\n this.outputInvalidLicenseKey();\n }\n }\n else {\n this.outputInvalidLicenseKey();\n }\n };\n LicenseManager.extractExpiry = function (license) {\n var restrictionHashed = license.substring(license.lastIndexOf('_') + 1, license.length);\n return new Date(parseInt(LicenseManager_1.decode(restrictionHashed), 10));\n };\n LicenseManager.extractLicenseComponents = function (licenseKey) {\n // when users copy the license key from a PDF extra zero width characters are sometimes copied too\n // carriage returns and line feeds are problematic too\n // all of which causes license key validation to fail - strip these out\n var cleanedLicenseKey = licenseKey.replace(/[\\u200B-\\u200D\\uFEFF]/g, '');\n cleanedLicenseKey = cleanedLicenseKey.replace(/\\r?\\n|\\r/g, '');\n var hashStart = cleanedLicenseKey.length - 32;\n var md5 = cleanedLicenseKey.substring(hashStart);\n var license = cleanedLicenseKey.substring(0, hashStart);\n var _a = __read(LicenseManager_1.extractBracketedInformation(cleanedLicenseKey), 2), version = _a[0], isTrial = _a[1];\n return { md5: md5, license: license, version: version, isTrial: isTrial };\n };\n LicenseManager.prototype.getLicenseDetails = function (licenseKey) {\n var _a = LicenseManager_1.extractLicenseComponents(licenseKey), md5 = _a.md5, license = _a.license, version = _a.version, isTrial = _a.isTrial;\n var valid = (md5 === this.md5.md5(license));\n var expiry = null;\n if (valid) {\n expiry = LicenseManager_1.extractExpiry(license);\n valid = !isNaN(expiry.getTime());\n }\n return {\n licenseKey: licenseKey,\n valid: valid,\n expiry: valid ? LicenseManager_1.formatDate(expiry) : null,\n version: version ? version : 'legacy',\n isTrial: isTrial\n };\n };\n LicenseManager.prototype.isDisplayWatermark = function () {\n return !_.missingOrEmpty(this.watermarkMessage);\n };\n LicenseManager.prototype.getWatermarkMessage = function () {\n return this.watermarkMessage || '';\n };\n LicenseManager.formatDate = function (date) {\n var monthNames = [\n 'January', 'February', 'March',\n 'April', 'May', 'June', 'July',\n 'August', 'September', 'October',\n 'November', 'December'\n ];\n var day = date.getDate();\n var monthIndex = date.getMonth();\n var year = date.getFullYear();\n return day + ' ' + monthNames[monthIndex] + ' ' + year;\n };\n LicenseManager.getGridReleaseDate = function () {\n return new Date(parseInt(LicenseManager_1.decode(LicenseManager_1.RELEASE_INFORMATION), 10));\n };\n LicenseManager.decode = function (input) {\n var keystr = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=';\n var t = '';\n var n, r, i;\n var s, o, u, a;\n var f = 0;\n var e = input.replace(/[^A-Za-z0-9+/=]/g, '');\n while (f < e.length) {\n s = keystr.indexOf(e.charAt(f++));\n o = keystr.indexOf(e.charAt(f++));\n u = keystr.indexOf(e.charAt(f++));\n a = keystr.indexOf(e.charAt(f++));\n n = s << 2 | o >> 4;\n r = (o & 15) << 4 | u >> 2;\n i = (u & 3) << 6 | a;\n t = t + String.fromCharCode(n);\n if (u != 64) {\n t = t + String.fromCharCode(r);\n }\n if (a != 64) {\n t = t + String.fromCharCode(i);\n }\n }\n t = LicenseManager_1.utf8_decode(t);\n return t;\n };\n LicenseManager.utf8_decode = function (input) {\n input = input.replace(/rn/g, 'n');\n var t = '';\n for (var n = 0; n < input.length; n++) {\n var r = input.charCodeAt(n);\n if (r < 128) {\n t += String.fromCharCode(r);\n }\n else if (r > 127 && r < 2048) {\n t += String.fromCharCode(r >> 6 | 192);\n t += String.fromCharCode(r & 63 | 128);\n }\n else {\n t += String.fromCharCode(r >> 12 | 224);\n t += String.fromCharCode(r >> 6 & 63 | 128);\n t += String.fromCharCode(r & 63 | 128);\n }\n }\n return t;\n };\n LicenseManager.setLicenseKey = function (licenseKey) {\n LicenseManager_1.licenseKey = licenseKey;\n };\n LicenseManager.extractBracketedInformation = function (licenseKey) {\n var matches = licenseKey.split('[')\n .filter(function (v) {\n return v.indexOf(']') > -1;\n })\n .map(function (value) {\n return value.split(']')[0];\n });\n if (!matches || matches.length === 0) {\n return [null, null];\n }\n var isTrial = matches.filter(function (match) { return match === 'TRIAL'; }).length === 1;\n var version = matches.filter(function (match) { return match.indexOf(\"v\") === 0; }).map(function (match) { return match.replace(/^v/, \"\"); })[0];\n return [version, isTrial];\n };\n LicenseManager.prototype.validateLicenseKeyForVersion = function (version, isTrial, license) {\n if (version !== '2') {\n return;\n }\n if (isTrial) {\n this.validateForTrial(license);\n }\n else {\n this.validateLegacyKey(license);\n }\n };\n LicenseManager.prototype.validateLegacyKey = function (license) {\n var gridReleaseDate = LicenseManager_1.getGridReleaseDate();\n var expiry = LicenseManager_1.extractExpiry(license);\n var valid = false;\n var current = false;\n if (!isNaN(expiry.getTime())) {\n valid = true;\n current = (gridReleaseDate < expiry);\n }\n if (!valid) {\n this.outputInvalidLicenseKey();\n }\n else if (!current) {\n var formattedExpiryDate = LicenseManager_1.formatDate(expiry);\n var formattedReleaseDate = LicenseManager_1.formatDate(gridReleaseDate);\n this.outputIncompatibleVersion(formattedExpiryDate, formattedReleaseDate);\n }\n };\n LicenseManager.prototype.validateForTrial = function (license) {\n var expiry = LicenseManager_1.extractExpiry(license);\n var now = new Date();\n var valid = false;\n var current = false;\n if (!isNaN(expiry.getTime())) {\n valid = true;\n current = (expiry > now);\n }\n if (!valid) {\n this.outputInvalidLicenseKey();\n }\n else if (!current) {\n var formattedExpiryDate = LicenseManager_1.formatDate(expiry);\n this.outputExpiredTrialKey(formattedExpiryDate);\n }\n };\n LicenseManager.prototype.outputInvalidLicenseKey = function () {\n console.error('*****************************************************************************************************************');\n console.error('***************************************** AG Grid Enterprise License ********************************************');\n console.error('********************************************* Invalid License ***************************************************');\n console.error('* Your license for AG Grid Enterprise is not valid - please contact info@ag-grid.com to obtain a valid license. *');\n console.error('*****************************************************************************************************************');\n console.error('*****************************************************************************************************************');\n this.watermarkMessage = \"Invalid License\";\n };\n LicenseManager.prototype.outputExpiredTrialKey = function (formattedExpiryDate) {\n console.error('****************************************************************************************************************');\n console.error('***************************************** AG Grid Enterprise License *******************************************');\n console.error('***************************************** Trial Period Expired. *******************************************');\n console.error(\"* Your license for AG Grid Enterprise expired on \" + formattedExpiryDate + \". *\");\n console.error('* Please email info@ag-grid.com to purchase a license. *');\n console.error('****************************************************************************************************************');\n console.error('****************************************************************************************************************');\n this.watermarkMessage = \"Trial Period Expired\";\n };\n LicenseManager.prototype.outputMissingLicenseKey = function () {\n console.error('****************************************************************************************************************');\n console.error('***************************************** AG Grid Enterprise License *******************************************');\n console.error('****************************************** License Key Not Found ***********************************************');\n console.error('* All AG Grid Enterprise features are unlocked. *');\n console.error('* This is an evaluation only version, it is not licensed for development projects intended for production. *');\n console.error('* If you want to hide the watermark, please email info@ag-grid.com for a trial license. *');\n console.error('****************************************************************************************************************');\n console.error('****************************************************************************************************************');\n this.watermarkMessage = \"For Trial Use Only\";\n };\n LicenseManager.prototype.outputIncompatibleVersion = function (formattedExpiryDate, formattedReleaseDate) {\n console.error('****************************************************************************************************************************');\n console.error('****************************************************************************************************************************');\n console.error('* AG Grid Enterprise License *');\n console.error('* License not compatible with installed version of AG Grid Enterprise. *');\n console.error('* *');\n console.error(\"* Your AG Grid License entitles you to all versions of AG Grid that we release within the time covered by your license *\");\n console.error(\"* - typically we provide one year licenses which entitles you to all releases / updates of AG Grid within that year. *\");\n console.error(\"* Your license has an end (expiry) date which stops the license key working with versions of AG Grid released after the *\");\n console.error(\"* license end date. The license key that you have expires on \" + formattedExpiryDate + \", however the version of AG Grid you *\");\n console.error(\"* are trying to use was released on \" + formattedReleaseDate + \". *\");\n console.error('* *');\n console.error('* Please contact info@ag-grid.com to renew your subscription to new versions and get a new license key to work with this *');\n console.error('* version of AG Grid. *');\n console.error('****************************************************************************************************************************');\n console.error('****************************************************************************************************************************');\n this.watermarkMessage = \"License Expired\";\n };\n var LicenseManager_1;\n LicenseManager.RELEASE_INFORMATION = 'MTY2MTE0ODY3Nzc2Nw==';\n __decorate([\n Autowired('md5')\n ], LicenseManager.prototype, \"md5\", void 0);\n __decorate([\n PreConstruct\n ], LicenseManager.prototype, \"validateLicense\", null);\n LicenseManager = LicenseManager_1 = __decorate([\n Bean('licenseManager')\n ], LicenseManager);\n return LicenseManager;\n}(BeanStub));\nexport { LicenseManager };\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean, BeanStub, PostConstruct } from \"@ag-grid-community/core\";\nvar MD5 = /** @class */ (function (_super) {\n __extends(MD5, _super);\n function MD5() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.ieCompatibility = false;\n return _this;\n }\n MD5.prototype.init = function () {\n this.ieCompatibility = (this.md5('hello') != '5d41402abc4b2a76b9719d911017c592');\n };\n MD5.prototype.md5cycle = function (x, k) {\n var a = x[0], b = x[1], c = x[2], d = x[3];\n a = this.ff(a, b, c, d, k[0], 7, -680876936);\n d = this.ff(d, a, b, c, k[1], 12, -389564586);\n c = this.ff(c, d, a, b, k[2], 17, 606105819);\n b = this.ff(b, c, d, a, k[3], 22, -1044525330);\n a = this.ff(a, b, c, d, k[4], 7, -176418897);\n d = this.ff(d, a, b, c, k[5], 12, 1200080426);\n c = this.ff(c, d, a, b, k[6], 17, -1473231341);\n b = this.ff(b, c, d, a, k[7], 22, -45705983);\n a = this.ff(a, b, c, d, k[8], 7, 1770035416);\n d = this.ff(d, a, b, c, k[9], 12, -1958414417);\n c = this.ff(c, d, a, b, k[10], 17, -42063);\n b = this.ff(b, c, d, a, k[11], 22, -1990404162);\n a = this.ff(a, b, c, d, k[12], 7, 1804603682);\n d = this.ff(d, a, b, c, k[13], 12, -40341101);\n c = this.ff(c, d, a, b, k[14], 17, -1502002290);\n b = this.ff(b, c, d, a, k[15], 22, 1236535329);\n a = this.gg(a, b, c, d, k[1], 5, -165796510);\n d = this.gg(d, a, b, c, k[6], 9, -1069501632);\n c = this.gg(c, d, a, b, k[11], 14, 643717713);\n b = this.gg(b, c, d, a, k[0], 20, -373897302);\n a = this.gg(a, b, c, d, k[5], 5, -701558691);\n d = this.gg(d, a, b, c, k[10], 9, 38016083);\n c = this.gg(c, d, a, b, k[15], 14, -660478335);\n b = this.gg(b, c, d, a, k[4], 20, -405537848);\n a = this.gg(a, b, c, d, k[9], 5, 568446438);\n d = this.gg(d, a, b, c, k[14], 9, -1019803690);\n c = this.gg(c, d, a, b, k[3], 14, -187363961);\n b = this.gg(b, c, d, a, k[8], 20, 1163531501);\n a = this.gg(a, b, c, d, k[13], 5, -1444681467);\n d = this.gg(d, a, b, c, k[2], 9, -51403784);\n c = this.gg(c, d, a, b, k[7], 14, 1735328473);\n b = this.gg(b, c, d, a, k[12], 20, -1926607734);\n a = this.hh(a, b, c, d, k[5], 4, -378558);\n d = this.hh(d, a, b, c, k[8], 11, -2022574463);\n c = this.hh(c, d, a, b, k[11], 16, 1839030562);\n b = this.hh(b, c, d, a, k[14], 23, -35309556);\n a = this.hh(a, b, c, d, k[1], 4, -1530992060);\n d = this.hh(d, a, b, c, k[4], 11, 1272893353);\n c = this.hh(c, d, a, b, k[7], 16, -155497632);\n b = this.hh(b, c, d, a, k[10], 23, -1094730640);\n a = this.hh(a, b, c, d, k[13], 4, 681279174);\n d = this.hh(d, a, b, c, k[0], 11, -358537222);\n c = this.hh(c, d, a, b, k[3], 16, -722521979);\n b = this.hh(b, c, d, a, k[6], 23, 76029189);\n a = this.hh(a, b, c, d, k[9], 4, -640364487);\n d = this.hh(d, a, b, c, k[12], 11, -421815835);\n c = this.hh(c, d, a, b, k[15], 16, 530742520);\n b = this.hh(b, c, d, a, k[2], 23, -995338651);\n a = this.ii(a, b, c, d, k[0], 6, -198630844);\n d = this.ii(d, a, b, c, k[7], 10, 1126891415);\n c = this.ii(c, d, a, b, k[14], 15, -1416354905);\n b = this.ii(b, c, d, a, k[5], 21, -57434055);\n a = this.ii(a, b, c, d, k[12], 6, 1700485571);\n d = this.ii(d, a, b, c, k[3], 10, -1894986606);\n c = this.ii(c, d, a, b, k[10], 15, -1051523);\n b = this.ii(b, c, d, a, k[1], 21, -2054922799);\n a = this.ii(a, b, c, d, k[8], 6, 1873313359);\n d = this.ii(d, a, b, c, k[15], 10, -30611744);\n c = this.ii(c, d, a, b, k[6], 15, -1560198380);\n b = this.ii(b, c, d, a, k[13], 21, 1309151649);\n a = this.ii(a, b, c, d, k[4], 6, -145523070);\n d = this.ii(d, a, b, c, k[11], 10, -1120210379);\n c = this.ii(c, d, a, b, k[2], 15, 718787259);\n b = this.ii(b, c, d, a, k[9], 21, -343485551);\n x[0] = this.add32(a, x[0]);\n x[1] = this.add32(b, x[1]);\n x[2] = this.add32(c, x[2]);\n x[3] = this.add32(d, x[3]);\n };\n MD5.prototype.cmn = function (q, a, b, x, s, t) {\n a = this.add32(this.add32(a, q), this.add32(x, t));\n return this.add32((a << s) | (a >>> (32 - s)), b);\n };\n MD5.prototype.ff = function (a, b, c, d, x, s, t) {\n return this.cmn((b & c) | ((~b) & d), a, b, x, s, t);\n };\n MD5.prototype.gg = function (a, b, c, d, x, s, t) {\n return this.cmn((b & d) | (c & (~d)), a, b, x, s, t);\n };\n MD5.prototype.hh = function (a, b, c, d, x, s, t) {\n return this.cmn(b ^ c ^ d, a, b, x, s, t);\n };\n MD5.prototype.ii = function (a, b, c, d, x, s, t) {\n return this.cmn(c ^ (b | (~d)), a, b, x, s, t);\n };\n MD5.prototype.md51 = function (s) {\n var n = s.length;\n var state = [1732584193, -271733879, -1732584194, 271733878];\n var i;\n for (i = 64; i <= s.length; i += 64) {\n this.md5cycle(state, this.md5blk(s.substring(i - 64, i)));\n }\n s = s.substring(i - 64);\n var tail = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0];\n for (i = 0; i < s.length; i++) {\n tail[i >> 2] |= s.charCodeAt(i) << ((i % 4) << 3);\n }\n tail[i >> 2] |= 0x80 << ((i % 4) << 3);\n if (i > 55) {\n this.md5cycle(state, tail);\n for (i = 0; i < 16; i++) {\n tail[i] = 0;\n }\n }\n tail[14] = n * 8;\n this.md5cycle(state, tail);\n return state;\n };\n /* there needs to be support for Unicode here, * unless we pretend that we can redefine the MD-5\n * algorithm for multi-byte characters (perhaps by adding every four 16-bit characters and\n * shortening the sum to 32 bits). Otherwise I suthis.ggest performing MD-5 as if every character\n * was two bytes--e.g., 0040 0025 = @%--but then how will an ordinary MD-5 sum be matched?\n * There is no way to standardize text to something like UTF-8 before transformation; speed cost is\n * utterly prohibitive. The JavaScript standard itself needs to look at this: it should start\n * providing access to strings as preformed UTF-8 8-bit unsigned value arrays.\n */\n MD5.prototype.md5blk = function (s) {\n var md5blks = [];\n /* Andy King said do it this way. */\n for (var i = 0; i < 64; i += 4) {\n md5blks[i >> 2] = s.charCodeAt(i)\n + (s.charCodeAt(i + 1) << 8)\n + (s.charCodeAt(i + 2) << 16)\n + (s.charCodeAt(i + 3) << 24);\n }\n return md5blks;\n };\n MD5.prototype.rhex = function (n) {\n var hex_chr = '0123456789abcdef'.split('');\n var s = '', j = 0;\n for (; j < 4; j++) {\n s += hex_chr[(n >> (j * 8 + 4)) & 0x0F]\n + hex_chr[(n >> (j * 8)) & 0x0F];\n }\n return s;\n };\n MD5.prototype.hex = function (x) {\n for (var i = 0; i < x.length; i++) {\n x[i] = this.rhex(x[i]);\n }\n return x.join('');\n };\n MD5.prototype.md5 = function (s) {\n return this.hex(this.md51(s));\n };\n MD5.prototype.add32 = function (a, b) {\n return this.ieCompatibility ? this.add32Compat(a, b) : this.add32Std(a, b);\n };\n /* this function is much faster, so if possible we use it. Some IEs are the only ones I know of that\n need the idiotic second function, generated by an if clause. */\n MD5.prototype.add32Std = function (a, b) {\n return (a + b) & 0xFFFFFFFF;\n };\n MD5.prototype.add32Compat = function (x, y) {\n var lsw = (x & 0xFFFF) + (y & 0xFFFF), msw = (x >> 16) + (y >> 16) + (lsw >> 16);\n return (msw << 16) | (lsw & 0xFFFF);\n };\n __decorate([\n PostConstruct\n ], MD5.prototype, \"init\", null);\n MD5 = __decorate([\n Bean('md5')\n ], MD5);\n return MD5;\n}(BeanStub));\nexport { MD5 };\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Component, PostConstruct, RefSelector } from '@ag-grid-community/core';\nvar WatermarkComp = /** @class */ (function (_super) {\n __extends(WatermarkComp, _super);\n function WatermarkComp() {\n return _super.call(this, \"
\\n
\\n
\") || this;\n }\n WatermarkComp.prototype.postConstruct = function () {\n var _this = this;\n var show = this.shouldDisplayWatermark();\n this.addOrRemoveCssClass('ag-hidden', !show);\n if (show) {\n this.eLicenseTextRef.innerText = this.licenseManager.getWatermarkMessage();\n window.setTimeout(function () { return _this.addCssClass('ag-opacity-zero'); }, 0);\n window.setTimeout(function () { return _this.addCssClass('ag-hidden'); }, 5000);\n }\n };\n WatermarkComp.prototype.shouldDisplayWatermark = function () {\n var eDocument = this.gridOptionsWrapper.getDocument();\n var win = (eDocument.defaultView || window);\n var loc = win.location;\n var _a = loc.hostname, hostname = _a === void 0 ? '' : _a, pathname = loc.pathname;\n var isDisplayWatermark = this.licenseManager.isDisplayWatermark();\n var isWhiteListURL = hostname.match('^(?:127\\.0\\.0\\.1|localhost|(?:\\w+\\.)?ag-grid\\.com)$') != null;\n var isForceWatermark = pathname ? pathname.indexOf('forceWatermark') !== -1 : false;\n return isForceWatermark || (isDisplayWatermark && !isWhiteListURL);\n };\n __decorate([\n Autowired('licenseManager')\n ], WatermarkComp.prototype, \"licenseManager\", void 0);\n __decorate([\n RefSelector('eLicenseTextRef')\n ], WatermarkComp.prototype, \"eLicenseTextRef\", void 0);\n __decorate([\n PostConstruct\n ], WatermarkComp.prototype, \"postConstruct\", null);\n return WatermarkComp;\n}(Component));\nexport { WatermarkComp };\n","import { ModuleNames } from \"@ag-grid-community/core\";\nimport { LicenseManager } from \"./licenseManager\";\nimport { MD5 } from \"./license/md5\";\nimport { WatermarkComp } from \"./license/watermark\";\nexport { LicenseManager } from \"./licenseManager\";\nexport { MD5 } from \"./license/md5\";\nexport { WatermarkComp } from \"./license/watermark\";\nexport var EnterpriseCoreModule = {\n moduleName: ModuleNames.EnterpriseCoreModule,\n beans: [LicenseManager, MD5],\n agStackComponents: [\n { componentName: 'AgWatermark', componentClass: WatermarkComp }\n ]\n};\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean, BeanStub, Autowired, _ } from \"@ag-grid-community/core\";\nvar AggregationStage = /** @class */ (function (_super) {\n __extends(AggregationStage, _super);\n function AggregationStage() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n // it's possible to recompute the aggregate without doing the other parts\n // + gridApi.recomputeAggregates()\n AggregationStage.prototype.execute = function (params) {\n // if changed path is active, it means we came from a) change detection or b) transaction update.\n // for both of these, if no value columns are present, it means there is nothing to aggregate now\n // and there is no cleanup to be done (as value columns don't change between transactions or change\n // detections). if no value columns and no changed path, means we have to go through all nodes in\n // case we need to clean up agg data from before.\n var noValueColumns = _.missingOrEmpty(this.columnModel.getValueColumns());\n var noUserAgg = !this.gridOptionsWrapper.getGroupRowAggFunc();\n var changedPathActive = params.changedPath && params.changedPath.isActive();\n if (noValueColumns && noUserAgg && changedPathActive) {\n return;\n }\n var aggDetails = this.createAggDetails(params);\n this.recursivelyCreateAggData(aggDetails);\n };\n AggregationStage.prototype.createAggDetails = function (params) {\n var pivotActive = this.columnModel.isPivotActive();\n var measureColumns = this.columnModel.getValueColumns();\n var pivotColumns = pivotActive ? this.columnModel.getPivotColumns() : [];\n var aggDetails = {\n changedPath: params.changedPath,\n valueColumns: measureColumns,\n pivotColumns: pivotColumns\n };\n return aggDetails;\n };\n AggregationStage.prototype.recursivelyCreateAggData = function (aggDetails) {\n var _this = this;\n // update prop, in case changed since last time\n this.filteredOnly = !this.gridOptionsWrapper.isSuppressAggFilteredOnly();\n var callback = function (rowNode) {\n var hasNoChildren = !rowNode.hasChildren();\n if (hasNoChildren) {\n // this check is needed for TreeData, in case the node is no longer a child,\n // but it was a child previously.\n if (rowNode.aggData) {\n rowNode.setAggData(null);\n }\n // never agg data for leaf nodes\n return;\n }\n //Optionally prevent the aggregation at the root Node\n //https://ag-grid.atlassian.net/browse/AG-388\n var isRootNode = rowNode.level === -1;\n if (isRootNode) {\n var notPivoting = !_this.columnModel.isPivotMode();\n var suppressAggAtRootLevel = _this.gridOptionsWrapper.isSuppressAggAtRootLevel();\n if (suppressAggAtRootLevel && notPivoting) {\n return;\n }\n }\n _this.aggregateRowNode(rowNode, aggDetails);\n };\n aggDetails.changedPath.forEachChangedNodeDepthFirst(callback, true);\n };\n AggregationStage.prototype.aggregateRowNode = function (rowNode, aggDetails) {\n var measureColumnsMissing = aggDetails.valueColumns.length === 0;\n var pivotColumnsMissing = aggDetails.pivotColumns.length === 0;\n var userFunc = this.gridOptionsWrapper.getGroupRowAggFunc();\n var aggResult;\n if (userFunc) {\n var params = { nodes: rowNode.childrenAfterFilter };\n aggResult = userFunc(params);\n }\n else if (measureColumnsMissing) {\n aggResult = null;\n }\n else if (pivotColumnsMissing) {\n aggResult = this.aggregateRowNodeUsingValuesOnly(rowNode, aggDetails);\n }\n else {\n aggResult = this.aggregateRowNodeUsingValuesAndPivot(rowNode);\n }\n rowNode.setAggData(aggResult);\n // if we are grouping, then it's possible there is a sibling footer\n // to the group, so update the data here also if there is one\n if (rowNode.sibling) {\n rowNode.sibling.setAggData(aggResult);\n }\n };\n AggregationStage.prototype.aggregateRowNodeUsingValuesAndPivot = function (rowNode) {\n var _this = this;\n var result = {};\n var pivotColumnDefs = this.pivotStage.getPivotColumnDefs();\n // Step 1: process value columns\n pivotColumnDefs\n .filter(function (v) { return !_.exists(v.pivotTotalColumnIds); }) // only process pivot value columns\n .forEach(function (valueColDef) {\n var keys = valueColDef.pivotKeys || [];\n var values;\n var valueColumn = valueColDef.pivotValueColumn;\n var colId = valueColDef.colId;\n if (rowNode.leafGroup) {\n // lowest level group, get the values from the mapped set\n values = _this.getValuesFromMappedSet(rowNode.childrenMapped, keys, valueColumn);\n }\n else {\n // value columns and pivot columns, non-leaf group\n values = _this.getValuesPivotNonLeaf(rowNode, colId);\n }\n result[colId] = _this.aggregateValues(values, valueColumn.getAggFunc(), valueColumn, rowNode);\n });\n // Step 2: process total columns\n pivotColumnDefs\n .filter(function (v) { return _.exists(v.pivotTotalColumnIds); }) // only process pivot total columns\n .forEach(function (totalColDef) {\n var aggResults = [];\n var pivotValueColumn = totalColDef.pivotValueColumn, pivotTotalColumnIds = totalColDef.pivotTotalColumnIds, colId = totalColDef.colId;\n //retrieve results for colIds associated with this pivot total column\n if (!pivotTotalColumnIds || !pivotTotalColumnIds.length) {\n return;\n }\n pivotTotalColumnIds.forEach(function (currentColId) {\n aggResults.push(result[currentColId]);\n });\n result[colId] = _this.aggregateValues(aggResults, pivotValueColumn.getAggFunc(), pivotValueColumn, rowNode);\n });\n return result;\n };\n AggregationStage.prototype.aggregateRowNodeUsingValuesOnly = function (rowNode, aggDetails) {\n var _this = this;\n var result = {};\n var changedValueColumns = aggDetails.changedPath.isActive() ?\n aggDetails.changedPath.getValueColumnsForNode(rowNode, aggDetails.valueColumns)\n : aggDetails.valueColumns;\n var notChangedValueColumns = aggDetails.changedPath.isActive() ?\n aggDetails.changedPath.getNotValueColumnsForNode(rowNode, aggDetails.valueColumns)\n : null;\n var values2d = this.getValuesNormal(rowNode, changedValueColumns);\n var oldValues = rowNode.aggData;\n changedValueColumns.forEach(function (valueColumn, index) {\n result[valueColumn.getId()] = _this.aggregateValues(values2d[index], valueColumn.getAggFunc(), valueColumn, rowNode);\n });\n if (notChangedValueColumns && oldValues) {\n notChangedValueColumns.forEach(function (valueColumn) {\n result[valueColumn.getId()] = oldValues[valueColumn.getId()];\n });\n }\n return result;\n };\n AggregationStage.prototype.getValuesPivotNonLeaf = function (rowNode, colId) {\n var values = [];\n rowNode.childrenAfterFilter.forEach(function (node) {\n var value = node.aggData[colId];\n values.push(value);\n });\n return values;\n };\n AggregationStage.prototype.getValuesFromMappedSet = function (mappedSet, keys, valueColumn) {\n var _this = this;\n var mapPointer = mappedSet;\n keys.forEach(function (key) { return (mapPointer = mapPointer ? mapPointer[key] : null); });\n if (!mapPointer) {\n return [];\n }\n var values = [];\n mapPointer.forEach(function (rowNode) {\n var value = _this.valueService.getValue(valueColumn, rowNode);\n values.push(value);\n });\n return values;\n };\n AggregationStage.prototype.getValuesNormal = function (rowNode, valueColumns) {\n // create 2d array, of all values for all valueColumns\n var values = [];\n valueColumns.forEach(function () { return values.push([]); });\n var valueColumnCount = valueColumns.length;\n var nodeList = this.filteredOnly ? rowNode.childrenAfterFilter : rowNode.childrenAfterGroup;\n var rowCount = nodeList.length;\n for (var i = 0; i < rowCount; i++) {\n var childNode = nodeList[i];\n for (var j = 0; j < valueColumnCount; j++) {\n var valueColumn = valueColumns[j];\n // if the row is a group, then it will only have an agg result value,\n // which means valueGetter is never used.\n var value = this.valueService.getValue(valueColumn, childNode);\n values[j].push(value);\n }\n }\n return values;\n };\n AggregationStage.prototype.aggregateValues = function (values, aggFuncOrString, column, rowNode) {\n var aggFunc = typeof aggFuncOrString === 'string' ?\n this.aggFuncService.getAggFunc(aggFuncOrString) :\n aggFuncOrString;\n if (typeof aggFunc !== 'function') {\n console.error(\"AG Grid: unrecognised aggregation function \" + aggFuncOrString);\n return null;\n }\n var deprecationWarning = function () {\n _.doOnce(function () {\n console.warn('AG Grid: since v24.0, custom aggregation functions take a params object. Please alter your aggregation function to use params.values');\n }, 'aggregationStage.aggregateValues Deprecation');\n };\n var aggFuncAny = aggFunc;\n var params = {\n values: values,\n column: column,\n colDef: column ? column.getColDef() : undefined,\n rowNode: rowNode,\n data: rowNode ? rowNode.data : undefined,\n api: this.gridApi,\n columnApi: this.columnApi,\n context: this.gridOptionsWrapper.getContext(),\n }; // the \"as any\" is needed to allow the deprecation warning messages\n return aggFuncAny(params);\n };\n __decorate([\n Autowired('columnModel')\n ], AggregationStage.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('valueService')\n ], AggregationStage.prototype, \"valueService\", void 0);\n __decorate([\n Autowired('pivotStage')\n ], AggregationStage.prototype, \"pivotStage\", void 0);\n __decorate([\n Autowired('aggFuncService')\n ], AggregationStage.prototype, \"aggFuncService\", void 0);\n __decorate([\n Autowired('gridApi')\n ], AggregationStage.prototype, \"gridApi\", void 0);\n __decorate([\n Autowired('columnApi')\n ], AggregationStage.prototype, \"columnApi\", void 0);\n AggregationStage = __decorate([\n Bean('aggregationStage')\n ], AggregationStage);\n return AggregationStage;\n}(BeanStub));\nexport { AggregationStage };\n","var BatchRemover = /** @class */ (function () {\n function BatchRemover() {\n this.allSets = {};\n this.allParents = [];\n }\n BatchRemover.prototype.removeFromChildrenAfterGroup = function (parent, child) {\n var set = this.getSet(parent);\n set.removeFromChildrenAfterGroup[child.id] = true;\n };\n BatchRemover.prototype.removeFromAllLeafChildren = function (parent, child) {\n var set = this.getSet(parent);\n set.removeFromAllLeafChildren[child.id] = true;\n };\n BatchRemover.prototype.getSet = function (parent) {\n if (!this.allSets[parent.id]) {\n this.allSets[parent.id] = {\n removeFromAllLeafChildren: {},\n removeFromChildrenAfterGroup: {}\n };\n this.allParents.push(parent);\n }\n return this.allSets[parent.id];\n };\n BatchRemover.prototype.getAllParents = function () {\n return this.allParents;\n };\n BatchRemover.prototype.flush = function () {\n var _this = this;\n this.allParents.forEach(function (parent) {\n var nodeDetails = _this.allSets[parent.id];\n parent.childrenAfterGroup = parent.childrenAfterGroup.filter(function (child) { return !nodeDetails.removeFromChildrenAfterGroup[child.id]; });\n parent.allLeafChildren = parent.allLeafChildren.filter(function (child) { return !nodeDetails.removeFromAllLeafChildren[child.id]; });\n parent.updateHasChildren();\n if (parent.sibling) {\n parent.sibling.childrenAfterGroup = parent.childrenAfterGroup;\n parent.sibling.allLeafChildren = parent.allLeafChildren;\n }\n });\n this.allSets = {};\n this.allParents.length = 0;\n };\n return BatchRemover;\n}());\nexport { BatchRemover };\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nimport { _, Autowired, Bean, BeanStub, NumberSequence, PostConstruct, RowNode } from \"@ag-grid-community/core\";\nimport { BatchRemover } from \"./batchRemover\";\nvar GroupStage = /** @class */ (function (_super) {\n __extends(GroupStage, _super);\n function GroupStage() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n // we use a sequence variable so that each time we do a grouping, we don't\n // reuse the ids - otherwise the rowRenderer will confuse rowNodes between redraws\n // when it tries to animate between rows.\n _this.groupIdSequence = new NumberSequence();\n return _this;\n }\n GroupStage.prototype.postConstruct = function () {\n this.usingTreeData = this.gridOptionsWrapper.isTreeData();\n if (this.usingTreeData) {\n this.getDataPath = this.gridOptionsWrapper.getDataPathFunc();\n }\n };\n GroupStage.prototype.execute = function (params) {\n var details = this.createGroupingDetails(params);\n if (details.transactions) {\n this.handleTransaction(details);\n }\n else {\n var afterColsChanged = params.afterColumnsChanged === true;\n this.shotgunResetEverything(details, afterColsChanged);\n }\n this.positionLeafsAboveGroups(params.changedPath);\n this.orderGroups(details.rootNode);\n this.selectableService.updateSelectableAfterGrouping(details.rootNode);\n };\n GroupStage.prototype.positionLeafsAboveGroups = function (changedPath) {\n // we don't do group sorting for tree data\n if (this.usingTreeData) {\n return;\n }\n changedPath.forEachChangedNodeDepthFirst(function (group) {\n if (group.childrenAfterGroup) {\n var leafNodes_1 = [];\n var groupNodes_1 = [];\n group.childrenAfterGroup.forEach(function (row) {\n var _a;\n if (!((_a = row.childrenAfterGroup) === null || _a === void 0 ? void 0 : _a.length)) {\n leafNodes_1.push(row);\n }\n else {\n groupNodes_1.push(row);\n }\n });\n group.childrenAfterGroup = __spread(leafNodes_1, groupNodes_1);\n }\n }, false);\n };\n GroupStage.prototype.createGroupingDetails = function (params) {\n var rowNode = params.rowNode, changedPath = params.changedPath, rowNodeTransactions = params.rowNodeTransactions, rowNodeOrder = params.rowNodeOrder;\n var groupedCols = this.usingTreeData ? null : this.columnModel.getRowGroupColumns();\n var details = {\n // someone complained that the parent attribute was causing some change detection\n // to break is some angular add-on - which i never used. taking the parent out breaks\n // a cyclic dependency, hence this flag got introduced.\n includeParents: !this.gridOptionsWrapper.isSuppressParentsInRowNodes(),\n expandByDefault: this.gridOptionsWrapper.getGroupDefaultExpanded(),\n groupedCols: groupedCols,\n rootNode: rowNode,\n pivotMode: this.columnModel.isPivotMode(),\n groupedColCount: this.usingTreeData || !groupedCols ? 0 : groupedCols.length,\n rowNodeOrder: rowNodeOrder,\n transactions: rowNodeTransactions,\n // if no transaction, then it's shotgun, changed path would be 'not active' at this point anyway\n changedPath: changedPath\n };\n return details;\n };\n GroupStage.prototype.handleTransaction = function (details) {\n var _this = this;\n details.transactions.forEach(function (tran) {\n // we don't allow batch remover for tree data as tree data uses Filler Nodes,\n // and creating/deleting filler nodes needs to be done alongside the node deleting\n // and moving. if we want to Batch Remover working with tree data then would need\n // to consider how Filler Nodes would be impacted (it's possible that it can be easily\n // modified to work, however for now I don't have the brain energy to work it all out).\n var batchRemover = !_this.usingTreeData ? new BatchRemover() : undefined;\n // the order here of [add, remove, update] needs to be the same as in ClientSideNodeManager,\n // as the order is important when a record with the same id is added and removed in the same\n // transaction.\n if (_.existsAndNotEmpty(tran.remove)) {\n _this.removeNodes(tran.remove, details, batchRemover);\n }\n if (_.existsAndNotEmpty(tran.update)) {\n _this.moveNodesInWrongPath(tran.update, details, batchRemover);\n }\n if (_.existsAndNotEmpty(tran.add)) {\n _this.insertNodes(tran.add, details, false);\n }\n // must flush here, and not allow another transaction to be applied,\n // as each transaction must finish leaving the data in a consistent state.\n if (batchRemover) {\n var parentsWithChildrenRemoved = batchRemover.getAllParents().slice();\n batchRemover.flush();\n _this.removeEmptyGroups(parentsWithChildrenRemoved, details);\n }\n });\n if (details.rowNodeOrder) {\n this.sortChildren(details);\n }\n };\n // this is used when doing delta updates, eg Redux, keeps nodes in right order\n GroupStage.prototype.sortChildren = function (details) {\n details.changedPath.forEachChangedNodeDepthFirst(function (rowNode) {\n _.sortRowNodesByOrder(rowNode.childrenAfterGroup, details.rowNodeOrder);\n });\n };\n GroupStage.prototype.orderGroups = function (rootNode) {\n // we don't do group sorting for tree data\n if (this.usingTreeData) {\n return;\n }\n var comparator = this.gridOptionsWrapper.getInitialGroupOrderComparator();\n if (_.exists(comparator)) {\n recursiveSort(rootNode);\n }\n function recursiveSort(rowNode) {\n var doSort = _.exists(rowNode.childrenAfterGroup) &&\n // we only want to sort groups, so we do not sort leafs (a leaf group has leafs as children)\n !rowNode.leafGroup;\n if (doSort) {\n rowNode.childrenAfterGroup.sort(function (nodeA, nodeB) { return comparator({ nodeA: nodeA, nodeB: nodeB }); });\n rowNode.childrenAfterGroup.forEach(function (childNode) { return recursiveSort(childNode); });\n }\n }\n };\n GroupStage.prototype.getExistingPathForNode = function (node, details) {\n var res = [];\n // when doing tree data, the node is part of the path,\n // but when doing grid grouping, the node is not part of the path so we start with the parent.\n var pointer = this.usingTreeData ? node : node.parent;\n while (pointer && pointer !== details.rootNode) {\n res.push({\n key: pointer.key,\n rowGroupColumn: pointer.rowGroupColumn,\n field: pointer.field\n });\n pointer = pointer.parent;\n }\n res.reverse();\n return res;\n };\n GroupStage.prototype.moveNodesInWrongPath = function (childNodes, details, batchRemover) {\n var _this = this;\n childNodes.forEach(function (childNode) {\n // we add node, even if parent has not changed, as the data could have\n // changed, hence aggregations will be wrong\n if (details.changedPath.isActive()) {\n details.changedPath.addParentNode(childNode.parent);\n }\n var infoToKeyMapper = function (item) { return item.key; };\n var oldPath = _this.getExistingPathForNode(childNode, details).map(infoToKeyMapper);\n var newPath = _this.getGroupInfo(childNode, details).map(infoToKeyMapper);\n var nodeInCorrectPath = _.areEqual(oldPath, newPath);\n if (!nodeInCorrectPath) {\n _this.moveNode(childNode, details, batchRemover);\n }\n });\n };\n GroupStage.prototype.moveNode = function (childNode, details, batchRemover) {\n this.removeNodesInStages([childNode], details, batchRemover);\n this.insertOneNode(childNode, details, true);\n // hack - if we didn't do this, then renaming a tree item (ie changing rowNode.key) wouldn't get\n // refreshed into the gui.\n // this is needed to kick off the event that rowComp listens to for refresh. this in turn\n // then will get each cell in the row to refresh - which is what we need as we don't know which\n // columns will be displaying the rowNode.key info.\n childNode.setData(childNode.data);\n // we add both old and new parents to changed path, as both will need to be refreshed.\n // we already added the old parent (in calling method), so just add the new parent here\n if (details.changedPath.isActive()) {\n var newParent = childNode.parent;\n details.changedPath.addParentNode(newParent);\n }\n };\n GroupStage.prototype.removeNodes = function (leafRowNodes, details, batchRemover) {\n this.removeNodesInStages(leafRowNodes, details, batchRemover);\n if (details.changedPath.isActive()) {\n leafRowNodes.forEach(function (rowNode) { return details.changedPath.addParentNode(rowNode.parent); });\n }\n };\n GroupStage.prototype.removeNodesInStages = function (leafRowNodes, details, batchRemover) {\n this.removeNodesFromParents(leafRowNodes, details, batchRemover);\n if (this.usingTreeData) {\n this.postRemoveCreateFillerNodes(leafRowNodes, details);\n // When not TreeData, then removeEmptyGroups is called just before the BatchRemover is flushed.\n // However for TreeData, there is no BatchRemover, so we have to call removeEmptyGroups here.\n var nodeParents = leafRowNodes.map(function (n) { return n.parent; });\n this.removeEmptyGroups(nodeParents, details);\n }\n };\n GroupStage.prototype.forEachParentGroup = function (details, group, callback) {\n var pointer = group;\n while (pointer && pointer !== details.rootNode) {\n callback(pointer);\n pointer = pointer.parent;\n }\n };\n GroupStage.prototype.removeNodesFromParents = function (nodesToRemove, details, provided) {\n var _this = this;\n // this method can be called with BatchRemover as optional. if it is missed, we created a local version\n // and flush it at the end. if one is provided, we add to the provided one and it gets flushed elsewhere.\n var batchRemoverIsLocal = provided == null;\n var batchRemoverToUse = provided ? provided : new BatchRemover();\n nodesToRemove.forEach(function (nodeToRemove) {\n _this.removeFromParent(nodeToRemove, batchRemoverToUse);\n // remove from allLeafChildren. we clear down all parents EXCEPT the Root Node, as\n // the ClientSideNodeManager is responsible for the Root Node.\n _this.forEachParentGroup(details, nodeToRemove.parent, function (parentNode) {\n batchRemoverToUse.removeFromAllLeafChildren(parentNode, nodeToRemove);\n });\n });\n if (batchRemoverIsLocal) {\n batchRemoverToUse.flush();\n }\n };\n GroupStage.prototype.postRemoveCreateFillerNodes = function (nodesToRemove, details) {\n var _this = this;\n nodesToRemove.forEach(function (nodeToRemove) {\n // if not group, and children are present, need to move children to a group.\n // otherwise if no children, we can just remove without replacing.\n var replaceWithGroup = nodeToRemove.hasChildren();\n if (replaceWithGroup) {\n var oldPath = _this.getExistingPathForNode(nodeToRemove, details);\n // because we just removed the userGroup, this will always return new support group\n var newGroupNode_1 = _this.findParentForNode(nodeToRemove, oldPath, details);\n // these properties are the ones that will be incorrect in the newly created group,\n // so copy them from the old childNode\n newGroupNode_1.expanded = nodeToRemove.expanded;\n newGroupNode_1.allLeafChildren = nodeToRemove.allLeafChildren;\n newGroupNode_1.childrenAfterGroup = nodeToRemove.childrenAfterGroup;\n newGroupNode_1.childrenMapped = nodeToRemove.childrenMapped;\n newGroupNode_1.updateHasChildren();\n newGroupNode_1.childrenAfterGroup.forEach(function (rowNode) { return rowNode.parent = newGroupNode_1; });\n }\n });\n };\n GroupStage.prototype.removeEmptyGroups = function (possibleEmptyGroups, details) {\n var _this = this;\n // we do this multiple times, as when we remove groups, that means the parent of just removed\n // group can then be empty. to get around this, if we remove, then we check everything again for\n // newly emptied groups. the max number of times this will execute is the depth of the group tree.\n var checkAgain = true;\n var groupShouldBeRemoved = function (rowNode) {\n // because of the while loop below, it's possible we already moved the node,\n // so double check before trying to remove again.\n var mapKey = _this.getChildrenMappedKey(rowNode.key, rowNode.rowGroupColumn);\n var parentRowNode = rowNode.parent;\n var groupAlreadyRemoved = (parentRowNode && parentRowNode.childrenMapped) ?\n !parentRowNode.childrenMapped[mapKey] : true;\n if (groupAlreadyRemoved) {\n // if not linked, then group was already removed\n return false;\n }\n // if still not removed, then we remove if this group is empty\n return !!rowNode.isEmptyRowGroupNode();\n };\n var _loop_1 = function () {\n checkAgain = false;\n var batchRemover = new BatchRemover();\n possibleEmptyGroups.forEach(function (possibleEmptyGroup) {\n // remove empty groups\n _this.forEachParentGroup(details, possibleEmptyGroup, function (rowNode) {\n if (groupShouldBeRemoved(rowNode)) {\n checkAgain = true;\n _this.removeFromParent(rowNode, batchRemover);\n // we remove selection on filler nodes here, as the selection would not be removed\n // from the RowNodeManager, as filler nodes don't exist on the RowNodeManager\n rowNode.setSelected(false);\n }\n });\n });\n batchRemover.flush();\n };\n while (checkAgain) {\n _loop_1();\n }\n };\n // removes the node from the parent by:\n // a) removing from childrenAfterGroup (using batchRemover if present, otherwise immediately)\n // b) removing from childrenMapped (immediately)\n // c) setRowTop(null) - as the rowRenderer uses this to know the RowNode is no longer needed\n // d) setRowIndex(null) - as the rowNode will no longer be displayed.\n GroupStage.prototype.removeFromParent = function (child, batchRemover) {\n if (child.parent) {\n if (batchRemover) {\n batchRemover.removeFromChildrenAfterGroup(child.parent, child);\n }\n else {\n _.removeFromArray(child.parent.childrenAfterGroup, child);\n child.parent.updateHasChildren();\n }\n }\n var mapKey = this.getChildrenMappedKey(child.key, child.rowGroupColumn);\n if (child.parent && child.parent.childrenMapped) {\n child.parent.childrenMapped[mapKey] = undefined;\n }\n // this is important for transition, see rowComp removeFirstPassFuncs. when doing animation and\n // remove, if rowTop is still present, the rowComp thinks it's just moved position.\n child.setRowTop(null);\n child.setRowIndex(null);\n };\n GroupStage.prototype.addToParent = function (child, parent) {\n var mapKey = this.getChildrenMappedKey(child.key, child.rowGroupColumn);\n if (parent) {\n var children = parent.childrenMapped != null;\n if (children) {\n parent.childrenMapped[mapKey] = child;\n }\n parent.childrenAfterGroup.push(child);\n parent.updateHasChildren();\n }\n };\n GroupStage.prototype.areGroupColsEqual = function (d1, d2) {\n if (d1 == null || d2 == null || d1.pivotMode !== d2.pivotMode) {\n return false;\n }\n return _.areEqual(d1.groupedCols, d2.groupedCols);\n };\n GroupStage.prototype.checkAllGroupDataAfterColsChanged = function (details) {\n var _this = this;\n var recurse = function (rowNodes) {\n if (!rowNodes) {\n return;\n }\n rowNodes.forEach(function (rowNode) {\n var isLeafNode = !_this.usingTreeData && !rowNode.group;\n if (isLeafNode) {\n return;\n }\n var groupInfo = {\n field: rowNode.field,\n key: rowNode.key,\n rowGroupColumn: rowNode.rowGroupColumn\n };\n _this.setGroupData(rowNode, groupInfo);\n recurse(rowNode.childrenAfterGroup);\n });\n };\n recurse(details.rootNode.childrenAfterGroup);\n };\n GroupStage.prototype.shotgunResetEverything = function (details, afterColumnsChanged) {\n if (this.noChangeInGroupingColumns(details, afterColumnsChanged)) {\n return;\n }\n // groups are about to get disposed, so need to deselect any that are selected\n this.selectionService.removeGroupsFromSelection();\n var rootNode = details.rootNode, groupedCols = details.groupedCols;\n // because we are not creating the root node each time, we have the logic\n // here to change leafGroup once.\n // we set .leafGroup to false for tree data, as .leafGroup is only used when pivoting, and pivoting\n // isn't allowed with treeData, so the grid never actually use .leafGroup when doing treeData.\n rootNode.leafGroup = this.usingTreeData ? false : groupedCols.length === 0;\n // we are doing everything from scratch, so reset childrenAfterGroup and childrenMapped from the rootNode\n rootNode.childrenAfterGroup = [];\n rootNode.childrenMapped = {};\n rootNode.updateHasChildren();\n var sibling = rootNode.sibling;\n if (sibling) {\n sibling.childrenAfterGroup = rootNode.childrenAfterGroup;\n sibling.childrenMapped = rootNode.childrenMapped;\n }\n this.insertNodes(rootNode.allLeafChildren, details, false);\n };\n GroupStage.prototype.noChangeInGroupingColumns = function (details, afterColumnsChanged) {\n var noFurtherProcessingNeeded = false;\n var groupDisplayColumns = this.columnModel.getGroupDisplayColumns();\n var newGroupDisplayColIds = groupDisplayColumns ?\n groupDisplayColumns.map(function (c) { return c.getId(); }).join('-') : '';\n if (afterColumnsChanged) {\n // we only need to redo grouping if doing normal grouping (ie not tree data)\n // and the group cols have changed.\n noFurtherProcessingNeeded = this.usingTreeData || this.areGroupColsEqual(details, this.oldGroupingDetails);\n // if the group display cols have changed, then we need to update rowNode.groupData\n // (regardless of tree data or row grouping)\n if (this.oldGroupDisplayColIds !== newGroupDisplayColIds) {\n this.checkAllGroupDataAfterColsChanged(details);\n }\n }\n this.oldGroupingDetails = details;\n this.oldGroupDisplayColIds = newGroupDisplayColIds;\n return noFurtherProcessingNeeded;\n };\n GroupStage.prototype.insertNodes = function (newRowNodes, details, isMove) {\n var _this = this;\n newRowNodes.forEach(function (rowNode) {\n _this.insertOneNode(rowNode, details, isMove);\n if (details.changedPath.isActive()) {\n details.changedPath.addParentNode(rowNode.parent);\n }\n });\n };\n GroupStage.prototype.insertOneNode = function (childNode, details, isMove) {\n var path = this.getGroupInfo(childNode, details);\n var parentGroup = this.findParentForNode(childNode, path, details);\n if (!parentGroup.group) {\n console.warn(\"AG Grid: duplicate group keys for row data, keys should be unique\", [parentGroup.data, childNode.data]);\n }\n if (this.usingTreeData) {\n this.swapGroupWithUserNode(parentGroup, childNode, isMove);\n }\n else {\n childNode.parent = parentGroup;\n childNode.level = path.length;\n parentGroup.childrenAfterGroup.push(childNode);\n parentGroup.updateHasChildren();\n }\n };\n GroupStage.prototype.findParentForNode = function (childNode, path, details) {\n var _this = this;\n var nextNode = details.rootNode;\n path.forEach(function (groupInfo, level) {\n nextNode = _this.getOrCreateNextNode(nextNode, groupInfo, level, details);\n // node gets added to all group nodes.\n // note: we do not add to rootNode here, as the rootNode is the master list of rowNodes\n nextNode.allLeafChildren.push(childNode);\n });\n return nextNode;\n };\n GroupStage.prototype.swapGroupWithUserNode = function (fillerGroup, userGroup, isMove) {\n userGroup.parent = fillerGroup.parent;\n userGroup.key = fillerGroup.key;\n userGroup.field = fillerGroup.field;\n userGroup.groupData = fillerGroup.groupData;\n userGroup.level = fillerGroup.level;\n // AG-3441 - preserve the existing expanded status of the node if we're moving it, so that\n // you can drag a sub tree from one parent to another without changing its expansion\n if (!isMove) {\n userGroup.expanded = fillerGroup.expanded;\n }\n // we set .leafGroup to false for tree data, as .leafGroup is only used when pivoting, and pivoting\n // isn't allowed with treeData, so the grid never actually use .leafGroup when doing treeData.\n userGroup.leafGroup = fillerGroup.leafGroup;\n // always null for userGroups, as row grouping is not allowed when doing tree data\n userGroup.rowGroupIndex = fillerGroup.rowGroupIndex;\n userGroup.allLeafChildren = fillerGroup.allLeafChildren;\n userGroup.childrenAfterGroup = fillerGroup.childrenAfterGroup;\n userGroup.childrenMapped = fillerGroup.childrenMapped;\n userGroup.updateHasChildren();\n this.removeFromParent(fillerGroup);\n userGroup.childrenAfterGroup.forEach(function (rowNode) { return rowNode.parent = userGroup; });\n this.addToParent(userGroup, fillerGroup.parent);\n };\n GroupStage.prototype.getOrCreateNextNode = function (parentGroup, groupInfo, level, details) {\n var key = this.getChildrenMappedKey(groupInfo.key, groupInfo.rowGroupColumn);\n var nextNode = parentGroup.childrenMapped ? parentGroup.childrenMapped[key] : undefined;\n if (!nextNode) {\n nextNode = this.createGroup(groupInfo, parentGroup, level, details);\n // attach the new group to the parent\n this.addToParent(nextNode, parentGroup);\n }\n return nextNode;\n };\n GroupStage.prototype.createGroup = function (groupInfo, parent, level, details) {\n var groupNode = new RowNode(this.beans);\n groupNode.group = true;\n groupNode.field = groupInfo.field;\n groupNode.rowGroupColumn = groupInfo.rowGroupColumn;\n this.setGroupData(groupNode, groupInfo);\n // we put 'row-group-' before the group id, so it doesn't clash with standard row id's. we also use 't-' and 'b-'\n // for top pinned and bottom pinned rows.\n groupNode.id = RowNode.ID_PREFIX_ROW_GROUP + this.groupIdSequence.next();\n groupNode.key = groupInfo.key;\n groupNode.level = level;\n groupNode.leafGroup = this.usingTreeData ? false : level === (details.groupedColCount - 1);\n groupNode.allLeafChildren = [];\n // why is this done here? we are not updating the children count as we go,\n // i suspect this is updated in the filter stage\n groupNode.setAllChildrenCount(0);\n groupNode.rowGroupIndex = this.usingTreeData ? null : level;\n groupNode.childrenAfterGroup = [];\n groupNode.childrenMapped = {};\n groupNode.updateHasChildren();\n groupNode.parent = details.includeParents ? parent : null;\n this.setExpandedInitialValue(details, groupNode);\n return groupNode;\n };\n GroupStage.prototype.setGroupData = function (groupNode, groupInfo) {\n var _this = this;\n groupNode.groupData = {};\n var groupDisplayCols = this.columnModel.getGroupDisplayColumns();\n groupDisplayCols.forEach(function (col) {\n // newGroup.rowGroupColumn=null when working off GroupInfo, and we always display the group in the group column\n // if rowGroupColumn is present, then it's grid row grouping and we only include if configuration says so\n var displayGroupForCol = _this.usingTreeData || (groupNode.rowGroupColumn ? col.isRowGroupDisplayed(groupNode.rowGroupColumn.getId()) : false);\n if (displayGroupForCol) {\n groupNode.groupData[col.getColId()] = groupInfo.key;\n }\n });\n };\n GroupStage.prototype.getChildrenMappedKey = function (key, rowGroupColumn) {\n if (rowGroupColumn) {\n // grouping by columns\n return rowGroupColumn.getId() + '-' + key;\n }\n // tree data - we don't have rowGroupColumns\n return key;\n };\n GroupStage.prototype.setExpandedInitialValue = function (details, groupNode) {\n // if pivoting the leaf group is never expanded as we do not show leaf rows\n if (details.pivotMode && groupNode.leafGroup) {\n groupNode.expanded = false;\n return;\n }\n // use callback if exists\n var userCallback = this.gridOptionsWrapper.getIsGroupOpenByDefaultFunc();\n if (userCallback) {\n var params = {\n rowNode: groupNode,\n field: groupNode.field,\n key: groupNode.key,\n level: groupNode.level,\n rowGroupColumn: groupNode.rowGroupColumn\n };\n groupNode.expanded = userCallback(params) == true;\n return;\n }\n // use expandByDefault if exists\n var expandByDefault = details.expandByDefault;\n if (details.expandByDefault === -1) {\n groupNode.expanded = true;\n return;\n }\n // otherwise\n groupNode.expanded = groupNode.level < expandByDefault;\n };\n GroupStage.prototype.getGroupInfo = function (rowNode, details) {\n if (this.usingTreeData) {\n return this.getGroupInfoFromCallback(rowNode);\n }\n return this.getGroupInfoFromGroupColumns(rowNode, details);\n };\n GroupStage.prototype.getGroupInfoFromCallback = function (rowNode) {\n var keys = this.getDataPath ? this.getDataPath(rowNode.data) : null;\n if (keys === null || keys === undefined || keys.length === 0) {\n _.doOnce(function () { return console.warn(\"AG Grid: getDataPath() should not return an empty path for data\", rowNode.data); }, 'groupStage.getGroupInfoFromCallback');\n }\n var groupInfoMapper = function (key) { return ({ key: key, field: null, rowGroupColumn: null }); };\n return keys ? keys.map(groupInfoMapper) : [];\n };\n GroupStage.prototype.getGroupInfoFromGroupColumns = function (rowNode, details) {\n var _this = this;\n var res = [];\n details.groupedCols.forEach(function (groupCol) {\n var key = _this.valueService.getKeyForNode(groupCol, rowNode);\n var keyExists = key !== null && key !== undefined;\n // unbalanced tree and pivot mode don't work together - not because of the grid, it doesn't make\n // mathematical sense as you are building up a cube. so if pivot mode, we put in a blank key where missing.\n // this keeps the tree balanced and hence can be represented as a group.\n if (details.pivotMode && !keyExists) {\n key = ' ';\n keyExists = true;\n }\n if (keyExists) {\n var item = {\n key: key,\n field: groupCol.getColDef().field,\n rowGroupColumn: groupCol\n };\n res.push(item);\n }\n });\n return res;\n };\n __decorate([\n Autowired('columnModel')\n ], GroupStage.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('selectableService')\n ], GroupStage.prototype, \"selectableService\", void 0);\n __decorate([\n Autowired('valueService')\n ], GroupStage.prototype, \"valueService\", void 0);\n __decorate([\n Autowired('beans')\n ], GroupStage.prototype, \"beans\", void 0);\n __decorate([\n Autowired('selectionService')\n ], GroupStage.prototype, \"selectionService\", void 0);\n __decorate([\n PostConstruct\n ], GroupStage.prototype, \"postConstruct\", null);\n GroupStage = __decorate([\n Bean('groupStage')\n ], GroupStage);\n return GroupStage;\n}(BeanStub));\nexport { GroupStage };\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nimport { Autowired, Bean, BeanStub, _ } from \"@ag-grid-community/core\";\nvar PivotColDefService = /** @class */ (function (_super) {\n __extends(PivotColDefService, _super);\n function PivotColDefService() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n PivotColDefService_1 = PivotColDefService;\n PivotColDefService.prototype.createPivotColumnDefs = function (uniqueValues) {\n // this is passed to the columnModel, to configure the columns and groups we show\n var pivotColumns = this.columnModel.getPivotColumns();\n var valueColumns = this.columnModel.getValueColumns();\n var levelsDeep = pivotColumns.length;\n var pivotColumnGroupDefs = this.recursiveBuildGroup(0, uniqueValues, [], levelsDeep, pivotColumns);\n function extractColDefs(input, arr) {\n if (arr === void 0) { arr = []; }\n input.forEach(function (def) {\n if (def.children !== undefined) {\n extractColDefs(def.children, arr);\n }\n else {\n arr.push(def);\n }\n });\n return arr;\n }\n var pivotColumnDefs = extractColDefs(pivotColumnGroupDefs);\n // additional columns that contain the aggregated total for each value column per row\n this.addRowGroupTotals(pivotColumnGroupDefs, pivotColumnDefs, valueColumns);\n // additional group columns that contain child totals for each collapsed child column / group\n this.addExpandablePivotGroups(pivotColumnGroupDefs, pivotColumnDefs);\n // additional group columns that contain an aggregated total across all child columns\n this.addPivotTotalsToGroups(pivotColumnGroupDefs, pivotColumnDefs);\n // we clone, so the colDefs in pivotColumnsGroupDefs and pivotColumnDefs are not shared. this is so that\n // any changes the user makes (via processSecondaryColumnDefinitions) don't impact the internal aggregations,\n // as these use the col defs also\n var pivotColumnDefsClone = pivotColumnDefs.map(function (colDef) { return _.cloneObject(colDef); });\n return {\n pivotColumnGroupDefs: pivotColumnGroupDefs,\n pivotColumnDefs: pivotColumnDefsClone\n };\n };\n PivotColDefService.prototype.recursiveBuildGroup = function (index, uniqueValue, pivotKeys, maxDepth, primaryPivotColumns) {\n var _this = this;\n var measureColumns = this.columnModel.getValueColumns();\n if (index >= maxDepth) { // Base case - build the measure columns\n return this.buildMeasureCols(pivotKeys);\n }\n // sort by either user provided comparator, or our own one\n var primaryPivotColumnDefs = primaryPivotColumns[index].getColDef();\n var comparator = this.headerNameComparator.bind(this, primaryPivotColumnDefs.pivotComparator);\n // Base case for the compact layout, instead of recursing build the last layer of groups as measure columns instead\n if (measureColumns.length === 1 && this.gridOptionsWrapper.isRemovePivotHeaderRowWhenSingleValueColumn() && index === maxDepth - 1) {\n var leafCols_1 = [];\n _.iterateObject(uniqueValue, function (key) {\n var newPivotKeys = __spread(pivotKeys, [key]);\n leafCols_1.push(__assign(__assign({}, _this.createColDef(measureColumns[0], key, newPivotKeys)), { columnGroupShow: 'open' }));\n });\n leafCols_1.sort(comparator);\n return leafCols_1;\n }\n // Recursive case\n var groups = [];\n _.iterateObject(uniqueValue, function (key, value) {\n var newPivotKeys = __spread(pivotKeys, [key]);\n groups.push({\n children: _this.recursiveBuildGroup(index + 1, value, newPivotKeys, maxDepth, primaryPivotColumns),\n headerName: key,\n pivotKeys: newPivotKeys,\n columnGroupShow: 'open',\n groupId: _this.generateColumnGroupId(newPivotKeys),\n });\n });\n groups.sort(comparator);\n return groups;\n };\n PivotColDefService.prototype.buildMeasureCols = function (pivotKeys) {\n var _this = this;\n var measureColumns = this.columnModel.getValueColumns();\n if (measureColumns.length === 0) {\n // if no value columns selected, then we insert one blank column, so the user at least sees columns\n // rendered. otherwise the grid would render with no columns (just empty groups) which would give the\n // impression that the grid is broken\n return [this.createColDef(null, '-', pivotKeys)];\n }\n return measureColumns.map(function (measureCol) {\n var columnName = _this.columnModel.getDisplayNameForColumn(measureCol, 'header');\n return __assign(__assign({}, _this.createColDef(measureCol, columnName, pivotKeys)), { columnGroupShow: 'open' });\n });\n };\n ;\n PivotColDefService.prototype.addExpandablePivotGroups = function (pivotColumnGroupDefs, pivotColumnDefs) {\n var _this = this;\n if (this.gridOptionsWrapper.isSuppressExpandablePivotGroups() ||\n this.gridOptionsWrapper.getPivotColumnGroupTotals()) {\n return;\n }\n var recursivelyAddSubTotals = function (groupDef, currentPivotColumnDefs, acc) {\n var group = groupDef;\n if (group.children) {\n var childAcc_1 = new Map();\n group.children.forEach(function (grp) {\n recursivelyAddSubTotals(grp, currentPivotColumnDefs, childAcc_1);\n });\n var firstGroup_1 = !group.children.some(function (child) { return child.children; });\n _this.columnModel.getValueColumns().forEach(function (valueColumn) {\n var columnName = _this.columnModel.getDisplayNameForColumn(valueColumn, 'header');\n var totalColDef = _this.createColDef(valueColumn, columnName, groupDef.pivotKeys);\n totalColDef.pivotTotalColumnIds = childAcc_1.get(valueColumn.getColId());\n totalColDef.columnGroupShow = 'closed';\n totalColDef.aggFunc = valueColumn.getAggFunc();\n if (!firstGroup_1) {\n // add total colDef to group and pivot colDefs array\n var children = groupDef.children;\n children.push(totalColDef);\n currentPivotColumnDefs.push(totalColDef);\n }\n });\n _this.merge(acc, childAcc_1);\n }\n else {\n var def = groupDef;\n // check that value column exists, i.e. aggFunc is supplied\n if (!def.pivotValueColumn) {\n return;\n }\n var pivotValueColId = def.pivotValueColumn.getColId();\n var arr = acc.has(pivotValueColId) ? acc.get(pivotValueColId) : [];\n arr.push(def.colId);\n acc.set(pivotValueColId, arr);\n }\n };\n pivotColumnGroupDefs.forEach(function (groupDef) {\n recursivelyAddSubTotals(groupDef, pivotColumnDefs, new Map());\n });\n };\n PivotColDefService.prototype.addPivotTotalsToGroups = function (pivotColumnGroupDefs, pivotColumnDefs) {\n var _this = this;\n if (!this.gridOptionsWrapper.getPivotColumnGroupTotals()) {\n return;\n }\n var insertAfter = this.gridOptionsWrapper.getPivotColumnGroupTotals() === 'after';\n var valueCols = this.columnModel.getValueColumns();\n var aggFuncs = valueCols.map(function (valueCol) { return valueCol.getAggFunc(); });\n // don't add pivot totals if there is less than 1 aggFunc or they are not all the same\n if (!aggFuncs || aggFuncs.length < 1 || !this.sameAggFuncs(aggFuncs)) {\n // console.warn('AG Grid: aborting adding pivot total columns - value columns require same aggFunc');\n return;\n }\n // arbitrarily select a value column to use as a template for pivot columns\n var valueColumn = valueCols[0];\n pivotColumnGroupDefs.forEach(function (groupDef) {\n _this.recursivelyAddPivotTotal(groupDef, pivotColumnDefs, valueColumn, insertAfter);\n });\n };\n PivotColDefService.prototype.recursivelyAddPivotTotal = function (groupDef, pivotColumnDefs, valueColumn, insertAfter) {\n var _this = this;\n var group = groupDef;\n if (!group.children) {\n var def = groupDef;\n return def.colId ? [def.colId] : null;\n }\n var colIds = [];\n // need to recurse children first to obtain colIds used in the aggregation stage\n group.children\n .forEach(function (grp) {\n var childColIds = _this.recursivelyAddPivotTotal(grp, pivotColumnDefs, valueColumn, insertAfter);\n if (childColIds) {\n colIds = colIds.concat(childColIds);\n }\n });\n // only add total colDef if there is more than 1 child node\n if (group.children.length > 1) {\n var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();\n var headerName = localeTextFunc('pivotColumnGroupTotals', 'Total');\n //create total colDef using an arbitrary value column as a template\n var totalColDef = this.createColDef(valueColumn, headerName, groupDef.pivotKeys, true);\n totalColDef.pivotTotalColumnIds = colIds;\n totalColDef.aggFunc = valueColumn.getAggFunc();\n // add total colDef to group and pivot colDefs array\n var children = groupDef.children;\n insertAfter ? children.push(totalColDef) : children.unshift(totalColDef);\n pivotColumnDefs.push(totalColDef);\n }\n return colIds;\n };\n PivotColDefService.prototype.addRowGroupTotals = function (pivotColumnGroupDefs, pivotColumnDefs, valueColumns) {\n var _this = this;\n if (!this.gridOptionsWrapper.getPivotRowTotals()) {\n return;\n }\n var insertAfter = this.gridOptionsWrapper.getPivotRowTotals() === 'after';\n // order of row group totals depends on position\n var valueCols = insertAfter ? valueColumns.slice() : valueColumns.slice().reverse();\n var _loop_1 = function (i) {\n var valueCol = valueCols[i];\n var colIds = [];\n pivotColumnGroupDefs.forEach(function (groupDef) {\n colIds = colIds.concat(_this.extractColIdsForValueColumn(groupDef, valueCol));\n });\n this_1.createRowGroupTotal(pivotColumnGroupDefs, pivotColumnDefs, valueCol, colIds, insertAfter);\n };\n var this_1 = this;\n for (var i = 0; i < valueCols.length; i++) {\n _loop_1(i);\n }\n };\n PivotColDefService.prototype.extractColIdsForValueColumn = function (groupDef, valueColumn) {\n var _this = this;\n var group = groupDef;\n if (!group.children) {\n var colDef = group;\n return colDef.pivotValueColumn === valueColumn && colDef.colId ? [colDef.colId] : [];\n }\n var colIds = [];\n group.children\n .forEach(function (grp) {\n _this.extractColIdsForValueColumn(grp, valueColumn);\n var childColIds = _this.extractColIdsForValueColumn(grp, valueColumn);\n colIds = colIds.concat(childColIds);\n });\n return colIds;\n };\n PivotColDefService.prototype.createRowGroupTotal = function (parentChildren, pivotColumnDefs, valueColumn, colIds, insertAfter) {\n var measureColumns = this.columnModel.getValueColumns();\n var colDef;\n if (measureColumns.length === 0) {\n colDef = this.createColDef(null, '-', []);\n }\n else {\n var columnName = this.columnModel.getDisplayNameForColumn(valueColumn, 'header');\n colDef = this.createColDef(valueColumn, columnName, []);\n colDef.pivotTotalColumnIds = colIds;\n }\n colDef.colId = PivotColDefService_1.PIVOT_ROW_TOTAL_PREFIX + colDef.colId;\n pivotColumnDefs.push(colDef);\n insertAfter ? parentChildren.push(colDef) : parentChildren.unshift(colDef);\n };\n PivotColDefService.prototype.createColDef = function (valueColumn, headerName, pivotKeys, totalColumn) {\n if (totalColumn === void 0) { totalColumn = false; }\n var colDef = {};\n // This is null when there are no measure columns and we're creating placeholder columns\n if (valueColumn) {\n var colDefToCopy = valueColumn.getColDef();\n Object.assign(colDef, colDefToCopy);\n // even if original column was hidden, we always show the pivot value column, otherwise it would be\n // very confusing for people thinking the pivot is broken\n colDef.hide = false;\n }\n colDef.headerName = headerName;\n colDef.colId = this.generateColumnId(pivotKeys || [], valueColumn && !totalColumn ? valueColumn.getColId() : '');\n // pivot columns repeat over field, so it makes sense to use the unique id instead. For example if you want to\n // assign values to pinned bottom rows using setPinnedBottomRowData the value service will use this colId.\n colDef.field = colDef.colId;\n colDef.pivotKeys = pivotKeys;\n colDef.pivotValueColumn = valueColumn;\n if (colDef.filter === true) {\n colDef.filter = 'agNumberColumnFilter';\n }\n return colDef;\n };\n PivotColDefService.prototype.sameAggFuncs = function (aggFuncs) {\n if (aggFuncs.length == 1) {\n return true;\n }\n //check if all aggFunc's match\n for (var i = 1; i < aggFuncs.length; i++) {\n if (aggFuncs[i] !== aggFuncs[0]) {\n return false;\n }\n }\n return true;\n };\n PivotColDefService.prototype.headerNameComparator = function (userComparator, a, b) {\n if (userComparator) {\n return userComparator(a.headerName, b.headerName);\n }\n else {\n if (a.headerName && !b.headerName) {\n return 1;\n }\n else if (!a.headerName && b.headerName) {\n return -1;\n }\n // slightly naff here - just to satify typescript\n // really should be &&, but if so ts complains\n // the above if/else checks would deal with either being falsy, so at this stage if either are falsy, both are\n // ..still naff though\n if (!a.headerName || !b.headerName) {\n return 0;\n }\n if (a.headerName < b.headerName) {\n return -1;\n }\n if (a.headerName > b.headerName) {\n return 1;\n }\n return 0;\n }\n };\n PivotColDefService.prototype.merge = function (m1, m2) {\n m2.forEach(function (value, key, map) {\n var existingList = m1.has(key) ? m1.get(key) : [];\n var updatedList = __spread(existingList, value);\n m1.set(key, updatedList);\n });\n };\n PivotColDefService.prototype.generateColumnGroupId = function (pivotKeys) {\n var pivotCols = this.columnModel.getPivotColumns().map(function (col) { return col.getColId(); });\n return \"pivotGroup_\" + pivotCols.join('-') + \"_\" + pivotKeys.join('-');\n };\n PivotColDefService.prototype.generateColumnId = function (pivotKeys, measureColumnId) {\n var pivotCols = this.columnModel.getPivotColumns().map(function (col) { return col.getColId(); });\n return \"pivot_\" + pivotCols.join('-') + \"_\" + pivotKeys.join('-') + \"_\" + measureColumnId;\n };\n var PivotColDefService_1;\n PivotColDefService.PIVOT_ROW_TOTAL_PREFIX = 'PivotRowTotal_';\n __decorate([\n Autowired('columnModel')\n ], PivotColDefService.prototype, \"columnModel\", void 0);\n PivotColDefService = PivotColDefService_1 = __decorate([\n Bean('pivotColDefService')\n ], PivotColDefService);\n return PivotColDefService;\n}(BeanStub));\nexport { PivotColDefService };\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, BeanStub, _ } from \"@ag-grid-community/core\";\nvar PivotStage = /** @class */ (function (_super) {\n __extends(PivotStage, _super);\n function PivotStage() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.uniqueValues = {};\n return _this;\n }\n PivotStage.prototype.execute = function (params) {\n var rootNode = params.rowNode;\n var changedPath = params.changedPath;\n if (this.columnModel.isPivotActive()) {\n this.executePivotOn(rootNode, changedPath);\n }\n else {\n this.executePivotOff(changedPath);\n }\n };\n PivotStage.prototype.executePivotOff = function (changedPath) {\n this.aggregationColumnsHashLastTime = null;\n this.uniqueValues = {};\n if (this.columnModel.isSecondaryColumnsPresent()) {\n this.columnModel.setSecondaryColumns(null, \"rowModelUpdated\");\n if (changedPath) {\n changedPath.setInactive();\n }\n }\n };\n PivotStage.prototype.executePivotOn = function (rootNode, changedPath) {\n var uniqueValues = this.bucketUpRowNodes(rootNode);\n var uniqueValuesChanged = this.setUniqueValues(uniqueValues);\n var aggregationColumns = this.columnModel.getValueColumns();\n var aggregationColumnsHash = aggregationColumns.map(function (column) { return column.getId() + \"-\" + column.getColDef().headerName; }).join('#');\n var aggregationFuncsHash = aggregationColumns.map(function (column) { return column.getAggFunc().toString(); }).join('#');\n var aggregationColumnsChanged = this.aggregationColumnsHashLastTime !== aggregationColumnsHash;\n var aggregationFuncsChanged = this.aggregationFuncsHashLastTime !== aggregationFuncsHash;\n this.aggregationColumnsHashLastTime = aggregationColumnsHash;\n this.aggregationFuncsHashLastTime = aggregationFuncsHash;\n var groupColumnsHash = this.columnModel.getRowGroupColumns().map(function (column) { return column.getId(); }).join('#');\n var groupColumnsChanged = groupColumnsHash !== this.groupColumnsHashLastTime;\n this.groupColumnsHashLastTime = groupColumnsHash;\n if (uniqueValuesChanged || aggregationColumnsChanged || groupColumnsChanged || aggregationFuncsChanged) {\n var _a = this.pivotColDefService.createPivotColumnDefs(this.uniqueValues), pivotColumnGroupDefs = _a.pivotColumnGroupDefs, pivotColumnDefs = _a.pivotColumnDefs;\n this.pivotColumnDefs = pivotColumnDefs;\n this.columnModel.setSecondaryColumns(pivotColumnGroupDefs, \"rowModelUpdated\");\n // because the secondary columns have changed, then the aggregation needs to visit the whole\n // tree again, so we make the changedPath not active, to force aggregation to visit all paths.\n if (changedPath) {\n changedPath.setInactive();\n }\n }\n };\n PivotStage.prototype.setUniqueValues = function (newValues) {\n var json1 = JSON.stringify(newValues);\n var json2 = JSON.stringify(this.uniqueValues);\n var uniqueValuesChanged = json1 !== json2;\n // we only continue the below if the unique values are different, as otherwise\n // the result will be the same as the last time we did it\n if (uniqueValuesChanged) {\n this.uniqueValues = newValues;\n return true;\n }\n else {\n return false;\n }\n };\n // returns true if values were different\n PivotStage.prototype.bucketUpRowNodes = function (rootNode) {\n var _this = this;\n // accessed from inside inner function\n var uniqueValues = {};\n // finds all leaf groups and calls mapRowNode with it\n var recursivelySearchForLeafNodes = function (rowNode) {\n if (rowNode.leafGroup) {\n _this.bucketRowNode(rowNode, uniqueValues);\n }\n else {\n rowNode.childrenAfterFilter.forEach(function (child) {\n recursivelySearchForLeafNodes(child);\n });\n }\n };\n recursivelySearchForLeafNodes(rootNode);\n return uniqueValues;\n };\n PivotStage.prototype.bucketRowNode = function (rowNode, uniqueValues) {\n var pivotColumns = this.columnModel.getPivotColumns();\n if (pivotColumns.length === 0) {\n rowNode.childrenMapped = null;\n }\n else {\n rowNode.childrenMapped = this.bucketChildren(rowNode.childrenAfterFilter, pivotColumns, 0, uniqueValues);\n }\n if (rowNode.sibling) {\n rowNode.sibling.childrenMapped = rowNode.childrenMapped;\n }\n };\n PivotStage.prototype.bucketChildren = function (children, pivotColumns, pivotIndex, uniqueValues) {\n var _this = this;\n var mappedChildren = {};\n var pivotColumn = pivotColumns[pivotIndex];\n // map the children out based on the pivot column\n children.forEach(function (child) {\n var key = _this.valueService.getKeyForNode(pivotColumn, child);\n if (_.missing(key)) {\n key = '';\n }\n if (!uniqueValues[key]) {\n uniqueValues[key] = {};\n }\n if (!mappedChildren[key]) {\n mappedChildren[key] = [];\n }\n mappedChildren[key].push(child);\n });\n // if it's the last pivot column, return as is, otherwise go one level further in the map\n if (pivotIndex === pivotColumns.length - 1) {\n return mappedChildren;\n }\n else {\n var result_1 = {};\n _.iterateObject(mappedChildren, function (key, value) {\n result_1[key] = _this.bucketChildren(value, pivotColumns, pivotIndex + 1, uniqueValues[key]);\n });\n return result_1;\n }\n };\n PivotStage.prototype.getPivotColumnDefs = function () {\n return this.pivotColumnDefs;\n };\n __decorate([\n Autowired('valueService')\n ], PivotStage.prototype, \"valueService\", void 0);\n __decorate([\n Autowired('columnModel')\n ], PivotStage.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('pivotColDefService')\n ], PivotStage.prototype, \"pivotColDefService\", void 0);\n PivotStage = __decorate([\n Bean('pivotStage')\n ], PivotStage);\n return PivotStage;\n}(BeanStub));\nexport { PivotStage };\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean, BeanStub, PostConstruct, _ } from '@ag-grid-community/core';\n// @ts-ignore\nvar AGBigInt = typeof BigInt === 'undefined' ? null : BigInt;\nvar AggFuncService = /** @class */ (function (_super) {\n __extends(AggFuncService, _super);\n function AggFuncService() {\n var _this = _super !== null && _super.apply(this, arguments) || this;\n _this.aggFuncsMap = {};\n _this.initialised = false;\n return _this;\n }\n AggFuncService_1 = AggFuncService;\n AggFuncService.prototype.init = function () {\n if (this.initialised) {\n return;\n }\n this.initialiseWithDefaultAggregations();\n this.addAggFuncs(this.gridOptionsWrapper.getAggFuncs());\n };\n AggFuncService.prototype.initialiseWithDefaultAggregations = function () {\n this.aggFuncsMap[AggFuncService_1.AGG_SUM] = aggSum;\n this.aggFuncsMap[AggFuncService_1.AGG_FIRST] = aggFirst;\n this.aggFuncsMap[AggFuncService_1.AGG_LAST] = aggLast;\n this.aggFuncsMap[AggFuncService_1.AGG_MIN] = aggMin;\n this.aggFuncsMap[AggFuncService_1.AGG_MAX] = aggMax;\n this.aggFuncsMap[AggFuncService_1.AGG_COUNT] = aggCount;\n this.aggFuncsMap[AggFuncService_1.AGG_AVG] = aggAvg;\n this.initialised = true;\n };\n AggFuncService.prototype.isAggFuncPossible = function (column, func) {\n var allKeys = this.getFuncNames(column);\n var allowed = _.includes(allKeys, func);\n var funcExists = _.exists(this.aggFuncsMap[func]);\n return allowed && funcExists;\n };\n AggFuncService.prototype.getDefaultAggFunc = function (column) {\n var defaultAgg = column.getColDef().defaultAggFunc;\n if (_.exists(defaultAgg) && this.isAggFuncPossible(column, defaultAgg)) {\n return defaultAgg;\n }\n if (this.isAggFuncPossible(column, AggFuncService_1.AGG_SUM)) {\n return AggFuncService_1.AGG_SUM;\n }\n var allKeys = this.getFuncNames(column);\n return _.existsAndNotEmpty(allKeys) ? allKeys[0] : null;\n };\n AggFuncService.prototype.addAggFuncs = function (aggFuncs) {\n _.iterateObject(aggFuncs, this.addAggFunc.bind(this));\n };\n AggFuncService.prototype.addAggFunc = function (key, aggFunc) {\n this.init();\n this.aggFuncsMap[key] = aggFunc;\n };\n AggFuncService.prototype.getAggFunc = function (name) {\n this.init();\n return this.aggFuncsMap[name];\n };\n AggFuncService.prototype.getFuncNames = function (column) {\n var userAllowedFuncs = column.getColDef().allowedAggFuncs;\n return userAllowedFuncs == null ? Object.keys(this.aggFuncsMap).sort() : userAllowedFuncs;\n };\n AggFuncService.prototype.clear = function () {\n this.aggFuncsMap = {};\n };\n var AggFuncService_1;\n AggFuncService.AGG_SUM = 'sum';\n AggFuncService.AGG_FIRST = 'first';\n AggFuncService.AGG_LAST = 'last';\n AggFuncService.AGG_MIN = 'min';\n AggFuncService.AGG_MAX = 'max';\n AggFuncService.AGG_COUNT = 'count';\n AggFuncService.AGG_AVG = 'avg';\n __decorate([\n PostConstruct\n ], AggFuncService.prototype, \"init\", null);\n AggFuncService = AggFuncService_1 = __decorate([\n Bean('aggFuncService')\n ], AggFuncService);\n return AggFuncService;\n}(BeanStub));\nexport { AggFuncService };\nfunction aggSum(params) {\n var values = params.values;\n var result = null; // the logic ensures that we never combine bigint arithmetic with numbers, but TS is hard to please\n // for optimum performance, we use a for loop here rather than calling any helper methods or using functional code\n for (var i = 0; i < values.length; i++) {\n var value = values[i];\n if (typeof value === 'number') {\n if (result === null) {\n result = value;\n }\n else {\n if (AGBigInt) {\n result += typeof result === 'number' ? value : AGBigInt(value);\n }\n else {\n result += value;\n }\n }\n }\n else if (typeof value === 'bigint') {\n if (result === null) {\n result = value;\n }\n else {\n result = (typeof result === 'bigint' ? result : AGBigInt(result)) + value;\n }\n }\n }\n return result;\n}\nfunction aggFirst(params) {\n return params.values.length > 0 ? params.values[0] : null;\n}\nfunction aggLast(params) {\n return params.values.length > 0 ? _.last(params.values) : null;\n}\nfunction aggMin(params) {\n var values = params.values;\n var result = null;\n // for optimum performance, we use a for loop here rather than calling any helper methods or using functional code\n for (var i = 0; i < values.length; i++) {\n var value = values[i];\n if ((typeof value === 'number' || typeof value === 'bigint') && (result === null || result > value)) {\n result = value;\n }\n }\n return result;\n}\nfunction aggMax(params) {\n var values = params.values;\n var result = null;\n // for optimum performance, we use a for loop here rather than calling any helper methods or using functional code\n for (var i = 0; i < values.length; i++) {\n var value = values[i];\n if ((typeof value === 'number' || typeof value === 'bigint') && (result === null || result < value)) {\n result = value;\n }\n }\n return result;\n}\nfunction aggCount(params) {\n var values = params.values;\n var result = 0;\n // for optimum performance, we use a for loop here rather than calling any helper methods or using functional code\n for (var i = 0; i < values.length; i++) {\n var value = values[i];\n // check if the value is from a group, in which case use the group's count\n result += value != null && typeof value.value === 'number' ? value.value : 1;\n }\n return {\n value: result,\n toString: function () {\n return this.value.toString();\n },\n // used for sorting\n toNumber: function () {\n return this.value;\n }\n };\n}\n// the average function is tricky as the multiple levels require weighted averages\n// for the non-leaf node aggregations.\nfunction aggAvg(params) {\n var values = params.values;\n var sum = 0; // the logic ensures that we never combine bigint arithmetic with numbers, but TS is hard to please\n var count = 0;\n // for optimum performance, we use a for loop here rather than calling any helper methods or using functional code\n for (var i = 0; i < values.length; i++) {\n var currentValue = values[i];\n var valueToAdd = null;\n if (typeof currentValue === 'number' || typeof currentValue === 'bigint') {\n valueToAdd = currentValue;\n count++;\n }\n else if (currentValue != null && (typeof currentValue.value === 'number' || typeof currentValue.value === 'bigint') && typeof currentValue.count === 'number') {\n // we are aggregating groups, so we take the aggregated values to calculated a weighted average\n if (AGBigInt) {\n valueToAdd = currentValue.value * (typeof currentValue.value === 'number' ? currentValue.count : AGBigInt(currentValue.count));\n }\n else {\n valueToAdd = currentValue.value * currentValue.count;\n }\n count += currentValue.count;\n }\n if (typeof valueToAdd === 'number') {\n if (AGBigInt) {\n sum += typeof sum === 'number' ? valueToAdd : AGBigInt(valueToAdd);\n }\n else {\n sum += valueToAdd;\n }\n }\n else if (typeof valueToAdd === 'bigint') {\n sum = (typeof sum === 'bigint' ? sum : AGBigInt(sum)) + valueToAdd;\n }\n }\n var value = null;\n // avoid divide by zero error\n if (count > 0) {\n if (AGBigInt) {\n value = sum / (typeof sum === 'number' ? count : AGBigInt(count));\n }\n else {\n value = sum / count;\n }\n }\n // the result will be an object. when this cell is rendered, only the avg is shown.\n // however when this cell is part of another aggregation, the count is also needed\n // to create a weighted average for the next level.\n return {\n count: count,\n value: value,\n // the grid by default uses toString to render values for an object, so this\n // is a trick to get the default cellRenderer to display the avg value\n toString: function () {\n return typeof this.value === 'number' || typeof this.value === 'bigint' ? this.value.toString() : '';\n },\n // used for sorting\n toNumber: function () {\n return this.value;\n }\n };\n}\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { DragSourceType, Component, Autowired, Events, TouchListener, DragAndDropService, PostConstruct, Column, RefSelector, Optional, VirtualList, KeyCode, _, } from \"@ag-grid-community/core\";\nvar DropZoneColumnComp = /** @class */ (function (_super) {\n __extends(DropZoneColumnComp, _super);\n function DropZoneColumnComp(column, dragSourceDropTarget, ghost, dropZonePurpose, horizontal) {\n var _this = _super.call(this) || this;\n _this.column = column;\n _this.dragSourceDropTarget = dragSourceDropTarget;\n _this.ghost = ghost;\n _this.dropZonePurpose = dropZonePurpose;\n _this.horizontal = horizontal;\n _this.popupShowing = false;\n return _this;\n }\n DropZoneColumnComp.prototype.init = function () {\n var _this = this;\n this.setTemplate(DropZoneColumnComp.TEMPLATE);\n var eGui = this.getGui();\n var isFunctionsReadOnly = this.gridOptionsWrapper.isFunctionsReadOnly();\n this.addElementClasses(eGui);\n this.addElementClasses(this.eDragHandle, 'drag-handle');\n this.addElementClasses(this.eText, 'text');\n this.addElementClasses(this.eButton, 'button');\n this.eDragHandle.appendChild(_.createIconNoSpan('columnDrag', this.gridOptionsWrapper));\n this.eButton.appendChild(_.createIconNoSpan('cancel', this.gridOptionsWrapper));\n this.setupSort();\n this.displayName = this.columnModel.getDisplayNameForColumn(this.column, 'columnDrop');\n this.setupComponents();\n if (!this.ghost && !isFunctionsReadOnly) {\n this.addDragSource();\n }\n this.setupAria();\n this.addManagedListener(this.column, Column.EVENT_SORT_CHANGED, function () {\n _this.setupAria();\n });\n this.setupTooltip();\n };\n DropZoneColumnComp.prototype.setupAria = function () {\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n var _a = this.getColumnAndAggFuncName(), name = _a.name, aggFuncName = _a.aggFuncName;\n var aggSeparator = translate('ariaDropZoneColumnComponentAggFuncSeperator', ' of ');\n var sortDirection = {\n asc: translate('ariaDropZoneColumnComponentSortAscending', 'ascending'),\n desc: translate('ariaDropZoneColumnComponentSortDescending', 'descending'),\n };\n var columnSort = this.column.getSort();\n var ariaInstructions = [\n [\n aggFuncName && \"\" + aggFuncName + aggSeparator,\n name,\n this.isGroupingZone() && columnSort && \", \" + sortDirection[columnSort]\n ].filter(function (part) { return !!part; }).join(''),\n ];\n var isFunctionsReadOnly = this.gridOptionsWrapper.isFunctionsReadOnly();\n if (this.isAggregationZone() && !isFunctionsReadOnly) {\n var aggregationMenuAria = translate('ariaDropZoneColumnValueItemDescription', 'Press ENTER to change the aggregation type');\n ariaInstructions.push(aggregationMenuAria);\n }\n if (this.isGroupingZone() && this.column.getColDef().sortable) {\n var sortProgressAria = translate('ariaDropZoneColumnGroupItemDescription', 'Press ENTER to sort');\n ariaInstructions.push(sortProgressAria);\n }\n var deleteAria = translate('ariaDropZoneColumnComponentDescription', 'Press DELETE to remove');\n ariaInstructions.push(deleteAria);\n _.setAriaLabel(this.getGui(), ariaInstructions.join('. '));\n };\n DropZoneColumnComp.prototype.setupTooltip = function () {\n var _this = this;\n var refresh = function () {\n var newTooltipText = _this.column.getColDef().headerTooltip;\n _this.setTooltip(newTooltipText);\n };\n refresh();\n this.addManagedListener(this.eventService, Events.EVENT_NEW_COLUMNS_LOADED, refresh);\n };\n DropZoneColumnComp.prototype.setupSort = function () {\n var _this = this;\n var canSort = this.column.getColDef().sortable;\n var isGroupingZone = this.isGroupingZone();\n if (!canSort || !isGroupingZone) {\n return;\n }\n this.eSortIndicator.setupSort(this.column, true);\n var performSort = function (event) {\n event.preventDefault();\n var sortUsingCtrl = _this.gridOptionsWrapper.isMultiSortKeyCtrl();\n var multiSort = sortUsingCtrl ? (event.ctrlKey || event.metaKey) : event.shiftKey;\n _this.sortController.progressSort(_this.column, multiSort, 'uiColumnSorted');\n };\n this.addGuiEventListener('click', performSort);\n this.addGuiEventListener('keydown', function (e) {\n var isEnter = e.key === KeyCode.ENTER;\n if (isEnter && _this.isGroupingZone()) {\n performSort(e);\n }\n });\n };\n DropZoneColumnComp.prototype.addDragSource = function () {\n var _this = this;\n var dragSource = {\n type: DragSourceType.ToolPanel,\n eElement: this.eDragHandle,\n defaultIconName: DragAndDropService.ICON_HIDE,\n getDragItem: function () { return _this.createDragItem(); },\n dragItemName: this.displayName,\n dragSourceDropTarget: this.dragSourceDropTarget\n };\n this.dragAndDropService.addDragSource(dragSource, true);\n this.addDestroyFunc(function () { return _this.dragAndDropService.removeDragSource(dragSource); });\n };\n DropZoneColumnComp.prototype.createDragItem = function () {\n var visibleState = {};\n visibleState[this.column.getId()] = this.column.isVisible();\n return {\n columns: [this.column],\n visibleState: visibleState\n };\n };\n DropZoneColumnComp.prototype.setupComponents = function () {\n this.setTextValue();\n this.setupRemove();\n if (this.ghost) {\n this.addCssClass('ag-column-drop-cell-ghost');\n }\n if (this.isAggregationZone() && !this.gridOptionsWrapper.isFunctionsReadOnly()) {\n this.addGuiEventListener('click', this.onShowAggFuncSelection.bind(this));\n }\n };\n DropZoneColumnComp.prototype.setupRemove = function () {\n var _this = this;\n _.setDisplayed(this.eButton, !this.gridOptionsWrapper.isFunctionsReadOnly());\n var agEvent = { type: DropZoneColumnComp.EVENT_COLUMN_REMOVE };\n this.addGuiEventListener('keydown', function (e) {\n var isEnter = e.key === KeyCode.ENTER;\n var isDelete = e.key === KeyCode.DELETE;\n if (isDelete) {\n e.preventDefault();\n _this.dispatchEvent(agEvent);\n }\n if (isEnter && _this.isAggregationZone() && !_this.gridOptionsWrapper.isFunctionsReadOnly()) {\n e.preventDefault();\n _this.onShowAggFuncSelection();\n }\n });\n this.addManagedListener(this.eButton, 'click', function (mouseEvent) {\n _this.dispatchEvent(agEvent);\n mouseEvent.stopPropagation();\n });\n var touchListener = new TouchListener(this.eButton);\n this.addManagedListener(touchListener, TouchListener.EVENT_TAP, function () {\n _this.dispatchEvent(agEvent);\n });\n this.addDestroyFunc(touchListener.destroy.bind(touchListener));\n };\n DropZoneColumnComp.prototype.getColumnAndAggFuncName = function () {\n var name = this.displayName;\n var aggFuncName = '';\n if (this.isAggregationZone()) {\n var aggFunc = this.column.getAggFunc();\n // if aggFunc is a string, we can use it, but if it's a function, then we swap with 'func'\n var aggFuncString = typeof aggFunc === 'string' ? aggFunc : 'agg';\n var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();\n aggFuncName = localeTextFunc(aggFuncString, aggFuncString);\n }\n return { name: name, aggFuncName: aggFuncName };\n };\n DropZoneColumnComp.prototype.setTextValue = function () {\n var _a = this.getColumnAndAggFuncName(), name = _a.name, aggFuncName = _a.aggFuncName;\n var displayValue = this.isAggregationZone() ? aggFuncName + \"(\" + name + \")\" : name;\n var displayValueSanitised = _.escapeString(displayValue);\n this.eText.innerHTML = displayValueSanitised;\n };\n DropZoneColumnComp.prototype.onShowAggFuncSelection = function () {\n var _this = this;\n if (this.popupShowing) {\n return;\n }\n this.popupShowing = true;\n var virtualList = new VirtualList('select-agg-func');\n var rows = this.aggFuncService.getFuncNames(this.column);\n var eGui = this.getGui();\n var virtualListGui = virtualList.getGui();\n virtualList.setModel({\n getRow: function (index) { return rows[index]; },\n getRowCount: function () { return rows.length; }\n });\n this.getContext().createBean(virtualList);\n var ePopup = _.loadTemplate(/* html*/ \"
\");\n ePopup.style.top = '0px';\n ePopup.style.left = '0px';\n ePopup.appendChild(virtualListGui);\n // ePopup.style.height = this.gridOptionsWrapper.getAggFuncPopupHeight() + 'px';\n ePopup.style.width = eGui.clientWidth + \"px\";\n var popupHiddenFunc = function () {\n _this.destroyBean(virtualList);\n _this.popupShowing = false;\n eGui.focus();\n };\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n var addPopupRes = this.popupService.addPopup({\n modal: true,\n eChild: ePopup,\n closeOnEsc: true,\n closedCallback: popupHiddenFunc,\n ariaLabel: translate('ariaLabelAggregationFunction', 'Aggregation Function')\n });\n if (addPopupRes) {\n virtualList.setComponentCreator(this.createAggSelect.bind(this, addPopupRes.hideFunc));\n }\n virtualList.addGuiEventListener('keydown', function (e) {\n if (e.key === KeyCode.ENTER || e.key === KeyCode.SPACE) {\n var row = virtualList.getLastFocusedRow();\n if (row == null) {\n return;\n }\n var comp = virtualList.getComponentAt(row);\n if (comp) {\n comp.selectItem();\n }\n }\n });\n this.popupService.positionPopupUnderComponent({\n type: 'aggFuncSelect',\n eventSource: eGui,\n ePopup: ePopup,\n keepWithinBounds: true,\n column: this.column\n });\n virtualList.refresh();\n var rowToFocus = rows.findIndex(function (r) { return r === _this.column.getAggFunc(); });\n if (rowToFocus === -1) {\n rowToFocus = 0;\n }\n virtualList.focusRow(rowToFocus);\n };\n DropZoneColumnComp.prototype.createAggSelect = function (hidePopup, value) {\n var _this = this;\n var itemSelected = function () {\n hidePopup();\n if (_this.gridOptionsWrapper.isFunctionsPassive()) {\n var event_1 = {\n type: Events.EVENT_COLUMN_AGG_FUNC_CHANGE_REQUEST,\n columns: [_this.column],\n aggFunc: value\n };\n _this.eventService.dispatchEvent(event_1);\n }\n else {\n _this.columnModel.setColumnAggFunc(_this.column, value, \"toolPanelDragAndDrop\");\n }\n };\n var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();\n var aggFuncString = value.toString();\n var aggFuncStringTranslated = localeTextFunc(aggFuncString, aggFuncString);\n var comp = new AggItemComp(itemSelected, aggFuncStringTranslated);\n return comp;\n };\n DropZoneColumnComp.prototype.addElementClasses = function (el, suffix) {\n suffix = suffix ? \"-\" + suffix : '';\n var direction = this.horizontal ? 'horizontal' : 'vertical';\n el.classList.add(\"ag-column-drop-cell\" + suffix, \"ag-column-drop-\" + direction + \"-cell\" + suffix);\n };\n DropZoneColumnComp.prototype.isAggregationZone = function () {\n return this.dropZonePurpose === 'aggregation';\n };\n DropZoneColumnComp.prototype.isGroupingZone = function () {\n return this.dropZonePurpose === 'rowGroup';\n };\n DropZoneColumnComp.EVENT_COLUMN_REMOVE = 'columnRemove';\n DropZoneColumnComp.TEMPLATE = \"\\n \\n \\n \\n \\n \";\n __decorate([\n Autowired('dragAndDropService')\n ], DropZoneColumnComp.prototype, \"dragAndDropService\", void 0);\n __decorate([\n Autowired('columnModel')\n ], DropZoneColumnComp.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('popupService')\n ], DropZoneColumnComp.prototype, \"popupService\", void 0);\n __decorate([\n Optional('aggFuncService')\n ], DropZoneColumnComp.prototype, \"aggFuncService\", void 0);\n __decorate([\n Autowired('sortController')\n ], DropZoneColumnComp.prototype, \"sortController\", void 0);\n __decorate([\n RefSelector('eText')\n ], DropZoneColumnComp.prototype, \"eText\", void 0);\n __decorate([\n RefSelector('eDragHandle')\n ], DropZoneColumnComp.prototype, \"eDragHandle\", void 0);\n __decorate([\n RefSelector('eButton')\n ], DropZoneColumnComp.prototype, \"eButton\", void 0);\n __decorate([\n RefSelector('eSortIndicator')\n ], DropZoneColumnComp.prototype, \"eSortIndicator\", void 0);\n __decorate([\n PostConstruct\n ], DropZoneColumnComp.prototype, \"init\", null);\n return DropZoneColumnComp;\n}(Component));\nexport { DropZoneColumnComp };\nvar AggItemComp = /** @class */ (function (_super) {\n __extends(AggItemComp, _super);\n function AggItemComp(itemSelected, value) {\n var _this = _super.call(this, /* html */ \"
\") || this;\n _this.selectItem = itemSelected;\n _this.getGui().innerText = value;\n _this.addGuiEventListener('click', _this.selectItem);\n return _this;\n }\n return AggItemComp;\n}(Component));\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __read = (this && this.__read) || function (o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n};\nvar __spread = (this && this.__spread) || function () {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n};\nimport { Autowired, Component, DragSourceType, Events, KeyCode, ManagedFocusFeature, PositionableFeature, _ } from \"@ag-grid-community/core\";\nimport { DropZoneColumnComp } from \"./dropZoneColumnComp\";\nvar BaseDropZonePanel = /** @class */ (function (_super) {\n __extends(BaseDropZonePanel, _super);\n function BaseDropZonePanel(horizontal, dropZonePurpose) {\n var _this = _super.call(this, /* html */ \"
\") || this;\n _this.horizontal = horizontal;\n _this.dropZonePurpose = dropZonePurpose;\n _this.state = BaseDropZonePanel.STATE_NOT_DRAGGING;\n _this.guiDestroyFunctions = [];\n _this.childColumnComponents = [];\n _this.resizeEnabled = false;\n _this.addElementClasses(_this.getGui());\n _this.eColumnDropList = document.createElement('div');\n _this.addElementClasses(_this.eColumnDropList, 'list');\n _.setAriaRole(_this.eColumnDropList, 'listbox');\n return _this;\n }\n BaseDropZonePanel.prototype.isHorizontal = function () {\n return this.horizontal;\n };\n BaseDropZonePanel.prototype.toggleResizable = function (resizable) {\n this.positionableFeature.setResizable(resizable ? { bottom: true } : false);\n this.resizeEnabled = resizable;\n };\n BaseDropZonePanel.prototype.setBeans = function (beans) {\n this.beans = beans;\n };\n BaseDropZonePanel.prototype.destroy = function () {\n this.destroyGui();\n _super.prototype.destroy.call(this);\n };\n BaseDropZonePanel.prototype.destroyGui = function () {\n this.guiDestroyFunctions.forEach(function (func) { return func(); });\n this.guiDestroyFunctions.length = 0;\n this.childColumnComponents.length = 0;\n _.clearElement(this.getGui());\n _.clearElement(this.eColumnDropList);\n };\n BaseDropZonePanel.prototype.init = function (params) {\n this.params = params;\n this.createManagedBean(new ManagedFocusFeature(this.getFocusableElement(), {\n handleKeyDown: this.handleKeyDown.bind(this)\n }));\n this.addManagedListener(this.beans.eventService, Events.EVENT_NEW_COLUMNS_LOADED, this.refreshGui.bind(this));\n this.addManagedListener(this.beans.gridOptionsWrapper, 'functionsReadOnly', this.refreshGui.bind(this));\n this.setupDropTarget();\n this.positionableFeature = new PositionableFeature(this.getGui(), { minHeight: 100 });\n this.createManagedBean(this.positionableFeature);\n // we don't know if this bean will be initialised before columnModel.\n // if columnModel first, then below will work\n // if columnModel second, then below will put blank in, and then above event gets first when columnModel is set up\n this.refreshGui();\n _.setAriaLabel(this.eColumnDropList, this.getAriaLabel());\n };\n BaseDropZonePanel.prototype.handleKeyDown = function (e) {\n var isVertical = !this.horizontal;\n var isNext = e.key === KeyCode.DOWN;\n var isPrevious = e.key === KeyCode.UP;\n if (!isVertical) {\n var isRtl = this.gridOptionsWrapper.isEnableRtl();\n isNext = (!isRtl && e.key === KeyCode.RIGHT) || (isRtl && e.key === KeyCode.LEFT);\n isPrevious = (!isRtl && e.key === KeyCode.LEFT) || (isRtl && e.key === KeyCode.RIGHT);\n }\n if (!isNext && !isPrevious) {\n return;\n }\n var el = this.focusService.findNextFocusableElement(this.getFocusableElement(), false, isPrevious);\n if (el) {\n e.preventDefault();\n el.focus();\n }\n };\n BaseDropZonePanel.prototype.addElementClasses = function (el, suffix) {\n suffix = suffix ? \"-\" + suffix : '';\n var direction = this.horizontal ? 'horizontal' : 'vertical';\n el.classList.add(\"ag-column-drop\" + suffix, \"ag-column-drop-\" + direction + suffix);\n };\n BaseDropZonePanel.prototype.setupDropTarget = function () {\n this.dropTarget = {\n getContainer: this.getGui.bind(this),\n getIconName: this.getIconName.bind(this),\n onDragging: this.onDragging.bind(this),\n onDragEnter: this.onDragEnter.bind(this),\n onDragLeave: this.onDragLeave.bind(this),\n onDragStop: this.onDragStop.bind(this),\n isInterestedIn: this.isInterestedIn.bind(this)\n };\n this.beans.dragAndDropService.addDropTarget(this.dropTarget);\n };\n BaseDropZonePanel.prototype.isInterestedIn = function (type) {\n // not interested in row drags\n return type === DragSourceType.HeaderCell || type === DragSourceType.ToolPanel;\n };\n BaseDropZonePanel.prototype.checkInsertIndex = function (draggingEvent) {\n var newIndex = this.getNewInsertIndex(draggingEvent);\n // <0 happens when drag is no a direction we are interested in, eg drag is up/down but in horizontal panel\n if (newIndex < 0) {\n return false;\n }\n var changed = newIndex !== this.insertIndex;\n if (changed) {\n this.insertIndex = newIndex;\n }\n return changed;\n };\n BaseDropZonePanel.prototype.getNewInsertIndex = function (draggingEvent) {\n var _this = this;\n var mouseEvent = draggingEvent.event;\n var mouseLocation = this.horizontal ? mouseEvent.clientX : mouseEvent.clientY;\n var boundsList = this.childColumnComponents.map(function (col) { return (col.getGui().getBoundingClientRect()); });\n // find the non-ghost component we're hovering\n var hoveredIndex = boundsList.findIndex(function (rect) { return (_this.horizontal ? (rect.right > mouseLocation && rect.left < mouseLocation) : (rect.top < mouseLocation && rect.bottom > mouseLocation)); });\n // not hovering a non-ghost component\n if (hoveredIndex === -1) {\n var enableRtl = this.beans.gridOptionsWrapper.isEnableRtl();\n // if mouse is below or right of all components then new index should be placed last\n var isLast = boundsList.every(function (rect) { return (mouseLocation > (_this.horizontal ? rect.right : rect.bottom)); });\n if (isLast) {\n return enableRtl && this.horizontal ? 0 : this.childColumnComponents.length;\n }\n // if mouse is above or left of all components, new index is first\n var isFirst = boundsList.every(function (rect) { return (mouseLocation < (_this.horizontal ? rect.left : rect.top)); });\n if (isFirst) {\n return enableRtl && this.horizontal ? this.childColumnComponents.length : 0;\n }\n // must be hovering a ghost, don't change the index\n return this.insertIndex;\n }\n // if the old index is equal to or less than the index of our new target\n // we need to shift right, to insert after rather than before\n if (this.insertIndex <= hoveredIndex) {\n return hoveredIndex + 1;\n }\n return hoveredIndex;\n };\n BaseDropZonePanel.prototype.checkDragStartedBySelf = function (draggingEvent) {\n if (this.state !== BaseDropZonePanel.STATE_NOT_DRAGGING) {\n return;\n }\n this.state = BaseDropZonePanel.STATE_REARRANGE_COLUMNS;\n this.potentialDndColumns = draggingEvent.dragSource.getDragItem().columns || [];\n this.refreshGui();\n this.checkInsertIndex(draggingEvent);\n this.refreshGui();\n };\n BaseDropZonePanel.prototype.onDragging = function (draggingEvent) {\n this.checkDragStartedBySelf(draggingEvent);\n if (this.checkInsertIndex(draggingEvent)) {\n this.refreshGui();\n }\n };\n BaseDropZonePanel.prototype.onDragEnter = function (draggingEvent) {\n // this will contain all columns that are potential drops\n var dragColumns = draggingEvent.dragSource.getDragItem().columns || [];\n this.state = BaseDropZonePanel.STATE_NEW_COLUMNS_IN;\n // take out columns that are not droppable\n var goodDragColumns = dragColumns.filter(this.isColumnDroppable.bind(this));\n if (goodDragColumns.length > 0) {\n var hideColumnOnExit = this.isRowGroupPanel() && !this.gridOptionsWrapper.isSuppressRowGroupHidesColumns() && !draggingEvent.fromNudge;\n if (hideColumnOnExit) {\n var dragItem = draggingEvent.dragSource.getDragItem();\n var columns = dragItem.columns;\n this.setColumnsVisible(columns, false, \"uiColumnDragged\");\n }\n this.potentialDndColumns = goodDragColumns;\n this.checkInsertIndex(draggingEvent);\n this.refreshGui();\n }\n };\n BaseDropZonePanel.prototype.setColumnsVisible = function (columns, visible, source) {\n if (source === void 0) { source = \"api\"; }\n if (columns) {\n var allowedCols = columns.filter(function (c) { return !c.getColDef().lockVisible; });\n this.colModel.setColumnsVisible(allowedCols, visible, source);\n }\n };\n BaseDropZonePanel.prototype.isPotentialDndColumns = function () {\n return _.existsAndNotEmpty(this.potentialDndColumns);\n };\n BaseDropZonePanel.prototype.isRowGroupPanel = function () {\n return this.dropZonePurpose === 'rowGroup';\n };\n BaseDropZonePanel.prototype.onDragLeave = function (draggingEvent) {\n // if the dragging started from us, we remove the group, however if it started\n // some place else, then we don't, as it was only 'asking'\n if (this.state === BaseDropZonePanel.STATE_REARRANGE_COLUMNS) {\n var columns = draggingEvent.dragSource.getDragItem().columns || [];\n this.removeColumns(columns);\n }\n if (this.isPotentialDndColumns()) {\n var showColumnOnExit = this.isRowGroupPanel() && !this.gridOptionsWrapper.isSuppressMakeColumnVisibleAfterUnGroup() && !draggingEvent.fromNudge;\n if (showColumnOnExit) {\n var dragItem = draggingEvent.dragSource.getDragItem();\n this.setColumnsVisible(dragItem.columns, true, \"uiColumnDragged\");\n }\n this.potentialDndColumns = [];\n this.refreshGui();\n }\n this.state = BaseDropZonePanel.STATE_NOT_DRAGGING;\n };\n BaseDropZonePanel.prototype.onDragStop = function () {\n if (this.isPotentialDndColumns()) {\n var success = false;\n if (this.state === BaseDropZonePanel.STATE_NEW_COLUMNS_IN) {\n this.addColumns(this.potentialDndColumns);\n success = true;\n }\n else {\n success = this.rearrangeColumns(this.potentialDndColumns);\n }\n this.potentialDndColumns = [];\n // If the function is passive, then we don't refresh, as we assume the client application\n // is going to call setRowGroups / setPivots / setValues at a later point which will then\n // cause a refresh. This gives a nice GUI where the ghost stays until the app has caught\n // up with the changes. However, if there was no change in the order, then we do need to\n // refresh to reset the columns\n if (!this.beans.gridOptionsWrapper.isFunctionsPassive() || !success) {\n this.refreshGui();\n }\n }\n this.state = BaseDropZonePanel.STATE_NOT_DRAGGING;\n };\n BaseDropZonePanel.prototype.removeColumns = function (columnsToRemove) {\n var newColumnList = this.getExistingColumns().filter(function (col) { return !_.includes(columnsToRemove, col); });\n this.updateColumns(newColumnList);\n };\n BaseDropZonePanel.prototype.addColumns = function (columnsToAdd) {\n if (!columnsToAdd) {\n return;\n }\n var newColumnList = this.getExistingColumns().slice();\n var colsToAddNoDuplicates = columnsToAdd.filter(function (col) { return newColumnList.indexOf(col) < 0; });\n _.insertArrayIntoArray(newColumnList, colsToAddNoDuplicates, this.insertIndex);\n this.updateColumns(newColumnList);\n };\n BaseDropZonePanel.prototype.rearrangeColumns = function (columnsToAdd) {\n var newColumnList = this.getNonGhostColumns().slice();\n _.insertArrayIntoArray(newColumnList, columnsToAdd, this.insertIndex);\n if (_.areEqual(newColumnList, this.getExistingColumns())) {\n return false;\n }\n this.updateColumns(newColumnList);\n return true;\n };\n BaseDropZonePanel.prototype.refreshGui = function () {\n // we reset the scroll position after the refresh.\n // if we don't do this, then the list will always scroll to the top\n // each time we refresh it. this is because part of the refresh empties\n // out the list which sets scroll to zero. so the user could be just\n // reordering the list - we want to prevent the resetting of the scroll.\n // this is relevant for vertical display only (as horizontal has no scroll)\n var scrollTop = this.eColumnDropList.scrollTop;\n var resizeEnabled = this.resizeEnabled;\n var focusedIndex = this.getFocusedItem();\n var alternateElement = this.focusService.findNextFocusableElement();\n if (!alternateElement) {\n alternateElement = this.focusService.findNextFocusableElement(undefined, false, true);\n }\n this.toggleResizable(false);\n this.destroyGui();\n this.addIconAndTitleToGui();\n this.addEmptyMessageToGui();\n this.addColumnsToGui();\n if (!this.isHorizontal()) {\n this.eColumnDropList.scrollTop = scrollTop;\n }\n if (resizeEnabled) {\n this.toggleResizable(resizeEnabled);\n }\n this.restoreFocus(focusedIndex, alternateElement);\n };\n BaseDropZonePanel.prototype.getFocusedItem = function () {\n var eGui = this.getGui();\n var activeElement = this.gridOptionsWrapper.getDocument().activeElement;\n if (!eGui.contains(activeElement)) {\n return -1;\n }\n var items = Array.from(eGui.querySelectorAll('.ag-column-drop-cell'));\n return items.indexOf(activeElement);\n };\n BaseDropZonePanel.prototype.restoreFocus = function (index, alternateElement) {\n var eGui = this.getGui();\n var items = Array.from(eGui.querySelectorAll('.ag-column-drop-cell'));\n if (index === -1) {\n return;\n }\n if (items.length === 0) {\n alternateElement.focus();\n }\n var indexToFocus = Math.min(items.length - 1, index);\n var el = items[indexToFocus];\n if (el) {\n el.focus();\n }\n };\n BaseDropZonePanel.prototype.getNonGhostColumns = function () {\n var _this = this;\n var existingColumns = this.getExistingColumns();\n if (this.isPotentialDndColumns()) {\n return existingColumns.filter(function (column) { return !_.includes(_this.potentialDndColumns, column); });\n }\n return existingColumns;\n };\n BaseDropZonePanel.prototype.addColumnsToGui = function () {\n var _this = this;\n var nonGhostColumns = this.getNonGhostColumns();\n var itemsToAddToGui = nonGhostColumns.map(function (column) { return (_this.createColumnComponent(column, false)); });\n if (this.isPotentialDndColumns()) {\n var dndColumns = this.potentialDndColumns.map(function (column) { return (_this.createColumnComponent(column, true)); });\n if (this.insertIndex >= itemsToAddToGui.length) {\n itemsToAddToGui.push.apply(itemsToAddToGui, __spread(dndColumns));\n }\n else {\n itemsToAddToGui.splice.apply(itemsToAddToGui, __spread([this.insertIndex, 0], dndColumns));\n }\n }\n this.appendChild(this.eColumnDropList);\n itemsToAddToGui.forEach(function (columnComponent, index) {\n if (index > 0) {\n _this.addArrow(_this.eColumnDropList);\n }\n _this.eColumnDropList.appendChild(columnComponent.getGui());\n });\n this.addAriaLabelsToComponents();\n };\n BaseDropZonePanel.prototype.addAriaLabelsToComponents = function () {\n var _this = this;\n this.childColumnComponents.forEach(function (comp, idx) {\n var eGui = comp.getGui();\n _.setAriaPosInSet(eGui, idx + 1);\n _.setAriaSetSize(eGui, _this.childColumnComponents.length);\n });\n };\n BaseDropZonePanel.prototype.createColumnComponent = function (column, ghost) {\n var _this = this;\n var columnComponent = new DropZoneColumnComp(column, this.dropTarget, ghost, this.dropZonePurpose, this.horizontal);\n columnComponent.addEventListener(DropZoneColumnComp.EVENT_COLUMN_REMOVE, this.removeColumns.bind(this, [column]));\n this.beans.context.createBean(columnComponent);\n this.guiDestroyFunctions.push(function () { return _this.destroyBean(columnComponent); });\n if (!ghost) {\n this.childColumnComponents.push(columnComponent);\n }\n return columnComponent;\n };\n BaseDropZonePanel.prototype.addIconAndTitleToGui = function () {\n var eGroupIcon = this.params.icon;\n var eTitleBar = document.createElement('div');\n eTitleBar.setAttribute('aria-hidden', 'true');\n this.addElementClasses(eTitleBar, 'title-bar');\n this.addElementClasses(eGroupIcon, 'icon');\n this.addOrRemoveCssClass('ag-column-drop-empty', this.isExistingColumnsEmpty());\n eTitleBar.appendChild(eGroupIcon);\n if (!this.horizontal) {\n var eTitle = document.createElement('span');\n this.addElementClasses(eTitle, 'title');\n eTitle.innerHTML = this.params.title;\n eTitleBar.appendChild(eTitle);\n }\n this.appendChild(eTitleBar);\n };\n BaseDropZonePanel.prototype.isExistingColumnsEmpty = function () {\n return this.getExistingColumns().length === 0;\n };\n BaseDropZonePanel.prototype.addEmptyMessageToGui = function () {\n if (!this.isExistingColumnsEmpty() || this.isPotentialDndColumns()) {\n return;\n }\n var eMessage = document.createElement('span');\n eMessage.innerHTML = this.params.emptyMessage;\n this.addElementClasses(eMessage, 'empty-message');\n this.eColumnDropList.appendChild(eMessage);\n };\n BaseDropZonePanel.prototype.addArrow = function (eParent) {\n // only add the arrows if the layout is horizontal\n if (this.horizontal) {\n // for RTL it's a left arrow, otherwise it's a right arrow\n var enableRtl = this.beans.gridOptionsWrapper.isEnableRtl();\n var icon = _.createIconNoSpan(enableRtl ? 'smallLeft' : 'smallRight', this.beans.gridOptionsWrapper);\n this.addElementClasses(icon, 'cell-separator');\n eParent.appendChild(icon);\n }\n };\n BaseDropZonePanel.STATE_NOT_DRAGGING = 'notDragging';\n BaseDropZonePanel.STATE_NEW_COLUMNS_IN = 'newColumnsIn';\n BaseDropZonePanel.STATE_REARRANGE_COLUMNS = 'rearrangeColumns';\n __decorate([\n Autowired('columnModel')\n ], BaseDropZonePanel.prototype, \"colModel\", void 0);\n __decorate([\n Autowired('focusService')\n ], BaseDropZonePanel.prototype, \"focusService\", void 0);\n return BaseDropZonePanel;\n}(Component));\nexport { BaseDropZonePanel };\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { _, Autowired, DragAndDropService, Events, PostConstruct } from \"@ag-grid-community/core\";\nimport { BaseDropZonePanel } from \"./baseDropZonePanel\";\nvar RowGroupDropZonePanel = /** @class */ (function (_super) {\n __extends(RowGroupDropZonePanel, _super);\n function RowGroupDropZonePanel(horizontal) {\n return _super.call(this, horizontal, 'rowGroup') || this;\n }\n RowGroupDropZonePanel.prototype.passBeansUp = function () {\n _super.prototype.setBeans.call(this, {\n gridOptionsWrapper: this.gridOptionsWrapper,\n eventService: this.eventService,\n context: this.getContext(),\n loggerFactory: this.loggerFactory,\n dragAndDropService: this.dragAndDropService\n });\n var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();\n var emptyMessage = localeTextFunc('rowGroupColumnsEmptyMessage', 'Drag here to set row groups');\n var title = localeTextFunc('groups', 'Row Groups');\n _super.prototype.init.call(this, {\n dragAndDropIcon: DragAndDropService.ICON_GROUP,\n icon: _.createIconNoSpan('rowGroupPanel', this.gridOptionsWrapper, null),\n emptyMessage: emptyMessage,\n title: title\n });\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, this.refreshGui.bind(this));\n };\n RowGroupDropZonePanel.prototype.getAriaLabel = function () {\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n var label = translate('ariaRowGroupDropZonePanelLabel', 'Row Groups');\n return label;\n };\n RowGroupDropZonePanel.prototype.getTooltipParams = function () {\n var res = _super.prototype.getTooltipParams.call(this);\n res.location = 'rowGroupColumnsList';\n return res;\n };\n RowGroupDropZonePanel.prototype.isColumnDroppable = function (column) {\n // we never allow grouping of secondary columns\n if (this.gridOptionsWrapper.isFunctionsReadOnly() || !column.isPrimary()) {\n return false;\n }\n return column.isAllowRowGroup() && !column.isRowGroupActive();\n };\n RowGroupDropZonePanel.prototype.updateColumns = function (columns) {\n if (this.gridOptionsWrapper.isFunctionsPassive()) {\n var event_1 = {\n type: Events.EVENT_COLUMN_ROW_GROUP_CHANGE_REQUEST,\n columns: columns\n };\n this.eventService.dispatchEvent(event_1);\n }\n else {\n this.columnModel.setRowGroupColumns(columns, \"toolPanelUi\");\n }\n };\n RowGroupDropZonePanel.prototype.getIconName = function () {\n return this.isPotentialDndColumns() ? DragAndDropService.ICON_GROUP : DragAndDropService.ICON_NOT_ALLOWED;\n };\n RowGroupDropZonePanel.prototype.getExistingColumns = function () {\n return this.columnModel.getRowGroupColumns();\n };\n __decorate([\n Autowired('columnModel')\n ], RowGroupDropZonePanel.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('loggerFactory')\n ], RowGroupDropZonePanel.prototype, \"loggerFactory\", void 0);\n __decorate([\n Autowired('dragAndDropService')\n ], RowGroupDropZonePanel.prototype, \"dragAndDropService\", void 0);\n __decorate([\n PostConstruct\n ], RowGroupDropZonePanel.prototype, \"passBeansUp\", null);\n return RowGroupDropZonePanel;\n}(BaseDropZonePanel));\nexport { RowGroupDropZonePanel };\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { _, Autowired, DragAndDropService, Events, PostConstruct } from \"@ag-grid-community/core\";\nimport { BaseDropZonePanel } from \"./baseDropZonePanel\";\nvar PivotDropZonePanel = /** @class */ (function (_super) {\n __extends(PivotDropZonePanel, _super);\n function PivotDropZonePanel(horizontal) {\n return _super.call(this, horizontal, 'pivot') || this;\n }\n PivotDropZonePanel.prototype.passBeansUp = function () {\n _super.prototype.setBeans.call(this, {\n gridOptionsWrapper: this.gridOptionsWrapper,\n eventService: this.eventService,\n context: this.getContext(),\n loggerFactory: this.loggerFactory,\n dragAndDropService: this.dragAndDropService\n });\n var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();\n var emptyMessage = localeTextFunc('pivotColumnsEmptyMessage', 'Drag here to set column labels');\n var title = localeTextFunc('pivots', 'Column Labels');\n _super.prototype.init.call(this, {\n dragAndDropIcon: DragAndDropService.ICON_GROUP,\n icon: _.createIconNoSpan('pivotPanel', this.gridOptionsWrapper, null),\n emptyMessage: emptyMessage,\n title: title\n });\n this.addManagedListener(this.eventService, Events.EVENT_NEW_COLUMNS_LOADED, this.refresh.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PIVOT_CHANGED, this.refresh.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PIVOT_MODE_CHANGED, this.checkVisibility.bind(this));\n this.refresh();\n };\n PivotDropZonePanel.prototype.getAriaLabel = function () {\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n var label = translate('ariaPivotDropZonePanelLabel', 'Column Labels');\n return label;\n };\n PivotDropZonePanel.prototype.getTooltipParams = function () {\n var res = _super.prototype.getTooltipParams.call(this);\n res.location = 'pivotColumnsList';\n return res;\n };\n PivotDropZonePanel.prototype.refresh = function () {\n this.checkVisibility();\n this.refreshGui();\n };\n PivotDropZonePanel.prototype.checkVisibility = function () {\n var pivotMode = this.columnModel.isPivotMode();\n if (this.isHorizontal()) {\n // what we do for horizontal (ie the pivot panel at the top) depends\n // on the user property as well as pivotMode.\n switch (this.gridOptionsWrapper.getPivotPanelShow()) {\n case 'always':\n this.setDisplayed(pivotMode);\n break;\n case 'onlyWhenPivoting':\n var pivotActive = this.columnModel.isPivotActive();\n this.setDisplayed(pivotMode && pivotActive);\n break;\n default:\n // never show it\n this.setDisplayed(false);\n break;\n }\n }\n else {\n // in toolPanel, the pivot panel is always shown when pivot mode is on\n this.setDisplayed(pivotMode);\n }\n };\n PivotDropZonePanel.prototype.isColumnDroppable = function (column) {\n // we never allow grouping of secondary columns\n if (this.gridOptionsWrapper.isFunctionsReadOnly() || !column.isPrimary()) {\n return false;\n }\n return column.isAllowPivot() && !column.isPivotActive();\n };\n PivotDropZonePanel.prototype.updateColumns = function (columns) {\n if (this.gridOptionsWrapper.isFunctionsPassive()) {\n var event_1 = {\n type: Events.EVENT_COLUMN_PIVOT_CHANGE_REQUEST,\n columns: columns\n };\n this.eventService.dispatchEvent(event_1);\n }\n else {\n this.columnModel.setPivotColumns(columns, \"toolPanelUi\");\n }\n };\n PivotDropZonePanel.prototype.getIconName = function () {\n return this.isPotentialDndColumns() ? DragAndDropService.ICON_PIVOT : DragAndDropService.ICON_NOT_ALLOWED;\n };\n PivotDropZonePanel.prototype.getExistingColumns = function () {\n return this.columnModel.getPivotColumns();\n };\n __decorate([\n Autowired('columnModel')\n ], PivotDropZonePanel.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('loggerFactory')\n ], PivotDropZonePanel.prototype, \"loggerFactory\", void 0);\n __decorate([\n Autowired('dragAndDropService')\n ], PivotDropZonePanel.prototype, \"dragAndDropService\", void 0);\n __decorate([\n PostConstruct\n ], PivotDropZonePanel.prototype, \"passBeansUp\", null);\n return PivotDropZonePanel;\n}(BaseDropZonePanel));\nexport { PivotDropZonePanel };\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Component, Constants, Events, PostConstruct, _ } from \"@ag-grid-community/core\";\nimport { RowGroupDropZonePanel } from \"./rowGroupDropZonePanel\";\nimport { PivotDropZonePanel } from \"./pivotDropZonePanel\";\nvar GridHeaderDropZones = /** @class */ (function (_super) {\n __extends(GridHeaderDropZones, _super);\n function GridHeaderDropZones() {\n return _super.call(this) || this;\n }\n GridHeaderDropZones.prototype.postConstruct = function () {\n this.setGui(this.createNorthPanel());\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, this.onRowGroupChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_NEW_COLUMNS_LOADED, this.onRowGroupChanged.bind(this));\n this.onRowGroupChanged();\n };\n GridHeaderDropZones.prototype.createNorthPanel = function () {\n var topPanelGui = document.createElement('div');\n var dropPanelVisibleListener = this.onDropPanelVisible.bind(this);\n topPanelGui.classList.add('ag-column-drop-wrapper');\n _.setAriaRole(topPanelGui, 'presentation');\n this.rowGroupComp = new RowGroupDropZonePanel(true);\n this.createManagedBean(this.rowGroupComp);\n this.pivotComp = new PivotDropZonePanel(true);\n this.createManagedBean(this.pivotComp);\n topPanelGui.appendChild(this.rowGroupComp.getGui());\n topPanelGui.appendChild(this.pivotComp.getGui());\n this.addManagedListener(this.rowGroupComp, Component.EVENT_DISPLAYED_CHANGED, dropPanelVisibleListener);\n this.addManagedListener(this.pivotComp, Component.EVENT_DISPLAYED_CHANGED, dropPanelVisibleListener);\n this.onDropPanelVisible();\n return topPanelGui;\n };\n GridHeaderDropZones.prototype.onDropPanelVisible = function () {\n var bothDisplayed = this.rowGroupComp.isDisplayed() && this.pivotComp.isDisplayed();\n this.rowGroupComp.addOrRemoveCssClass('ag-column-drop-horizontal-half-width', bothDisplayed);\n this.pivotComp.addOrRemoveCssClass('ag-column-drop-horizontal-half-width', bothDisplayed);\n };\n GridHeaderDropZones.prototype.onRowGroupChanged = function () {\n if (!this.rowGroupComp) {\n return;\n }\n var rowGroupPanelShow = this.gridOptionsWrapper.getRowGroupPanelShow();\n if (rowGroupPanelShow === Constants.ALWAYS) {\n this.rowGroupComp.setDisplayed(true);\n }\n else if (rowGroupPanelShow === Constants.ONLY_WHEN_GROUPING) {\n var grouping = !this.columnModel.isRowGroupEmpty();\n this.rowGroupComp.setDisplayed(grouping);\n }\n else {\n this.rowGroupComp.setDisplayed(false);\n }\n };\n __decorate([\n Autowired('columnModel')\n ], GridHeaderDropZones.prototype, \"columnModel\", void 0);\n __decorate([\n PostConstruct\n ], GridHeaderDropZones.prototype, \"postConstruct\", null);\n return GridHeaderDropZones;\n}(Component));\nexport { GridHeaderDropZones };\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, BeanStub, } from \"@ag-grid-community/core\";\nvar FilterAggregatesStage = /** @class */ (function (_super) {\n __extends(FilterAggregatesStage, _super);\n function FilterAggregatesStage() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n FilterAggregatesStage.prototype.execute = function (params) {\n var _this = this;\n var isPivotMode = this.columnModel.isPivotMode();\n var isAggFilterActive = this.filterManager.isAggregateFilterPresent();\n // This is the default filter for applying only to leaf nodes, realistically this should not apply as primary agg columns,\n // should not be applied by the filterManager if getGroupAggFiltering is missing. Predicate will apply filters to leaf level.\n var defaultPrimaryColumnPredicate = function (params) { return !params.node.group; };\n // Default secondary column predicate, selecting only leaf level groups.\n var defaultSecondaryColumnPredicate = (function (params) { return params.node.leafGroup; });\n // The predicate to determine whether filters should apply to this row. Either defined by the user in groupAggFiltering or a default depending\n // on current pivot mode status.\n var applyFilterToNode = this.gridOptionsWrapper.getGroupAggFiltering()\n || (isPivotMode ? defaultSecondaryColumnPredicate : defaultPrimaryColumnPredicate);\n var changedPath = params.changedPath;\n var preserveChildren = function (node, recursive) {\n if (recursive === void 0) { recursive = false; }\n if (node.childrenAfterFilter) {\n node.childrenAfterAggFilter = node.childrenAfterFilter;\n if (recursive) {\n node.childrenAfterAggFilter.forEach(function (child) { return preserveChildren(child, recursive); });\n }\n _this.setAllChildrenCount(node);\n }\n if (node.sibling) {\n node.sibling.childrenAfterAggFilter = node.childrenAfterAggFilter;\n }\n };\n var filterChildren = function (node) {\n var _a;\n node.childrenAfterAggFilter = ((_a = node.childrenAfterFilter) === null || _a === void 0 ? void 0 : _a.filter(function (child) {\n var _a;\n var shouldFilterRow = applyFilterToNode({ node: child });\n if (shouldFilterRow) {\n var doesNodePassFilter = _this.filterManager.doesRowPassAggregateFilters({ rowNode: child });\n if (doesNodePassFilter) {\n // Node has passed, so preserve children\n preserveChildren(child, true);\n return true;\n }\n }\n var hasChildPassed = (_a = child.childrenAfterAggFilter) === null || _a === void 0 ? void 0 : _a.length;\n return hasChildPassed;\n })) || null;\n _this.setAllChildrenCount(node);\n if (node.sibling) {\n node.sibling.childrenAfterAggFilter = node.childrenAfterAggFilter;\n }\n };\n changedPath.forEachChangedNodeDepthFirst(isAggFilterActive ? filterChildren : preserveChildren, true);\n };\n FilterAggregatesStage.prototype.setAllChildrenCountTreeData = function (rowNode) {\n // for tree data, we include all children, groups and leafs\n var allChildrenCount = 0;\n rowNode.childrenAfterAggFilter.forEach(function (child) {\n // include child itself\n allChildrenCount++;\n // include children of children\n allChildrenCount += child.allChildrenCount;\n });\n rowNode.setAllChildrenCount(allChildrenCount);\n };\n FilterAggregatesStage.prototype.setAllChildrenCountGridGrouping = function (rowNode) {\n // for grid data, we only count the leafs\n var allChildrenCount = 0;\n rowNode.childrenAfterAggFilter.forEach(function (child) {\n if (child.group) {\n allChildrenCount += child.allChildrenCount;\n }\n else {\n allChildrenCount++;\n }\n });\n rowNode.setAllChildrenCount(allChildrenCount);\n };\n FilterAggregatesStage.prototype.setAllChildrenCount = function (rowNode) {\n if (!rowNode.hasChildren()) {\n rowNode.setAllChildrenCount(null);\n return;\n }\n if (this.gridOptionsWrapper.isTreeData()) {\n this.setAllChildrenCountTreeData(rowNode);\n }\n else {\n this.setAllChildrenCountGridGrouping(rowNode);\n }\n };\n __decorate([\n Autowired('filterManager')\n ], FilterAggregatesStage.prototype, \"filterManager\", void 0);\n __decorate([\n Autowired('columnModel')\n ], FilterAggregatesStage.prototype, \"columnModel\", void 0);\n FilterAggregatesStage = __decorate([\n Bean('filterAggregatesStage')\n ], FilterAggregatesStage);\n return FilterAggregatesStage;\n}(BeanStub));\nexport { FilterAggregatesStage };\n","import { ModuleNames } from \"@ag-grid-community/core\";\nimport { EnterpriseCoreModule } from \"@ag-grid-enterprise/core\";\nimport { AggregationStage } from \"./rowGrouping/aggregationStage\";\nimport { GroupStage } from \"./rowGrouping/groupStage\";\nimport { PivotColDefService } from \"./rowGrouping/pivotColDefService\";\nimport { PivotStage } from \"./rowGrouping/pivotStage\";\nimport { AggFuncService } from \"./rowGrouping/aggFuncService\";\nimport { GridHeaderDropZones } from \"./rowGrouping/columnDropZones/gridHeaderDropZones\";\nimport { FilterAggregatesStage } from \"./rowGrouping/filterAggregatesStage\";\nexport var RowGroupingModule = {\n moduleName: ModuleNames.RowGroupingModule,\n beans: [AggregationStage, FilterAggregatesStage, GroupStage, PivotColDefService, PivotStage, AggFuncService],\n agStackComponents: [\n { componentName: 'AgGridHeaderDropZones', componentClass: GridHeaderDropZones }\n ],\n dependantModules: [\n EnterpriseCoreModule\n ]\n};\n","var __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { _, Autowired, DragAndDropService, Events, PostConstruct } from \"@ag-grid-community/core\";\nimport { BaseDropZonePanel } from \"./baseDropZonePanel\";\nvar ValuesDropZonePanel = /** @class */ (function (_super) {\n __extends(ValuesDropZonePanel, _super);\n function ValuesDropZonePanel(horizontal) {\n return _super.call(this, horizontal, 'aggregation') || this;\n }\n ValuesDropZonePanel.prototype.passBeansUp = function () {\n _super.prototype.setBeans.call(this, {\n gridOptionsWrapper: this.gridOptionsWrapper,\n eventService: this.eventService,\n context: this.getContext(),\n loggerFactory: this.loggerFactory,\n dragAndDropService: this.dragAndDropService\n });\n var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();\n var emptyMessage = localeTextFunc('valueColumnsEmptyMessage', 'Drag here to aggregate');\n var title = localeTextFunc('values', 'Values');\n _super.prototype.init.call(this, {\n dragAndDropIcon: DragAndDropService.ICON_AGGREGATE,\n icon: _.createIconNoSpan('valuePanel', this.gridOptionsWrapper, null),\n emptyMessage: emptyMessage,\n title: title\n });\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_VALUE_CHANGED, this.refreshGui.bind(this));\n };\n ValuesDropZonePanel.prototype.getAriaLabel = function () {\n var translate = this.gridOptionsWrapper.getLocaleTextFunc();\n var label = translate('ariaValuesDropZonePanelLabel', 'Values');\n return label;\n };\n ValuesDropZonePanel.prototype.getTooltipParams = function () {\n var res = _super.prototype.getTooltipParams.call(this);\n res.location = 'valueColumnsList';\n return res;\n };\n ValuesDropZonePanel.prototype.getIconName = function () {\n return this.isPotentialDndColumns() ? DragAndDropService.ICON_AGGREGATE : DragAndDropService.ICON_NOT_ALLOWED;\n };\n ValuesDropZonePanel.prototype.isColumnDroppable = function (column) {\n // we never allow grouping of secondary columns\n if (this.gridOptionsWrapper.isFunctionsReadOnly() || !column.isPrimary()) {\n return false;\n }\n return column.isAllowValue() && !column.isValueActive();\n };\n ValuesDropZonePanel.prototype.updateColumns = function (columns) {\n if (this.gridOptionsWrapper.isFunctionsPassive()) {\n var event_1 = {\n type: Events.EVENT_COLUMN_VALUE_CHANGE_REQUEST,\n columns: columns\n };\n this.eventService.dispatchEvent(event_1);\n }\n else {\n this.columnModel.setValueColumns(columns, \"toolPanelUi\");\n }\n };\n ValuesDropZonePanel.prototype.getExistingColumns = function () {\n return this.columnModel.getValueColumns();\n };\n __decorate([\n Autowired('columnModel')\n ], ValuesDropZonePanel.prototype, \"columnModel\", void 0);\n __decorate([\n Autowired('loggerFactory')\n ], ValuesDropZonePanel.prototype, \"loggerFactory\", void 0);\n __decorate([\n Autowired('dragAndDropService')\n ], ValuesDropZonePanel.prototype, \"dragAndDropService\", void 0);\n __decorate([\n PostConstruct\n ], ValuesDropZonePanel.prototype, \"passBeansUp\", null);\n return ValuesDropZonePanel;\n}(BaseDropZonePanel));\nexport { ValuesDropZonePanel };\n","/**\n * If value is undefined, null or blank, returns null, otherwise returns the value\n * @param {T} value\n * @returns {T | null}\n */\nexport function makeNull(value) {\n if (value == null || value === '') {\n return null;\n }\n return value;\n}\nexport function exists(value, allowEmptyString = false) {\n return value != null && (value !== '' || allowEmptyString);\n}\nexport function missing(value) {\n return !exists(value);\n}\nexport function missingOrEmpty(value) {\n return value == null || value.length === 0;\n}\nexport function toStringOrNull(value) {\n return value != null && typeof value.toString === 'function' ? value.toString() : null;\n}\n// for parsing html attributes, where we want empty strings and missing attributes to be undefined\nexport function attrToNumber(value) {\n if (value === undefined) {\n // undefined or empty means ignore the value\n return;\n }\n if (value === null || value === '') {\n // null or blank means clear\n return null;\n }\n if (typeof value === 'number') {\n return isNaN(value) ? undefined : value;\n }\n const valueParsed = parseInt(value, 10);\n return isNaN(valueParsed) ? undefined : valueParsed;\n}\n// for parsing html attributes, where we want empty strings and missing attributes to be undefined\nexport function attrToBoolean(value) {\n if (value === undefined) {\n // undefined or empty means ignore the value\n return;\n }\n if (value === null || value === '') {\n // null means clear\n return false;\n }\n if (typeof value === 'boolean') {\n // if simple boolean, return the boolean\n return value;\n }\n // if equal to the string 'true' (ignoring case) then return true\n return (/true/i).test(value);\n}\n// for parsing html attributes, where we want empty strings and missing attributes to be undefined\nexport function attrToString(value) {\n if (value == null || value === '') {\n return;\n }\n return value;\n}\n/** @deprecated */\nexport function referenceCompare(left, right) {\n if (left == null && right == null) {\n return true;\n }\n if (left == null && right != null) {\n return false;\n }\n if (left != null && right == null) {\n return false;\n }\n return left === right;\n}\nexport function jsonEquals(val1, val2) {\n const val1Json = val1 ? JSON.stringify(val1) : null;\n const val2Json = val2 ? JSON.stringify(val2) : null;\n return val1Json === val2Json;\n}\nexport function defaultComparator(valueA, valueB, accentedCompare = false) {\n const valueAMissing = valueA == null;\n const valueBMissing = valueB == null;\n // this is for aggregations sum and avg, where the result can be a number that is wrapped.\n // if we didn't do this, then the toString() value would be used, which would result in\n // the strings getting used instead of the numbers.\n if (valueA && valueA.toNumber) {\n valueA = valueA.toNumber();\n }\n if (valueB && valueB.toNumber) {\n valueB = valueB.toNumber();\n }\n if (valueAMissing && valueBMissing) {\n return 0;\n }\n if (valueAMissing) {\n return -1;\n }\n if (valueBMissing) {\n return 1;\n }\n function doQuickCompare(a, b) {\n return (a > b ? 1 : (a < b ? -1 : 0));\n }\n if (typeof valueA !== 'string') {\n return doQuickCompare(valueA, valueB);\n }\n if (!accentedCompare) {\n return doQuickCompare(valueA, valueB);\n }\n try {\n // using local compare also allows chinese comparisons\n return valueA.localeCompare(valueB);\n }\n catch (e) {\n // if something wrong with localeCompare, eg not supported\n // by browser, then just continue with the quick one\n return doQuickCompare(valueA, valueB);\n }\n}\nexport function values(object) {\n if (object instanceof Set || object instanceof Map) {\n const arr = [];\n object.forEach((value) => arr.push(value));\n return arr;\n }\n return Object.values(object);\n}\n","// class returns a unique id to use for the column. it checks the existing columns, and if the requested\n// id is already taken, it will start appending numbers until it gets a unique id.\n// eg, if the col field is 'name', it will try ids: {name, name_1, name_2...}\n// if no field or id provided in the col, it will try the ids of natural numbers\nimport { toStringOrNull } from \"../utils/generic.mjs\";\nexport class ColumnKeyCreator {\n constructor() {\n this.existingKeys = {};\n }\n addExistingKeys(keys) {\n for (let i = 0; i < keys.length; i++) {\n this.existingKeys[keys[i]] = true;\n }\n }\n getUniqueKey(colId, colField) {\n // in case user passed in number for colId, convert to string\n colId = toStringOrNull(colId);\n let count = 0;\n while (true) {\n let idToTry;\n if (colId) {\n idToTry = colId;\n if (count !== 0) {\n idToTry += '_' + count;\n }\n }\n else if (colField) {\n idToTry = colField;\n if (count !== 0) {\n idToTry += '_' + count;\n }\n }\n else {\n // no point in stringing this, object treats it the same anyway.\n idToTry = count;\n }\n if (!this.existingKeys[idToTry]) {\n this.existingKeys[idToTry] = true;\n return String(idToTry);\n }\n count++;\n }\n }\n}\n","import { missing, exists } from './generic.mjs';\nexport function iterateObject(object, callback) {\n if (object == null) {\n return;\n }\n if (Array.isArray(object)) {\n for (let i = 0; i < object.length; i++) {\n callback(i.toString(), object[i]);\n }\n return;\n }\n for (const [key, value] of Object.entries(object)) {\n callback(key, value);\n }\n}\nexport function cloneObject(object) {\n const copy = {};\n const keys = Object.keys(object);\n for (let i = 0; i < keys.length; i++) {\n const key = keys[i];\n const value = object[key];\n copy[key] = value;\n }\n return copy;\n}\nexport function deepCloneObject(object) {\n return JSON.parse(JSON.stringify(object));\n}\n// returns copy of an object, doing a deep clone of any objects with that object.\n// this is used for eg creating copies of Column Definitions, where we want to\n// deep copy all objects, but do not want to deep copy functions (eg when user provides\n// a function or class for colDef.cellRenderer)\nexport function deepCloneDefinition(object, keysToSkip) {\n if (!object) {\n return;\n }\n const obj = object;\n const res = {};\n Object.keys(obj).forEach(key => {\n if (keysToSkip && keysToSkip.indexOf(key) >= 0) {\n return;\n }\n const value = obj[key];\n // 'simple object' means a bunch of key/value pairs, eg {filter: 'myFilter'}. it does\n // NOT include the following:\n // 1) arrays\n // 2) functions or classes (eg ColumnAPI instance)\n const sourceIsSimpleObject = isNonNullObject(value) && value.constructor === Object;\n if (sourceIsSimpleObject) {\n res[key] = deepCloneDefinition(value);\n }\n else {\n res[key] = value;\n }\n });\n return res;\n}\nexport function getProperty(object, key) {\n return object[key];\n}\nexport function setProperty(object, key, value) {\n object[key] = value;\n}\n/**\n * Will copy the specified properties from `source` into the equivalent properties on `target`, ignoring properties with\n * a value of `undefined`.\n */\nexport function copyPropertiesIfPresent(source, target, ...properties) {\n properties.forEach(p => copyPropertyIfPresent(source, target, p));\n}\n/**\n * Will copy the specified property from `source` into the equivalent property on `target`, unless the property has a\n * value of `undefined`. If a transformation is provided, it will be applied to the value before being set on `target`.\n */\nexport function copyPropertyIfPresent(source, target, property, transform) {\n const value = getProperty(source, property);\n if (value !== undefined) {\n setProperty(target, property, transform ? transform(value) : value);\n }\n}\nexport function getAllKeysInObjects(objects) {\n const allValues = {};\n objects.filter(obj => obj != null).forEach(obj => {\n Object.keys(obj).forEach(key => allValues[key] = null);\n });\n return Object.keys(allValues);\n}\nexport function getAllValuesInObject(obj) {\n if (!obj) {\n return [];\n }\n const anyObject = Object;\n if (typeof anyObject.values === 'function') {\n return anyObject.values(obj);\n }\n const ret = [];\n for (const key in obj) {\n if (obj.hasOwnProperty(key) && obj.propertyIsEnumerable(key)) {\n ret.push(obj[key]);\n }\n }\n return ret;\n}\nexport function mergeDeep(dest, source, copyUndefined = true, makeCopyOfSimpleObjects = false) {\n if (!exists(source)) {\n return;\n }\n iterateObject(source, (key, sourceValue) => {\n let destValue = dest[key];\n if (destValue === sourceValue) {\n return;\n }\n // when creating params, we don't want to just copy objects over. otherwise merging ColDefs (eg DefaultColDef\n // and Column Types) would result in params getting shared between objects.\n // by putting an empty value into destValue first, it means we end up copying over values from\n // the source object, rather than just copying in the source object in it's entirety.\n if (makeCopyOfSimpleObjects) {\n const objectIsDueToBeCopied = destValue == null && sourceValue != null;\n if (objectIsDueToBeCopied) {\n // 'simple object' means a bunch of key/value pairs, eg {filter: 'myFilter'}, as opposed\n // to a Class instance (such as ColumnAPI instance).\n const sourceIsSimpleObject = typeof sourceValue === 'object' && sourceValue.constructor === Object;\n const dontCopy = sourceIsSimpleObject;\n if (dontCopy) {\n destValue = {};\n dest[key] = destValue;\n }\n }\n }\n if (isNonNullObject(sourceValue) && isNonNullObject(destValue) && !Array.isArray(destValue)) {\n mergeDeep(destValue, sourceValue, copyUndefined, makeCopyOfSimpleObjects);\n }\n else if (copyUndefined || sourceValue !== undefined) {\n dest[key] = sourceValue;\n }\n });\n}\nexport function missingOrEmptyObject(value) {\n return missing(value) || Object.keys(value).length === 0;\n}\nexport function get(source, expression, defaultValue) {\n if (source == null) {\n return defaultValue;\n }\n const keys = expression.split('.');\n let objectToRead = source;\n while (keys.length > 1) {\n objectToRead = objectToRead[keys.shift()];\n if (objectToRead == null) {\n return defaultValue;\n }\n }\n const value = objectToRead[keys[0]];\n return value != null ? value : defaultValue;\n}\nexport function set(target, expression, value) {\n if (target == null) {\n return;\n }\n const keys = expression.split('.');\n let objectToUpdate = target;\n // Create empty objects\n keys.forEach((key, i) => {\n if (!objectToUpdate[key]) {\n objectToUpdate[key] = {};\n }\n if (i < keys.length - 1) {\n objectToUpdate = objectToUpdate[key];\n }\n });\n objectToUpdate[keys[keys.length - 1]] = value;\n}\nexport function getValueUsingField(data, field, fieldContainsDots) {\n if (!field || !data) {\n return;\n }\n // if no '.', then it's not a deep value\n if (!fieldContainsDots) {\n return data[field];\n }\n // otherwise it is a deep value, so need to dig for it\n const fields = field.split('.');\n let currentObject = data;\n for (let i = 0; i < fields.length; i++) {\n if (currentObject == null) {\n return undefined;\n }\n currentObject = currentObject[fields[i]];\n }\n return currentObject;\n}\n// used by ColumnAPI and GridAPI to remove all references, so keeping grid in memory resulting in a\n// memory leak if user is not disposing of the GridAPI or ColumnApi references\nexport function removeAllReferences(obj, objectName) {\n Object.keys(obj).forEach(key => {\n const value = obj[key];\n // we want to replace all the @autowired services, which are objects. any simple types (boolean, string etc)\n // we don't care about\n if (typeof value === 'object') {\n obj[key] = undefined;\n }\n });\n const proto = Object.getPrototypeOf(obj);\n const properties = {};\n Object.keys(proto).forEach(key => {\n const value = proto[key];\n // leave all basic types - this is needed for GridAPI to leave the \"destroyed: boolean\" attribute alone\n if (typeof value === 'function') {\n const func = () => {\n console.warn(`AG Grid: ${objectName} function ${key}() cannot be called as the grid has been destroyed.\n Please don't call grid API functions on destroyed grids - as a matter of fact you shouldn't\n be keeping the API reference, your application has a memory leak! Remove the API reference\n when the grid is destroyed.`);\n };\n properties[key] = { value: func, writable: true };\n }\n });\n Object.defineProperties(obj, properties);\n}\nexport function isNonNullObject(value) {\n return typeof value === 'object' && value !== null;\n}\n","const doOnceFlags = {};\n/**\n * If the key was passed before, then doesn't execute the func\n * @param {Function} func\n * @param {string} key\n */\nexport function doOnce(func, key) {\n if (doOnceFlags[key]) {\n return;\n }\n func();\n doOnceFlags[key] = true;\n}\nexport function getFunctionName(funcConstructor) {\n // for every other browser in the world\n if (funcConstructor.name) {\n return funcConstructor.name;\n }\n // for the pestilence that is ie11\n const matches = /function\\s+([^\\(]+)/.exec(funcConstructor.toString());\n return matches && matches.length === 2 ? matches[1].trim() : null;\n}\nexport function isFunction(val) {\n return !!(val && val.constructor && val.call && val.apply);\n}\nexport function executeInAWhile(funcs) {\n executeAfter(funcs, 400);\n}\nconst executeNextVMTurnFuncs = [];\nlet executeNextVMTurnPending = false;\nexport function executeNextVMTurn(func) {\n executeNextVMTurnFuncs.push(func);\n if (executeNextVMTurnPending) {\n return;\n }\n executeNextVMTurnPending = true;\n window.setTimeout(() => {\n const funcsCopy = executeNextVMTurnFuncs.slice();\n executeNextVMTurnFuncs.length = 0;\n executeNextVMTurnPending = false;\n funcsCopy.forEach(func => func());\n }, 0);\n}\nexport function executeAfter(funcs, milliseconds = 0) {\n if (funcs.length > 0) {\n window.setTimeout(() => funcs.forEach(func => func()), milliseconds);\n }\n}\n/**\n * @param {Function} func The function to be debounced\n * @param {number} delay The time in ms to debounce\n * @return {Function} The debounced function\n */\nexport function debounce(func, delay) {\n let timeout;\n // Calling debounce returns a new anonymous function\n return function (...args) {\n const context = this;\n window.clearTimeout(timeout);\n // Set the new timeout\n timeout = window.setTimeout(function () {\n func.apply(context, args);\n }, delay);\n };\n}\n/**\n * @param {Function} func The function to be throttled\n * @param {number} wait The time in ms to throttle\n * @return {Function} The throttled function\n */\nexport function throttle(func, wait) {\n let previousCall = 0;\n return function (...args) {\n const context = this;\n const currentCall = new Date().getTime();\n if (currentCall - previousCall < wait) {\n return;\n }\n previousCall = currentCall;\n func.apply(context, args);\n };\n}\nexport function waitUntil(condition, callback, timeout = 100, timeoutMessage) {\n const timeStamp = new Date().getTime();\n let interval = null;\n let executed = false;\n const internalCallback = () => {\n const reachedTimeout = ((new Date().getTime()) - timeStamp) > timeout;\n if (condition() || reachedTimeout) {\n callback();\n executed = true;\n if (interval != null) {\n window.clearInterval(interval);\n interval = null;\n }\n if (reachedTimeout && timeoutMessage) {\n console.warn(timeoutMessage);\n }\n }\n };\n internalCallback();\n if (!executed) {\n interval = window.setInterval(internalCallback, 10);\n }\n}\nexport function compose(...fns) {\n return (arg) => fns.reduce((composed, f) => f(composed), arg);\n}\nexport function callIfPresent(func) {\n if (func) {\n func();\n }\n}\nexport const noop = () => { return; };\n","export var ModuleNames;\n(function (ModuleNames) {\n ModuleNames[\"CommunityCoreModule\"] = \"@ag-grid-community/core\";\n // community modules\n ModuleNames[\"InfiniteRowModelModule\"] = \"@ag-grid-community/infinite-row-model\";\n ModuleNames[\"ClientSideRowModelModule\"] = \"@ag-grid-community/client-side-row-model\";\n ModuleNames[\"CsvExportModule\"] = \"@ag-grid-community/csv-export\";\n // enterprise core - users don't need to import on this, but other enterprise modules do\n ModuleNames[\"EnterpriseCoreModule\"] = \"@ag-grid-enterprise/core\";\n // enterprise modules\n ModuleNames[\"RowGroupingModule\"] = \"@ag-grid-enterprise/row-grouping\";\n ModuleNames[\"ColumnsToolPanelModule\"] = \"@ag-grid-enterprise/column-tool-panel\";\n ModuleNames[\"FiltersToolPanelModule\"] = \"@ag-grid-enterprise/filter-tool-panel\";\n ModuleNames[\"MenuModule\"] = \"@ag-grid-enterprise/menu\";\n ModuleNames[\"SetFilterModule\"] = \"@ag-grid-enterprise/set-filter\";\n ModuleNames[\"MultiFilterModule\"] = \"@ag-grid-enterprise/multi-filter\";\n ModuleNames[\"StatusBarModule\"] = \"@ag-grid-enterprise/status-bar\";\n ModuleNames[\"SideBarModule\"] = \"@ag-grid-enterprise/side-bar\";\n ModuleNames[\"RangeSelectionModule\"] = \"@ag-grid-enterprise/range-selection\";\n ModuleNames[\"MasterDetailModule\"] = \"@ag-grid-enterprise/master-detail\";\n ModuleNames[\"RichSelectModule\"] = \"@ag-grid-enterprise/rich-select\";\n ModuleNames[\"GridChartsModule\"] = \"@ag-grid-enterprise/charts\";\n ModuleNames[\"ViewportRowModelModule\"] = \"@ag-grid-enterprise/viewport-row-model\";\n ModuleNames[\"ServerSideRowModelModule\"] = \"@ag-grid-enterprise/server-side-row-model\";\n ModuleNames[\"ExcelExportModule\"] = \"@ag-grid-enterprise/excel-export\";\n ModuleNames[\"ClipboardModule\"] = \"@ag-grid-enterprise/clipboard\";\n ModuleNames[\"SparklinesModule\"] = \"@ag-grid-enterprise/sparklines\";\n ModuleNames[\"AdvancedFilterModule\"] = \"@ag-grid-enterprise/advanced-filter\";\n // framework wrappers currently don't provide beans, comps etc, so no need to be modules,\n // however i argue they should be as in theory they 'could' provide beans etc\n ModuleNames[\"AngularModule\"] = \"@ag-grid-community/angular\";\n ModuleNames[\"ReactModule\"] = \"@ag-grid-community/react\";\n ModuleNames[\"VueModule\"] = \"@ag-grid-community/vue\";\n // and then this, which is definitely not a grid module, as it should not have any dependency\n // on the grid (ie shouldn't even reference the Module interface)\n // ChartsModule = \"@ag-grid-community/charts-core\",\n})(ModuleNames || (ModuleNames = {}));\n","import { ModuleNames } from \"./moduleNames.mjs\";\nimport { doOnce } from \"../utils/function.mjs\";\nimport { values } from \"../utils/generic.mjs\";\nexport class ModuleRegistry {\n /**\n * Globally register the given module for all grids.\n * @param module - module to register\n */\n static register(module) {\n ModuleRegistry.__register(module, true, undefined);\n }\n /**\n * Globally register the given modules for all grids.\n * @param modules - modules to register\n */\n static registerModules(modules) {\n ModuleRegistry.__registerModules(modules, true, undefined);\n }\n /** AG GRID INTERNAL - Module registration helper. */\n static __register(module, moduleBased, gridId) {\n ModuleRegistry.runVersionChecks(module);\n if (gridId !== undefined) {\n ModuleRegistry.areGridScopedModules = true;\n if (ModuleRegistry.gridModulesMap[gridId] === undefined) {\n ModuleRegistry.gridModulesMap[gridId] = {};\n }\n ModuleRegistry.gridModulesMap[gridId][module.moduleName] = module;\n }\n else {\n ModuleRegistry.globalModulesMap[module.moduleName] = module;\n }\n ModuleRegistry.setModuleBased(moduleBased);\n }\n /** AG GRID INTERNAL - Unregister grid scoped module. */\n static __unRegisterGridModules(gridId) {\n delete ModuleRegistry.gridModulesMap[gridId];\n }\n /** AG GRID INTERNAL - Module registration helper. */\n static __registerModules(modules, moduleBased, gridId) {\n ModuleRegistry.setModuleBased(moduleBased);\n if (!modules) {\n return;\n }\n modules.forEach(module => ModuleRegistry.__register(module, moduleBased, gridId));\n }\n static isValidModuleVersion(module) {\n const [moduleMajor, moduleMinor] = module.version.split('.') || [];\n const [currentModuleMajor, currentModuleMinor] = ModuleRegistry.currentModuleVersion.split('.') || [];\n return moduleMajor === currentModuleMajor && moduleMinor === currentModuleMinor;\n }\n static runVersionChecks(module) {\n if (!ModuleRegistry.currentModuleVersion) {\n ModuleRegistry.currentModuleVersion = module.version;\n }\n if (!module.version) {\n console.error(`AG Grid: You are using incompatible versions of AG Grid modules. Major and minor versions should always match across modules. '${module.moduleName}' is incompatible. Please update all modules to the same version.`);\n }\n else if (!ModuleRegistry.isValidModuleVersion(module)) {\n console.error(`AG Grid: You are using incompatible versions of AG Grid modules. Major and minor versions should always match across modules. '${module.moduleName}' is version ${module.version} but the other modules are version ${this.currentModuleVersion}. Please update all modules to the same version.`);\n }\n if (module.validate) {\n const result = module.validate();\n if (!result.isValid) {\n const errorResult = result;\n console.error(`AG Grid: ${errorResult.message}`);\n }\n }\n }\n static setModuleBased(moduleBased) {\n if (ModuleRegistry.moduleBased === undefined) {\n ModuleRegistry.moduleBased = moduleBased;\n }\n else {\n if (ModuleRegistry.moduleBased !== moduleBased) {\n doOnce(() => {\n console.warn(`AG Grid: You are mixing modules (i.e. @ag-grid-community/core) and packages (ag-grid-community) - you can only use one or the other of these mechanisms.`);\n console.warn('Please see https://www.ag-grid.com/javascript-grid/packages-modules/ for more information.');\n }, 'ModulePackageCheck');\n }\n }\n }\n /**\n * AG GRID INTERNAL - Set if files are being served from a single UMD bundle to provide accurate enterprise upgrade steps.\n */\n static __setIsBundled() {\n ModuleRegistry.isBundled = true;\n }\n /** AG GRID INTERNAL - Assert a given module has been register, globally or individually with this grid. */\n static __assertRegistered(moduleName, reason, gridId) {\n var _a;\n if (this.__isRegistered(moduleName, gridId)) {\n return true;\n }\n const warningKey = reason + moduleName;\n let warningMessage;\n if (ModuleRegistry.isBundled) {\n {\n warningMessage =\n `AG Grid: unable to use ${reason} as 'ag-grid-enterprise' has not been loaded. Check you are using the Enterprise bundle:\n \n \n \nFor more info see: https://ag-grid.com/javascript-data-grid/getting-started/#getting-started-with-ag-grid-enterprise`;\n }\n }\n else if (ModuleRegistry.moduleBased || ModuleRegistry.moduleBased === undefined) {\n let modName = (_a = Object.entries(ModuleNames).find(([k, v]) => v === moduleName)) === null || _a === void 0 ? void 0 : _a[0];\n warningMessage =\n `AG Grid: unable to use ${reason} as the ${modName} is not registered${ModuleRegistry.areGridScopedModules ? ` for gridId: ${gridId}` : ''}. Check if you have registered the module:\n \n import { ModuleRegistry } from '@ag-grid-community/core';\n import { ${modName} } from '${moduleName}';\n \n ModuleRegistry.registerModules([ ${modName} ]);\n\nFor more info see: https://www.ag-grid.com/javascript-grid/modules/`;\n }\n else {\n warningMessage =\n `AG Grid: unable to use ${reason} as package 'ag-grid-enterprise' has not been imported. Check that you have imported the package:\n \n import 'ag-grid-enterprise';\n \nFor more info see: https://www.ag-grid.com/javascript-grid/packages/`;\n }\n doOnce(() => {\n console.warn(warningMessage);\n }, warningKey);\n return false;\n }\n /** AG GRID INTERNAL - Is the given module registered, globally or individually with this grid. */\n static __isRegistered(moduleName, gridId) {\n var _a;\n return !!ModuleRegistry.globalModulesMap[moduleName] || !!((_a = ModuleRegistry.gridModulesMap[gridId]) === null || _a === void 0 ? void 0 : _a[moduleName]);\n }\n /** AG GRID INTERNAL - Get all registered modules globally / individually for this grid. */\n static __getRegisteredModules(gridId) {\n return [...values(ModuleRegistry.globalModulesMap), ...values(ModuleRegistry.gridModulesMap[gridId] || {})];\n }\n /** AG GRID INTERNAL - Get the list of modules registered individually for this grid. */\n static __getGridRegisteredModules(gridId) {\n var _a;\n return values((_a = ModuleRegistry.gridModulesMap[gridId]) !== null && _a !== void 0 ? _a : {}) || [];\n }\n /** INTERNAL */\n static __isPackageBased() {\n return !ModuleRegistry.moduleBased;\n }\n}\n// having in a map a) removes duplicates and b) allows fast lookup\nModuleRegistry.globalModulesMap = {};\nModuleRegistry.gridModulesMap = {};\nModuleRegistry.areGridScopedModules = false;\n","import { exists, values } from \"../utils/generic.mjs\";\nimport { iterateObject } from \"../utils/object.mjs\";\nimport { getFunctionName } from \"../utils/function.mjs\";\nimport { ModuleRegistry } from \"../modules/moduleRegistry.mjs\";\nexport class Context {\n constructor(params, logger) {\n this.beanWrappers = {};\n this.destroyed = false;\n if (!params || !params.beanClasses) {\n return;\n }\n this.contextParams = params;\n this.logger = logger;\n this.logger.log(\">> creating ag-Application Context\");\n this.createBeans();\n const beanInstances = this.getBeanInstances();\n this.wireBeans(beanInstances);\n this.logger.log(\">> ag-Application Context ready - component is alive\");\n }\n getBeanInstances() {\n return values(this.beanWrappers).map(beanEntry => beanEntry.beanInstance);\n }\n createBean(bean, afterPreCreateCallback) {\n if (!bean) {\n throw Error(`Can't wire to bean since it is null`);\n }\n this.wireBeans([bean], afterPreCreateCallback);\n return bean;\n }\n wireBeans(beanInstances, afterPreCreateCallback) {\n this.autoWireBeans(beanInstances);\n this.methodWireBeans(beanInstances);\n this.callLifeCycleMethods(beanInstances, 'preConstructMethods');\n // the callback sets the attributes, so the component has access to attributes\n // before postConstruct methods in the component are executed\n if (exists(afterPreCreateCallback)) {\n beanInstances.forEach(afterPreCreateCallback);\n }\n this.callLifeCycleMethods(beanInstances, 'postConstructMethods');\n }\n createBeans() {\n // register all normal beans\n this.contextParams.beanClasses.forEach(this.createBeanWrapper.bind(this));\n // register override beans, these will overwrite beans above of same name\n // instantiate all beans - overridden beans will be left out\n iterateObject(this.beanWrappers, (key, beanEntry) => {\n let constructorParamsMeta;\n if (beanEntry.bean.__agBeanMetaData && beanEntry.bean.__agBeanMetaData.autowireMethods && beanEntry.bean.__agBeanMetaData.autowireMethods.agConstructor) {\n constructorParamsMeta = beanEntry.bean.__agBeanMetaData.autowireMethods.agConstructor;\n }\n const constructorParams = this.getBeansForParameters(constructorParamsMeta, beanEntry.bean.name);\n const newInstance = new (beanEntry.bean.bind.apply(beanEntry.bean, [null, ...constructorParams]));\n beanEntry.beanInstance = newInstance;\n });\n const createdBeanNames = Object.keys(this.beanWrappers).join(', ');\n this.logger.log(`created beans: ${createdBeanNames}`);\n }\n // tslint:disable-next-line\n createBeanWrapper(BeanClass) {\n const metaData = BeanClass.__agBeanMetaData;\n if (!metaData) {\n let beanName;\n if (BeanClass.prototype.constructor) {\n beanName = getFunctionName(BeanClass.prototype.constructor);\n }\n else {\n beanName = \"\" + BeanClass;\n }\n console.error(`Context item ${beanName} is not a bean`);\n return;\n }\n const beanEntry = {\n bean: BeanClass,\n beanInstance: null,\n beanName: metaData.beanName\n };\n this.beanWrappers[metaData.beanName] = beanEntry;\n }\n autoWireBeans(beanInstances) {\n beanInstances.forEach(beanInstance => {\n this.forEachMetaDataInHierarchy(beanInstance, (metaData, beanName) => {\n const attributes = metaData.agClassAttributes;\n if (!attributes) {\n return;\n }\n attributes.forEach((attribute) => {\n const otherBean = this.lookupBeanInstance(beanName, attribute.beanName, attribute.optional);\n beanInstance[attribute.attributeName] = otherBean;\n });\n });\n });\n }\n methodWireBeans(beanInstances) {\n beanInstances.forEach(beanInstance => {\n this.forEachMetaDataInHierarchy(beanInstance, (metaData, beanName) => {\n iterateObject(metaData.autowireMethods, (methodName, wireParams) => {\n // skip constructor, as this is dealt with elsewhere\n if (methodName === \"agConstructor\") {\n return;\n }\n const initParams = this.getBeansForParameters(wireParams, beanName);\n beanInstance[methodName].apply(beanInstance, initParams);\n });\n });\n });\n }\n forEachMetaDataInHierarchy(beanInstance, callback) {\n let prototype = Object.getPrototypeOf(beanInstance);\n while (prototype != null) {\n const constructor = prototype.constructor;\n if (constructor.hasOwnProperty('__agBeanMetaData')) {\n const metaData = constructor.__agBeanMetaData;\n const beanName = this.getBeanName(constructor);\n callback(metaData, beanName);\n }\n prototype = Object.getPrototypeOf(prototype);\n }\n }\n getBeanName(constructor) {\n if (constructor.__agBeanMetaData && constructor.__agBeanMetaData.beanName) {\n return constructor.__agBeanMetaData.beanName;\n }\n const constructorString = constructor.toString();\n const beanName = constructorString.substring(9, constructorString.indexOf(\"(\"));\n return beanName;\n }\n getBeansForParameters(parameters, beanName) {\n const beansList = [];\n if (parameters) {\n iterateObject(parameters, (paramIndex, otherBeanName) => {\n const otherBean = this.lookupBeanInstance(beanName, otherBeanName);\n beansList[Number(paramIndex)] = otherBean;\n });\n }\n return beansList;\n }\n lookupBeanInstance(wiringBean, beanName, optional = false) {\n if (this.destroyed) {\n this.logger.log(`AG Grid: bean reference ${beanName} is used after the grid is destroyed!`);\n return null;\n }\n if (beanName === \"context\") {\n return this;\n }\n if (this.contextParams.providedBeanInstances && this.contextParams.providedBeanInstances.hasOwnProperty(beanName)) {\n return this.contextParams.providedBeanInstances[beanName];\n }\n const beanEntry = this.beanWrappers[beanName];\n if (beanEntry) {\n return beanEntry.beanInstance;\n }\n if (!optional) {\n console.error(`AG Grid: unable to find bean reference ${beanName} while initialising ${wiringBean}`);\n }\n return null;\n }\n callLifeCycleMethods(beanInstances, lifeCycleMethod) {\n beanInstances.forEach(beanInstance => this.callLifeCycleMethodsOnBean(beanInstance, lifeCycleMethod));\n }\n callLifeCycleMethodsOnBean(beanInstance, lifeCycleMethod, methodToIgnore) {\n // putting all methods into a map removes duplicates\n const allMethods = {};\n // dump methods from each level of the metadata hierarchy\n this.forEachMetaDataInHierarchy(beanInstance, (metaData) => {\n const methods = metaData[lifeCycleMethod];\n if (methods) {\n methods.forEach(methodName => {\n if (methodName != methodToIgnore) {\n allMethods[methodName] = true;\n }\n });\n }\n });\n const allMethodsList = Object.keys(allMethods);\n allMethodsList.forEach(methodName => beanInstance[methodName]());\n }\n getBean(name) {\n return this.lookupBeanInstance(\"getBean\", name, true);\n }\n destroy() {\n if (this.destroyed) {\n return;\n }\n // Set before doing the destroy, so if context.destroy() gets called via another bean\n // we are marked as destroyed already to prevent running destroy() twice\n this.destroyed = true;\n this.logger.log(\">> Shutting down ag-Application Context\");\n const beanInstances = this.getBeanInstances();\n this.destroyBeans(beanInstances);\n this.contextParams.providedBeanInstances = null;\n ModuleRegistry.__unRegisterGridModules(this.contextParams.gridId);\n this.logger.log(\">> ag-Application Context shut down - component is dead\");\n }\n destroyBean(bean) {\n if (!bean) {\n return;\n }\n this.destroyBeans([bean]);\n }\n destroyBeans(beans) {\n if (!beans) {\n return [];\n }\n beans.forEach(bean => {\n this.callLifeCycleMethodsOnBean(bean, 'preDestroyMethods', 'destroy');\n // call destroy() explicitly if it exists\n const beanAny = bean;\n if (typeof beanAny.destroy === 'function') {\n beanAny.destroy();\n }\n });\n return [];\n }\n isDestroyed() {\n return this.destroyed;\n }\n getGridId() {\n return this.contextParams.gridId;\n }\n}\nexport function PreConstruct(target, methodName, descriptor) {\n const props = getOrCreateProps(target.constructor);\n if (!props.preConstructMethods) {\n props.preConstructMethods = [];\n }\n props.preConstructMethods.push(methodName);\n}\nexport function PostConstruct(target, methodName, descriptor) {\n const props = getOrCreateProps(target.constructor);\n if (!props.postConstructMethods) {\n props.postConstructMethods = [];\n }\n props.postConstructMethods.push(methodName);\n}\nexport function PreDestroy(target, methodName, descriptor) {\n const props = getOrCreateProps(target.constructor);\n if (!props.preDestroyMethods) {\n props.preDestroyMethods = [];\n }\n props.preDestroyMethods.push(methodName);\n}\nexport function Bean(beanName) {\n return (classConstructor) => {\n const props = getOrCreateProps(classConstructor);\n props.beanName = beanName;\n };\n}\nexport function Autowired(name) {\n return (target, propertyKey, descriptor) => {\n autowiredFunc(target, name, false, target, propertyKey, null);\n };\n}\nexport function Optional(name) {\n return (target, propertyKey, descriptor) => {\n autowiredFunc(target, name, true, target, propertyKey, null);\n };\n}\nfunction autowiredFunc(target, name, optional, classPrototype, methodOrAttributeName, index) {\n if (name === null) {\n console.error(\"AG Grid: Autowired name should not be null\");\n return;\n }\n if (typeof index === \"number\") {\n console.error(\"AG Grid: Autowired should be on an attribute\");\n return;\n }\n // it's an attribute on the class\n const props = getOrCreateProps(target.constructor);\n if (!props.agClassAttributes) {\n props.agClassAttributes = [];\n }\n props.agClassAttributes.push({\n attributeName: methodOrAttributeName,\n beanName: name,\n optional: optional\n });\n}\nexport function Qualifier(name) {\n return (classPrototype, methodOrAttributeName, index) => {\n const constructor = typeof classPrototype == \"function\" ? classPrototype : classPrototype.constructor;\n let props;\n if (typeof index === \"number\") {\n // it's a parameter on a method\n let methodName;\n if (methodOrAttributeName) {\n props = getOrCreateProps(constructor);\n methodName = methodOrAttributeName;\n }\n else {\n props = getOrCreateProps(constructor);\n methodName = \"agConstructor\";\n }\n if (!props.autowireMethods) {\n props.autowireMethods = {};\n }\n if (!props.autowireMethods[methodName]) {\n props.autowireMethods[methodName] = {};\n }\n props.autowireMethods[methodName][index] = name;\n }\n };\n}\nfunction getOrCreateProps(target) {\n if (!target.hasOwnProperty(\"__agBeanMetaData\")) {\n target.__agBeanMetaData = {};\n }\n return target.__agBeanMetaData;\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n};\nimport { Bean, Qualifier } from \"./context/context.mjs\";\nlet EventService = class EventService {\n constructor() {\n this.allSyncListeners = new Map();\n this.allAsyncListeners = new Map();\n this.globalSyncListeners = new Set();\n this.globalAsyncListeners = new Set();\n this.asyncFunctionsQueue = [];\n this.scheduled = false;\n // using an object performs better than a Set for the number of different events we have\n this.firedEvents = {};\n }\n // because this class is used both inside the context and outside the context, we do not\n // use autowired attributes, as that would be confusing, as sometimes the attributes\n // would be wired, and sometimes not.\n //\n // the global event servers used by AG Grid is autowired by the context once, and this\n // setBeans method gets called once.\n //\n // the times when this class is used outside of the context (eg RowNode has an instance of this\n // class) then it is not a bean, and this setBeans method is not called.\n setBeans(loggerFactory, gridOptionsService, frameworkOverrides, globalEventListener = null, globalSyncEventListener = null) {\n this.frameworkOverrides = frameworkOverrides;\n this.gridOptionsService = gridOptionsService;\n if (globalEventListener) {\n const async = gridOptionsService.useAsyncEvents();\n this.addGlobalListener(globalEventListener, async);\n }\n if (globalSyncEventListener) {\n this.addGlobalListener(globalSyncEventListener, false);\n }\n }\n getListeners(eventType, async, autoCreateListenerCollection) {\n const listenerMap = async ? this.allAsyncListeners : this.allSyncListeners;\n let listeners = listenerMap.get(eventType);\n // Note: 'autoCreateListenerCollection' should only be 'true' if a listener is about to be added. For instance\n // getListeners() is also called during event dispatch even though no listeners are added. This measure protects\n // against 'memory bloat' as empty collections will prevent the RowNode's event service from being removed after\n // the RowComp is destroyed, see noRegisteredListenersExist() below.\n if (!listeners && autoCreateListenerCollection) {\n listeners = new Set();\n listenerMap.set(eventType, listeners);\n }\n return listeners;\n }\n noRegisteredListenersExist() {\n return this.allSyncListeners.size === 0 && this.allAsyncListeners.size === 0 &&\n this.globalSyncListeners.size === 0 && this.globalAsyncListeners.size === 0;\n }\n addEventListener(eventType, listener, async = false) {\n this.getListeners(eventType, async, true).add(listener);\n }\n removeEventListener(eventType, listener, async = false) {\n const listeners = this.getListeners(eventType, async, false);\n if (!listeners) {\n return;\n }\n listeners.delete(listener);\n if (listeners.size === 0) {\n const listenerMap = async ? this.allAsyncListeners : this.allSyncListeners;\n listenerMap.delete(eventType);\n }\n }\n addGlobalListener(listener, async = false) {\n (async ? this.globalAsyncListeners : this.globalSyncListeners).add(listener);\n }\n removeGlobalListener(listener, async = false) {\n (async ? this.globalAsyncListeners : this.globalSyncListeners).delete(listener);\n }\n dispatchEvent(event) {\n let agEvent = event;\n if (this.gridOptionsService) {\n // Apply common properties to all dispatched events if this event service has had its beans set with gridOptionsService.\n // Note there are multiple instances of EventService that are used local to components which do not set gridOptionsService.\n const { api, columnApi, context } = this.gridOptionsService;\n agEvent.api = api;\n agEvent.columnApi = columnApi;\n agEvent.context = context;\n }\n this.dispatchToListeners(agEvent, true);\n this.dispatchToListeners(agEvent, false);\n this.firedEvents[agEvent.type] = true;\n }\n dispatchEventOnce(event) {\n if (!this.firedEvents[event.type]) {\n this.dispatchEvent(event);\n }\n }\n dispatchToListeners(event, async) {\n const eventType = event.type;\n if (async && 'event' in event) {\n const browserEvent = event.event;\n if (browserEvent instanceof Event) {\n // AG-7893 - Persist composedPath() so that its result can still be accessed by the user asynchronously.\n // Within an async event handler if they call composedPath() on the event it will always return an empty [].\n event.eventPath = browserEvent.composedPath();\n }\n }\n const processEventListeners = (listeners) => listeners.forEach(listener => {\n if (async) {\n this.dispatchAsync(() => listener(event));\n }\n else {\n listener(event);\n }\n });\n // create a shallow copy to prevent listeners cyclically adding more listeners to capture this event\n const listeners = new Set(this.getListeners(eventType, async, false));\n if (listeners.size > 0) {\n processEventListeners(listeners);\n }\n const globalListeners = new Set(async ? this.globalAsyncListeners : this.globalSyncListeners);\n globalListeners.forEach(listener => {\n if (async) {\n this.dispatchAsync(() => this.frameworkOverrides.dispatchEvent(eventType, () => listener(eventType, event), true));\n }\n else {\n this.frameworkOverrides.dispatchEvent(eventType, () => listener(eventType, event), true);\n }\n });\n }\n // this gets called inside the grid's thread, for each event that it\n // wants to set async. the grid then batches the events into one setTimeout()\n // because setTimeout() is an expensive operation. ideally we would have\n // each event in it's own setTimeout(), but we batch for performance.\n dispatchAsync(func) {\n // add to the queue for executing later in the next VM turn\n this.asyncFunctionsQueue.push(func);\n // check if timeout is already scheduled. the first time the grid calls\n // this within it's thread turn, this should be false, so it will schedule\n // the 'flush queue' method the first time it comes here. then the flag is\n // set to 'true' so it will know it's already scheduled for subsequent calls.\n if (!this.scheduled) {\n // if not scheduled, schedule one\n window.setTimeout(this.flushAsyncQueue.bind(this), 0);\n // mark that it is scheduled\n this.scheduled = true;\n }\n }\n // this happens in the next VM turn only, and empties the queue of events\n flushAsyncQueue() {\n this.scheduled = false;\n // we take a copy, because the event listener could be using\n // the grid, which would cause more events, which would be potentially\n // added to the queue, so safe to take a copy, the new events will\n // get executed in a later VM turn rather than risk updating the\n // queue as we are flushing it.\n const queueCopy = this.asyncFunctionsQueue.slice();\n this.asyncFunctionsQueue = [];\n // execute the queue\n queueCopy.forEach(func => func());\n }\n};\n__decorate([\n __param(0, Qualifier('loggerFactory')),\n __param(1, Qualifier('gridOptionsService')),\n __param(2, Qualifier('frameworkOverrides')),\n __param(3, Qualifier('globalEventListener')),\n __param(4, Qualifier('globalSyncEventListener'))\n], EventService.prototype, \"setBeans\", null);\nEventService = __decorate([\n Bean('eventService')\n], EventService);\nexport { EventService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { EventService } from \"../eventService.mjs\";\nimport { Autowired, PostConstruct } from \"../context/context.mjs\";\nimport { ModuleNames } from \"../modules/moduleNames.mjs\";\nimport { ModuleRegistry } from \"../modules/moduleRegistry.mjs\";\nimport { attrToNumber, attrToBoolean, exists, missing } from \"../utils/generic.mjs\";\nimport { doOnce } from \"../utils/function.mjs\";\nimport { mergeDeep } from \"../utils/object.mjs\";\nlet instanceIdSequence = 0;\nexport function getNextColInstanceId() {\n return instanceIdSequence++;\n}\n// Wrapper around a user provide column definition. The grid treats the column definition as ready only.\n// This class contains all the runtime information about a column, plus some logic (the definition has no logic).\n// This class implements both interfaces ColumnGroupChild and ProvidedColumnGroupChild as the class can\n// appear as a child of either the original tree or the displayed tree. However the relevant group classes\n// for each type only implements one, as each group can only appear in it's associated tree (eg ProvidedColumnGroup\n// can only appear in OriginalColumn tree).\nexport class Column {\n constructor(colDef, userProvidedColDef, colId, primary) {\n // used by React (and possibly other frameworks) as key for rendering. also used to\n // identify old vs new columns for destroying cols when no longer used.\n this.instanceId = getNextColInstanceId();\n // The measured height of this column's header when autoHeaderHeight is enabled\n this.autoHeaderHeight = null;\n this.moving = false;\n this.menuVisible = false;\n this.lastLeftPinned = false;\n this.firstRightPinned = false;\n this.filterActive = false;\n this.eventService = new EventService();\n this.tooltipEnabled = false;\n this.rowGroupActive = false;\n this.pivotActive = false;\n this.aggregationActive = false;\n this.colDef = colDef;\n this.userProvidedColDef = userProvidedColDef;\n this.colId = colId;\n this.primary = primary;\n this.setState(colDef);\n }\n getInstanceId() {\n return this.instanceId;\n }\n setState(colDef) {\n // sort\n if (colDef.sort !== undefined) {\n if (colDef.sort === 'asc' || colDef.sort === 'desc') {\n this.sort = colDef.sort;\n }\n }\n else {\n if (colDef.initialSort === 'asc' || colDef.initialSort === 'desc') {\n this.sort = colDef.initialSort;\n }\n }\n // sortIndex\n const sortIndex = attrToNumber(colDef.sortIndex);\n const initialSortIndex = attrToNumber(colDef.initialSortIndex);\n if (sortIndex !== undefined) {\n if (sortIndex !== null) {\n this.sortIndex = sortIndex;\n }\n }\n else {\n if (initialSortIndex !== null) {\n this.sortIndex = initialSortIndex;\n }\n }\n // hide\n const hide = attrToBoolean(colDef.hide);\n const initialHide = attrToBoolean(colDef.initialHide);\n if (hide !== undefined) {\n this.visible = !hide;\n }\n else {\n this.visible = !initialHide;\n }\n // pinned\n if (colDef.pinned !== undefined) {\n this.setPinned(colDef.pinned);\n }\n else {\n this.setPinned(colDef.initialPinned);\n }\n // flex\n const flex = attrToNumber(colDef.flex);\n const initialFlex = attrToNumber(colDef.initialFlex);\n if (flex !== undefined) {\n this.flex = flex;\n }\n else if (initialFlex !== undefined) {\n this.flex = initialFlex;\n }\n }\n // gets called when user provides an alternative colDef, eg\n setColDef(colDef, userProvidedColDef) {\n this.colDef = colDef;\n this.userProvidedColDef = userProvidedColDef;\n this.initMinAndMaxWidths();\n this.initDotNotation();\n this.eventService.dispatchEvent(this.createColumnEvent('colDefChanged', \"api\"));\n }\n /**\n * Returns the column definition provided by the application.\n * This may not be correct, as items can be superseded by default column options.\n * However it's useful for comparison, eg to know which application column definition matches that column.\n */\n getUserProvidedColDef() {\n return this.userProvidedColDef;\n }\n setParent(parent) {\n this.parent = parent;\n }\n /** Returns the parent column group, if column grouping is active. */\n getParent() {\n return this.parent;\n }\n setOriginalParent(originalParent) {\n this.originalParent = originalParent;\n }\n /**\n * Used for marryChildren, helps with comparing when duplicate groups have been created to manage split groups.\n *\n * Parent may contain a duplicate but not identical group when the group is split.\n */\n getOriginalParent() {\n return this.originalParent;\n }\n // this is done after constructor as it uses gridOptionsService\n initialise() {\n this.initMinAndMaxWidths();\n this.resetActualWidth('gridInitializing');\n this.initDotNotation();\n this.initTooltip();\n this.validate();\n }\n initDotNotation() {\n const suppressDotNotation = this.gridOptionsService.is('suppressFieldDotNotation');\n this.fieldContainsDots = exists(this.colDef.field) && this.colDef.field.indexOf('.') >= 0 && !suppressDotNotation;\n this.tooltipFieldContainsDots = exists(this.colDef.tooltipField) && this.colDef.tooltipField.indexOf('.') >= 0 && !suppressDotNotation;\n }\n initMinAndMaxWidths() {\n const colDef = this.colDef;\n this.minWidth = this.columnUtils.calculateColMinWidth(colDef);\n this.maxWidth = this.columnUtils.calculateColMaxWidth(colDef);\n }\n initTooltip() {\n this.tooltipEnabled = exists(this.colDef.tooltipField) ||\n exists(this.colDef.tooltipValueGetter) ||\n exists(this.colDef.tooltipComponent);\n }\n resetActualWidth(source = 'api') {\n const initialWidth = this.columnUtils.calculateColInitialWidth(this.colDef);\n this.setActualWidth(initialWidth, source, true);\n }\n isEmptyGroup() {\n return false;\n }\n isRowGroupDisplayed(colId) {\n if (missing(this.colDef) || missing(this.colDef.showRowGroup)) {\n return false;\n }\n const showingAllGroups = this.colDef.showRowGroup === true;\n const showingThisGroup = this.colDef.showRowGroup === colId;\n return showingAllGroups || showingThisGroup;\n }\n /** Returns `true` if column is a primary column, `false` if secondary. Secondary columns are used for pivoting. */\n isPrimary() {\n return this.primary;\n }\n /** Returns `true` if column filtering is allowed. */\n isFilterAllowed() {\n // filter defined means it's a string, class or true.\n // if its false, null or undefined then it's false.\n const filterDefined = !!this.colDef.filter;\n return filterDefined;\n }\n isFieldContainsDots() {\n return this.fieldContainsDots;\n }\n isTooltipEnabled() {\n return this.tooltipEnabled;\n }\n isTooltipFieldContainsDots() {\n return this.tooltipFieldContainsDots;\n }\n validate() {\n const colDefAny = this.colDef;\n function warnOnce(msg, key, obj) {\n doOnce(() => {\n if (obj) {\n console.warn(msg, obj);\n }\n else {\n doOnce(() => console.warn(msg), key);\n }\n }, key);\n }\n const usingCSRM = this.gridOptionsService.isRowModelType('clientSide');\n if (usingCSRM && !ModuleRegistry.__isRegistered(ModuleNames.RowGroupingModule, this.gridOptionsService.getGridId())) {\n const rowGroupingItems = ['enableRowGroup', 'rowGroup', 'rowGroupIndex', 'enablePivot', 'enableValue', 'pivot', 'pivotIndex', 'aggFunc'];\n const itemsUsed = rowGroupingItems.filter(x => exists(colDefAny[x]));\n if (itemsUsed.length > 0) {\n ModuleRegistry.__assertRegistered(ModuleNames.RowGroupingModule, itemsUsed.map(i => 'colDef.' + i).join(', '), this.gridOptionsService.getGridId());\n }\n }\n if (this.colDef.cellEditor === 'agRichSelect' || this.colDef.cellEditor === 'agRichSelectCellEditor') {\n ModuleRegistry.__assertRegistered(ModuleNames.RichSelectModule, this.colDef.cellEditor, this.gridOptionsService.getGridId());\n }\n if (this.gridOptionsService.is('treeData')) {\n const itemsNotAllowedWithTreeData = ['rowGroup', 'rowGroupIndex', 'pivot', 'pivotIndex'];\n const itemsUsed = itemsNotAllowedWithTreeData.filter(x => exists(colDefAny[x]));\n if (itemsUsed.length > 0) {\n warnOnce(`AG Grid: ${itemsUsed.join()} is not possible when doing tree data, your column definition should not have ${itemsUsed.join()}`, 'TreeDataCannotRowGroup');\n }\n }\n if (exists(colDefAny.menuTabs)) {\n if (Array.isArray(colDefAny.menuTabs)) {\n const communityMenuTabs = ['filterMenuTab'];\n const enterpriseMenuTabs = ['columnsMenuTab', 'generalMenuTab'];\n const itemsUsed = enterpriseMenuTabs.filter(x => colDefAny.menuTabs.includes(x));\n if (itemsUsed.length > 0) {\n ModuleRegistry.__assertRegistered(ModuleNames.MenuModule, `menuTab(s): ${itemsUsed.map(t => `'${t}'`).join()}`, this.gridOptionsService.getGridId());\n }\n colDefAny.menuTabs.forEach((tab) => {\n if (!enterpriseMenuTabs.includes(tab) && !communityMenuTabs.includes(tab)) {\n warnOnce(`AG Grid: '${tab}' is not valid for 'colDef.menuTabs'. Valid values are: ${[...communityMenuTabs, ...enterpriseMenuTabs].map(t => `'${t}'`).join()}.`, 'wrongValue_menuTabs_' + tab);\n }\n });\n }\n else {\n warnOnce(`AG Grid: The typeof 'colDef.menuTabs' should be an array not:` + typeof colDefAny.menuTabs, 'wrongType_menuTabs');\n }\n }\n if (exists(colDefAny.columnsMenuParams)) {\n ModuleRegistry.__assertRegistered(ModuleNames.MenuModule, 'columnsMenuParams', this.gridOptionsService.getGridId());\n }\n if (exists(colDefAny.columnsMenuParams)) {\n ModuleRegistry.__assertRegistered(ModuleNames.ColumnsToolPanelModule, 'columnsMenuParams', this.gridOptionsService.getGridId());\n }\n if (exists(this.colDef.width) && typeof this.colDef.width !== 'number') {\n warnOnce('AG Grid: colDef.width should be a number, not ' + typeof this.colDef.width, 'ColumnCheck');\n }\n if (exists(colDefAny.columnGroupShow) && colDefAny.columnGroupShow !== 'closed' && colDefAny.columnGroupShow !== 'open') {\n warnOnce(`AG Grid: '${colDefAny.columnGroupShow}' is not valid for columnGroupShow. Valid values are 'open', 'closed', undefined, null`, 'columnGroupShow_invalid');\n }\n }\n /** Add an event listener to the column. */\n addEventListener(eventType, listener) {\n this.eventService.addEventListener(eventType, listener);\n }\n /** Remove event listener from the column. */\n removeEventListener(eventType, listener) {\n this.eventService.removeEventListener(eventType, listener);\n }\n createColumnFunctionCallbackParams(rowNode) {\n return {\n node: rowNode,\n data: rowNode.data,\n column: this,\n colDef: this.colDef,\n context: this.gridOptionsService.context,\n api: this.gridOptionsService.api,\n columnApi: this.gridOptionsService.columnApi\n };\n }\n isSuppressNavigable(rowNode) {\n // if boolean set, then just use it\n if (typeof this.colDef.suppressNavigable === 'boolean') {\n return this.colDef.suppressNavigable;\n }\n // if function, then call the function to find out\n if (typeof this.colDef.suppressNavigable === 'function') {\n const params = this.createColumnFunctionCallbackParams(rowNode);\n const userFunc = this.colDef.suppressNavigable;\n return userFunc(params);\n }\n return false;\n }\n /**\n * Returns `true` if the cell for this column is editable for the given `rowNode`, otherwise `false`.\n */\n isCellEditable(rowNode) {\n // only allow editing of groups if the user has this option enabled\n if (rowNode.group && !this.gridOptionsService.is('enableGroupEdit')) {\n return false;\n }\n return this.isColumnFunc(rowNode, this.colDef.editable);\n }\n isSuppressFillHandle() {\n return !!attrToBoolean(this.colDef.suppressFillHandle);\n }\n isAutoHeight() {\n return !!attrToBoolean(this.colDef.autoHeight);\n }\n isAutoHeaderHeight() {\n return !!attrToBoolean(this.colDef.autoHeaderHeight);\n }\n isRowDrag(rowNode) {\n return this.isColumnFunc(rowNode, this.colDef.rowDrag);\n }\n isDndSource(rowNode) {\n return this.isColumnFunc(rowNode, this.colDef.dndSource);\n }\n isCellCheckboxSelection(rowNode) {\n return this.isColumnFunc(rowNode, this.colDef.checkboxSelection);\n }\n isSuppressPaste(rowNode) {\n return this.isColumnFunc(rowNode, this.colDef ? this.colDef.suppressPaste : null);\n }\n isResizable() {\n return !!attrToBoolean(this.colDef.resizable);\n }\n isColumnFunc(rowNode, value) {\n // if boolean set, then just use it\n if (typeof value === 'boolean') {\n return value;\n }\n // if function, then call the function to find out\n if (typeof value === 'function') {\n const params = this.createColumnFunctionCallbackParams(rowNode);\n const editableFunc = value;\n return editableFunc(params);\n }\n return false;\n }\n setMoving(moving, source = \"api\") {\n this.moving = moving;\n this.eventService.dispatchEvent(this.createColumnEvent('movingChanged', source));\n }\n createColumnEvent(type, source) {\n return {\n type: type,\n column: this,\n columns: [this],\n source: source,\n api: this.gridOptionsService.api,\n columnApi: this.gridOptionsService.columnApi,\n context: this.gridOptionsService.context\n };\n }\n isMoving() {\n return this.moving;\n }\n /** If sorting is active, returns the sort direction e.g. `'asc'` or `'desc'`. */\n getSort() {\n return this.sort;\n }\n setSort(sort, source = \"api\") {\n if (this.sort !== sort) {\n this.sort = sort;\n this.eventService.dispatchEvent(this.createColumnEvent('sortChanged', source));\n }\n this.dispatchStateUpdatedEvent('sort');\n }\n setMenuVisible(visible, source = \"api\") {\n if (this.menuVisible !== visible) {\n this.menuVisible = visible;\n this.eventService.dispatchEvent(this.createColumnEvent('menuVisibleChanged', source));\n }\n }\n isMenuVisible() {\n return this.menuVisible;\n }\n isSortAscending() {\n return this.sort === 'asc';\n }\n isSortDescending() {\n return this.sort === 'desc';\n }\n isSortNone() {\n return missing(this.sort);\n }\n isSorting() {\n return exists(this.sort);\n }\n getSortIndex() {\n return this.sortIndex;\n }\n setSortIndex(sortOrder) {\n this.sortIndex = sortOrder;\n this.dispatchStateUpdatedEvent('sortIndex');\n }\n setAggFunc(aggFunc) {\n this.aggFunc = aggFunc;\n this.dispatchStateUpdatedEvent('aggFunc');\n }\n /** If aggregation is set for the column, returns the aggregation function. */\n getAggFunc() {\n return this.aggFunc;\n }\n getLeft() {\n return this.left;\n }\n getOldLeft() {\n return this.oldLeft;\n }\n getRight() {\n return this.left + this.actualWidth;\n }\n setLeft(left, source = \"api\") {\n this.oldLeft = this.left;\n if (this.left !== left) {\n this.left = left;\n this.eventService.dispatchEvent(this.createColumnEvent('leftChanged', source));\n }\n }\n /** Returns `true` if filter is active on the column. */\n isFilterActive() {\n return this.filterActive;\n }\n // additionalEventAttributes is used by provided simple floating filter, so it can add 'floatingFilter=true' to the event\n setFilterActive(active, source = \"api\", additionalEventAttributes) {\n if (this.filterActive !== active) {\n this.filterActive = active;\n this.eventService.dispatchEvent(this.createColumnEvent('filterActiveChanged', source));\n }\n const filterChangedEvent = this.createColumnEvent('filterChanged', source);\n if (additionalEventAttributes) {\n mergeDeep(filterChangedEvent, additionalEventAttributes);\n }\n this.eventService.dispatchEvent(filterChangedEvent);\n }\n /** Returns `true` when this `Column` is hovered, otherwise `false` */\n isHovered() {\n return this.columnHoverService.isHovered(this);\n }\n setPinned(pinned) {\n if (pinned === true || pinned === 'left') {\n this.pinned = 'left';\n }\n else if (pinned === 'right') {\n this.pinned = 'right';\n }\n else {\n this.pinned = null;\n }\n this.dispatchStateUpdatedEvent('pinned');\n }\n setFirstRightPinned(firstRightPinned, source = \"api\") {\n if (this.firstRightPinned !== firstRightPinned) {\n this.firstRightPinned = firstRightPinned;\n this.eventService.dispatchEvent(this.createColumnEvent('firstRightPinnedChanged', source));\n }\n }\n setLastLeftPinned(lastLeftPinned, source = \"api\") {\n if (this.lastLeftPinned !== lastLeftPinned) {\n this.lastLeftPinned = lastLeftPinned;\n this.eventService.dispatchEvent(this.createColumnEvent('lastLeftPinnedChanged', source));\n }\n }\n isFirstRightPinned() {\n return this.firstRightPinned;\n }\n isLastLeftPinned() {\n return this.lastLeftPinned;\n }\n isPinned() {\n return this.pinned === 'left' || this.pinned === 'right';\n }\n isPinnedLeft() {\n return this.pinned === 'left';\n }\n isPinnedRight() {\n return this.pinned === 'right';\n }\n getPinned() {\n return this.pinned;\n }\n setVisible(visible, source = \"api\") {\n const newValue = visible === true;\n if (this.visible !== newValue) {\n this.visible = newValue;\n this.eventService.dispatchEvent(this.createColumnEvent('visibleChanged', source));\n }\n this.dispatchStateUpdatedEvent('hide');\n }\n isVisible() {\n return this.visible;\n }\n isSpanHeaderHeight() {\n const colDef = this.getColDef();\n return !colDef.suppressSpanHeaderHeight && !colDef.autoHeaderHeight;\n }\n /** Returns the column definition for this column.\n * The column definition will be the result of merging the application provided column definition with any provided defaults\n * (e.g. `defaultColDef` grid option, or column types.\n *\n * Equivalent: `getDefinition` */\n getColDef() {\n return this.colDef;\n }\n getColumnGroupShow() {\n return this.colDef.columnGroupShow;\n }\n /**\n * Returns the unique ID for the column.\n *\n * Equivalent: `getId`, `getUniqueId` */\n getColId() {\n return this.colId;\n }\n /**\n * Returns the unique ID for the column.\n *\n * Equivalent: `getColId`, `getUniqueId` */\n getId() {\n return this.colId;\n }\n /**\n * Returns the unique ID for the column.\n *\n * Equivalent: `getColId`, `getId` */\n getUniqueId() {\n return this.colId;\n }\n getDefinition() {\n return this.colDef;\n }\n /** Returns the current width of the column. If the column is resized, the actual width is the new size. */\n getActualWidth() {\n return this.actualWidth;\n }\n getAutoHeaderHeight() {\n return this.autoHeaderHeight;\n }\n /** Returns true if the header height has changed */\n setAutoHeaderHeight(height) {\n const changed = height !== this.autoHeaderHeight;\n this.autoHeaderHeight = height;\n return changed;\n }\n createBaseColDefParams(rowNode) {\n const params = {\n node: rowNode,\n data: rowNode.data,\n colDef: this.colDef,\n column: this,\n api: this.gridOptionsService.api,\n columnApi: this.gridOptionsService.columnApi,\n context: this.gridOptionsService.context\n };\n return params;\n }\n getColSpan(rowNode) {\n if (missing(this.colDef.colSpan)) {\n return 1;\n }\n const params = this.createBaseColDefParams(rowNode);\n const colSpan = this.colDef.colSpan(params);\n // colSpan must be number equal to or greater than 1\n return Math.max(colSpan, 1);\n }\n getRowSpan(rowNode) {\n if (missing(this.colDef.rowSpan)) {\n return 1;\n }\n const params = this.createBaseColDefParams(rowNode);\n const rowSpan = this.colDef.rowSpan(params);\n // rowSpan must be number equal to or greater than 1\n return Math.max(rowSpan, 1);\n }\n setActualWidth(actualWidth, source = \"api\", silent = false) {\n if (this.minWidth != null) {\n actualWidth = Math.max(actualWidth, this.minWidth);\n }\n if (this.maxWidth != null) {\n actualWidth = Math.min(actualWidth, this.maxWidth);\n }\n if (this.actualWidth !== actualWidth) {\n // disable flex for this column if it was manually resized.\n this.actualWidth = actualWidth;\n if (this.flex && source !== 'flex' && source !== 'gridInitializing') {\n this.flex = null;\n }\n if (!silent) {\n this.fireColumnWidthChangedEvent(source);\n }\n }\n this.dispatchStateUpdatedEvent('width');\n }\n fireColumnWidthChangedEvent(source) {\n this.eventService.dispatchEvent(this.createColumnEvent('widthChanged', source));\n }\n isGreaterThanMax(width) {\n if (this.maxWidth != null) {\n return width > this.maxWidth;\n }\n return false;\n }\n getMinWidth() {\n return this.minWidth;\n }\n getMaxWidth() {\n return this.maxWidth;\n }\n getFlex() {\n return this.flex || 0;\n }\n // this method should only be used by the columnModel to\n // change flex when required by the applyColumnState method.\n setFlex(flex) {\n if (this.flex !== flex) {\n this.flex = flex;\n }\n this.dispatchStateUpdatedEvent('flex');\n }\n setMinimum(source = \"api\") {\n if (exists(this.minWidth)) {\n this.setActualWidth(this.minWidth, source);\n }\n }\n setRowGroupActive(rowGroup, source = \"api\") {\n if (this.rowGroupActive !== rowGroup) {\n this.rowGroupActive = rowGroup;\n this.eventService.dispatchEvent(this.createColumnEvent('columnRowGroupChanged', source));\n }\n this.dispatchStateUpdatedEvent('rowGroup');\n }\n /** Returns `true` if row group is currently active for this column. */\n isRowGroupActive() {\n return this.rowGroupActive;\n }\n setPivotActive(pivot, source = \"api\") {\n if (this.pivotActive !== pivot) {\n this.pivotActive = pivot;\n this.eventService.dispatchEvent(this.createColumnEvent('columnPivotChanged', source));\n }\n this.dispatchStateUpdatedEvent('pivot');\n }\n /** Returns `true` if pivot is currently active for this column. */\n isPivotActive() {\n return this.pivotActive;\n }\n isAnyFunctionActive() {\n return this.isPivotActive() || this.isRowGroupActive() || this.isValueActive();\n }\n isAnyFunctionAllowed() {\n return this.isAllowPivot() || this.isAllowRowGroup() || this.isAllowValue();\n }\n setValueActive(value, source = \"api\") {\n if (this.aggregationActive !== value) {\n this.aggregationActive = value;\n this.eventService.dispatchEvent(this.createColumnEvent('columnValueChanged', source));\n }\n }\n /** Returns `true` if value (aggregation) is currently active for this column. */\n isValueActive() {\n return this.aggregationActive;\n }\n isAllowPivot() {\n return this.colDef.enablePivot === true;\n }\n isAllowValue() {\n return this.colDef.enableValue === true;\n }\n isAllowRowGroup() {\n return this.colDef.enableRowGroup === true;\n }\n getMenuTabs(defaultValues) {\n let menuTabs = this.getColDef().menuTabs;\n if (menuTabs == null) {\n menuTabs = defaultValues;\n }\n return menuTabs;\n }\n dispatchStateUpdatedEvent(key) {\n this.eventService.dispatchEvent({\n type: Column.EVENT_STATE_UPDATED,\n key\n });\n }\n}\n// + renderedHeaderCell - for making header cell transparent when moving\nColumn.EVENT_MOVING_CHANGED = 'movingChanged';\n// + renderedCell - changing left position\nColumn.EVENT_LEFT_CHANGED = 'leftChanged';\n// + renderedCell - changing width\nColumn.EVENT_WIDTH_CHANGED = 'widthChanged';\n// + renderedCell - for changing pinned classes\nColumn.EVENT_LAST_LEFT_PINNED_CHANGED = 'lastLeftPinnedChanged';\nColumn.EVENT_FIRST_RIGHT_PINNED_CHANGED = 'firstRightPinnedChanged';\n// + renderedColumn - for changing visibility icon\nColumn.EVENT_VISIBLE_CHANGED = 'visibleChanged';\n// + every time the filter changes, used in the floating filters\nColumn.EVENT_FILTER_CHANGED = 'filterChanged';\n// + renderedHeaderCell - marks the header with filter icon\nColumn.EVENT_FILTER_ACTIVE_CHANGED = 'filterActiveChanged';\n// + renderedHeaderCell - marks the header with sort icon\nColumn.EVENT_SORT_CHANGED = 'sortChanged';\n// + renderedHeaderCell - marks the header with sort icon\nColumn.EVENT_COL_DEF_CHANGED = 'colDefChanged';\nColumn.EVENT_MENU_VISIBLE_CHANGED = 'menuVisibleChanged';\n// + toolpanel, for gui updates\nColumn.EVENT_ROW_GROUP_CHANGED = 'columnRowGroupChanged';\n// + toolpanel, for gui updates\nColumn.EVENT_PIVOT_CHANGED = 'columnPivotChanged';\n// + toolpanel, for gui updates\nColumn.EVENT_VALUE_CHANGED = 'columnValueChanged';\n// + dataTypeService - when waiting to infer cell data types\nColumn.EVENT_STATE_UPDATED = 'columnStateUpdated';\n__decorate([\n Autowired('gridOptionsService')\n], Column.prototype, \"gridOptionsService\", void 0);\n__decorate([\n Autowired('columnUtils')\n], Column.prototype, \"columnUtils\", void 0);\n__decorate([\n Autowired('columnHoverService')\n], Column.prototype, \"columnHoverService\", void 0);\n__decorate([\n PostConstruct\n], Column.prototype, \"initialise\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Column, getNextColInstanceId } from \"./column.mjs\";\nimport { EventService } from \"../eventService.mjs\";\nimport { PreDestroy } from \"../context/context.mjs\";\nexport class ProvidedColumnGroup {\n constructor(colGroupDef, groupId, padding, level) {\n this.localEventService = new EventService();\n this.expandable = false;\n // used by React (and possibly other frameworks) as key for rendering. also used to\n // identify old vs new columns for destroying cols when no longer used.\n this.instanceId = getNextColInstanceId();\n this.expandableListenerRemoveCallback = null;\n this.colGroupDef = colGroupDef;\n this.groupId = groupId;\n this.expanded = !!colGroupDef && !!colGroupDef.openByDefault;\n this.padding = padding;\n this.level = level;\n }\n destroy() {\n if (this.expandableListenerRemoveCallback) {\n this.reset(null, undefined);\n }\n }\n reset(colGroupDef, level) {\n this.colGroupDef = colGroupDef;\n this.level = level;\n this.originalParent = null;\n if (this.expandableListenerRemoveCallback) {\n this.expandableListenerRemoveCallback();\n }\n // we use ! below, as we want to set the object back to the\n // way it was when it was first created\n this.children = undefined;\n this.expandable = undefined;\n }\n getInstanceId() {\n return this.instanceId;\n }\n setOriginalParent(originalParent) {\n this.originalParent = originalParent;\n }\n getOriginalParent() {\n return this.originalParent;\n }\n getLevel() {\n return this.level;\n }\n isVisible() {\n // return true if at least one child is visible\n if (this.children) {\n return this.children.some(child => child.isVisible());\n }\n return false;\n }\n isPadding() {\n return this.padding;\n }\n setExpanded(expanded) {\n this.expanded = expanded === undefined ? false : expanded;\n const event = {\n type: ProvidedColumnGroup.EVENT_EXPANDED_CHANGED\n };\n this.localEventService.dispatchEvent(event);\n }\n isExpandable() {\n return this.expandable;\n }\n isExpanded() {\n return this.expanded;\n }\n getGroupId() {\n return this.groupId;\n }\n getId() {\n return this.getGroupId();\n }\n setChildren(children) {\n this.children = children;\n }\n getChildren() {\n return this.children;\n }\n getColGroupDef() {\n return this.colGroupDef;\n }\n getLeafColumns() {\n const result = [];\n this.addLeafColumns(result);\n return result;\n }\n addLeafColumns(leafColumns) {\n if (!this.children) {\n return;\n }\n this.children.forEach((child) => {\n if (child instanceof Column) {\n leafColumns.push(child);\n }\n else if (child instanceof ProvidedColumnGroup) {\n child.addLeafColumns(leafColumns);\n }\n });\n }\n getColumnGroupShow() {\n const colGroupDef = this.colGroupDef;\n if (!colGroupDef) {\n return;\n }\n return colGroupDef.columnGroupShow;\n }\n // need to check that this group has at least one col showing when both expanded and contracted.\n // if not, then we don't allow expanding and contracting on this group\n setupExpandable() {\n this.setExpandable();\n if (this.expandableListenerRemoveCallback) {\n this.expandableListenerRemoveCallback();\n }\n const listener = this.onColumnVisibilityChanged.bind(this);\n this.getLeafColumns().forEach(col => col.addEventListener('visibleChanged', listener));\n this.expandableListenerRemoveCallback = () => {\n this.getLeafColumns().forEach(col => col.removeEventListener('visibleChanged', listener));\n this.expandableListenerRemoveCallback = null;\n };\n }\n setExpandable() {\n if (this.isPadding()) {\n return;\n }\n // want to make sure the group doesn't disappear when it's open\n let atLeastOneShowingWhenOpen = false;\n // want to make sure the group doesn't disappear when it's closed\n let atLeastOneShowingWhenClosed = false;\n // want to make sure the group has something to show / hide\n let atLeastOneChangeable = false;\n const children = this.findChildrenRemovingPadding();\n for (let i = 0, j = children.length; i < j; i++) {\n const abstractColumn = children[i];\n if (!abstractColumn.isVisible()) {\n continue;\n }\n // if the abstractColumn is a grid generated group, there will be no colDef\n const headerGroupShow = abstractColumn.getColumnGroupShow();\n if (headerGroupShow === 'open') {\n atLeastOneShowingWhenOpen = true;\n atLeastOneChangeable = true;\n }\n else if (headerGroupShow === 'closed') {\n atLeastOneShowingWhenClosed = true;\n atLeastOneChangeable = true;\n }\n else {\n atLeastOneShowingWhenOpen = true;\n atLeastOneShowingWhenClosed = true;\n }\n }\n const expandable = atLeastOneShowingWhenOpen && atLeastOneShowingWhenClosed && atLeastOneChangeable;\n if (this.expandable !== expandable) {\n this.expandable = expandable;\n const event = {\n type: ProvidedColumnGroup.EVENT_EXPANDABLE_CHANGED\n };\n this.localEventService.dispatchEvent(event);\n }\n }\n findChildrenRemovingPadding() {\n const res = [];\n const process = (items) => {\n items.forEach(item => {\n // if padding, we add this children instead of the padding\n const skipBecausePadding = item instanceof ProvidedColumnGroup && item.isPadding();\n if (skipBecausePadding) {\n process(item.children);\n }\n else {\n res.push(item);\n }\n });\n };\n process(this.children);\n return res;\n }\n onColumnVisibilityChanged() {\n this.setExpandable();\n }\n addEventListener(eventType, listener) {\n this.localEventService.addEventListener(eventType, listener);\n }\n removeEventListener(eventType, listener) {\n this.localEventService.removeEventListener(eventType, listener);\n }\n}\nProvidedColumnGroup.EVENT_EXPANDED_CHANGED = 'expandedChanged';\nProvidedColumnGroup.EVENT_EXPANDABLE_CHANGED = 'expandableChanged';\n__decorate([\n PreDestroy\n], ProvidedColumnGroup.prototype, \"destroy\", null);\n","export const DefaultColumnTypes = {\n numericColumn: {\n headerClass: 'ag-right-aligned-header',\n cellClass: 'ag-right-aligned-cell'\n },\n rightAligned: {\n headerClass: 'ag-right-aligned-header',\n cellClass: 'ag-right-aligned-cell'\n }\n};\n","import { exists, toStringOrNull } from './generic.mjs';\nexport function firstExistingValue(...values) {\n for (let i = 0; i < values.length; i++) {\n const value = values[i];\n if (exists(value)) {\n return value;\n }\n }\n return null;\n}\nexport function existsAndNotEmpty(value) {\n return value != null && value.length > 0;\n}\nexport function last(arr) {\n if (!arr || !arr.length) {\n return;\n }\n return arr[arr.length - 1];\n}\nexport function areEqual(a, b, comparator) {\n if (a == null && b == null) {\n return true;\n }\n return a != null &&\n b != null &&\n a.length === b.length &&\n a.every((value, index) => comparator ? comparator(value, b[index]) : b[index] === value);\n}\n/** @deprecated */\nexport function shallowCompare(arr1, arr2) {\n return areEqual(arr1, arr2);\n}\nexport function sortNumerically(array) {\n return array.sort((a, b) => a - b);\n}\nexport function removeRepeatsFromArray(array, object) {\n if (!array) {\n return;\n }\n for (let index = array.length - 2; index >= 0; index--) {\n const thisOneMatches = array[index] === object;\n const nextOneMatches = array[index + 1] === object;\n if (thisOneMatches && nextOneMatches) {\n array.splice(index + 1, 1);\n }\n }\n}\nexport function removeFromUnorderedArray(array, object) {\n const index = array.indexOf(object);\n if (index >= 0) {\n // preserve the last element, then shorten array length by 1 to delete index\n array[index] = array[array.length - 1];\n array.pop();\n }\n}\nexport function removeFromArray(array, object) {\n const index = array.indexOf(object);\n if (index >= 0) {\n array.splice(index, 1);\n }\n}\nexport function removeAllFromUnorderedArray(array, toRemove) {\n for (let i = 0; i < toRemove.length; i++) {\n removeFromUnorderedArray(array, toRemove[i]);\n }\n}\nexport function removeAllFromArray(array, toRemove) {\n for (let i = 0; i < toRemove.length; i++) {\n removeFromArray(array, toRemove[i]);\n }\n}\nexport function insertIntoArray(array, object, toIndex) {\n array.splice(toIndex, 0, object);\n}\nexport function insertArrayIntoArray(dest, src, toIndex) {\n if (dest == null || src == null) {\n return;\n }\n // put items in backwards, otherwise inserted items end up in reverse order\n for (let i = src.length - 1; i >= 0; i--) {\n const item = src[i];\n insertIntoArray(dest, item, toIndex);\n }\n}\nexport function moveInArray(array, objectsToMove, toIndex) {\n // first take out items from the array\n removeAllFromArray(array, objectsToMove);\n // now add the objects, in same order as provided to us, that means we start at the end\n // as the objects will be pushed to the right as they are inserted\n objectsToMove.slice().reverse().forEach(obj => insertIntoArray(array, obj, toIndex));\n}\nexport function includes(array, value) {\n return array.indexOf(value) > -1;\n}\nexport function flatten(arrayOfArrays) {\n return [].concat.apply([], arrayOfArrays);\n}\nexport function pushAll(target, source) {\n if (source == null || target == null) {\n return;\n }\n source.forEach(value => target.push(value));\n}\nexport function toStrings(array) {\n return array.map(toStringOrNull);\n}\nexport function forEachReverse(list, action) {\n if (list == null) {\n return;\n }\n for (let i = list.length - 1; i >= 0; i--) {\n action(list[i], i);\n }\n}\n","import { includes } from './array.mjs';\nconst AG_GRID_STOP_PROPAGATION = '__ag_Grid_Stop_Propagation';\nconst PASSIVE_EVENTS = ['touchstart', 'touchend', 'touchmove', 'touchcancel', 'scroll'];\nconst supports = {};\n/**\n * a user once raised an issue - they said that when you opened a popup (eg context menu)\n * and then clicked on a selection checkbox, the popup wasn't closed. this is because the\n * popup listens for clicks on the body, however ag-grid WAS stopping propagation on the\n * checkbox clicks (so the rows didn't pick them up as row selection selection clicks).\n * to get around this, we have a pattern to stop propagation for the purposes of AG Grid,\n * but we still let the event pass back to the body.\n * @param {Event} event\n */\nexport function stopPropagationForAgGrid(event) {\n event[AG_GRID_STOP_PROPAGATION] = true;\n}\nexport function isStopPropagationForAgGrid(event) {\n return event[AG_GRID_STOP_PROPAGATION] === true;\n}\nexport const isEventSupported = (() => {\n const tags = {\n select: 'input',\n change: 'input',\n submit: 'form',\n reset: 'form',\n error: 'img',\n load: 'img',\n abort: 'img'\n };\n const eventChecker = (eventName) => {\n if (typeof supports[eventName] === 'boolean') {\n return supports[eventName];\n }\n const el = document.createElement(tags[eventName] || 'div');\n eventName = 'on' + eventName;\n return supports[eventName] = (eventName in el);\n };\n return eventChecker;\n})();\nexport function getCtrlForEventTarget(gridOptionsService, eventTarget, type) {\n let sourceElement = eventTarget;\n while (sourceElement) {\n const renderedComp = gridOptionsService.getDomData(sourceElement, type);\n if (renderedComp) {\n return renderedComp;\n }\n sourceElement = sourceElement.parentElement;\n }\n return null;\n}\nexport function isElementInEventPath(element, event) {\n if (!event || !element) {\n return false;\n }\n return getEventPath(event).indexOf(element) >= 0;\n}\nexport function createEventPath(event) {\n const res = [];\n let pointer = event.target;\n while (pointer) {\n res.push(pointer);\n pointer = pointer.parentElement;\n }\n return res;\n}\n/**\n * Gets the path for a browser Event or from the target on an AG Grid Event\n * https://developer.mozilla.org/en-US/docs/Web/API/Event\n * @param {Event| { target: EventTarget }} event\n * @returns {EventTarget[]}\n */\nexport function getEventPath(event) {\n // This can be called with either a browser event or an AG Grid Event that has a target property.\n const eventNoType = event;\n if (eventNoType.path) {\n return eventNoType.path;\n }\n if (eventNoType.composedPath) {\n return eventNoType.composedPath();\n }\n // If this is an AG Grid event build the path ourselves\n return createEventPath(eventNoType);\n}\nexport function addSafePassiveEventListener(frameworkOverrides, eElement, event, listener) {\n const isPassive = includes(PASSIVE_EVENTS, event);\n const options = isPassive ? { passive: true } : undefined;\n // this check is here for certain scenarios where I believe the user must be destroying\n // the grid somehow but continuing for it to be used\n if (frameworkOverrides && frameworkOverrides.addEventListener) {\n frameworkOverrides.addEventListener(eElement, event, listener, options);\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { EventService } from \"../eventService.mjs\";\nimport { Autowired, PreDestroy } from \"./context.mjs\";\nimport { addSafePassiveEventListener } from \"../utils/event.mjs\";\nexport class BeanStub {\n constructor() {\n this.destroyFunctions = [];\n this.destroyed = false;\n // for vue 3 - prevents Vue from trying to make this (and obviously any sub classes) from being reactive\n // prevents vue from creating proxies for created objects and prevents identity related issues\n this.__v_skip = true;\n // this was a test constructor niall built, when active, it prints after 5 seconds all beans/components that are\n // not destroyed. to use, create a new grid, then api.destroy() before 5 seconds. then anything that gets printed\n // points to a bean or component that was not properly disposed of.\n // constructor() {\n // setTimeout(()=> {\n // if (this.isAlive()) {\n // let prototype: any = Object.getPrototypeOf(this);\n // const constructor: any = prototype.constructor;\n // const constructorString = constructor.toString();\n // const beanName = constructorString.substring(9, constructorString.indexOf(\"(\"));\n // console.log('is alive ' + beanName);\n // }\n // }, 5000);\n // }\n // Enable multiple grid properties to be updated together by the user but only trigger shared logic once.\n // Closely related to logic in ComponentUtil.ts\n this.lastChangeSetIdLookup = {};\n this.propertyListenerId = 0;\n this.isAlive = () => !this.destroyed;\n }\n // CellComp and GridComp and override this because they get the FrameworkOverrides from the Beans bean\n getFrameworkOverrides() {\n return this.frameworkOverrides;\n }\n getContext() {\n return this.context;\n }\n destroy() {\n // let prototype: any = Object.getPrototypeOf(this);\n // const constructor: any = prototype.constructor;\n // const constructorString = constructor.toString();\n // const beanName = constructorString.substring(9, constructorString.indexOf(\"(\"));\n this.destroyFunctions.forEach(func => func());\n this.destroyFunctions.length = 0;\n this.destroyed = true;\n this.dispatchEvent({ type: BeanStub.EVENT_DESTROYED });\n }\n addEventListener(eventType, listener) {\n if (!this.localEventService) {\n this.localEventService = new EventService();\n }\n this.localEventService.addEventListener(eventType, listener);\n }\n removeEventListener(eventType, listener) {\n if (this.localEventService) {\n this.localEventService.removeEventListener(eventType, listener);\n }\n }\n dispatchEventAsync(event) {\n window.setTimeout(() => this.dispatchEvent(event), 0);\n }\n dispatchEvent(event) {\n if (this.localEventService) {\n this.localEventService.dispatchEvent(event);\n }\n }\n addManagedListener(object, event, listener) {\n if (this.destroyed) {\n return;\n }\n if (object instanceof HTMLElement) {\n addSafePassiveEventListener(this.getFrameworkOverrides(), object, event, listener);\n }\n else {\n object.addEventListener(event, listener);\n }\n const destroyFunc = () => {\n object.removeEventListener(event, listener);\n this.destroyFunctions = this.destroyFunctions.filter(fn => fn !== destroyFunc);\n return null;\n };\n this.destroyFunctions.push(destroyFunc);\n return destroyFunc;\n }\n setupGridOptionListener(event, listener) {\n this.gridOptionsService.addEventListener(event, listener);\n const destroyFunc = () => {\n this.gridOptionsService.removeEventListener(event, listener);\n this.destroyFunctions = this.destroyFunctions.filter((fn) => fn !== destroyFunc);\n return null;\n };\n this.destroyFunctions.push(destroyFunc);\n }\n /**\n * Setup a managed property listener for the given GridOption property.\n * @param event GridOption property to listen to changes for.\n * @param listener Listener to run when property value changes\n */\n addManagedPropertyListener(event, listener) {\n if (this.destroyed) {\n return;\n }\n this.setupGridOptionListener(event, listener);\n }\n /**\n * Setup managed property listeners for the given set of GridOption properties.\n * The listener will be run if any of the property changes but will only run once if\n * multiple of the properties change within the same framework lifecycle event.\n * Works on the basis that GridOptionsService updates all properties *before* any property change events are fired.\n * @param events Array of GridOption properties to listen for changes too.\n * @param listener Shared listener to run if any of the properties change\n */\n addManagedPropertyListeners(events, listener) {\n if (this.destroyed) {\n return;\n }\n // Ensure each set of events can run for the same changeSetId\n const eventsKey = events.join('-') + this.propertyListenerId++;\n const wrappedListener = (event) => {\n if (event.changeSet) {\n // ChangeSet is only set when the property change is part of a group of changes from ComponentUtils\n // Direct api calls should always be run as \n if (event.changeSet && event.changeSet.id === this.lastChangeSetIdLookup[eventsKey]) {\n // Already run the listener for this set of prop changes so don't run again\n return;\n }\n this.lastChangeSetIdLookup[eventsKey] = event.changeSet.id;\n }\n // Don't expose the underlying event value changes to the group listener.\n const propertiesChangeEvent = {\n type: 'gridPropertyChanged',\n changeSet: event.changeSet,\n };\n listener(propertiesChangeEvent);\n };\n events.forEach((event) => this.setupGridOptionListener(event, wrappedListener));\n }\n addDestroyFunc(func) {\n // if we are already destroyed, we execute the func now\n if (this.isAlive()) {\n this.destroyFunctions.push(func);\n }\n else {\n func();\n }\n }\n createManagedBean(bean, context) {\n const res = this.createBean(bean, context);\n this.addDestroyFunc(this.destroyBean.bind(this, bean, context));\n return res;\n }\n createBean(bean, context, afterPreCreateCallback) {\n return (context || this.getContext()).createBean(bean, afterPreCreateCallback);\n }\n destroyBean(bean, context) {\n return (context || this.getContext()).destroyBean(bean);\n }\n destroyBeans(beans, context) {\n if (beans) {\n beans.forEach(bean => this.destroyBean(bean, context));\n }\n return [];\n }\n}\nBeanStub.EVENT_DESTROYED = 'destroyed';\n__decorate([\n Autowired('frameworkOverrides')\n], BeanStub.prototype, \"frameworkOverrides\", void 0);\n__decorate([\n Autowired('context')\n], BeanStub.prototype, \"context\", void 0);\n__decorate([\n Autowired('eventService')\n], BeanStub.prototype, \"eventService\", void 0);\n__decorate([\n Autowired('gridOptionsService')\n], BeanStub.prototype, \"gridOptionsService\", void 0);\n__decorate([\n Autowired('localeService')\n], BeanStub.prototype, \"localeService\", void 0);\n__decorate([\n Autowired('environment')\n], BeanStub.prototype, \"environment\", void 0);\n__decorate([\n PreDestroy\n], BeanStub.prototype, \"destroy\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n};\nimport { ColumnKeyCreator } from \"./columnKeyCreator.mjs\";\nimport { ProvidedColumnGroup } from \"../entities/providedColumnGroup.mjs\";\nimport { Column } from \"../entities/column.mjs\";\nimport { Autowired, Bean, Qualifier } from \"../context/context.mjs\";\nimport { DefaultColumnTypes } from \"../entities/defaultColumnTypes.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { iterateObject, mergeDeep } from '../utils/object.mjs';\nimport { attrToNumber, attrToBoolean } from '../utils/generic.mjs';\n// takes ColDefs and ColGroupDefs and turns them into Columns and OriginalGroups\nlet ColumnFactory = class ColumnFactory extends BeanStub {\n setBeans(loggerFactory) {\n this.logger = loggerFactory.create('ColumnFactory');\n }\n createColumnTree(defs, primaryColumns, existingTree) {\n // column key creator dishes out unique column id's in a deterministic way,\n // so if we have two grids (that could be master/slave) with same column definitions,\n // then this ensures the two grids use identical id's.\n const columnKeyCreator = new ColumnKeyCreator();\n const { existingCols, existingGroups, existingColKeys } = this.extractExistingTreeData(existingTree);\n columnKeyCreator.addExistingKeys(existingColKeys);\n // create am unbalanced tree that maps the provided definitions\n const unbalancedTree = this.recursivelyCreateColumns(defs, 0, primaryColumns, existingCols, columnKeyCreator, existingGroups);\n const treeDept = this.findMaxDept(unbalancedTree, 0);\n this.logger.log('Number of levels for grouped columns is ' + treeDept);\n const columnTree = this.balanceColumnTree(unbalancedTree, 0, treeDept, columnKeyCreator);\n const deptFirstCallback = (child, parent) => {\n if (child instanceof ProvidedColumnGroup) {\n child.setupExpandable();\n }\n // we set the original parents at the end, rather than when we go along, as balancing the tree\n // adds extra levels into the tree. so we can only set parents when balancing is done.\n child.setOriginalParent(parent);\n };\n this.columnUtils.depthFirstOriginalTreeSearch(null, columnTree, deptFirstCallback);\n return {\n columnTree,\n treeDept\n };\n }\n extractExistingTreeData(existingTree) {\n const existingCols = [];\n const existingGroups = [];\n const existingColKeys = [];\n if (existingTree) {\n this.columnUtils.depthFirstOriginalTreeSearch(null, existingTree, (item) => {\n if (item instanceof ProvidedColumnGroup) {\n const group = item;\n existingGroups.push(group);\n }\n else {\n const col = item;\n existingColKeys.push(col.getId());\n existingCols.push(col);\n }\n });\n }\n return { existingCols, existingGroups, existingColKeys };\n }\n createForAutoGroups(autoGroupCols, gridBalancedTree) {\n return autoGroupCols.map((col) => this.createAutoGroupTreeItem(gridBalancedTree, col));\n }\n createAutoGroupTreeItem(balancedColumnTree, column) {\n const dept = this.findDepth(balancedColumnTree);\n // at the end, this will be the top of the tree item.\n let nextChild = column;\n for (let i = dept - 1; i >= 0; i--) {\n const autoGroup = new ProvidedColumnGroup(null, `FAKE_PATH_${column.getId()}}_${i}`, true, i);\n this.createBean(autoGroup);\n autoGroup.setChildren([nextChild]);\n nextChild.setOriginalParent(autoGroup);\n nextChild = autoGroup;\n }\n if (dept === 0) {\n column.setOriginalParent(null);\n }\n // at this point, the nextChild is the top most item in the tree\n return nextChild;\n }\n findDepth(balancedColumnTree) {\n let dept = 0;\n let pointer = balancedColumnTree;\n while (pointer && pointer[0] && pointer[0] instanceof ProvidedColumnGroup) {\n dept++;\n pointer = pointer[0].getChildren();\n }\n return dept;\n }\n balanceColumnTree(unbalancedTree, currentDept, columnDept, columnKeyCreator) {\n const result = [];\n // go through each child, for groups, recurse a level deeper,\n // for columns we need to pad\n for (let i = 0; i < unbalancedTree.length; i++) {\n const child = unbalancedTree[i];\n if (child instanceof ProvidedColumnGroup) {\n // child is a group, all we do is go to the next level of recursion\n const originalGroup = child;\n const newChildren = this.balanceColumnTree(originalGroup.getChildren(), currentDept + 1, columnDept, columnKeyCreator);\n originalGroup.setChildren(newChildren);\n result.push(originalGroup);\n }\n else {\n // child is a column - so here we add in the padded column groups if needed\n let firstPaddedGroup;\n let currentPaddedGroup;\n // this for loop will NOT run any loops if no padded column groups are needed\n for (let j = columnDept - 1; j >= currentDept; j--) {\n const newColId = columnKeyCreator.getUniqueKey(null, null);\n const colGroupDefMerged = this.createMergedColGroupDef(null);\n const paddedGroup = new ProvidedColumnGroup(colGroupDefMerged, newColId, true, currentDept);\n this.createBean(paddedGroup);\n if (currentPaddedGroup) {\n currentPaddedGroup.setChildren([paddedGroup]);\n }\n currentPaddedGroup = paddedGroup;\n if (!firstPaddedGroup) {\n firstPaddedGroup = currentPaddedGroup;\n }\n }\n // likewise this if statement will not run if no padded groups\n if (firstPaddedGroup && currentPaddedGroup) {\n result.push(firstPaddedGroup);\n const hasGroups = unbalancedTree.some(leaf => leaf instanceof ProvidedColumnGroup);\n if (hasGroups) {\n currentPaddedGroup.setChildren([child]);\n continue;\n }\n else {\n currentPaddedGroup.setChildren(unbalancedTree);\n break;\n }\n }\n result.push(child);\n }\n }\n return result;\n }\n findMaxDept(treeChildren, dept) {\n let maxDeptThisLevel = dept;\n for (let i = 0; i < treeChildren.length; i++) {\n const abstractColumn = treeChildren[i];\n if (abstractColumn instanceof ProvidedColumnGroup) {\n const originalGroup = abstractColumn;\n const newDept = this.findMaxDept(originalGroup.getChildren(), dept + 1);\n if (maxDeptThisLevel < newDept) {\n maxDeptThisLevel = newDept;\n }\n }\n }\n return maxDeptThisLevel;\n }\n recursivelyCreateColumns(defs, level, primaryColumns, existingColsCopy, columnKeyCreator, existingGroups) {\n if (!defs)\n return [];\n const result = new Array(defs.length);\n for (let i = 0; i < result.length; i++) {\n const def = defs[i];\n if (this.isColumnGroup(def)) {\n result[i] = this.createColumnGroup(primaryColumns, def, level, existingColsCopy, columnKeyCreator, existingGroups);\n }\n else {\n result[i] = this.createColumn(primaryColumns, def, existingColsCopy, columnKeyCreator);\n }\n }\n return result;\n }\n createColumnGroup(primaryColumns, colGroupDef, level, existingColumns, columnKeyCreator, existingGroups) {\n const colGroupDefMerged = this.createMergedColGroupDef(colGroupDef);\n const groupId = columnKeyCreator.getUniqueKey(colGroupDefMerged.groupId || null, null);\n const providedGroup = new ProvidedColumnGroup(colGroupDefMerged, groupId, false, level);\n this.createBean(providedGroup);\n const existingGroupAndIndex = this.findExistingGroup(colGroupDef, existingGroups);\n // make sure we remove, so if user provided duplicate id, then we don't have more than\n // one column instance for colDef with common id\n if (existingGroupAndIndex) {\n existingGroups.splice(existingGroupAndIndex.idx, 1);\n }\n let existingGroup = existingGroupAndIndex === null || existingGroupAndIndex === void 0 ? void 0 : existingGroupAndIndex.group;\n if (existingGroup) {\n providedGroup.setExpanded(existingGroup.isExpanded());\n }\n const children = this.recursivelyCreateColumns(colGroupDefMerged.children, level + 1, primaryColumns, existingColumns, columnKeyCreator, existingGroups);\n providedGroup.setChildren(children);\n return providedGroup;\n }\n createMergedColGroupDef(colGroupDef) {\n const colGroupDefMerged = {};\n Object.assign(colGroupDefMerged, this.gridOptionsService.get('defaultColGroupDef'));\n Object.assign(colGroupDefMerged, colGroupDef);\n return colGroupDefMerged;\n }\n createColumn(primaryColumns, colDef, existingColsCopy, columnKeyCreator) {\n // see if column already exists\n const existingColAndIndex = this.findExistingColumn(colDef, existingColsCopy);\n // make sure we remove, so if user provided duplicate id, then we don't have more than\n // one column instance for colDef with common id\n if (existingColAndIndex) {\n existingColsCopy === null || existingColsCopy === void 0 ? void 0 : existingColsCopy.splice(existingColAndIndex.idx, 1);\n }\n let column = existingColAndIndex === null || existingColAndIndex === void 0 ? void 0 : existingColAndIndex.column;\n if (!column) {\n // no existing column, need to create one\n const colId = columnKeyCreator.getUniqueKey(colDef.colId, colDef.field);\n const colDefMerged = this.addColumnDefaultAndTypes(colDef, colId);\n column = new Column(colDefMerged, colDef, colId, primaryColumns);\n this.context.createBean(column);\n }\n else {\n const colDefMerged = this.addColumnDefaultAndTypes(colDef, column.getColId());\n column.setColDef(colDefMerged, colDef);\n this.applyColumnState(column, colDefMerged);\n }\n this.dataTypeService.addColumnListeners(column);\n return column;\n }\n applyColumnState(column, colDef) {\n // flex\n const flex = attrToNumber(colDef.flex);\n if (flex !== undefined) {\n column.setFlex(flex);\n }\n // width - we only set width if column is not flexing\n const noFlexThisCol = column.getFlex() <= 0;\n if (noFlexThisCol) {\n // both null and undefined means we skip, as it's not possible to 'clear' width (a column must have a width)\n const width = attrToNumber(colDef.width);\n if (width != null) {\n column.setActualWidth(width);\n }\n else {\n // otherwise set the width again, in case min or max width has changed,\n // and width needs to be adjusted.\n const widthBeforeUpdate = column.getActualWidth();\n column.setActualWidth(widthBeforeUpdate);\n }\n }\n // sort - anything but undefined will set sort, thus null or empty string will clear the sort\n if (colDef.sort !== undefined) {\n if (colDef.sort == 'asc' || colDef.sort == 'desc') {\n column.setSort(colDef.sort);\n }\n else {\n column.setSort(undefined);\n }\n }\n // sorted at - anything but undefined, thus null will clear the sortIndex\n const sortIndex = attrToNumber(colDef.sortIndex);\n if (sortIndex !== undefined) {\n column.setSortIndex(sortIndex);\n }\n // hide - anything but undefined, thus null will clear the hide\n const hide = attrToBoolean(colDef.hide);\n if (hide !== undefined) {\n column.setVisible(!hide);\n }\n // pinned - anything but undefined, thus null or empty string will remove pinned\n if (colDef.pinned !== undefined) {\n column.setPinned(colDef.pinned);\n }\n }\n findExistingColumn(newColDef, existingColsCopy) {\n if (!existingColsCopy)\n return undefined;\n for (let i = 0; i < existingColsCopy.length; i++) {\n const def = existingColsCopy[i].getUserProvidedColDef();\n if (!def)\n continue;\n const newHasId = newColDef.colId != null;\n if (newHasId) {\n if (existingColsCopy[i].getId() === newColDef.colId) {\n return { idx: i, column: existingColsCopy[i] };\n }\n continue;\n }\n const newHasField = newColDef.field != null;\n if (newHasField) {\n if (def.field === newColDef.field) {\n return { idx: i, column: existingColsCopy[i] };\n }\n continue;\n }\n if (def === newColDef) {\n return { idx: i, column: existingColsCopy[i] };\n }\n }\n return undefined;\n }\n findExistingGroup(newGroupDef, existingGroups) {\n const newHasId = newGroupDef.groupId != null;\n if (!newHasId) {\n return undefined;\n }\n for (let i = 0; i < existingGroups.length; i++) {\n const existingGroup = existingGroups[i];\n const existingDef = existingGroup.getColGroupDef();\n if (!existingDef) {\n continue;\n }\n if (existingGroup.getId() === newGroupDef.groupId) {\n return { idx: i, group: existingGroup };\n }\n }\n return undefined;\n }\n addColumnDefaultAndTypes(colDef, colId) {\n // start with empty merged definition\n const res = {};\n // merge properties from default column definitions\n const defaultColDef = this.gridOptionsService.get('defaultColDef');\n mergeDeep(res, defaultColDef, false, true);\n const columnType = this.dataTypeService.updateColDefAndGetColumnType(res, colDef, colId);\n if (columnType) {\n this.assignColumnTypes(columnType, res);\n }\n // merge properties from column definitions\n mergeDeep(res, colDef, false, true);\n const autoGroupColDef = this.gridOptionsService.get('autoGroupColumnDef');\n const isSortingCoupled = this.gridOptionsService.isColumnsSortingCoupledToGroup();\n if (colDef.rowGroup && autoGroupColDef && isSortingCoupled) {\n // override the sort for row group columns where the autoGroupColDef defines these values.\n mergeDeep(res, { sort: autoGroupColDef.sort, initialSort: autoGroupColDef.initialSort }, false, true);\n }\n this.dataTypeService.validateColDef(res);\n return res;\n }\n assignColumnTypes(typeKeys, colDefMerged) {\n if (!typeKeys.length) {\n return;\n }\n // merge user defined with default column types\n const allColumnTypes = Object.assign({}, DefaultColumnTypes);\n const userTypes = this.gridOptionsService.get('columnTypes') || {};\n iterateObject(userTypes, (key, value) => {\n if (key in allColumnTypes) {\n console.warn(`AG Grid: the column type '${key}' is a default column type and cannot be overridden.`);\n }\n else {\n allColumnTypes[key] = value;\n }\n });\n typeKeys.forEach((t) => {\n const typeColDef = allColumnTypes[t.trim()];\n if (typeColDef) {\n mergeDeep(colDefMerged, typeColDef, false, true);\n }\n else {\n console.warn(\"AG Grid: colDef.type '\" + t + \"' does not correspond to defined gridOptions.columnTypes\");\n }\n });\n }\n // if object has children, we assume it's a group\n isColumnGroup(abstractColDef) {\n return abstractColDef.children !== undefined;\n }\n};\n__decorate([\n Autowired('columnUtils')\n], ColumnFactory.prototype, \"columnUtils\", void 0);\n__decorate([\n Autowired('dataTypeService')\n], ColumnFactory.prototype, \"dataTypeService\", void 0);\n__decorate([\n __param(0, Qualifier('loggerFactory'))\n], ColumnFactory.prototype, \"setBeans\", null);\nColumnFactory = __decorate([\n Bean('columnFactory')\n], ColumnFactory);\nexport { ColumnFactory };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Column } from \"./column.mjs\";\nimport { EventService } from \"../eventService.mjs\";\nimport { Autowired } from \"../context/context.mjs\";\nimport { last } from \"../utils/array.mjs\";\nexport class ColumnGroup {\n constructor(providedColumnGroup, groupId, partId, pinned) {\n // depends on the open/closed state of the group, only displaying columns are stored here\n this.displayedChildren = [];\n this.localEventService = new EventService();\n this.groupId = groupId;\n this.partId = partId;\n this.providedColumnGroup = providedColumnGroup;\n this.pinned = pinned;\n }\n // this is static, a it is used outside of this class\n static createUniqueId(groupId, instanceId) {\n return groupId + '_' + instanceId;\n }\n // as the user is adding and removing columns, the groups are recalculated.\n // this reset clears out all children, ready for children to be added again\n reset() {\n this.parent = null;\n this.children = null;\n this.displayedChildren = null;\n }\n getParent() {\n return this.parent;\n }\n setParent(parent) {\n this.parent = parent;\n }\n getUniqueId() {\n return ColumnGroup.createUniqueId(this.groupId, this.partId);\n }\n isEmptyGroup() {\n return this.displayedChildren.length === 0;\n }\n isMoving() {\n const allLeafColumns = this.getProvidedColumnGroup().getLeafColumns();\n if (!allLeafColumns || allLeafColumns.length === 0) {\n return false;\n }\n return allLeafColumns.every(col => col.isMoving());\n }\n checkLeft() {\n // first get all children to setLeft, as it impacts our decision below\n this.displayedChildren.forEach((child) => {\n if (child instanceof ColumnGroup) {\n child.checkLeft();\n }\n });\n // set our left based on first displayed column\n if (this.displayedChildren.length > 0) {\n if (this.gridOptionsService.is('enableRtl')) {\n const lastChild = last(this.displayedChildren);\n const lastChildLeft = lastChild.getLeft();\n this.setLeft(lastChildLeft);\n }\n else {\n const firstChildLeft = this.displayedChildren[0].getLeft();\n this.setLeft(firstChildLeft);\n }\n }\n else {\n // this should never happen, as if we have no displayed columns, then\n // this groups should not even exist.\n this.setLeft(null);\n }\n }\n getLeft() {\n return this.left;\n }\n getOldLeft() {\n return this.oldLeft;\n }\n setLeft(left) {\n this.oldLeft = left;\n if (this.left !== left) {\n this.left = left;\n this.localEventService.dispatchEvent(this.createAgEvent(ColumnGroup.EVENT_LEFT_CHANGED));\n }\n }\n getPinned() {\n return this.pinned;\n }\n createAgEvent(type) {\n return { type };\n }\n addEventListener(eventType, listener) {\n this.localEventService.addEventListener(eventType, listener);\n }\n removeEventListener(eventType, listener) {\n this.localEventService.removeEventListener(eventType, listener);\n }\n getGroupId() {\n return this.groupId;\n }\n getPartId() {\n return this.partId;\n }\n isChildInThisGroupDeepSearch(wantedChild) {\n let result = false;\n this.children.forEach((foundChild) => {\n if (wantedChild === foundChild) {\n result = true;\n }\n if (foundChild instanceof ColumnGroup) {\n if (foundChild.isChildInThisGroupDeepSearch(wantedChild)) {\n result = true;\n }\n }\n });\n return result;\n }\n getActualWidth() {\n let groupActualWidth = 0;\n if (this.displayedChildren) {\n this.displayedChildren.forEach((child) => {\n groupActualWidth += child.getActualWidth();\n });\n }\n return groupActualWidth;\n }\n isResizable() {\n if (!this.displayedChildren) {\n return false;\n }\n // if at least one child is resizable, then the group is resizable\n let result = false;\n this.displayedChildren.forEach((child) => {\n if (child.isResizable()) {\n result = true;\n }\n });\n return result;\n }\n getMinWidth() {\n let result = 0;\n this.displayedChildren.forEach((groupChild) => {\n result += groupChild.getMinWidth() || 0;\n });\n return result;\n }\n addChild(child) {\n if (!this.children) {\n this.children = [];\n }\n this.children.push(child);\n }\n getDisplayedChildren() {\n return this.displayedChildren;\n }\n getLeafColumns() {\n const result = [];\n this.addLeafColumns(result);\n return result;\n }\n getDisplayedLeafColumns() {\n const result = [];\n this.addDisplayedLeafColumns(result);\n return result;\n }\n getDefinition() {\n return this.providedColumnGroup.getColGroupDef();\n }\n getColGroupDef() {\n return this.providedColumnGroup.getColGroupDef();\n }\n isPadding() {\n return this.providedColumnGroup.isPadding();\n }\n isExpandable() {\n return this.providedColumnGroup.isExpandable();\n }\n isExpanded() {\n return this.providedColumnGroup.isExpanded();\n }\n setExpanded(expanded) {\n this.providedColumnGroup.setExpanded(expanded);\n }\n addDisplayedLeafColumns(leafColumns) {\n this.displayedChildren.forEach((child) => {\n if (child instanceof Column) {\n leafColumns.push(child);\n }\n else if (child instanceof ColumnGroup) {\n child.addDisplayedLeafColumns(leafColumns);\n }\n });\n }\n addLeafColumns(leafColumns) {\n this.children.forEach((child) => {\n if (child instanceof Column) {\n leafColumns.push(child);\n }\n else if (child instanceof ColumnGroup) {\n child.addLeafColumns(leafColumns);\n }\n });\n }\n getChildren() {\n return this.children;\n }\n getColumnGroupShow() {\n return this.providedColumnGroup.getColumnGroupShow();\n }\n getProvidedColumnGroup() {\n return this.providedColumnGroup;\n }\n getPaddingLevel() {\n const parent = this.getParent();\n if (!this.isPadding() || !parent || !parent.isPadding()) {\n return 0;\n }\n return 1 + parent.getPaddingLevel();\n }\n calculateDisplayedColumns() {\n // clear out last time we calculated\n this.displayedChildren = [];\n // find the column group that is controlling expandable. this is relevant when we have padding (empty)\n // groups, where the expandable is actually the first parent that is not a padding group.\n let parentWithExpansion = this;\n while (parentWithExpansion != null && parentWithExpansion.isPadding()) {\n parentWithExpansion = parentWithExpansion.getParent();\n }\n const isExpandable = parentWithExpansion ? parentWithExpansion.providedColumnGroup.isExpandable() : false;\n // it not expandable, everything is visible\n if (!isExpandable) {\n this.displayedChildren = this.children;\n this.localEventService.dispatchEvent(this.createAgEvent(ColumnGroup.EVENT_DISPLAYED_CHILDREN_CHANGED));\n return;\n }\n // Add cols based on columnGroupShow\n // Note - the below also adds padding groups, these are always added because they never have\n // colDef.columnGroupShow set.\n this.children.forEach(child => {\n // never add empty groups\n const emptyGroup = child instanceof ColumnGroup && (!child.displayedChildren || !child.displayedChildren.length);\n if (emptyGroup) {\n return;\n }\n const headerGroupShow = child.getColumnGroupShow();\n switch (headerGroupShow) {\n case 'open':\n // when set to open, only show col if group is open\n if (parentWithExpansion.providedColumnGroup.isExpanded()) {\n this.displayedChildren.push(child);\n }\n break;\n case 'closed':\n // when set to open, only show col if group is open\n if (!parentWithExpansion.providedColumnGroup.isExpanded()) {\n this.displayedChildren.push(child);\n }\n break;\n default:\n this.displayedChildren.push(child);\n break;\n }\n });\n this.localEventService.dispatchEvent(this.createAgEvent(ColumnGroup.EVENT_DISPLAYED_CHILDREN_CHANGED));\n }\n}\nColumnGroup.EVENT_LEFT_CHANGED = 'leftChanged';\nColumnGroup.EVENT_DISPLAYED_CHILDREN_CHANGED = 'displayedChildrenChanged';\n__decorate([\n Autowired('gridOptionsService')\n], ColumnGroup.prototype, \"gridOptionsService\", void 0);\n","export class Events {\n}\n/** Everything has changed with the columns. Either complete new set of columns set, or user called applyColumnState() */\n/** @deprecated - grid no longer uses this, and setSate() also fires individual events */\nEvents.EVENT_COLUMN_EVERYTHING_CHANGED = 'columnEverythingChanged';\n/** User has set in new columns. */\nEvents.EVENT_NEW_COLUMNS_LOADED = 'newColumnsLoaded';\n/** The pivot mode flag was changed */\nEvents.EVENT_COLUMN_PIVOT_MODE_CHANGED = 'columnPivotModeChanged';\n/** A row group column was added, removed or order changed. */\nEvents.EVENT_COLUMN_ROW_GROUP_CHANGED = 'columnRowGroupChanged';\n/** expandAll / collapseAll was called from the api. */\nEvents.EVENT_EXPAND_COLLAPSE_ALL = 'expandOrCollapseAll';\n/** A pivot column was added, removed or order changed. */\nEvents.EVENT_COLUMN_PIVOT_CHANGED = 'columnPivotChanged';\n/** The list of grid columns has changed. */\nEvents.EVENT_GRID_COLUMNS_CHANGED = 'gridColumnsChanged';\n/** A value column was added, removed or agg function was changed. */\nEvents.EVENT_COLUMN_VALUE_CHANGED = 'columnValueChanged';\n/** A column was moved */\nEvents.EVENT_COLUMN_MOVED = 'columnMoved';\n/** One or more columns was shown / hidden */\nEvents.EVENT_COLUMN_VISIBLE = 'columnVisible';\n/** One or more columns was pinned / unpinned*/\nEvents.EVENT_COLUMN_PINNED = 'columnPinned';\n/** A column group was opened / closed */\nEvents.EVENT_COLUMN_GROUP_OPENED = 'columnGroupOpened';\n/** One or more columns was resized. If just one, the column in the event is set. */\nEvents.EVENT_COLUMN_RESIZED = 'columnResized';\n/** The list of displayed columns has changed, can result from columns open / close, column move, pivot, group, etc */\nEvents.EVENT_DISPLAYED_COLUMNS_CHANGED = 'displayedColumnsChanged';\n/** The list of virtual columns has changed, results from viewport changing */\nEvents.EVENT_VIRTUAL_COLUMNS_CHANGED = 'virtualColumnsChanged';\n/** Async Transactions Executed */\nEvents.EVENT_ASYNC_TRANSACTIONS_FLUSHED = 'asyncTransactionsFlushed';\n/** A row group was opened / closed */\nEvents.EVENT_ROW_GROUP_OPENED = 'rowGroupOpened';\n/** @deprecated v28 use EVENT_ROW_DATA_UPDATED instead */\nEvents.EVENT_ROW_DATA_CHANGED = 'rowDataChanged';\n/** The client has updated data for the grid */\nEvents.EVENT_ROW_DATA_UPDATED = 'rowDataUpdated';\n/** The client has set new floating data into the grid */\nEvents.EVENT_PINNED_ROW_DATA_CHANGED = 'pinnedRowDataChanged';\n/** Range selection has changed */\nEvents.EVENT_RANGE_SELECTION_CHANGED = 'rangeSelectionChanged';\n/** Chart was created */\nEvents.EVENT_CHART_CREATED = 'chartCreated';\n/** Chart Range selection has changed */\nEvents.EVENT_CHART_RANGE_SELECTION_CHANGED = 'chartRangeSelectionChanged';\n/** Chart Options have changed */\nEvents.EVENT_CHART_OPTIONS_CHANGED = 'chartOptionsChanged';\n/** Chart was destroyed */\nEvents.EVENT_CHART_DESTROYED = 'chartDestroyed';\n/** For when the tool panel is shown / hidden */\nEvents.EVENT_TOOL_PANEL_VISIBLE_CHANGED = 'toolPanelVisibleChanged';\nEvents.EVENT_TOOL_PANEL_SIZE_CHANGED = 'toolPanelSizeChanged';\nEvents.EVENT_COLUMN_PANEL_ITEM_DRAG_START = 'columnPanelItemDragStart';\nEvents.EVENT_COLUMN_PANEL_ITEM_DRAG_END = 'columnPanelItemDragEnd';\n/** Model was updated - grid updates the drawn rows when this happens */\nEvents.EVENT_MODEL_UPDATED = 'modelUpdated';\nEvents.EVENT_CUT_START = 'cutStart';\nEvents.EVENT_CUT_END = 'cutEnd';\nEvents.EVENT_PASTE_START = 'pasteStart';\nEvents.EVENT_PASTE_END = 'pasteEnd';\nEvents.EVENT_FILL_START = 'fillStart';\nEvents.EVENT_FILL_END = 'fillEnd';\nEvents.EVENT_RANGE_DELETE_START = 'rangeDeleteStart';\nEvents.EVENT_RANGE_DELETE_END = 'rangeDeleteEnd';\n/** Undo operation has started. */\nEvents.EVENT_UNDO_STARTED = 'undoStarted';\n/** Undo operation has ended. */\nEvents.EVENT_UNDO_ENDED = 'undoEnded';\n/** Redo operation has started. */\nEvents.EVENT_REDO_STARTED = 'redoStarted';\n/** Redo operation has ended. */\nEvents.EVENT_REDO_ENDED = 'redoEnded';\nEvents.EVENT_KEY_SHORTCUT_CHANGED_CELL_START = 'keyShortcutChangedCellStart';\nEvents.EVENT_KEY_SHORTCUT_CHANGED_CELL_END = 'keyShortcutChangedCellEnd';\nEvents.EVENT_CELL_CLICKED = 'cellClicked';\nEvents.EVENT_CELL_DOUBLE_CLICKED = 'cellDoubleClicked';\nEvents.EVENT_CELL_MOUSE_DOWN = 'cellMouseDown';\nEvents.EVENT_CELL_CONTEXT_MENU = 'cellContextMenu';\nEvents.EVENT_CELL_VALUE_CHANGED = 'cellValueChanged';\nEvents.EVENT_CELL_EDIT_REQUEST = 'cellEditRequest';\nEvents.EVENT_ROW_VALUE_CHANGED = 'rowValueChanged';\nEvents.EVENT_CELL_FOCUSED = 'cellFocused';\nEvents.EVENT_CELL_FOCUS_CLEARED = 'cellFocusCleared';\nEvents.EVENT_FULL_WIDTH_ROW_FOCUSED = 'fullWidthRowFocused';\nEvents.EVENT_ROW_SELECTED = 'rowSelected';\nEvents.EVENT_SELECTION_CHANGED = 'selectionChanged';\nEvents.EVENT_TOOLTIP_SHOW = 'tooltipShow';\nEvents.EVENT_TOOLTIP_HIDE = 'tooltipHide';\nEvents.EVENT_CELL_KEY_DOWN = 'cellKeyDown';\nEvents.EVENT_CELL_MOUSE_OVER = 'cellMouseOver';\nEvents.EVENT_CELL_MOUSE_OUT = 'cellMouseOut';\n/** 2 events for filtering. The grid LISTENS for filterChanged and afterFilterChanged */\nEvents.EVENT_FILTER_CHANGED = 'filterChanged';\n/** Filter was change but not applied. Only useful if apply buttons are used in filters. */\nEvents.EVENT_FILTER_MODIFIED = 'filterModified';\nEvents.EVENT_FILTER_OPENED = 'filterOpened';\nEvents.EVENT_ADVANCED_FILTER_BUILDER_VISIBLE_CHANGED = 'advancedFilterBuilderVisibleChanged';\nEvents.EVENT_SORT_CHANGED = 'sortChanged';\n/** A row was removed from the dom, for any reason. Use to clean up resources (if any) used by the row. */\nEvents.EVENT_VIRTUAL_ROW_REMOVED = 'virtualRowRemoved';\nEvents.EVENT_ROW_CLICKED = 'rowClicked';\nEvents.EVENT_ROW_DOUBLE_CLICKED = 'rowDoubleClicked';\n/** Gets called once after the grid has finished initialising. */\nEvents.EVENT_GRID_READY = 'gridReady';\n/** Called once when the grid is about to get destroyed. */\nEvents.EVENT_GRID_PRE_DESTROYED = 'gridPreDestroyed';\n/** Width of height of the main grid div has changed. Grid listens for this and does layout of grid if it's\n * changed, so always filling the space it was given. */\nEvents.EVENT_GRID_SIZE_CHANGED = 'gridSizeChanged';\n/** The indexes of the rows rendered has changed, eg user has scrolled to a new vertical position. */\nEvents.EVENT_VIEWPORT_CHANGED = 'viewportChanged';\n/* The width of the scrollbar has been calculated */\nEvents.EVENT_SCROLLBAR_WIDTH_CHANGED = 'scrollbarWidthChanged';\n/** Rows were rendered for the first time (ie on async data load). */\nEvents.EVENT_FIRST_DATA_RENDERED = 'firstDataRendered';\n/** A column drag has started, either resizing a column or moving a column. */\nEvents.EVENT_DRAG_STARTED = 'dragStarted';\n/** A column drag has stopped */\nEvents.EVENT_DRAG_STOPPED = 'dragStopped';\nEvents.EVENT_CHECKBOX_CHANGED = 'checkboxChanged';\nEvents.EVENT_ROW_EDITING_STARTED = 'rowEditingStarted';\nEvents.EVENT_ROW_EDITING_STOPPED = 'rowEditingStopped';\nEvents.EVENT_CELL_EDITING_STARTED = 'cellEditingStarted';\nEvents.EVENT_CELL_EDITING_STOPPED = 'cellEditingStopped';\n/** Main body of grid has scrolled, either horizontally or vertically */\nEvents.EVENT_BODY_SCROLL = 'bodyScroll';\n/** Main body of the grid has stopped scrolling, either horizontally or vertically */\nEvents.EVENT_BODY_SCROLL_END = 'bodyScrollEnd';\nEvents.EVENT_HEIGHT_SCALE_CHANGED = 'heightScaleChanged';\n/** The displayed page for pagination has changed. For example the data was filtered or sorted,\n * or the user has moved to a different page. */\nEvents.EVENT_PAGINATION_CHANGED = 'paginationChanged';\n/** Only used by React, Angular, Web Components and VueJS AG Grid components\n * (not used if doing plain JavaScript). If the grid receives changes due\n * to bound properties, this event fires after the grid has finished processing the change. */\nEvents.EVENT_COMPONENT_STATE_CHANGED = 'componentStateChanged';\n/** Only used by the SSRM, called when the grid has no more rows to refresh */\nEvents.EVENT_STORE_REFRESHED = 'storeRefreshed';\n/***************************** INTERNAL EVENTS: START ******************************************* */\n/** Please remember to add to ComponentUtil.EXCLUDED_INTERNAL_EVENTS to not have these events exposed to framework components. */\n/** All items from here down are used internally by the grid, not intended for external use. */\n// not documented, either experimental, or we just don't want users using an depending on them\nEvents.EVENT_BODY_HEIGHT_CHANGED = 'bodyHeightChanged';\nEvents.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED = 'displayedColumnsWidthChanged';\nEvents.EVENT_SCROLL_VISIBILITY_CHANGED = 'scrollVisibilityChanged';\nEvents.EVENT_COLUMN_HOVER_CHANGED = 'columnHoverChanged';\nEvents.EVENT_FLASH_CELLS = 'flashCells';\nEvents.EVENT_PAGINATION_PIXEL_OFFSET_CHANGED = 'paginationPixelOffsetChanged';\nEvents.EVENT_DISPLAYED_ROWS_CHANGED = 'displayedRowsChanged';\nEvents.EVENT_LEFT_PINNED_WIDTH_CHANGED = 'leftPinnedWidthChanged';\nEvents.EVENT_RIGHT_PINNED_WIDTH_CHANGED = 'rightPinnedWidthChanged';\nEvents.EVENT_ROW_CONTAINER_HEIGHT_CHANGED = 'rowContainerHeightChanged';\nEvents.EVENT_HEADER_HEIGHT_CHANGED = 'headerHeightChanged';\nEvents.EVENT_COLUMN_HEADER_HEIGHT_CHANGED = 'columnHeaderHeightChanged';\nEvents.EVENT_ROW_DRAG_ENTER = 'rowDragEnter';\nEvents.EVENT_ROW_DRAG_MOVE = 'rowDragMove';\nEvents.EVENT_ROW_DRAG_LEAVE = 'rowDragLeave';\nEvents.EVENT_ROW_DRAG_END = 'rowDragEnd';\n// environment\nEvents.EVENT_GRID_STYLES_CHANGED = 'gridStylesChanged';\n// primarily for charts\nEvents.EVENT_POPUP_TO_FRONT = 'popupToFront';\n// these are used for server side group and agg - only used by CS with Viewport Row Model - intention is\n// to design these better around server side functions and then release to general public when fully working with\n// all the row models.\nEvents.EVENT_COLUMN_ROW_GROUP_CHANGE_REQUEST = 'columnRowGroupChangeRequest';\nEvents.EVENT_COLUMN_PIVOT_CHANGE_REQUEST = 'columnPivotChangeRequest';\nEvents.EVENT_COLUMN_VALUE_CHANGE_REQUEST = 'columnValueChangeRequest';\nEvents.EVENT_COLUMN_AGG_FUNC_CHANGE_REQUEST = 'columnAggFuncChangeRequest';\nEvents.EVENT_KEYBOARD_FOCUS = 'keyboardFocus';\nEvents.EVENT_MOUSE_FOCUS = 'mouseFocus';\nEvents.EVENT_STORE_UPDATED = 'storeUpdated';\nEvents.EVENT_FILTER_DESTROYED = 'filterDestroyed';\nEvents.EVENT_ROW_DATA_UPDATE_STARTED = 'rowDataUpdateStarted';\n// Advanced Filters\nEvents.EVENT_ADVANCED_FILTER_ENABLED_CHANGED = 'advancedFilterEnabledChanged';\nEvents.EVENT_DATA_TYPES_INFERRED = 'dataTypesInferred';\n// Widgets\nEvents.EVENT_FIELD_VALUE_CHANGED = 'fieldValueChanged';\nEvents.EVENT_FIELD_PICKER_VALUE_SELECTED = 'fieldPickerValueSelected';\n","// class returns unique instance id's for columns.\n// eg, the following calls (in this order) will result in:\n//\n// getInstanceIdForKey('country') => 0\n// getInstanceIdForKey('country') => 1\n// getInstanceIdForKey('country') => 2\n// getInstanceIdForKey('country') => 3\n// getInstanceIdForKey('age') => 0\n// getInstanceIdForKey('age') => 1\n// getInstanceIdForKey('country') => 4\nexport class GroupInstanceIdCreator {\n constructor() {\n // this map contains keys to numbers, so we remember what the last call was\n this.existingIds = {};\n }\n getInstanceIdForKey(key) {\n const lastResult = this.existingIds[key];\n let result;\n if (typeof lastResult !== 'number') {\n // first time this key\n result = 0;\n }\n else {\n result = lastResult + 1;\n }\n this.existingIds[key] = result;\n return result;\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean } from \"../context/context.mjs\";\nimport { Column } from \"../entities/column.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { mergeDeep } from \"../utils/object.mjs\";\nimport { missing } from \"../utils/generic.mjs\";\nexport const GROUP_AUTO_COLUMN_ID = 'ag-Grid-AutoColumn';\nlet AutoGroupColService = class AutoGroupColService extends BeanStub {\n createAutoGroupColumns(rowGroupColumns) {\n const groupAutoColumns = [];\n const doingTreeData = this.gridOptionsService.is('treeData');\n let doingMultiAutoColumn = this.gridOptionsService.isGroupMultiAutoColumn();\n if (doingTreeData && doingMultiAutoColumn) {\n console.warn('AG Grid: you cannot mix groupDisplayType = \"multipleColumns\" with treeData, only one column can be used to display groups when doing tree data');\n doingMultiAutoColumn = false;\n }\n // if doing groupDisplayType = \"multipleColumns\", then we call the method multiple times, once\n // for each column we are grouping by\n if (doingMultiAutoColumn) {\n rowGroupColumns.forEach((rowGroupCol, index) => {\n groupAutoColumns.push(this.createOneAutoGroupColumn(rowGroupCol, index));\n });\n }\n else {\n groupAutoColumns.push(this.createOneAutoGroupColumn());\n }\n return groupAutoColumns;\n }\n updateAutoGroupColumns(autoGroupColumns) {\n autoGroupColumns.forEach((column, index) => this.updateOneAutoGroupColumn(column, index));\n }\n // rowGroupCol and index are missing if groupDisplayType != \"multipleColumns\"\n createOneAutoGroupColumn(rowGroupCol, index) {\n // if doing multi, set the field\n let colId;\n if (rowGroupCol) {\n colId = `${GROUP_AUTO_COLUMN_ID}-${rowGroupCol.getId()}`;\n }\n else {\n colId = GROUP_AUTO_COLUMN_ID;\n }\n const colDef = this.createAutoGroupColDef(colId, rowGroupCol, index);\n colDef.colId = colId;\n const newCol = new Column(colDef, null, colId, true);\n this.context.createBean(newCol);\n return newCol;\n }\n /**\n * Refreshes an auto group col to load changes from defaultColDef or autoGroupColDef\n */\n updateOneAutoGroupColumn(colToUpdate, index) {\n const oldColDef = colToUpdate.getColDef();\n const underlyingColId = typeof oldColDef.showRowGroup == 'string' ? oldColDef.showRowGroup : undefined;\n const underlyingColumn = underlyingColId != null ? this.columnModel.getPrimaryColumn(underlyingColId) : undefined;\n const colDef = this.createAutoGroupColDef(colToUpdate.getId(), underlyingColumn !== null && underlyingColumn !== void 0 ? underlyingColumn : undefined, index);\n colToUpdate.setColDef(colDef, null);\n this.columnFactory.applyColumnState(colToUpdate, colDef);\n }\n createAutoGroupColDef(colId, underlyingColumn, index) {\n // if one provided by user, use it, otherwise create one\n let res = this.createBaseColDef(underlyingColumn);\n const autoGroupColumnDef = this.gridOptionsService.get('autoGroupColumnDef');\n mergeDeep(res, autoGroupColumnDef);\n res = this.columnFactory.addColumnDefaultAndTypes(res, colId);\n // For tree data the filter is always allowed\n if (!this.gridOptionsService.is('treeData')) {\n // we would only allow filter if the user has provided field or value getter. otherwise the filter\n // would not be able to work.\n const noFieldOrValueGetter = missing(res.field) &&\n missing(res.valueGetter) &&\n missing(res.filterValueGetter) &&\n res.filter !== 'agGroupColumnFilter';\n if (noFieldOrValueGetter) {\n res.filter = false;\n }\n }\n // if showing many cols, we don't want to show more than one with a checkbox for selection\n if (index && index > 0) {\n res.headerCheckboxSelection = false;\n }\n const isSortingCoupled = this.gridOptionsService.isColumnsSortingCoupledToGroup();\n const hasOwnData = res.valueGetter || res.field != null;\n if (isSortingCoupled && !hasOwnData) {\n // if col is coupled sorting, and has sort attribute, we want to ignore this\n // because we only accept the sort on creation of the col\n res.sortIndex = undefined;\n res.initialSort = undefined;\n }\n return res;\n }\n createBaseColDef(rowGroupCol) {\n const userDef = this.gridOptionsService.get('autoGroupColumnDef');\n const localeTextFunc = this.localeService.getLocaleTextFunc();\n const res = {\n headerName: localeTextFunc('group', 'Group')\n };\n const userHasProvidedGroupCellRenderer = userDef &&\n (userDef.cellRenderer || userDef.cellRendererSelector);\n // only add the default group cell renderer if user hasn't provided one\n if (!userHasProvidedGroupCellRenderer) {\n res.cellRenderer = 'agGroupCellRenderer';\n }\n // we never allow moving the group column\n // defaultAutoColDef.suppressMovable = true;\n if (rowGroupCol) {\n const colDef = rowGroupCol.getColDef();\n Object.assign(res, {\n // cellRendererParams.groupKey: colDefToCopy.field;\n headerName: this.columnModel.getDisplayNameForColumn(rowGroupCol, 'header'),\n headerValueGetter: colDef.headerValueGetter\n });\n if (colDef.cellRenderer) {\n Object.assign(res, {\n cellRendererParams: {\n innerRenderer: colDef.cellRenderer,\n innerRendererParams: colDef.cellRendererParams\n }\n });\n }\n res.showRowGroup = rowGroupCol.getColId();\n }\n else {\n res.showRowGroup = true;\n }\n return res;\n }\n};\n__decorate([\n Autowired('columnModel')\n], AutoGroupColService.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('columnFactory')\n], AutoGroupColService.prototype, \"columnFactory\", void 0);\nAutoGroupColService = __decorate([\n Bean('autoGroupColService')\n], AutoGroupColService);\nexport { AutoGroupColService };\n","const reUnescapedHtml = /[&<>\"']/g;\n/**\n * HTML Escapes.\n */\nconst HTML_ESCAPES = {\n '&': '&',\n '<': '<',\n '>': '>',\n '\"': '"',\n \"'\": '''\n};\n/**\n * It encodes any string in UTF-8 format\n * taken from https://github.com/mathiasbynens/utf8.js\n * @param {string} s\n * @returns {string}\n */\nexport function utf8_encode(s) {\n const stringFromCharCode = String.fromCharCode;\n function ucs2decode(string) {\n const output = [];\n if (!string) {\n return [];\n }\n const len = string.length;\n let counter = 0;\n let value;\n let extra;\n while (counter < len) {\n value = string.charCodeAt(counter++);\n if (value >= 0xD800 && value <= 0xDBFF && counter < len) {\n // high surrogate, and there is a next character\n extra = string.charCodeAt(counter++);\n if ((extra & 0xFC00) == 0xDC00) { // low surrogate\n output.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000);\n }\n else {\n // unmatched surrogate; only append this code unit, in case the next\n // code unit is the high surrogate of a surrogate pair\n output.push(value);\n counter--;\n }\n }\n else {\n output.push(value);\n }\n }\n return output;\n }\n function checkScalarValue(point) {\n if (point >= 0xD800 && point <= 0xDFFF) {\n throw Error('Lone surrogate U+' + point.toString(16).toUpperCase() +\n ' is not a scalar value');\n }\n }\n function createByte(point, shift) {\n return stringFromCharCode(((point >> shift) & 0x3F) | 0x80);\n }\n function encodeCodePoint(point) {\n if ((point >= 0 && point <= 31 && point !== 10)) {\n const convertedCode = point.toString(16).toUpperCase();\n const paddedCode = convertedCode.padStart(4, '0');\n return `_x${paddedCode}_`;\n }\n if ((point & 0xFFFFFF80) == 0) { // 1-byte sequence\n return stringFromCharCode(point);\n }\n let symbol = '';\n if ((point & 0xFFFFF800) == 0) { // 2-byte sequence\n symbol = stringFromCharCode(((point >> 6) & 0x1F) | 0xC0);\n }\n else if ((point & 0xFFFF0000) == 0) { // 3-byte sequence\n checkScalarValue(point);\n symbol = stringFromCharCode(((point >> 12) & 0x0F) | 0xE0);\n symbol += createByte(point, 6);\n }\n else if ((point & 0xFFE00000) == 0) { // 4-byte sequence\n symbol = stringFromCharCode(((point >> 18) & 0x07) | 0xF0);\n symbol += createByte(point, 12);\n symbol += createByte(point, 6);\n }\n symbol += stringFromCharCode((point & 0x3F) | 0x80);\n return symbol;\n }\n const codePoints = ucs2decode(s);\n const length = codePoints.length;\n let index = -1;\n let codePoint;\n let byteString = '';\n while (++index < length) {\n codePoint = codePoints[index];\n byteString += encodeCodePoint(codePoint);\n }\n return byteString;\n}\nexport function capitalise(str) {\n return str[0].toUpperCase() + str.substr(1).toLowerCase();\n}\nexport function escapeString(toEscape, skipEscapingHtmlChars) {\n if (toEscape == null) {\n return null;\n }\n // we call toString() twice, in case value is an object, where user provides\n // a toString() method, and first call to toString() returns back something other\n // than a string (eg a number to render)\n const stringResult = toEscape.toString().toString();\n if (skipEscapingHtmlChars) {\n return stringResult;\n }\n // in react we don't need to escape html characters, as it's done by the framework\n return stringResult.replace(reUnescapedHtml, chr => HTML_ESCAPES[chr]);\n}\n/**\n * Converts a camelCase string into startCase\n * @param {string} camelCase\n * @return {string}\n */\nexport function camelCaseToHumanText(camelCase) {\n if (!camelCase || camelCase == null) {\n return null;\n }\n // either split on a lowercase followed by uppercase ie asHereTo -> as Here To\n const rex = /([a-z])([A-Z])/g;\n // or starts with uppercase and we take all expect the last which is assumed to be part of next word if followed by lowercase HEREToThere -> HERE To There\n const rexCaps = /([A-Z]+)([A-Z])([a-z])/g;\n const words = camelCase\n .replace(rex, '$1 $2')\n .replace(rexCaps, '$1 $2$3')\n .replace(/\\./g, ' ')\n .split(' ');\n return words.map(word => word.substring(0, 1).toUpperCase() + ((word.length > 1) ? word.substring(1, word.length) : '')).join(' ');\n}\n/**\n * Converts a camelCase string into hyphenated string\n * @param {string} camelCase\n * @return {string}\n */\nexport function camelCaseToHyphenated(camelCase) {\n return camelCase.replace(/[A-Z]/g, s => `-${s.toLocaleLowerCase()}`);\n}\n","export function convertToMap(arr) {\n const map = new Map();\n arr.forEach(pair => map.set(pair[0], pair[1]));\n return map;\n}\n// handy for organising a list into a map, where each item is mapped by an attribute, eg mapping Columns by ID\nexport function mapById(arr, callback) {\n const map = new Map();\n arr.forEach(item => map.set(callback(item), item));\n return map;\n}\nexport function keys(map) {\n const arr = [];\n map.forEach((_, key) => arr.push(key));\n return arr;\n}\n","export class ColDefUtil {\n}\nColDefUtil.ColDefPropertyMap = {\n headerName: undefined,\n columnGroupShow: undefined,\n headerClass: undefined,\n toolPanelClass: undefined,\n headerValueGetter: undefined,\n pivotKeys: undefined,\n groupId: undefined,\n colId: undefined,\n sort: undefined,\n initialSort: undefined,\n field: undefined,\n type: undefined,\n cellDataType: undefined,\n tooltipComponent: undefined,\n tooltipField: undefined,\n headerTooltip: undefined,\n cellClass: undefined,\n showRowGroup: undefined,\n filter: undefined,\n initialAggFunc: undefined,\n defaultAggFunc: undefined,\n aggFunc: undefined,\n pinned: undefined,\n initialPinned: undefined,\n chartDataType: undefined,\n cellEditorPopupPosition: undefined,\n headerGroupComponent: undefined,\n headerGroupComponentParams: undefined,\n cellStyle: undefined,\n cellRenderer: undefined,\n cellRendererParams: undefined,\n cellEditor: undefined,\n cellEditorParams: undefined,\n filterParams: undefined,\n pivotValueColumn: undefined,\n headerComponent: undefined,\n headerComponentParams: undefined,\n floatingFilterComponent: undefined,\n floatingFilterComponentParams: undefined,\n tooltipComponentParams: undefined,\n refData: undefined,\n columnsMenuParams: undefined,\n children: undefined,\n sortingOrder: undefined,\n allowedAggFuncs: undefined,\n menuTabs: undefined,\n pivotTotalColumnIds: undefined,\n cellClassRules: undefined,\n icons: undefined,\n sortIndex: undefined,\n initialSortIndex: undefined,\n flex: undefined,\n initialFlex: undefined,\n width: undefined,\n initialWidth: undefined,\n minWidth: undefined,\n maxWidth: undefined,\n rowGroupIndex: undefined,\n initialRowGroupIndex: undefined,\n pivotIndex: undefined,\n initialPivotIndex: undefined,\n suppressCellFlash: undefined,\n suppressColumnsToolPanel: undefined,\n suppressFiltersToolPanel: undefined,\n openByDefault: undefined,\n marryChildren: undefined,\n suppressStickyLabel: undefined,\n hide: undefined,\n initialHide: undefined,\n rowGroup: undefined,\n initialRowGroup: undefined,\n pivot: undefined,\n initialPivot: undefined,\n checkboxSelection: undefined,\n showDisabledCheckboxes: undefined,\n headerCheckboxSelection: undefined,\n headerCheckboxSelectionFilteredOnly: undefined,\n headerCheckboxSelectionCurrentPageOnly: undefined,\n suppressMenu: undefined,\n suppressMovable: undefined,\n lockPosition: undefined,\n lockVisible: undefined,\n lockPinned: undefined,\n unSortIcon: undefined,\n suppressSizeToFit: undefined,\n suppressAutoSize: undefined,\n enableRowGroup: undefined,\n enablePivot: undefined,\n enableValue: undefined,\n editable: undefined,\n suppressPaste: undefined,\n suppressNavigable: undefined,\n enableCellChangeFlash: undefined,\n rowDrag: undefined,\n dndSource: undefined,\n autoHeight: undefined,\n wrapText: undefined,\n sortable: undefined,\n resizable: undefined,\n singleClickEdit: undefined,\n floatingFilter: undefined,\n cellEditorPopup: undefined,\n suppressFillHandle: undefined,\n wrapHeaderText: undefined,\n autoHeaderHeight: undefined,\n dndSourceOnRowDrag: undefined,\n valueGetter: undefined,\n valueSetter: undefined,\n filterValueGetter: undefined,\n keyCreator: undefined,\n valueFormatter: undefined,\n valueParser: undefined,\n comparator: undefined,\n equals: undefined,\n pivotComparator: undefined,\n suppressKeyboardEvent: undefined,\n suppressHeaderKeyboardEvent: undefined,\n colSpan: undefined,\n rowSpan: undefined,\n getQuickFilterText: undefined,\n onCellValueChanged: undefined,\n onCellClicked: undefined,\n onCellDoubleClicked: undefined,\n onCellContextMenu: undefined,\n rowDragText: undefined,\n tooltipValueGetter: undefined,\n cellRendererSelector: undefined,\n cellEditorSelector: undefined,\n suppressSpanHeaderHeight: undefined,\n useValueFormatterForExport: undefined,\n useValueParserForImport: undefined,\n};\nColDefUtil.ALL_PROPERTIES = Object.keys(ColDefUtil.ColDefPropertyMap);\n","/**\n * These keys are used for validating properties supplied on a gridOptions object, and for code generation.\n * If you change the properties on the gridOptions interface, you *must* update this file as well to be consistent.\n */\nexport class PropertyKeys {\n}\nPropertyKeys.STRING_PROPERTIES = [\n 'rowSelection', 'overlayLoadingTemplate', 'overlayNoRowsTemplate', 'gridId',\n 'quickFilterText', 'rowModelType', 'editType', 'domLayout', 'clipboardDelimiter', 'rowGroupPanelShow',\n 'multiSortKey', 'pivotColumnGroupTotals', 'pivotRowTotals', 'pivotPanelShow', 'fillHandleDirection',\n 'serverSideStoreType', 'groupDisplayType', 'treeDataDisplayType', 'colResizeDefault', 'tooltipTrigger',\n 'serverSidePivotResultFieldSeparator',\n];\nPropertyKeys.OBJECT_PROPERTIES = [\n 'components', 'rowStyle', 'context', 'autoGroupColumnDef', 'localeText', 'icons',\n 'datasource', 'serverSideDatasource', 'viewportDatasource', 'groupRowRendererParams', 'aggFuncs', 'fullWidthCellRendererParams',\n 'defaultColGroupDef', 'defaultColDef', 'defaultCsvExportParams', 'defaultExcelExportParams', 'columnTypes',\n 'rowClassRules', 'detailCellRendererParams', 'loadingCellRendererParams', 'loadingOverlayComponentParams',\n 'noRowsOverlayComponentParams', 'popupParent', 'statusBar', 'sideBar', 'chartThemeOverrides',\n 'customChartThemes', 'chartToolPanelsDef', 'dataTypeDefinitions', 'advancedFilterModel', 'advancedFilterParent',\n 'advancedFilterBuilderParams',\n];\nPropertyKeys.ARRAY_PROPERTIES = [\n 'sortingOrder', 'alignedGrids', 'rowData', 'columnDefs', 'excelStyles', 'pinnedTopRowData', 'pinnedBottomRowData', 'chartThemes', 'rowClass',\n];\nPropertyKeys.NUMBER_PROPERTIES = [\n 'rowHeight', 'detailRowHeight', 'rowBuffer', 'headerHeight', 'groupHeaderHeight', 'floatingFiltersHeight',\n 'pivotHeaderHeight', 'pivotGroupHeaderHeight', 'groupDefaultExpanded', 'pivotDefaultExpanded', 'viewportRowModelPageSize',\n 'viewportRowModelBufferSize', 'autoSizePadding', 'maxBlocksInCache', 'maxConcurrentDatasourceRequests', 'tooltipShowDelay',\n 'tooltipHideDelay', 'cacheOverflowSize', 'paginationPageSize', 'cacheBlockSize', 'infiniteInitialRowCount', 'serverSideInitialRowCount', 'scrollbarWidth',\n 'asyncTransactionWaitMillis', 'blockLoadDebounceMillis', 'keepDetailRowsCount',\n 'undoRedoCellEditingLimit', 'cellFlashDelay', 'cellFadeDelay', 'tabIndex'\n];\nPropertyKeys.BOOLEAN_PROPERTIES = [\n 'suppressMakeColumnVisibleAfterUnGroup', 'suppressRowClickSelection', 'suppressCellFocus', 'suppressHorizontalScroll',\n 'alwaysShowHorizontalScroll', 'alwaysShowVerticalScroll', 'debug', 'enableBrowserTooltips', 'enableCellExpressions', 'groupSelectsChildren',\n 'groupIncludeTotalFooter', 'groupSuppressBlankHeader', 'suppressMenuHide', 'suppressRowDeselection', 'unSortIcon',\n 'suppressMultiSort', 'alwaysMultiSort', 'singleClickEdit', 'suppressLoadingOverlay', 'suppressNoRowsOverlay', 'suppressAutoSize',\n 'skipHeaderOnAutoSize', 'suppressParentsInRowNodes', 'suppressColumnMoveAnimation', 'suppressMovableColumns', 'suppressFieldDotNotation',\n 'enableRangeSelection', 'enableRangeHandle', 'enableFillHandle', 'suppressClearOnFillReduction', 'deltaSort', 'suppressTouch', 'suppressAsyncEvents',\n 'allowContextMenuWithControlKey', 'suppressContextMenu', 'rememberGroupStateWhenNewData', 'enableCellChangeFlash', 'suppressDragLeaveHidesColumns',\n 'suppressRowGroupHidesColumns', 'suppressMiddleClickScrolls', 'suppressPreventDefaultOnMouseWheel', 'suppressCopyRowsToClipboard', 'copyHeadersToClipboard',\n 'copyGroupHeadersToClipboard', 'pivotMode', 'suppressAggFuncInHeader', 'suppressColumnVirtualisation', 'alwaysAggregateAtRootLevel', 'suppressAggAtRootLevel',\n 'suppressFocusAfterRefresh', 'functionsPassive', 'functionsReadOnly', 'animateRows', 'groupSelectsFiltered', 'groupRemoveSingleChildren',\n 'groupRemoveLowestSingleChildren', 'enableRtl', 'suppressClickEdit', 'rowDragEntireRow', 'rowDragManaged', 'suppressRowDrag', 'suppressMoveWhenRowDragging',\n 'rowDragMultiRow', 'enableGroupEdit', 'embedFullWidthRows', 'suppressPaginationPanel', 'groupHideOpenParents', 'groupAllowUnbalanced', 'pagination',\n 'paginationAutoPageSize', 'suppressScrollOnNewData', 'suppressScrollWhenPopupsAreOpen', 'purgeClosedRowNodes', 'cacheQuickFilter', 'includeHiddenColumnsInQuickFilter',\n 'excludeHiddenColumnsFromQuickFilter', 'ensureDomOrder', 'accentedSort', 'suppressChangeDetection', 'valueCache', 'valueCacheNeverExpires', 'aggregateOnlyChangedColumns',\n 'suppressAnimationFrame', 'suppressExcelExport', 'suppressCsvExport', 'treeData', 'masterDetail', 'suppressMultiRangeSelection', 'enterMovesDown',\n 'enterMovesDownAfterEdit', 'enterNavigatesVerticallyAfterEdit', 'enterNavigatesVertically', 'suppressPropertyNamesCheck', 'rowMultiSelectWithClick',\n 'suppressRowHoverHighlight', 'suppressRowTransform', 'suppressClipboardPaste', 'suppressLastEmptyLineOnPaste', 'enableCharts', 'enableChartToolPanelsButton',\n 'suppressChartToolPanelsButton', 'suppressMaintainUnsortedOrder', 'enableCellTextSelection', 'suppressBrowserResizeObserver', 'suppressMaxRenderedRowRestriction',\n 'excludeChildrenWhenTreeDataFiltering', 'tooltipMouseTrack', 'tooltipInteraction', 'keepDetailRows', 'paginateChildRows', 'preventDefaultOnContextMenu',\n 'undoRedoCellEditing', 'allowDragFromColumnsToolPanel', 'pivotSuppressAutoColumn', 'suppressExpandablePivotGroups', 'debounceVerticalScrollbar', 'detailRowAutoHeight',\n 'serverSideFilteringAlwaysResets', 'serverSideFilterAllLevels', 'serverSideSortingAlwaysResets', 'serverSideSortAllLevels', 'serverSideOnlyRefreshFilteredGroups',\n 'serverSideSortOnServer', 'serverSideFilterOnServer', 'suppressAggFilteredOnly', 'showOpenedGroup', 'suppressClipboardApi', 'suppressModelUpdateAfterUpdateTransaction',\n 'stopEditingWhenCellsLoseFocus', 'maintainColumnOrder', 'groupMaintainOrder', 'columnHoverHighlight', 'suppressReactUi', 'readOnlyEdit', 'suppressRowVirtualisation',\n 'enableCellEditingOnBackspace', 'resetRowDataOnUpdate', 'removePivotHeaderRowWhenSingleValueColumn', 'suppressCopySingleCellRanges', 'suppressGroupRowsSticky',\n 'suppressServerSideInfiniteScroll', 'rowGroupPanelSuppressSort', 'allowShowChangeAfterFilter', 'suppressCutToClipboard', 'enableAdvancedFilter',\n 'includeHiddenColumnsInAdvancedFilter',\n];\n/** You do not need to include event callbacks in this list, as they are generated automatically. */\nPropertyKeys.FUNCTIONAL_PROPERTIES = [\n 'doesExternalFilterPass', 'processSecondaryColDef', 'processSecondaryColGroupDef', 'processPivotResultColDef',\n 'processPivotResultColGroupDef', 'getBusinessKeyForNode', 'isRowSelectable', 'rowDragText',\n 'groupRowRenderer', 'fullWidthCellRenderer',\n 'loadingCellRenderer', 'loadingOverlayComponent', 'noRowsOverlayComponent',\n 'detailCellRenderer', 'quickFilterParser', 'quickFilterMatcher'\n];\nPropertyKeys.CALLBACK_PROPERTIES = [\n 'getLocaleText', 'isExternalFilterPresent', 'getRowHeight', 'getRowClass', 'getRowStyle', 'getContextMenuItems', 'getMainMenuItems',\n 'processRowPostCreate', 'processCellForClipboard', 'getGroupRowAgg', 'isFullWidthRow',\n 'sendToClipboard', 'navigateToNextHeader', 'tabToNextHeader', 'navigateToNextCell',\n 'tabToNextCell', 'processCellFromClipboard', 'getDocument', 'postProcessPopup', 'getChildCount', 'getDataPath', 'isRowMaster', 'postSortRows', 'processHeaderForClipboard',\n 'processGroupHeaderForClipboard', 'paginationNumberFormatter', 'processDataFromClipboard', 'getServerSideGroupKey', 'isServerSideGroup',\n 'createChartContainer', 'getChartToolbarItems', 'fillOperation', 'isApplyServerSideTransaction', 'getServerSideStoreParams', 'getServerSideGroupLevelParams',\n 'isServerSideGroupOpenByDefault', 'isGroupOpenByDefault', 'initialGroupOrderComparator', 'groupIncludeFooter',\n 'loadingCellRendererSelector', 'getRowId', 'groupAggFiltering'\n];\nPropertyKeys.FUNCTION_PROPERTIES = [\n ...PropertyKeys.FUNCTIONAL_PROPERTIES,\n ...PropertyKeys.CALLBACK_PROPERTIES\n];\nPropertyKeys.ALL_PROPERTIES = [\n ...PropertyKeys.ARRAY_PROPERTIES,\n ...PropertyKeys.OBJECT_PROPERTIES,\n ...PropertyKeys.STRING_PROPERTIES,\n ...PropertyKeys.NUMBER_PROPERTIES,\n ...PropertyKeys.FUNCTION_PROPERTIES,\n ...PropertyKeys.BOOLEAN_PROPERTIES\n];\n","import { Events } from '../events.mjs';\nimport { PropertyKeys } from '../propertyKeys.mjs';\nimport { iterateObject } from '../utils/object.mjs';\nimport { includes } from '../utils/array.mjs';\nimport { values } from '../utils/generic.mjs';\nexport class ComponentUtil {\n static getCallbackForEvent(eventName) {\n if (!eventName || eventName.length < 2) {\n return eventName;\n }\n return 'on' + eventName[0].toUpperCase() + eventName.substr(1);\n }\n static getCoercionLookup() {\n let coercionLookup = {};\n [\n ...ComponentUtil.ARRAY_PROPERTIES,\n ...ComponentUtil.OBJECT_PROPERTIES,\n ...ComponentUtil.STRING_PROPERTIES,\n ...ComponentUtil.FUNCTION_PROPERTIES,\n ...ComponentUtil.EVENT_CALLBACKS,\n ]\n .forEach((key) => coercionLookup[key] = 'none');\n ComponentUtil.BOOLEAN_PROPERTIES\n .forEach(key => coercionLookup[key] = 'boolean');\n ComponentUtil.NUMBER_PROPERTIES\n .forEach(key => coercionLookup[key] = 'number');\n return coercionLookup;\n }\n static getValue(key, rawValue) {\n const coercionStep = ComponentUtil.coercionLookup[key];\n if (coercionStep) {\n let newValue = rawValue;\n switch (coercionStep) {\n case 'number': {\n newValue = ComponentUtil.toNumber(rawValue);\n break;\n }\n case 'boolean': {\n newValue = ComponentUtil.toBoolean(rawValue);\n break;\n }\n case 'none': {\n // if groupAggFiltering exists and isn't a function, handle as a boolean.\n if (key === 'groupAggFiltering' && typeof rawValue !== 'function') {\n newValue = ComponentUtil.toBoolean(rawValue);\n }\n break;\n }\n }\n return newValue;\n }\n return undefined;\n }\n static getGridOptionKeys(component, isVue) {\n // Vue does not have keys in prod so instead need to run through all the \n // gridOptions checking for presence of a gridOption key.\n return isVue\n ? Object.keys(ComponentUtil.coercionLookup)\n : Object.keys(component);\n }\n static copyAttributesToGridOptions(gridOptions, component, isVue = false) {\n // create empty grid options if none were passed\n if (typeof gridOptions !== 'object') {\n gridOptions = {};\n }\n // to allow array style lookup in TypeScript, take type away from 'this' and 'gridOptions'\n const pGridOptions = gridOptions;\n const keys = ComponentUtil.getGridOptionKeys(component, isVue);\n // Loop through component props, if they are not undefined and a valid gridOption copy to gridOptions\n keys.forEach(key => {\n const value = component[key];\n if (typeof value !== 'undefined') {\n const coercedValue = ComponentUtil.getValue(key, value);\n if (coercedValue !== undefined) {\n pGridOptions[key] = coercedValue;\n }\n }\n });\n return gridOptions;\n }\n static processOnChange(changes, api) {\n if (!changes || Object.keys(changes).length === 0) {\n return;\n }\n this.changeSetId++;\n const changesToApply = Object.assign({}, changes);\n // We manually call these updates so that we can provide a different source of gridOptionsChanged\n // We do not call setProperty as this will be called by the grid api methods\n if (changesToApply.columnTypes) {\n api.setColumnTypes(changesToApply.columnTypes.currentValue, \"gridOptionsChanged\");\n delete changesToApply.columnTypes;\n }\n if (changesToApply.autoGroupColumnDef) {\n api.setAutoGroupColumnDef(changesToApply.autoGroupColumnDef.currentValue, \"gridOptionsChanged\");\n delete changesToApply.autoGroupColumnDef;\n }\n if (changesToApply.defaultColDef) {\n api.setDefaultColDef(changesToApply.defaultColDef.currentValue, \"gridOptionsChanged\");\n delete changesToApply.defaultColDef;\n }\n if (changesToApply.columnDefs) {\n api.setColumnDefs(changesToApply.columnDefs.currentValue, \"gridOptionsChanged\");\n delete changesToApply.columnDefs;\n }\n // Update all the properties on GridOptions first so that we can optimise updates\n // and so that any update logic triggered off events is only run after all the\n // props have been updated. This avoids potential sync issues\n const updates = Object.keys(changesToApply).map(key => {\n const gridKey = key;\n const coercedValue = ComponentUtil.getValue(gridKey, changesToApply[gridKey].currentValue);\n // Use isChanged to control event via force option as by the time we call __updateProperty the gridOptions[key] will already contain the new value.\n const isChanged = api.__setPropertyOnly(gridKey, coercedValue);\n return { gridKey, coercedValue, isChanged };\n })\n // Only include properties that have changed\n .filter(u => u.isChanged);\n // Then cause any property change event listeners to be fired.\n const updatedKeys = updates.map(u => u.gridKey);\n updates.forEach((u) => api.__updateProperty(u.gridKey, u.coercedValue, u.isChanged, { id: this.changeSetId, properties: updatedKeys }));\n // copy changes into an event for dispatch\n const event = {\n type: Events.EVENT_COMPONENT_STATE_CHANGED\n };\n iterateObject(changes, (key, value) => {\n event[key] = value;\n });\n api.dispatchEvent(event);\n }\n static toBoolean(value) {\n if (typeof value === 'boolean') {\n return value;\n }\n if (typeof value === 'string') {\n // for boolean, compare to empty String to allow attributes appearing with\n // no value to be treated as 'true'\n return value.toUpperCase() === 'TRUE' || value == '';\n }\n return false;\n }\n static toNumber(value) {\n if (typeof value === 'number') {\n return value;\n }\n if (typeof value === 'string') {\n return Number(value);\n }\n }\n}\n// all events\nComponentUtil.EVENTS = values(Events);\n// events that are internal to AG Grid and should not be exposed to users via documentation or generated framework components\n/** Exclude the following internal events from code generation to prevent exposing these events via framework components */\nComponentUtil.EXCLUDED_INTERNAL_EVENTS = [\n Events.EVENT_SCROLLBAR_WIDTH_CHANGED,\n Events.EVENT_CHECKBOX_CHANGED,\n Events.EVENT_HEIGHT_SCALE_CHANGED,\n Events.EVENT_BODY_HEIGHT_CHANGED,\n Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED,\n Events.EVENT_SCROLL_VISIBILITY_CHANGED,\n Events.EVENT_COLUMN_HOVER_CHANGED,\n Events.EVENT_FLASH_CELLS,\n Events.EVENT_PAGINATION_PIXEL_OFFSET_CHANGED,\n Events.EVENT_DISPLAYED_ROWS_CHANGED,\n Events.EVENT_LEFT_PINNED_WIDTH_CHANGED,\n Events.EVENT_RIGHT_PINNED_WIDTH_CHANGED,\n Events.EVENT_ROW_CONTAINER_HEIGHT_CHANGED,\n Events.EVENT_POPUP_TO_FRONT,\n Events.EVENT_KEYBOARD_FOCUS,\n Events.EVENT_MOUSE_FOCUS,\n Events.EVENT_STORE_UPDATED,\n Events.EVENT_COLUMN_PANEL_ITEM_DRAG_START,\n Events.EVENT_COLUMN_PANEL_ITEM_DRAG_END,\n Events.EVENT_FILL_START,\n Events.EVENT_FILL_END,\n Events.EVENT_KEY_SHORTCUT_CHANGED_CELL_START,\n Events.EVENT_KEY_SHORTCUT_CHANGED_CELL_END,\n Events.EVENT_FULL_WIDTH_ROW_FOCUSED,\n Events.EVENT_HEADER_HEIGHT_CHANGED,\n Events.EVENT_COLUMN_HEADER_HEIGHT_CHANGED,\n Events.EVENT_CELL_FOCUS_CLEARED,\n Events.EVENT_GRID_STYLES_CHANGED,\n Events.EVENT_FILTER_DESTROYED,\n Events.EVENT_ROW_DATA_UPDATE_STARTED,\n Events.EVENT_ADVANCED_FILTER_ENABLED_CHANGED,\n Events.EVENT_DATA_TYPES_INFERRED,\n Events.EVENT_FIELD_VALUE_CHANGED,\n Events.EVENT_FIELD_PICKER_VALUE_SELECTED\n];\n// events that are available for use by users of AG Grid and so should be documented\n/** EVENTS that should be exposed via code generation for the framework components. */\nComponentUtil.PUBLIC_EVENTS = ComponentUtil.EVENTS.filter(e => !includes(ComponentUtil.EXCLUDED_INTERNAL_EVENTS, e));\n// onXXX methods, based on the above events\nComponentUtil.EVENT_CALLBACKS = ComponentUtil.EVENTS.map(event => ComponentUtil.getCallbackForEvent(event));\nComponentUtil.STRING_PROPERTIES = PropertyKeys.STRING_PROPERTIES;\nComponentUtil.OBJECT_PROPERTIES = PropertyKeys.OBJECT_PROPERTIES;\nComponentUtil.ARRAY_PROPERTIES = PropertyKeys.ARRAY_PROPERTIES;\nComponentUtil.NUMBER_PROPERTIES = PropertyKeys.NUMBER_PROPERTIES;\nComponentUtil.BOOLEAN_PROPERTIES = PropertyKeys.BOOLEAN_PROPERTIES;\nComponentUtil.FUNCTION_PROPERTIES = PropertyKeys.FUNCTION_PROPERTIES;\nComponentUtil.ALL_PROPERTIES = PropertyKeys.ALL_PROPERTIES;\nComponentUtil.ALL_PROPERTIES_SET = new Set(PropertyKeys.ALL_PROPERTIES);\nComponentUtil.changeSetId = 0;\nComponentUtil.coercionLookup = ComponentUtil.getCoercionLookup();\n","export function fuzzyCheckStrings(inputValues, validValues, allSuggestions) {\n const fuzzyMatches = {};\n const invalidInputs = inputValues.filter(inputValue => !validValues.some((validValue) => validValue === inputValue));\n if (invalidInputs.length > 0) {\n invalidInputs.forEach(invalidInput => fuzzyMatches[invalidInput] = fuzzySuggestions(invalidInput, allSuggestions).values);\n }\n return fuzzyMatches;\n}\n/**\n *\n * @param {String} inputValue The value to be compared against a list of strings\n * @param allSuggestions The list of strings to be compared against\n */\nexport function fuzzySuggestions(inputValue, allSuggestions, hideIrrelevant, filterByPercentageOfBestMatch) {\n let thisSuggestions = allSuggestions.map((text, idx) => ({\n value: text,\n relevance: stringWeightedDistances(inputValue.toLowerCase(), text.toLocaleLowerCase()),\n idx\n }));\n thisSuggestions.sort((a, b) => b.relevance - a.relevance);\n if (hideIrrelevant) {\n thisSuggestions = thisSuggestions.filter(suggestion => suggestion.relevance !== 0);\n }\n if (thisSuggestions.length > 0 && filterByPercentageOfBestMatch && filterByPercentageOfBestMatch > 0) {\n const bestMatch = thisSuggestions[0].relevance;\n const limit = bestMatch * filterByPercentageOfBestMatch;\n thisSuggestions = thisSuggestions.filter(suggestion => limit - suggestion.relevance < 0);\n }\n const values = [];\n const indices = [];\n for (const suggestion of thisSuggestions) {\n values.push(suggestion.value);\n indices.push(suggestion.idx);\n }\n return { values, indices };\n}\nfunction stringWeightedDistances(str1, str2) {\n const a = str1.replace(/\\s/g, '');\n const b = str2.replace(/\\s/g, '');\n let weight = 0;\n let lastIndex = -1;\n for (let i = 0; i < a.length; i++) {\n const idx = b.indexOf(a[i], lastIndex + 1);\n if (idx === -1) {\n continue;\n }\n lastIndex = idx;\n weight += (100 - (lastIndex * 100 / 10000) * 100);\n }\n return weight;\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { ColDefUtil } from './components/colDefUtil.mjs';\nimport { ComponentUtil } from './components/componentUtil.mjs';\nimport { Autowired, Bean, PostConstruct } from './context/context.mjs';\nimport { ModuleNames } from './modules/moduleNames.mjs';\nimport { ModuleRegistry } from './modules/moduleRegistry.mjs';\nimport { PropertyKeys } from './propertyKeys.mjs';\nimport { doOnce } from './utils/function.mjs';\nimport { fuzzyCheckStrings } from './utils/fuzzyMatch.mjs';\nimport { iterateObject } from './utils/object.mjs';\nexport function logDeprecation(version, oldProp, newProp, message) {\n const newPropMsg = newProp ? `Please use '${newProp}' instead. ` : '';\n doOnce(() => console.warn(`AG Grid: since v${version}, '${oldProp}' is deprecated. ${newPropMsg}${message !== null && message !== void 0 ? message : ''}`), `Deprecated_${oldProp}`);\n}\n// Vue adds these properties to all objects, so we ignore them when checking for invalid properties\nconst VUE_FRAMEWORK_PROPS = ['__ob__', '__v_skip', '__metadata__'];\nlet GridOptionsValidator = class GridOptionsValidator {\n constructor() {\n this.deprecatedProperties = {\n rememberGroupStateWhenNewData: { version: '24', message: 'Now that transaction updates are possible and they keep group state, this feature is no longer needed.' },\n serverSideFilteringAlwaysResets: { version: '28.0', newProp: 'serverSideOnlyRefreshFilteredGroups', copyToNewProp: true, },\n serverSideSortingAlwaysResets: { version: '28.0', newProp: 'serverSideSortAllLevels', copyToNewProp: true, },\n suppressReactUi: { version: '28', message: 'The legacy React rendering engine is deprecated and will be removed in the next major version of the grid.' },\n processSecondaryColDef: { version: '28', newProp: 'processPivotResultColDef', copyToNewProp: true },\n processSecondaryColGroupDef: { version: '28', newProp: 'processPivotResultColGroupDef', copyToNewProp: true },\n getServerSideStoreParams: { version: '28', newProp: 'getServerSideGroupLevelParams', copyToNewProp: true },\n serverSideInfiniteScroll: { version: '29', message: 'Infinite Scrolling is now the default behaviour. This can be suppressed with `suppressServerSideInfiniteScroll`.' },\n enableChartToolPanelsButton: { version: '29', message: 'The Chart Tool Panels button is now enabled by default. To hide the Chart Tool Panels button and display the hamburger button instead, set suppressChartToolPanelsButton=true.' },\n functionsPassive: { version: '29.2' },\n onColumnRowGroupChangeRequest: { version: '29.2' },\n onColumnPivotChangeRequest: { version: '29.2' },\n onColumnValueChangeRequest: { version: '29.2' },\n onColumnAggFuncChangeRequest: { version: '29.2' },\n serverSideFilterAllLevels: { version: '30', message: 'All server-side group levels are now filtered by default. This can be toggled using `serverSideOnlyRefreshFilteredGroups`.' },\n suppressAggAtRootLevel: { version: '30', message: 'The root level aggregation is now suppressed by default. This can be toggled using `alwaysAggregateAtRootLevel`.' },\n excludeHiddenColumnsFromQuickFilter: { version: '30', message: 'Hidden columns are now excluded from the Quick Filter by default. This can be toggled using `includeHiddenColumnsInQuickFilter`.' },\n enterMovesDown: { version: '30', newProp: 'enterNavigatesVertically', copyToNewProp: true },\n enterMovesDownAfterEdit: { version: '30', newProp: 'enterNavigatesVerticallyAfterEdit', copyToNewProp: true },\n suppressParentsInRowNodes: { version: '30.2', message: 'Using suppressParentsInRowNodes is no longer recommended. To serialize nodes it is now recommended to instead remove the parent node reference before serialization.' },\n };\n }\n pickOneWarning(prop1, prop2) {\n console.warn(`AG Grid: ${prop1} and ${prop2} do not work with each other, you need to pick one.`);\n }\n init() {\n this.checkForDeprecated();\n this.checkForViolations();\n if (this.gridOptions.suppressPropertyNamesCheck !== true) {\n this.checkGridOptionsProperties();\n this.checkColumnDefProperties();\n }\n this.checkColumnDefViolations();\n if (this.gridOptionsService.is('groupSelectsChildren') && this.gridOptionsService.is('suppressParentsInRowNodes')) {\n console.warn(\"AG Grid: 'groupSelectsChildren' does not work with 'suppressParentsInRowNodes', this selection method needs the part in rowNode to work\");\n }\n if (this.gridOptionsService.is('groupSelectsChildren')) {\n if (this.gridOptionsService.get('rowSelection') !== 'multiple') {\n console.warn(\"AG Grid: rowSelection must be 'multiple' for groupSelectsChildren to make sense\");\n }\n }\n if (this.gridOptionsService.is('groupRemoveSingleChildren') && this.gridOptionsService.is('groupHideOpenParents')) {\n this.pickOneWarning('groupRemoveSingleChildren', 'groupHideOpenParents');\n }\n if (this.gridOptionsService.isRowModelType('serverSide')) {\n const msg = (prop, alt) => (`AG Grid: '${prop}' is not supported on the Server-Side Row Model.` + (alt ? ` Please use ${alt} instead.` : ''));\n if (this.gridOptionsService.exists('groupDefaultExpanded')) {\n console.warn(msg('groupDefaultExpanded', 'isServerSideGroupOpenByDefault callback'));\n }\n if (this.gridOptionsService.exists('groupIncludeFooter') && this.gridOptionsService.is('suppressServerSideInfiniteScroll')) {\n console.warn(msg('groupIncludeFooter'));\n }\n if (this.gridOptionsService.exists('groupIncludeTotalFooter')) {\n console.warn(msg('groupIncludeTotalFooter'));\n }\n }\n if (this.gridOptionsService.is('enableRangeSelection')) {\n ModuleRegistry.__assertRegistered(ModuleNames.RangeSelectionModule, 'enableRangeSelection', this.gridOptionsService.getGridId());\n }\n else if (this.gridOptionsService.is('enableRangeHandle') || this.gridOptionsService.is('enableFillHandle')) {\n console.warn(\"AG Grid: 'enableRangeHandle' or 'enableFillHandle' will not work unless 'enableRangeSelection' is set to true\");\n }\n const validateRegistered = (prop, module) => this.gridOptionsService.exists(prop) && ModuleRegistry.__assertRegistered(module, prop, this.gridOptionsService.getGridId());\n // Ensure the SideBar is registered which will then lead them to register Column / Filter Tool panels as required by their config.\n // It is possible to use the SideBar only with your own custom tool panels.\n validateRegistered('sideBar', ModuleNames.SideBarModule);\n validateRegistered('statusBar', ModuleNames.StatusBarModule);\n validateRegistered('enableCharts', ModuleNames.GridChartsModule);\n validateRegistered('getMainMenuItems', ModuleNames.MenuModule);\n validateRegistered('getContextMenuItems', ModuleNames.MenuModule);\n validateRegistered('allowContextMenuWithControlKey', ModuleNames.MenuModule);\n validateRegistered('enableAdvancedFilter', ModuleNames.AdvancedFilterModule);\n validateRegistered('treeData', ModuleNames.RowGroupingModule);\n validateRegistered('enableRangeSelection', ModuleNames.RangeSelectionModule);\n validateRegistered('masterDetail', ModuleNames.MasterDetailModule);\n }\n checkColumnDefProperties() {\n if (this.gridOptions.columnDefs == null) {\n return;\n }\n const validProperties = ColDefUtil.ALL_PROPERTIES;\n const validateColDef = (colDef, propertyName) => {\n const userProperties = Object.getOwnPropertyNames(colDef);\n this.checkProperties(userProperties, [...validProperties, ...VUE_FRAMEWORK_PROPS], validProperties, propertyName, 'https://www.ag-grid.com/javascript-data-grid/column-properties/');\n if (colDef.children) {\n colDef.children.forEach(child => validateColDef(child, 'columnDefs.children'));\n }\n };\n this.gridOptions.columnDefs.forEach(colDef => validateColDef(colDef, 'columnDefs'));\n if (this.gridOptions.defaultColDef) {\n validateColDef(this.gridOptions.defaultColDef, 'defaultColDef');\n }\n }\n checkColumnDefViolations() {\n var _a;\n const rowModel = (_a = this.gridOptionsService.get('rowModelType')) !== null && _a !== void 0 ? _a : 'clientSide';\n const unsupportedPropertiesMap = {\n infinite: ['headerCheckboxSelection', 'headerCheckboxSelectionFilteredOnly', 'headerCheckboxSelectionCurrentPageOnly'],\n viewport: ['headerCheckboxSelection', 'headerCheckboxSelectionFilteredOnly', 'headerCheckboxSelectionCurrentPageOnly'],\n serverSide: ['headerCheckboxSelectionFilteredOnly', 'headerCheckboxSelectionCurrentPageOnly'],\n clientSide: [],\n };\n const unsupportedProperties = unsupportedPropertiesMap[rowModel];\n if (!unsupportedProperties) {\n return;\n }\n const isMultiSelect = this.gridOptionsService.get('rowSelection') === 'multiple';\n const multiSelectDependencies = ['headerCheckboxSelection', 'headerCheckboxSelectionFilteredOnly', 'headerCheckboxSelectionCurrentPageOnly'];\n const validateColDef = (colDef) => {\n if (!isMultiSelect) {\n multiSelectDependencies.forEach(property => {\n if (property in colDef && !!colDef[property]) {\n console.warn(`AG Grid: Column property ${property} is not supported unless rowSelection='multiple'.`);\n }\n });\n }\n unsupportedProperties.forEach(property => {\n if (property in colDef && !!colDef[property]) {\n console.warn(`AG Grid: Column property ${property} is not supported with the row model type ${rowModel}.`);\n }\n });\n };\n if (this.gridOptions.columnDefs != null) {\n this.gridOptions.columnDefs.forEach(colDef => validateColDef(colDef));\n }\n if (this.gridOptions.autoGroupColumnDef != null) {\n validateColDef(this.gridOptions.autoGroupColumnDef);\n }\n if (this.gridOptions.defaultColDef != null) {\n validateColDef(this.gridOptions.defaultColDef);\n }\n }\n checkGridOptionsProperties() {\n const userProperties = Object.getOwnPropertyNames(this.gridOptions);\n const validProperties = [\n ...PropertyKeys.ALL_PROPERTIES,\n ...ComponentUtil.EVENT_CALLBACKS\n ];\n const validPropertiesAndExceptions = [...validProperties, 'api', 'columnApi', ...VUE_FRAMEWORK_PROPS, ...Object.keys(this.deprecatedProperties)];\n this.checkProperties(userProperties, validPropertiesAndExceptions, validProperties, 'gridOptions', 'https://www.ag-grid.com/javascript-data-grid/grid-options/');\n }\n checkProperties(userProperties, validPropertiesAndExceptions, validProperties, containerName, docsUrl) {\n const invalidProperties = fuzzyCheckStrings(userProperties, validPropertiesAndExceptions, validProperties);\n iterateObject(invalidProperties, (key, value) => {\n doOnce(() => console.warn(`AG Grid: invalid ${containerName} property '${key}' did you mean any of these: ${value.slice(0, 8).join(\", \")}`), 'invalidProperty' + containerName + key);\n });\n if (Object.keys(invalidProperties).length > 0) {\n doOnce(() => console.warn(`AG Grid: to see all the valid ${containerName} properties please check: ${docsUrl}`), 'invalidProperties' + containerName + docsUrl);\n }\n }\n checkForDeprecated() {\n // casting to generic object, so typescript compiles even though\n // we are looking for attributes that don't exist\n const options = this.gridOptions;\n Object.entries(this.deprecatedProperties).forEach(([oldProp, details]) => {\n var _a;\n const oldPropValue = options[oldProp];\n if (oldPropValue) {\n logDeprecation(details.version, oldProp, details.newProp, details.message);\n if (details.copyToNewProp && details.newProp && options[details.newProp] == null) {\n options[details.newProp] = (_a = details.newPropValue) !== null && _a !== void 0 ? _a : oldPropValue;\n }\n }\n });\n // Manual messages and deprecation behaviour that don't fit our standard approach above.\n if (options.serverSideStoreType) {\n console.warn('AG Grid: since v29.0, `serverSideStoreType` has been replaced by `suppressServerSideInfiniteScroll`. Set to false to use Partial Store, and true to use Full Store.');\n options.suppressServerSideInfiniteScroll = options.serverSideStoreType !== 'partial';\n }\n }\n checkForViolations() {\n if (this.gridOptionsService.is('treeData')) {\n this.treeDataViolations();\n }\n }\n treeDataViolations() {\n if (this.gridOptionsService.isRowModelType('clientSide')) {\n if (!this.gridOptionsService.exists('getDataPath')) {\n console.warn('AG Grid: property usingTreeData=true with rowModel=clientSide, but you did not ' +\n 'provide getDataPath function, please provide getDataPath function if using tree data.');\n }\n }\n if (this.gridOptionsService.isRowModelType('serverSide')) {\n if (!this.gridOptionsService.exists('isServerSideGroup')) {\n console.warn('AG Grid: property usingTreeData=true with rowModel=serverSide, but you did not ' +\n 'provide isServerSideGroup function, please provide isServerSideGroup function if using tree data.');\n }\n if (!this.gridOptionsService.exists('getServerSideGroupKey')) {\n console.warn('AG Grid: property usingTreeData=true with rowModel=serverSide, but you did not ' +\n 'provide getServerSideGroupKey function, please provide getServerSideGroupKey function if using tree data.');\n }\n }\n }\n};\n__decorate([\n Autowired('gridOptions')\n], GridOptionsValidator.prototype, \"gridOptions\", void 0);\n__decorate([\n Autowired('gridOptionsService')\n], GridOptionsValidator.prototype, \"gridOptionsService\", void 0);\n__decorate([\n PostConstruct\n], GridOptionsValidator.prototype, \"init\", null);\nGridOptionsValidator = __decorate([\n Bean('gridOptionsValidator')\n], GridOptionsValidator);\nexport { GridOptionsValidator };\nexport function matchesGroupDisplayType(toMatch, supplied) {\n const groupDisplayTypeValues = ['groupRows', 'multipleColumns', 'custom', 'singleColumn'];\n if (groupDisplayTypeValues.indexOf(supplied) < 0) {\n console.warn(`AG Grid: '${supplied}' is not a valid groupDisplayType value - possible values are: '${groupDisplayTypeValues.join(\"', '\")}'`);\n return false;\n }\n return supplied === toMatch;\n}\nexport function matchesTreeDataDisplayType(toMatch, supplied) {\n const treeDataDisplayTypeValues = ['auto', 'custom'];\n if (treeDataDisplayTypeValues.indexOf(supplied) < 0) {\n console.warn(`AG Grid: '${supplied}' is not a valid treeDataDisplayType value - possible values are: '${treeDataDisplayTypeValues.join(\"', '\")}'`);\n return false;\n }\n return supplied === toMatch;\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n};\nvar __rest = (this && this.__rest) || function (s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n t[p[i]] = s[p[i]];\n }\n return t;\n};\nimport { ColumnGroup } from '../entities/columnGroup.mjs';\nimport { Column } from '../entities/column.mjs';\nimport { Events } from '../events.mjs';\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { ProvidedColumnGroup } from '../entities/providedColumnGroup.mjs';\nimport { GroupInstanceIdCreator } from './groupInstanceIdCreator.mjs';\nimport { Autowired, Bean, Optional, PostConstruct, PreDestroy, Qualifier } from '../context/context.mjs';\nimport { GROUP_AUTO_COLUMN_ID } from './autoGroupColService.mjs';\nimport { areEqual, last, removeFromArray, moveInArray, includes, insertIntoArray, removeAllFromUnorderedArray, removeFromUnorderedArray } from '../utils/array.mjs';\nimport { missingOrEmpty, exists, missing, attrToBoolean, attrToNumber } from '../utils/generic.mjs';\nimport { camelCaseToHumanText } from '../utils/string.mjs';\nimport { convertToMap } from '../utils/map.mjs';\nimport { doOnce } from '../utils/function.mjs';\nimport { matchesGroupDisplayType, matchesTreeDataDisplayType } from '../gridOptionsValidator.mjs';\nlet ColumnModel = class ColumnModel extends BeanStub {\n constructor() {\n super(...arguments);\n // header row count, based on user provided columns\n this.primaryHeaderRowCount = 0;\n this.secondaryHeaderRowCount = 0;\n // header row count, either above, or based on pivoting if we are pivoting\n this.gridHeaderRowCount = 0;\n // leave level columns of the displayed trees\n this.displayedColumnsLeft = [];\n this.displayedColumnsRight = [];\n this.displayedColumnsCenter = [];\n // all three lists above combined\n this.displayedColumns = [];\n // for fast lookup, to see if a column or group is still displayed\n this.displayedColumnsAndGroupsMap = {};\n // all columns to be rendered\n this.viewportColumns = [];\n // A hash key to keep track of changes in viewport columns\n this.viewportColumnsHash = '';\n // same as viewportColumns, except we always include columns with headerAutoHeight\n this.headerViewportColumns = [];\n // all columns to be rendered in the centre\n this.viewportColumnsCenter = [];\n // same as viewportColumnsCenter, except we always include columns with headerAutoHeight\n this.headerViewportColumnsCenter = [];\n this.autoHeightActiveAtLeastOnce = false;\n this.rowGroupColumns = [];\n this.valueColumns = [];\n this.pivotColumns = [];\n this.ready = false;\n this.autoGroupsNeedBuilding = false;\n this.forceRecreateAutoGroups = false;\n this.pivotMode = false;\n this.bodyWidth = 0;\n this.leftWidth = 0;\n this.rightWidth = 0;\n this.bodyWidthDirty = true;\n // when we're waiting for cell data types to be inferred, we need to defer column resizing\n this.shouldQueueResizeOperations = false;\n this.resizeOperationQueue = [];\n }\n init() {\n this.suppressColumnVirtualisation = this.gridOptionsService.is('suppressColumnVirtualisation');\n const pivotMode = this.gridOptionsService.is('pivotMode');\n if (this.isPivotSettingAllowed(pivotMode)) {\n this.pivotMode = pivotMode;\n }\n this.addManagedPropertyListeners(['groupDisplayType', 'treeData'], () => this.buildAutoGroupColumns());\n this.addManagedPropertyListener('autoGroupColumnDef', () => this.onAutoGroupColumnDefChanged());\n this.addManagedPropertyListener('defaultColDef', (params) => this.onSharedColDefChanged(params.source));\n this.addManagedPropertyListener('columnTypes', (params) => this.onSharedColDefChanged(params.source));\n }\n buildAutoGroupColumns() {\n // Possible for update to be called before columns are present in which case there is nothing to do here.\n if (!this.columnDefs) {\n return;\n }\n this.autoGroupsNeedBuilding = true;\n this.forceRecreateAutoGroups = true;\n this.updateGridColumns();\n this.updateDisplayedColumns('gridOptionsChanged');\n }\n onAutoGroupColumnDefChanged() {\n if (this.groupAutoColumns) {\n this.autoGroupColService.updateAutoGroupColumns(this.groupAutoColumns);\n }\n }\n onSharedColDefChanged(source = 'api') {\n // if we aren't going to force, update the auto cols in place\n if (this.groupAutoColumns) {\n this.autoGroupColService.updateAutoGroupColumns(this.groupAutoColumns);\n }\n this.createColumnsFromColumnDefs(true, source);\n }\n setColumnDefs(columnDefs, source = 'api') {\n const colsPreviouslyExisted = !!this.columnDefs;\n this.columnDefs = columnDefs;\n this.createColumnsFromColumnDefs(colsPreviouslyExisted, source);\n }\n recreateColumnDefs(source = 'api') {\n this.onSharedColDefChanged(source);\n }\n destroyOldColumns(oldTree, newTree) {\n const oldObjectsById = {};\n if (!oldTree) {\n return;\n }\n // add in all old columns to be destroyed\n this.columnUtils.depthFirstOriginalTreeSearch(null, oldTree, child => {\n oldObjectsById[child.getInstanceId()] = child;\n });\n // however we don't destroy anything in the new tree. if destroying the grid, there is no new tree\n if (newTree) {\n this.columnUtils.depthFirstOriginalTreeSearch(null, newTree, child => {\n oldObjectsById[child.getInstanceId()] = null;\n });\n }\n // what's left can be destroyed\n const colsToDestroy = Object.values(oldObjectsById).filter(item => item != null);\n this.destroyBeans(colsToDestroy);\n }\n destroyColumns() {\n this.destroyOldColumns(this.primaryColumnTree);\n this.destroyOldColumns(this.secondaryBalancedTree);\n this.destroyOldColumns(this.groupAutoColsBalancedTree);\n }\n createColumnsFromColumnDefs(colsPreviouslyExisted, source = 'api') {\n // only need to dispatch before/after events if updating columns, never if setting columns for first time\n const dispatchEventsFunc = colsPreviouslyExisted ? this.compareColumnStatesAndDispatchEvents(source) : undefined;\n // always invalidate cache on changing columns, as the column id's for the new columns\n // could overlap with the old id's, so the cache would return old values for new columns.\n this.valueCache.expire();\n // NOTE ==================\n // we should be destroying the existing columns and groups if they exist, for example, the original column\n // group adds a listener to the columns, it should be also removing the listeners\n this.autoGroupsNeedBuilding = true;\n const oldPrimaryColumns = this.primaryColumns;\n const oldPrimaryTree = this.primaryColumnTree;\n const balancedTreeResult = this.columnFactory.createColumnTree(this.columnDefs, true, oldPrimaryTree);\n this.destroyOldColumns(this.primaryColumnTree, balancedTreeResult.columnTree);\n this.primaryColumnTree = balancedTreeResult.columnTree;\n this.primaryHeaderRowCount = balancedTreeResult.treeDept + 1;\n this.primaryColumns = this.getColumnsFromTree(this.primaryColumnTree);\n this.primaryColumnsMap = {};\n this.primaryColumns.forEach(col => this.primaryColumnsMap[col.getId()] = col);\n this.extractRowGroupColumns(source, oldPrimaryColumns);\n this.extractPivotColumns(source, oldPrimaryColumns);\n this.extractValueColumns(source, oldPrimaryColumns);\n this.ready = true;\n // if we are showing secondary columns, then no need to update grid columns\n // unless the auto column needs rebuilt, as it's the pivot service responsibility to change these\n // if we are no longer pivoting (ie and need to revert back to primary, otherwise\n // we shouldn't be touching the primary).\n const gridColsNotProcessed = this.gridColsArePrimary === undefined;\n const processGridCols = this.gridColsArePrimary || gridColsNotProcessed || this.autoGroupsNeedBuilding;\n if (processGridCols) {\n this.updateGridColumns();\n if (colsPreviouslyExisted && this.gridColsArePrimary && !this.gridOptionsService.is('maintainColumnOrder')) {\n this.orderGridColumnsLikePrimary();\n }\n this.updateDisplayedColumns(source);\n this.checkViewportColumns();\n }\n // this event is not used by AG Grid, but left here for backwards compatibility,\n // in case applications use it\n this.dispatchEverythingChanged(source);\n if (dispatchEventsFunc) {\n dispatchEventsFunc();\n }\n this.dispatchNewColumnsLoaded(source);\n }\n dispatchNewColumnsLoaded(source) {\n const newColumnsLoadedEvent = {\n type: Events.EVENT_NEW_COLUMNS_LOADED,\n source\n };\n this.eventService.dispatchEvent(newColumnsLoadedEvent);\n }\n // this event is legacy, no grid code listens to it. instead the grid listens to New Columns Loaded\n dispatchEverythingChanged(source = 'api') {\n const eventEverythingChanged = {\n type: Events.EVENT_COLUMN_EVERYTHING_CHANGED,\n source\n };\n this.eventService.dispatchEvent(eventEverythingChanged);\n }\n orderGridColumnsLikePrimary() {\n const primaryColumns = this.primaryColumns;\n if (!primaryColumns) {\n return;\n }\n const primaryColsOrdered = primaryColumns.filter(col => this.gridColumns.indexOf(col) >= 0);\n const otherCols = this.gridColumns.filter(col => primaryColsOrdered.indexOf(col) < 0);\n this.gridColumns = [...otherCols, ...primaryColsOrdered];\n this.gridColumns = this.placeLockedColumns(this.gridColumns);\n }\n getAllDisplayedAutoHeightCols() {\n return this.displayedAutoHeightCols;\n }\n setViewport() {\n if (this.gridOptionsService.is('enableRtl')) {\n this.viewportLeft = this.bodyWidth - this.scrollPosition - this.scrollWidth;\n this.viewportRight = this.bodyWidth - this.scrollPosition;\n }\n else {\n this.viewportLeft = this.scrollPosition;\n this.viewportRight = this.scrollWidth + this.scrollPosition;\n }\n }\n // used by clipboard service, to know what columns to paste into\n getDisplayedColumnsStartingAt(column) {\n let currentColumn = column;\n const columns = [];\n while (currentColumn != null) {\n columns.push(currentColumn);\n currentColumn = this.getDisplayedColAfter(currentColumn);\n }\n return columns;\n }\n // checks what columns are currently displayed due to column virtualisation. dispatches an event\n // if the list of columns has changed.\n // + setColumnWidth(), setViewportPosition(), setColumnDefs(), sizeColumnsToFit()\n checkViewportColumns(afterScroll = false) {\n // check displayCenterColumnTree exists first, as it won't exist when grid is initialising\n if (this.displayedColumnsCenter == null) {\n return;\n }\n const viewportColumnsChanged = this.extractViewport();\n if (!viewportColumnsChanged) {\n return;\n }\n const event = {\n type: Events.EVENT_VIRTUAL_COLUMNS_CHANGED,\n afterScroll,\n };\n this.eventService.dispatchEvent(event);\n }\n setViewportPosition(scrollWidth, scrollPosition, afterScroll = false) {\n if (scrollWidth !== this.scrollWidth || scrollPosition !== this.scrollPosition || this.bodyWidthDirty) {\n this.scrollWidth = scrollWidth;\n this.scrollPosition = scrollPosition;\n // we need to call setVirtualViewportLeftAndRight() at least once after the body width changes,\n // as the viewport can stay the same, but in RTL, if body width changes, we need to work out the\n // virtual columns again\n this.bodyWidthDirty = true;\n this.setViewport();\n if (this.ready) {\n this.checkViewportColumns(afterScroll);\n }\n }\n }\n isPivotMode() {\n return this.pivotMode;\n }\n isPivotSettingAllowed(pivot) {\n if (pivot && this.gridOptionsService.is('treeData')) {\n console.warn(\"AG Grid: Pivot mode not available in conjunction Tree Data i.e. 'gridOptions.treeData: true'\");\n return false;\n }\n return true;\n }\n setPivotMode(pivotMode, source = 'api') {\n if (pivotMode === this.pivotMode || !this.isPivotSettingAllowed(this.pivotMode)) {\n return;\n }\n this.pivotMode = pivotMode;\n // we need to update grid columns to cover the scenario where user has groupDisplayType = 'custom', as\n // this means we don't use auto group column UNLESS we are in pivot mode (it's mandatory in pivot mode),\n // so need to updateGridColumn() to check it autoGroupCol needs to be added / removed\n this.autoGroupsNeedBuilding = true;\n this.updateGridColumns();\n this.updateDisplayedColumns(source);\n const event = {\n type: Events.EVENT_COLUMN_PIVOT_MODE_CHANGED\n };\n this.eventService.dispatchEvent(event);\n }\n getSecondaryPivotColumn(pivotKeys, valueColKey) {\n if (missing(this.secondaryColumns)) {\n return null;\n }\n const valueColumnToFind = this.getPrimaryColumn(valueColKey);\n let foundColumn = null;\n this.secondaryColumns.forEach(column => {\n const thisPivotKeys = column.getColDef().pivotKeys;\n const pivotValueColumn = column.getColDef().pivotValueColumn;\n const pivotKeyMatches = areEqual(thisPivotKeys, pivotKeys);\n const pivotValueMatches = pivotValueColumn === valueColumnToFind;\n if (pivotKeyMatches && pivotValueMatches) {\n foundColumn = column;\n }\n });\n return foundColumn;\n }\n setBeans(loggerFactory) {\n this.logger = loggerFactory.create('columnModel');\n }\n setFirstRightAndLastLeftPinned(source) {\n let lastLeft;\n let firstRight;\n if (this.gridOptionsService.is('enableRtl')) {\n lastLeft = this.displayedColumnsLeft ? this.displayedColumnsLeft[0] : null;\n firstRight = this.displayedColumnsRight ? last(this.displayedColumnsRight) : null;\n }\n else {\n lastLeft = this.displayedColumnsLeft ? last(this.displayedColumnsLeft) : null;\n firstRight = this.displayedColumnsRight ? this.displayedColumnsRight[0] : null;\n }\n this.gridColumns.forEach((column) => {\n column.setLastLeftPinned(column === lastLeft, source);\n column.setFirstRightPinned(column === firstRight, source);\n });\n }\n autoSizeColumns(params) {\n if (this.shouldQueueResizeOperations) {\n this.resizeOperationQueue.push(() => this.autoSizeColumns(params));\n return;\n }\n const { columns, skipHeader, skipHeaderGroups, stopAtGroup, source = 'api' } = params;\n // because of column virtualisation, we can only do this function on columns that are\n // actually rendered, as non-rendered columns (outside the viewport and not rendered\n // due to column virtualisation) are not present. this can result in all rendered columns\n // getting narrowed, which in turn introduces more rendered columns on the RHS which\n // did not get autosized in the original run, leaving the visible grid with columns on\n // the LHS sized, but RHS no. so we keep looping through the visible columns until\n // no more cols are available (rendered) to be resized\n // we autosize after animation frames finish in case any cell renderers need to complete first. this can\n // happen eg if client code is calling api.autoSizeAllColumns() straight after grid is initialised, but grid\n // hasn't fully drawn out all the cells yet (due to cell renderers in animation frames).\n this.animationFrameService.flushAllFrames();\n // keep track of which cols we have resized in here\n const columnsAutosized = [];\n // initialise with anything except 0 so that while loop executes at least once\n let changesThisTimeAround = -1;\n const shouldSkipHeader = skipHeader != null ? skipHeader : this.gridOptionsService.is('skipHeaderOnAutoSize');\n const shouldSkipHeaderGroups = skipHeaderGroups != null ? skipHeaderGroups : shouldSkipHeader;\n while (changesThisTimeAround !== 0) {\n changesThisTimeAround = 0;\n this.actionOnGridColumns(columns, (column) => {\n // if already autosized, skip it\n if (columnsAutosized.indexOf(column) >= 0) {\n return false;\n }\n // get how wide this col should be\n const preferredWidth = this.autoWidthCalculator.getPreferredWidthForColumn(column, shouldSkipHeader);\n // preferredWidth = -1 if this col is not on the screen\n if (preferredWidth > 0) {\n const newWidth = this.normaliseColumnWidth(column, preferredWidth);\n column.setActualWidth(newWidth, source);\n columnsAutosized.push(column);\n changesThisTimeAround++;\n }\n return true;\n }, source);\n }\n if (!shouldSkipHeaderGroups) {\n this.autoSizeColumnGroupsByColumns(columns, source, stopAtGroup);\n }\n this.dispatchColumnResizedEvent(columnsAutosized, true, 'autosizeColumns');\n }\n dispatchColumnResizedEvent(columns, finished, source, flexColumns = null) {\n if (columns && columns.length) {\n const event = {\n type: Events.EVENT_COLUMN_RESIZED,\n columns: columns,\n column: columns.length === 1 ? columns[0] : null,\n flexColumns: flexColumns,\n finished: finished,\n source: source\n };\n this.eventService.dispatchEvent(event);\n }\n }\n dispatchColumnChangedEvent(type, columns, source) {\n const event = {\n type: type,\n columns: columns,\n column: (columns && columns.length == 1) ? columns[0] : null,\n source: source\n };\n this.eventService.dispatchEvent(event);\n }\n dispatchColumnMovedEvent(params) {\n const { movedColumns, source, toIndex, finished } = params;\n const event = {\n type: Events.EVENT_COLUMN_MOVED,\n columns: movedColumns,\n column: movedColumns && movedColumns.length === 1 ? movedColumns[0] : null,\n toIndex,\n finished,\n source\n };\n this.eventService.dispatchEvent(event);\n }\n dispatchColumnPinnedEvent(changedColumns, source) {\n if (!changedColumns.length) {\n return;\n }\n // if just one column, we use this, otherwise we don't include the col\n const column = changedColumns.length === 1 ? changedColumns[0] : null;\n // only include visible if it's common in all columns\n const pinned = this.getCommonValue(changedColumns, col => col.getPinned());\n const event = {\n type: Events.EVENT_COLUMN_PINNED,\n // mistake in typing, 'undefined' should be allowed, as 'null' means 'not pinned'\n pinned: pinned != null ? pinned : null,\n columns: changedColumns,\n column,\n source: source\n };\n this.eventService.dispatchEvent(event);\n }\n dispatchColumnVisibleEvent(changedColumns, source) {\n if (!changedColumns.length) {\n return;\n }\n // if just one column, we use this, otherwise we don't include the col\n const column = changedColumns.length === 1 ? changedColumns[0] : null;\n // only include visible if it's common in all columns\n const visible = this.getCommonValue(changedColumns, col => col.isVisible());\n const event = {\n type: Events.EVENT_COLUMN_VISIBLE,\n visible,\n columns: changedColumns,\n column,\n source: source\n };\n this.eventService.dispatchEvent(event);\n }\n autoSizeColumn(key, skipHeader, source = \"api\") {\n if (key) {\n this.autoSizeColumns({ columns: [key], skipHeader, skipHeaderGroups: true, source });\n }\n }\n autoSizeColumnGroupsByColumns(keys, source, stopAtGroup) {\n const columnGroups = new Set();\n const columns = this.getGridColumns(keys);\n columns.forEach(col => {\n let parent = col.getParent();\n while (parent && parent != stopAtGroup) {\n if (!parent.isPadding()) {\n columnGroups.add(parent);\n }\n parent = parent.getParent();\n }\n });\n let headerGroupCtrl;\n const resizedColumns = [];\n for (const columnGroup of columnGroups) {\n for (const headerContainerCtrl of this.ctrlsService.getHeaderRowContainerCtrls()) {\n headerGroupCtrl = headerContainerCtrl.getHeaderCtrlForColumn(columnGroup);\n if (headerGroupCtrl) {\n break;\n }\n }\n if (headerGroupCtrl) {\n headerGroupCtrl.resizeLeafColumnsToFit(source);\n }\n }\n return resizedColumns;\n }\n autoSizeAllColumns(skipHeader, source = \"api\") {\n if (this.shouldQueueResizeOperations) {\n this.resizeOperationQueue.push(() => this.autoSizeAllColumns(skipHeader, source));\n return;\n }\n const allDisplayedColumns = this.getAllDisplayedColumns();\n this.autoSizeColumns({ columns: allDisplayedColumns, skipHeader, source });\n }\n // Possible candidate for reuse (alot of recursive traversal duplication)\n getColumnsFromTree(rootColumns) {\n const result = [];\n const recursiveFindColumns = (childColumns) => {\n for (let i = 0; i < childColumns.length; i++) {\n const child = childColumns[i];\n if (child instanceof Column) {\n result.push(child);\n }\n else if (child instanceof ProvidedColumnGroup) {\n recursiveFindColumns(child.getChildren());\n }\n }\n };\n recursiveFindColumns(rootColumns);\n return result;\n }\n getAllDisplayedTrees() {\n if (this.displayedTreeLeft && this.displayedTreeRight && this.displayedTreeCentre) {\n return this.displayedTreeLeft\n .concat(this.displayedTreeCentre)\n .concat(this.displayedTreeRight);\n }\n return null;\n }\n // + columnSelectPanel\n getPrimaryColumnTree() {\n return this.primaryColumnTree;\n }\n // + gridPanel -> for resizing the body and setting top margin\n getHeaderRowCount() {\n return this.gridHeaderRowCount;\n }\n // + headerRenderer -> setting pinned body width\n getDisplayedTreeLeft() {\n return this.displayedTreeLeft;\n }\n // + headerRenderer -> setting pinned body width\n getDisplayedTreeRight() {\n return this.displayedTreeRight;\n }\n // + headerRenderer -> setting pinned body width\n getDisplayedTreeCentre() {\n return this.displayedTreeCentre;\n }\n // gridPanel -> ensureColumnVisible\n isColumnDisplayed(column) {\n return this.getAllDisplayedColumns().indexOf(column) >= 0;\n }\n // + csvCreator\n getAllDisplayedColumns() {\n return this.displayedColumns;\n }\n getViewportColumns() {\n return this.viewportColumns;\n }\n getDisplayedLeftColumnsForRow(rowNode) {\n if (!this.colSpanActive) {\n return this.displayedColumnsLeft;\n }\n return this.getDisplayedColumnsForRow(rowNode, this.displayedColumnsLeft);\n }\n getDisplayedRightColumnsForRow(rowNode) {\n if (!this.colSpanActive) {\n return this.displayedColumnsRight;\n }\n return this.getDisplayedColumnsForRow(rowNode, this.displayedColumnsRight);\n }\n isColSpanActive() {\n return this.colSpanActive;\n }\n getDisplayedColumnsForRow(rowNode, displayedColumns, filterCallback, emptySpaceBeforeColumn) {\n const result = [];\n let lastConsideredCol = null;\n for (let i = 0; i < displayedColumns.length; i++) {\n const col = displayedColumns[i];\n const maxAllowedColSpan = displayedColumns.length - i;\n const colSpan = Math.min(col.getColSpan(rowNode), maxAllowedColSpan);\n const columnsToCheckFilter = [col];\n if (colSpan > 1) {\n const colsToRemove = colSpan - 1;\n for (let j = 1; j <= colsToRemove; j++) {\n columnsToCheckFilter.push(displayedColumns[i + j]);\n }\n i += colsToRemove;\n }\n // see which cols we should take out for column virtualisation\n let filterPasses;\n if (filterCallback) {\n // if user provided a callback, means some columns may not be in the viewport.\n // the user will NOT provide a callback if we are talking about pinned areas,\n // as pinned areas have no horizontal scroll and do not virtualise the columns.\n // if lots of columns, that means column spanning, and we set filterPasses = true\n // if one or more of the columns spanned pass the filter.\n filterPasses = false;\n columnsToCheckFilter.forEach(colForFilter => {\n if (filterCallback(colForFilter)) {\n filterPasses = true;\n }\n });\n }\n else {\n filterPasses = true;\n }\n if (filterPasses) {\n if (result.length === 0 && lastConsideredCol) {\n const gapBeforeColumn = emptySpaceBeforeColumn ? emptySpaceBeforeColumn(col) : false;\n if (gapBeforeColumn) {\n result.push(lastConsideredCol);\n }\n }\n result.push(col);\n }\n lastConsideredCol = col;\n }\n return result;\n }\n // + rowRenderer\n // if we are not column spanning, this just returns back the virtual centre columns,\n // however if we are column spanning, then different rows can have different virtual\n // columns, so we have to work out the list for each individual row.\n getViewportCenterColumnsForRow(rowNode) {\n if (!this.colSpanActive) {\n return this.viewportColumnsCenter;\n }\n const emptySpaceBeforeColumn = (col) => {\n const left = col.getLeft();\n return exists(left) && left > this.viewportLeft;\n };\n // if doing column virtualisation, then we filter based on the viewport.\n const filterCallback = this.suppressColumnVirtualisation ? null : this.isColumnInRowViewport.bind(this);\n return this.getDisplayedColumnsForRow(rowNode, this.displayedColumnsCenter, filterCallback, emptySpaceBeforeColumn);\n }\n getAriaColumnIndex(col) {\n return this.getAllGridColumns().indexOf(col) + 1;\n }\n isColumnInHeaderViewport(col) {\n // for headers, we never filter out autoHeaderHeight columns, if calculating\n if (col.isAutoHeaderHeight()) {\n return true;\n }\n return this.isColumnInRowViewport(col);\n }\n isColumnInRowViewport(col) {\n // we never filter out autoHeight columns, as we need them in the DOM for calculating Auto Height\n if (col.isAutoHeight()) {\n return true;\n }\n const columnLeft = col.getLeft() || 0;\n const columnRight = columnLeft + col.getActualWidth();\n // adding 200 for buffer size, so some cols off viewport are rendered.\n // this helps horizontal scrolling so user rarely sees white space (unless\n // they scroll horizontally fast). however we are conservative, as the more\n // buffer the slower the vertical redraw speed\n const leftBounds = this.viewportLeft - 200;\n const rightBounds = this.viewportRight + 200;\n const columnToMuchLeft = columnLeft < leftBounds && columnRight < leftBounds;\n const columnToMuchRight = columnLeft > rightBounds && columnRight > rightBounds;\n return !columnToMuchLeft && !columnToMuchRight;\n }\n // used by:\n // + angularGrid -> setting pinned body width\n // note: this should be cached\n getDisplayedColumnsLeftWidth() {\n return this.getWidthOfColsInList(this.displayedColumnsLeft);\n }\n // note: this should be cached\n getDisplayedColumnsRightWidth() {\n return this.getWidthOfColsInList(this.displayedColumnsRight);\n }\n updatePrimaryColumnList(keys, masterList, actionIsAdd, columnCallback, eventType, source = \"api\") {\n if (!keys || missingOrEmpty(keys)) {\n return;\n }\n let atLeastOne = false;\n keys.forEach(key => {\n const columnToAdd = this.getPrimaryColumn(key);\n if (!columnToAdd) {\n return;\n }\n if (actionIsAdd) {\n if (masterList.indexOf(columnToAdd) >= 0) {\n return;\n }\n masterList.push(columnToAdd);\n }\n else {\n if (masterList.indexOf(columnToAdd) < 0) {\n return;\n }\n removeFromArray(masterList, columnToAdd);\n }\n columnCallback(columnToAdd);\n atLeastOne = true;\n });\n if (!atLeastOne) {\n return;\n }\n if (this.autoGroupsNeedBuilding) {\n this.updateGridColumns();\n }\n this.updateDisplayedColumns(source);\n const event = {\n type: eventType,\n columns: masterList,\n column: masterList.length === 1 ? masterList[0] : null,\n source: source\n };\n this.eventService.dispatchEvent(event);\n }\n setRowGroupColumns(colKeys, source = \"api\") {\n this.autoGroupsNeedBuilding = true;\n this.setPrimaryColumnList(colKeys, this.rowGroupColumns, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, true, this.setRowGroupActive.bind(this), source);\n }\n setRowGroupActive(active, column, source) {\n if (active === column.isRowGroupActive()) {\n return;\n }\n column.setRowGroupActive(active, source);\n if (active && !this.gridOptionsService.is('suppressRowGroupHidesColumns')) {\n this.setColumnVisible(column, false, source);\n }\n if (!active && !this.gridOptionsService.is('suppressMakeColumnVisibleAfterUnGroup')) {\n this.setColumnVisible(column, true, source);\n }\n }\n addRowGroupColumn(key, source = \"api\") {\n if (key) {\n this.addRowGroupColumns([key], source);\n }\n }\n addRowGroupColumns(keys, source = \"api\") {\n this.autoGroupsNeedBuilding = true;\n this.updatePrimaryColumnList(keys, this.rowGroupColumns, true, this.setRowGroupActive.bind(this, true), Events.EVENT_COLUMN_ROW_GROUP_CHANGED, source);\n }\n removeRowGroupColumns(keys, source = \"api\") {\n this.autoGroupsNeedBuilding = true;\n this.updatePrimaryColumnList(keys, this.rowGroupColumns, false, this.setRowGroupActive.bind(this, false), Events.EVENT_COLUMN_ROW_GROUP_CHANGED, source);\n }\n removeRowGroupColumn(key, source = \"api\") {\n if (key) {\n this.removeRowGroupColumns([key], source);\n }\n }\n addPivotColumns(keys, source = \"api\") {\n this.updatePrimaryColumnList(keys, this.pivotColumns, true, column => column.setPivotActive(true, source), Events.EVENT_COLUMN_PIVOT_CHANGED, source);\n }\n setPivotColumns(colKeys, source = \"api\") {\n this.setPrimaryColumnList(colKeys, this.pivotColumns, Events.EVENT_COLUMN_PIVOT_CHANGED, true, (added, column) => {\n column.setPivotActive(added, source);\n }, source);\n }\n addPivotColumn(key, source = \"api\") {\n this.addPivotColumns([key], source);\n }\n removePivotColumns(keys, source = \"api\") {\n this.updatePrimaryColumnList(keys, this.pivotColumns, false, column => column.setPivotActive(false, source), Events.EVENT_COLUMN_PIVOT_CHANGED, source);\n }\n removePivotColumn(key, source = \"api\") {\n this.removePivotColumns([key], source);\n }\n setPrimaryColumnList(colKeys, masterList, eventName, detectOrderChange, columnCallback, source) {\n const changes = new Map();\n // store all original cols and their index.\n masterList.forEach((col, idx) => changes.set(col, idx));\n masterList.length = 0;\n if (exists(colKeys)) {\n colKeys.forEach(key => {\n const column = this.getPrimaryColumn(key);\n if (column) {\n masterList.push(column);\n }\n });\n }\n masterList.forEach((col, idx) => {\n const oldIndex = changes.get(col);\n // if the column was not in the list, we add it as it's a change\n // idx is irrelevant now.\n if (oldIndex === undefined) {\n changes.set(col, 0);\n return;\n }\n if (detectOrderChange && oldIndex !== idx) {\n // if we're detecting order changes, and the indexes differ, we retain this as it's changed\n return;\n }\n // otherwise remove this col, as it's unchanged.\n changes.delete(col);\n });\n (this.primaryColumns || []).forEach(column => {\n const added = masterList.indexOf(column) >= 0;\n columnCallback(added, column);\n });\n if (this.autoGroupsNeedBuilding) {\n this.updateGridColumns();\n }\n this.updateDisplayedColumns(source);\n this.dispatchColumnChangedEvent(eventName, [...changes.keys()], source);\n }\n setValueColumns(colKeys, source = \"api\") {\n this.setPrimaryColumnList(colKeys, this.valueColumns, Events.EVENT_COLUMN_VALUE_CHANGED, false, this.setValueActive.bind(this), source);\n }\n setValueActive(active, column, source) {\n if (active === column.isValueActive()) {\n return;\n }\n column.setValueActive(active, source);\n if (active && !column.getAggFunc()) {\n const initialAggFunc = this.aggFuncService.getDefaultAggFunc(column);\n column.setAggFunc(initialAggFunc);\n }\n }\n addValueColumns(keys, source = \"api\") {\n this.updatePrimaryColumnList(keys, this.valueColumns, true, this.setValueActive.bind(this, true), Events.EVENT_COLUMN_VALUE_CHANGED, source);\n }\n addValueColumn(colKey, source = \"api\") {\n if (colKey) {\n this.addValueColumns([colKey], source);\n }\n }\n removeValueColumn(colKey, source = \"api\") {\n this.removeValueColumns([colKey], source);\n }\n removeValueColumns(keys, source = \"api\") {\n this.updatePrimaryColumnList(keys, this.valueColumns, false, this.setValueActive.bind(this, false), Events.EVENT_COLUMN_VALUE_CHANGED, source);\n }\n // returns the width we can set to this col, taking into consideration min and max widths\n normaliseColumnWidth(column, newWidth) {\n const minWidth = column.getMinWidth();\n if (exists(minWidth) && newWidth < minWidth) {\n newWidth = minWidth;\n }\n const maxWidth = column.getMaxWidth();\n if (exists(maxWidth) && column.isGreaterThanMax(newWidth)) {\n newWidth = maxWidth;\n }\n return newWidth;\n }\n getPrimaryOrGridColumn(key) {\n const column = this.getPrimaryColumn(key);\n return column || this.getGridColumn(key);\n }\n setColumnWidths(columnWidths, shiftKey, // @takeFromAdjacent - if user has 'shift' pressed, then pixels are taken from adjacent column\n finished, // @finished - ends up in the event, tells the user if more events are to come\n source = \"api\") {\n const sets = [];\n columnWidths.forEach(columnWidth => {\n const col = this.getPrimaryOrGridColumn(columnWidth.key);\n if (!col) {\n return;\n }\n sets.push({\n width: columnWidth.newWidth,\n ratios: [1],\n columns: [col]\n });\n // if user wants to do shift resize by default, then we invert the shift operation\n const defaultIsShift = this.gridOptionsService.get('colResizeDefault') === 'shift';\n if (defaultIsShift) {\n shiftKey = !shiftKey;\n }\n if (shiftKey) {\n const otherCol = this.getDisplayedColAfter(col);\n if (!otherCol) {\n return;\n }\n const widthDiff = col.getActualWidth() - columnWidth.newWidth;\n const otherColWidth = otherCol.getActualWidth() + widthDiff;\n sets.push({\n width: otherColWidth,\n ratios: [1],\n columns: [otherCol]\n });\n }\n });\n if (sets.length === 0) {\n return;\n }\n this.resizeColumnSets({\n resizeSets: sets,\n finished,\n source\n });\n }\n checkMinAndMaxWidthsForSet(columnResizeSet) {\n const { columns, width } = columnResizeSet;\n // every col has a min width, so sum them all up and see if we have enough room\n // for all the min widths\n let minWidthAccumulated = 0;\n let maxWidthAccumulated = 0;\n let maxWidthActive = true;\n columns.forEach(col => {\n const minWidth = col.getMinWidth();\n minWidthAccumulated += minWidth || 0;\n const maxWidth = col.getMaxWidth();\n if (exists(maxWidth) && maxWidth > 0) {\n maxWidthAccumulated += maxWidth;\n }\n else {\n // if at least one columns has no max width, it means the group of columns\n // then has no max width, as at least one column can take as much width as possible\n maxWidthActive = false;\n }\n });\n const minWidthPasses = width >= minWidthAccumulated;\n const maxWidthPasses = !maxWidthActive || (width <= maxWidthAccumulated);\n return minWidthPasses && maxWidthPasses;\n }\n // method takes sets of columns and resizes them. either all sets will be resized, or nothing\n // be resized. this is used for example when user tries to resize a group and holds shift key,\n // then both the current group (grows), and the adjacent group (shrinks), will get resized,\n // so that's two sets for this method.\n resizeColumnSets(params) {\n const { resizeSets, finished, source } = params;\n const passMinMaxCheck = !resizeSets || resizeSets.every(columnResizeSet => this.checkMinAndMaxWidthsForSet(columnResizeSet));\n if (!passMinMaxCheck) {\n // even though we are not going to resize beyond min/max size, we still need to dispatch event when finished\n if (finished) {\n const columns = resizeSets && resizeSets.length > 0 ? resizeSets[0].columns : null;\n this.dispatchColumnResizedEvent(columns, finished, source);\n }\n return; // don't resize!\n }\n const changedCols = [];\n const allResizedCols = [];\n resizeSets.forEach(set => {\n const { width, columns, ratios } = set;\n // keep track of pixels used, and last column gets the remaining,\n // to cater for rounding errors, and min width adjustments\n const newWidths = {};\n const finishedCols = {};\n columns.forEach(col => allResizedCols.push(col));\n // the loop below goes through each col. if a col exceeds it's min/max width,\n // it then gets set to its min/max width and the column is removed marked as 'finished'\n // and the calculation is done again leaving this column out. take for example columns\n // {A, width: 50, maxWidth: 100}\n // {B, width: 50}\n // {C, width: 50}\n // and then the set is set to width 600 - on the first pass the grid tries to set each column\n // to 200. it checks A and sees 200 > 100 and so sets the width to 100. col A is then marked\n // as 'finished' and the calculation is done again with the remaining cols B and C, which end up\n // splitting the remaining 500 pixels.\n let finishedColsGrew = true;\n let loopCount = 0;\n while (finishedColsGrew) {\n loopCount++;\n if (loopCount > 1000) {\n // this should never happen, but in the future, someone might introduce a bug here,\n // so we stop the browser from hanging and report bug properly\n console.error('AG Grid: infinite loop in resizeColumnSets');\n break;\n }\n finishedColsGrew = false;\n const subsetCols = [];\n let subsetRatioTotal = 0;\n let pixelsToDistribute = width;\n columns.forEach((col, index) => {\n const thisColFinished = finishedCols[col.getId()];\n if (thisColFinished) {\n pixelsToDistribute -= newWidths[col.getId()];\n }\n else {\n subsetCols.push(col);\n const ratioThisCol = ratios[index];\n subsetRatioTotal += ratioThisCol;\n }\n });\n // because we are not using all of the ratios (cols can be missing),\n // we scale the ratio. if all columns are included, then subsetRatioTotal=1,\n // and so the ratioScale will be 1.\n const ratioScale = 1 / subsetRatioTotal;\n subsetCols.forEach((col, index) => {\n const lastCol = index === (subsetCols.length - 1);\n let colNewWidth;\n if (lastCol) {\n colNewWidth = pixelsToDistribute;\n }\n else {\n colNewWidth = Math.round(ratios[index] * width * ratioScale);\n pixelsToDistribute -= colNewWidth;\n }\n const minWidth = col.getMinWidth();\n const maxWidth = col.getMaxWidth();\n if (exists(minWidth) && colNewWidth < minWidth) {\n colNewWidth = minWidth;\n finishedCols[col.getId()] = true;\n finishedColsGrew = true;\n }\n else if (exists(maxWidth) && maxWidth > 0 && colNewWidth > maxWidth) {\n colNewWidth = maxWidth;\n finishedCols[col.getId()] = true;\n finishedColsGrew = true;\n }\n newWidths[col.getId()] = colNewWidth;\n });\n }\n columns.forEach(col => {\n const newWidth = newWidths[col.getId()];\n const actualWidth = col.getActualWidth();\n if (actualWidth !== newWidth) {\n col.setActualWidth(newWidth, source);\n changedCols.push(col);\n }\n });\n });\n // if no cols changed, then no need to update more or send event.\n const atLeastOneColChanged = changedCols.length > 0;\n let flexedCols = [];\n if (atLeastOneColChanged) {\n flexedCols = this.refreshFlexedColumns({ resizingCols: allResizedCols, skipSetLeft: true });\n this.setLeftValues(source);\n this.updateBodyWidths();\n this.checkViewportColumns();\n }\n // check for change first, to avoid unnecessary firing of events\n // however we always dispatch 'finished' events. this is important\n // when groups are resized, as if the group is changing slowly,\n // eg 1 pixel at a time, then each change will dispatch change events\n // in all the columns in the group, but only one with get the pixel.\n const colsForEvent = allResizedCols.concat(flexedCols);\n if (atLeastOneColChanged || finished) {\n this.dispatchColumnResizedEvent(colsForEvent, finished, source, flexedCols);\n }\n }\n setColumnAggFunc(key, aggFunc, source = \"api\") {\n if (!key) {\n return;\n }\n const column = this.getPrimaryColumn(key);\n if (!column) {\n return;\n }\n column.setAggFunc(aggFunc);\n this.dispatchColumnChangedEvent(Events.EVENT_COLUMN_VALUE_CHANGED, [column], source);\n }\n moveRowGroupColumn(fromIndex, toIndex, source = \"api\") {\n const column = this.rowGroupColumns[fromIndex];\n const impactedColumns = this.rowGroupColumns.slice(fromIndex, toIndex);\n this.rowGroupColumns.splice(fromIndex, 1);\n this.rowGroupColumns.splice(toIndex, 0, column);\n const event = {\n type: Events.EVENT_COLUMN_ROW_GROUP_CHANGED,\n columns: impactedColumns,\n column: impactedColumns.length === 1 ? impactedColumns[0] : null,\n source: source\n };\n this.eventService.dispatchEvent(event);\n }\n moveColumns(columnsToMoveKeys, toIndex, source = \"api\", finished = true) {\n this.columnAnimationService.start();\n if (toIndex > this.gridColumns.length - columnsToMoveKeys.length) {\n console.warn('AG Grid: tried to insert columns in invalid location, toIndex = ' + toIndex);\n console.warn('AG Grid: remember that you should not count the moving columns when calculating the new index');\n return;\n }\n // we want to pull all the columns out first and put them into an ordered list\n const movedColumns = this.getGridColumns(columnsToMoveKeys);\n const failedRules = !this.doesMovePassRules(movedColumns, toIndex);\n if (failedRules) {\n return;\n }\n moveInArray(this.gridColumns, movedColumns, toIndex);\n this.updateDisplayedColumns(source);\n this.dispatchColumnMovedEvent({ movedColumns, source, toIndex, finished });\n this.columnAnimationService.finish();\n }\n doesMovePassRules(columnsToMove, toIndex) {\n // make a copy of what the grid columns would look like after the move\n const proposedColumnOrder = this.getProposedColumnOrder(columnsToMove, toIndex);\n return this.doesOrderPassRules(proposedColumnOrder);\n }\n doesOrderPassRules(gridOrder) {\n if (!this.doesMovePassMarryChildren(gridOrder)) {\n return false;\n }\n if (!this.doesMovePassLockedPositions(gridOrder)) {\n return false;\n }\n return true;\n }\n getProposedColumnOrder(columnsToMove, toIndex) {\n const proposedColumnOrder = this.gridColumns.slice();\n moveInArray(proposedColumnOrder, columnsToMove, toIndex);\n return proposedColumnOrder;\n }\n // returns the provided cols sorted in same order as they appear in grid columns. eg if grid columns\n // contains [a,b,c,d,e] and col passed is [e,a] then the passed cols are sorted into [a,e]\n sortColumnsLikeGridColumns(cols) {\n if (!cols || cols.length <= 1) {\n return;\n }\n const notAllColsInGridColumns = cols.filter(c => this.gridColumns.indexOf(c) < 0).length > 0;\n if (notAllColsInGridColumns) {\n return;\n }\n cols.sort((a, b) => {\n const indexA = this.gridColumns.indexOf(a);\n const indexB = this.gridColumns.indexOf(b);\n return indexA - indexB;\n });\n }\n doesMovePassLockedPositions(proposedColumnOrder) {\n // Placement is a number indicating 'left' 'center' or 'right' as 0 1 2\n let lastPlacement = 0;\n let rulePassed = true;\n const lockPositionToPlacement = (position) => {\n if (!position) { // false or undefined\n return 1;\n }\n if (position === true) {\n return 0;\n }\n return position === 'left' ? 0 : 2; // Otherwise 'right'\n };\n proposedColumnOrder.forEach(col => {\n const placement = lockPositionToPlacement(col.getColDef().lockPosition);\n if (placement < lastPlacement) { // If placement goes down, we're not in the correct order\n rulePassed = false;\n }\n lastPlacement = placement;\n });\n return rulePassed;\n }\n doesMovePassMarryChildren(allColumnsCopy) {\n let rulePassed = true;\n this.columnUtils.depthFirstOriginalTreeSearch(null, this.gridBalancedTree, child => {\n if (!(child instanceof ProvidedColumnGroup)) {\n return;\n }\n const columnGroup = child;\n const colGroupDef = columnGroup.getColGroupDef();\n const marryChildren = colGroupDef && colGroupDef.marryChildren;\n if (!marryChildren) {\n return;\n }\n const newIndexes = [];\n columnGroup.getLeafColumns().forEach(col => {\n const newColIndex = allColumnsCopy.indexOf(col);\n newIndexes.push(newColIndex);\n });\n const maxIndex = Math.max.apply(Math, newIndexes);\n const minIndex = Math.min.apply(Math, newIndexes);\n // spread is how far the first column in this group is away from the last column\n const spread = maxIndex - minIndex;\n const maxSpread = columnGroup.getLeafColumns().length - 1;\n // if the columns\n if (spread > maxSpread) {\n rulePassed = false;\n }\n // console.log(`maxIndex = ${maxIndex}, minIndex = ${minIndex}, spread = ${spread}, maxSpread = ${maxSpread}, fail = ${spread > (count-1)}`)\n // console.log(allColumnsCopy.map( col => col.getColDef().field).join(','));\n });\n return rulePassed;\n }\n moveColumn(key, toIndex, source = \"api\") {\n this.moveColumns([key], toIndex, source);\n }\n moveColumnByIndex(fromIndex, toIndex, source = \"api\") {\n const column = this.gridColumns[fromIndex];\n this.moveColumn(column, toIndex, source);\n }\n getColumnDefs() {\n if (!this.primaryColumns) {\n return;\n }\n const cols = this.primaryColumns.slice();\n if (this.gridColsArePrimary) {\n cols.sort((a, b) => this.gridColumns.indexOf(a) - this.gridColumns.indexOf(b));\n }\n else if (this.lastPrimaryOrder) {\n cols.sort((a, b) => this.lastPrimaryOrder.indexOf(a) - this.lastPrimaryOrder.indexOf(b));\n }\n return this.columnDefFactory.buildColumnDefs(cols, this.rowGroupColumns, this.pivotColumns);\n }\n // used by:\n // + angularGrid -> for setting body width\n // + rowController -> setting main row widths (when inserting and resizing)\n // need to cache this\n getBodyContainerWidth() {\n return this.bodyWidth;\n }\n getContainerWidth(pinned) {\n switch (pinned) {\n case 'left':\n return this.leftWidth;\n case 'right':\n return this.rightWidth;\n default:\n return this.bodyWidth;\n }\n }\n // after setColumnWidth or updateGroupsAndDisplayedColumns\n updateBodyWidths() {\n const newBodyWidth = this.getWidthOfColsInList(this.displayedColumnsCenter);\n const newLeftWidth = this.getWidthOfColsInList(this.displayedColumnsLeft);\n const newRightWidth = this.getWidthOfColsInList(this.displayedColumnsRight);\n // this is used by virtual col calculation, for RTL only, as a change to body width can impact displayed\n // columns, due to RTL inverting the y coordinates\n this.bodyWidthDirty = this.bodyWidth !== newBodyWidth;\n const atLeastOneChanged = this.bodyWidth !== newBodyWidth || this.leftWidth !== newLeftWidth || this.rightWidth !== newRightWidth;\n if (atLeastOneChanged) {\n this.bodyWidth = newBodyWidth;\n this.leftWidth = newLeftWidth;\n this.rightWidth = newRightWidth;\n // when this fires, it is picked up by the gridPanel, which ends up in\n // gridPanel calling setWidthAndScrollPosition(), which in turn calls setViewportPosition()\n const event = {\n type: Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED,\n };\n this.eventService.dispatchEvent(event);\n }\n }\n // + rowController\n getValueColumns() {\n return this.valueColumns ? this.valueColumns : [];\n }\n // + rowController\n getPivotColumns() {\n return this.pivotColumns ? this.pivotColumns : [];\n }\n // + clientSideRowModel\n isPivotActive() {\n return this.pivotColumns && this.pivotColumns.length > 0 && this.pivotMode;\n }\n // + toolPanel\n getRowGroupColumns() {\n return this.rowGroupColumns ? this.rowGroupColumns : [];\n }\n // + rowController -> while inserting rows\n getDisplayedCenterColumns() {\n return this.displayedColumnsCenter;\n }\n // + rowController -> while inserting rows\n getDisplayedLeftColumns() {\n return this.displayedColumnsLeft;\n }\n getDisplayedRightColumns() {\n return this.displayedColumnsRight;\n }\n getDisplayedColumns(type) {\n switch (type) {\n case 'left':\n return this.getDisplayedLeftColumns();\n case 'right':\n return this.getDisplayedRightColumns();\n default:\n return this.getDisplayedCenterColumns();\n }\n }\n // used by:\n // + clientSideRowController -> sorting, building quick filter text\n // + headerRenderer -> sorting (clearing icon)\n getAllPrimaryColumns() {\n return this.primaryColumns ? this.primaryColumns.slice() : null;\n }\n getSecondaryColumns() {\n return this.secondaryColumns ? this.secondaryColumns.slice() : null;\n }\n getAllColumnsForQuickFilter() {\n return this.columnsForQuickFilter;\n }\n // + moveColumnController\n getAllGridColumns() {\n return this.gridColumns;\n }\n isEmpty() {\n return missingOrEmpty(this.gridColumns);\n }\n isRowGroupEmpty() {\n return missingOrEmpty(this.rowGroupColumns);\n }\n setColumnVisible(key, visible, source = \"api\") {\n this.setColumnsVisible([key], visible, source);\n }\n setColumnsVisible(keys, visible = false, source = \"api\") {\n this.applyColumnState({\n state: keys.map(key => ({\n colId: typeof key === 'string' ? key : key.getColId(),\n hide: !visible,\n })),\n }, source);\n }\n setColumnPinned(key, pinned, source = \"api\") {\n if (key) {\n this.setColumnsPinned([key], pinned, source);\n }\n }\n setColumnsPinned(keys, pinned, source = \"api\") {\n if (this.gridOptionsService.isDomLayout('print')) {\n console.warn(`AG Grid: Changing the column pinning status is not allowed with domLayout='print'`);\n return;\n }\n this.columnAnimationService.start();\n let actualPinned;\n if (pinned === true || pinned === 'left') {\n actualPinned = 'left';\n }\n else if (pinned === 'right') {\n actualPinned = 'right';\n }\n else {\n actualPinned = null;\n }\n this.actionOnGridColumns(keys, (col) => {\n if (col.getPinned() !== actualPinned) {\n col.setPinned(actualPinned);\n return true;\n }\n return false;\n }, source, () => {\n const event = {\n type: Events.EVENT_COLUMN_PINNED,\n pinned: actualPinned,\n column: null,\n columns: null,\n source: source\n };\n return event;\n });\n this.columnAnimationService.finish();\n }\n // does an action on a set of columns. provides common functionality for looking up the\n // columns based on key, getting a list of effected columns, and then updated the event\n // with either one column (if it was just one col) or a list of columns\n // used by: autoResize, setVisible, setPinned\n actionOnGridColumns(// the column keys this action will be on\n keys, \n // the action to do - if this returns false, the column was skipped\n // and won't be included in the event\n action, \n // should return back a column event of the right type\n source, createEvent) {\n if (missingOrEmpty(keys)) {\n return;\n }\n const updatedColumns = [];\n keys.forEach((key) => {\n const column = this.getGridColumn(key);\n if (!column) {\n return;\n }\n // need to check for false with type (ie !== instead of !=)\n // as not returning anything (undefined) would also be false\n const resultOfAction = action(column);\n if (resultOfAction !== false) {\n updatedColumns.push(column);\n }\n });\n if (!updatedColumns.length) {\n return;\n }\n this.updateDisplayedColumns(source);\n if (exists(createEvent) && createEvent) {\n const event = createEvent();\n event.columns = updatedColumns;\n event.column = updatedColumns.length === 1 ? updatedColumns[0] : null;\n this.eventService.dispatchEvent(event);\n }\n }\n getDisplayedColBefore(col) {\n const allDisplayedColumns = this.getAllDisplayedColumns();\n const oldIndex = allDisplayedColumns.indexOf(col);\n if (oldIndex > 0) {\n return allDisplayedColumns[oldIndex - 1];\n }\n return null;\n }\n // used by:\n // + rowRenderer -> for navigation\n getDisplayedColAfter(col) {\n const allDisplayedColumns = this.getAllDisplayedColumns();\n const oldIndex = allDisplayedColumns.indexOf(col);\n if (oldIndex < (allDisplayedColumns.length - 1)) {\n return allDisplayedColumns[oldIndex + 1];\n }\n return null;\n }\n getDisplayedGroupAfter(columnGroup) {\n return this.getDisplayedGroupAtDirection(columnGroup, 'After');\n }\n getDisplayedGroupBefore(columnGroup) {\n return this.getDisplayedGroupAtDirection(columnGroup, 'Before');\n }\n getDisplayedGroupAtDirection(columnGroup, direction) {\n // pick the last displayed column in this group\n const requiredLevel = columnGroup.getProvidedColumnGroup().getLevel() + columnGroup.getPaddingLevel();\n const colGroupLeafColumns = columnGroup.getDisplayedLeafColumns();\n const col = direction === 'After' ? last(colGroupLeafColumns) : colGroupLeafColumns[0];\n const getDisplayColMethod = `getDisplayedCol${direction}`;\n while (true) {\n // keep moving to the next col, until we get to another group\n const column = this[getDisplayColMethod](col);\n if (!column) {\n return null;\n }\n const groupPointer = this.getColumnGroupAtLevel(column, requiredLevel);\n if (groupPointer !== columnGroup) {\n return groupPointer;\n }\n }\n }\n getColumnGroupAtLevel(column, level) {\n // get group at same level as the one we are looking for\n let groupPointer = column.getParent();\n let originalGroupLevel;\n let groupPointerLevel;\n while (true) {\n const groupPointerProvidedColumnGroup = groupPointer.getProvidedColumnGroup();\n originalGroupLevel = groupPointerProvidedColumnGroup.getLevel();\n groupPointerLevel = groupPointer.getPaddingLevel();\n if (originalGroupLevel + groupPointerLevel <= level) {\n break;\n }\n groupPointer = groupPointer.getParent();\n }\n return groupPointer;\n }\n isPinningLeft() {\n return this.displayedColumnsLeft.length > 0;\n }\n isPinningRight() {\n return this.displayedColumnsRight.length > 0;\n }\n getPrimaryAndSecondaryAndAutoColumns() {\n return [].concat(...[\n this.primaryColumns || [],\n this.groupAutoColumns || [],\n this.secondaryColumns || [],\n ]);\n }\n createStateItemFromColumn(column) {\n const rowGroupIndex = column.isRowGroupActive() ? this.rowGroupColumns.indexOf(column) : null;\n const pivotIndex = column.isPivotActive() ? this.pivotColumns.indexOf(column) : null;\n const aggFunc = column.isValueActive() ? column.getAggFunc() : null;\n const sort = column.getSort() != null ? column.getSort() : null;\n const sortIndex = column.getSortIndex() != null ? column.getSortIndex() : null;\n const flex = column.getFlex() != null && column.getFlex() > 0 ? column.getFlex() : null;\n const res = {\n colId: column.getColId(),\n width: column.getActualWidth(),\n hide: !column.isVisible(),\n pinned: column.getPinned(),\n sort,\n sortIndex,\n aggFunc,\n rowGroup: column.isRowGroupActive(),\n rowGroupIndex,\n pivot: column.isPivotActive(),\n pivotIndex: pivotIndex,\n flex\n };\n return res;\n }\n getColumnState() {\n if (missing(this.primaryColumns) || !this.isAlive()) {\n return [];\n }\n const colsForState = this.getPrimaryAndSecondaryAndAutoColumns();\n const res = colsForState.map(this.createStateItemFromColumn.bind(this));\n this.orderColumnStateList(res);\n return res;\n }\n orderColumnStateList(columnStateList) {\n // for fast looking, store the index of each column\n const colIdToGridIndexMap = convertToMap(this.gridColumns.map((col, index) => [col.getColId(), index]));\n columnStateList.sort((itemA, itemB) => {\n const posA = colIdToGridIndexMap.has(itemA.colId) ? colIdToGridIndexMap.get(itemA.colId) : -1;\n const posB = colIdToGridIndexMap.has(itemB.colId) ? colIdToGridIndexMap.get(itemB.colId) : -1;\n return posA - posB;\n });\n }\n resetColumnState(source = \"api\") {\n // NOTE = there is one bug here that no customer has noticed - if a column has colDef.lockPosition,\n // this is ignored below when ordering the cols. to work, we should always put lockPosition cols first.\n // As a work around, developers should just put lockPosition columns first in their colDef list.\n // we can't use 'allColumns' as the order might of messed up, so get the primary ordered list\n const primaryColumns = this.getColumnsFromTree(this.primaryColumnTree);\n const columnStates = [];\n // we start at 1000, so if user has mix of rowGroup and group specified, it will work with both.\n // eg IF user has ColA.rowGroupIndex=0, ColB.rowGroupIndex=1, ColC.rowGroup=true,\n // THEN result will be ColA.rowGroupIndex=0, ColB.rowGroupIndex=1, ColC.rowGroup=1000\n let letRowGroupIndex = 1000;\n let letPivotIndex = 1000;\n let colsToProcess = [];\n if (this.groupAutoColumns) {\n colsToProcess = colsToProcess.concat(this.groupAutoColumns);\n }\n if (primaryColumns) {\n colsToProcess = colsToProcess.concat(primaryColumns);\n }\n colsToProcess.forEach(column => {\n const stateItem = this.getColumnStateFromColDef(column);\n if (missing(stateItem.rowGroupIndex) && stateItem.rowGroup) {\n stateItem.rowGroupIndex = letRowGroupIndex++;\n }\n if (missing(stateItem.pivotIndex) && stateItem.pivot) {\n stateItem.pivotIndex = letPivotIndex++;\n }\n columnStates.push(stateItem);\n });\n this.applyColumnState({ state: columnStates, applyOrder: true }, source);\n }\n getColumnStateFromColDef(column) {\n const getValueOrNull = (a, b) => a != null ? a : b != null ? b : null;\n const colDef = column.getColDef();\n const sort = getValueOrNull(colDef.sort, colDef.initialSort);\n const sortIndex = getValueOrNull(colDef.sortIndex, colDef.initialSortIndex);\n const hide = getValueOrNull(colDef.hide, colDef.initialHide);\n const pinned = getValueOrNull(colDef.pinned, colDef.initialPinned);\n const width = getValueOrNull(colDef.width, colDef.initialWidth);\n const flex = getValueOrNull(colDef.flex, colDef.initialFlex);\n let rowGroupIndex = getValueOrNull(colDef.rowGroupIndex, colDef.initialRowGroupIndex);\n let rowGroup = getValueOrNull(colDef.rowGroup, colDef.initialRowGroup);\n if (rowGroupIndex == null && (rowGroup == null || rowGroup == false)) {\n rowGroupIndex = null;\n rowGroup = null;\n }\n let pivotIndex = getValueOrNull(colDef.pivotIndex, colDef.initialPivotIndex);\n let pivot = getValueOrNull(colDef.pivot, colDef.initialPivot);\n if (pivotIndex == null && (pivot == null || pivot == false)) {\n pivotIndex = null;\n pivot = null;\n }\n const aggFunc = getValueOrNull(colDef.aggFunc, colDef.initialAggFunc);\n return {\n colId: column.getColId(),\n sort,\n sortIndex,\n hide,\n pinned,\n width,\n flex,\n rowGroup,\n rowGroupIndex,\n pivot,\n pivotIndex,\n aggFunc,\n };\n }\n applyColumnState(params, source) {\n if (missingOrEmpty(this.primaryColumns)) {\n return false;\n }\n if (params && params.state && !params.state.forEach) {\n console.warn('AG Grid: applyColumnState() - the state attribute should be an array, however an array was not found. Please provide an array of items (one for each col you want to change) for state.');\n return false;\n }\n const applyStates = (states, existingColumns, getById) => {\n const dispatchEventsFunc = this.compareColumnStatesAndDispatchEvents(source);\n this.autoGroupsNeedBuilding = true;\n // at the end below, this list will have all columns we got no state for\n const columnsWithNoState = existingColumns.slice();\n const rowGroupIndexes = {};\n const pivotIndexes = {};\n const autoGroupColumnStates = [];\n // If pivoting is modified, these are the states we try to reapply after\n // the secondary columns are re-generated\n const unmatchedAndAutoStates = [];\n let unmatchedCount = 0;\n const previousRowGroupCols = this.rowGroupColumns.slice();\n const previousPivotCols = this.pivotColumns.slice();\n states.forEach((state) => {\n const colId = state.colId || '';\n // auto group columns are re-created so deferring syncing with ColumnState\n const isAutoGroupColumn = colId.startsWith(GROUP_AUTO_COLUMN_ID);\n if (isAutoGroupColumn) {\n autoGroupColumnStates.push(state);\n unmatchedAndAutoStates.push(state);\n return;\n }\n const column = getById(colId);\n if (!column) {\n unmatchedAndAutoStates.push(state);\n unmatchedCount += 1;\n }\n else {\n this.syncColumnWithStateItem(column, state, params.defaultState, rowGroupIndexes, pivotIndexes, false, source);\n removeFromArray(columnsWithNoState, column);\n }\n });\n // anything left over, we got no data for, so add in the column as non-value, non-rowGroup and hidden\n const applyDefaultsFunc = (col) => this.syncColumnWithStateItem(col, null, params.defaultState, rowGroupIndexes, pivotIndexes, false, source);\n columnsWithNoState.forEach(applyDefaultsFunc);\n // sort the lists according to the indexes that were provided\n const comparator = (indexes, oldList, colA, colB) => {\n const indexA = indexes[colA.getId()];\n const indexB = indexes[colB.getId()];\n const aHasIndex = indexA != null;\n const bHasIndex = indexB != null;\n if (aHasIndex && bHasIndex) {\n // both a and b are new cols with index, so sort on index\n return indexA - indexB;\n }\n if (aHasIndex) {\n // a has an index, so it should be before a\n return -1;\n }\n if (bHasIndex) {\n // b has an index, so it should be before a\n return 1;\n }\n const oldIndexA = oldList.indexOf(colA);\n const oldIndexB = oldList.indexOf(colB);\n const aHasOldIndex = oldIndexA >= 0;\n const bHasOldIndex = oldIndexB >= 0;\n if (aHasOldIndex && bHasOldIndex) {\n // both a and b are old cols, so sort based on last order\n return oldIndexA - oldIndexB;\n }\n if (aHasOldIndex) {\n // a is old, b is new, so b is first\n return -1;\n }\n // this bit does matter, means both are new cols\n // but without index or that b is old and a is new\n return 1;\n };\n this.rowGroupColumns.sort(comparator.bind(this, rowGroupIndexes, previousRowGroupCols));\n this.pivotColumns.sort(comparator.bind(this, pivotIndexes, previousPivotCols));\n this.updateGridColumns();\n // sync newly created auto group columns with ColumnState\n const autoGroupColsCopy = this.groupAutoColumns ? this.groupAutoColumns.slice() : [];\n autoGroupColumnStates.forEach(stateItem => {\n const autoCol = this.getAutoColumn(stateItem.colId);\n removeFromArray(autoGroupColsCopy, autoCol);\n this.syncColumnWithStateItem(autoCol, stateItem, params.defaultState, null, null, true, source);\n });\n // autogroup cols with nothing else, apply the default\n autoGroupColsCopy.forEach(applyDefaultsFunc);\n this.applyOrderAfterApplyState(params);\n this.updateDisplayedColumns(source);\n this.dispatchEverythingChanged(source);\n dispatchEventsFunc(); // Will trigger secondary column changes if pivoting modified\n return { unmatchedAndAutoStates, unmatchedCount };\n };\n this.columnAnimationService.start();\n let { unmatchedAndAutoStates, unmatchedCount, } = applyStates(params.state || [], this.primaryColumns || [], (id) => this.getPrimaryColumn(id));\n // If there are still states left over, see if we can apply them to newly generated\n // secondary or auto columns. Also if defaults exist, ensure they are applied to secondary cols\n if (unmatchedAndAutoStates.length > 0 || exists(params.defaultState)) {\n unmatchedCount = applyStates(unmatchedAndAutoStates, this.secondaryColumns || [], (id) => this.getSecondaryColumn(id)).unmatchedCount;\n }\n this.columnAnimationService.finish();\n return unmatchedCount === 0; // Successful if no states unaccounted for\n }\n applyOrderAfterApplyState(params) {\n if (!params.applyOrder || !params.state) {\n return;\n }\n let newOrder = [];\n const processedColIds = {};\n params.state.forEach(item => {\n if (!item.colId || processedColIds[item.colId]) {\n return;\n }\n const col = this.gridColumnsMap[item.colId];\n if (col) {\n newOrder.push(col);\n processedColIds[item.colId] = true;\n }\n });\n // add in all other columns\n let autoGroupInsertIndex = 0;\n this.gridColumns.forEach(col => {\n const colId = col.getColId();\n const alreadyProcessed = processedColIds[colId] != null;\n if (alreadyProcessed) {\n return;\n }\n const isAutoGroupCol = colId.startsWith(GROUP_AUTO_COLUMN_ID);\n if (isAutoGroupCol) {\n // auto group columns, if missing from state list, are added to the start.\n // it's common to have autoGroup missing, as grouping could be on by default\n // on a column, but the user could of since removed the grouping via the UI.\n // if we don't inc the insert index, autoGroups will be inserted in reverse order\n insertIntoArray(newOrder, col, autoGroupInsertIndex++);\n }\n else {\n // normal columns, if missing from state list, are added at the end\n newOrder.push(col);\n }\n });\n // this is already done in updateGridColumns, however we changed the order above (to match the order of the state\n // columns) so we need to do it again. we could of put logic into the order above to take into account fixed\n // columns, however if we did then we would have logic for updating fixed columns twice. reusing the logic here\n // is less sexy for the code here, but it keeps consistency.\n newOrder = this.placeLockedColumns(newOrder);\n if (!this.doesMovePassMarryChildren(newOrder)) {\n console.warn('AG Grid: Applying column order broke a group where columns should be married together. Applying new order has been discarded.');\n return;\n }\n this.gridColumns = newOrder;\n }\n compareColumnStatesAndDispatchEvents(source) {\n const startState = {\n rowGroupColumns: this.rowGroupColumns.slice(),\n pivotColumns: this.pivotColumns.slice(),\n valueColumns: this.valueColumns.slice()\n };\n const columnStateBefore = this.getColumnState();\n const columnStateBeforeMap = {};\n columnStateBefore.forEach(col => {\n columnStateBeforeMap[col.colId] = col;\n });\n return () => {\n const colsForState = this.getPrimaryAndSecondaryAndAutoColumns();\n // dispatches generic ColumnEvents where all columns are returned rather than what has changed\n const dispatchWhenListsDifferent = (eventType, colsBefore, colsAfter, idMapper) => {\n const beforeList = colsBefore.map(idMapper);\n const afterList = colsAfter.map(idMapper);\n const unchanged = areEqual(beforeList, afterList);\n if (unchanged) {\n return;\n }\n const changes = new Set(colsBefore);\n colsAfter.forEach(id => {\n // if the first list had it, delete it, as it's unchanged.\n if (!changes.delete(id)) {\n // if the second list has it, and first doesn't, add it.\n changes.add(id);\n }\n });\n const changesArr = [...changes];\n const event = {\n type: eventType,\n columns: changesArr,\n column: changesArr.length === 1 ? changesArr[0] : null,\n source: source\n };\n this.eventService.dispatchEvent(event);\n };\n // determines which columns have changed according to supplied predicate\n const getChangedColumns = (changedPredicate) => {\n const changedColumns = [];\n colsForState.forEach(column => {\n const colStateBefore = columnStateBeforeMap[column.getColId()];\n if (colStateBefore && changedPredicate(colStateBefore, column)) {\n changedColumns.push(column);\n }\n });\n return changedColumns;\n };\n const columnIdMapper = (c) => c.getColId();\n dispatchWhenListsDifferent(Events.EVENT_COLUMN_ROW_GROUP_CHANGED, startState.rowGroupColumns, this.rowGroupColumns, columnIdMapper);\n dispatchWhenListsDifferent(Events.EVENT_COLUMN_PIVOT_CHANGED, startState.pivotColumns, this.pivotColumns, columnIdMapper);\n const valueChangePredicate = (cs, c) => {\n const oldActive = cs.aggFunc != null;\n const activeChanged = oldActive != c.isValueActive();\n // we only check aggFunc if the agg is active\n const aggFuncChanged = oldActive && cs.aggFunc != c.getAggFunc();\n return activeChanged || aggFuncChanged;\n };\n const changedValues = getChangedColumns(valueChangePredicate);\n if (changedValues.length > 0) {\n this.dispatchColumnChangedEvent(Events.EVENT_COLUMN_VALUE_CHANGED, changedValues, source);\n }\n const resizeChangePredicate = (cs, c) => cs.width != c.getActualWidth();\n this.dispatchColumnResizedEvent(getChangedColumns(resizeChangePredicate), true, source);\n const pinnedChangePredicate = (cs, c) => cs.pinned != c.getPinned();\n this.dispatchColumnPinnedEvent(getChangedColumns(pinnedChangePredicate), source);\n const visibilityChangePredicate = (cs, c) => cs.hide == c.isVisible();\n this.dispatchColumnVisibleEvent(getChangedColumns(visibilityChangePredicate), source);\n const sortChangePredicate = (cs, c) => cs.sort != c.getSort() || cs.sortIndex != c.getSortIndex();\n if (getChangedColumns(sortChangePredicate).length > 0) {\n this.sortController.dispatchSortChangedEvents(source);\n }\n // special handling for moved column events\n this.normaliseColumnMovedEventForColumnState(columnStateBefore, source);\n };\n }\n getCommonValue(cols, valueGetter) {\n if (!cols || cols.length == 0) {\n return undefined;\n }\n // compare each value to the first value. if nothing differs, then value is common so return it.\n const firstValue = valueGetter(cols[0]);\n for (let i = 1; i < cols.length; i++) {\n if (firstValue !== valueGetter(cols[i])) {\n // values differ, no common value\n return undefined;\n }\n }\n return firstValue;\n }\n normaliseColumnMovedEventForColumnState(colStateBefore, source) {\n // we are only interested in columns that were both present and visible before and after\n const colStateAfter = this.getColumnState();\n const colStateAfterMapped = {};\n colStateAfter.forEach(s => colStateAfterMapped[s.colId] = s);\n // get id's of cols in both before and after lists\n const colsIntersectIds = {};\n colStateBefore.forEach(s => {\n if (colStateAfterMapped[s.colId]) {\n colsIntersectIds[s.colId] = true;\n }\n });\n // filter state lists, so we only have cols that were present before and after\n const beforeFiltered = colStateBefore.filter(c => colsIntersectIds[c.colId]);\n const afterFiltered = colStateAfter.filter(c => colsIntersectIds[c.colId]);\n // see if any cols are in a different location\n const movedColumns = [];\n afterFiltered.forEach((csAfter, index) => {\n const csBefore = beforeFiltered && beforeFiltered[index];\n if (csBefore && csBefore.colId !== csAfter.colId) {\n const gridCol = this.getGridColumn(csBefore.colId);\n if (gridCol) {\n movedColumns.push(gridCol);\n }\n }\n });\n if (!movedColumns.length) {\n return;\n }\n this.dispatchColumnMovedEvent({ movedColumns, source, finished: true });\n }\n syncColumnWithStateItem(column, stateItem, defaultState, rowGroupIndexes, pivotIndexes, autoCol, source) {\n if (!column) {\n return;\n }\n const getValue = (key1, key2) => {\n const obj = { value1: undefined, value2: undefined };\n let calculated = false;\n if (stateItem) {\n if (stateItem[key1] !== undefined) {\n obj.value1 = stateItem[key1];\n calculated = true;\n }\n if (exists(key2) && stateItem[key2] !== undefined) {\n obj.value2 = stateItem[key2];\n calculated = true;\n }\n }\n if (!calculated && defaultState) {\n if (defaultState[key1] !== undefined) {\n obj.value1 = defaultState[key1];\n }\n if (exists(key2) && defaultState[key2] !== undefined) {\n obj.value2 = defaultState[key2];\n }\n }\n return obj;\n };\n // following ensures we are left with boolean true or false, eg converts (null, undefined, 0) all to true\n const hide = getValue('hide').value1;\n if (hide !== undefined) {\n column.setVisible(!hide, source);\n }\n // sets pinned to 'left' or 'right'\n const pinned = getValue('pinned').value1;\n if (pinned !== undefined) {\n column.setPinned(pinned);\n }\n // if width provided and valid, use it, otherwise stick with the old width\n const minColWidth = this.columnUtils.calculateColMinWidth(column.getColDef());\n // flex\n const flex = getValue('flex').value1;\n if (flex !== undefined) {\n column.setFlex(flex);\n }\n // width - we only set width if column is not flexing\n const noFlexThisCol = column.getFlex() <= 0;\n if (noFlexThisCol) {\n // both null and undefined means we skip, as it's not possible to 'clear' width (a column must have a width)\n const width = getValue('width').value1;\n if (width != null) {\n if (minColWidth != null && width >= minColWidth) {\n column.setActualWidth(width, source);\n }\n }\n }\n const sort = getValue('sort').value1;\n if (sort !== undefined) {\n if (sort === 'desc' || sort === 'asc') {\n column.setSort(sort, source);\n }\n else {\n column.setSort(undefined, source);\n }\n }\n const sortIndex = getValue('sortIndex').value1;\n if (sortIndex !== undefined) {\n column.setSortIndex(sortIndex);\n }\n // we do not do aggFunc, rowGroup or pivot for auto cols or secondary cols\n if (autoCol || !column.isPrimary()) {\n return;\n }\n const aggFunc = getValue('aggFunc').value1;\n if (aggFunc !== undefined) {\n if (typeof aggFunc === 'string') {\n column.setAggFunc(aggFunc);\n if (!column.isValueActive()) {\n column.setValueActive(true, source);\n this.valueColumns.push(column);\n }\n }\n else {\n if (exists(aggFunc)) {\n console.warn('AG Grid: stateItem.aggFunc must be a string. if using your own aggregation ' +\n 'functions, register the functions first before using them in get/set state. This is because it is ' +\n 'intended for the column state to be stored and retrieved as simple JSON.');\n }\n // Note: we do not call column.setAggFunc(null), so that next time we aggregate\n // by this column (eg drag the column to the agg section int he toolpanel) it will\n // default to the last aggregation function.\n if (column.isValueActive()) {\n column.setValueActive(false, source);\n removeFromArray(this.valueColumns, column);\n }\n }\n }\n const { value1: rowGroup, value2: rowGroupIndex } = getValue('rowGroup', 'rowGroupIndex');\n if (rowGroup !== undefined || rowGroupIndex !== undefined) {\n if (typeof rowGroupIndex === 'number' || rowGroup) {\n if (!column.isRowGroupActive()) {\n column.setRowGroupActive(true, source);\n this.rowGroupColumns.push(column);\n }\n if (rowGroupIndexes && typeof rowGroupIndex === 'number') {\n rowGroupIndexes[column.getId()] = rowGroupIndex;\n }\n }\n else {\n if (column.isRowGroupActive()) {\n column.setRowGroupActive(false, source);\n removeFromArray(this.rowGroupColumns, column);\n }\n }\n }\n const { value1: pivot, value2: pivotIndex } = getValue('pivot', 'pivotIndex');\n if (pivot !== undefined || pivotIndex !== undefined) {\n if (typeof pivotIndex === 'number' || pivot) {\n if (!column.isPivotActive()) {\n column.setPivotActive(true, source);\n this.pivotColumns.push(column);\n }\n if (pivotIndexes && typeof pivotIndex === 'number') {\n pivotIndexes[column.getId()] = pivotIndex;\n }\n }\n else {\n if (column.isPivotActive()) {\n column.setPivotActive(false, source);\n removeFromArray(this.pivotColumns, column);\n }\n }\n }\n }\n getGridColumns(keys) {\n return this.getColumns(keys, this.getGridColumn.bind(this));\n }\n getColumns(keys, columnLookupCallback) {\n const foundColumns = [];\n if (keys) {\n keys.forEach((key) => {\n const column = columnLookupCallback(key);\n if (column) {\n foundColumns.push(column);\n }\n });\n }\n return foundColumns;\n }\n // used by growGroupPanel\n getColumnWithValidation(key) {\n if (key == null) {\n return null;\n }\n const column = this.getGridColumn(key);\n if (!column) {\n console.warn('AG Grid: could not find column ' + key);\n }\n return column;\n }\n getPrimaryColumn(key) {\n if (!this.primaryColumns) {\n return null;\n }\n return this.getColumn(key, this.primaryColumns, this.primaryColumnsMap);\n }\n getGridColumn(key) {\n return this.getColumn(key, this.gridColumns, this.gridColumnsMap);\n }\n lookupGridColumn(key) {\n return this.gridColumnsMap[key];\n }\n getSecondaryColumn(key) {\n if (!this.secondaryColumns) {\n return null;\n }\n return this.getColumn(key, this.secondaryColumns, this.secondaryColumnsMap);\n }\n getColumn(key, columnList, columnMap) {\n if (!key) {\n return null;\n }\n // most of the time this method gets called the key is a string, so we put this shortcut in\n // for performance reasons, to see if we can match for ID (it doesn't do auto columns, that's done below)\n if (typeof key == 'string' && columnMap[key]) {\n return columnMap[key];\n }\n for (let i = 0; i < columnList.length; i++) {\n if (this.columnsMatch(columnList[i], key)) {\n return columnList[i];\n }\n }\n return this.getAutoColumn(key);\n }\n getSourceColumnsForGroupColumn(groupCol) {\n const sourceColumnId = groupCol.getColDef().showRowGroup;\n if (!sourceColumnId) {\n return null;\n }\n if (sourceColumnId === true) {\n return this.rowGroupColumns.slice(0);\n }\n const column = this.getPrimaryColumn(sourceColumnId);\n return column ? [column] : null;\n }\n getAutoColumn(key) {\n if (!this.groupAutoColumns ||\n !exists(this.groupAutoColumns) ||\n missing(this.groupAutoColumns)) {\n return null;\n }\n return this.groupAutoColumns.find(groupCol => this.columnsMatch(groupCol, key)) || null;\n }\n columnsMatch(column, key) {\n const columnMatches = column === key;\n const colDefMatches = column.getColDef() === key;\n const idMatches = column.getColId() == key;\n return columnMatches || colDefMatches || idMatches;\n }\n getDisplayNameForColumn(column, location, includeAggFunc = false) {\n if (!column) {\n return null;\n }\n const headerName = this.getHeaderName(column.getColDef(), column, null, null, location);\n if (includeAggFunc) {\n return this.wrapHeaderNameWithAggFunc(column, headerName);\n }\n return headerName;\n }\n getDisplayNameForProvidedColumnGroup(columnGroup, providedColumnGroup, location) {\n const colGroupDef = providedColumnGroup ? providedColumnGroup.getColGroupDef() : null;\n if (colGroupDef) {\n return this.getHeaderName(colGroupDef, null, columnGroup, providedColumnGroup, location);\n }\n return null;\n }\n getDisplayNameForColumnGroup(columnGroup, location) {\n return this.getDisplayNameForProvidedColumnGroup(columnGroup, columnGroup.getProvidedColumnGroup(), location);\n }\n // location is where the column is going to appear, ie who is calling us\n getHeaderName(colDef, column, columnGroup, providedColumnGroup, location) {\n const headerValueGetter = colDef.headerValueGetter;\n if (headerValueGetter) {\n const params = {\n colDef: colDef,\n column: column,\n columnGroup: columnGroup,\n providedColumnGroup: providedColumnGroup,\n location: location,\n api: this.gridOptionsService.api,\n columnApi: this.gridOptionsService.columnApi,\n context: this.gridOptionsService.context\n };\n if (typeof headerValueGetter === 'function') {\n // valueGetter is a function, so just call it\n return headerValueGetter(params);\n }\n else if (typeof headerValueGetter === 'string') {\n // valueGetter is an expression, so execute the expression\n return this.expressionService.evaluate(headerValueGetter, params);\n }\n console.warn('AG Grid: headerValueGetter must be a function or a string');\n return '';\n }\n else if (colDef.headerName != null) {\n return colDef.headerName;\n }\n else if (colDef.field) {\n return camelCaseToHumanText(colDef.field);\n }\n return '';\n }\n wrapHeaderNameWithAggFunc(column, headerName) {\n if (this.gridOptionsService.is('suppressAggFuncInHeader')) {\n return headerName;\n }\n // only columns with aggregation active can have aggregations\n const pivotValueColumn = column.getColDef().pivotValueColumn;\n const pivotActiveOnThisColumn = exists(pivotValueColumn);\n let aggFunc = null;\n let aggFuncFound;\n // otherwise we have a measure that is active, and we are doing aggregation on it\n if (pivotActiveOnThisColumn) {\n const isCollapsedHeaderEnabled = this.gridOptionsService.is('removePivotHeaderRowWhenSingleValueColumn') && this.valueColumns.length === 1;\n const isTotalColumn = column.getColDef().pivotTotalColumnIds !== undefined;\n if (isCollapsedHeaderEnabled && !isTotalColumn) {\n return headerName; // Skip decorating the header - in this case the label is the pivot key, not the value col\n }\n aggFunc = pivotValueColumn ? pivotValueColumn.getAggFunc() : null;\n aggFuncFound = true;\n }\n else {\n const measureActive = column.isValueActive();\n const aggregationPresent = this.pivotMode || !this.isRowGroupEmpty();\n if (measureActive && aggregationPresent) {\n aggFunc = column.getAggFunc();\n aggFuncFound = true;\n }\n else {\n aggFuncFound = false;\n }\n }\n if (aggFuncFound) {\n const aggFuncString = (typeof aggFunc === 'string') ? aggFunc : 'func';\n const localeTextFunc = this.localeService.getLocaleTextFunc();\n const aggFuncStringTranslated = localeTextFunc(aggFuncString, aggFuncString);\n return `${aggFuncStringTranslated}(${headerName})`;\n }\n return headerName;\n }\n // returns the group with matching colId and instanceId. If instanceId is missing,\n // matches only on the colId.\n getColumnGroup(colId, partId) {\n if (!colId) {\n return null;\n }\n if (colId instanceof ColumnGroup) {\n return colId;\n }\n const allColumnGroups = this.getAllDisplayedTrees();\n const checkPartId = typeof partId === 'number';\n let result = null;\n this.columnUtils.depthFirstAllColumnTreeSearch(allColumnGroups, (child) => {\n if (child instanceof ColumnGroup) {\n const columnGroup = child;\n let matched;\n if (checkPartId) {\n matched = colId === columnGroup.getGroupId() && partId === columnGroup.getPartId();\n }\n else {\n matched = colId === columnGroup.getGroupId();\n }\n if (matched) {\n result = columnGroup;\n }\n }\n });\n return result;\n }\n isReady() {\n return this.ready;\n }\n extractValueColumns(source, oldPrimaryColumns) {\n this.valueColumns = this.extractColumns(oldPrimaryColumns, this.valueColumns, (col, flag) => col.setValueActive(flag, source), \n // aggFunc doesn't have index variant, cos order of value cols doesn't matter, so always return null\n () => undefined, () => undefined, \n // aggFunc is a string, so return it's existence\n (colDef) => {\n const aggFunc = colDef.aggFunc;\n // null or empty string means clear\n if (aggFunc === null || aggFunc === '') {\n return null;\n }\n if (aggFunc === undefined) {\n return;\n }\n return !!aggFunc;\n }, (colDef) => {\n // return false if any of the following: null, undefined, empty string\n return colDef.initialAggFunc != null && colDef.initialAggFunc != '';\n });\n // all new columns added will have aggFunc missing, so set it to what is in the colDef\n this.valueColumns.forEach(col => {\n const colDef = col.getColDef();\n // if aggFunc provided, we always override, as reactive property\n if (colDef.aggFunc != null && colDef.aggFunc != '') {\n col.setAggFunc(colDef.aggFunc);\n }\n else {\n // otherwise we use initialAggFunc only if no agg func set - which happens when new column only\n if (!col.getAggFunc()) {\n col.setAggFunc(colDef.initialAggFunc);\n }\n }\n });\n }\n extractRowGroupColumns(source, oldPrimaryColumns) {\n this.rowGroupColumns = this.extractColumns(oldPrimaryColumns, this.rowGroupColumns, (col, flag) => col.setRowGroupActive(flag, source), (colDef) => colDef.rowGroupIndex, (colDef) => colDef.initialRowGroupIndex, (colDef) => colDef.rowGroup, (colDef) => colDef.initialRowGroup);\n }\n extractColumns(oldPrimaryColumns = [], previousCols = [], setFlagFunc, getIndexFunc, getInitialIndexFunc, getValueFunc, getInitialValueFunc) {\n const colsWithIndex = [];\n const colsWithValue = [];\n // go though all cols.\n // if value, change\n // if default only, change only if new\n (this.primaryColumns || []).forEach(col => {\n const colIsNew = oldPrimaryColumns.indexOf(col) < 0;\n const colDef = col.getColDef();\n const value = attrToBoolean(getValueFunc(colDef));\n const initialValue = attrToBoolean(getInitialValueFunc(colDef));\n const index = attrToNumber(getIndexFunc(colDef));\n const initialIndex = attrToNumber(getInitialIndexFunc(colDef));\n let include;\n const valuePresent = value !== undefined;\n const indexPresent = index !== undefined;\n const initialValuePresent = initialValue !== undefined;\n const initialIndexPresent = initialIndex !== undefined;\n if (valuePresent) {\n include = value; // boolean value is guaranteed as attrToBoolean() is used above\n }\n else if (indexPresent) {\n if (index === null) {\n // if col is new we don't want to use the default / initial if index is set to null. Similarly,\n // we don't want to include the property for existing columns, i.e. we want to 'clear' it.\n include = false;\n }\n else {\n // note that 'null >= 0' evaluates to true which means 'rowGroupIndex = null' would enable row\n // grouping if the null check didn't exist above.\n include = index >= 0;\n }\n }\n else {\n if (colIsNew) {\n // as no value or index is 'present' we use the default / initial when col is new\n if (initialValuePresent) {\n include = initialValue;\n }\n else if (initialIndexPresent) {\n include = initialIndex != null && initialIndex >= 0;\n }\n else {\n include = false;\n }\n }\n else {\n // otherwise include it if included last time, e.g. if we are extracting row group cols and this col\n // is an existing row group col (i.e. it exists in 'previousCols') then we should include it.\n include = previousCols.indexOf(col) >= 0;\n }\n }\n if (include) {\n const useIndex = colIsNew ? (index != null || initialIndex != null) : index != null;\n useIndex ? colsWithIndex.push(col) : colsWithValue.push(col);\n }\n });\n const getIndexForCol = (col) => {\n const index = getIndexFunc(col.getColDef());\n const defaultIndex = getInitialIndexFunc(col.getColDef());\n return index != null ? index : defaultIndex;\n };\n // sort cols with index, and add these first\n colsWithIndex.sort((colA, colB) => {\n const indexA = getIndexForCol(colA);\n const indexB = getIndexForCol(colB);\n if (indexA === indexB) {\n return 0;\n }\n if (indexA < indexB) {\n return -1;\n }\n return 1;\n });\n const res = [].concat(colsWithIndex);\n // second add columns that were there before and in the same order as they were before,\n // so we are preserving order of current grouping of columns that simply have rowGroup=true\n previousCols.forEach(col => {\n if (colsWithValue.indexOf(col) >= 0) {\n res.push(col);\n }\n });\n // lastly put in all remaining cols\n colsWithValue.forEach(col => {\n if (res.indexOf(col) < 0) {\n res.push(col);\n }\n });\n // set flag=false for removed cols\n previousCols.forEach(col => {\n if (res.indexOf(col) < 0) {\n setFlagFunc(col, false);\n }\n });\n // set flag=true for newly added cols\n res.forEach(col => {\n if (previousCols.indexOf(col) < 0) {\n setFlagFunc(col, true);\n }\n });\n return res;\n }\n extractPivotColumns(source, oldPrimaryColumns) {\n this.pivotColumns = this.extractColumns(oldPrimaryColumns, this.pivotColumns, (col, flag) => col.setPivotActive(flag, source), (colDef) => colDef.pivotIndex, (colDef) => colDef.initialPivotIndex, (colDef) => colDef.pivot, (colDef) => colDef.initialPivot);\n }\n resetColumnGroupState(source = \"api\") {\n const stateItems = [];\n this.columnUtils.depthFirstOriginalTreeSearch(null, this.primaryColumnTree, child => {\n if (child instanceof ProvidedColumnGroup) {\n const colGroupDef = child.getColGroupDef();\n const groupState = {\n groupId: child.getGroupId(),\n open: !colGroupDef ? undefined : colGroupDef.openByDefault\n };\n stateItems.push(groupState);\n }\n });\n this.setColumnGroupState(stateItems, source);\n }\n getColumnGroupState() {\n const columnGroupState = [];\n this.columnUtils.depthFirstOriginalTreeSearch(null, this.gridBalancedTree, node => {\n if (node instanceof ProvidedColumnGroup) {\n columnGroupState.push({\n groupId: node.getGroupId(),\n open: node.isExpanded()\n });\n }\n });\n return columnGroupState;\n }\n setColumnGroupState(stateItems, source = \"api\") {\n this.columnAnimationService.start();\n const impactedGroups = [];\n stateItems.forEach(stateItem => {\n const groupKey = stateItem.groupId;\n const newValue = stateItem.open;\n const providedColumnGroup = this.getProvidedColumnGroup(groupKey);\n if (!providedColumnGroup) {\n return;\n }\n if (providedColumnGroup.isExpanded() === newValue) {\n return;\n }\n this.logger.log('columnGroupOpened(' + providedColumnGroup.getGroupId() + ',' + newValue + ')');\n providedColumnGroup.setExpanded(newValue);\n impactedGroups.push(providedColumnGroup);\n });\n this.updateGroupsAndDisplayedColumns(source);\n this.setFirstRightAndLastLeftPinned(source);\n impactedGroups.forEach(providedColumnGroup => {\n const event = {\n type: Events.EVENT_COLUMN_GROUP_OPENED,\n columnGroup: providedColumnGroup\n };\n this.eventService.dispatchEvent(event);\n });\n this.columnAnimationService.finish();\n }\n // called by headerRenderer - when a header is opened or closed\n setColumnGroupOpened(key, newValue, source = \"api\") {\n let keyAsString;\n if (key instanceof ProvidedColumnGroup) {\n keyAsString = key.getId();\n }\n else {\n keyAsString = key || '';\n }\n this.setColumnGroupState([{ groupId: keyAsString, open: newValue }], source);\n }\n getProvidedColumnGroup(key) {\n // if (key instanceof ProvidedColumnGroup) { return key; }\n if (typeof key !== 'string') {\n console.error('AG Grid: group key must be a string');\n }\n // otherwise, search for the column group by id\n let res = null;\n this.columnUtils.depthFirstOriginalTreeSearch(null, this.gridBalancedTree, node => {\n if (node instanceof ProvidedColumnGroup) {\n if (node.getId() === key) {\n res = node;\n }\n }\n });\n return res;\n }\n calculateColumnsForDisplay() {\n let columnsForDisplay;\n if (this.pivotMode && missing(this.secondaryColumns)) {\n // pivot mode is on, but we are not pivoting, so we only\n // show columns we are aggregating on\n columnsForDisplay = this.gridColumns.filter(column => {\n const isAutoGroupCol = this.groupAutoColumns && includes(this.groupAutoColumns, column);\n const isValueCol = this.valueColumns && includes(this.valueColumns, column);\n return isAutoGroupCol || isValueCol;\n });\n }\n else {\n // otherwise continue as normal. this can be working on the primary\n // or secondary columns, whatever the gridColumns are set to\n columnsForDisplay = this.gridColumns.filter(column => {\n // keep col if a) it's auto-group or b) it's visible\n const isAutoGroupCol = this.groupAutoColumns && includes(this.groupAutoColumns, column);\n return isAutoGroupCol || column.isVisible();\n });\n }\n return columnsForDisplay;\n }\n checkColSpanActiveInCols(columns) {\n let result = false;\n columns.forEach(col => {\n if (exists(col.getColDef().colSpan)) {\n result = true;\n }\n });\n return result;\n }\n calculateColumnsForGroupDisplay() {\n this.groupDisplayColumns = [];\n this.groupDisplayColumnsMap = {};\n const checkFunc = (col) => {\n const colDef = col.getColDef();\n const underlyingColumn = colDef.showRowGroup;\n if (colDef && exists(underlyingColumn)) {\n this.groupDisplayColumns.push(col);\n if (typeof underlyingColumn === 'string') {\n this.groupDisplayColumnsMap[underlyingColumn] = col;\n }\n else if (underlyingColumn === true) {\n this.getRowGroupColumns().forEach(rowGroupCol => {\n this.groupDisplayColumnsMap[rowGroupCol.getId()] = col;\n });\n }\n }\n };\n this.gridColumns.forEach(checkFunc);\n }\n getGroupDisplayColumns() {\n return this.groupDisplayColumns;\n }\n getGroupDisplayColumnForGroup(rowGroupColumnId) {\n return this.groupDisplayColumnsMap[rowGroupColumnId];\n }\n updateDisplayedColumns(source) {\n const columnsForDisplay = this.calculateColumnsForDisplay();\n this.buildDisplayedTrees(columnsForDisplay);\n // also called when group opened/closed\n this.updateGroupsAndDisplayedColumns(source);\n // also called when group opened/closed\n this.setFirstRightAndLastLeftPinned(source);\n }\n isSecondaryColumnsPresent() {\n return exists(this.secondaryColumns);\n }\n setSecondaryColumns(colDefs, source = \"api\") {\n const newColsPresent = colDefs && colDefs.length > 0;\n // if not cols passed, and we had no cols anyway, then do nothing\n if (!newColsPresent && missing(this.secondaryColumns)) {\n return;\n }\n if (newColsPresent) {\n this.processSecondaryColumnDefinitions(colDefs);\n const balancedTreeResult = this.columnFactory.createColumnTree(colDefs, false, this.secondaryBalancedTree || this.previousSecondaryColumns || undefined);\n this.destroyOldColumns(this.secondaryBalancedTree, balancedTreeResult.columnTree);\n this.secondaryBalancedTree = balancedTreeResult.columnTree;\n this.secondaryHeaderRowCount = balancedTreeResult.treeDept + 1;\n this.secondaryColumns = this.getColumnsFromTree(this.secondaryBalancedTree);\n this.secondaryColumnsMap = {};\n this.secondaryColumns.forEach(col => this.secondaryColumnsMap[col.getId()] = col);\n this.previousSecondaryColumns = null;\n }\n else {\n this.previousSecondaryColumns = this.secondaryBalancedTree;\n this.secondaryBalancedTree = null;\n this.secondaryHeaderRowCount = -1;\n this.secondaryColumns = null;\n this.secondaryColumnsMap = {};\n }\n this.updateGridColumns();\n this.updateDisplayedColumns(source);\n }\n processSecondaryColumnDefinitions(colDefs) {\n const columnCallback = this.gridOptionsService.get('processPivotResultColDef') || this.gridOptionsService.get('processSecondaryColDef');\n const groupCallback = this.gridOptionsService.get('processPivotResultColGroupDef') || this.gridOptionsService.get('processSecondaryColGroupDef');\n if (!columnCallback && !groupCallback) {\n return undefined;\n }\n const searchForColDefs = (colDefs2) => {\n colDefs2.forEach((abstractColDef) => {\n const isGroup = exists(abstractColDef.children);\n if (isGroup) {\n const colGroupDef = abstractColDef;\n if (groupCallback) {\n groupCallback(colGroupDef);\n }\n searchForColDefs(colGroupDef.children);\n }\n else {\n const colDef = abstractColDef;\n if (columnCallback) {\n columnCallback(colDef);\n }\n }\n });\n };\n if (colDefs) {\n searchForColDefs(colDefs);\n }\n }\n // called from: applyColumnState, setColumnDefs, setSecondaryColumns\n updateGridColumns() {\n const prevGridCols = this.gridBalancedTree;\n if (this.gridColsArePrimary) {\n this.lastPrimaryOrder = this.gridColumns;\n }\n else {\n this.lastSecondaryOrder = this.gridColumns;\n }\n let sortOrderToRecover;\n if (this.secondaryColumns && this.secondaryBalancedTree) {\n const hasSameColumns = this.secondaryColumns.every((col) => {\n return this.gridColumnsMap[col.getColId()] !== undefined;\n });\n this.gridBalancedTree = this.secondaryBalancedTree.slice();\n this.gridHeaderRowCount = this.secondaryHeaderRowCount;\n this.gridColumns = this.secondaryColumns.slice();\n this.gridColsArePrimary = false;\n // If the current columns are the same or a subset of the previous\n // we keep the previous order, otherwise we go back to the order the pivot\n // cols are generated in\n if (hasSameColumns) {\n sortOrderToRecover = this.lastSecondaryOrder;\n }\n }\n else if (this.primaryColumns) {\n this.gridBalancedTree = this.primaryColumnTree.slice();\n this.gridHeaderRowCount = this.primaryHeaderRowCount;\n this.gridColumns = this.primaryColumns.slice();\n this.gridColsArePrimary = true;\n // updateGridColumns gets called after user adds a row group. we want to maintain the order of the columns\n // when this happens (eg if user moved a column) rather than revert back to the original column order.\n // likewise if changing in/out of pivot mode, we want to maintain the order of the cols\n sortOrderToRecover = this.lastPrimaryOrder;\n }\n // create the new auto columns\n const areAutoColsChanged = this.createGroupAutoColumnsIfNeeded();\n // if auto group cols have changed, and we have a sort order, we need to move auto cols to the start\n if (areAutoColsChanged && sortOrderToRecover) {\n const groupAutoColsMap = convertToMap(this.groupAutoColumns.map(col => [col, true]));\n // if group columns has changed, we don't preserve the group column order, so remove them from the old order\n sortOrderToRecover = sortOrderToRecover.filter(col => !groupAutoColsMap.has(col));\n // and add them to the start of the order\n sortOrderToRecover = [...this.groupAutoColumns, ...sortOrderToRecover];\n }\n this.addAutoGroupToGridColumns();\n this.orderGridColsLike(sortOrderToRecover);\n this.gridColumns = this.placeLockedColumns(this.gridColumns);\n this.calculateColumnsForGroupDisplay();\n this.refreshQuickFilterColumns();\n this.clearDisplayedAndViewportColumns();\n this.colSpanActive = this.checkColSpanActiveInCols(this.gridColumns);\n this.gridColumnsMap = {};\n this.gridColumns.forEach(col => this.gridColumnsMap[col.getId()] = col);\n this.setAutoHeightActive();\n if (!areEqual(prevGridCols, this.gridBalancedTree)) {\n const event = {\n type: Events.EVENT_GRID_COLUMNS_CHANGED\n };\n this.eventService.dispatchEvent(event);\n }\n }\n setAutoHeightActive() {\n this.autoHeightActive = this.gridColumns.filter(col => col.isAutoHeight()).length > 0;\n if (this.autoHeightActive) {\n this.autoHeightActiveAtLeastOnce = true;\n const supportedRowModel = this.gridOptionsService.isRowModelType('clientSide') || this.gridOptionsService.isRowModelType('serverSide');\n if (!supportedRowModel) {\n const message = 'AG Grid - autoHeight columns only work with Client Side Row Model and Server Side Row Model.';\n doOnce(() => console.warn(message), 'autoHeightActive.wrongRowModel');\n }\n }\n }\n orderGridColsLike(colsOrder) {\n if (missing(colsOrder)) {\n return;\n }\n const lastOrderMapped = convertToMap(colsOrder.map((col, index) => [col, index]));\n // only do the sort if at least one column is accounted for. columns will be not accounted for\n // if changing from secondary to primary columns\n let noColsFound = true;\n this.gridColumns.forEach(col => {\n if (lastOrderMapped.has(col)) {\n noColsFound = false;\n }\n });\n if (noColsFound) {\n return;\n }\n // order cols in the same order as before. we need to make sure that all\n // cols still exists, so filter out any that no longer exist.\n const gridColsMap = convertToMap(this.gridColumns.map(col => [col, true]));\n const oldColsOrdered = colsOrder.filter(col => gridColsMap.has(col));\n const oldColsMap = convertToMap(oldColsOrdered.map(col => [col, true]));\n const newColsOrdered = this.gridColumns.filter(col => !oldColsMap.has(col));\n // add in the new columns, at the end (if no group), or at the end of the group (if a group)\n const newGridColumns = oldColsOrdered.slice();\n newColsOrdered.forEach(newCol => {\n let parent = newCol.getOriginalParent();\n // if no parent, means we are not grouping, so just add the column to the end\n if (!parent) {\n newGridColumns.push(newCol);\n return;\n }\n // find the group the column belongs to. if no siblings at the current level (eg col in group on it's\n // own) then go up one level and look for siblings there.\n const siblings = [];\n while (!siblings.length && parent) {\n const leafCols = parent.getLeafColumns();\n leafCols.forEach(leafCol => {\n const presentInNewGriColumns = newGridColumns.indexOf(leafCol) >= 0;\n const noYetInSiblings = siblings.indexOf(leafCol) < 0;\n if (presentInNewGriColumns && noYetInSiblings) {\n siblings.push(leafCol);\n }\n });\n parent = parent.getOriginalParent();\n }\n // if no siblings exist at any level, this means the col is in a group (or parent groups) on it's own\n if (!siblings.length) {\n newGridColumns.push(newCol);\n return;\n }\n // find index of last column in the group\n const indexes = siblings.map(col => newGridColumns.indexOf(col));\n const lastIndex = Math.max(...indexes);\n insertIntoArray(newGridColumns, newCol, lastIndex + 1);\n });\n this.gridColumns = newGridColumns;\n }\n isPrimaryColumnGroupsPresent() {\n return this.primaryHeaderRowCount > 1;\n }\n // if we are using autoGroupCols, then they should be included for quick filter. this covers the\n // following scenarios:\n // a) user provides 'field' into autoGroupCol of normal grid, so now because a valid col to filter leafs on\n // b) using tree data and user depends on autoGroupCol for first col, and we also want to filter on this\n // (tree data is a bit different, as parent rows can be filtered on, unlike row grouping)\n refreshQuickFilterColumns() {\n var _a;\n let columnsForQuickFilter = (_a = (this.isPivotMode() ? this.secondaryColumns : this.primaryColumns)) !== null && _a !== void 0 ? _a : [];\n if (this.groupAutoColumns) {\n columnsForQuickFilter = columnsForQuickFilter.concat(this.groupAutoColumns);\n }\n this.columnsForQuickFilter = this.gridOptionsService.is('includeHiddenColumnsInQuickFilter')\n ? columnsForQuickFilter\n : columnsForQuickFilter.filter(col => col.isVisible() || col.isRowGroupActive());\n }\n placeLockedColumns(cols) {\n const left = [];\n const normal = [];\n const right = [];\n cols.forEach((col) => {\n const position = col.getColDef().lockPosition;\n if (position === 'right') {\n right.push(col);\n }\n else if (position === 'left' || position === true) {\n left.push(col);\n }\n else {\n normal.push(col);\n }\n });\n return [...left, ...normal, ...right];\n }\n addAutoGroupToGridColumns() {\n if (missing(this.groupAutoColumns)) {\n this.destroyOldColumns(this.groupAutoColsBalancedTree);\n this.groupAutoColsBalancedTree = null;\n return;\n }\n this.gridColumns = this.groupAutoColumns ? this.groupAutoColumns.concat(this.gridColumns) : this.gridColumns;\n const newAutoColsTree = this.columnFactory.createForAutoGroups(this.groupAutoColumns, this.gridBalancedTree);\n this.destroyOldColumns(this.groupAutoColsBalancedTree, newAutoColsTree);\n this.groupAutoColsBalancedTree = newAutoColsTree;\n this.gridBalancedTree = newAutoColsTree.concat(this.gridBalancedTree);\n }\n // gets called after we copy down grid columns, to make sure any part of the gui\n // that tries to draw, eg the header, it will get empty lists of columns rather\n // than stale columns. for example, the header will received gridColumnsChanged\n // event, so will try and draw, but it will draw successfully when it acts on the\n // virtualColumnsChanged event\n clearDisplayedAndViewportColumns() {\n this.viewportRowLeft = {};\n this.viewportRowRight = {};\n this.viewportRowCenter = {};\n this.displayedColumnsLeft = [];\n this.displayedColumnsRight = [];\n this.displayedColumnsCenter = [];\n this.displayedColumns = [];\n this.viewportColumns = [];\n this.headerViewportColumns = [];\n this.viewportColumnsHash = '';\n }\n updateGroupsAndDisplayedColumns(source) {\n this.updateOpenClosedVisibilityInColumnGroups();\n this.deriveDisplayedColumns(source);\n this.refreshFlexedColumns();\n this.extractViewport();\n this.updateBodyWidths();\n // this event is picked up by the gui, headerRenderer and rowRenderer, to recalculate what columns to display\n const event = {\n type: Events.EVENT_DISPLAYED_COLUMNS_CHANGED\n };\n this.eventService.dispatchEvent(event);\n }\n deriveDisplayedColumns(source) {\n this.derivedDisplayedColumnsFromDisplayedTree(this.displayedTreeLeft, this.displayedColumnsLeft);\n this.derivedDisplayedColumnsFromDisplayedTree(this.displayedTreeCentre, this.displayedColumnsCenter);\n this.derivedDisplayedColumnsFromDisplayedTree(this.displayedTreeRight, this.displayedColumnsRight);\n this.joinDisplayedColumns();\n this.setLeftValues(source);\n this.displayedAutoHeightCols = this.displayedColumns.filter(col => col.isAutoHeight());\n }\n isAutoRowHeightActive() {\n return this.autoHeightActive;\n }\n wasAutoRowHeightEverActive() {\n return this.autoHeightActiveAtLeastOnce;\n }\n joinDisplayedColumns() {\n if (this.gridOptionsService.is('enableRtl')) {\n this.displayedColumns = this.displayedColumnsRight\n .concat(this.displayedColumnsCenter)\n .concat(this.displayedColumnsLeft);\n }\n else {\n this.displayedColumns = this.displayedColumnsLeft\n .concat(this.displayedColumnsCenter)\n .concat(this.displayedColumnsRight);\n }\n }\n // sets the left pixel position of each column\n setLeftValues(source) {\n this.setLeftValuesOfColumns(source);\n this.setLeftValuesOfGroups();\n }\n setLeftValuesOfColumns(source) {\n if (!this.primaryColumns) {\n return;\n }\n // go through each list of displayed columns\n const allColumns = this.primaryColumns.slice(0);\n // let totalColumnWidth = this.getWidthOfColsInList()\n const doingRtl = this.gridOptionsService.is('enableRtl');\n [\n this.displayedColumnsLeft,\n this.displayedColumnsRight,\n this.displayedColumnsCenter\n ].forEach(columns => {\n if (doingRtl) {\n // when doing RTL, we start at the top most pixel (ie RHS) and work backwards\n let left = this.getWidthOfColsInList(columns);\n columns.forEach(column => {\n left -= column.getActualWidth();\n column.setLeft(left, source);\n });\n }\n else {\n // otherwise normal LTR, we start at zero\n let left = 0;\n columns.forEach(column => {\n column.setLeft(left, source);\n left += column.getActualWidth();\n });\n }\n removeAllFromUnorderedArray(allColumns, columns);\n });\n // items left in allColumns are columns not displayed, so remove the left position. this is\n // important for the rows, as if a col is made visible, then taken out, then made visible again,\n // we don't want the animation of the cell floating in from the old position, whatever that was.\n allColumns.forEach((column) => {\n column.setLeft(null, source);\n });\n }\n setLeftValuesOfGroups() {\n // a groups left value is the lest left value of it's children\n [\n this.displayedTreeLeft,\n this.displayedTreeRight,\n this.displayedTreeCentre\n ].forEach(columns => {\n columns.forEach(column => {\n if (column instanceof ColumnGroup) {\n const columnGroup = column;\n columnGroup.checkLeft();\n }\n });\n });\n }\n derivedDisplayedColumnsFromDisplayedTree(tree, columns) {\n columns.length = 0;\n this.columnUtils.depthFirstDisplayedColumnTreeSearch(tree, (child) => {\n if (child instanceof Column) {\n columns.push(child);\n }\n });\n }\n extractViewportColumns() {\n if (this.suppressColumnVirtualisation) {\n // no virtualisation, so don't filter\n this.viewportColumnsCenter = this.displayedColumnsCenter;\n this.headerViewportColumnsCenter = this.displayedColumnsCenter;\n }\n else {\n // filter out what should be visible\n this.viewportColumnsCenter = this.displayedColumnsCenter.filter(this.isColumnInRowViewport.bind(this));\n this.headerViewportColumnsCenter = this.displayedColumnsCenter.filter(this.isColumnInHeaderViewport.bind(this));\n }\n this.viewportColumns = this.viewportColumnsCenter\n .concat(this.displayedColumnsLeft)\n .concat(this.displayedColumnsRight);\n this.headerViewportColumns = this.headerViewportColumnsCenter\n .concat(this.displayedColumnsLeft)\n .concat(this.displayedColumnsRight);\n }\n getVirtualHeaderGroupRow(type, dept) {\n let result;\n switch (type) {\n case 'left':\n result = this.viewportRowLeft[dept];\n break;\n case 'right':\n result = this.viewportRowRight[dept];\n break;\n default:\n result = this.viewportRowCenter[dept];\n break;\n }\n if (missing(result)) {\n result = [];\n }\n return result;\n }\n calculateHeaderRows() {\n // go through each group, see if any of it's cols are displayed, and if yes,\n // then this group is included\n this.viewportRowLeft = {};\n this.viewportRowRight = {};\n this.viewportRowCenter = {};\n // for easy lookup when building the groups.\n const virtualColIds = {};\n this.headerViewportColumns.forEach(col => virtualColIds[col.getId()] = true);\n const testGroup = (children, result, dept) => {\n let returnValue = false;\n for (let i = 0; i < children.length; i++) {\n // see if this item is within viewport\n const child = children[i];\n let addThisItem = false;\n if (child instanceof Column) {\n // for column, test if column is included\n addThisItem = virtualColIds[child.getId()] === true;\n }\n else {\n // if group, base decision on children\n const columnGroup = child;\n const displayedChildren = columnGroup.getDisplayedChildren();\n if (displayedChildren) {\n addThisItem = testGroup(displayedChildren, result, dept + 1);\n }\n }\n if (addThisItem) {\n returnValue = true;\n if (!result[dept]) {\n result[dept] = [];\n }\n result[dept].push(child);\n }\n }\n return returnValue;\n };\n testGroup(this.displayedTreeLeft, this.viewportRowLeft, 0);\n testGroup(this.displayedTreeRight, this.viewportRowRight, 0);\n testGroup(this.displayedTreeCentre, this.viewportRowCenter, 0);\n }\n extractViewport() {\n const hashColumn = (c) => `${c.getId()}-${c.getPinned() || 'normal'}`;\n this.extractViewportColumns();\n const newHash = this.viewportColumns.map(hashColumn).join('#');\n const changed = this.viewportColumnsHash !== newHash;\n if (changed) {\n this.viewportColumnsHash = newHash;\n this.calculateHeaderRows();\n }\n return changed;\n }\n refreshFlexedColumns(params = {}) {\n var _a;\n const source = params.source ? params.source : 'flex';\n if (params.viewportWidth != null) {\n this.flexViewportWidth = params.viewportWidth;\n }\n if (!this.flexViewportWidth) {\n return [];\n }\n // If the grid has left-over space, divide it between flexing columns in proportion to their flex value.\n // A \"flexing column\" is one that has a 'flex' value set and is not currently being constrained by its\n // minWidth or maxWidth rules.\n let flexAfterDisplayIndex = -1;\n if (params.resizingCols) {\n const allResizingCols = new Set(params.resizingCols);\n // find the last resizing col, as only cols after this one are affected by the resizing\n let displayedCols = this.displayedColumnsCenter;\n for (let i = displayedCols.length - 1; i >= 0; i--) {\n if (allResizingCols.has(displayedCols[i])) {\n flexAfterDisplayIndex = i;\n break;\n }\n }\n }\n // the width of all of the columns for which the width has been determined\n let knownColumnsWidth = 0;\n let flexingColumns = [];\n // store the minimum width of all the flex columns, so we can determine if flex is even possible more quickly\n let minimumFlexedWidth = 0;\n let totalFlex = 0;\n for (let i = 0; i < this.displayedColumnsCenter.length; i++) {\n const isFlex = this.displayedColumnsCenter[i].getFlex() && i > flexAfterDisplayIndex;\n if (isFlex) {\n flexingColumns.push(this.displayedColumnsCenter[i]);\n totalFlex += this.displayedColumnsCenter[i].getFlex();\n minimumFlexedWidth += (_a = this.displayedColumnsCenter[i].getMinWidth()) !== null && _a !== void 0 ? _a : 0;\n }\n else {\n knownColumnsWidth += this.displayedColumnsCenter[i].getActualWidth();\n }\n }\n ;\n if (!flexingColumns.length) {\n return [];\n }\n let changedColumns = [];\n // this is for performance to prevent trying to flex when unnecessary\n if (knownColumnsWidth + minimumFlexedWidth > this.flexViewportWidth) {\n // known columns and the minimum width of all the flex cols are too wide for viewport\n // so don't flex\n flexingColumns.forEach(col => { var _a; return col.setActualWidth((_a = col.getMinWidth()) !== null && _a !== void 0 ? _a : 0, source); });\n // No columns should flex, but all have been changed. Swap arrays so events fire properly.\n // Expensive logic won't execute as flex columns is empty.\n changedColumns = flexingColumns;\n flexingColumns = [];\n }\n const flexingColumnSizes = [];\n let spaceForFlexingColumns;\n outer: while (true) {\n spaceForFlexingColumns = this.flexViewportWidth - knownColumnsWidth;\n const spacePerFlex = spaceForFlexingColumns / totalFlex;\n for (let i = 0; i < flexingColumns.length; i++) {\n const col = flexingColumns[i];\n const widthByFlexRule = spacePerFlex * col.getFlex();\n let constrainedWidth = 0;\n const minWidth = col.getMinWidth();\n const maxWidth = col.getMaxWidth();\n if (exists(minWidth) && widthByFlexRule < minWidth) {\n constrainedWidth = minWidth;\n }\n else if (exists(maxWidth) && widthByFlexRule > maxWidth) {\n constrainedWidth = maxWidth;\n }\n if (constrainedWidth) {\n // This column is not in fact flexing as it is being constrained to a specific size\n // so remove it from the list of flexing columns and start again\n col.setActualWidth(constrainedWidth, source);\n removeFromUnorderedArray(flexingColumns, col);\n totalFlex -= col.getFlex();\n changedColumns.push(col);\n knownColumnsWidth += col.getActualWidth();\n continue outer;\n }\n flexingColumnSizes[i] = Math.round(widthByFlexRule);\n }\n break;\n }\n let remainingSpace = spaceForFlexingColumns;\n flexingColumns.forEach((col, i) => {\n col.setActualWidth(Math.min(flexingColumnSizes[i], remainingSpace), source);\n changedColumns.push(col);\n remainingSpace -= flexingColumnSizes[i];\n });\n if (!params.skipSetLeft) {\n this.setLeftValues(source);\n }\n if (params.updateBodyWidths) {\n this.updateBodyWidths();\n }\n if (params.fireResizedEvent) {\n this.dispatchColumnResizedEvent(changedColumns, true, source, flexingColumns);\n }\n return flexingColumns;\n }\n // called from api\n sizeColumnsToFit(gridWidth, source = \"sizeColumnsToFit\", silent, params) {\n var _a, _b, _c, _d, _e;\n if (this.shouldQueueResizeOperations) {\n this.resizeOperationQueue.push(() => this.sizeColumnsToFit(gridWidth, source, silent, params));\n return;\n }\n const limitsMap = {};\n if (params) {\n (_a = params === null || params === void 0 ? void 0 : params.columnLimits) === null || _a === void 0 ? void 0 : _a.forEach((_a) => {\n var { key } = _a, dimensions = __rest(_a, [\"key\"]);\n limitsMap[typeof key === 'string' ? key : key.getColId()] = dimensions;\n });\n }\n // avoid divide by zero\n const allDisplayedColumns = this.getAllDisplayedColumns();\n const doColumnsAlreadyFit = gridWidth === this.getWidthOfColsInList(allDisplayedColumns);\n if (gridWidth <= 0 || !allDisplayedColumns.length || doColumnsAlreadyFit) {\n return;\n }\n const colsToSpread = [];\n const colsToNotSpread = [];\n allDisplayedColumns.forEach(column => {\n if (column.getColDef().suppressSizeToFit === true) {\n colsToNotSpread.push(column);\n }\n else {\n colsToSpread.push(column);\n }\n });\n // make a copy of the cols that are going to be resized\n const colsToDispatchEventFor = colsToSpread.slice(0);\n let finishedResizing = false;\n const moveToNotSpread = (column) => {\n removeFromArray(colsToSpread, column);\n colsToNotSpread.push(column);\n };\n // resetting cols to their original width makes the sizeColumnsToFit more deterministic,\n // rather than depending on the current size of the columns. most users call sizeColumnsToFit\n // immediately after grid is created, so will make no difference. however if application is calling\n // sizeColumnsToFit repeatedly (eg after column group is opened / closed repeatedly) we don't want\n // the columns to start shrinking / growing over time.\n //\n // NOTE: the process below will assign values to `this.actualWidth` of each column without firing events\n // for this reason we need to manually dispatch resize events after the resize has been done for each column.\n colsToSpread.forEach(column => {\n var _a, _b;\n column.resetActualWidth(source);\n const widthOverride = limitsMap === null || limitsMap === void 0 ? void 0 : limitsMap[column.getId()];\n const minOverride = ((_a = widthOverride === null || widthOverride === void 0 ? void 0 : widthOverride.minWidth) !== null && _a !== void 0 ? _a : params === null || params === void 0 ? void 0 : params.defaultMinWidth);\n const maxOverride = ((_b = widthOverride === null || widthOverride === void 0 ? void 0 : widthOverride.maxWidth) !== null && _b !== void 0 ? _b : params === null || params === void 0 ? void 0 : params.defaultMaxWidth);\n const colWidth = column.getActualWidth();\n if (typeof minOverride === 'number' && colWidth < minOverride) {\n column.setActualWidth(minOverride, source, true);\n }\n else if (typeof maxOverride === 'number' && colWidth > maxOverride) {\n column.setActualWidth(maxOverride, source, true);\n }\n });\n while (!finishedResizing) {\n finishedResizing = true;\n const availablePixels = gridWidth - this.getWidthOfColsInList(colsToNotSpread);\n if (availablePixels <= 0) {\n // no width, set everything to minimum\n colsToSpread.forEach((column) => {\n var _a, _b;\n const widthOverride = (_b = (_a = limitsMap === null || limitsMap === void 0 ? void 0 : limitsMap[column.getId()]) === null || _a === void 0 ? void 0 : _a.minWidth) !== null && _b !== void 0 ? _b : params === null || params === void 0 ? void 0 : params.defaultMinWidth;\n if (typeof widthOverride === 'number') {\n column.setActualWidth(widthOverride, source, true);\n return;\n }\n column.setMinimum(source);\n });\n }\n else {\n const scale = availablePixels / this.getWidthOfColsInList(colsToSpread);\n // we set the pixels for the last col based on what's left, as otherwise\n // we could be a pixel or two short or extra because of rounding errors.\n let pixelsForLastCol = availablePixels;\n // backwards through loop, as we are removing items as we go\n for (let i = colsToSpread.length - 1; i >= 0; i--) {\n const column = colsToSpread[i];\n const widthOverride = limitsMap === null || limitsMap === void 0 ? void 0 : limitsMap[column.getId()];\n const minOverride = ((_b = widthOverride === null || widthOverride === void 0 ? void 0 : widthOverride.minWidth) !== null && _b !== void 0 ? _b : params === null || params === void 0 ? void 0 : params.defaultMinWidth);\n const maxOverride = ((_c = widthOverride === null || widthOverride === void 0 ? void 0 : widthOverride.maxWidth) !== null && _c !== void 0 ? _c : params === null || params === void 0 ? void 0 : params.defaultMaxWidth);\n const colMinWidth = (_d = column.getMinWidth()) !== null && _d !== void 0 ? _d : 0;\n const colMaxWidth = (_e = column.getMaxWidth()) !== null && _e !== void 0 ? _e : Number.MAX_VALUE;\n const minWidth = typeof minOverride === 'number' && minOverride > colMinWidth ? minOverride : column.getMinWidth();\n const maxWidth = typeof maxOverride === 'number' && maxOverride < colMaxWidth ? maxOverride : column.getMaxWidth();\n let newWidth = Math.round(column.getActualWidth() * scale);\n if (exists(minWidth) && newWidth < minWidth) {\n newWidth = minWidth;\n moveToNotSpread(column);\n finishedResizing = false;\n }\n else if (exists(maxWidth) && newWidth > maxWidth) {\n newWidth = maxWidth;\n moveToNotSpread(column);\n finishedResizing = false;\n }\n else if (i === 0) { // if this is the last column\n newWidth = pixelsForLastCol;\n }\n column.setActualWidth(newWidth, source, true);\n pixelsForLastCol -= newWidth;\n }\n }\n }\n // see notes above\n colsToDispatchEventFor.forEach(col => {\n col.fireColumnWidthChangedEvent(source);\n });\n this.setLeftValues(source);\n this.updateBodyWidths();\n if (silent) {\n return;\n }\n this.dispatchColumnResizedEvent(colsToDispatchEventFor, true, source);\n }\n buildDisplayedTrees(visibleColumns) {\n const leftVisibleColumns = [];\n const rightVisibleColumns = [];\n const centerVisibleColumns = [];\n visibleColumns.forEach(column => {\n switch (column.getPinned()) {\n case \"left\":\n leftVisibleColumns.push(column);\n break;\n case \"right\":\n rightVisibleColumns.push(column);\n break;\n default:\n centerVisibleColumns.push(column);\n break;\n }\n });\n const groupInstanceIdCreator = new GroupInstanceIdCreator();\n this.displayedTreeLeft = this.displayedGroupCreator.createDisplayedGroups(leftVisibleColumns, groupInstanceIdCreator, 'left', this.displayedTreeLeft);\n this.displayedTreeRight = this.displayedGroupCreator.createDisplayedGroups(rightVisibleColumns, groupInstanceIdCreator, 'right', this.displayedTreeRight);\n this.displayedTreeCentre = this.displayedGroupCreator.createDisplayedGroups(centerVisibleColumns, groupInstanceIdCreator, null, this.displayedTreeCentre);\n this.updateDisplayedMap();\n }\n updateDisplayedMap() {\n this.displayedColumnsAndGroupsMap = {};\n const func = (child) => {\n this.displayedColumnsAndGroupsMap[child.getUniqueId()] = child;\n };\n this.columnUtils.depthFirstAllColumnTreeSearch(this.displayedTreeCentre, func);\n this.columnUtils.depthFirstAllColumnTreeSearch(this.displayedTreeLeft, func);\n this.columnUtils.depthFirstAllColumnTreeSearch(this.displayedTreeRight, func);\n }\n isDisplayed(item) {\n const fromMap = this.displayedColumnsAndGroupsMap[item.getUniqueId()];\n // check for reference, in case new column / group with same id is now present\n return fromMap === item;\n }\n updateOpenClosedVisibilityInColumnGroups() {\n const allColumnGroups = this.getAllDisplayedTrees();\n this.columnUtils.depthFirstAllColumnTreeSearch(allColumnGroups, child => {\n if (child instanceof ColumnGroup) {\n child.calculateDisplayedColumns();\n }\n });\n }\n getGroupAutoColumns() {\n return this.groupAutoColumns;\n }\n /**\n * Creates new auto group columns if required\n * @returns whether auto cols have changed\n */\n createGroupAutoColumnsIfNeeded() {\n const forceRecreateAutoGroups = this.forceRecreateAutoGroups;\n this.forceRecreateAutoGroups = false;\n if (!this.autoGroupsNeedBuilding) {\n return false;\n }\n this.autoGroupsNeedBuilding = false;\n const groupFullWidthRow = this.gridOptionsService.isGroupUseEntireRow(this.pivotMode);\n // we need to allow suppressing auto-column separately for group and pivot as the normal situation\n // is CSRM and user provides group column themselves for normal view, but when they go into pivot the\n // columns are generated by the grid so no opportunity for user to provide group column. so need a way\n // to suppress auto-col for grouping only, and not pivot.\n // however if using Viewport RM or SSRM and user is providing the columns, the user may wish full control\n // of the group column in this instance.\n const suppressAutoColumn = this.pivotMode ?\n this.gridOptionsService.is('pivotSuppressAutoColumn') : this.isGroupSuppressAutoColumn();\n const groupingActive = this.rowGroupColumns.length > 0 || this.gridOptionsService.is('treeData');\n const needAutoColumns = groupingActive && !suppressAutoColumn && !groupFullWidthRow;\n if (needAutoColumns) {\n const newAutoGroupCols = this.autoGroupColService.createAutoGroupColumns(this.rowGroupColumns);\n const autoColsDifferent = !this.autoColsEqual(newAutoGroupCols, this.groupAutoColumns);\n // we force recreate so new group cols pick up the new\n // definitions. otherwise we could ignore the new cols because they appear to be the same.\n if (autoColsDifferent || forceRecreateAutoGroups) {\n this.groupAutoColumns = newAutoGroupCols;\n return true;\n }\n }\n else {\n this.groupAutoColumns = null;\n }\n return false;\n }\n isGroupSuppressAutoColumn() {\n const groupDisplayType = this.gridOptionsService.get('groupDisplayType');\n const isCustomRowGroups = groupDisplayType ? matchesGroupDisplayType('custom', groupDisplayType) : false;\n if (isCustomRowGroups) {\n return true;\n }\n const treeDataDisplayType = this.gridOptionsService.get('treeDataDisplayType');\n return treeDataDisplayType ? matchesTreeDataDisplayType('custom', treeDataDisplayType) : false;\n }\n autoColsEqual(colsA, colsB) {\n return areEqual(colsA, colsB, (a, b) => a.getColId() === b.getColId());\n }\n getWidthOfColsInList(columnList) {\n return columnList.reduce((width, col) => width + col.getActualWidth(), 0);\n }\n getGridBalancedTree() {\n return this.gridBalancedTree;\n }\n getFirstDisplayedColumn() {\n const isRtl = this.gridOptionsService.is('enableRtl');\n const queryOrder = [\n 'getDisplayedLeftColumns',\n 'getDisplayedCenterColumns',\n 'getDisplayedRightColumns'\n ];\n if (isRtl) {\n queryOrder.reverse();\n }\n for (let i = 0; i < queryOrder.length; i++) {\n const container = this[queryOrder[i]]();\n if (container.length) {\n return isRtl ? last(container) : container[0];\n }\n }\n return null;\n }\n setColumnHeaderHeight(col, height) {\n const changed = col.setAutoHeaderHeight(height);\n if (changed) {\n const event = {\n type: Events.EVENT_COLUMN_HEADER_HEIGHT_CHANGED,\n column: col,\n columns: [col],\n source: 'autosizeColumnHeaderHeight',\n };\n this.eventService.dispatchEvent(event);\n }\n }\n getColumnGroupHeaderRowHeight() {\n if (this.isPivotMode()) {\n return this.getPivotGroupHeaderHeight();\n }\n return this.getGroupHeaderHeight();\n }\n getColumnHeaderRowHeight() {\n const defaultHeight = (this.isPivotMode() ?\n this.getPivotHeaderHeight() :\n this.getHeaderHeight());\n const displayedHeights = this.getAllDisplayedColumns()\n .filter((col) => col.isAutoHeaderHeight())\n .map((col) => col.getAutoHeaderHeight() || 0);\n return Math.max(defaultHeight, ...displayedHeights);\n }\n getHeaderHeight() {\n var _a;\n return (_a = this.gridOptionsService.getNum('headerHeight')) !== null && _a !== void 0 ? _a : this.environment.getFromTheme(25, 'headerHeight');\n }\n getFloatingFiltersHeight() {\n var _a;\n return (_a = this.gridOptionsService.getNum('floatingFiltersHeight')) !== null && _a !== void 0 ? _a : this.getHeaderHeight();\n }\n getGroupHeaderHeight() {\n var _a;\n return (_a = this.gridOptionsService.getNum('groupHeaderHeight')) !== null && _a !== void 0 ? _a : this.getHeaderHeight();\n }\n getPivotHeaderHeight() {\n var _a;\n return (_a = this.gridOptionsService.getNum('pivotHeaderHeight')) !== null && _a !== void 0 ? _a : this.getHeaderHeight();\n }\n getPivotGroupHeaderHeight() {\n var _a;\n return (_a = this.gridOptionsService.getNum('pivotGroupHeaderHeight')) !== null && _a !== void 0 ? _a : this.getGroupHeaderHeight();\n }\n queueResizeOperations() {\n this.shouldQueueResizeOperations = true;\n }\n processResizeOperations() {\n this.shouldQueueResizeOperations = false;\n this.resizeOperationQueue.forEach(resizeOperation => resizeOperation());\n this.resizeOperationQueue = [];\n }\n resetColumnDefIntoColumn(column) {\n const userColDef = column.getUserProvidedColDef();\n if (!userColDef) {\n return false;\n }\n const newColDef = this.columnFactory.addColumnDefaultAndTypes(userColDef, column.getColId());\n column.setColDef(newColDef, userColDef);\n return true;\n }\n generateColumnStateForRowGroupAndPivotIndexes(updatedRowGroupColumnState, updatedPivotColumnState) {\n // Generally columns should appear in the order they were before. For any new columns, these should appear in the original col def order.\n // The exception is for columns that were added via `addGroupColumns`. These should appear at the end.\n // We don't have to worry about full updates, as in this case the arrays are correct, and they won't appear in the updated lists.\n let existingColumnStateUpdates = {};\n const orderColumns = (updatedColumnState, colList, enableProp, initialEnableProp, indexProp, initialIndexProp) => {\n if (!colList.length || !this.primaryColumns) {\n return [];\n }\n const updatedColIdArray = Object.keys(updatedColumnState);\n const updatedColIds = new Set(updatedColIdArray);\n const newColIds = new Set(updatedColIdArray);\n const allColIds = new Set(colList.map(column => {\n const colId = column.getColId();\n newColIds.delete(colId);\n return colId;\n }).concat(updatedColIdArray));\n const colIdsInOriginalOrder = [];\n const originalOrderMap = {};\n let orderIndex = 0;\n for (let i = 0; i < this.primaryColumns.length; i++) {\n const colId = this.primaryColumns[i].getColId();\n if (allColIds.has(colId)) {\n colIdsInOriginalOrder.push(colId);\n originalOrderMap[colId] = orderIndex++;\n }\n }\n // follow approach in `resetColumnState`\n let index = 1000;\n let hasAddedNewCols = false;\n let lastIndex = 0;\n const processPrecedingNewCols = (colId) => {\n const originalOrderIndex = originalOrderMap[colId];\n for (let i = lastIndex; i < originalOrderIndex; i++) {\n const newColId = colIdsInOriginalOrder[i];\n if (newColIds.has(newColId)) {\n updatedColumnState[newColId][indexProp] = index++;\n newColIds.delete(newColId);\n }\n }\n lastIndex = originalOrderIndex;\n };\n colList.forEach(column => {\n const colId = column.getColId();\n if (updatedColIds.has(colId)) {\n // New col already exists. Add any other new cols that should be before it.\n processPrecedingNewCols(colId);\n updatedColumnState[colId][indexProp] = index++;\n }\n else {\n const colDef = column.getColDef();\n const missingIndex = colDef[indexProp] === null || (colDef[indexProp] === undefined && colDef[initialIndexProp] == null);\n if (missingIndex) {\n if (!hasAddedNewCols) {\n const propEnabled = colDef[enableProp] || (colDef[enableProp] === undefined && colDef[initialEnableProp]);\n if (propEnabled) {\n processPrecedingNewCols(colId);\n }\n else {\n // Reached the first manually added column. Add all the new columns now.\n newColIds.forEach(newColId => {\n // Rather than increment the index, just use the original order index - doesn't need to be contiguous.\n updatedColumnState[newColId][indexProp] = index + originalOrderMap[newColId];\n });\n index += colIdsInOriginalOrder.length;\n hasAddedNewCols = true;\n }\n }\n if (!existingColumnStateUpdates[colId]) {\n existingColumnStateUpdates[colId] = { colId };\n }\n existingColumnStateUpdates[colId][indexProp] = index++;\n }\n }\n });\n };\n orderColumns(updatedRowGroupColumnState, this.rowGroupColumns, 'rowGroup', 'initialRowGroup', 'rowGroupIndex', 'initialRowGroupIndex');\n orderColumns(updatedPivotColumnState, this.pivotColumns, 'pivot', 'initialPivot', 'pivotIndex', 'initialPivotIndex');\n return Object.values(existingColumnStateUpdates);\n }\n};\n__decorate([\n Autowired('expressionService')\n], ColumnModel.prototype, \"expressionService\", void 0);\n__decorate([\n Autowired('columnFactory')\n], ColumnModel.prototype, \"columnFactory\", void 0);\n__decorate([\n Autowired('displayedGroupCreator')\n], ColumnModel.prototype, \"displayedGroupCreator\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], ColumnModel.prototype, \"ctrlsService\", void 0);\n__decorate([\n Autowired('autoWidthCalculator')\n], ColumnModel.prototype, \"autoWidthCalculator\", void 0);\n__decorate([\n Autowired('columnUtils')\n], ColumnModel.prototype, \"columnUtils\", void 0);\n__decorate([\n Autowired('columnAnimationService')\n], ColumnModel.prototype, \"columnAnimationService\", void 0);\n__decorate([\n Autowired('autoGroupColService')\n], ColumnModel.prototype, \"autoGroupColService\", void 0);\n__decorate([\n Optional('aggFuncService')\n], ColumnModel.prototype, \"aggFuncService\", void 0);\n__decorate([\n Optional('valueCache')\n], ColumnModel.prototype, \"valueCache\", void 0);\n__decorate([\n Optional('animationFrameService')\n], ColumnModel.prototype, \"animationFrameService\", void 0);\n__decorate([\n Autowired('sortController')\n], ColumnModel.prototype, \"sortController\", void 0);\n__decorate([\n Autowired('columnDefFactory')\n], ColumnModel.prototype, \"columnDefFactory\", void 0);\n__decorate([\n PostConstruct\n], ColumnModel.prototype, \"init\", null);\n__decorate([\n PreDestroy\n], ColumnModel.prototype, \"destroyColumns\", null);\n__decorate([\n __param(0, Qualifier('loggerFactory'))\n], ColumnModel.prototype, \"setBeans\", null);\nColumnModel = __decorate([\n Bean('columnModel')\n], ColumnModel);\nexport { ColumnModel };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { ColumnGroup } from \"../entities/columnGroup.mjs\";\nimport { ProvidedColumnGroup } from \"../entities/providedColumnGroup.mjs\";\nimport { Bean } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { attrToNumber } from \"../utils/generic.mjs\";\n// takes in a list of columns, as specified by the column definitions, and returns column groups\nlet ColumnUtils = class ColumnUtils extends BeanStub {\n calculateColMinWidth(colDef) {\n return colDef.minWidth != null ? colDef.minWidth : this.environment.getMinColWidth();\n }\n calculateColMaxWidth(colDef) {\n return colDef.maxWidth != null ? colDef.maxWidth : Number.MAX_SAFE_INTEGER;\n }\n calculateColInitialWidth(colDef) {\n const minColWidth = this.calculateColMinWidth(colDef);\n const maxColWidth = this.calculateColMaxWidth(colDef);\n let width;\n const colDefWidth = attrToNumber(colDef.width);\n const colDefInitialWidth = attrToNumber(colDef.initialWidth);\n if (colDefWidth != null) {\n width = colDefWidth;\n }\n else if (colDefInitialWidth != null) {\n width = colDefInitialWidth;\n }\n else {\n width = 200;\n }\n return Math.max(Math.min(width, maxColWidth), minColWidth);\n }\n getOriginalPathForColumn(column, originalBalancedTree) {\n const result = [];\n let found = false;\n const recursePath = (balancedColumnTree, dept) => {\n for (let i = 0; i < balancedColumnTree.length; i++) {\n if (found) {\n return;\n }\n // quit the search, so 'result' is kept with the found result\n const node = balancedColumnTree[i];\n if (node instanceof ProvidedColumnGroup) {\n const nextNode = node;\n recursePath(nextNode.getChildren(), dept + 1);\n result[dept] = node;\n }\n else if (node === column) {\n found = true;\n }\n }\n };\n recursePath(originalBalancedTree, 0);\n // we should always find the path, but in case there is a bug somewhere, returning null\n // will make it fail rather than provide a 'hard to track down' bug\n return found ? result : null;\n }\n depthFirstOriginalTreeSearch(parent, tree, callback) {\n if (!tree) {\n return;\n }\n tree.forEach((child) => {\n if (child instanceof ProvidedColumnGroup) {\n this.depthFirstOriginalTreeSearch(child, child.getChildren(), callback);\n }\n callback(child, parent);\n });\n }\n depthFirstAllColumnTreeSearch(tree, callback) {\n if (!tree) {\n return;\n }\n tree.forEach((child) => {\n if (child instanceof ColumnGroup) {\n this.depthFirstAllColumnTreeSearch(child.getChildren(), callback);\n }\n callback(child);\n });\n }\n depthFirstDisplayedColumnTreeSearch(tree, callback) {\n if (!tree) {\n return;\n }\n tree.forEach((child) => {\n if (child instanceof ColumnGroup) {\n this.depthFirstDisplayedColumnTreeSearch(child.getDisplayedChildren(), callback);\n }\n callback(child);\n });\n }\n};\nColumnUtils = __decorate([\n Bean('columnUtils')\n], ColumnUtils);\nexport { ColumnUtils };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { ColumnGroup } from \"../entities/columnGroup.mjs\";\nimport { Bean } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { exists } from \"../utils/generic.mjs\";\n// takes in a list of columns, as specified by the column definitions, and returns column groups\nlet DisplayedGroupCreator = class DisplayedGroupCreator extends BeanStub {\n createDisplayedGroups(\n // all displayed columns sorted - this is the columns the grid should show\n sortedVisibleColumns, \n // creates unique id's for the group\n groupInstanceIdCreator, \n // whether it's left, right or center col\n pinned, \n // we try to reuse old groups if we can, to allow gui to do animation\n oldDisplayedGroups) {\n const oldColumnsMapped = this.mapOldGroupsById(oldDisplayedGroups);\n /**\n * The following logic starts at the leaf level of columns, iterating through them to build their parent\n * groups when the parents match.\n *\n * The created groups are then added to an array, and similarly iterated on until we reach the top level.\n *\n * When row groups have no original parent, it's added to the result.\n */\n const topLevelResultCols = [];\n // this is an array of cols or col groups at one level of depth, starting from leaf and ending at root\n let groupsOrColsAtCurrentLevel = sortedVisibleColumns;\n while (groupsOrColsAtCurrentLevel.length) {\n // store what's currently iterating so the function can build the next level of col groups\n const currentlyIterating = groupsOrColsAtCurrentLevel;\n groupsOrColsAtCurrentLevel = [];\n // store the index of the last row which was different from the previous row, this is used as a slice\n // index for finding the children to group together\n let lastGroupedColIdx = 0;\n // create a group of children from lastGroupedColIdx to the provided `to` parameter\n const createGroupToIndex = (to) => {\n const from = lastGroupedColIdx;\n lastGroupedColIdx = to;\n const previousNode = currentlyIterating[from];\n const previousNodeProvided = previousNode instanceof ColumnGroup ? previousNode.getProvidedColumnGroup() : previousNode;\n const previousNodeParent = previousNodeProvided.getOriginalParent();\n if (previousNodeParent == null) {\n // if the last node was different, and had a null parent, then we add all the nodes to the final\n // results)\n for (let i = from; i < to; i++) {\n topLevelResultCols.push(currentlyIterating[i]);\n }\n return;\n }\n // the parent differs from the previous node, so we create a group from the previous node\n // and add all to the result array, except the current node.\n const newGroup = this.createColumnGroup(previousNodeParent, groupInstanceIdCreator, oldColumnsMapped, pinned);\n for (let i = from; i < to; i++) {\n newGroup.addChild(currentlyIterating[i]);\n }\n groupsOrColsAtCurrentLevel.push(newGroup);\n };\n for (let i = 1; i < currentlyIterating.length; i++) {\n const thisNode = currentlyIterating[i];\n const thisNodeProvided = thisNode instanceof ColumnGroup ? thisNode.getProvidedColumnGroup() : thisNode;\n const thisNodeParent = thisNodeProvided.getOriginalParent();\n const previousNode = currentlyIterating[lastGroupedColIdx];\n const previousNodeProvided = previousNode instanceof ColumnGroup ? previousNode.getProvidedColumnGroup() : previousNode;\n const previousNodeParent = previousNodeProvided.getOriginalParent();\n if (thisNodeParent !== previousNodeParent) {\n createGroupToIndex(i);\n }\n }\n if (lastGroupedColIdx < currentlyIterating.length) {\n createGroupToIndex(currentlyIterating.length);\n }\n }\n this.setupParentsIntoColumns(topLevelResultCols, null);\n return topLevelResultCols;\n }\n createColumnGroup(providedGroup, groupInstanceIdCreator, oldColumnsMapped, pinned) {\n const groupId = providedGroup.getGroupId();\n const instanceId = groupInstanceIdCreator.getInstanceIdForKey(groupId);\n const uniqueId = ColumnGroup.createUniqueId(groupId, instanceId);\n let columnGroup = oldColumnsMapped[uniqueId];\n // if the user is setting new colDefs, it is possible that the id's overlap, and we\n // would have a false match from above. so we double check we are talking about the\n // same original column group.\n if (columnGroup && columnGroup.getProvidedColumnGroup() !== providedGroup) {\n columnGroup = null;\n }\n if (exists(columnGroup)) {\n // clean out the old column group here, as we will be adding children into it again\n columnGroup.reset();\n }\n else {\n columnGroup = new ColumnGroup(providedGroup, groupId, instanceId, pinned);\n this.context.createBean(columnGroup);\n }\n return columnGroup;\n }\n // returns back a 2d map of ColumnGroup as follows: groupId -> instanceId -> ColumnGroup\n mapOldGroupsById(displayedGroups) {\n const result = {};\n const recursive = (columnsOrGroups) => {\n columnsOrGroups.forEach(columnOrGroup => {\n if (columnOrGroup instanceof ColumnGroup) {\n const columnGroup = columnOrGroup;\n result[columnOrGroup.getUniqueId()] = columnGroup;\n recursive(columnGroup.getChildren());\n }\n });\n };\n if (displayedGroups) {\n recursive(displayedGroups);\n }\n return result;\n }\n setupParentsIntoColumns(columnsOrGroups, parent) {\n columnsOrGroups.forEach(columnsOrGroup => {\n columnsOrGroup.setParent(parent);\n if (columnsOrGroup instanceof ColumnGroup) {\n const columnGroup = columnsOrGroup;\n this.setupParentsIntoColumns(columnGroup.getChildren(), columnGroup);\n }\n });\n }\n};\nDisplayedGroupCreator = __decorate([\n Bean('displayedGroupCreator')\n], DisplayedGroupCreator);\nexport { DisplayedGroupCreator };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nlet AgStackComponentsRegistry = class AgStackComponentsRegistry extends BeanStub {\n constructor() {\n super(...arguments);\n this.componentsMappedByName = {};\n }\n setupComponents(components) {\n if (components) {\n components.forEach(componentMeta => this.addComponent(componentMeta));\n }\n }\n addComponent(componentMeta) {\n // get name of the class as a string\n // insert a dash after every capital letter\n // let classEscaped = className.replace(/([A-Z])/g, \"-$1\").toLowerCase();\n const classEscaped = componentMeta.componentName.replace(/([a-z])([A-Z])/g, \"$1-$2\").toLowerCase();\n // put all to upper case\n const classUpperCase = classEscaped.toUpperCase();\n // finally store\n this.componentsMappedByName[classUpperCase] = componentMeta.componentClass;\n }\n getComponentClass(htmlTag) {\n return this.componentsMappedByName[htmlTag];\n }\n};\nAgStackComponentsRegistry = __decorate([\n Bean('agStackComponentsRegistry')\n], AgStackComponentsRegistry);\nexport { AgStackComponentsRegistry };\n","// ARIA HELPER FUNCTIONS\nfunction toggleAriaAttribute(element, attribute, value) {\n if (value == null || value == '') {\n removeAriaAttribute(element, attribute);\n }\n else {\n setAriaAttribute(element, attribute, value);\n }\n}\nfunction setAriaAttribute(element, attribute, value) {\n element.setAttribute(ariaAttributeName(attribute), value.toString());\n}\nfunction removeAriaAttribute(element, attribute) {\n element.removeAttribute(ariaAttributeName(attribute));\n}\nfunction ariaAttributeName(attribute) {\n return `aria-${attribute}`;\n}\nexport function setAriaRole(element, role) {\n if (role) {\n element.setAttribute('role', role);\n }\n else {\n element.removeAttribute('role');\n }\n}\nexport function getAriaSortState(sortDirection) {\n let sort;\n if (sortDirection === 'asc') {\n sort = 'ascending';\n }\n else if (sortDirection === 'desc') {\n sort = 'descending';\n }\n else if (sortDirection === 'mixed') {\n sort = 'other';\n }\n else {\n sort = 'none';\n }\n return sort;\n}\n// ARIA ATTRIBUTE GETTERS\nexport function getAriaLevel(element) {\n return parseInt(element.getAttribute('aria-level'), 10);\n}\nexport function getAriaPosInSet(element) {\n return parseInt(element.getAttribute('aria-posinset'), 10);\n}\nexport function getAriaDescribedBy(element) {\n return element.getAttribute('aria-describedby') || '';\n}\n// ARIA ATTRIBUTE SETTERS\nexport function setAriaLabel(element, label) {\n toggleAriaAttribute(element, 'label', label);\n}\nexport function setAriaLabelledBy(element, labelledBy) {\n toggleAriaAttribute(element, 'labelledby', labelledBy);\n}\nexport function setAriaDescription(element, description) {\n toggleAriaAttribute(element, 'description', description);\n}\nexport function setAriaDescribedBy(element, describedby) {\n toggleAriaAttribute(element, 'describedby', describedby);\n}\nexport function setAriaLive(element, live) {\n toggleAriaAttribute(element, 'live', live);\n}\nexport function setAriaLevel(element, level) {\n toggleAriaAttribute(element, 'level', level);\n}\nexport function setAriaDisabled(element, disabled) {\n toggleAriaAttribute(element, 'disabled', disabled);\n}\nexport function setAriaHidden(element, hidden) {\n toggleAriaAttribute(element, 'hidden', hidden);\n}\nexport function setAriaActiveDescendant(element, descendantId) {\n toggleAriaAttribute(element, 'activedescendant', descendantId);\n}\nexport function setAriaExpanded(element, expanded) {\n setAriaAttribute(element, 'expanded', expanded);\n}\nexport function removeAriaExpanded(element) {\n removeAriaAttribute(element, 'expanded');\n}\nexport function setAriaSetSize(element, setsize) {\n setAriaAttribute(element, 'setsize', setsize);\n}\nexport function setAriaPosInSet(element, position) {\n setAriaAttribute(element, 'posinset', position);\n}\nexport function setAriaMultiSelectable(element, multiSelectable) {\n setAriaAttribute(element, 'multiselectable', multiSelectable);\n}\nexport function setAriaRowCount(element, rowCount) {\n setAriaAttribute(element, 'rowcount', rowCount);\n}\nexport function setAriaRowIndex(element, rowIndex) {\n setAriaAttribute(element, 'rowindex', rowIndex);\n}\nexport function setAriaColCount(element, colCount) {\n setAriaAttribute(element, 'colcount', colCount);\n}\nexport function setAriaColIndex(element, colIndex) {\n setAriaAttribute(element, 'colindex', colIndex);\n}\nexport function setAriaColSpan(element, colSpan) {\n setAriaAttribute(element, 'colspan', colSpan);\n}\nexport function setAriaSort(element, sort) {\n setAriaAttribute(element, 'sort', sort);\n}\nexport function removeAriaSort(element) {\n removeAriaAttribute(element, 'sort');\n}\nexport function setAriaSelected(element, selected) {\n toggleAriaAttribute(element, 'selected', selected);\n}\nexport function setAriaChecked(element, checked) {\n setAriaAttribute(element, 'checked', checked === undefined ? 'mixed' : checked);\n}\nexport function setAriaControls(controllerElement, controlledElement) {\n toggleAriaAttribute(controllerElement, 'controls', controlledElement.id);\n setAriaLabelledBy(controlledElement, controllerElement.id);\n}\nexport function getAriaCheckboxStateName(translate, state) {\n return state === undefined\n ? translate('ariaIndeterminate', 'indeterminate')\n : (state === true\n ? translate('ariaChecked', 'checked')\n : translate('ariaUnchecked', 'unchecked'));\n}\n","/**\n * These variables are lazy loaded, as otherwise they try and get initialised when we are loading\n * unit tests and we don't have references to window or document in the unit tests\n */\nlet isSafari;\nlet safariVersion;\nlet isChrome;\nlet isFirefox;\nlet isMacOs;\nlet isIOS;\nlet invisibleScrollbar;\nlet browserScrollbarWidth;\nexport function isBrowserSafari() {\n if (isSafari === undefined) {\n isSafari = /^((?!chrome|android).)*safari/i.test(navigator.userAgent);\n }\n return isSafari;\n}\nexport function getSafariVersion() {\n if (safariVersion === undefined) {\n if (isBrowserSafari()) {\n const versionMatch = navigator.userAgent.match(/version\\/(\\d+)/i);\n if (versionMatch) {\n safariVersion = versionMatch[1] != null ? parseFloat(versionMatch[1]) : 0;\n }\n }\n else {\n safariVersion = 0;\n }\n }\n return safariVersion;\n}\n/**\n * Returns true for Chrome and also for Edge (Chromium)\n */\nexport function isBrowserChrome() {\n if (isChrome === undefined) {\n const win = window;\n isChrome = (!!win.chrome && (!!win.chrome.webstore || !!win.chrome.runtime)) ||\n (/Chrome/.test(navigator.userAgent) && /Google Inc/.test(navigator.vendor));\n }\n return isChrome;\n}\nexport function isBrowserFirefox() {\n if (isFirefox === undefined) {\n isFirefox = /(firefox)/i.test(navigator.userAgent);\n }\n return isFirefox;\n}\nexport function isMacOsUserAgent() {\n if (isMacOs === undefined) {\n isMacOs = /(Mac|iPhone|iPod|iPad)/i.test(navigator.platform);\n }\n return isMacOs;\n}\nexport function isIOSUserAgent() {\n if (isIOS === undefined) {\n isIOS = (/iPad|iPhone|iPod/.test(navigator.platform) ||\n // eslint-disable-next-line\n (navigator.platform === 'MacIntel' && navigator.maxTouchPoints > 1));\n }\n return isIOS;\n}\nexport function browserSupportsPreventScroll() {\n // all browsers except safari support focus({ preventScroll: true }).\n // this feature was added on Safari 15+\n return !isBrowserSafari() || getSafariVersion() >= 15;\n}\nexport function getTabIndex(el) {\n if (!el) {\n return null;\n }\n const numberTabIndex = el.tabIndex;\n const tabIndex = el.getAttribute('tabIndex');\n if (numberTabIndex === -1 && (tabIndex === null || (tabIndex === '' && !isBrowserFirefox()))) {\n return null;\n }\n return numberTabIndex.toString();\n}\nexport function getMaxDivHeight() {\n if (!document.body) {\n return -1;\n }\n let res = 1000000;\n // FF reports the height back but still renders blank after ~6M px\n const testUpTo = navigator.userAgent.toLowerCase().match(/firefox/) ? 6000000 : 1000000000;\n const div = document.createElement('div');\n document.body.appendChild(div);\n while (true) {\n const test = res * 2;\n div.style.height = test + 'px';\n if (test > testUpTo || div.clientHeight !== test) {\n break;\n }\n else {\n res = test;\n }\n }\n document.body.removeChild(div);\n return res;\n}\nexport function getBodyWidth() {\n var _a, _b, _c;\n return (_b = (_a = document.body) === null || _a === void 0 ? void 0 : _a.clientWidth) !== null && _b !== void 0 ? _b : (window.innerHeight || ((_c = document.documentElement) === null || _c === void 0 ? void 0 : _c.clientWidth) || -1);\n}\nexport function getBodyHeight() {\n var _a, _b, _c;\n return (_b = (_a = document.body) === null || _a === void 0 ? void 0 : _a.clientHeight) !== null && _b !== void 0 ? _b : (window.innerHeight || ((_c = document.documentElement) === null || _c === void 0 ? void 0 : _c.clientHeight) || -1);\n}\nexport function getScrollbarWidth() {\n if (browserScrollbarWidth == null) {\n initScrollbarWidthAndVisibility();\n }\n return browserScrollbarWidth;\n}\nfunction initScrollbarWidthAndVisibility() {\n const body = document.body;\n const div = document.createElement('div');\n div.style.width = div.style.height = '100px';\n div.style.opacity = '0';\n div.style.overflow = 'scroll';\n div.style.msOverflowStyle = 'scrollbar'; // needed for WinJS apps\n div.style.position = 'absolute';\n body.appendChild(div);\n let width = div.offsetWidth - div.clientWidth;\n // if width is 0 and client width is 0, means the DOM isn't ready\n if (width === 0 && div.clientWidth === 0) {\n width = null;\n }\n // remove div\n if (div.parentNode) {\n div.parentNode.removeChild(div);\n }\n if (width != null) {\n browserScrollbarWidth = width;\n invisibleScrollbar = width === 0;\n }\n}\nexport function isInvisibleScrollbar() {\n if (invisibleScrollbar == null) {\n initScrollbarWidthAndVisibility();\n }\n return invisibleScrollbar;\n}\n","export function padStartWidthZeros(value, totalStringSize) {\n return value.toString().padStart(totalStringSize, '0');\n}\nexport function createArrayOfNumbers(first, last) {\n const result = [];\n for (let i = first; i <= last; i++) {\n result.push(i);\n }\n return result;\n}\nexport function cleanNumber(value) {\n if (typeof value === 'string') {\n value = parseInt(value, 10);\n }\n if (typeof value === 'number') {\n return Math.floor(value);\n }\n return null;\n}\nexport function decToHex(number, bytes) {\n let hex = '';\n for (let i = 0; i < bytes; i++) {\n hex += String.fromCharCode(number & 0xff);\n number >>>= 8;\n }\n return hex;\n}\nexport function formatNumberTwoDecimalPlacesAndCommas(value, thousandSeparator, decimalSeparator) {\n if (typeof value !== 'number') {\n return '';\n }\n return formatNumberCommas(Math.round(value * 100) / 100, thousandSeparator, decimalSeparator);\n}\n/**\n * the native method number.toLocaleString(undefined, {minimumFractionDigits: 0})\n * puts in decimal places in IE, so we use this method instead\n * from: http://blog.tompawlak.org/number-currency-formatting-javascript\n * @param {number} value\n * @returns {string}\n */\nexport function formatNumberCommas(value, thousandSeparator, decimalSeparator) {\n if (typeof value !== 'number') {\n return '';\n }\n return value.toString().replace('.', decimalSeparator).replace(/(\\d)(?=(\\d{3})+(?!\\d))/g, `$1${thousandSeparator}`);\n}\nexport function sum(values) {\n return values == null ? null : values.reduce((total, value) => total + value, 0);\n}\nexport function zeroOrGreater(value, defaultValue) {\n if (value >= 0) {\n return value;\n }\n // zero gets returned if number is missing or the wrong type\n return defaultValue;\n}\nexport function oneOrGreater(value, defaultValue) {\n const valueNumber = parseInt(value, 10);\n if (!isNaN(valueNumber) && isFinite(valueNumber) && valueNumber > 0) {\n return valueNumber;\n }\n return defaultValue;\n}\n","import { padStartWidthZeros } from './number.mjs';\n/**\n * Serialises a Date to a string of format `yyyy-MM-dd HH:mm:ss`.\n * An alternative separator can be provided to be used instead of hyphens.\n * @param date The date to serialise\n * @param includeTime Whether to include the time in the serialised string\n * @param separator The separator to use between date parts\n */\nexport function serialiseDate(date, includeTime = true, separator = '-') {\n if (!date) {\n return null;\n }\n let serialised = [date.getFullYear(), date.getMonth() + 1, date.getDate()].map(part => padStartWidthZeros(part, 2)).join(separator);\n if (includeTime) {\n serialised += ' ' + [date.getHours(), date.getMinutes(), date.getSeconds()].map(part => padStartWidthZeros(part, 2)).join(':');\n }\n return serialised;\n}\nconst calculateOrdinal = (value) => {\n if (value > 3 && value < 21) {\n return 'th';\n }\n const remainder = value % 10;\n switch (remainder) {\n case 1: return \"st\";\n case 2: return \"nd\";\n case 3: return \"rd\";\n }\n return 'th';\n};\n/**\n * Serialises a Date to a string of format the defined format, does not include time.\n * @param date The date to serialise\n * @param format The string to format the date to, defaults to YYYY-MM-DD\n */\nexport function dateToFormattedString(date, format = 'YYYY-MM-DD') {\n const fullYear = padStartWidthZeros(date.getFullYear(), 4);\n const months = [\n 'January', 'February', 'March', 'April', 'May', 'June',\n 'July', 'August', 'September', 'October', 'November', 'December',\n ];\n const days = [\n 'Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday',\n ];\n const replace = {\n YYYY: () => fullYear.slice(fullYear.length - 4, fullYear.length),\n YY: () => fullYear.slice(fullYear.length - 2, fullYear.length),\n Y: () => `${date.getFullYear()}`,\n MMMM: () => months[date.getMonth()],\n MMM: () => months[date.getMonth()].slice(0, 3),\n MM: () => padStartWidthZeros(date.getMonth() + 1, 2),\n Mo: () => `${date.getMonth() + 1}${calculateOrdinal(date.getMonth() + 1)}`,\n M: () => `${date.getMonth() + 1}`,\n Do: () => `${date.getDate()}${calculateOrdinal(date.getDate())}`,\n DD: () => padStartWidthZeros(date.getDate(), 2),\n D: () => `${date.getDate()}`,\n dddd: () => days[date.getDay()],\n ddd: () => days[date.getDay()].slice(0, 3),\n dd: () => days[date.getDay()].slice(0, 2),\n do: () => `${date.getDay()}${calculateOrdinal(date.getDay())}`,\n d: () => `${date.getDay()}`,\n };\n const regexp = new RegExp(Object.keys(replace).join('|'), 'g');\n return format.replace(regexp, (match) => {\n if (match in replace) {\n return replace[match]();\n }\n return match;\n });\n}\n/**\n * Parses a date and time from a string in the format `yyyy-MM-dd HH:mm:ss`\n */\nexport function parseDateTimeFromString(value) {\n if (!value) {\n return null;\n }\n const [dateStr, timeStr] = value.split(' ');\n if (!dateStr) {\n return null;\n }\n const fields = dateStr.split('-').map(f => parseInt(f, 10));\n if (fields.filter(f => !isNaN(f)).length !== 3) {\n return null;\n }\n const [year, month, day] = fields;\n const date = new Date(year, month - 1, day);\n if (date.getFullYear() !== year ||\n date.getMonth() !== month - 1 ||\n date.getDate() !== day) {\n // date was not parsed as expected so must have been invalid\n return null;\n }\n if (!timeStr || timeStr === '00:00:00') {\n return date;\n }\n const [hours, minutes, seconds] = timeStr.split(':').map(part => parseInt(part, 10));\n if (hours >= 0 && hours < 24) {\n date.setHours(hours);\n }\n if (minutes >= 0 && minutes < 60) {\n date.setMinutes(minutes);\n }\n if (seconds >= 0 && seconds < 60) {\n date.setSeconds(seconds);\n }\n return date;\n}\n","import { browserSupportsPreventScroll, isBrowserChrome, isBrowserSafari } from './browser.mjs';\nimport { exists } from './generic.mjs';\nimport { setAriaHidden } from './aria.mjs';\nimport { camelCaseToHyphenated } from './string.mjs';\nlet rtlNegativeScroll;\n/**\n * This method adds a class to an element and remove that class from all siblings.\n * Useful for toggling state.\n * @param {HTMLElement} element The element to receive the class\n * @param {string} elementClass The class to be assigned to the element\n * @param {boolean} otherElementClass The class to be assigned to siblings of the element, but not the element itself\n */\nexport function radioCssClass(element, elementClass, otherElementClass) {\n const parent = element.parentElement;\n let sibling = parent && parent.firstChild;\n while (sibling) {\n if (elementClass) {\n sibling.classList.toggle(elementClass, sibling === element);\n }\n if (otherElementClass) {\n sibling.classList.toggle(otherElementClass, sibling !== element);\n }\n sibling = sibling.nextSibling;\n }\n}\nexport const FOCUSABLE_SELECTOR = '[tabindex], input, select, button, textarea, [href]';\nexport const FOCUSABLE_EXCLUDE = '.ag-hidden, .ag-hidden *, [disabled], .ag-disabled:not(.ag-button), .ag-disabled *.mjs';\nexport function isFocusableFormField(element) {\n const matches = Element.prototype.matches || Element.prototype.msMatchesSelector;\n const inputSelector = 'input, select, button, textarea';\n const isFocusable = matches.call(element, inputSelector);\n const isNotFocusable = matches.call(element, FOCUSABLE_EXCLUDE);\n const isElementVisible = isVisible(element);\n const focusable = isFocusable && !isNotFocusable && isElementVisible;\n return focusable;\n}\nexport function setDisplayed(element, displayed, options = {}) {\n const { skipAriaHidden } = options;\n element.classList.toggle('ag-hidden', !displayed);\n if (!skipAriaHidden) {\n setAriaHidden(element, !displayed);\n }\n}\nexport function setVisible(element, visible, options = {}) {\n const { skipAriaHidden } = options;\n element.classList.toggle('ag-invisible', !visible);\n if (!skipAriaHidden) {\n setAriaHidden(element, !visible);\n }\n}\nexport function setDisabled(element, disabled) {\n const attributeName = 'disabled';\n const addOrRemoveDisabledAttribute = disabled ?\n (e) => e.setAttribute(attributeName, '') :\n (e) => e.removeAttribute(attributeName);\n addOrRemoveDisabledAttribute(element);\n nodeListForEach(element.querySelectorAll('input'), input => addOrRemoveDisabledAttribute(input));\n}\nexport function isElementChildOfClass(element, cls, maxNest) {\n let counter = 0;\n while (element) {\n if (element.classList.contains(cls)) {\n return true;\n }\n element = element.parentElement;\n if (typeof maxNest == 'number') {\n if (++counter > maxNest) {\n break;\n }\n }\n else if (element === maxNest) {\n break;\n }\n }\n return false;\n}\n// returns back sizes as doubles instead of strings. similar to\n// getBoundingClientRect, however getBoundingClientRect does not:\n// a) work with fractions (eg browser is zooming)\n// b) has CSS transitions applied (eg CSS scale, browser zoom), which we don't want, we want the un-transitioned values\nexport function getElementSize(el) {\n const { height, width, borderTopWidth, borderRightWidth, borderBottomWidth, borderLeftWidth, paddingTop, paddingRight, paddingBottom, paddingLeft, marginTop, marginRight, marginBottom, marginLeft, boxSizing } = window.getComputedStyle(el);\n return {\n height: parseFloat(height),\n width: parseFloat(width),\n borderTopWidth: parseFloat(borderTopWidth),\n borderRightWidth: parseFloat(borderRightWidth),\n borderBottomWidth: parseFloat(borderBottomWidth),\n borderLeftWidth: parseFloat(borderLeftWidth),\n paddingTop: parseFloat(paddingTop),\n paddingRight: parseFloat(paddingRight),\n paddingBottom: parseFloat(paddingBottom),\n paddingLeft: parseFloat(paddingLeft),\n marginTop: parseFloat(marginTop),\n marginRight: parseFloat(marginRight),\n marginBottom: parseFloat(marginBottom),\n marginLeft: parseFloat(marginLeft),\n boxSizing\n };\n}\nexport function getInnerHeight(el) {\n const size = getElementSize(el);\n if (size.boxSizing === 'border-box') {\n return size.height - size.paddingTop - size.paddingBottom;\n }\n return size.height;\n}\nexport function getInnerWidth(el) {\n const size = getElementSize(el);\n if (size.boxSizing === 'border-box') {\n return size.width - size.paddingLeft - size.paddingRight;\n }\n return size.width;\n}\nexport function getAbsoluteHeight(el) {\n const size = getElementSize(el);\n const marginRight = size.marginBottom + size.marginTop;\n return Math.ceil(el.offsetHeight + marginRight);\n}\nexport function getAbsoluteWidth(el) {\n const size = getElementSize(el);\n const marginWidth = size.marginLeft + size.marginRight;\n return Math.ceil(el.offsetWidth + marginWidth);\n}\nexport function getElementRectWithOffset(el) {\n const offsetElementRect = el.getBoundingClientRect();\n const { borderTopWidth, borderLeftWidth, borderRightWidth, borderBottomWidth } = getElementSize(el);\n return {\n top: offsetElementRect.top + (borderTopWidth || 0),\n left: offsetElementRect.left + (borderLeftWidth || 0),\n right: offsetElementRect.right + (borderRightWidth || 0),\n bottom: offsetElementRect.bottom + (borderBottomWidth || 0),\n };\n}\nexport function isRtlNegativeScroll() {\n if (typeof rtlNegativeScroll === \"boolean\") {\n return rtlNegativeScroll;\n }\n const template = document.createElement('div');\n template.style.direction = 'rtl';\n template.style.width = '1px';\n template.style.height = '1px';\n template.style.position = 'fixed';\n template.style.top = '0px';\n template.style.overflow = 'hidden';\n template.dir = 'rtl';\n template.innerHTML = /* html */\n `
\n \n \n
`;\n document.body.appendChild(template);\n template.scrollLeft = 1;\n rtlNegativeScroll = Math.floor(template.scrollLeft) === 0;\n document.body.removeChild(template);\n return rtlNegativeScroll;\n}\nexport function getScrollLeft(element, rtl) {\n let scrollLeft = element.scrollLeft;\n if (rtl) {\n // Absolute value - for FF that reports RTL scrolls in negative numbers\n scrollLeft = Math.abs(scrollLeft);\n if (isBrowserChrome() && !isRtlNegativeScroll()) {\n scrollLeft = element.scrollWidth - element.clientWidth - scrollLeft;\n }\n }\n return scrollLeft;\n}\nexport function setScrollLeft(element, value, rtl) {\n if (rtl) {\n // Chrome and Safari when doing RTL have the END position of the scroll as zero, not the start\n if (isRtlNegativeScroll()) {\n value *= -1;\n }\n else if (isBrowserSafari() || isBrowserChrome()) {\n value = element.scrollWidth - element.clientWidth - value;\n }\n }\n element.scrollLeft = value;\n}\nexport function clearElement(el) {\n while (el && el.firstChild) {\n el.removeChild(el.firstChild);\n }\n}\n/** @deprecated */\nexport function removeElement(parent, cssSelector) {\n removeFromParent(parent.querySelector(cssSelector));\n}\nexport function removeFromParent(node) {\n if (node && node.parentNode) {\n node.parentNode.removeChild(node);\n }\n}\nexport function isVisible(element) {\n return element.offsetParent !== null;\n}\n/**\n * Loads the template and returns it as an element. makes up for no simple way in\n * the dom api to load html directly, eg we cannot do this: document.createElement(template)\n * @param {string} template\n * @returns {HTMLElement}\n */\nexport function loadTemplate(template) {\n const tempDiv = document.createElement('div');\n tempDiv.innerHTML = (template || '').trim();\n return tempDiv.firstChild;\n}\nexport function appendHtml(eContainer, htmlTemplate) {\n if (eContainer.lastChild) {\n // https://developer.mozilla.org/en-US/docs/Web/API/Element/insertAdjacentHTML\n // we put the items at the start, so new items appear underneath old items,\n // so when expanding/collapsing groups, the new rows don't go on top of the\n // rows below that are moving our of the way\n eContainer.insertAdjacentHTML('afterbegin', htmlTemplate);\n }\n else {\n eContainer.innerHTML = htmlTemplate;\n }\n}\n/** @deprecated */\nexport function getElementAttribute(element, attributeName) {\n if (element.attributes && element.attributes[attributeName]) {\n const attribute = element.attributes[attributeName];\n return attribute.value;\n }\n return null;\n}\nexport function offsetHeight(element) {\n return element && element.clientHeight ? element.clientHeight : 0;\n}\nexport function offsetWidth(element) {\n return element && element.clientWidth ? element.clientWidth : 0;\n}\nexport function ensureDomOrder(eContainer, eChild, eChildBefore) {\n // if already in right order, do nothing\n if (eChildBefore && eChildBefore.nextSibling === eChild) {\n return;\n }\n const focusedEl = document.activeElement;\n const eChildHasFocus = eChild.contains(focusedEl);\n if (eChildBefore) {\n if (eChildBefore.nextSibling) {\n // insert between the eRowBefore and the row after it\n eContainer.insertBefore(eChild, eChildBefore.nextSibling);\n }\n else {\n // if nextSibling is missing, means other row is at end, so just append new row at the end\n eContainer.appendChild(eChild);\n }\n }\n else {\n // otherwise put at start\n if (eContainer.firstChild && eContainer.firstChild !== eChild) {\n // insert it at the first location\n eContainer.insertAdjacentElement('afterbegin', eChild);\n }\n }\n if (eChildHasFocus && focusedEl && browserSupportsPreventScroll()) {\n focusedEl.focus({ preventScroll: true });\n }\n}\nexport function setDomChildOrder(eContainer, orderedChildren) {\n for (let i = 0; i < orderedChildren.length; i++) {\n const correctCellAtIndex = orderedChildren[i];\n const actualCellAtIndex = eContainer.children[i];\n if (actualCellAtIndex !== correctCellAtIndex) {\n eContainer.insertBefore(correctCellAtIndex, actualCellAtIndex);\n }\n }\n}\nexport function insertWithDomOrder(eContainer, eToInsert, eChildBefore) {\n if (eChildBefore) {\n // if previous element exists, just slot in after the previous element\n eChildBefore.insertAdjacentElement('afterend', eToInsert);\n }\n else {\n if (eContainer.firstChild) {\n // insert it at the first location\n eContainer.insertAdjacentElement('afterbegin', eToInsert);\n }\n else {\n // otherwise eContainer is empty, so just append it\n eContainer.appendChild(eToInsert);\n }\n }\n}\n/** @deprecated */\nexport function prependDC(parent, documentFragment) {\n if (exists(parent.firstChild)) {\n parent.insertBefore(documentFragment, parent.firstChild);\n }\n else {\n parent.appendChild(documentFragment);\n }\n}\nexport function addStylesToElement(eElement, styles) {\n if (!styles) {\n return;\n }\n for (const [key, value] of Object.entries(styles)) {\n if (!key || !key.length || value == null) {\n continue;\n }\n // changes the key from camelCase into a hyphenated-string\n const parsedKey = camelCaseToHyphenated(key);\n const valueAsString = value.toString();\n const parsedValue = valueAsString.replace(/\\s*!important/g, '');\n const priority = parsedValue.length != valueAsString.length ? 'important' : undefined;\n eElement.style.setProperty(parsedKey, parsedValue, priority);\n }\n}\nexport function isHorizontalScrollShowing(element) {\n return element.clientWidth < element.scrollWidth;\n}\nexport function isVerticalScrollShowing(element) {\n return element.clientHeight < element.scrollHeight;\n}\nexport function setElementWidth(element, width) {\n if (width === 'flex') {\n element.style.removeProperty('width');\n element.style.removeProperty('minWidth');\n element.style.removeProperty('maxWidth');\n element.style.flex = '1 1 auto';\n }\n else {\n setFixedWidth(element, width);\n }\n}\nexport function setFixedWidth(element, width) {\n width = formatSize(width);\n element.style.width = width.toString();\n element.style.maxWidth = width.toString();\n element.style.minWidth = width.toString();\n}\nexport function setElementHeight(element, height) {\n if (height === 'flex') {\n element.style.removeProperty('height');\n element.style.removeProperty('minHeight');\n element.style.removeProperty('maxHeight');\n element.style.flex = '1 1 auto';\n }\n else {\n setFixedHeight(element, height);\n }\n}\nexport function setFixedHeight(element, height) {\n height = formatSize(height);\n element.style.height = height.toString();\n element.style.maxHeight = height.toString();\n element.style.minHeight = height.toString();\n}\nexport function formatSize(size) {\n if (typeof size === 'number') {\n return `${size}px`;\n }\n return size;\n}\nexport function isNodeOrElement(o) {\n return o instanceof Node || o instanceof HTMLElement;\n}\n/**\n * Makes a copy of a node list into a list\n * @param {NodeList} nodeList\n * @returns {Node[]}\n */\nexport function copyNodeList(nodeList) {\n if (nodeList == null) {\n return [];\n }\n const result = [];\n nodeListForEach(nodeList, node => result.push(node));\n return result;\n}\nexport function iterateNamedNodeMap(map, callback) {\n if (!map) {\n return;\n }\n for (let i = 0; i < map.length; i++) {\n const attr = map[i];\n callback(attr.name, attr.value);\n }\n}\nexport function addOrRemoveAttribute(element, name, value) {\n if (value == null) {\n element.removeAttribute(name);\n }\n else {\n element.setAttribute(name, value.toString());\n }\n}\nexport function nodeListForEach(nodeList, action) {\n if (nodeList == null) {\n return;\n }\n for (let i = 0; i < nodeList.length; i++) {\n action(nodeList[i]);\n }\n}\n/**\n * cell renderers are used in a few places. they bind to dom slightly differently to other cell renders as they\n * can return back strings (instead of html element) in the getGui() method. common code placed here to handle that.\n * @param {AgPromise} cellRendererPromise\n * @param {HTMLElement} eTarget\n */\nexport function bindCellRendererToHtmlElement(cellRendererPromise, eTarget) {\n cellRendererPromise.then(cellRenderer => {\n const gui = cellRenderer.getGui();\n if (gui != null) {\n if (typeof gui === 'object') {\n eTarget.appendChild(gui);\n }\n else {\n eTarget.innerHTML = gui;\n }\n }\n });\n}\n","import { loadTemplate, isNodeOrElement } from './dom.mjs';\nimport { setAriaRole } from './aria.mjs';\n//\n// IMPORTANT NOTE!\n//\n// If you change the list below, copy/paste the new content into the docs page custom-icons\n//\nexport const iconNameClassMap = {\n // header column group shown when expanded (click to contract)\n columnGroupOpened: 'expanded',\n // header column group shown when contracted (click to expand)\n columnGroupClosed: 'contracted',\n // tool panel column group contracted (click to expand)\n columnSelectClosed: 'tree-closed',\n // tool panel column group expanded (click to contract)\n columnSelectOpen: 'tree-open',\n // column tool panel header expand/collapse all button, shown when some children are expanded and\n // others are collapsed\n columnSelectIndeterminate: 'tree-indeterminate',\n // shown on ghost icon while dragging column to the side of the grid to pin\n columnMovePin: 'pin',\n // shown on ghost icon while dragging over part of the page that is not a drop zone\n columnMoveHide: 'eye-slash',\n // shown on ghost icon while dragging columns to reorder\n columnMoveMove: 'arrows',\n // animating icon shown when dragging a column to the right of the grid causes horizontal scrolling\n columnMoveLeft: 'left',\n // animating icon shown when dragging a column to the left of the grid causes horizontal scrolling\n columnMoveRight: 'right',\n // shown on ghost icon while dragging over Row Groups drop zone\n columnMoveGroup: 'group',\n // shown on ghost icon while dragging over Values drop zone\n columnMoveValue: 'aggregation',\n // shown on ghost icon while dragging over pivot drop zone\n columnMovePivot: 'pivot',\n // shown on ghost icon while dragging over drop zone that doesn't support it, e.g.\n // string column over aggregation drop zone\n dropNotAllowed: 'not-allowed',\n // shown on row group when contracted (click to expand)\n groupContracted: 'tree-closed',\n // shown on row group when expanded (click to contract)\n groupExpanded: 'tree-open',\n // set filter tree list group contracted (click to expand)\n setFilterGroupClosed: 'tree-closed',\n // set filter tree list group expanded (click to contract)\n setFilterGroupOpen: 'tree-open',\n // set filter tree list expand/collapse all button, shown when some children are expanded and\n // others are collapsed\n setFilterGroupIndeterminate: 'tree-indeterminate',\n // context menu chart item\n chart: 'chart',\n // chart window title bar\n close: 'cross',\n // X (remove) on column 'pill' after adding it to a drop zone list\n cancel: 'cancel',\n // indicates the currently active pin state in the \"Pin column\" sub-menu of the column menu\n check: 'tick',\n // \"go to first\" button in pagination controls\n first: 'first',\n // \"go to previous\" button in pagination controls\n previous: 'previous',\n // \"go to next\" button in pagination controls\n next: 'next',\n // \"go to last\" button in pagination controls\n last: 'last',\n // shown on top right of chart when chart is linked to range data (click to unlink)\n linked: 'linked',\n // shown on top right of chart when chart is not linked to range data (click to link)\n unlinked: 'unlinked',\n // \"Choose colour\" button on chart settings tab\n colorPicker: 'color-picker',\n // rotating spinner shown by the loading cell renderer\n groupLoading: 'loading',\n // button to launch enterprise column menu\n menu: 'menu',\n // filter tool panel tab\n filter: 'filter',\n // column tool panel tab\n columns: 'columns',\n // button in chart regular size window title bar (click to maximise)\n maximize: 'maximize',\n // button in chart maximised window title bar (click to make regular size)\n minimize: 'minimize',\n // \"Pin column\" item in column header menu\n menuPin: 'pin',\n // \"Value aggregation\" column menu item (shown on numeric columns when grouping is active)\"\n menuValue: 'aggregation',\n // \"Group by {column-name}\" item in column header menu\n menuAddRowGroup: 'group',\n // \"Un-Group by {column-name}\" item in column header menu\n menuRemoveRowGroup: 'group',\n // context menu copy item\n clipboardCopy: 'copy',\n // context menu cut item\n clipboardCut: 'cut',\n // context menu paste item\n clipboardPaste: 'paste',\n // identifies the pivot drop zone\n pivotPanel: 'pivot',\n // \"Row groups\" drop zone in column tool panel\n rowGroupPanel: 'group',\n // columns tool panel Values drop zone\n valuePanel: 'aggregation',\n // drag handle used to pick up draggable columns\n columnDrag: 'grip',\n // drag handle used to pick up draggable rows\n rowDrag: 'grip',\n // context menu export item\n save: 'save',\n // csv export\n csvExport: 'csv',\n // excel export,\n excelExport: 'excel',\n // icon on dropdown editors\n smallDown: 'small-down',\n // version of small-right used in RTL mode\n smallLeft: 'small-left',\n // separater between column 'pills' when you add multiple columns to the header drop zone\n smallRight: 'small-right',\n smallUp: 'small-up',\n // show on column header when column is sorted ascending\n sortAscending: 'asc',\n // show on column header when column is sorted descending\n sortDescending: 'desc',\n // show on column header when column has no sort, only when enabled with gridOptions.unSortIcon=true\n sortUnSort: 'none',\n // Builder button in Advanced Filter\n advancedFilterBuilder: 'group',\n // drag handle used to pick up Advanced Filter Builder rows\n advancedFilterBuilderDrag: 'grip',\n // Advanced Filter Builder row validation error\n advancedFilterBuilderInvalid: 'not-allowed',\n // shown on Advanced Filter Builder rows to move them up\n advancedFilterBuilderMoveUp: 'up',\n // shown on Advanced Filter Builder rows to move them down\n advancedFilterBuilderMoveDown: 'down',\n // shown on Advanced Filter Builder rows to add new rows\n advancedFilterBuilderAdd: 'plus',\n // shown on Advanced Filter Builder rows to remove row\n advancedFilterBuilderRemove: 'minus',\n};\n/**\n * If icon provided, use this (either a string, or a function callback).\n * if not, then use the default icon from the theme\n * @param {string} iconName\n * @param {GridOptionsService} gridOptionsService\n * @param {Column | null} [column]\n * @returns {Element}\n */\nexport function createIcon(iconName, gridOptionsService, column) {\n const iconContents = createIconNoSpan(iconName, gridOptionsService, column);\n if (iconContents) {\n const { className } = iconContents;\n if ((typeof className === 'string' && className.indexOf('ag-icon') > -1) ||\n (typeof className === 'object' && className['ag-icon'])) {\n return iconContents;\n }\n }\n const eResult = document.createElement('span');\n eResult.appendChild(iconContents);\n return eResult;\n}\nexport function createIconNoSpan(iconName, gridOptionsService, column, forceCreate) {\n let userProvidedIcon = null;\n // check col for icon first\n const icons = column && column.getColDef().icons;\n if (icons) {\n userProvidedIcon = icons[iconName];\n }\n // if not in col, try grid options\n if (gridOptionsService && !userProvidedIcon) {\n const optionsIcons = gridOptionsService.get('icons');\n if (optionsIcons) {\n userProvidedIcon = optionsIcons[iconName];\n }\n }\n // now if user provided, use it\n if (userProvidedIcon) {\n let rendererResult;\n if (typeof userProvidedIcon === 'function') {\n rendererResult = userProvidedIcon();\n }\n else if (typeof userProvidedIcon === 'string') {\n rendererResult = userProvidedIcon;\n }\n else {\n throw new Error('icon from grid options needs to be a string or a function');\n }\n if (typeof rendererResult === 'string') {\n return loadTemplate(rendererResult);\n }\n if (isNodeOrElement(rendererResult)) {\n return rendererResult;\n }\n console.warn('AG Grid: iconRenderer should return back a string or a dom object');\n }\n else {\n const span = document.createElement('span');\n let cssClass = iconNameClassMap[iconName];\n if (!cssClass) {\n if (!forceCreate) {\n console.warn(`AG Grid: Did not find icon ${iconName}`);\n cssClass = '';\n }\n else {\n cssClass = iconName;\n }\n }\n span.setAttribute('class', `ag-icon ag-icon-${cssClass}`);\n span.setAttribute('unselectable', 'on');\n setAriaRole(span, 'presentation');\n return span;\n }\n}\n","export class KeyCode {\n}\nKeyCode.BACKSPACE = 'Backspace';\nKeyCode.TAB = 'Tab';\nKeyCode.ENTER = 'Enter';\nKeyCode.ESCAPE = 'Escape';\nKeyCode.SPACE = ' ';\nKeyCode.LEFT = 'ArrowLeft';\nKeyCode.UP = 'ArrowUp';\nKeyCode.RIGHT = 'ArrowRight';\nKeyCode.DOWN = 'ArrowDown';\nKeyCode.DELETE = 'Delete';\nKeyCode.F2 = 'F2';\nKeyCode.PAGE_UP = 'PageUp';\nKeyCode.PAGE_DOWN = 'PageDown';\nKeyCode.PAGE_HOME = 'Home';\nKeyCode.PAGE_END = 'End';\n// these should be used with `event.code` instead of `event.key`\n// as `event.key` changes when non-latin keyboards are used\nKeyCode.A = 'KeyA';\nKeyCode.C = 'KeyC';\nKeyCode.D = 'KeyD';\nKeyCode.V = 'KeyV';\nKeyCode.X = 'KeyX';\nKeyCode.Y = 'KeyY';\nKeyCode.Z = 'KeyZ';\n","import { KeyCode } from '../constants/keyCode.mjs';\nimport { isMacOsUserAgent } from './browser.mjs';\nimport { exists } from './generic.mjs';\nconst A_KEYCODE = 65;\nconst C_KEYCODE = 67;\nconst V_KEYCODE = 86;\nconst D_KEYCODE = 68;\nconst Z_KEYCODE = 90;\nconst Y_KEYCODE = 89;\nexport function isEventFromPrintableCharacter(event) {\n // no allowed printable chars have alt or ctrl key combinations\n if (event.altKey || event.ctrlKey || event.metaKey) {\n return false;\n }\n // if key is length 1, eg if it is 'a' for the a key, or '2' for the '2' key.\n // non-printable characters have names, eg 'Enter' or 'Backspace'.\n const printableCharacter = event.key.length === 1;\n return printableCharacter;\n}\n/**\n * Allows user to tell the grid to skip specific keyboard events\n * @param {GridOptionsService} gridOptionsService\n * @param {KeyboardEvent} keyboardEvent\n * @param {IRowNode} rowNode\n * @param {Column} column\n * @param {boolean} editing\n * @returns {boolean}\n */\nexport function isUserSuppressingKeyboardEvent(gridOptionsService, keyboardEvent, rowNode, column, editing) {\n const colDefFunc = column ? column.getColDef().suppressKeyboardEvent : undefined;\n // if no callbacks provided by user, then do nothing\n if (!colDefFunc) {\n return false;\n }\n const params = {\n event: keyboardEvent,\n editing,\n column,\n api: gridOptionsService.api,\n node: rowNode,\n data: rowNode.data,\n colDef: column.getColDef(),\n context: gridOptionsService.context,\n columnApi: gridOptionsService.columnApi\n };\n // colDef get first preference on suppressing events\n if (colDefFunc) {\n const colDefFuncResult = colDefFunc(params);\n // if colDef func suppressed, then return now, no need to call gridOption func\n if (colDefFuncResult) {\n return true;\n }\n }\n // otherwise return false, don't suppress, as colDef didn't suppress and no func on gridOptions\n return false;\n}\nexport function isUserSuppressingHeaderKeyboardEvent(gridOptionsService, keyboardEvent, headerRowIndex, column) {\n const colDef = column.getDefinition();\n const colDefFunc = colDef && colDef.suppressHeaderKeyboardEvent;\n if (!exists(colDefFunc)) {\n return false;\n }\n const params = {\n api: gridOptionsService.api,\n columnApi: gridOptionsService.columnApi,\n context: gridOptionsService.context,\n colDef: colDef,\n column,\n headerRowIndex,\n event: keyboardEvent\n };\n return !!colDefFunc(params);\n}\nexport function normaliseQwertyAzerty(keyboardEvent) {\n const { keyCode } = keyboardEvent;\n let code;\n switch (keyCode) {\n case A_KEYCODE:\n code = KeyCode.A;\n break;\n case C_KEYCODE:\n code = KeyCode.C;\n break;\n case V_KEYCODE:\n code = KeyCode.V;\n break;\n case D_KEYCODE:\n code = KeyCode.D;\n break;\n case Z_KEYCODE:\n code = KeyCode.Z;\n break;\n case Y_KEYCODE:\n code = KeyCode.Y;\n break;\n default:\n code = keyboardEvent.code;\n }\n return code;\n}\nexport function isDeleteKey(key, alwaysReturnFalseOnBackspace = false) {\n if (key === KeyCode.DELETE) {\n return true;\n }\n if (!alwaysReturnFalseOnBackspace && key === KeyCode.BACKSPACE) {\n return isMacOsUserAgent();\n }\n return false;\n}\n","/**\n * `True` if the event is close to the original event by X pixels either vertically or horizontally.\n * we only start dragging after X pixels so this allows us to know if we should start dragging yet.\n * @param {MouseEvent | TouchEvent} e1\n * @param {MouseEvent | TouchEvent} e2\n * @param {number} pixelCount\n * @returns {boolean}\n */\nexport function areEventsNear(e1, e2, pixelCount) {\n // by default, we wait 4 pixels before starting the drag\n if (pixelCount === 0) {\n return false;\n }\n const diffX = Math.abs(e1.clientX - e2.clientX);\n const diffY = Math.abs(e1.clientY - e2.clientY);\n return Math.max(diffX, diffY) <= pixelCount;\n}\n","/**\n * Gets called by: a) ClientSideNodeManager and b) GroupStage to do sorting.\n * when in ClientSideNodeManager we always have indexes (as this sorts the items the\n * user provided) but when in GroupStage, the nodes can contain filler nodes that\n * don't have order id's\n * @param {RowNode[]} rowNodes\n * @param {Object} rowNodeOrder\n *\n * @returns a boolean representing whether nodes were reordered\n */\nexport function sortRowNodesByOrder(rowNodes, rowNodeOrder) {\n if (!rowNodes) {\n return false;\n }\n const comparator = (nodeA, nodeB) => {\n const positionA = rowNodeOrder[nodeA.id];\n const positionB = rowNodeOrder[nodeB.id];\n const aHasIndex = positionA !== undefined;\n const bHasIndex = positionB !== undefined;\n const bothNodesAreUserNodes = aHasIndex && bHasIndex;\n const bothNodesAreFillerNodes = !aHasIndex && !bHasIndex;\n if (bothNodesAreUserNodes) {\n // when comparing two nodes the user has provided, they always\n // have indexes\n return positionA - positionB;\n }\n if (bothNodesAreFillerNodes) {\n // when comparing two filler nodes, we have no index to compare them\n // against, however we want this sorting to be deterministic, so that\n // the rows don't jump around as the user does delta updates. so we\n // want the same sort result. so we use the __objectId - which doesn't make sense\n // from a sorting point of view, but does give consistent behaviour between\n // calls. otherwise groups jump around as delta updates are done.\n // note: previously here we used nodeId, however this gave a strange order\n // as string ordering of numbers is wrong, so using id based on creation order\n // as least gives better looking order.\n return nodeA.__objectId - nodeB.__objectId;\n }\n if (aHasIndex) {\n return 1;\n }\n return -1;\n };\n // check if the list first needs sorting\n let rowNodeA;\n let rowNodeB;\n let atLeastOneOutOfOrder = false;\n for (let i = 0; i < rowNodes.length - 1; i++) {\n rowNodeA = rowNodes[i];\n rowNodeB = rowNodes[i + 1];\n if (comparator(rowNodeA, rowNodeB) > 0) {\n atLeastOneOutOfOrder = true;\n break;\n }\n }\n if (atLeastOneOutOfOrder) {\n rowNodes.sort(comparator);\n return true;\n }\n return false;\n}\nexport function traverseNodesWithKey(nodes, callback) {\n const keyParts = [];\n recursiveSearchNodes(nodes);\n function recursiveSearchNodes(currentNodes) {\n if (!currentNodes) {\n return;\n }\n currentNodes.forEach((node) => {\n // also checking for children for tree data\n if (node.group || node.hasChildren()) {\n keyParts.push(node.key);\n const key = keyParts.join('|');\n callback(node, key);\n recursiveSearchNodes(node.childrenAfterGroup);\n keyParts.pop();\n }\n });\n }\n}\n","export function convertToSet(list) {\n const set = new Set();\n list.forEach(x => set.add(x));\n return set;\n}\n","import * as AriaUtils from './aria.mjs';\nimport * as ArrayUtils from './array.mjs';\nimport * as BrowserUtils from './browser.mjs';\nimport * as DateUtils from './date.mjs';\nimport * as DomUtils from './dom.mjs';\nimport * as EventUtils from './event.mjs';\nimport * as FunctionUtils from './function.mjs';\nimport * as FuzzyMatchUtils from './fuzzyMatch.mjs';\nimport * as GenericUtils from './generic.mjs';\nimport * as IconUtils from './icon.mjs';\nimport * as KeyboardUtils from './keyboard.mjs';\nimport * as MapUtils from './map.mjs';\nimport * as MouseUtils from './mouse.mjs';\nimport * as NumberUtils from './number.mjs';\nimport * as ObjectUtils from './object.mjs';\nimport * as RowNodeUtils from './rowNode.mjs';\nimport * as SetUtils from './set.mjs';\nimport * as StringUtils from './string.mjs';\nconst utils = Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({}, AriaUtils), ArrayUtils), BrowserUtils), DateUtils), DomUtils), EventUtils), FunctionUtils), FuzzyMatchUtils), GenericUtils), IconUtils), KeyboardUtils), MapUtils), MouseUtils), NumberUtils), ObjectUtils), RowNodeUtils), SetUtils), StringUtils);\nexport const _ = utils;\n","export class NumberSequence {\n constructor(initValue = 0, step = 1) {\n this.nextValue = initValue;\n this.step = step;\n }\n next() {\n const valToReturn = this.nextValue;\n this.nextValue += this.step;\n return valToReturn;\n }\n peek() {\n return this.nextValue;\n }\n skip(count) {\n this.nextValue += count;\n }\n}\n","export var AgPromiseStatus;\n(function (AgPromiseStatus) {\n AgPromiseStatus[AgPromiseStatus[\"IN_PROGRESS\"] = 0] = \"IN_PROGRESS\";\n AgPromiseStatus[AgPromiseStatus[\"RESOLVED\"] = 1] = \"RESOLVED\";\n})(AgPromiseStatus || (AgPromiseStatus = {}));\nexport class AgPromise {\n constructor(callback) {\n this.status = AgPromiseStatus.IN_PROGRESS;\n this.resolution = null;\n this.waiters = [];\n callback(value => this.onDone(value), params => this.onReject(params));\n }\n static all(promises) {\n return new AgPromise(resolve => {\n let remainingToResolve = promises.length;\n const combinedValues = new Array(remainingToResolve);\n promises.forEach((promise, index) => {\n promise.then(value => {\n combinedValues[index] = value;\n remainingToResolve--;\n if (remainingToResolve === 0) {\n resolve(combinedValues);\n }\n });\n });\n });\n }\n static resolve(value = null) {\n return new AgPromise(resolve => resolve(value));\n }\n then(func) {\n return new AgPromise(resolve => {\n if (this.status === AgPromiseStatus.RESOLVED) {\n resolve(func(this.resolution));\n }\n else {\n this.waiters.push(value => resolve(func(value)));\n }\n });\n }\n resolveNow(ifNotResolvedValue, ifResolved) {\n return this.status === AgPromiseStatus.RESOLVED ? ifResolved(this.resolution) : ifNotResolvedValue;\n }\n onDone(value) {\n this.status = AgPromiseStatus.RESOLVED;\n this.resolution = value;\n this.waiters.forEach(waiter => waiter(value));\n }\n onReject(params) {\n console.warn('TBI');\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { exists } from \"../utils/generic.mjs\";\nimport { isIOSUserAgent } from \"../utils/browser.mjs\";\nimport { doOnce } from \"../utils/function.mjs\";\nimport { Events } from \"../eventKeys.mjs\";\nvar TooltipStates;\n(function (TooltipStates) {\n TooltipStates[TooltipStates[\"NOTHING\"] = 0] = \"NOTHING\";\n TooltipStates[TooltipStates[\"WAITING_TO_SHOW\"] = 1] = \"WAITING_TO_SHOW\";\n TooltipStates[TooltipStates[\"SHOWING\"] = 2] = \"SHOWING\";\n})(TooltipStates || (TooltipStates = {}));\nvar TooltipTrigger;\n(function (TooltipTrigger) {\n TooltipTrigger[TooltipTrigger[\"HOVER\"] = 0] = \"HOVER\";\n TooltipTrigger[TooltipTrigger[\"FOCUS\"] = 1] = \"FOCUS\";\n})(TooltipTrigger || (TooltipTrigger = {}));\nexport class CustomTooltipFeature extends BeanStub {\n constructor(parentComp, tooltipShowDelayOverride, tooltipHideDelayOverride) {\n super();\n this.parentComp = parentComp;\n this.tooltipShowDelayOverride = tooltipShowDelayOverride;\n this.tooltipHideDelayOverride = tooltipHideDelayOverride;\n this.DEFAULT_SHOW_TOOLTIP_DELAY = 2000;\n this.DEFAULT_HIDE_TOOLTIP_DELAY = 10000;\n this.SHOW_QUICK_TOOLTIP_DIFF = 1000;\n this.FADE_OUT_TOOLTIP_TIMEOUT = 1000;\n this.INTERACTIVE_HIDE_DELAY = 100;\n this.interactionEnabled = false;\n this.isInteractingWithTooltip = false;\n this.state = TooltipStates.NOTHING;\n // when showing the tooltip, we need to make sure it's the most recent instance we request, as due to\n // async we could request two tooltips before the first instance returns, in which case we should\n // disregard the second instance.\n this.tooltipInstanceCount = 0;\n this.tooltipMouseTrack = false;\n }\n postConstruct() {\n if (this.gridOptionsService.is('tooltipInteraction')) {\n this.interactionEnabled = true;\n }\n this.tooltipTrigger = this.getTooltipTrigger();\n this.tooltipShowDelay = this.getTooltipDelay('show');\n this.tooltipHideDelay = this.getTooltipDelay('hide');\n this.tooltipMouseTrack = this.gridOptionsService.is('tooltipMouseTrack');\n const el = this.parentComp.getGui();\n if (this.tooltipTrigger === TooltipTrigger.HOVER) {\n this.addManagedListener(el, 'mouseenter', this.onMouseEnter.bind(this));\n this.addManagedListener(el, 'mouseleave', this.onMouseLeave.bind(this));\n }\n if (this.tooltipTrigger === TooltipTrigger.FOCUS) {\n this.addManagedListener(el, 'focusin', this.onFocusIn.bind(this));\n this.addManagedListener(el, 'focusout', this.onFocusOut.bind(this));\n }\n this.addManagedListener(el, 'mousemove', this.onMouseMove.bind(this));\n if (!this.interactionEnabled) {\n this.addManagedListener(el, 'mousedown', this.onMouseDown.bind(this));\n this.addManagedListener(el, 'keydown', this.onKeyDown.bind(this));\n }\n }\n getGridOptionsTooltipDelay(delayOption) {\n const delay = this.gridOptionsService.getNum(delayOption);\n if (exists(delay)) {\n if (delay < 0) {\n doOnce(() => console.warn(`AG Grid: ${delayOption} should not be lower than 0`), `${delayOption}Warn`);\n }\n return Math.max(200, delay);\n }\n return undefined;\n }\n getTooltipDelay(type) {\n var _a, _b, _c, _d;\n if (type === 'show') {\n return (_b = (_a = this.getGridOptionsTooltipDelay('tooltipShowDelay')) !== null && _a !== void 0 ? _a : this.tooltipShowDelayOverride) !== null && _b !== void 0 ? _b : this.DEFAULT_SHOW_TOOLTIP_DELAY;\n }\n else {\n return (_d = (_c = this.getGridOptionsTooltipDelay('tooltipHideDelay')) !== null && _c !== void 0 ? _c : this.tooltipHideDelayOverride) !== null && _d !== void 0 ? _d : this.DEFAULT_HIDE_TOOLTIP_DELAY;\n }\n }\n destroy() {\n // if this component gets destroyed while tooltip is showing, need to make sure\n // we don't end with no mouseLeave event resulting in zombie tooltip\n this.setToDoNothing();\n super.destroy();\n }\n getTooltipTrigger() {\n const trigger = this.gridOptionsService.get('tooltipTrigger');\n if (!trigger || trigger === 'hover') {\n return TooltipTrigger.HOVER;\n }\n return TooltipTrigger.FOCUS;\n }\n onMouseEnter(e) {\n // if `interactiveTooltipTimeoutId` is set, it means that this cell has a tooltip\n // and we are in the process of moving the cursor from the tooltip back to the cell\n // so we need to unlock this service here.\n if (this.interactionEnabled && this.interactiveTooltipTimeoutId) {\n this.unlockService();\n this.startHideTimeout();\n }\n if (isIOSUserAgent()) {\n return;\n }\n if (CustomTooltipFeature.isLocked) {\n this.showTooltipTimeoutId = window.setTimeout(() => {\n this.prepareToShowTooltip(e);\n }, this.INTERACTIVE_HIDE_DELAY);\n }\n else {\n this.prepareToShowTooltip(e);\n }\n }\n onMouseMove(e) {\n // there is a delay from the time we mouseOver a component and the time the\n // tooltip is displayed, so we need to track mousemove to be able to correctly\n // position the tooltip when showTooltip is called.\n if (this.lastMouseEvent) {\n this.lastMouseEvent = e;\n }\n if (this.tooltipMouseTrack &&\n this.state === TooltipStates.SHOWING &&\n this.tooltipComp) {\n this.positionTooltip();\n }\n }\n onMouseDown() {\n this.setToDoNothing();\n }\n onMouseLeave() {\n // if interaction is enabled, we need to verify if the user is moving\n // the cursor from the cell onto the tooltip, so we lock the service \n // for 100ms to prevent other tooltips from being created while this is happening.\n if (this.interactionEnabled) {\n this.lockService();\n }\n else {\n this.setToDoNothing();\n }\n }\n onFocusIn() {\n this.prepareToShowTooltip();\n }\n onFocusOut(e) {\n var _a;\n const relatedTarget = e.relatedTarget;\n const parentCompGui = this.parentComp.getGui();\n const tooltipGui = (_a = this.tooltipComp) === null || _a === void 0 ? void 0 : _a.getGui();\n if (this.isInteractingWithTooltip ||\n parentCompGui.contains(relatedTarget) ||\n (this.interactionEnabled && (tooltipGui === null || tooltipGui === void 0 ? void 0 : tooltipGui.contains(relatedTarget)))) {\n return;\n }\n this.setToDoNothing();\n }\n onKeyDown() {\n this.setToDoNothing();\n }\n prepareToShowTooltip(mouseEvent) {\n // every mouseenter should be following by a mouseleave, however for some unknown, it's possible for\n // mouseenter to be called twice in a row, which can happen if editing the cell. this was reported\n // in https://ag-grid.atlassian.net/browse/AG-4422. to get around this, we check the state, and if\n // state is != nothing, then we know mouseenter was already received.\n if (this.state != TooltipStates.NOTHING || CustomTooltipFeature.isLocked) {\n return false;\n }\n // if we are showing the tooltip because of focus, no delay at all\n // if another tooltip was hidden very recently, we only wait 200ms to show, not the normal waiting time\n let delay = 0;\n if (mouseEvent) {\n delay = this.isLastTooltipHiddenRecently() ? 200 : this.tooltipShowDelay;\n }\n this.lastMouseEvent = mouseEvent || null;\n this.showTooltipTimeoutId = window.setTimeout(this.showTooltip.bind(this), delay);\n this.state = TooltipStates.WAITING_TO_SHOW;\n return true;\n }\n isLastTooltipHiddenRecently() {\n // return true if <1000ms since last time we hid a tooltip\n const now = new Date().getTime();\n const then = CustomTooltipFeature.lastTooltipHideTime;\n return (now - then) < this.SHOW_QUICK_TOOLTIP_DIFF;\n }\n setToDoNothing() {\n if (this.state === TooltipStates.SHOWING) {\n this.hideTooltip();\n }\n if (this.onBodyScrollEventCallback) {\n this.onBodyScrollEventCallback();\n this.onBodyScrollEventCallback = undefined;\n }\n if (this.onColumnMovedEventCallback) {\n this.onColumnMovedEventCallback();\n this.onColumnMovedEventCallback = undefined;\n }\n this.clearTimeouts();\n this.state = TooltipStates.NOTHING;\n this.lastMouseEvent = null;\n }\n showTooltip() {\n const params = Object.assign({}, this.parentComp.getTooltipParams());\n if (!exists(params.value)) {\n this.setToDoNothing();\n return;\n }\n this.state = TooltipStates.SHOWING;\n this.tooltipInstanceCount++;\n // we pass in tooltipInstanceCount so the callback knows what the count was when\n // we requested the tooltip, so if another tooltip was requested in the mean time\n // we disregard it\n const callback = this.newTooltipComponentCallback.bind(this, this.tooltipInstanceCount);\n const userDetails = this.userComponentFactory.getTooltipCompDetails(params);\n userDetails.newAgStackInstance().then(callback);\n }\n hideTooltip(forceHide) {\n if (!forceHide && this.isInteractingWithTooltip) {\n return;\n }\n // check if comp exists - due to async, although we asked for\n // one, the instance may not be back yet\n if (this.tooltipComp) {\n this.destroyTooltipComp();\n CustomTooltipFeature.lastTooltipHideTime = new Date().getTime();\n }\n const event = {\n type: Events.EVENT_TOOLTIP_HIDE,\n parentGui: this.parentComp.getGui()\n };\n this.eventService.dispatchEvent(event);\n this.state = TooltipStates.NOTHING;\n }\n newTooltipComponentCallback(tooltipInstanceCopy, tooltipComp) {\n const compNoLongerNeeded = this.state !== TooltipStates.SHOWING || this.tooltipInstanceCount !== tooltipInstanceCopy;\n if (compNoLongerNeeded) {\n this.getContext().destroyBean(tooltipComp);\n return;\n }\n const eGui = tooltipComp.getGui();\n this.tooltipComp = tooltipComp;\n if (!eGui.classList.contains('ag-tooltip')) {\n eGui.classList.add('ag-tooltip-custom');\n }\n if (this.tooltipTrigger === TooltipTrigger.HOVER) {\n eGui.classList.add('ag-tooltip-animate');\n }\n if (this.interactionEnabled) {\n eGui.classList.add('ag-tooltip-interactive');\n }\n const translate = this.localeService.getLocaleTextFunc();\n const addPopupRes = this.popupService.addPopup({\n eChild: eGui,\n ariaLabel: translate('ariaLabelTooltip', 'Tooltip')\n });\n if (addPopupRes) {\n this.tooltipPopupDestroyFunc = addPopupRes.hideFunc;\n }\n this.positionTooltip();\n if (this.tooltipTrigger === TooltipTrigger.FOCUS) {\n this.onBodyScrollEventCallback = this.addManagedListener(this.eventService, Events.EVENT_BODY_SCROLL, this.setToDoNothing.bind(this));\n this.onColumnMovedEventCallback = this.addManagedListener(this.eventService, Events.EVENT_COLUMN_MOVED, this.setToDoNothing.bind(this));\n }\n if (this.interactionEnabled) {\n if (this.tooltipTrigger === TooltipTrigger.HOVER) {\n this.tooltipMouseEnterListener = this.addManagedListener(eGui, 'mouseenter', this.onTooltipMouseEnter.bind(this)) || null;\n this.tooltipMouseLeaveListener = this.addManagedListener(eGui, 'mouseleave', this.onTooltipMouseLeave.bind(this)) || null;\n }\n else {\n this.tooltipFocusInListener = this.addManagedListener(eGui, 'focusin', this.onTooltipFocusIn.bind(this)) || null;\n this.tooltipFocusOutListener = this.addManagedListener(eGui, 'focusout', this.onTooltipFocusOut.bind(this)) || null;\n }\n }\n const event = {\n type: Events.EVENT_TOOLTIP_SHOW,\n tooltipGui: eGui,\n parentGui: this.parentComp.getGui()\n };\n this.eventService.dispatchEvent(event);\n this.startHideTimeout();\n }\n onTooltipMouseEnter() {\n this.isInteractingWithTooltip = true;\n this.unlockService();\n }\n onTooltipMouseLeave() {\n this.isInteractingWithTooltip = false;\n this.lockService();\n }\n onTooltipFocusIn() {\n this.isInteractingWithTooltip = true;\n }\n onTooltipFocusOut(e) {\n var _a;\n const parentGui = this.parentComp.getGui();\n const tooltipGui = (_a = this.tooltipComp) === null || _a === void 0 ? void 0 : _a.getGui();\n const relatedTarget = e.relatedTarget;\n // focusout is dispatched when inner elements lose focus\n // so we need to verify if focus is contained within the tooltip\n if (tooltipGui === null || tooltipGui === void 0 ? void 0 : tooltipGui.contains(relatedTarget)) {\n return;\n }\n this.isInteractingWithTooltip = false;\n // if we move the focus from the tooltip back to the original cell\n // the tooltip should remain open, but we need to restart the hide timeout counter\n if (parentGui.contains(relatedTarget)) {\n this.startHideTimeout();\n }\n // if the parent cell doesn't contain the focus, simply hide the tooltip\n else {\n this.hideTooltip();\n }\n }\n positionTooltip() {\n const params = {\n type: 'tooltip',\n ePopup: this.tooltipComp.getGui(),\n nudgeY: 18,\n skipObserver: this.tooltipMouseTrack\n };\n if (this.lastMouseEvent) {\n this.popupService.positionPopupUnderMouseEvent(Object.assign(Object.assign({}, params), { mouseEvent: this.lastMouseEvent }));\n }\n else {\n this.popupService.positionPopupByComponent(Object.assign(Object.assign({}, params), { eventSource: this.parentComp.getGui(), position: 'under', keepWithinBounds: true, nudgeY: 5 }));\n }\n }\n destroyTooltipComp() {\n // add class to fade out the tooltip\n this.tooltipComp.getGui().classList.add('ag-tooltip-hiding');\n // make local copies of these variables, as we use them in the async function below,\n // and we clear then to 'undefined' later, so need to take a copy before they are undefined.\n const tooltipPopupDestroyFunc = this.tooltipPopupDestroyFunc;\n const tooltipComp = this.tooltipComp;\n const delay = this.tooltipTrigger === TooltipTrigger.HOVER ? this.FADE_OUT_TOOLTIP_TIMEOUT : 0;\n window.setTimeout(() => {\n tooltipPopupDestroyFunc();\n this.getContext().destroyBean(tooltipComp);\n }, delay);\n this.clearTooltipListeners();\n this.tooltipPopupDestroyFunc = undefined;\n this.tooltipComp = undefined;\n }\n clearTooltipListeners() {\n [\n this.tooltipMouseEnterListener, this.tooltipMouseLeaveListener,\n this.tooltipFocusInListener, this.tooltipFocusOutListener\n ].forEach(listener => {\n if (listener) {\n listener();\n }\n });\n this.tooltipMouseEnterListener = this.tooltipMouseLeaveListener =\n this.tooltipFocusInListener = this.tooltipFocusOutListener = null;\n }\n lockService() {\n CustomTooltipFeature.isLocked = true;\n this.interactiveTooltipTimeoutId = window.setTimeout(() => {\n this.unlockService();\n this.setToDoNothing();\n }, this.INTERACTIVE_HIDE_DELAY);\n }\n unlockService() {\n CustomTooltipFeature.isLocked = false;\n this.clearInteractiveTimeout();\n }\n startHideTimeout() {\n this.clearHideTimeout();\n this.hideTooltipTimeoutId = window.setTimeout(this.hideTooltip.bind(this), this.tooltipHideDelay);\n }\n clearShowTimeout() {\n if (!this.showTooltipTimeoutId) {\n return;\n }\n window.clearTimeout(this.showTooltipTimeoutId);\n this.showTooltipTimeoutId = undefined;\n }\n clearHideTimeout() {\n if (!this.hideTooltipTimeoutId) {\n return;\n }\n window.clearTimeout(this.hideTooltipTimeoutId);\n this.hideTooltipTimeoutId = undefined;\n }\n clearInteractiveTimeout() {\n if (!this.interactiveTooltipTimeoutId) {\n return;\n }\n window.clearTimeout(this.interactiveTooltipTimeoutId);\n this.interactiveTooltipTimeoutId = undefined;\n }\n clearTimeouts() {\n this.clearShowTimeout();\n this.clearHideTimeout();\n this.clearInteractiveTimeout();\n }\n}\nCustomTooltipFeature.isLocked = false;\n__decorate([\n Autowired('popupService')\n], CustomTooltipFeature.prototype, \"popupService\", void 0);\n__decorate([\n Autowired('userComponentFactory')\n], CustomTooltipFeature.prototype, \"userComponentFactory\", void 0);\n__decorate([\n PostConstruct\n], CustomTooltipFeature.prototype, \"postConstruct\", null);\n","export class CssClassManager {\n constructor(getGui) {\n // to minimise DOM hits, we only apply CSS classes if they have changed. as adding a CSS class that is already\n // there, or removing one that wasn't present, all takes CPU.\n this.cssClassStates = {};\n this.getGui = getGui;\n }\n addCssClass(className) {\n const list = (className || '').split(' ');\n if (list.length > 1) {\n list.forEach(cls => this.addCssClass(cls));\n return;\n }\n const updateNeeded = this.cssClassStates[className] !== true;\n if (updateNeeded && className.length) {\n const eGui = this.getGui();\n if (eGui) {\n eGui.classList.add(className);\n }\n this.cssClassStates[className] = true;\n }\n }\n removeCssClass(className) {\n const list = (className || '').split(' ');\n if (list.length > 1) {\n list.forEach(cls => this.removeCssClass(cls));\n return;\n }\n const updateNeeded = this.cssClassStates[className] !== false;\n if (updateNeeded && className.length) {\n const eGui = this.getGui();\n if (eGui) {\n eGui.classList.remove(className);\n }\n this.cssClassStates[className] = false;\n }\n }\n containsCssClass(className) {\n const eGui = this.getGui();\n if (!eGui) {\n return false;\n }\n return eGui.classList.contains(className);\n }\n addOrRemoveCssClass(className, addOrRemove) {\n if (!className) {\n return;\n }\n // we check for spaces before doing the split, as doing the split\n // created a performance problem (on windows only, see AG-6765)\n if (className.indexOf(' ') >= 0) {\n const list = (className || '').split(' ');\n if (list.length > 1) {\n list.forEach(cls => this.addOrRemoveCssClass(cls, addOrRemove));\n return;\n }\n }\n const updateNeeded = this.cssClassStates[className] !== addOrRemove;\n if (updateNeeded && className.length) {\n const eGui = this.getGui();\n if (eGui) {\n eGui.classList.toggle(className, addOrRemove);\n }\n this.cssClassStates[className] = addOrRemove;\n }\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PreConstruct } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { NumberSequence } from \"../utils/index.mjs\";\nimport { isNodeOrElement, copyNodeList, iterateNamedNodeMap, loadTemplate, setVisible, setDisplayed } from '../utils/dom.mjs';\nimport { getFunctionName } from '../utils/function.mjs';\nimport { CustomTooltipFeature } from \"./customTooltipFeature.mjs\";\nimport { CssClassManager } from \"../rendering/cssClassManager.mjs\";\nconst compIdSequence = new NumberSequence();\nexport class Component extends BeanStub {\n constructor(template) {\n super();\n // if false, then CSS class \"ag-hidden\" is applied, which sets \"display: none\"\n this.displayed = true;\n // if false, then CSS class \"ag-invisible\" is applied, which sets \"visibility: hidden\"\n this.visible = true;\n // unique id for this row component. this is used for getting a reference to the HTML dom.\n // we cannot use the RowNode id as this is not unique (due to animation, old rows can be lying\n // around as we create a new rowComp instance for the same row node).\n this.compId = compIdSequence.next();\n this.cssClassManager = new CssClassManager(() => this.eGui);\n if (template) {\n this.setTemplate(template);\n }\n }\n preConstructOnComponent() {\n this.usingBrowserTooltips = this.gridOptionsService.is('enableBrowserTooltips');\n }\n getCompId() {\n return this.compId;\n }\n getTooltipParams() {\n return {\n value: this.tooltipText,\n location: 'UNKNOWN'\n };\n }\n setTooltip(newTooltipText, showDelayOverride, hideDelayOverride) {\n const removeTooltip = () => {\n if (this.usingBrowserTooltips) {\n this.getGui().removeAttribute('title');\n }\n else {\n this.tooltipFeature = this.destroyBean(this.tooltipFeature);\n }\n };\n const addTooltip = () => {\n if (this.usingBrowserTooltips) {\n this.getGui().setAttribute('title', this.tooltipText);\n }\n else {\n this.tooltipFeature = this.createBean(new CustomTooltipFeature(this, showDelayOverride, hideDelayOverride));\n }\n };\n if (this.tooltipText != newTooltipText) {\n if (this.tooltipText) {\n removeTooltip();\n }\n if (newTooltipText != null) {\n this.tooltipText = newTooltipText;\n if (this.tooltipText) {\n addTooltip();\n }\n }\n }\n }\n // for registered components only, eg creates AgCheckbox instance from ag-checkbox HTML tag\n createChildComponentsFromTags(parentNode, paramsMap) {\n // we MUST take a copy of the list first, as the 'swapComponentForNode' adds comments into the DOM\n // which messes up the traversal order of the children.\n const childNodeList = copyNodeList(parentNode.childNodes);\n childNodeList.forEach(childNode => {\n if (!(childNode instanceof HTMLElement)) {\n return;\n }\n const childComp = this.createComponentFromElement(childNode, childComp => {\n // copy over all attributes, including css classes, so any attributes user put on the tag\n // wll be carried across\n const childGui = childComp.getGui();\n if (childGui) {\n this.copyAttributesFromNode(childNode, childComp.getGui());\n }\n }, paramsMap);\n if (childComp) {\n if (childComp.addItems && childNode.children.length) {\n this.createChildComponentsFromTags(childNode, paramsMap);\n // converting from HTMLCollection to Array\n const items = Array.prototype.slice.call(childNode.children);\n childComp.addItems(items);\n }\n // replace the tag (eg ag-checkbox) with the proper HTMLElement (eg 'div') in the dom\n this.swapComponentForNode(childComp, parentNode, childNode);\n }\n else if (childNode.childNodes) {\n this.createChildComponentsFromTags(childNode, paramsMap);\n }\n });\n }\n createComponentFromElement(element, afterPreCreateCallback, paramsMap) {\n const key = element.nodeName;\n const componentParams = paramsMap ? paramsMap[element.getAttribute('ref')] : undefined;\n const ComponentClass = this.agStackComponentsRegistry.getComponentClass(key);\n if (ComponentClass) {\n Component.elementGettingCreated = element;\n const newComponent = new ComponentClass(componentParams);\n newComponent.setParentComponent(this);\n this.createBean(newComponent, null, afterPreCreateCallback);\n return newComponent;\n }\n return null;\n }\n copyAttributesFromNode(source, dest) {\n iterateNamedNodeMap(source.attributes, (name, value) => dest.setAttribute(name, value));\n }\n swapComponentForNode(newComponent, parentNode, childNode) {\n const eComponent = newComponent.getGui();\n parentNode.replaceChild(eComponent, childNode);\n parentNode.insertBefore(document.createComment(childNode.nodeName), eComponent);\n this.addDestroyFunc(this.destroyBean.bind(this, newComponent));\n this.swapInComponentForQuerySelectors(newComponent, childNode);\n }\n swapInComponentForQuerySelectors(newComponent, childNode) {\n const thisNoType = this;\n this.iterateOverQuerySelectors((querySelector) => {\n if (thisNoType[querySelector.attributeName] === childNode) {\n thisNoType[querySelector.attributeName] = newComponent;\n }\n });\n }\n iterateOverQuerySelectors(action) {\n let thisPrototype = Object.getPrototypeOf(this);\n while (thisPrototype != null) {\n const metaData = thisPrototype.__agComponentMetaData;\n const currentProtoName = getFunctionName(thisPrototype.constructor);\n if (metaData && metaData[currentProtoName] && metaData[currentProtoName].querySelectors) {\n metaData[currentProtoName].querySelectors.forEach((querySelector) => action(querySelector));\n }\n thisPrototype = Object.getPrototypeOf(thisPrototype);\n }\n }\n activateTabIndex(elements) {\n const tabIndex = this.gridOptionsService.getNum('tabIndex') || 0;\n if (!elements) {\n elements = [];\n }\n if (!elements.length) {\n elements.push(this.getGui());\n }\n elements.forEach(el => el.setAttribute('tabindex', tabIndex.toString()));\n }\n setTemplate(template, paramsMap) {\n const eGui = loadTemplate(template);\n this.setTemplateFromElement(eGui, paramsMap);\n }\n setTemplateFromElement(element, paramsMap) {\n this.eGui = element;\n this.eGui.__agComponent = this;\n this.wireQuerySelectors();\n // context will not be available when user sets template in constructor\n if (!!this.getContext()) {\n this.createChildComponentsFromTags(this.getGui(), paramsMap);\n }\n }\n createChildComponentsPreConstruct() {\n // ui exists if user sets template in constructor. when this happens, we have to wait for the context\n // to be autoWired first before we can create child components.\n if (!!this.getGui()) {\n this.createChildComponentsFromTags(this.getGui());\n }\n }\n wireQuerySelectors() {\n if (!this.eGui) {\n return;\n }\n const thisNoType = this;\n this.iterateOverQuerySelectors((querySelector) => {\n const setResult = (result) => thisNoType[querySelector.attributeName] = result;\n // if it's a ref selector, and match is on top level component, we return\n // the element. otherwise no way of components putting ref=xxx on the top\n // level element as querySelector only looks at children.\n const topLevelRefMatch = querySelector.refSelector\n && this.getAttribute('ref') === querySelector.refSelector;\n if (topLevelRefMatch) {\n setResult(this.eGui);\n }\n else {\n // otherwise use querySelector, which looks at children\n const resultOfQuery = this.eGui.querySelector(querySelector.querySelector);\n if (resultOfQuery) {\n setResult(resultOfQuery.__agComponent || resultOfQuery);\n }\n }\n });\n }\n getGui() {\n return this.eGui;\n }\n getFocusableElement() {\n return this.eGui;\n }\n getAriaElement() {\n return this.getFocusableElement();\n }\n setParentComponent(component) {\n this.parentComponent = component;\n }\n getParentComponent() {\n return this.parentComponent;\n }\n // this method is for older code, that wants to provide the gui element,\n // it is not intended for this to be in ag-Stack\n setGui(eGui) {\n this.eGui = eGui;\n }\n queryForHtmlElement(cssSelector) {\n return this.eGui.querySelector(cssSelector);\n }\n queryForHtmlInputElement(cssSelector) {\n return this.eGui.querySelector(cssSelector);\n }\n appendChild(newChild, container) {\n if (newChild == null) {\n return;\n }\n if (!container) {\n container = this.eGui;\n }\n if (isNodeOrElement(newChild)) {\n container.appendChild(newChild);\n }\n else {\n const childComponent = newChild;\n container.appendChild(childComponent.getGui());\n }\n }\n isDisplayed() {\n return this.displayed;\n }\n setVisible(visible, options = {}) {\n if (visible !== this.visible) {\n this.visible = visible;\n const { skipAriaHidden } = options;\n setVisible(this.eGui, visible, { skipAriaHidden });\n }\n }\n setDisplayed(displayed, options = {}) {\n if (displayed !== this.displayed) {\n this.displayed = displayed;\n const { skipAriaHidden } = options;\n setDisplayed(this.eGui, displayed, { skipAriaHidden });\n const event = {\n type: Component.EVENT_DISPLAYED_CHANGED,\n visible: this.displayed\n };\n this.dispatchEvent(event);\n }\n }\n destroy() {\n if (this.tooltipFeature) {\n this.tooltipFeature = this.destroyBean(this.tooltipFeature);\n }\n if (this.parentComponent) {\n this.parentComponent = undefined;\n }\n const eGui = this.eGui;\n if (eGui && eGui.__agComponent) {\n eGui.__agComponent = undefined;\n }\n super.destroy();\n }\n addGuiEventListener(event, listener, options) {\n this.eGui.addEventListener(event, listener, options);\n this.addDestroyFunc(() => this.eGui.removeEventListener(event, listener));\n }\n addCssClass(className) {\n this.cssClassManager.addCssClass(className);\n }\n removeCssClass(className) {\n this.cssClassManager.removeCssClass(className);\n }\n containsCssClass(className) {\n return this.cssClassManager.containsCssClass(className);\n }\n addOrRemoveCssClass(className, addOrRemove) {\n this.cssClassManager.addOrRemoveCssClass(className, addOrRemove);\n }\n getAttribute(key) {\n const { eGui } = this;\n return eGui ? eGui.getAttribute(key) : null;\n }\n getRefElement(refName) {\n return this.queryForHtmlElement(`[ref=\"${refName}\"]`);\n }\n}\nComponent.EVENT_DISPLAYED_CHANGED = 'displayedChanged';\n__decorate([\n Autowired('agStackComponentsRegistry')\n], Component.prototype, \"agStackComponentsRegistry\", void 0);\n__decorate([\n PreConstruct\n], Component.prototype, \"preConstructOnComponent\", null);\n__decorate([\n PreConstruct\n], Component.prototype, \"createChildComponentsPreConstruct\", null);\n","import { getFunctionName } from '../utils/function.mjs';\nexport function QuerySelector(selector) {\n return querySelectorFunc.bind(this, selector, undefined);\n}\nexport function RefSelector(ref) {\n return querySelectorFunc.bind(this, `[ref=${ref}]`, ref);\n}\nfunction querySelectorFunc(selector, refSelector, classPrototype, methodOrAttributeName, index) {\n if (selector === null) {\n console.error('AG Grid: QuerySelector selector should not be null');\n return;\n }\n if (typeof index === 'number') {\n console.error('AG Grid: QuerySelector should be on an attribute');\n return;\n }\n addToObjectProps(classPrototype, 'querySelectors', {\n attributeName: methodOrAttributeName,\n querySelector: selector,\n refSelector: refSelector\n });\n}\n// // think we should take this out, put property bindings on the\n// export function Method(eventName?: string): Function {\n// return methodFunc.bind(this, eventName);\n// }\n//\n// function methodFunc(alias: string, target: Object, methodName: string) {\n// if (alias === null) {\n// console.error(\"AG Grid: EventListener eventName should not be null\");\n// return;\n// }\n//\n// addToObjectProps(target, 'methods', {\n// methodName: methodName,\n// alias: alias\n// });\n// }\nfunction addToObjectProps(target, key, value) {\n // it's an attribute on the class\n const props = getOrCreateProps(target, getFunctionName(target.constructor));\n if (!props[key]) {\n props[key] = [];\n }\n props[key].push(value);\n}\nfunction getOrCreateProps(target, instanceName) {\n if (!target.__agComponentMetaData) {\n target.__agComponentMetaData = {};\n }\n if (!target.__agComponentMetaData[instanceName]) {\n target.__agComponentMetaData[instanceName] = {};\n }\n return target.__agComponentMetaData[instanceName];\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from '../../../widgets/component.mjs';\nimport { RefSelector } from '../../../widgets/componentAnnotations.mjs';\nimport { Autowired } from '../../../context/context.mjs';\n// optional floating filter for user provided filters - instead of providing a floating filter,\n// they can provide a getModelAsString() method on the filter instead. this class just displays\n// the string returned from getModelAsString()\nexport class ReadOnlyFloatingFilter extends Component {\n constructor() {\n super(/* html */ `\n
\n \n
`);\n }\n // this is a user component, and IComponent has \"public destroy()\" as part of the interface.\n // so we need to override destroy() just to make the method public.\n destroy() {\n super.destroy();\n }\n init(params) {\n this.params = params;\n const displayName = this.columnModel.getDisplayNameForColumn(params.column, 'header', true);\n const translate = this.localeService.getLocaleTextFunc();\n this.eFloatingFilterText\n .setDisabled(true)\n .setInputAriaLabel(`${displayName} ${translate('ariaFilterInput', 'Filter Input')}`);\n }\n onParentModelChanged(parentModel) {\n if (!parentModel) {\n this.eFloatingFilterText.setValue('');\n return;\n }\n this.params.parentFilterInstance(filterInstance => {\n // it would be nice to check if getModelAsString was present before creating this component,\n // however that is not possible, as React Hooks and VueJS don't attached the methods to the Filter until\n // AFTER the filter is created, not allowing inspection before this (we create floating filters as columns\n // are drawn, but the parent filters are only created when needed).\n if (filterInstance.getModelAsString) {\n const modelAsString = filterInstance.getModelAsString(parentModel);\n this.eFloatingFilterText.setValue(modelAsString);\n }\n });\n }\n onParamsUpdated(params) {\n this.init(params);\n }\n}\n__decorate([\n RefSelector('eFloatingFilterText')\n], ReadOnlyFloatingFilter.prototype, \"eFloatingFilterText\", void 0);\n__decorate([\n Autowired('columnModel')\n], ReadOnlyFloatingFilter.prototype, \"columnModel\", void 0);\n","import { setDisplayed } from '../../../utils/dom.mjs';\n/** Provides sync access to async component. Date component can be lazy created - this class encapsulates\n * this by keeping value locally until DateComp has loaded, then passing DateComp the value. */\nexport class DateCompWrapper {\n constructor(context, userComponentFactory, dateComponentParams, eParent) {\n this.alive = true;\n this.context = context;\n this.eParent = eParent;\n const compDetails = userComponentFactory.getDateCompDetails(dateComponentParams);\n const promise = compDetails.newAgStackInstance();\n promise.then(dateComp => {\n // because async, check the filter still exists after component comes back\n if (!this.alive) {\n context.destroyBean(dateComp);\n return;\n }\n this.dateComp = dateComp;\n if (!dateComp) {\n return;\n }\n eParent.appendChild(dateComp.getGui());\n if (dateComp.afterGuiAttached) {\n dateComp.afterGuiAttached();\n }\n if (this.tempValue) {\n dateComp.setDate(this.tempValue);\n }\n if (this.disabled != null) {\n this.setDateCompDisabled(this.disabled);\n }\n });\n }\n destroy() {\n this.alive = false;\n this.dateComp = this.context.destroyBean(this.dateComp);\n }\n getDate() {\n return this.dateComp ? this.dateComp.getDate() : this.tempValue;\n }\n setDate(value) {\n if (this.dateComp) {\n this.dateComp.setDate(value);\n }\n else {\n this.tempValue = value;\n }\n }\n setDisabled(disabled) {\n if (this.dateComp) {\n this.setDateCompDisabled(disabled);\n }\n else {\n this.disabled = disabled;\n }\n }\n setDisplayed(displayed) {\n setDisplayed(this.eParent, displayed);\n }\n setInputPlaceholder(placeholder) {\n if (this.dateComp && this.dateComp.setInputPlaceholder) {\n this.dateComp.setInputPlaceholder(placeholder);\n }\n }\n setInputAriaLabel(label) {\n if (this.dateComp && this.dateComp.setInputAriaLabel) {\n this.dateComp.setInputAriaLabel(label);\n }\n }\n afterGuiAttached(params) {\n if (this.dateComp && typeof this.dateComp.afterGuiAttached === 'function') {\n this.dateComp.afterGuiAttached(params);\n }\n }\n updateParams(params) {\n var _a;\n if (((_a = this.dateComp) === null || _a === void 0 ? void 0 : _a.onParamsUpdated) && typeof this.dateComp.onParamsUpdated === 'function') {\n this.dateComp.onParamsUpdated(params);\n }\n }\n setDateCompDisabled(disabled) {\n if (this.dateComp == null) {\n return;\n }\n if (this.dateComp.setDisabled == null) {\n return;\n }\n this.dateComp.setDisabled(disabled);\n }\n}\n","/* Common logic for options, used by both filters and floating filters. */\nexport class OptionsFactory {\n constructor() {\n this.customFilterOptions = {};\n }\n init(params, defaultOptions) {\n this.filterOptions = params.filterOptions || defaultOptions;\n this.mapCustomOptions();\n this.selectDefaultItem(params);\n }\n getFilterOptions() {\n return this.filterOptions;\n }\n mapCustomOptions() {\n if (!this.filterOptions) {\n return;\n }\n this.filterOptions.forEach(filterOption => {\n if (typeof filterOption === 'string') {\n return;\n }\n const requiredProperties = [['displayKey'], ['displayName'], ['predicate', 'test']];\n const propertyCheck = (keys) => {\n if (!keys.some(key => filterOption[key] != null)) {\n console.warn(`AG Grid: ignoring FilterOptionDef as it doesn't contain one of '${keys}'`);\n return false;\n }\n return true;\n };\n if (!requiredProperties.every(propertyCheck)) {\n this.filterOptions = this.filterOptions.filter(v => v === filterOption) || [];\n return;\n }\n this.customFilterOptions[filterOption.displayKey] = filterOption;\n });\n }\n selectDefaultItem(params) {\n if (params.defaultOption) {\n this.defaultOption = params.defaultOption;\n }\n else if (this.filterOptions.length >= 1) {\n const firstFilterOption = this.filterOptions[0];\n if (typeof firstFilterOption === 'string') {\n this.defaultOption = firstFilterOption;\n }\n else if (firstFilterOption.displayKey) {\n this.defaultOption = firstFilterOption.displayKey;\n }\n else {\n console.warn(`AG Grid: invalid FilterOptionDef supplied as it doesn't contain a 'displayKey'`);\n }\n }\n else {\n console.warn('AG Grid: no filter options for filter');\n }\n }\n getDefaultOption() {\n return this.defaultOption;\n }\n getCustomOption(name) {\n return this.customFilterOptions[name];\n }\n}\n","export const DEFAULT_FILTER_LOCALE_TEXT = {\n applyFilter: 'Apply',\n clearFilter: 'Clear',\n resetFilter: 'Reset',\n cancelFilter: 'Cancel',\n textFilter: 'Text Filter',\n numberFilter: 'Number Filter',\n dateFilter: 'Date Filter',\n setFilter: 'Set Filter',\n filterOoo: 'Filter...',\n empty: 'Choose One',\n equals: 'Equals',\n notEqual: 'Not equal',\n lessThan: 'Less than',\n greaterThan: 'Greater than',\n inRange: 'In range',\n inRangeStart: 'From',\n inRangeEnd: 'To',\n lessThanOrEqual: 'Less than or equals',\n greaterThanOrEqual: 'Greater than or equals',\n contains: 'Contains',\n notContains: 'Not contains',\n startsWith: 'Starts with',\n endsWith: 'Ends with',\n blank: 'Blank',\n notBlank: 'Not blank',\n andCondition: 'AND',\n orCondition: 'OR',\n dateFormatOoo: 'yyyy-mm-dd',\n};\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PostConstruct, Autowired } from '../context/context.mjs';\nimport { KeyCode } from '../constants/keyCode.mjs';\nimport { isStopPropagationForAgGrid, stopPropagationForAgGrid } from '../utils/event.mjs';\nimport { BeanStub } from '../context/beanStub.mjs';\nexport class ManagedFocusFeature extends BeanStub {\n constructor(eFocusableElement, callbacks = {}) {\n super();\n this.eFocusableElement = eFocusableElement;\n this.callbacks = callbacks;\n this.callbacks = Object.assign({ shouldStopEventPropagation: () => false, onTabKeyDown: (e) => {\n if (e.defaultPrevented) {\n return;\n }\n const nextRoot = this.focusService.findNextFocusableElement(this.eFocusableElement, false, e.shiftKey);\n if (!nextRoot) {\n return;\n }\n nextRoot.focus();\n e.preventDefault();\n } }, callbacks);\n }\n postConstruct() {\n this.eFocusableElement.classList.add(ManagedFocusFeature.FOCUS_MANAGED_CLASS);\n this.addKeyDownListeners(this.eFocusableElement);\n if (this.callbacks.onFocusIn) {\n this.addManagedListener(this.eFocusableElement, 'focusin', this.callbacks.onFocusIn);\n }\n if (this.callbacks.onFocusOut) {\n this.addManagedListener(this.eFocusableElement, 'focusout', this.callbacks.onFocusOut);\n }\n }\n addKeyDownListeners(eGui) {\n this.addManagedListener(eGui, 'keydown', (e) => {\n if (e.defaultPrevented || isStopPropagationForAgGrid(e)) {\n return;\n }\n if (this.callbacks.shouldStopEventPropagation(e)) {\n stopPropagationForAgGrid(e);\n return;\n }\n if (e.key === KeyCode.TAB) {\n this.callbacks.onTabKeyDown(e);\n }\n else if (this.callbacks.handleKeyDown) {\n this.callbacks.handleKeyDown(e);\n }\n });\n }\n}\nManagedFocusFeature.FOCUS_MANAGED_CLASS = 'ag-focus-managed';\n__decorate([\n Autowired('focusService')\n], ManagedFocusFeature.prototype, \"focusService\", void 0);\n__decorate([\n PostConstruct\n], ManagedFocusFeature.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nimport { Autowired } from \"../../context/context.mjs\";\nimport { getAbsoluteHeight, getAbsoluteWidth, setFixedHeight, setFixedWidth } from \"../../utils/dom.mjs\";\nconst RESIZE_CONTAINER_STYLE = 'ag-resizer-wrapper';\nconst RESIZE_TEMPLATE = /* html */ `
\n
\n
\n
\n
\n
\n
\n
\n
\n
`;\nexport class PositionableFeature extends BeanStub {\n constructor(element, config) {\n super();\n this.element = element;\n this.dragStartPosition = {\n x: 0,\n y: 0\n };\n this.position = {\n x: 0,\n y: 0\n };\n this.lastSize = {\n width: -1,\n height: -1\n };\n this.positioned = false;\n this.resizersAdded = false;\n this.resizeListeners = [];\n this.boundaryEl = null;\n this.isResizing = false;\n this.isMoving = false;\n this.resizable = {};\n this.movable = false;\n this.currentResizer = null;\n this.config = Object.assign({}, { popup: false }, config);\n }\n center() {\n const { clientHeight, clientWidth } = this.offsetParent;\n const x = (clientWidth / 2) - (this.getWidth() / 2);\n const y = (clientHeight / 2) - (this.getHeight() / 2);\n this.offsetElement(x, y);\n }\n initialisePosition() {\n if (this.positioned) {\n return;\n }\n const { centered, forcePopupParentAsOffsetParent, minWidth, width, minHeight, height, x, y } = this.config;\n if (!this.offsetParent) {\n this.setOffsetParent();\n }\n let computedMinHeight = 0;\n let computedMinWidth = 0;\n // here we don't use the main offset parent but the element's offsetParent\n // in order to calculated the minWidth and minHeight correctly\n const isVisible = !!this.element.offsetParent;\n if (isVisible) {\n const boundaryEl = this.findBoundaryElement();\n const offsetParentComputedStyles = window.getComputedStyle(boundaryEl);\n if (offsetParentComputedStyles.minWidth != null) {\n const paddingWidth = boundaryEl.offsetWidth - this.element.offsetWidth;\n computedMinWidth = parseInt(offsetParentComputedStyles.minWidth, 10) - paddingWidth;\n }\n if (offsetParentComputedStyles.minHeight != null) {\n const paddingHeight = boundaryEl.offsetHeight - this.element.offsetHeight;\n computedMinHeight = parseInt(offsetParentComputedStyles.minHeight, 10) - paddingHeight;\n }\n }\n this.minHeight = minHeight || computedMinHeight;\n this.minWidth = minWidth || computedMinWidth;\n if (width) {\n this.setWidth(width);\n }\n if (height) {\n this.setHeight(height);\n }\n if (!width || !height) {\n this.refreshSize();\n }\n if (centered) {\n this.center();\n }\n else if (x || y) {\n this.offsetElement(x, y);\n }\n else if (isVisible && forcePopupParentAsOffsetParent) {\n let boundaryEl = this.boundaryEl;\n let initialisedDuringPositioning = true;\n if (!boundaryEl) {\n boundaryEl = this.findBoundaryElement();\n initialisedDuringPositioning = false;\n }\n if (boundaryEl) {\n const top = parseFloat(boundaryEl.style.top);\n const left = parseFloat(boundaryEl.style.left);\n if (initialisedDuringPositioning) {\n this.offsetElement(isNaN(left) ? 0 : left, isNaN(top) ? 0 : top);\n }\n else {\n this.setPosition(left, top);\n }\n }\n }\n this.positioned = !!this.offsetParent;\n }\n isPositioned() {\n return this.positioned;\n }\n getPosition() {\n return this.position;\n }\n setMovable(movable, moveElement) {\n if (!this.config.popup || movable === this.movable) {\n return;\n }\n this.movable = movable;\n const params = this.moveElementDragListener || {\n eElement: moveElement,\n onDragStart: this.onMoveStart.bind(this),\n onDragging: this.onMove.bind(this),\n onDragStop: this.onMoveEnd.bind(this)\n };\n if (movable) {\n this.dragService.addDragSource(params);\n this.moveElementDragListener = params;\n }\n else {\n this.dragService.removeDragSource(params);\n this.moveElementDragListener = undefined;\n }\n }\n setResizable(resizable) {\n this.clearResizeListeners();\n if (resizable) {\n this.addResizers();\n }\n else {\n this.removeResizers();\n }\n if (typeof resizable === 'boolean') {\n if (resizable === false) {\n return;\n }\n resizable = {\n topLeft: resizable,\n top: resizable,\n topRight: resizable,\n right: resizable,\n bottomRight: resizable,\n bottom: resizable,\n bottomLeft: resizable,\n left: resizable\n };\n }\n Object.keys(resizable).forEach((side) => {\n const resizableStructure = resizable;\n const isSideResizable = !!resizableStructure[side];\n const resizerEl = this.getResizerElement(side);\n const params = {\n dragStartPixels: 0,\n eElement: resizerEl,\n onDragStart: (e) => this.onResizeStart(e, side),\n onDragging: this.onResize.bind(this),\n onDragStop: (e) => this.onResizeEnd(e, side),\n };\n if (isSideResizable || (!this.isAlive() && !isSideResizable)) {\n if (isSideResizable) {\n this.dragService.addDragSource(params);\n this.resizeListeners.push(params);\n resizerEl.style.pointerEvents = 'all';\n }\n else {\n resizerEl.style.pointerEvents = 'none';\n }\n this.resizable[side] = isSideResizable;\n }\n });\n }\n removeSizeFromEl() {\n this.element.style.removeProperty('height');\n this.element.style.removeProperty('width');\n this.element.style.removeProperty('flex');\n }\n restoreLastSize() {\n this.element.style.flex = '0 0 auto';\n const { height, width } = this.lastSize;\n if (width !== -1) {\n this.element.style.width = `${width}px`;\n }\n if (height !== -1) {\n this.element.style.height = `${height}px`;\n }\n }\n getHeight() {\n return this.element.offsetHeight;\n }\n setHeight(height) {\n const { popup } = this.config;\n const eGui = this.element;\n let isPercent = false;\n if (typeof height === 'string' && height.indexOf('%') !== -1) {\n setFixedHeight(eGui, height);\n height = getAbsoluteHeight(eGui);\n isPercent = true;\n }\n else {\n height = Math.max(this.minHeight, height);\n if (this.positioned) {\n const availableHeight = this.getAvailableHeight();\n if (availableHeight && height > availableHeight) {\n height = availableHeight;\n }\n }\n }\n if (this.getHeight() === height) {\n return;\n }\n if (!isPercent) {\n if (popup) {\n setFixedHeight(eGui, height);\n }\n else {\n eGui.style.height = `${height}px`;\n eGui.style.flex = '0 0 auto';\n this.lastSize.height = typeof height === 'number' ? height : parseFloat(height);\n }\n }\n else {\n eGui.style.maxHeight = 'unset';\n eGui.style.minHeight = 'unset';\n }\n }\n getAvailableHeight() {\n const { popup, forcePopupParentAsOffsetParent } = this.config;\n if (!this.positioned) {\n this.initialisePosition();\n }\n const { clientHeight } = this.offsetParent;\n if (!clientHeight) {\n return null;\n }\n const elRect = this.element.getBoundingClientRect();\n const offsetParentRect = this.offsetParent.getBoundingClientRect();\n const yPosition = popup ? this.position.y : elRect.top;\n const parentTop = popup ? 0 : offsetParentRect.top;\n // When `forcePopupParentAsOffsetParent`, there may be elements that appear after the resizable element, but aren't included in the height.\n // Take these into account here\n let additionalHeight = 0;\n if (forcePopupParentAsOffsetParent) {\n const parentEl = this.element.parentElement;\n if (parentEl) {\n const { bottom } = parentEl.getBoundingClientRect();\n additionalHeight = bottom - elRect.bottom;\n }\n }\n const availableHeight = clientHeight + parentTop - yPosition - additionalHeight;\n return availableHeight;\n }\n getWidth() {\n return this.element.offsetWidth;\n }\n setWidth(width) {\n const eGui = this.element;\n const { popup } = this.config;\n let isPercent = false;\n if (typeof width === 'string' && width.indexOf('%') !== -1) {\n setFixedWidth(eGui, width);\n width = getAbsoluteWidth(eGui);\n isPercent = true;\n }\n else if (this.positioned) {\n width = Math.max(this.minWidth, width);\n const { clientWidth } = this.offsetParent;\n const xPosition = popup ? this.position.x : this.element.getBoundingClientRect().left;\n if (clientWidth && (width + xPosition > clientWidth)) {\n width = clientWidth - xPosition;\n }\n }\n if (this.getWidth() === width) {\n return;\n }\n if (!isPercent) {\n if (this.config.popup) {\n setFixedWidth(eGui, width);\n }\n else {\n eGui.style.width = `${width}px`;\n eGui.style.flex = ' unset';\n this.lastSize.width = typeof width === 'number' ? width : parseFloat(width);\n }\n }\n else {\n eGui.style.maxWidth = 'unset';\n eGui.style.minWidth = 'unset';\n }\n }\n offsetElement(x = 0, y = 0) {\n const { forcePopupParentAsOffsetParent } = this.config;\n const ePopup = forcePopupParentAsOffsetParent ? this.boundaryEl : this.element;\n if (!ePopup) {\n return;\n }\n this.popupService.positionPopup({\n ePopup,\n keepWithinBounds: true,\n skipObserver: this.movable || this.isResizable(),\n updatePosition: () => ({ x, y })\n });\n this.setPosition(parseFloat(ePopup.style.left), parseFloat(ePopup.style.top));\n }\n constrainSizeToAvailableHeight(constrain) {\n if (!this.config.forcePopupParentAsOffsetParent) {\n return;\n }\n const applyMaxHeightToElement = () => {\n const availableHeight = this.getAvailableHeight();\n this.element.style.setProperty('max-height', `${availableHeight}px`);\n };\n if (constrain) {\n this.resizeObserverSubscriber = this.resizeObserverService.observeResize(this.popupService.getPopupParent(), applyMaxHeightToElement);\n }\n else {\n this.element.style.removeProperty('max-height');\n if (this.resizeObserverSubscriber) {\n this.resizeObserverSubscriber();\n this.resizeObserverSubscriber = undefined;\n }\n }\n }\n setPosition(x, y) {\n this.position.x = x;\n this.position.y = y;\n }\n updateDragStartPosition(x, y) {\n this.dragStartPosition = { x, y };\n }\n calculateMouseMovement(params) {\n const { e, isLeft, isTop, anywhereWithin, topBuffer } = params;\n const xDiff = e.clientX - this.dragStartPosition.x;\n const yDiff = e.clientY - this.dragStartPosition.y;\n const movementX = this.shouldSkipX(e, !!isLeft, !!anywhereWithin, xDiff) ? 0 : xDiff;\n const movementY = this.shouldSkipY(e, !!isTop, topBuffer, yDiff) ? 0 : yDiff;\n return { movementX, movementY };\n }\n shouldSkipX(e, isLeft, anywhereWithin, diff) {\n const elRect = this.element.getBoundingClientRect();\n const parentRect = this.offsetParent.getBoundingClientRect();\n const boundaryElRect = this.boundaryEl.getBoundingClientRect();\n const xPosition = this.config.popup ? this.position.x : elRect.left;\n // skip if cursor is outside of popupParent horizontally\n let skipX = ((xPosition <= 0 && parentRect.left >= e.clientX) ||\n (parentRect.right <= e.clientX && parentRect.right <= boundaryElRect.right));\n if (skipX) {\n return true;\n }\n if (isLeft) {\n skipX = (\n // skip if we are moving to the left and the cursor\n // is positioned to the right of the left side anchor\n (diff < 0 && e.clientX > xPosition + parentRect.left) ||\n // skip if we are moving to the right and the cursor\n // is positioned to the left of the dialog\n (diff > 0 && e.clientX < xPosition + parentRect.left));\n }\n else {\n if (anywhereWithin) {\n // if anywhereWithin is true, we allow to move\n // as long as the cursor is within the dialog\n skipX = ((diff < 0 && e.clientX > boundaryElRect.right) ||\n (diff > 0 && e.clientX < xPosition + parentRect.left));\n }\n else {\n skipX = (\n // if the movement is bound to the right side of the dialog\n // we skip if we are moving to the left and the cursor\n // is to the right of the dialog\n (diff < 0 && e.clientX > boundaryElRect.right) ||\n // or skip if we are moving to the right and the cursor\n // is to the left of the right side anchor\n (diff > 0 && e.clientX < boundaryElRect.right));\n }\n }\n return skipX;\n }\n shouldSkipY(e, isTop, topBuffer = 0, diff) {\n const elRect = this.element.getBoundingClientRect();\n const parentRect = this.offsetParent.getBoundingClientRect();\n const boundaryElRect = this.boundaryEl.getBoundingClientRect();\n const yPosition = this.config.popup ? this.position.y : elRect.top;\n // skip if cursor is outside of popupParent vertically\n let skipY = ((yPosition <= 0 && parentRect.top >= e.clientY) ||\n (parentRect.bottom <= e.clientY && parentRect.bottom <= boundaryElRect.bottom));\n if (skipY) {\n return true;\n }\n if (isTop) {\n skipY = (\n // skip if we are moving to towards top and the cursor is\n // below the top anchor + topBuffer\n // note: topBuffer is used when moving the dialog using the title bar\n (diff < 0 && e.clientY > yPosition + parentRect.top + topBuffer) ||\n // skip if we are moving to the bottom and the cursor is\n // above the top anchor\n (diff > 0 && e.clientY < yPosition + parentRect.top));\n }\n else {\n skipY = (\n // skip if we are moving towards the top and the cursor\n // is below the bottom anchor\n (diff < 0 && e.clientY > boundaryElRect.bottom) ||\n // skip if we are moving towards the bottom and the cursor\n // is above the bottom anchor\n (diff > 0 && e.clientY < boundaryElRect.bottom));\n }\n return skipY;\n }\n createResizeMap() {\n const eGui = this.element;\n this.resizerMap = {\n topLeft: { element: eGui.querySelector('[ref=eTopLeftResizer]') },\n top: { element: eGui.querySelector('[ref=eTopResizer]') },\n topRight: { element: eGui.querySelector('[ref=eTopRightResizer]') },\n right: { element: eGui.querySelector('[ref=eRightResizer]') },\n bottomRight: { element: eGui.querySelector('[ref=eBottomRightResizer]') },\n bottom: { element: eGui.querySelector('[ref=eBottomResizer]') },\n bottomLeft: { element: eGui.querySelector('[ref=eBottomLeftResizer]') },\n left: { element: eGui.querySelector('[ref=eLeftResizer]') }\n };\n }\n addResizers() {\n if (this.resizersAdded) {\n return;\n }\n const eGui = this.element;\n if (!eGui) {\n return;\n }\n const parser = new DOMParser();\n const resizers = parser.parseFromString(RESIZE_TEMPLATE, 'text/html').body;\n eGui.appendChild(resizers.firstChild);\n this.createResizeMap();\n this.resizersAdded = true;\n }\n removeResizers() {\n this.resizerMap = undefined;\n const resizerEl = this.element.querySelector(`.${RESIZE_CONTAINER_STYLE}`);\n if (resizerEl) {\n this.element.removeChild(resizerEl);\n }\n this.resizersAdded = false;\n }\n getResizerElement(side) {\n return this.resizerMap[side].element;\n }\n onResizeStart(e, side) {\n this.boundaryEl = this.findBoundaryElement();\n if (!this.positioned) {\n this.initialisePosition();\n }\n this.currentResizer = {\n isTop: !!side.match(/top/i),\n isRight: !!side.match(/right/i),\n isBottom: !!side.match(/bottom/i),\n isLeft: !!side.match(/left/i),\n };\n this.element.classList.add('ag-resizing');\n this.resizerMap[side].element.classList.add('ag-active');\n const { popup, forcePopupParentAsOffsetParent } = this.config;\n if (!popup && !forcePopupParentAsOffsetParent) {\n this.applySizeToSiblings(this.currentResizer.isBottom || this.currentResizer.isTop);\n }\n this.isResizing = true;\n this.updateDragStartPosition(e.clientX, e.clientY);\n }\n getSiblings() {\n const element = this.element;\n const parent = element.parentElement;\n if (!parent) {\n return null;\n }\n return Array.prototype.slice.call(parent.children).filter((el) => !el.classList.contains('ag-hidden'));\n }\n getMinSizeOfSiblings() {\n const siblings = this.getSiblings() || [];\n let height = 0;\n let width = 0;\n for (let i = 0; i < siblings.length; i++) {\n const currentEl = siblings[i];\n const isFlex = !!currentEl.style.flex && currentEl.style.flex !== '0 0 auto';\n if (currentEl === this.element) {\n continue;\n }\n let nextHeight = this.minHeight || 0;\n let nextWidth = this.minWidth || 0;\n if (isFlex) {\n const computedStyle = window.getComputedStyle(currentEl);\n if (computedStyle.minHeight) {\n nextHeight = parseInt(computedStyle.minHeight, 10);\n }\n if (computedStyle.minWidth) {\n nextWidth = parseInt(computedStyle.minWidth, 10);\n }\n }\n else {\n nextHeight = currentEl.offsetHeight;\n nextWidth = currentEl.offsetWidth;\n }\n height += nextHeight;\n width += nextWidth;\n }\n return { height, width };\n }\n applySizeToSiblings(vertical) {\n let containerToFlex = null;\n const siblings = this.getSiblings();\n if (!siblings) {\n return;\n }\n for (let i = 0; i < siblings.length; i++) {\n const el = siblings[i];\n if (el === containerToFlex) {\n continue;\n }\n if (vertical) {\n el.style.height = `${el.offsetHeight}px`;\n }\n else {\n el.style.width = `${el.offsetWidth}px`;\n }\n el.style.flex = '0 0 auto';\n if (el === this.element) {\n containerToFlex = siblings[i + 1];\n }\n }\n if (containerToFlex) {\n containerToFlex.style.removeProperty('height');\n containerToFlex.style.removeProperty('min-height');\n containerToFlex.style.removeProperty('max-height');\n containerToFlex.style.flex = '1 1 auto';\n }\n }\n isResizable() {\n return Object.values(this.resizable).some(value => value);\n }\n onResize(e) {\n if (!this.isResizing || !this.currentResizer) {\n return;\n }\n const { popup, forcePopupParentAsOffsetParent } = this.config;\n const { isTop, isRight, isBottom, isLeft } = this.currentResizer;\n const isHorizontal = isRight || isLeft;\n const isVertical = isBottom || isTop;\n const { movementX, movementY } = this.calculateMouseMovement({ e, isLeft, isTop });\n const xPosition = this.position.x;\n const yPosition = this.position.y;\n let offsetLeft = 0;\n let offsetTop = 0;\n if (isHorizontal && movementX) {\n const direction = isLeft ? -1 : 1;\n const oldWidth = this.getWidth();\n const newWidth = oldWidth + (movementX * direction);\n let skipWidth = false;\n if (isLeft) {\n offsetLeft = oldWidth - newWidth;\n if (xPosition + offsetLeft <= 0 || newWidth <= this.minWidth) {\n skipWidth = true;\n offsetLeft = 0;\n }\n }\n if (!skipWidth) {\n this.setWidth(newWidth);\n }\n }\n if (isVertical && movementY) {\n const direction = isTop ? -1 : 1;\n const oldHeight = this.getHeight();\n const newHeight = oldHeight + (movementY * direction);\n let skipHeight = false;\n if (isTop) {\n offsetTop = oldHeight - newHeight;\n if (yPosition + offsetTop <= 0 || newHeight <= this.minHeight) {\n skipHeight = true;\n offsetTop = 0;\n }\n }\n else {\n // do not let the size of all siblings be higher than the parent container\n if (!this.config.popup &&\n !this.config.forcePopupParentAsOffsetParent &&\n oldHeight < newHeight &&\n (this.getMinSizeOfSiblings().height + newHeight) > this.element.parentElement.offsetHeight) {\n skipHeight = true;\n }\n }\n if (!skipHeight) {\n this.setHeight(newHeight);\n }\n }\n this.updateDragStartPosition(e.clientX, e.clientY);\n if ((popup || forcePopupParentAsOffsetParent) && offsetLeft || offsetTop) {\n this.offsetElement(xPosition + offsetLeft, yPosition + offsetTop);\n }\n }\n onResizeEnd(e, side) {\n this.isResizing = false;\n this.currentResizer = null;\n this.boundaryEl = null;\n const params = {\n type: 'resize',\n api: this.gridOptionsService.api,\n columnApi: this.gridOptionsService.columnApi\n };\n this.element.classList.remove('ag-resizing');\n this.resizerMap[side].element.classList.remove('ag-active');\n this.dispatchEvent(params);\n }\n refreshSize() {\n const eGui = this.element;\n if (this.config.popup) {\n if (!this.config.width) {\n this.setWidth(eGui.offsetWidth);\n }\n if (!this.config.height) {\n this.setHeight(eGui.offsetHeight);\n }\n }\n }\n onMoveStart(e) {\n this.boundaryEl = this.findBoundaryElement();\n if (!this.positioned) {\n this.initialisePosition();\n }\n this.isMoving = true;\n this.element.classList.add('ag-moving');\n this.updateDragStartPosition(e.clientX, e.clientY);\n }\n onMove(e) {\n if (!this.isMoving) {\n return;\n }\n const { x, y } = this.position;\n let topBuffer;\n if (this.config.calculateTopBuffer) {\n topBuffer = this.config.calculateTopBuffer();\n }\n const { movementX, movementY } = this.calculateMouseMovement({\n e,\n isTop: true,\n anywhereWithin: true,\n topBuffer\n });\n this.offsetElement(x + movementX, y + movementY);\n this.updateDragStartPosition(e.clientX, e.clientY);\n }\n onMoveEnd() {\n this.isMoving = false;\n this.boundaryEl = null;\n this.element.classList.remove('ag-moving');\n }\n setOffsetParent() {\n if (this.config.forcePopupParentAsOffsetParent) {\n this.offsetParent = this.popupService.getPopupParent();\n }\n else {\n this.offsetParent = this.element.offsetParent;\n }\n }\n findBoundaryElement() {\n let el = this.element;\n while (el) {\n if (window.getComputedStyle(el).position !== 'static') {\n return el;\n }\n el = el.parentElement;\n }\n return this.element;\n }\n clearResizeListeners() {\n while (this.resizeListeners.length) {\n const params = this.resizeListeners.pop();\n this.dragService.removeDragSource(params);\n }\n }\n destroy() {\n super.destroy();\n if (this.moveElementDragListener) {\n this.dragService.removeDragSource(this.moveElementDragListener);\n }\n this.constrainSizeToAvailableHeight(false);\n this.clearResizeListeners();\n this.removeResizers();\n }\n}\n__decorate([\n Autowired('popupService')\n], PositionableFeature.prototype, \"popupService\", void 0);\n__decorate([\n Autowired('resizeObserverService')\n], PositionableFeature.prototype, \"resizeObserverService\", void 0);\n__decorate([\n Autowired('dragService')\n], PositionableFeature.prototype, \"dragService\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from '../../context/context.mjs';\nimport { loadTemplate, setDisabled } from '../../utils/dom.mjs';\nimport { debounce } from '../../utils/function.mjs';\nimport { DEFAULT_FILTER_LOCALE_TEXT } from '../filterLocaleText.mjs';\nimport { ManagedFocusFeature } from '../../widgets/managedFocusFeature.mjs';\nimport { convertToSet } from '../../utils/set.mjs';\nimport { Component } from '../../widgets/component.mjs';\nimport { RefSelector } from '../../widgets/componentAnnotations.mjs';\nimport { PositionableFeature } from '../../rendering/features/positionableFeature.mjs';\n/**\n * Contains common logic to all provided filters (apply button, clear button, etc).\n * All the filters that come with AG Grid extend this class. User filters do not\n * extend this class.\n *\n * @param M type of filter-model managed by the concrete sub-class that extends this type\n * @param V type of value managed by the concrete sub-class that extends this type\n */\nexport class ProvidedFilter extends Component {\n constructor(filterNameKey) {\n super();\n this.filterNameKey = filterNameKey;\n this.applyActive = false;\n this.hidePopup = null;\n this.debouncePending = false;\n // after the user hits 'apply' the model gets copied to here. this is then the model that we use for\n // all filtering. so if user changes UI but doesn't hit apply, then the UI will be out of sync with this model.\n // this is what we want, as the UI should only become the 'active' filter once it's applied. when apply is\n // inactive, this model will be in sync (following the debounce ms). if the UI is not a valid filter\n // (eg the value is missing so nothing to filter on, or for set filter all checkboxes are checked so filter\n // not active) then this appliedModel will be null/undefined.\n this.appliedModel = null;\n }\n postConstruct() {\n this.resetTemplate(); // do this first to create the DOM\n this.createManagedBean(new ManagedFocusFeature(this.getFocusableElement(), {\n handleKeyDown: this.handleKeyDown.bind(this)\n }));\n this.positionableFeature = new PositionableFeature(this.getPositionableElement(), {\n forcePopupParentAsOffsetParent: true\n });\n this.createBean(this.positionableFeature);\n }\n // override\n handleKeyDown(e) { }\n getFilterTitle() {\n return this.translate(this.filterNameKey);\n }\n isFilterActive() {\n // filter is active if we have a valid applied model\n return !!this.appliedModel;\n }\n resetTemplate(paramsMap) {\n let eGui = this.getGui();\n if (eGui) {\n eGui.removeEventListener('submit', this.onFormSubmit);\n }\n const templateString = /* html */ `\n
\n
\n ${this.createBodyTemplate()}\n
\n
`;\n this.setTemplate(templateString, paramsMap);\n eGui = this.getGui();\n if (eGui) {\n eGui.addEventListener('submit', this.onFormSubmit);\n }\n }\n isReadOnly() {\n return !!this.providedFilterParams.readOnly;\n }\n init(params) {\n this.setParams(params);\n this.resetUiToDefaults(true).then(() => {\n this.updateUiVisibility();\n this.setupOnBtApplyDebounce();\n });\n }\n setParams(params) {\n this.providedFilterParams = params;\n this.applyActive = ProvidedFilter.isUseApplyButton(params);\n this.createButtonPanel();\n }\n createButtonPanel() {\n const { buttons } = this.providedFilterParams;\n if (!buttons || buttons.length < 1 || this.isReadOnly()) {\n return;\n }\n const eButtonsPanel = document.createElement('div');\n eButtonsPanel.classList.add('ag-filter-apply-panel');\n const addButton = (type) => {\n let text;\n let clickListener;\n switch (type) {\n case 'apply':\n text = this.translate('applyFilter');\n clickListener = (e) => this.onBtApply(false, false, e);\n break;\n case 'clear':\n text = this.translate('clearFilter');\n clickListener = () => this.onBtClear();\n break;\n case 'reset':\n text = this.translate('resetFilter');\n clickListener = () => this.onBtReset();\n break;\n case 'cancel':\n text = this.translate('cancelFilter');\n clickListener = (e) => { this.onBtCancel(e); };\n break;\n default:\n console.warn('AG Grid: Unknown button type specified');\n return;\n }\n const buttonType = type === 'apply' ? 'submit' : 'button';\n const button = loadTemplate(\n /* html */\n `${text}\n `);\n eButtonsPanel.appendChild(button);\n this.addManagedListener(button, 'click', clickListener);\n };\n convertToSet(buttons).forEach(type => addButton(type));\n this.getGui().appendChild(eButtonsPanel);\n }\n // subclasses can override this to provide alternative debounce defaults\n getDefaultDebounceMs() {\n return 0;\n }\n setupOnBtApplyDebounce() {\n const debounceMs = ProvidedFilter.getDebounceMs(this.providedFilterParams, this.getDefaultDebounceMs());\n const debounceFunc = debounce(this.checkApplyDebounce.bind(this), debounceMs);\n this.onBtApplyDebounce = () => {\n this.debouncePending = true;\n debounceFunc();\n };\n }\n checkApplyDebounce() {\n if (this.debouncePending) {\n // May already have been applied, so don't apply again (e.g. closing filter before debounce timeout)\n this.debouncePending = false;\n this.onBtApply();\n }\n }\n getModel() {\n return this.appliedModel ? this.appliedModel : null;\n }\n setModel(model) {\n const promise = model != null ? this.setModelIntoUi(model) : this.resetUiToDefaults();\n return promise.then(() => {\n this.updateUiVisibility();\n // we set the model from the GUI, rather than the provided model,\n // so the model is consistent, e.g. handling of null/undefined will be the same,\n // or if model is case insensitive, then casing is removed.\n this.applyModel('api');\n });\n }\n onBtCancel(e) {\n this.resetUiToActiveModel(this.getModel(), () => {\n this.handleCancelEnd(e);\n });\n }\n handleCancelEnd(e) {\n if (this.providedFilterParams.closeOnApply) {\n this.close(e);\n }\n }\n resetUiToActiveModel(currentModel, afterUiUpdatedFunc) {\n const afterAppliedFunc = () => {\n this.onUiChanged(false, 'prevent');\n afterUiUpdatedFunc === null || afterUiUpdatedFunc === void 0 ? void 0 : afterUiUpdatedFunc();\n };\n if (currentModel != null) {\n this.setModelIntoUi(currentModel).then(afterAppliedFunc);\n }\n else {\n this.resetUiToDefaults().then(afterAppliedFunc);\n }\n }\n onBtClear() {\n this.resetUiToDefaults().then(() => this.onUiChanged());\n }\n onBtReset() {\n this.onBtClear();\n this.onBtApply();\n }\n /**\n * Applies changes made in the UI to the filter, and returns true if the model has changed.\n */\n applyModel(source = 'api') {\n const newModel = this.getModelFromUi();\n if (!this.isModelValid(newModel)) {\n return false;\n }\n const previousModel = this.appliedModel;\n this.appliedModel = newModel;\n // models can be same if user pasted same content into text field, or maybe just changed the case\n // and it's a case insensitive filter\n return !this.areModelsEqual(previousModel, newModel);\n }\n isModelValid(model) {\n return true;\n }\n onFormSubmit(e) {\n e.preventDefault();\n }\n onBtApply(afterFloatingFilter = false, afterDataChange = false, e) {\n // Prevent form submission\n if (e) {\n e.preventDefault();\n }\n if (this.applyModel(afterDataChange ? 'rowDataUpdated' : 'ui')) {\n // the floating filter uses 'afterFloatingFilter' info, so it doesn't refresh after filter changed if change\n // came from floating filter\n const source = 'columnFilter';\n this.providedFilterParams.filterChangedCallback({ afterFloatingFilter, afterDataChange, source });\n }\n const { closeOnApply } = this.providedFilterParams;\n // only close if an apply button is visible, otherwise we'd be closing every time a change was made!\n if (closeOnApply && this.applyActive && !afterFloatingFilter && !afterDataChange) {\n this.close(e);\n }\n }\n onNewRowsLoaded() {\n }\n close(e) {\n if (!this.hidePopup) {\n return;\n }\n const keyboardEvent = e;\n const key = keyboardEvent && keyboardEvent.key;\n let params;\n if (key === 'Enter' || key === 'Space') {\n params = { keyboardEvent };\n }\n this.hidePopup(params);\n this.hidePopup = null;\n }\n /**\n * By default, if the change came from a floating filter it will be applied immediately, otherwise if there is no\n * apply button it will be applied after a debounce, otherwise it will not be applied at all. This behaviour can\n * be adjusted by using the apply parameter.\n */\n onUiChanged(fromFloatingFilter = false, apply) {\n this.updateUiVisibility();\n this.providedFilterParams.filterModifiedCallback();\n if (this.applyActive && !this.isReadOnly()) {\n const isValid = this.isModelValid(this.getModelFromUi());\n setDisabled(this.getRefElement('applyFilterButton'), !isValid);\n }\n if ((fromFloatingFilter && !apply) || apply === 'immediately') {\n this.onBtApply(fromFloatingFilter);\n }\n else if ((!this.applyActive && !apply) || apply === 'debounce') {\n this.onBtApplyDebounce();\n }\n }\n afterGuiAttached(params) {\n if (params) {\n this.hidePopup = params.hidePopup;\n }\n this.refreshFilterResizer(params === null || params === void 0 ? void 0 : params.container);\n }\n refreshFilterResizer(containerType) {\n // tool panel is scrollable, so don't need to size\n if (!this.positionableFeature || containerType === 'toolPanel') {\n return;\n }\n const isFloatingFilter = containerType === 'floatingFilter';\n const { positionableFeature, gridOptionsService } = this;\n if (isFloatingFilter) {\n positionableFeature.restoreLastSize();\n positionableFeature.setResizable(gridOptionsService.is('enableRtl')\n ? { bottom: true, bottomLeft: true, left: true }\n : { bottom: true, bottomRight: true, right: true });\n }\n else {\n this.positionableFeature.removeSizeFromEl();\n this.positionableFeature.setResizable(false);\n }\n this.positionableFeature.constrainSizeToAvailableHeight(true);\n }\n afterGuiDetached() {\n this.checkApplyDebounce();\n if (this.positionableFeature) {\n this.positionableFeature.constrainSizeToAvailableHeight(false);\n }\n }\n // static, as used by floating filter also\n static getDebounceMs(params, debounceDefault) {\n if (ProvidedFilter.isUseApplyButton(params)) {\n if (params.debounceMs != null) {\n console.warn('AG Grid: debounceMs is ignored when apply button is present');\n }\n return 0;\n }\n return params.debounceMs != null ? params.debounceMs : debounceDefault;\n }\n // static, as used by floating filter also\n static isUseApplyButton(params) {\n return !!params.buttons && params.buttons.indexOf('apply') >= 0;\n }\n destroy() {\n const eGui = this.getGui();\n if (eGui) {\n eGui.removeEventListener('submit', this.onFormSubmit);\n }\n this.hidePopup = null;\n if (this.positionableFeature) {\n this.positionableFeature = this.destroyBean(this.positionableFeature);\n }\n super.destroy();\n }\n translate(key) {\n const translate = this.localeService.getLocaleTextFunc();\n return translate(key, DEFAULT_FILTER_LOCALE_TEXT[key]);\n }\n getCellValue(rowNode) {\n const { api, colDef, column, columnApi, context } = this.providedFilterParams;\n return this.providedFilterParams.valueGetter({\n api,\n colDef,\n column,\n columnApi,\n context,\n data: rowNode.data,\n getValue: (field) => rowNode.data[field],\n node: rowNode,\n });\n }\n // override to control positionable feature\n getPositionableElement() {\n return this.eFilterBody;\n }\n}\n__decorate([\n Autowired('rowModel')\n], ProvidedFilter.prototype, \"rowModel\", void 0);\n__decorate([\n RefSelector('eFilterBody')\n], ProvidedFilter.prototype, \"eFilterBody\", void 0);\n__decorate([\n PostConstruct\n], ProvidedFilter.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from \"./component.mjs\";\nimport { PostConstruct } from \"../context/context.mjs\";\nimport { clearElement, setDisabled, setDisplayed, setElementWidth } from \"../utils/dom.mjs\";\nimport { setAriaRole } from \"../utils/aria.mjs\";\nexport class AgAbstractLabel extends Component {\n constructor(config, template) {\n super(template);\n this.labelSeparator = '';\n this.labelAlignment = 'left';\n this.disabled = false;\n this.label = '';\n this.config = config || {};\n }\n postConstruct() {\n this.addCssClass('ag-labeled');\n this.eLabel.classList.add('ag-label');\n const { labelSeparator, label, labelWidth, labelAlignment } = this.config;\n if (labelSeparator != null) {\n this.setLabelSeparator(labelSeparator);\n }\n if (label != null) {\n this.setLabel(label);\n }\n if (labelWidth != null) {\n this.setLabelWidth(labelWidth);\n }\n this.setLabelAlignment(labelAlignment || this.labelAlignment);\n this.refreshLabel();\n }\n refreshLabel() {\n clearElement(this.eLabel);\n if (typeof this.label === 'string') {\n this.eLabel.innerText = this.label + this.labelSeparator;\n }\n else if (this.label) {\n this.eLabel.appendChild(this.label);\n }\n if (this.label === '') {\n setDisplayed(this.eLabel, false);\n setAriaRole(this.eLabel, 'presentation');\n }\n else {\n setDisplayed(this.eLabel, true);\n setAriaRole(this.eLabel, null);\n }\n }\n setLabelSeparator(labelSeparator) {\n if (this.labelSeparator === labelSeparator) {\n return this;\n }\n this.labelSeparator = labelSeparator;\n if (this.label != null) {\n this.refreshLabel();\n }\n return this;\n }\n getLabelId() {\n this.eLabel.id = this.eLabel.id || `ag-${this.getCompId()}-label`;\n return this.eLabel.id;\n }\n getLabel() {\n return this.label;\n }\n setLabel(label) {\n if (this.label === label) {\n return this;\n }\n this.label = label;\n this.refreshLabel();\n return this;\n }\n setLabelAlignment(alignment) {\n const eGui = this.getGui();\n const eGuiClassList = eGui.classList;\n eGuiClassList.toggle('ag-label-align-left', alignment === 'left');\n eGuiClassList.toggle('ag-label-align-right', alignment === 'right');\n eGuiClassList.toggle('ag-label-align-top', alignment === 'top');\n return this;\n }\n setLabelEllipsis(hasEllipsis) {\n this.eLabel.classList.toggle('ag-label-ellipsis', hasEllipsis);\n return this;\n }\n setLabelWidth(width) {\n if (this.label == null) {\n return this;\n }\n setElementWidth(this.eLabel, width);\n return this;\n }\n setDisabled(disabled) {\n disabled = !!disabled;\n const element = this.getGui();\n setDisabled(element, disabled);\n element.classList.toggle('ag-disabled', disabled);\n this.disabled = disabled;\n return this;\n }\n isDisabled() {\n return !!this.disabled;\n }\n}\n__decorate([\n PostConstruct\n], AgAbstractLabel.prototype, \"postConstruct\", null);\n","import { AgAbstractLabel } from './agAbstractLabel.mjs';\nimport { setFixedWidth } from '../utils/dom.mjs';\nimport { Events } from '../eventKeys.mjs';\nexport class AgAbstractField extends AgAbstractLabel {\n constructor(config, template, className) {\n super(config, template);\n this.className = className;\n }\n postConstruct() {\n super.postConstruct();\n if (this.className) {\n this.addCssClass(this.className);\n }\n }\n onValueChange(callbackFn) {\n this.addManagedListener(this, Events.EVENT_FIELD_VALUE_CHANGED, () => callbackFn(this.getValue()));\n return this;\n }\n getWidth() {\n return this.getGui().clientWidth;\n }\n setWidth(width) {\n setFixedWidth(this.getGui(), width);\n return this;\n }\n getPreviousValue() {\n return this.previousValue;\n }\n getValue() {\n return this.value;\n }\n setValue(value, silent) {\n if (this.value === value) {\n return this;\n }\n this.previousValue = this.value;\n this.value = value;\n if (!silent) {\n this.dispatchEvent({ type: Events.EVENT_FIELD_VALUE_CHANGED });\n }\n return this;\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { AgAbstractField } from \"./agAbstractField.mjs\";\nimport { RefSelector } from \"./componentAnnotations.mjs\";\nimport { setAriaLabelledBy, setAriaLabel, setAriaDescribedBy, setAriaExpanded, setAriaRole } from \"../utils/aria.mjs\";\nimport { createIconNoSpan } from \"../utils/icon.mjs\";\nimport { setElementWidth, getAbsoluteWidth, getInnerHeight, formatSize } from \"../utils/dom.mjs\";\nimport { KeyCode } from '../constants/keyCode.mjs';\nimport { Autowired } from \"../context/context.mjs\";\nconst TEMPLATE = /* html */ `\n
\n
\n
\n
\n
\n
\n
`;\nexport class AgPickerField extends AgAbstractField {\n constructor(config) {\n super(config, (config === null || config === void 0 ? void 0 : config.template) || TEMPLATE, config === null || config === void 0 ? void 0 : config.className);\n this.isPickerDisplayed = false;\n this.skipClick = false;\n this.pickerGap = 4;\n this.hideCurrentPicker = null;\n this.ariaRole = config === null || config === void 0 ? void 0 : config.ariaRole;\n this.onPickerFocusIn = this.onPickerFocusIn.bind(this);\n this.onPickerFocusOut = this.onPickerFocusOut.bind(this);\n if (!config) {\n return;\n }\n const { pickerGap, maxPickerHeight, variableWidth, minPickerWidth, maxPickerWidth } = config;\n if (pickerGap != null) {\n this.pickerGap = pickerGap;\n }\n this.variableWidth = !!variableWidth;\n if (maxPickerHeight != null) {\n this.setPickerMaxHeight(maxPickerHeight);\n }\n if (minPickerWidth != null) {\n this.setPickerMinWidth(minPickerWidth);\n }\n if (maxPickerWidth != null) {\n this.setPickerMaxWidth(maxPickerWidth);\n }\n }\n postConstruct() {\n super.postConstruct();\n this.setupAria();\n const displayId = `ag-${this.getCompId()}-display`;\n this.eDisplayField.setAttribute('id', displayId);\n const ariaEl = this.getAriaElement();\n setAriaDescribedBy(ariaEl, displayId);\n this.addManagedListener(ariaEl, 'keydown', this.onKeyDown.bind(this));\n this.addManagedListener(this.eLabel, 'mousedown', this.onLabelOrWrapperMouseDown.bind(this));\n this.addManagedListener(this.eWrapper, 'mousedown', this.onLabelOrWrapperMouseDown.bind(this));\n const { pickerIcon } = this.config;\n if (pickerIcon) {\n const icon = createIconNoSpan(pickerIcon, this.gridOptionsService);\n if (icon) {\n this.eIcon.appendChild(icon);\n }\n }\n }\n setupAria() {\n const ariaEl = this.getAriaElement();\n ariaEl.setAttribute('tabindex', (this.gridOptionsService.getNum('tabIndex') || 0).toString());\n setAriaExpanded(ariaEl, false);\n if (this.ariaRole) {\n setAriaRole(ariaEl, this.ariaRole);\n }\n }\n refreshLabel() {\n var _a;\n const ariaEl = this.getAriaElement();\n setAriaLabelledBy(ariaEl, (_a = this.getLabelId()) !== null && _a !== void 0 ? _a : '');\n super.refreshLabel();\n }\n onLabelOrWrapperMouseDown(e) {\n if (e) {\n // this prevents a BUG where MouseDown causes the element to be focused\n // after the picker is shown and focus ends up being lost.\n e.preventDefault();\n this.getFocusableElement().focus();\n }\n if (this.skipClick) {\n this.skipClick = false;\n return;\n }\n if (this.isDisabled()) {\n return;\n }\n if (this.isPickerDisplayed) {\n this.hidePicker();\n }\n else {\n this.showPicker();\n }\n }\n onKeyDown(e) {\n switch (e.key) {\n case KeyCode.UP:\n case KeyCode.DOWN:\n case KeyCode.ENTER:\n case KeyCode.SPACE:\n e.preventDefault();\n this.onLabelOrWrapperMouseDown();\n break;\n case KeyCode.ESCAPE:\n if (this.isPickerDisplayed) {\n e.preventDefault();\n e.stopPropagation();\n if (this.hideCurrentPicker) {\n this.hideCurrentPicker();\n }\n }\n break;\n }\n }\n showPicker() {\n this.isPickerDisplayed = true;\n if (!this.pickerComponent) {\n this.pickerComponent = this.createPickerComponent();\n }\n const pickerGui = this.pickerComponent.getGui();\n pickerGui.addEventListener('focusin', this.onPickerFocusIn);\n pickerGui.addEventListener('focusout', this.onPickerFocusOut);\n this.hideCurrentPicker = this.renderAndPositionPicker();\n this.toggleExpandedStyles(true);\n }\n renderAndPositionPicker() {\n const eDocument = this.gridOptionsService.getDocument();\n const ePicker = this.pickerComponent.getGui();\n if (!this.gridOptionsService.is('suppressScrollWhenPopupsAreOpen')) {\n this.destroyMouseWheelFunc = this.addManagedListener(eDocument.body, 'wheel', (e) => {\n if (!ePicker.contains(e.target)) {\n this.hidePicker();\n }\n });\n }\n const translate = this.localeService.getLocaleTextFunc();\n const { pickerType, pickerAriaLabelKey, pickerAriaLabelValue, modalPicker = true } = this.config;\n const popupParams = {\n modal: modalPicker,\n eChild: ePicker,\n closeOnEsc: true,\n closedCallback: () => {\n const shouldRestoreFocus = eDocument.activeElement === eDocument.body;\n this.beforeHidePicker();\n if (shouldRestoreFocus && this.isAlive()) {\n this.getFocusableElement().focus();\n }\n },\n ariaLabel: translate(pickerAriaLabelKey, pickerAriaLabelValue),\n };\n const addPopupRes = this.popupService.addPopup(popupParams);\n const { maxPickerHeight, minPickerWidth, maxPickerWidth, pickerGap, variableWidth } = this;\n if (variableWidth) {\n if (minPickerWidth) {\n ePicker.style.minWidth = minPickerWidth;\n }\n ePicker.style.width = formatSize(getAbsoluteWidth(this.eWrapper));\n if (maxPickerWidth) {\n ePicker.style.maxWidth = maxPickerWidth;\n }\n }\n else {\n setElementWidth(ePicker, maxPickerWidth !== null && maxPickerWidth !== void 0 ? maxPickerWidth : getAbsoluteWidth(this.eWrapper));\n }\n const maxHeight = maxPickerHeight !== null && maxPickerHeight !== void 0 ? maxPickerHeight : `${getInnerHeight(this.popupService.getPopupParent())}px`;\n ePicker.style.setProperty('max-height', maxHeight);\n ePicker.style.position = 'absolute';\n const alignSide = this.gridOptionsService.is('enableRtl') ? 'right' : 'left';\n this.popupService.positionPopupByComponent({\n type: pickerType,\n eventSource: this.eWrapper,\n ePopup: ePicker,\n position: 'under',\n alignSide,\n keepWithinBounds: true,\n nudgeY: pickerGap\n });\n return addPopupRes.hideFunc;\n }\n beforeHidePicker() {\n if (this.destroyMouseWheelFunc) {\n this.destroyMouseWheelFunc();\n this.destroyMouseWheelFunc = undefined;\n }\n this.toggleExpandedStyles(false);\n const pickerGui = this.pickerComponent.getGui();\n pickerGui.removeEventListener('focusin', this.onPickerFocusIn);\n pickerGui.removeEventListener('focusout', this.onPickerFocusOut);\n this.isPickerDisplayed = false;\n this.pickerComponent = undefined;\n this.hideCurrentPicker = null;\n }\n toggleExpandedStyles(expanded) {\n if (!this.isAlive()) {\n return;\n }\n const ariaEl = this.getAriaElement();\n setAriaExpanded(ariaEl, expanded);\n this.eWrapper.classList.toggle('ag-picker-expanded', expanded);\n this.eWrapper.classList.toggle('ag-picker-collapsed', !expanded);\n }\n onPickerFocusIn() {\n this.togglePickerHasFocus(true);\n }\n onPickerFocusOut(e) {\n var _a;\n if (!((_a = this.pickerComponent) === null || _a === void 0 ? void 0 : _a.getGui().contains(e.relatedTarget))) {\n this.togglePickerHasFocus(false);\n }\n }\n togglePickerHasFocus(focused) {\n if (!this.pickerComponent) {\n return;\n }\n this.eWrapper.classList.toggle('ag-picker-has-focus', focused);\n }\n hidePicker() {\n if (this.hideCurrentPicker) {\n this.hideCurrentPicker();\n }\n }\n setAriaLabel(label) {\n setAriaLabel(this.getAriaElement(), label);\n return this;\n }\n setInputWidth(width) {\n setElementWidth(this.eWrapper, width);\n return this;\n }\n getFocusableElement() {\n return this.eWrapper;\n }\n setPickerGap(gap) {\n this.pickerGap = gap;\n return this;\n }\n setPickerMinWidth(width) {\n if (typeof width === 'number') {\n width = `${width}px`;\n }\n this.minPickerWidth = width == null ? undefined : width;\n return this;\n }\n setPickerMaxWidth(width) {\n if (typeof width === 'number') {\n width = `${width}px`;\n }\n this.maxPickerWidth = width == null ? undefined : width;\n return this;\n }\n setPickerMaxHeight(height) {\n if (typeof height === 'number') {\n height = `${height}px`;\n }\n this.maxPickerHeight = height == null ? undefined : height;\n return this;\n }\n destroy() {\n this.hidePicker();\n super.destroy();\n }\n}\n__decorate([\n Autowired('popupService')\n], AgPickerField.prototype, \"popupService\", void 0);\n__decorate([\n RefSelector('eLabel')\n], AgPickerField.prototype, \"eLabel\", void 0);\n__decorate([\n RefSelector('eWrapper')\n], AgPickerField.prototype, \"eWrapper\", void 0);\n__decorate([\n RefSelector('eDisplayField')\n], AgPickerField.prototype, \"eDisplayField\", void 0);\n__decorate([\n RefSelector('eIcon')\n], AgPickerField.prototype, \"eIcon\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from \"./component.mjs\";\nimport { PostConstruct } from \"../context/context.mjs\";\nimport { escapeString } from \"../utils/string.mjs\";\nimport { KeyCode } from '../constants/keyCode.mjs';\nimport { setAriaPosInSet, setAriaRole, setAriaSelected, setAriaSetSize } from '../utils/aria.mjs';\nimport { Events } from \"../eventKeys.mjs\";\nexport class AgList extends Component {\n constructor(cssIdentifier = 'default') {\n super(/* html */ `
`);\n this.cssIdentifier = cssIdentifier;\n this.options = [];\n this.itemEls = [];\n }\n init() {\n this.addManagedListener(this.getGui(), 'keydown', this.handleKeyDown.bind(this));\n }\n handleKeyDown(e) {\n const key = e.key;\n switch (key) {\n case KeyCode.ENTER:\n if (!this.highlightedEl) {\n this.setValue(this.getValue());\n }\n else {\n const pos = this.itemEls.indexOf(this.highlightedEl);\n this.setValueByIndex(pos);\n }\n break;\n case KeyCode.DOWN:\n case KeyCode.UP:\n const isDown = key === KeyCode.DOWN;\n let itemToHighlight;\n e.preventDefault();\n if (!this.highlightedEl) {\n itemToHighlight = this.itemEls[isDown ? 0 : this.itemEls.length - 1];\n }\n else {\n const currentIdx = this.itemEls.indexOf(this.highlightedEl);\n let nextPos = currentIdx + (isDown ? 1 : -1);\n nextPos = Math.min(Math.max(nextPos, 0), this.itemEls.length - 1);\n itemToHighlight = this.itemEls[nextPos];\n }\n this.highlightItem(itemToHighlight);\n break;\n }\n }\n addOptions(listOptions) {\n listOptions.forEach(listOption => this.addOption(listOption));\n return this;\n }\n addOption(listOption) {\n const { value, text } = listOption;\n const sanitisedText = escapeString(text || value);\n this.options.push({ value, text: sanitisedText });\n this.renderOption(value, sanitisedText);\n this.updateIndices();\n return this;\n }\n updateIndices() {\n const options = this.getGui().querySelectorAll('.ag-list-item');\n options.forEach((option, idx) => {\n setAriaPosInSet(option, idx + 1);\n setAriaSetSize(option, options.length);\n });\n }\n renderOption(value, text) {\n const itemEl = document.createElement('div');\n setAriaRole(itemEl, 'option');\n itemEl.classList.add('ag-list-item', `ag-${this.cssIdentifier}-list-item`);\n itemEl.innerHTML = `${text}`;\n itemEl.tabIndex = -1;\n this.itemEls.push(itemEl);\n this.addManagedListener(itemEl, 'mouseover', () => this.highlightItem(itemEl));\n this.addManagedListener(itemEl, 'mouseleave', () => this.clearHighlighted());\n this.addManagedListener(itemEl, 'click', () => this.setValue(value));\n this.getGui().appendChild(itemEl);\n }\n setValue(value, silent) {\n if (this.value === value) {\n this.fireItemSelected();\n return this;\n }\n if (value == null) {\n this.reset();\n return this;\n }\n const idx = this.options.findIndex(option => option.value === value);\n if (idx !== -1) {\n const option = this.options[idx];\n this.value = option.value;\n this.displayValue = option.text != null ? option.text : option.value;\n this.highlightItem(this.itemEls[idx]);\n if (!silent) {\n this.fireChangeEvent();\n }\n }\n return this;\n }\n setValueByIndex(idx) {\n return this.setValue(this.options[idx].value);\n }\n getValue() {\n return this.value;\n }\n getDisplayValue() {\n return this.displayValue;\n }\n refreshHighlighted() {\n this.clearHighlighted();\n const idx = this.options.findIndex(option => option.value === this.value);\n if (idx !== -1) {\n this.highlightItem(this.itemEls[idx]);\n }\n }\n reset() {\n this.value = null;\n this.displayValue = null;\n this.clearHighlighted();\n this.fireChangeEvent();\n }\n highlightItem(el) {\n if (!el.offsetParent) {\n return;\n }\n this.clearHighlighted();\n this.highlightedEl = el;\n this.highlightedEl.classList.add(AgList.ACTIVE_CLASS);\n setAriaSelected(this.highlightedEl, true);\n this.highlightedEl.focus();\n }\n clearHighlighted() {\n if (!this.highlightedEl || !this.highlightedEl.offsetParent) {\n return;\n }\n this.highlightedEl.classList.remove(AgList.ACTIVE_CLASS);\n setAriaSelected(this.highlightedEl, false);\n this.highlightedEl = null;\n }\n fireChangeEvent() {\n this.dispatchEvent({ type: Events.EVENT_FIELD_VALUE_CHANGED });\n this.fireItemSelected();\n }\n fireItemSelected() {\n this.dispatchEvent({ type: AgList.EVENT_ITEM_SELECTED });\n }\n}\nAgList.EVENT_ITEM_SELECTED = 'selectedItem';\nAgList.ACTIVE_CLASS = 'ag-active-item';\n__decorate([\n PostConstruct\n], AgList.prototype, \"init\", null);\n","import { AgPickerField } from \"./agPickerField.mjs\";\nimport { AgList } from \"./agList.mjs\";\nimport { Events } from \"../eventKeys.mjs\";\nimport { KeyCode } from \"../constants/keyCode.mjs\";\nexport class AgSelect extends AgPickerField {\n constructor(config) {\n super(Object.assign({ pickerAriaLabelKey: 'ariaLabelSelectField', pickerAriaLabelValue: 'Select Field', pickerType: 'ag-list', className: 'ag-select', pickerIcon: 'smallDown', ariaRole: 'listbox' }, config));\n }\n postConstruct() {\n var _a;\n super.postConstruct();\n this.createListComponent();\n this.eWrapper.tabIndex = (_a = this.gridOptionsService.getNum('tabIndex')) !== null && _a !== void 0 ? _a : 0;\n }\n createListComponent() {\n this.listComponent = this.createBean(new AgList('select'));\n this.listComponent.setParentComponent(this);\n this.listComponent.addGuiEventListener('keydown', (e) => {\n if (e.key === KeyCode.TAB) {\n e.preventDefault();\n e.stopImmediatePropagation();\n this.getGui().dispatchEvent(new KeyboardEvent('keydown', {\n key: e.key,\n shiftKey: e.shiftKey,\n ctrlKey: e.ctrlKey,\n bubbles: true\n }));\n }\n ;\n });\n this.listComponent.addManagedListener(this.listComponent, AgList.EVENT_ITEM_SELECTED, () => {\n this.hidePicker();\n this.dispatchEvent({ type: AgSelect.EVENT_ITEM_SELECTED });\n });\n this.listComponent.addManagedListener(this.listComponent, Events.EVENT_FIELD_VALUE_CHANGED, () => {\n if (!this.listComponent) {\n return;\n }\n this.setValue(this.listComponent.getValue(), false, true);\n this.hidePicker();\n });\n }\n createPickerComponent() {\n // do not create the picker every time to save state\n return this.listComponent;\n }\n showPicker() {\n if (!this.listComponent) {\n return;\n }\n super.showPicker();\n this.listComponent.refreshHighlighted();\n }\n addOptions(options) {\n options.forEach(option => this.addOption(option));\n return this;\n }\n addOption(option) {\n this.listComponent.addOption(option);\n return this;\n }\n setValue(value, silent, fromPicker) {\n if (this.value === value || !this.listComponent) {\n return this;\n }\n if (!fromPicker) {\n this.listComponent.setValue(value, true);\n }\n const newValue = this.listComponent.getValue();\n if (newValue === this.getValue()) {\n return this;\n }\n this.eDisplayField.innerHTML = this.listComponent.getDisplayValue();\n return super.setValue(value, silent);\n }\n destroy() {\n if (this.listComponent) {\n this.destroyBean(this.listComponent);\n this.listComponent = undefined;\n }\n super.destroy();\n }\n}\nAgSelect.EVENT_ITEM_SELECTED = 'selectedItem';\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { RefSelector } from './componentAnnotations.mjs';\nimport { AgAbstractField } from './agAbstractField.mjs';\nimport { setDisabled, setElementWidth, addOrRemoveAttribute } from '../utils/dom.mjs';\nimport { setAriaLabelledBy, setAriaLabel } from '../utils/aria.mjs';\nimport { exists } from '../utils/generic.mjs';\nexport class AgAbstractInputField extends AgAbstractField {\n constructor(config, className, inputType = 'text', displayFieldTag = 'input') {\n super(config, /* html */ `\n
\n
\n
\n <${displayFieldTag} ref=\"eInput\" class=\"ag-input-field-input\">\n
\n
`, className);\n this.inputType = inputType;\n this.displayFieldTag = displayFieldTag;\n }\n postConstruct() {\n super.postConstruct();\n this.setInputType();\n this.eLabel.classList.add(`${this.className}-label`);\n this.eWrapper.classList.add(`${this.className}-input-wrapper`);\n this.eInput.classList.add(`${this.className}-input`);\n this.addCssClass('ag-input-field');\n this.eInput.id = this.eInput.id || `ag-${this.getCompId()}-input`;\n const { width, value } = this.config;\n if (width != null) {\n this.setWidth(width);\n }\n if (value != null) {\n this.setValue(value);\n }\n this.addInputListeners();\n this.activateTabIndex([this.eInput]);\n }\n refreshLabel() {\n if (exists(this.getLabel())) {\n setAriaLabelledBy(this.eInput, this.getLabelId());\n }\n else {\n this.eInput.removeAttribute('aria-labelledby');\n }\n super.refreshLabel();\n }\n addInputListeners() {\n this.addManagedListener(this.eInput, 'input', e => this.setValue(e.target.value));\n }\n setInputType() {\n if (this.displayFieldTag === 'input') {\n this.eInput.setAttribute('type', this.inputType);\n }\n }\n getInputElement() {\n return this.eInput;\n }\n setInputWidth(width) {\n setElementWidth(this.eWrapper, width);\n return this;\n }\n setInputName(name) {\n this.getInputElement().setAttribute('name', name);\n return this;\n }\n getFocusableElement() {\n return this.eInput;\n }\n setMaxLength(length) {\n const eInput = this.eInput;\n eInput.maxLength = length;\n return this;\n }\n setInputPlaceholder(placeholder) {\n addOrRemoveAttribute(this.eInput, 'placeholder', placeholder);\n return this;\n }\n setInputAriaLabel(label) {\n setAriaLabel(this.eInput, label);\n return this;\n }\n setDisabled(disabled) {\n setDisabled(this.eInput, disabled);\n return super.setDisabled(disabled);\n }\n setAutoComplete(value) {\n if (value === true) {\n // Remove the autocomplete attribute if the value is explicitly set to true\n // to allow the default browser autocomplete/autofill behaviour.\n addOrRemoveAttribute(this.eInput, 'autocomplete', null);\n }\n else {\n // When a string is provided, use it as the value of the autocomplete attribute.\n // This enables users to specify how they want to the browser to handle the autocomplete on the input, as per spec:\n // https://developer.mozilla.org/en-US/docs/Web/HTML/Attributes/autocomplete#values\n const autoCompleteValue = typeof value === 'string' ? value : 'off';\n addOrRemoveAttribute(this.eInput, 'autocomplete', autoCompleteValue);\n }\n return this;\n }\n}\n__decorate([\n RefSelector('eLabel')\n], AgAbstractInputField.prototype, \"eLabel\", void 0);\n__decorate([\n RefSelector('eWrapper')\n], AgAbstractInputField.prototype, \"eWrapper\", void 0);\n__decorate([\n RefSelector('eInput')\n], AgAbstractInputField.prototype, \"eInput\", void 0);\n","import { Events } from \"../events.mjs\";\nimport { AgAbstractInputField } from './agAbstractInputField.mjs';\nexport class AgCheckbox extends AgAbstractInputField {\n constructor(config, className = 'ag-checkbox', inputType = 'checkbox') {\n super(config, className, inputType);\n this.labelAlignment = 'right';\n this.selected = false;\n this.readOnly = false;\n this.passive = false;\n }\n addInputListeners() {\n this.addManagedListener(this.eInput, 'click', this.onCheckboxClick.bind(this));\n this.addManagedListener(this.eLabel, 'click', this.toggle.bind(this));\n }\n getNextValue() {\n return this.selected === undefined ? true : !this.selected;\n }\n setPassive(passive) {\n this.passive = passive;\n }\n isReadOnly() {\n return this.readOnly;\n }\n setReadOnly(readOnly) {\n this.eWrapper.classList.toggle('ag-disabled', readOnly);\n this.eInput.disabled = readOnly;\n this.readOnly = readOnly;\n }\n setDisabled(disabled) {\n this.eWrapper.classList.toggle('ag-disabled', disabled);\n return super.setDisabled(disabled);\n }\n toggle() {\n if (this.eInput.disabled) {\n return;\n }\n const previousValue = this.isSelected();\n const nextValue = this.getNextValue();\n if (this.passive) {\n this.dispatchChange(nextValue, previousValue);\n }\n else {\n this.setValue(nextValue);\n }\n }\n getValue() {\n return this.isSelected();\n }\n setValue(value, silent) {\n this.refreshSelectedClass(value);\n this.setSelected(value, silent);\n return this;\n }\n setName(name) {\n const input = this.getInputElement();\n input.name = name;\n return this;\n }\n isSelected() {\n return this.selected;\n }\n setSelected(selected, silent) {\n if (this.isSelected() === selected) {\n return;\n }\n this.previousValue = this.isSelected();\n selected = this.selected = typeof selected === 'boolean' ? selected : undefined;\n this.eInput.checked = selected;\n this.eInput.indeterminate = selected === undefined;\n if (!silent) {\n this.dispatchChange(this.selected, this.previousValue);\n }\n }\n dispatchChange(selected, previousValue, event) {\n this.dispatchEvent({ type: Events.EVENT_FIELD_VALUE_CHANGED, selected, previousValue, event });\n const input = this.getInputElement();\n const checkboxChangedEvent = {\n type: Events.EVENT_CHECKBOX_CHANGED,\n id: input.id,\n name: input.name,\n selected,\n previousValue\n };\n this.eventService.dispatchEvent(checkboxChangedEvent);\n }\n onCheckboxClick(e) {\n if (this.passive || this.eInput.disabled) {\n return;\n }\n const previousValue = this.isSelected();\n const selected = this.selected = e.target.checked;\n this.refreshSelectedClass(selected);\n this.dispatchChange(selected, previousValue, e);\n }\n refreshSelectedClass(value) {\n this.eWrapper.classList.toggle('ag-checked', value === true);\n this.eWrapper.classList.toggle('ag-indeterminate', value == null);\n }\n}\n","import { AgCheckbox } from './agCheckbox.mjs';\nimport { Events } from '../eventKeys.mjs';\nexport class AgRadioButton extends AgCheckbox {\n constructor(config) {\n super(config, 'ag-radio-button', 'radio');\n }\n isSelected() {\n return this.eInput.checked;\n }\n toggle() {\n if (this.eInput.disabled) {\n return;\n }\n // do not allow an active radio button to be deselected\n if (!this.isSelected()) {\n this.setValue(true);\n }\n }\n addInputListeners() {\n super.addInputListeners();\n this.addManagedListener(this.eventService, Events.EVENT_CHECKBOX_CHANGED, this.onChange.bind(this));\n }\n /**\n * This ensures that if another radio button in the same named group is selected, we deselect this radio button.\n * By default the browser does this for you, but we are managing classes ourselves in order to ensure input\n * elements are styled correctly in IE11, and the DOM 'changed' event is only fired when a button is selected,\n * not deselected, so we need to use our own event.\n */\n onChange(event) {\n if (event.selected &&\n event.name &&\n this.eInput.name &&\n this.eInput.name === event.name &&\n event.id &&\n this.eInput.id !== event.id) {\n this.setValue(false, true);\n }\n }\n}\n","import { OptionsFactory } from './optionsFactory.mjs';\nimport { ProvidedFilter } from './providedFilter.mjs';\nimport { AgPromise } from '../../utils/index.mjs';\nimport { AgSelect } from '../../widgets/agSelect.mjs';\nimport { AgRadioButton } from '../../widgets/agRadioButton.mjs';\nimport { areEqual } from '../../utils/array.mjs';\nimport { setDisplayed, setDisabled, removeFromParent } from '../../utils/dom.mjs';\nimport { DEFAULT_FILTER_LOCALE_TEXT } from '../filterLocaleText.mjs';\nimport { Component } from '../../widgets/component.mjs';\nimport { AgAbstractInputField } from '../../widgets/agAbstractInputField.mjs';\nimport { doOnce, isFunction } from '../../utils/function.mjs';\nexport class SimpleFilterModelFormatter {\n constructor(localeService, optionsFactory, valueFormatter) {\n this.localeService = localeService;\n this.optionsFactory = optionsFactory;\n this.valueFormatter = valueFormatter;\n }\n // used by:\n // 1) NumberFloatingFilter & TextFloatingFilter: Always, for both when editable and read only.\n // 2) DateFloatingFilter: Only when read only (as we show text rather than a date picker when read only)\n getModelAsString(model) {\n if (!model) {\n return null;\n }\n const isCombined = model.operator != null;\n const translate = this.localeService.getLocaleTextFunc();\n if (isCombined) {\n const combinedModel = model;\n let { conditions } = combinedModel;\n if (!conditions) {\n const { condition1, condition2 } = combinedModel;\n conditions = [condition1, condition2];\n }\n const customOptions = conditions.map(condition => this.getModelAsString(condition));\n const joinOperatorTranslateKey = combinedModel.operator === 'AND' ? 'andCondition' : 'orCondition';\n return customOptions.join(` ${translate(joinOperatorTranslateKey, DEFAULT_FILTER_LOCALE_TEXT[joinOperatorTranslateKey])} `);\n }\n else if (model.type === SimpleFilter.BLANK || model.type === SimpleFilter.NOT_BLANK) {\n return translate(model.type, model.type);\n }\n else {\n const condition = model;\n const customOption = this.optionsFactory.getCustomOption(condition.type);\n // For custom filter options we display the Name of the filter instead\n // of displaying the `from` value, as it wouldn't be relevant\n const { displayKey, displayName, numberOfInputs } = customOption || {};\n if (displayKey && displayName && numberOfInputs === 0) {\n translate(displayKey, displayName);\n return displayName;\n }\n return this.conditionToString(condition, customOption);\n }\n }\n updateParams(params) {\n this.optionsFactory = params.optionsFactory;\n }\n formatValue(value) {\n var _a;\n return this.valueFormatter ? ((_a = this.valueFormatter(value !== null && value !== void 0 ? value : null)) !== null && _a !== void 0 ? _a : '') : String(value);\n }\n}\n/**\n * Every filter with a dropdown where the user can specify a comparing type against the filter values.\n *\n * @param M type of filter-model managed by the concrete sub-class that extends this type\n * @param V type of value managed by the concrete sub-class that extends this type\n * @param E type of UI element used for collecting user-input\n */\nexport class SimpleFilter extends ProvidedFilter {\n constructor() {\n super(...arguments);\n this.eTypes = [];\n this.eJoinOperatorPanels = [];\n this.eJoinOperatorsAnd = [];\n this.eJoinOperatorsOr = [];\n this.eConditionBodies = [];\n this.listener = () => this.onUiChanged();\n this.lastUiCompletePosition = null;\n this.joinOperatorId = 0;\n }\n getNumberOfInputs(type) {\n const customOpts = this.optionsFactory.getCustomOption(type);\n if (customOpts) {\n const { numberOfInputs } = customOpts;\n return numberOfInputs != null ? numberOfInputs : 1;\n }\n const zeroInputTypes = [\n SimpleFilter.EMPTY, SimpleFilter.NOT_BLANK, SimpleFilter.BLANK,\n ];\n if (type && zeroInputTypes.indexOf(type) >= 0) {\n return 0;\n }\n else if (type === SimpleFilter.IN_RANGE) {\n return 2;\n }\n return 1;\n }\n // floating filter calls this when user applies filter from floating filter\n onFloatingFilterChanged(type, value) {\n this.setTypeFromFloatingFilter(type);\n this.setValueFromFloatingFilter(value);\n this.onUiChanged(true);\n }\n setTypeFromFloatingFilter(type) {\n this.eTypes.forEach((eType, position) => {\n if (position === 0) {\n eType.setValue(type, true);\n }\n else {\n eType.setValue(this.optionsFactory.getDefaultOption(), true);\n }\n });\n }\n getModelFromUi() {\n const conditions = this.getUiCompleteConditions();\n if (conditions.length === 0) {\n return null;\n }\n if (this.maxNumConditions > 1 && conditions.length > 1) {\n return {\n filterType: this.getFilterType(),\n operator: this.getJoinOperator(),\n condition1: conditions[0],\n condition2: conditions[1],\n conditions\n };\n }\n return conditions[0];\n }\n getConditionTypes() {\n return this.eTypes.map(eType => eType.getValue());\n }\n getConditionType(position) {\n return this.eTypes[position].getValue();\n }\n getJoinOperator() {\n if (this.eJoinOperatorsOr.length === 0) {\n return this.defaultJoinOperator;\n }\n return this.eJoinOperatorsOr[0].getValue() === true ? 'OR' : 'AND';\n }\n areModelsEqual(a, b) {\n // both are missing\n if (!a && !b) {\n return true;\n }\n // one is missing, other present\n if ((!a && b) || (a && !b)) {\n return false;\n }\n // one is combined, the other is not\n const aIsSimple = !a.operator;\n const bIsSimple = !b.operator;\n const oneSimpleOneCombined = (!aIsSimple && bIsSimple) || (aIsSimple && !bIsSimple);\n if (oneSimpleOneCombined) {\n return false;\n }\n let res;\n // otherwise both present, so compare\n if (aIsSimple) {\n const aSimple = a;\n const bSimple = b;\n res = this.areSimpleModelsEqual(aSimple, bSimple);\n }\n else {\n const aCombined = a;\n const bCombined = b;\n res = aCombined.operator === bCombined.operator\n && areEqual(aCombined.conditions, bCombined.conditions, (aModel, bModel) => this.areSimpleModelsEqual(aModel, bModel));\n }\n return res;\n }\n setModelIntoUi(model) {\n const isCombined = model.operator;\n if (isCombined) {\n let combinedModel = model;\n if (!combinedModel.conditions) {\n combinedModel.conditions = [\n combinedModel.condition1,\n combinedModel.condition2\n ];\n }\n const numConditions = this.validateAndUpdateConditions(combinedModel.conditions);\n const numPrevConditions = this.getNumConditions();\n if (numConditions < numPrevConditions) {\n this.removeConditionsAndOperators(numConditions);\n }\n else if (numConditions > numPrevConditions) {\n for (let i = numPrevConditions; i < numConditions; i++) {\n this.createJoinOperatorPanel();\n this.createOption();\n }\n }\n const orChecked = combinedModel.operator === 'OR';\n this.eJoinOperatorsAnd.forEach(eJoinOperatorAnd => eJoinOperatorAnd.setValue(!orChecked, true));\n this.eJoinOperatorsOr.forEach(eJoinOperatorOr => eJoinOperatorOr.setValue(orChecked, true));\n combinedModel.conditions.forEach((condition, position) => {\n this.eTypes[position].setValue(condition.type, true);\n this.setConditionIntoUi(condition, position);\n });\n }\n else {\n const simpleModel = model;\n if (this.getNumConditions() > 1) {\n this.removeConditionsAndOperators(1);\n }\n this.eTypes[0].setValue(simpleModel.type, true);\n this.setConditionIntoUi(simpleModel, 0);\n }\n this.lastUiCompletePosition = this.getNumConditions() - 1;\n this.createMissingConditionsAndOperators();\n this.onUiChanged();\n return AgPromise.resolve();\n }\n validateAndUpdateConditions(conditions) {\n let numConditions = conditions.length;\n if (numConditions > this.maxNumConditions) {\n conditions.splice(this.maxNumConditions);\n doOnce(() => console.warn('AG Grid: Filter Model contains more conditions than \"filterParams.maxNumConditions\". Additional conditions have been ignored.'), 'simpleFilterSetModelMaxNumConditions');\n numConditions = this.maxNumConditions;\n }\n return numConditions;\n }\n doesFilterPass(params) {\n var _a;\n const model = this.getModel();\n if (model == null) {\n return true;\n }\n const { operator } = model;\n const models = [];\n if (operator) {\n const combinedModel = model;\n models.push(...((_a = combinedModel.conditions) !== null && _a !== void 0 ? _a : []));\n }\n else {\n models.push(model);\n }\n const combineFunction = operator && operator === 'OR' ? 'some' : 'every';\n return models[combineFunction](m => this.individualConditionPasses(params, m));\n }\n setParams(params) {\n super.setParams(params);\n this.setNumConditions(params);\n this.defaultJoinOperator = this.getDefaultJoinOperator(params.defaultJoinOperator);\n this.filterPlaceholder = params.filterPlaceholder;\n this.optionsFactory = new OptionsFactory();\n this.optionsFactory.init(params, this.getDefaultFilterOptions());\n this.createFilterListOptions();\n this.createOption();\n this.createMissingConditionsAndOperators();\n if (this.isReadOnly()) {\n // only do this when read only (so no other focusable elements), otherwise the tab order breaks\n // as the tabbed layout managed focus feature will focus the body when it shouldn't\n this.eFilterBody.setAttribute('tabindex', '-1');\n }\n }\n setNumConditions(params) {\n var _a, _b;\n if (params.suppressAndOrCondition != null) {\n doOnce(() => console.warn('AG Grid: Since v29.2 \"filterParams.suppressAndOrCondition\" is deprecated. Use \"filterParams.maxNumConditions = 1\" instead.'), 'simpleFilterSuppressAndOrCondition');\n }\n if (params.alwaysShowBothConditions != null) {\n doOnce(() => console.warn('AG Grid: Since v29.2 \"filterParams.alwaysShowBothConditions\" is deprecated. Use \"filterParams.numAlwaysVisibleConditions = 2\" instead.'), 'simpleFilterAlwaysShowBothConditions');\n }\n this.maxNumConditions = (_a = params.maxNumConditions) !== null && _a !== void 0 ? _a : (params.suppressAndOrCondition ? 1 : 2);\n if (this.maxNumConditions < 1) {\n doOnce(() => console.warn('AG Grid: \"filterParams.maxNumConditions\" must be greater than or equal to zero.'), 'simpleFilterMaxNumConditions');\n this.maxNumConditions = 1;\n }\n this.numAlwaysVisibleConditions = (_b = params.numAlwaysVisibleConditions) !== null && _b !== void 0 ? _b : (params.alwaysShowBothConditions ? 2 : 1);\n if (this.numAlwaysVisibleConditions < 1) {\n doOnce(() => console.warn('AG Grid: \"filterParams.numAlwaysVisibleConditions\" must be greater than or equal to zero.'), 'simpleFilterNumAlwaysVisibleConditions');\n this.numAlwaysVisibleConditions = 1;\n }\n if (this.numAlwaysVisibleConditions > this.maxNumConditions) {\n doOnce(() => console.warn('AG Grid: \"filterParams.numAlwaysVisibleConditions\" cannot be greater than \"filterParams.maxNumConditions\".'), 'simpleFilterNumAlwaysVisibleGreaterThanMaxNumConditions');\n this.numAlwaysVisibleConditions = this.maxNumConditions;\n }\n }\n createOption() {\n const eType = this.createManagedBean(new AgSelect());\n this.eTypes.push(eType);\n eType.addCssClass('ag-filter-select');\n this.eFilterBody.appendChild(eType.getGui());\n const eConditionBody = this.createValueElement();\n this.eConditionBodies.push(eConditionBody);\n this.eFilterBody.appendChild(eConditionBody);\n this.putOptionsIntoDropdown(eType);\n this.resetType(eType);\n const position = this.getNumConditions() - 1;\n this.forEachPositionInput(position, (element) => this.resetInput(element));\n this.addChangedListeners(eType, position);\n }\n createJoinOperatorPanel() {\n const eJoinOperatorPanel = document.createElement('div');\n this.eJoinOperatorPanels.push(eJoinOperatorPanel);\n eJoinOperatorPanel.classList.add('ag-filter-condition');\n const eJoinOperatorAnd = this.createJoinOperator(this.eJoinOperatorsAnd, eJoinOperatorPanel, 'and');\n const eJoinOperatorOr = this.createJoinOperator(this.eJoinOperatorsOr, eJoinOperatorPanel, 'or');\n this.eFilterBody.appendChild(eJoinOperatorPanel);\n const index = this.eJoinOperatorPanels.length - 1;\n const uniqueGroupId = this.joinOperatorId++;\n this.resetJoinOperatorAnd(eJoinOperatorAnd, index, uniqueGroupId);\n this.resetJoinOperatorOr(eJoinOperatorOr, index, uniqueGroupId);\n if (!this.isReadOnly()) {\n eJoinOperatorAnd.onValueChange(this.listener);\n eJoinOperatorOr.onValueChange(this.listener);\n }\n }\n createJoinOperator(eJoinOperators, eJoinOperatorPanel, andOr) {\n const eJoinOperator = this.createManagedBean(new AgRadioButton());\n eJoinOperators.push(eJoinOperator);\n eJoinOperator.addCssClass('ag-filter-condition-operator');\n eJoinOperator.addCssClass(`ag-filter-condition-operator-${andOr}`);\n eJoinOperatorPanel.appendChild(eJoinOperator.getGui());\n return eJoinOperator;\n }\n getDefaultJoinOperator(defaultJoinOperator) {\n return defaultJoinOperator === 'AND' || defaultJoinOperator === 'OR' ? defaultJoinOperator : 'AND';\n }\n createFilterListOptions() {\n const filterOptions = this.optionsFactory.getFilterOptions();\n this.filterListOptions = filterOptions.map(option => typeof option === 'string' ?\n this.createBoilerplateListOption(option) :\n this.createCustomListOption(option));\n }\n putOptionsIntoDropdown(eType) {\n // Add specified options to condition drop-down.\n this.filterListOptions.forEach(listOption => {\n eType.addOption(listOption);\n });\n // Make drop-downs read-only if there is only one option.\n eType.setDisabled(this.filterListOptions.length <= 1);\n }\n createBoilerplateListOption(option) {\n return { value: option, text: this.translate(option) };\n }\n createCustomListOption(option) {\n const { displayKey } = option;\n const customOption = this.optionsFactory.getCustomOption(option.displayKey);\n return {\n value: displayKey,\n text: customOption ?\n this.localeService.getLocaleTextFunc()(customOption.displayKey, customOption.displayName) :\n this.translate(displayKey),\n };\n }\n /**\n * @deprecated As of v29.2 filters can have more than two conditions. Check `colDef.filterParams.maxNumConditions` instead.\n */\n isAllowTwoConditions() {\n return this.maxNumConditions >= 2;\n }\n createBodyTemplate() {\n // created dynamically\n return '';\n }\n getCssIdentifier() {\n return 'simple-filter';\n }\n updateUiVisibility() {\n const joinOperator = this.getJoinOperator();\n this.updateNumConditions();\n // from here, the number of elements in all the collections is correct, so can just update the values/statuses\n this.updateConditionStatusesAndValues(this.lastUiCompletePosition, joinOperator);\n }\n updateNumConditions() {\n var _a;\n // Collection sizes are already correct if updated via API, so only need to handle UI updates here\n let lastUiCompletePosition = -1;\n let areAllConditionsUiComplete = true;\n for (let position = 0; position < this.getNumConditions(); position++) {\n if (this.isConditionUiComplete(position)) {\n lastUiCompletePosition = position;\n }\n else {\n areAllConditionsUiComplete = false;\n }\n }\n if (this.shouldAddNewConditionAtEnd(areAllConditionsUiComplete)) {\n this.createJoinOperatorPanel();\n this.createOption();\n }\n else {\n const activePosition = (_a = this.lastUiCompletePosition) !== null && _a !== void 0 ? _a : this.getNumConditions() - 2;\n if (lastUiCompletePosition < activePosition) {\n // remove any incomplete conditions at the end, excluding the active position\n this.removeConditionsAndOperators(activePosition + 1);\n const removeStartPosition = lastUiCompletePosition + 1;\n const numConditionsToRemove = activePosition - removeStartPosition;\n if (numConditionsToRemove > 0) {\n this.removeConditionsAndOperators(removeStartPosition, numConditionsToRemove);\n }\n this.createMissingConditionsAndOperators();\n }\n }\n this.lastUiCompletePosition = lastUiCompletePosition;\n }\n updateConditionStatusesAndValues(lastUiCompletePosition, joinOperator) {\n this.eTypes.forEach((eType, position) => {\n const disabled = this.isConditionDisabled(position, lastUiCompletePosition);\n eType.setDisabled(disabled || this.filterListOptions.length <= 1);\n if (position === 1) {\n setDisabled(this.eJoinOperatorPanels[0], disabled);\n this.eJoinOperatorsAnd[0].setDisabled(disabled);\n this.eJoinOperatorsOr[0].setDisabled(disabled);\n }\n });\n this.eConditionBodies.forEach((element, index) => {\n setDisplayed(element, this.isConditionBodyVisible(index));\n });\n const orChecked = (joinOperator !== null && joinOperator !== void 0 ? joinOperator : this.getJoinOperator()) === 'OR';\n this.eJoinOperatorsAnd.forEach((eJoinOperatorAnd, index) => {\n eJoinOperatorAnd.setValue(!orChecked, true);\n });\n this.eJoinOperatorsOr.forEach((eJoinOperatorOr, index) => {\n eJoinOperatorOr.setValue(orChecked, true);\n });\n this.forEachInput((element, index, position, numberOfInputs) => {\n this.setElementDisplayed(element, index < numberOfInputs);\n this.setElementDisabled(element, this.isConditionDisabled(position, lastUiCompletePosition));\n });\n this.resetPlaceholder();\n }\n shouldAddNewConditionAtEnd(areAllConditionsUiComplete) {\n return areAllConditionsUiComplete && this.getNumConditions() < this.maxNumConditions && !this.isReadOnly();\n }\n removeConditionsAndOperators(startPosition, deleteCount) {\n if (startPosition >= this.getNumConditions()) {\n return;\n }\n this.removeComponents(this.eTypes, startPosition, deleteCount);\n this.removeElements(this.eConditionBodies, startPosition, deleteCount);\n this.removeValueElements(startPosition, deleteCount);\n const joinOperatorIndex = Math.max(startPosition - 1, 0);\n this.removeElements(this.eJoinOperatorPanels, joinOperatorIndex, deleteCount);\n this.removeComponents(this.eJoinOperatorsAnd, joinOperatorIndex, deleteCount);\n this.removeComponents(this.eJoinOperatorsOr, joinOperatorIndex, deleteCount);\n }\n removeElements(elements, startPosition, deleteCount) {\n const removedElements = this.removeItems(elements, startPosition, deleteCount);\n removedElements.forEach(element => removeFromParent(element));\n }\n removeComponents(components, startPosition, deleteCount) {\n const removedComponents = this.removeItems(components, startPosition, deleteCount);\n removedComponents.forEach(comp => {\n removeFromParent(comp.getGui());\n this.destroyBean(comp);\n });\n }\n removeItems(items, startPosition, deleteCount) {\n return deleteCount == null ? items.splice(startPosition) : items.splice(startPosition, deleteCount);\n }\n afterGuiAttached(params) {\n super.afterGuiAttached(params);\n this.resetPlaceholder();\n if (!(params === null || params === void 0 ? void 0 : params.suppressFocus)) {\n if (this.isReadOnly()) {\n // something needs focus otherwise keyboard navigation breaks, so focus the filter body\n this.eFilterBody.focus();\n }\n else {\n const firstInput = this.getInputs(0)[0];\n if (!firstInput) {\n return;\n }\n if (firstInput instanceof AgAbstractInputField) {\n firstInput.getInputElement().focus();\n }\n }\n }\n }\n afterGuiDetached() {\n super.afterGuiDetached();\n const appliedModel = this.getModel();\n if (!this.areModelsEqual(appliedModel, this.getModelFromUi()) || this.hasInvalidInputs()) {\n this.resetUiToActiveModel(appliedModel);\n }\n // remove incomplete positions\n let lastUiCompletePosition = -1;\n // as we remove incomplete positions, the last UI complete position will change\n let updatedLastUiCompletePosition = -1;\n let conditionsRemoved = false;\n const joinOperator = this.getJoinOperator();\n for (let position = this.getNumConditions() - 1; position >= 0; position--) {\n if (this.isConditionUiComplete(position)) {\n if (lastUiCompletePosition === -1) {\n lastUiCompletePosition = position;\n updatedLastUiCompletePosition = position;\n }\n }\n else {\n const shouldRemovePositionAtEnd = position >= this.numAlwaysVisibleConditions && !this.isConditionUiComplete(position - 1);\n const positionBeforeLastUiCompletePosition = position < lastUiCompletePosition;\n if (shouldRemovePositionAtEnd || positionBeforeLastUiCompletePosition) {\n this.removeConditionsAndOperators(position, 1);\n conditionsRemoved = true;\n if (positionBeforeLastUiCompletePosition) {\n updatedLastUiCompletePosition--;\n }\n }\n }\n }\n let shouldUpdateConditionStatusesAndValues = false;\n if (this.getNumConditions() < this.numAlwaysVisibleConditions) {\n // if conditions have been removed, need to recreate new ones at the end up to the number required\n this.createMissingConditionsAndOperators();\n shouldUpdateConditionStatusesAndValues = true;\n }\n if (this.shouldAddNewConditionAtEnd(updatedLastUiCompletePosition === this.getNumConditions() - 1)) {\n this.createJoinOperatorPanel();\n this.createOption();\n shouldUpdateConditionStatusesAndValues = true;\n }\n if (shouldUpdateConditionStatusesAndValues) {\n this.updateConditionStatusesAndValues(updatedLastUiCompletePosition, joinOperator);\n }\n if (conditionsRemoved) {\n this.updateJoinOperatorsDisabled();\n }\n this.lastUiCompletePosition = updatedLastUiCompletePosition;\n }\n getPlaceholderText(defaultPlaceholder, position) {\n let placeholder = this.translate(defaultPlaceholder);\n if (isFunction(this.filterPlaceholder)) {\n const filterPlaceholderFn = this.filterPlaceholder;\n const filterOptionKey = this.eTypes[position].getValue();\n const filterOption = this.translate(filterOptionKey);\n placeholder = filterPlaceholderFn({\n filterOptionKey,\n filterOption,\n placeholder\n });\n }\n else if (typeof this.filterPlaceholder === 'string') {\n placeholder = this.filterPlaceholder;\n }\n return placeholder;\n }\n // allow sub-classes to reset HTML placeholders after UI update.\n resetPlaceholder() {\n const globalTranslate = this.localeService.getLocaleTextFunc();\n this.forEachInput((element, index, position, numberOfInputs) => {\n if (!(element instanceof AgAbstractInputField)) {\n return;\n }\n const placeholder = index === 0 && numberOfInputs > 1 ? 'inRangeStart' :\n index === 0 ? 'filterOoo' :\n 'inRangeEnd';\n const ariaLabel = index === 0 && numberOfInputs > 1 ? globalTranslate('ariaFilterFromValue', 'Filter from value') :\n index === 0 ? globalTranslate('ariaFilterValue', 'Filter Value') :\n globalTranslate('ariaFilterToValue', 'Filter to Value');\n element.setInputPlaceholder(this.getPlaceholderText(placeholder, position));\n element.setInputAriaLabel(ariaLabel);\n });\n }\n setElementValue(element, value, fromFloatingFilter) {\n if (element instanceof AgAbstractInputField) {\n element.setValue(value != null ? String(value) : null, true);\n }\n }\n setElementDisplayed(element, displayed) {\n if (element instanceof Component) {\n setDisplayed(element.getGui(), displayed);\n }\n }\n setElementDisabled(element, disabled) {\n if (element instanceof Component) {\n setDisabled(element.getGui(), disabled);\n }\n }\n attachElementOnChange(element, listener) {\n if (element instanceof AgAbstractInputField) {\n element.onValueChange(listener);\n }\n }\n forEachInput(cb) {\n this.getConditionTypes().forEach((type, position) => {\n this.forEachPositionTypeInput(position, type, cb);\n });\n }\n forEachPositionInput(position, cb) {\n const type = this.getConditionType(position);\n this.forEachPositionTypeInput(position, type, cb);\n }\n forEachPositionTypeInput(position, type, cb) {\n const numberOfInputs = this.getNumberOfInputs(type);\n const inputs = this.getInputs(position);\n for (let index = 0; index < inputs.length; index++) {\n const input = inputs[index];\n if (input != null) {\n cb(input, index, position, numberOfInputs);\n }\n }\n }\n isConditionDisabled(position, lastUiCompletePosition) {\n if (this.isReadOnly()) {\n return true;\n } // Read-only mode trumps everything.\n if (position === 0) {\n return false;\n } // Position 0 should typically be editable.\n // Only allow editing of a 2nd or later condition if the previous condition is complete and no subsequent conditions are complete.\n return position > lastUiCompletePosition + 1;\n }\n isConditionBodyVisible(position) {\n // Check that the condition needs inputs.\n const type = this.getConditionType(position);\n const numberOfInputs = this.getNumberOfInputs(type);\n return numberOfInputs > 0;\n }\n // returns true if the UI represents a working filter, eg all parts are filled out.\n // eg if text filter and textfield blank then returns false.\n isConditionUiComplete(position) {\n if (position >= this.getNumConditions()) {\n return false;\n } // Condition doesn't exist.\n const type = this.getConditionType(position);\n if (type === SimpleFilter.EMPTY) {\n return false;\n }\n if (this.getValues(position).some(v => v == null)) {\n return false;\n }\n return true;\n }\n getNumConditions() {\n return this.eTypes.length;\n }\n getUiCompleteConditions() {\n const conditions = [];\n for (let position = 0; position < this.getNumConditions(); position++) {\n if (this.isConditionUiComplete(position)) {\n conditions.push(this.createCondition(position));\n }\n }\n return conditions;\n }\n createMissingConditionsAndOperators() {\n if (this.isReadOnly()) {\n return;\n } // don't show incomplete conditions when read only\n for (let i = this.getNumConditions(); i < this.numAlwaysVisibleConditions; i++) {\n this.createJoinOperatorPanel();\n this.createOption();\n }\n }\n resetUiToDefaults(silent) {\n this.removeConditionsAndOperators(this.isReadOnly() ? 1 : this.numAlwaysVisibleConditions);\n this.eTypes.forEach(eType => this.resetType(eType));\n this.eJoinOperatorsAnd.forEach((eJoinOperatorAnd, index) => this.resetJoinOperatorAnd(eJoinOperatorAnd, index, this.joinOperatorId + index));\n this.eJoinOperatorsOr.forEach((eJoinOperatorOr, index) => this.resetJoinOperatorOr(eJoinOperatorOr, index, this.joinOperatorId + index));\n this.joinOperatorId++;\n this.forEachInput((element) => this.resetInput(element));\n this.resetPlaceholder();\n this.createMissingConditionsAndOperators();\n this.lastUiCompletePosition = null;\n if (!silent) {\n this.onUiChanged();\n }\n return AgPromise.resolve();\n }\n resetType(eType) {\n const translate = this.localeService.getLocaleTextFunc();\n const filteringLabel = translate('ariaFilteringOperator', 'Filtering operator');\n eType\n .setValue(this.optionsFactory.getDefaultOption(), true)\n .setAriaLabel(filteringLabel)\n .setDisabled(this.isReadOnly() || this.filterListOptions.length <= 1);\n }\n resetJoinOperatorAnd(eJoinOperatorAnd, index, uniqueGroupId) {\n this.resetJoinOperator(eJoinOperatorAnd, index, this.isDefaultOperator('AND'), this.translate('andCondition'), uniqueGroupId);\n }\n resetJoinOperatorOr(eJoinOperatorOr, index, uniqueGroupId) {\n this.resetJoinOperator(eJoinOperatorOr, index, this.isDefaultOperator('OR'), this.translate('orCondition'), uniqueGroupId);\n }\n resetJoinOperator(eJoinOperator, index, value, label, uniqueGroupId) {\n this.updateJoinOperatorDisabled(eJoinOperator\n .setValue(value, true)\n .setName(`ag-simple-filter-and-or-${this.getCompId()}-${uniqueGroupId}`)\n .setLabel(label), index);\n }\n updateJoinOperatorsDisabled() {\n this.eJoinOperatorsAnd.forEach((eJoinOperator, index) => this.updateJoinOperatorDisabled(eJoinOperator, index));\n this.eJoinOperatorsOr.forEach((eJoinOperator, index) => this.updateJoinOperatorDisabled(eJoinOperator, index));\n }\n updateJoinOperatorDisabled(eJoinOperator, index) {\n eJoinOperator.setDisabled(this.isReadOnly() || index > 0);\n }\n resetInput(element) {\n this.setElementValue(element, null);\n this.setElementDisabled(element, this.isReadOnly());\n }\n // puts model values into the UI\n setConditionIntoUi(model, position) {\n const values = this.mapValuesFromModel(model);\n this.forEachInput((element, index, elPosition, _) => {\n if (elPosition !== position) {\n return;\n }\n this.setElementValue(element, values[index] != null ? values[index] : null);\n });\n }\n // after floating filter changes, this sets the 'value' section. this is implemented by the base class\n // (as that's where value is controlled), the 'type' part from the floating filter is dealt with in this class.\n setValueFromFloatingFilter(value) {\n this.forEachInput((element, index, position, _) => {\n this.setElementValue(element, index === 0 && position === 0 ? value : null, true);\n });\n }\n isDefaultOperator(operator) {\n return operator === this.defaultJoinOperator;\n }\n addChangedListeners(eType, position) {\n if (this.isReadOnly()) {\n return;\n }\n eType.onValueChange(this.listener);\n this.forEachPositionInput(position, (element) => {\n this.attachElementOnChange(element, this.listener);\n });\n }\n /** returns true if the row passes the said condition */\n individualConditionPasses(params, filterModel) {\n const cellValue = this.getCellValue(params.node);\n const values = this.mapValuesFromModel(filterModel);\n const customFilterOption = this.optionsFactory.getCustomOption(filterModel.type);\n const customFilterResult = this.evaluateCustomFilter(customFilterOption, values, cellValue);\n if (customFilterResult != null) {\n return customFilterResult;\n }\n if (cellValue == null) {\n return this.evaluateNullValue(filterModel.type);\n }\n return this.evaluateNonNullValue(values, cellValue, filterModel, params);\n }\n evaluateCustomFilter(customFilterOption, values, cellValue) {\n if (customFilterOption == null) {\n return;\n }\n const { predicate } = customFilterOption;\n // only execute the custom filter if a value exists or a value isn't required, i.e. input is hidden\n if (predicate != null && !values.some(v => v == null)) {\n return predicate(values, cellValue);\n }\n // No custom filter invocation, indicate that to the caller.\n return;\n }\n isBlank(cellValue) {\n return cellValue == null ||\n (typeof cellValue === 'string' && cellValue.trim().length === 0);\n }\n hasInvalidInputs() {\n return false;\n }\n}\nSimpleFilter.EMPTY = 'empty';\nSimpleFilter.BLANK = 'blank';\nSimpleFilter.NOT_BLANK = 'notBlank';\nSimpleFilter.EQUALS = 'equals';\nSimpleFilter.NOT_EQUAL = 'notEqual';\nSimpleFilter.LESS_THAN = 'lessThan';\nSimpleFilter.LESS_THAN_OR_EQUAL = 'lessThanOrEqual';\nSimpleFilter.GREATER_THAN = 'greaterThan';\nSimpleFilter.GREATER_THAN_OR_EQUAL = 'greaterThanOrEqual';\nSimpleFilter.IN_RANGE = 'inRange';\nSimpleFilter.CONTAINS = 'contains';\nSimpleFilter.NOT_CONTAINS = 'notContains';\nSimpleFilter.STARTS_WITH = 'startsWith';\nSimpleFilter.ENDS_WITH = 'endsWith';\n","import { SimpleFilter } from \"./simpleFilter.mjs\";\nexport class ScalarFilter extends SimpleFilter {\n setParams(params) {\n super.setParams(params);\n this.scalarFilterParams = params;\n }\n evaluateNullValue(filterType) {\n switch (filterType) {\n case ScalarFilter.EQUALS:\n case ScalarFilter.NOT_EQUAL:\n if (this.scalarFilterParams.includeBlanksInEquals) {\n return true;\n }\n break;\n case ScalarFilter.GREATER_THAN:\n case ScalarFilter.GREATER_THAN_OR_EQUAL:\n if (this.scalarFilterParams.includeBlanksInGreaterThan) {\n return true;\n }\n break;\n case ScalarFilter.LESS_THAN:\n case ScalarFilter.LESS_THAN_OR_EQUAL:\n if (this.scalarFilterParams.includeBlanksInLessThan) {\n return true;\n }\n break;\n case ScalarFilter.IN_RANGE:\n if (this.scalarFilterParams.includeBlanksInRange) {\n return true;\n }\n break;\n case ScalarFilter.BLANK:\n return true;\n case ScalarFilter.NOT_BLANK:\n return false;\n }\n return false;\n }\n evaluateNonNullValue(values, cellValue, filterModel) {\n const comparator = this.comparator();\n const compareResult = values[0] != null ? comparator(values[0], cellValue) : 0;\n switch (filterModel.type) {\n case ScalarFilter.EQUALS:\n return compareResult === 0;\n case ScalarFilter.NOT_EQUAL:\n return compareResult !== 0;\n case ScalarFilter.GREATER_THAN:\n return compareResult > 0;\n case ScalarFilter.GREATER_THAN_OR_EQUAL:\n return compareResult >= 0;\n case ScalarFilter.LESS_THAN:\n return compareResult < 0;\n case ScalarFilter.LESS_THAN_OR_EQUAL:\n return compareResult <= 0;\n case ScalarFilter.IN_RANGE: {\n const compareToResult = comparator(values[1], cellValue);\n return this.scalarFilterParams.inRangeInclusive ?\n compareResult >= 0 && compareToResult <= 0 :\n compareResult > 0 && compareToResult < 0;\n }\n case ScalarFilter.BLANK:\n return this.isBlank(cellValue);\n case ScalarFilter.NOT_BLANK:\n return !this.isBlank(cellValue);\n default:\n console.warn('AG Grid: Unexpected type of filter \"' + filterModel.type + '\", it looks like the filter was configured with incorrect Filter Options');\n return true;\n }\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired } from '../../../context/context.mjs';\nimport { DateCompWrapper } from './dateCompWrapper.mjs';\nimport { SimpleFilter, SimpleFilterModelFormatter } from '../simpleFilter.mjs';\nimport { ScalarFilter } from '../scalarFilter.mjs';\nimport { serialiseDate, parseDateTimeFromString, dateToFormattedString } from '../../../utils/date.mjs';\nconst DEFAULT_MIN_YEAR = 1000;\nconst DEFAULT_MAX_YEAR = Infinity;\nexport class DateFilterModelFormatter extends SimpleFilterModelFormatter {\n constructor(dateFilterParams, localeService, optionsFactory) {\n super(localeService, optionsFactory);\n this.dateFilterParams = dateFilterParams;\n }\n conditionToString(condition, options) {\n const { type } = condition;\n const { numberOfInputs } = options || {};\n const isRange = type == SimpleFilter.IN_RANGE || numberOfInputs === 2;\n const dateFrom = parseDateTimeFromString(condition.dateFrom);\n const dateTo = parseDateTimeFromString(condition.dateTo);\n const format = this.dateFilterParams.inRangeFloatingFilterDateFormat;\n if (isRange) {\n const formattedFrom = dateFrom !== null ? dateToFormattedString(dateFrom, format) : 'null';\n const formattedTo = dateTo !== null ? dateToFormattedString(dateTo, format) : 'null';\n return `${formattedFrom}-${formattedTo}`;\n }\n if (dateFrom != null) {\n return dateToFormattedString(dateFrom, format);\n }\n // cater for when the type doesn't need a value\n return `${type}`;\n }\n updateParams(params) {\n super.updateParams(params);\n this.dateFilterParams = params.dateFilterParams;\n }\n}\nexport class DateFilter extends ScalarFilter {\n constructor() {\n super('dateFilter');\n this.eConditionPanelsFrom = [];\n this.eConditionPanelsTo = [];\n this.dateConditionFromComps = [];\n this.dateConditionToComps = [];\n this.minValidYear = DEFAULT_MIN_YEAR;\n this.maxValidYear = DEFAULT_MAX_YEAR;\n this.minValidDate = null;\n this.maxValidDate = null;\n }\n afterGuiAttached(params) {\n super.afterGuiAttached(params);\n this.dateConditionFromComps[0].afterGuiAttached(params);\n }\n mapValuesFromModel(filterModel) {\n // unlike the other filters, we do two things here:\n // 1) allow for different attribute names (same as done for other filters) (eg the 'from' and 'to'\n // are in different locations in Date and Number filter models)\n // 2) convert the type (because Date filter uses Dates, however model is 'string')\n //\n // NOTE: The conversion of string to date also removes the timezone - i.e. when user picks\n // a date from the UI, it will have timezone info in it. This is lost when creating\n // the model. When we recreate the date again here, it's without a timezone.\n const { dateFrom, dateTo, type } = filterModel || {};\n return [\n dateFrom && parseDateTimeFromString(dateFrom) || null,\n dateTo && parseDateTimeFromString(dateTo) || null,\n ].slice(0, this.getNumberOfInputs(type));\n }\n comparator() {\n return this.dateFilterParams.comparator ? this.dateFilterParams.comparator : this.defaultComparator.bind(this);\n }\n defaultComparator(filterDate, cellValue) {\n // The default comparator assumes that the cellValue is a date\n const cellAsDate = cellValue;\n if (cellValue == null || cellAsDate < filterDate) {\n return -1;\n }\n if (cellAsDate > filterDate) {\n return 1;\n }\n return 0;\n }\n setParams(params) {\n this.dateFilterParams = params;\n super.setParams(params);\n const yearParser = (param, fallback) => {\n if (params[param] != null) {\n if (!isNaN(params[param])) {\n return params[param] == null ? fallback : Number(params[param]);\n }\n else {\n console.warn(`AG Grid: DateFilter ${param} is not a number`);\n }\n }\n return fallback;\n };\n this.minValidYear = yearParser('minValidYear', DEFAULT_MIN_YEAR);\n this.maxValidYear = yearParser('maxValidYear', DEFAULT_MAX_YEAR);\n if (this.minValidYear > this.maxValidYear) {\n console.warn(`AG Grid: DateFilter minValidYear should be <= maxValidYear`);\n }\n if (params.minValidDate) {\n this.minValidDate = params.minValidDate instanceof Date ? params.minValidDate : parseDateTimeFromString(params.minValidDate);\n }\n else {\n this.minValidDate = null;\n }\n if (params.maxValidDate) {\n this.maxValidDate = params.maxValidDate instanceof Date ? params.maxValidDate : parseDateTimeFromString(params.maxValidDate);\n }\n else {\n this.maxValidDate = null;\n }\n if (this.minValidDate && this.maxValidDate && this.minValidDate > this.maxValidDate) {\n console.warn(`AG Grid: DateFilter minValidDate should be <= maxValidDate`);\n }\n this.filterModelFormatter = new DateFilterModelFormatter(this.dateFilterParams, this.localeService, this.optionsFactory);\n }\n createDateCompWrapper(element) {\n const dateCompWrapper = new DateCompWrapper(this.getContext(), this.userComponentFactory, {\n onDateChanged: () => this.onUiChanged(),\n filterParams: this.dateFilterParams\n }, element);\n this.addDestroyFunc(() => dateCompWrapper.destroy());\n return dateCompWrapper;\n }\n setElementValue(element, value) {\n element.setDate(value);\n }\n setElementDisplayed(element, displayed) {\n element.setDisplayed(displayed);\n }\n setElementDisabled(element, disabled) {\n element.setDisabled(disabled);\n }\n getDefaultFilterOptions() {\n return DateFilter.DEFAULT_FILTER_OPTIONS;\n }\n createValueElement() {\n const eCondition = document.createElement('div');\n eCondition.classList.add('ag-filter-body');\n this.createFromToElement(eCondition, this.eConditionPanelsFrom, this.dateConditionFromComps, 'from');\n this.createFromToElement(eCondition, this.eConditionPanelsTo, this.dateConditionToComps, 'to');\n return eCondition;\n }\n createFromToElement(eCondition, eConditionPanels, dateConditionComps, fromTo) {\n const eConditionPanel = document.createElement('div');\n eConditionPanel.classList.add(`ag-filter-${fromTo}`);\n eConditionPanel.classList.add(`ag-filter-date-${fromTo}`);\n eConditionPanels.push(eConditionPanel);\n eCondition.appendChild(eConditionPanel);\n dateConditionComps.push(this.createDateCompWrapper(eConditionPanel));\n }\n removeValueElements(startPosition, deleteCount) {\n this.removeDateComps(this.dateConditionFromComps, startPosition, deleteCount);\n this.removeDateComps(this.dateConditionToComps, startPosition, deleteCount);\n this.removeItems(this.eConditionPanelsFrom, startPosition, deleteCount);\n this.removeItems(this.eConditionPanelsTo, startPosition, deleteCount);\n }\n removeDateComps(components, startPosition, deleteCount) {\n const removedComponents = this.removeItems(components, startPosition, deleteCount);\n removedComponents.forEach(comp => comp.destroy());\n }\n isValidDateValue(value) {\n if (value === null) {\n return false;\n }\n if (this.minValidDate) {\n if (value < this.minValidDate) {\n return false;\n }\n }\n else {\n if (value.getUTCFullYear() < this.minValidYear) {\n return false;\n }\n }\n if (this.maxValidDate) {\n if (value > this.maxValidDate) {\n return false;\n }\n }\n else {\n if (value.getUTCFullYear() > this.maxValidYear) {\n return false;\n }\n }\n return true;\n }\n ;\n isConditionUiComplete(position) {\n if (!super.isConditionUiComplete(position)) {\n return false;\n }\n let valid = true;\n this.forEachInput((element, index, elPosition, numberOfInputs) => {\n if (elPosition !== position || !valid || index >= numberOfInputs) {\n return;\n }\n valid = valid && this.isValidDateValue(element.getDate());\n });\n return valid;\n }\n areSimpleModelsEqual(aSimple, bSimple) {\n return aSimple.dateFrom === bSimple.dateFrom\n && aSimple.dateTo === bSimple.dateTo\n && aSimple.type === bSimple.type;\n }\n getFilterType() {\n return 'date';\n }\n createCondition(position) {\n const type = this.getConditionType(position);\n const model = {};\n const values = this.getValues(position);\n if (values.length > 0) {\n model.dateFrom = serialiseDate(values[0]);\n }\n if (values.length > 1) {\n model.dateTo = serialiseDate(values[1]);\n }\n return Object.assign({ dateFrom: null, dateTo: null, filterType: this.getFilterType(), type }, model);\n }\n resetPlaceholder() {\n const globalTranslate = this.localeService.getLocaleTextFunc();\n const placeholder = this.translate('dateFormatOoo');\n const ariaLabel = globalTranslate('ariaFilterValue', 'Filter Value');\n this.forEachInput((element) => {\n element.setInputPlaceholder(placeholder);\n element.setInputAriaLabel(ariaLabel);\n });\n }\n getInputs(position) {\n if (position >= this.dateConditionFromComps.length) {\n return [null, null];\n }\n return [this.dateConditionFromComps[position], this.dateConditionToComps[position]];\n }\n getValues(position) {\n const result = [];\n this.forEachPositionInput(position, (element, index, _elPosition, numberOfInputs) => {\n if (index < numberOfInputs) {\n result.push(element.getDate());\n }\n });\n return result;\n }\n getModelAsString(model) {\n var _a;\n return (_a = this.filterModelFormatter.getModelAsString(model)) !== null && _a !== void 0 ? _a : '';\n }\n}\nDateFilter.DEFAULT_FILTER_OPTIONS = [\n ScalarFilter.EQUALS,\n ScalarFilter.GREATER_THAN,\n ScalarFilter.LESS_THAN,\n ScalarFilter.NOT_EQUAL,\n ScalarFilter.IN_RANGE,\n ScalarFilter.BLANK,\n ScalarFilter.NOT_BLANK,\n];\n__decorate([\n Autowired('userComponentFactory')\n], DateFilter.prototype, \"userComponentFactory\", void 0);\n","import { Component } from '../../../widgets/component.mjs';\nimport { SimpleFilter } from '../../provided/simpleFilter.mjs';\nimport { OptionsFactory } from '../../provided/optionsFactory.mjs';\nexport class SimpleFloatingFilter extends Component {\n getDefaultDebounceMs() {\n return 0;\n }\n // this is a user component, and IComponent has \"public destroy()\" as part of the interface.\n // so we need to override destroy() just to make the method public.\n destroy() {\n super.destroy();\n }\n isEventFromFloatingFilter(event) {\n return event && event.afterFloatingFilter;\n }\n isEventFromDataChange(event) {\n return event === null || event === void 0 ? void 0 : event.afterDataChange;\n }\n getLastType() {\n return this.lastType;\n }\n isReadOnly() {\n return this.readOnly;\n }\n setLastTypeFromModel(model) {\n // if no model provided by the parent filter use default\n if (!model) {\n this.lastType = this.optionsFactory.getDefaultOption();\n return;\n }\n const isCombined = model.operator;\n let condition;\n if (isCombined) {\n const combinedModel = model;\n condition = combinedModel.conditions[0];\n }\n else {\n condition = model;\n }\n this.lastType = condition.type;\n }\n canWeEditAfterModelFromParentFilter(model) {\n if (!model) {\n // if no model, then we can edit as long as the lastType is something we can edit, as this\n // is the type we will provide to the parent filter if the user decides to use the floating filter.\n return this.isTypeEditable(this.lastType);\n }\n // never allow editing if the filter is combined (ie has two parts)\n const isCombined = model.operator;\n if (isCombined) {\n return false;\n }\n const simpleModel = model;\n return this.isTypeEditable(simpleModel.type);\n }\n init(params) {\n this.setSimpleParams(params);\n }\n setSimpleParams(params) {\n this.optionsFactory = new OptionsFactory();\n this.optionsFactory.init(params.filterParams, this.getDefaultFilterOptions());\n this.lastType = this.optionsFactory.getDefaultOption();\n // readOnly is a property of ProvidedFilterParams - we need to find a better (type-safe)\n // way to support reading this in the future.\n this.readOnly = !!params.filterParams.readOnly;\n // we are editable if:\n // 1) there is a type (user has configured filter wrong if not type)\n // AND\n // 2) the default type is not 'in range'\n const editable = this.isTypeEditable(this.lastType);\n this.setEditable(editable);\n }\n onParamsUpdated(params) {\n this.setSimpleParams(params);\n }\n doesFilterHaveSingleInput(filterType) {\n const customFilterOption = this.optionsFactory.getCustomOption(filterType);\n const { numberOfInputs } = customFilterOption || {};\n return numberOfInputs == null || numberOfInputs == 1;\n }\n isTypeEditable(type) {\n const uneditableTypes = [\n SimpleFilter.IN_RANGE, SimpleFilter.EMPTY, SimpleFilter.BLANK, SimpleFilter.NOT_BLANK,\n ];\n return !!type &&\n !this.isReadOnly() &&\n this.doesFilterHaveSingleInput(type) &&\n uneditableTypes.indexOf(type) < 0;\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { DateFilter, DateFilterModelFormatter } from './dateFilter.mjs';\nimport { Autowired } from '../../../context/context.mjs';\nimport { DateCompWrapper } from './dateCompWrapper.mjs';\nimport { RefSelector } from '../../../widgets/componentAnnotations.mjs';\nimport { SimpleFloatingFilter } from '../../floating/provided/simpleFloatingFilter.mjs';\nimport { ProvidedFilter } from '../providedFilter.mjs';\nimport { setDisplayed } from '../../../utils/dom.mjs';\nimport { parseDateTimeFromString, serialiseDate } from '../../../utils/date.mjs';\nimport { debounce } from '../../../utils/function.mjs';\nexport class DateFloatingFilter extends SimpleFloatingFilter {\n constructor() {\n super(/* html */ `\n
\n \n
\n
`);\n }\n getDefaultFilterOptions() {\n return DateFilter.DEFAULT_FILTER_OPTIONS;\n }\n init(params) {\n super.init(params);\n this.params = params;\n this.filterParams = params.filterParams;\n this.createDateComponent();\n this.filterModelFormatter = new DateFilterModelFormatter(this.filterParams, this.localeService, this.optionsFactory);\n const translate = this.localeService.getLocaleTextFunc();\n this.eReadOnlyText\n .setDisabled(true)\n .setInputAriaLabel(translate('ariaDateFilterInput', 'Date Filter Input'));\n }\n onParamsUpdated(params) {\n super.onParamsUpdated(params);\n this.params = params;\n this.filterParams = params.filterParams;\n this.updateDateComponent();\n this.filterModelFormatter.updateParams({ optionsFactory: this.optionsFactory, dateFilterParams: this.filterParams });\n }\n setEditable(editable) {\n setDisplayed(this.eDateWrapper, editable);\n setDisplayed(this.eReadOnlyText.getGui(), !editable);\n }\n onParentModelChanged(model, event) {\n // We don't want to update the floating filter if the floating filter caused the change,\n // because the UI is already in sync. if we didn't do this, the UI would behave strangely\n // as it would be updating as the user is typing.\n // This is similar for data changes, which don't affect provided date floating filters\n if (this.isEventFromFloatingFilter(event) || this.isEventFromDataChange(event)) {\n return;\n }\n super.setLastTypeFromModel(model);\n const allowEditing = !this.isReadOnly() &&\n this.canWeEditAfterModelFromParentFilter(model);\n this.setEditable(allowEditing);\n if (allowEditing) {\n if (model) {\n const dateModel = model;\n this.dateComp.setDate(parseDateTimeFromString(dateModel.dateFrom));\n }\n else {\n this.dateComp.setDate(null);\n }\n this.eReadOnlyText.setValue('');\n }\n else {\n this.eReadOnlyText.setValue(this.filterModelFormatter.getModelAsString(model));\n this.dateComp.setDate(null);\n }\n }\n onDateChanged() {\n const filterValueDate = this.dateComp.getDate();\n const filterValueText = serialiseDate(filterValueDate);\n this.params.parentFilterInstance(filterInstance => {\n if (filterInstance) {\n const date = parseDateTimeFromString(filterValueText);\n filterInstance.onFloatingFilterChanged(this.getLastType() || null, date);\n }\n });\n }\n getDateComponentParams() {\n const debounceMs = ProvidedFilter.getDebounceMs(this.params.filterParams, this.getDefaultDebounceMs());\n return {\n onDateChanged: debounce(this.onDateChanged.bind(this), debounceMs),\n filterParams: this.params.column.getColDef().filterParams\n };\n }\n createDateComponent() {\n this.dateComp = new DateCompWrapper(this.getContext(), this.userComponentFactory, this.getDateComponentParams(), this.eDateWrapper);\n this.addDestroyFunc(() => this.dateComp.destroy());\n }\n updateDateComponent() {\n const params = this.getDateComponentParams();\n const { api, columnApi, context } = this.gridOptionsService;\n params.api = api;\n params.columnApi = columnApi;\n params.context = context;\n this.dateComp.updateParams(params);\n }\n getFilterModelFormatter() {\n return this.filterModelFormatter;\n }\n}\n__decorate([\n Autowired('userComponentFactory')\n], DateFloatingFilter.prototype, \"userComponentFactory\", void 0);\n__decorate([\n RefSelector('eReadOnlyText')\n], DateFloatingFilter.prototype, \"eReadOnlyText\", void 0);\n__decorate([\n RefSelector('eDateWrapper')\n], DateFloatingFilter.prototype, \"eDateWrapper\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from '../../../widgets/component.mjs';\nimport { RefSelector } from '../../../widgets/componentAnnotations.mjs';\nimport { serialiseDate, parseDateTimeFromString, dateToFormattedString } from '../../../utils/date.mjs';\nimport { getSafariVersion, isBrowserChrome, isBrowserFirefox, isBrowserSafari } from '../../../utils/browser.mjs';\nimport { doOnce } from '../../../utils/function.mjs';\nexport class DefaultDateComponent extends Component {\n constructor() {\n super(/* html */ `\n
\n \n
`);\n }\n // this is a user component, and IComponent has \"public destroy()\" as part of the interface.\n // so we need to override destroy() just to make the method public.\n destroy() {\n super.destroy();\n }\n init(params) {\n this.params = params;\n this.setParams(params);\n const eDocument = this.gridOptionsService.getDocument();\n const inputElement = this.eDateInput.getInputElement();\n // ensures that the input element is focussed when a clear button is clicked,\n // unless using safari as there is no clear button and focus does not work properly\n this.addManagedListener(inputElement, 'mousedown', () => {\n if (this.eDateInput.isDisabled() || this.usingSafariDatePicker) {\n return;\n }\n inputElement.focus();\n });\n this.addManagedListener(inputElement, 'input', e => {\n if (e.target !== eDocument.activeElement) {\n return;\n }\n if (this.eDateInput.isDisabled()) {\n return;\n }\n this.params.onDateChanged();\n });\n }\n setParams(params) {\n const inputElement = this.eDateInput.getInputElement();\n const shouldUseBrowserDatePicker = this.shouldUseBrowserDatePicker(params);\n this.usingSafariDatePicker = shouldUseBrowserDatePicker && isBrowserSafari();\n inputElement.type = shouldUseBrowserDatePicker ? 'date' : 'text';\n const { minValidYear, maxValidYear, minValidDate, maxValidDate, } = params.filterParams || {};\n if (minValidDate && minValidYear) {\n doOnce(() => console.warn('AG Grid: DateFilter should not have both minValidDate and minValidYear parameters set at the same time! minValidYear will be ignored.'), 'DateFilter.minValidDateAndMinValidYearWarning');\n }\n if (maxValidDate && maxValidYear) {\n doOnce(() => console.warn('AG Grid: DateFilter should not have both maxValidDate and maxValidYear parameters set at the same time! maxValidYear will be ignored.'), 'DateFilter.maxValidDateAndMaxValidYearWarning');\n }\n if (minValidDate && maxValidDate) {\n const [parsedMinValidDate, parsedMaxValidDate] = [minValidDate, maxValidDate]\n .map(v => v instanceof Date ? v : parseDateTimeFromString(v));\n if (parsedMinValidDate && parsedMaxValidDate && parsedMinValidDate.getTime() > parsedMaxValidDate.getTime()) {\n doOnce(() => console.warn('AG Grid: DateFilter parameter minValidDate should always be lower than or equal to parameter maxValidDate.'), 'DateFilter.minValidDateAndMaxValidDateWarning');\n }\n }\n if (minValidDate) {\n if (minValidDate instanceof Date) {\n inputElement.min = dateToFormattedString(minValidDate);\n }\n else {\n inputElement.min = minValidDate;\n }\n }\n else {\n if (minValidYear) {\n inputElement.min = `${minValidYear}-01-01`;\n }\n }\n if (maxValidDate) {\n if (maxValidDate instanceof Date) {\n inputElement.max = dateToFormattedString(maxValidDate);\n }\n else {\n inputElement.max = maxValidDate;\n }\n }\n else {\n if (maxValidYear) {\n inputElement.max = `${maxValidYear}-12-31`;\n }\n }\n }\n onParamsUpdated(params) {\n this.params = params;\n this.setParams(params);\n }\n getDate() {\n return parseDateTimeFromString(this.eDateInput.getValue());\n }\n setDate(date) {\n this.eDateInput.setValue(serialiseDate(date, false));\n }\n setInputPlaceholder(placeholder) {\n this.eDateInput.setInputPlaceholder(placeholder);\n }\n setDisabled(disabled) {\n this.eDateInput.setDisabled(disabled);\n }\n afterGuiAttached(params) {\n if (!params || !params.suppressFocus) {\n this.eDateInput.getInputElement().focus();\n }\n }\n shouldUseBrowserDatePicker(params) {\n if (params.filterParams && params.filterParams.browserDatePicker != null) {\n return params.filterParams.browserDatePicker;\n }\n return isBrowserChrome() || isBrowserFirefox() || (isBrowserSafari() && getSafariVersion() >= 14.1);\n }\n}\n__decorate([\n RefSelector('eDateInput')\n], DefaultDateComponent.prototype, \"eDateInput\", void 0);\n","import { AgAbstractInputField } from './agAbstractInputField.mjs';\nimport { exists } from '../utils/generic.mjs';\nimport { isEventFromPrintableCharacter } from '../utils/keyboard.mjs';\nexport class AgInputTextField extends AgAbstractInputField {\n constructor(config, className = 'ag-text-field', inputType = 'text') {\n super(config, className, inputType);\n }\n postConstruct() {\n super.postConstruct();\n if (this.config.allowedCharPattern) {\n this.preventDisallowedCharacters();\n }\n }\n setValue(value, silent) {\n // update the input before we call super.setValue, so it's updated before the value changed event is fired\n if (this.eInput.value !== value) {\n this.eInput.value = exists(value) ? value : '';\n }\n return super.setValue(value, silent);\n }\n /** Used to set an initial value into the input without necessarily setting `this.value` or triggering events (e.g. to set an invalid value) */\n setStartValue(value) {\n this.setValue(value, true);\n }\n preventDisallowedCharacters() {\n const pattern = new RegExp(`[${this.config.allowedCharPattern}]`);\n const preventCharacters = (event) => {\n if (!isEventFromPrintableCharacter(event)) {\n return;\n }\n if (event.key && !pattern.test(event.key)) {\n event.preventDefault();\n }\n };\n this.addManagedListener(this.eInput, 'keydown', preventCharacters);\n this.addManagedListener(this.eInput, 'paste', (e) => {\n var _a;\n const text = (_a = e.clipboardData) === null || _a === void 0 ? void 0 : _a.getData('text');\n if (text && text.split('').some((c) => !pattern.test(c))) {\n e.preventDefault();\n }\n });\n }\n}\n","import { AgInputTextField } from \"./agInputTextField.mjs\";\nimport { addOrRemoveAttribute } from '../utils/dom.mjs';\nimport { exists } from \"../utils/generic.mjs\";\nexport class AgInputNumberField extends AgInputTextField {\n constructor(config) {\n super(config, 'ag-number-field', 'number');\n }\n postConstruct() {\n super.postConstruct();\n this.addManagedListener(this.eInput, 'blur', () => {\n const floatedValue = parseFloat(this.eInput.value);\n const value = isNaN(floatedValue) ? '' : this.normalizeValue(floatedValue.toString());\n if (this.value !== value) {\n this.setValue(value);\n }\n });\n this.addManagedListener(this.eInput, 'wheel', this.onWheel.bind(this));\n this.eInput.step = 'any';\n }\n onWheel(e) {\n // Prevent default scroll events from incrementing / decrementing the input, since its inconsistent between browsers\n if (document.activeElement === this.eInput) {\n e.preventDefault();\n }\n }\n normalizeValue(value) {\n if (value === '') {\n return '';\n }\n if (this.precision != null) {\n value = this.adjustPrecision(value);\n }\n const val = parseFloat(value);\n if (this.min != null && val < this.min) {\n value = this.min.toString();\n }\n else if (this.max != null && val > this.max) {\n value = this.max.toString();\n }\n return value;\n }\n adjustPrecision(value, isScientificNotation) {\n if (this.precision == null) {\n return value;\n }\n if (isScientificNotation) {\n const floatString = parseFloat(value).toFixed(this.precision);\n return parseFloat(floatString).toString();\n }\n // can't use toFixed here because we don't want to round up\n const parts = String(value).split('.');\n if (parts.length > 1) {\n if (parts[1].length <= this.precision) {\n return value;\n }\n else if (this.precision > 0) {\n return `${parts[0]}.${parts[1].slice(0, this.precision)}`;\n }\n }\n return parts[0];\n }\n setMin(min) {\n if (this.min === min) {\n return this;\n }\n this.min = min;\n addOrRemoveAttribute(this.eInput, 'min', min);\n return this;\n }\n setMax(max) {\n if (this.max === max) {\n return this;\n }\n this.max = max;\n addOrRemoveAttribute(this.eInput, 'max', max);\n return this;\n }\n setPrecision(precision) {\n this.precision = precision;\n return this;\n }\n setStep(step) {\n if (this.step === step) {\n return this;\n }\n this.step = step;\n addOrRemoveAttribute(this.eInput, 'step', step);\n return this;\n }\n setValue(value, silent) {\n return this.setValueOrInputValue(v => super.setValue(v, silent), () => this, value);\n }\n setStartValue(value) {\n return this.setValueOrInputValue(v => super.setValue(v, true), v => { this.eInput.value = v; }, value);\n }\n setValueOrInputValue(setValueFunc, setInputValueOnlyFunc, value) {\n if (exists(value)) {\n // need to maintain the scientific notation format whilst typing (e.g. 1e10)\n let setInputValueOnly = this.isScientificNotation(value);\n if (setInputValueOnly && this.eInput.validity.valid) {\n return setValueFunc(value);\n }\n if (!setInputValueOnly) {\n value = this.adjustPrecision(value);\n const normalizedValue = this.normalizeValue(value);\n // outside of valid range\n setInputValueOnly = value != normalizedValue;\n }\n if (setInputValueOnly) {\n return setInputValueOnlyFunc(value);\n }\n }\n return setValueFunc(value);\n }\n getValue() {\n if (!this.eInput.validity.valid) {\n return undefined;\n }\n const inputValue = this.eInput.value;\n if (this.isScientificNotation(inputValue)) {\n return this.adjustPrecision(inputValue, true);\n }\n return super.getValue();\n }\n isScientificNotation(value) {\n return typeof value === 'string' && value.includes('e');\n }\n}\n","import { SimpleFilter, SimpleFilterModelFormatter } from '../simpleFilter.mjs';\nimport { ScalarFilter } from '../scalarFilter.mjs';\nimport { makeNull } from '../../../utils/generic.mjs';\nimport { AgInputTextField } from '../../../widgets/agInputTextField.mjs';\nimport { setAriaRole } from '../../../utils/aria.mjs';\nimport { AgInputNumberField } from '../../../widgets/agInputNumberField.mjs';\nexport class NumberFilterModelFormatter extends SimpleFilterModelFormatter {\n conditionToString(condition, options) {\n const { numberOfInputs } = options || {};\n const isRange = condition.type == SimpleFilter.IN_RANGE || numberOfInputs === 2;\n if (isRange) {\n return `${this.formatValue(condition.filter)}-${this.formatValue(condition.filterTo)}`;\n }\n // cater for when the type doesn't need a value\n if (condition.filter != null) {\n return this.formatValue(condition.filter);\n }\n return `${condition.type}`;\n }\n}\nexport function getAllowedCharPattern(filterParams) {\n const { allowedCharPattern } = filterParams !== null && filterParams !== void 0 ? filterParams : {};\n return allowedCharPattern !== null && allowedCharPattern !== void 0 ? allowedCharPattern : null;\n}\nexport class NumberFilter extends ScalarFilter {\n constructor() {\n super('numberFilter');\n this.eValuesFrom = [];\n this.eValuesTo = [];\n }\n mapValuesFromModel(filterModel) {\n const { filter, filterTo, type } = filterModel || {};\n return [\n this.processValue(filter),\n this.processValue(filterTo),\n ].slice(0, this.getNumberOfInputs(type));\n }\n getDefaultDebounceMs() {\n return 500;\n }\n comparator() {\n return (left, right) => {\n if (left === right) {\n return 0;\n }\n return left < right ? 1 : -1;\n };\n }\n setParams(params) {\n this.numberFilterParams = params;\n super.setParams(params);\n this.filterModelFormatter = new NumberFilterModelFormatter(this.localeService, this.optionsFactory, this.numberFilterParams.numberFormatter);\n }\n getDefaultFilterOptions() {\n return NumberFilter.DEFAULT_FILTER_OPTIONS;\n }\n setElementValue(element, value, fromFloatingFilter) {\n // values from floating filter are directly from the input, not from the model\n const valueToSet = !fromFloatingFilter && this.numberFilterParams.numberFormatter\n ? this.numberFilterParams.numberFormatter(value !== null && value !== void 0 ? value : null)\n : value;\n super.setElementValue(element, valueToSet);\n }\n createValueElement() {\n const allowedCharPattern = getAllowedCharPattern(this.numberFilterParams);\n const eCondition = document.createElement('div');\n eCondition.classList.add('ag-filter-body');\n setAriaRole(eCondition, 'presentation');\n this.createFromToElement(eCondition, this.eValuesFrom, 'from', allowedCharPattern);\n this.createFromToElement(eCondition, this.eValuesTo, 'to', allowedCharPattern);\n return eCondition;\n }\n createFromToElement(eCondition, eValues, fromTo, allowedCharPattern) {\n const eValue = this.createManagedBean(allowedCharPattern ? new AgInputTextField({ allowedCharPattern }) : new AgInputNumberField());\n eValue.addCssClass(`ag-filter-${fromTo}`);\n eValue.addCssClass('ag-filter-filter');\n eValues.push(eValue);\n eCondition.appendChild(eValue.getGui());\n }\n removeValueElements(startPosition, deleteCount) {\n this.removeComponents(this.eValuesFrom, startPosition, deleteCount);\n this.removeComponents(this.eValuesTo, startPosition, deleteCount);\n }\n getValues(position) {\n const result = [];\n this.forEachPositionInput(position, (element, index, _elPosition, numberOfInputs) => {\n if (index < numberOfInputs) {\n result.push(this.processValue(this.stringToFloat(element.getValue())));\n }\n });\n return result;\n }\n areSimpleModelsEqual(aSimple, bSimple) {\n return aSimple.filter === bSimple.filter\n && aSimple.filterTo === bSimple.filterTo\n && aSimple.type === bSimple.type;\n }\n getFilterType() {\n return 'number';\n }\n processValue(value) {\n if (value == null) {\n return null;\n }\n return isNaN(value) ? null : value;\n }\n stringToFloat(value) {\n if (typeof value === 'number') {\n return value;\n }\n let filterText = makeNull(value);\n if (filterText != null && filterText.trim() === '') {\n filterText = null;\n }\n if (this.numberFilterParams.numberParser) {\n return this.numberFilterParams.numberParser(filterText);\n }\n return filterText == null || filterText.trim() === '-' ? null : parseFloat(filterText);\n }\n createCondition(position) {\n const type = this.getConditionType(position);\n const model = {\n filterType: this.getFilterType(),\n type\n };\n const values = this.getValues(position);\n if (values.length > 0) {\n model.filter = values[0];\n }\n if (values.length > 1) {\n model.filterTo = values[1];\n }\n return model;\n }\n getInputs(position) {\n if (position >= this.eValuesFrom.length) {\n return [null, null];\n }\n return [this.eValuesFrom[position], this.eValuesTo[position]];\n }\n getModelAsString(model) {\n var _a;\n return (_a = this.filterModelFormatter.getModelAsString(model)) !== null && _a !== void 0 ? _a : '';\n }\n hasInvalidInputs() {\n let invalidInputs = false;\n this.forEachInput(element => {\n if (!element.getInputElement().validity.valid) {\n invalidInputs = true;\n return;\n }\n });\n return invalidInputs;\n }\n}\nNumberFilter.DEFAULT_FILTER_OPTIONS = [\n ScalarFilter.EQUALS,\n ScalarFilter.NOT_EQUAL,\n ScalarFilter.LESS_THAN,\n ScalarFilter.LESS_THAN_OR_EQUAL,\n ScalarFilter.GREATER_THAN,\n ScalarFilter.GREATER_THAN_OR_EQUAL,\n ScalarFilter.IN_RANGE,\n ScalarFilter.BLANK,\n ScalarFilter.NOT_BLANK,\n];\n","import { SimpleFilter, SimpleFilterModelFormatter } from '../simpleFilter.mjs';\nimport { AgInputTextField } from '../../../widgets/agInputTextField.mjs';\nimport { makeNull } from '../../../utils/generic.mjs';\nimport { _ } from '../../../utils/index.mjs';\nimport { setAriaRole } from '../../../utils/aria.mjs';\nexport class TextFilterModelFormatter extends SimpleFilterModelFormatter {\n conditionToString(condition, options) {\n const { numberOfInputs } = options || {};\n const isRange = condition.type == SimpleFilter.IN_RANGE || numberOfInputs === 2;\n if (isRange) {\n return `${condition.filter}-${condition.filterTo}`;\n }\n // cater for when the type doesn't need a value\n if (condition.filter != null) {\n return `${condition.filter}`;\n }\n return `${condition.type}`;\n }\n}\nexport class TextFilter extends SimpleFilter {\n constructor() {\n super('textFilter');\n this.eValuesFrom = [];\n this.eValuesTo = [];\n }\n static trimInput(value) {\n const trimmedInput = value && value.trim();\n // trim the input, unless it is all whitespace (this is consistent with Excel behaviour)\n return trimmedInput === '' ? value : trimmedInput;\n }\n getDefaultDebounceMs() {\n return 500;\n }\n setParams(params) {\n this.textFilterParams = params;\n super.setParams(params);\n this.matcher = this.getTextMatcher();\n this.formatter = this.textFilterParams.textFormatter ||\n (this.textFilterParams.caseSensitive ? TextFilter.DEFAULT_FORMATTER : TextFilter.DEFAULT_LOWERCASE_FORMATTER);\n this.filterModelFormatter = new TextFilterModelFormatter(this.localeService, this.optionsFactory);\n }\n getTextMatcher() {\n const legacyComparator = this.textFilterParams.textCustomComparator;\n if (legacyComparator) {\n _.doOnce(() => console.warn('AG Grid - textCustomComparator is deprecated, use textMatcher instead.'), 'textCustomComparator.deprecated');\n return ({ filterOption, value, filterText }) => legacyComparator(filterOption, value, filterText);\n }\n return this.textFilterParams.textMatcher || TextFilter.DEFAULT_MATCHER;\n }\n createCondition(position) {\n const type = this.getConditionType(position);\n const model = {\n filterType: this.getFilterType(),\n type,\n };\n const values = this.getValuesWithSideEffects(position, true);\n if (values.length > 0) {\n model.filter = values[0];\n }\n if (values.length > 1) {\n model.filterTo = values[1];\n }\n return model;\n }\n getFilterType() {\n return 'text';\n }\n areSimpleModelsEqual(aSimple, bSimple) {\n return aSimple.filter === bSimple.filter &&\n aSimple.filterTo === bSimple.filterTo &&\n aSimple.type === bSimple.type;\n }\n getInputs(position) {\n if (position >= this.eValuesFrom.length) {\n return [null, null];\n }\n return [this.eValuesFrom[position], this.eValuesTo[position]];\n }\n getValues(position) {\n return this.getValuesWithSideEffects(position, false);\n }\n getValuesWithSideEffects(position, applySideEffects) {\n const result = [];\n this.forEachPositionInput(position, (element, index, _elPosition, numberOfInputs) => {\n var _a;\n if (index < numberOfInputs) {\n let value = makeNull(element.getValue());\n if (applySideEffects && this.textFilterParams.trimInput) {\n value = (_a = TextFilter.trimInput(value)) !== null && _a !== void 0 ? _a : null;\n element.setValue(value, true); // ensure clean value is visible\n }\n result.push(value);\n }\n });\n return result;\n }\n getDefaultFilterOptions() {\n return TextFilter.DEFAULT_FILTER_OPTIONS;\n }\n createValueElement() {\n const eCondition = document.createElement('div');\n eCondition.classList.add('ag-filter-body');\n setAriaRole(eCondition, 'presentation');\n this.createFromToElement(eCondition, this.eValuesFrom, 'from');\n this.createFromToElement(eCondition, this.eValuesTo, 'to');\n return eCondition;\n }\n createFromToElement(eCondition, eValues, fromTo) {\n const eValue = this.createManagedBean(new AgInputTextField());\n eValue.addCssClass(`ag-filter-${fromTo}`);\n eValue.addCssClass('ag-filter-filter');\n eValues.push(eValue);\n eCondition.appendChild(eValue.getGui());\n }\n removeValueElements(startPosition, deleteCount) {\n this.removeComponents(this.eValuesFrom, startPosition, deleteCount);\n this.removeComponents(this.eValuesTo, startPosition, deleteCount);\n }\n mapValuesFromModel(filterModel) {\n const { filter, filterTo, type } = filterModel || {};\n return [\n filter || null,\n filterTo || null,\n ].slice(0, this.getNumberOfInputs(type));\n }\n evaluateNullValue(filterType) {\n const filterTypesAllowNulls = [\n SimpleFilter.NOT_EQUAL, SimpleFilter.NOT_CONTAINS, SimpleFilter.BLANK,\n ];\n return filterType ? filterTypesAllowNulls.indexOf(filterType) >= 0 : false;\n }\n evaluateNonNullValue(values, cellValue, filterModel, params) {\n const formattedValues = values.map(v => this.formatter(v)) || [];\n const cellValueFormatted = this.formatter(cellValue);\n const { api, colDef, column, columnApi, context, textFormatter } = this.textFilterParams;\n if (filterModel.type === SimpleFilter.BLANK) {\n return this.isBlank(cellValue);\n }\n else if (filterModel.type === SimpleFilter.NOT_BLANK) {\n return !this.isBlank(cellValue);\n }\n const matcherParams = {\n api,\n colDef,\n column,\n columnApi,\n context,\n node: params.node,\n data: params.data,\n filterOption: filterModel.type,\n value: cellValueFormatted,\n textFormatter,\n };\n return formattedValues.some(v => this.matcher(Object.assign(Object.assign({}, matcherParams), { filterText: v })));\n }\n getModelAsString(model) {\n var _a;\n return (_a = this.filterModelFormatter.getModelAsString(model)) !== null && _a !== void 0 ? _a : '';\n }\n}\nTextFilter.DEFAULT_FILTER_OPTIONS = [\n SimpleFilter.CONTAINS,\n SimpleFilter.NOT_CONTAINS,\n SimpleFilter.EQUALS,\n SimpleFilter.NOT_EQUAL,\n SimpleFilter.STARTS_WITH,\n SimpleFilter.ENDS_WITH,\n SimpleFilter.BLANK,\n SimpleFilter.NOT_BLANK,\n];\nTextFilter.DEFAULT_FORMATTER = (from) => from;\nTextFilter.DEFAULT_LOWERCASE_FORMATTER = (from) => from == null ? null : from.toString().toLowerCase();\nTextFilter.DEFAULT_MATCHER = ({ filterOption, value, filterText }) => {\n if (filterText == null) {\n return false;\n }\n switch (filterOption) {\n case TextFilter.CONTAINS:\n return value.indexOf(filterText) >= 0;\n case TextFilter.NOT_CONTAINS:\n return value.indexOf(filterText) < 0;\n case TextFilter.EQUALS:\n return value === filterText;\n case TextFilter.NOT_EQUAL:\n return value != filterText;\n case TextFilter.STARTS_WITH:\n return value.indexOf(filterText) === 0;\n case TextFilter.ENDS_WITH:\n const index = value.lastIndexOf(filterText);\n return index >= 0 && index === (value.length - filterText.length);\n default:\n return false;\n }\n};\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { RefSelector } from '../../../widgets/componentAnnotations.mjs';\nimport { debounce } from '../../../utils/function.mjs';\nimport { ProvidedFilter } from '../../provided/providedFilter.mjs';\nimport { PostConstruct, Autowired } from '../../../context/context.mjs';\nimport { SimpleFloatingFilter } from './simpleFloatingFilter.mjs';\nimport { AgInputTextField } from '../../../widgets/agInputTextField.mjs';\nimport { KeyCode } from '../../../constants/keyCode.mjs';\nimport { TextFilter } from '../../provided/text/textFilter.mjs';\nimport { BeanStub } from '../../../context/beanStub.mjs';\nimport { clearElement } from '../../../utils/dom.mjs';\nexport class FloatingFilterTextInputService extends BeanStub {\n constructor(params) {\n super();\n this.params = params;\n this.valueChangedListener = () => { };\n }\n setupGui(parentElement) {\n var _a;\n this.eFloatingFilterTextInput = this.createManagedBean(new AgInputTextField((_a = this.params) === null || _a === void 0 ? void 0 : _a.config));\n const eInput = this.eFloatingFilterTextInput.getGui();\n parentElement.appendChild(eInput);\n this.addManagedListener(eInput, 'input', (e) => this.valueChangedListener(e));\n this.addManagedListener(eInput, 'keydown', (e) => this.valueChangedListener(e));\n }\n setEditable(editable) {\n this.eFloatingFilterTextInput.setDisabled(!editable);\n }\n setAutoComplete(autoComplete) {\n this.eFloatingFilterTextInput.setAutoComplete(autoComplete);\n }\n getValue() {\n return this.eFloatingFilterTextInput.getValue();\n }\n setValue(value, silent) {\n this.eFloatingFilterTextInput.setValue(value, silent);\n }\n setValueChangedListener(listener) {\n this.valueChangedListener = listener;\n }\n setParams(params) {\n this.setAriaLabel(params.ariaLabel);\n if (params.autoComplete !== undefined) {\n this.setAutoComplete(params.autoComplete);\n }\n }\n setAriaLabel(ariaLabel) {\n this.eFloatingFilterTextInput.setInputAriaLabel(ariaLabel);\n }\n}\n;\nexport class TextInputFloatingFilter extends SimpleFloatingFilter {\n postConstruct() {\n this.setTemplate(/* html */ `\n
\n `);\n }\n getDefaultDebounceMs() {\n return 500;\n }\n onParentModelChanged(model, event) {\n if (this.isEventFromFloatingFilter(event) || this.isEventFromDataChange(event)) {\n // if the floating filter triggered the change, it is already in sync.\n // Data changes also do not affect provided text floating filters\n return;\n }\n this.setLastTypeFromModel(model);\n this.setEditable(this.canWeEditAfterModelFromParentFilter(model));\n this.floatingFilterInputService.setValue(this.getFilterModelFormatter().getModelAsString(model));\n }\n init(params) {\n this.setupFloatingFilterInputService(params);\n super.init(params);\n this.setTextInputParams(params);\n }\n setupFloatingFilterInputService(params) {\n this.floatingFilterInputService = this.createFloatingFilterInputService(params);\n this.floatingFilterInputService.setupGui(this.eFloatingFilterInputContainer);\n }\n setTextInputParams(params) {\n var _a;\n this.params = params;\n const autoComplete = (_a = params.browserAutoComplete) !== null && _a !== void 0 ? _a : false;\n this.floatingFilterInputService.setParams({\n ariaLabel: this.getAriaLabel(params),\n autoComplete,\n });\n this.applyActive = ProvidedFilter.isUseApplyButton(this.params.filterParams);\n if (!this.isReadOnly()) {\n const debounceMs = ProvidedFilter.getDebounceMs(this.params.filterParams, this.getDefaultDebounceMs());\n const toDebounce = debounce(this.syncUpWithParentFilter.bind(this), debounceMs);\n this.floatingFilterInputService.setValueChangedListener(toDebounce);\n }\n }\n onParamsUpdated(params) {\n super.onParamsUpdated(params);\n this.setTextInputParams(params);\n }\n recreateFloatingFilterInputService(params) {\n const value = this.floatingFilterInputService.getValue();\n clearElement(this.eFloatingFilterInputContainer);\n this.destroyBean(this.floatingFilterInputService);\n this.setupFloatingFilterInputService(params);\n this.floatingFilterInputService.setValue(value, true);\n }\n getAriaLabel(params) {\n const displayName = this.columnModel.getDisplayNameForColumn(params.column, 'header', true);\n const translate = this.localeService.getLocaleTextFunc();\n return `${displayName} ${translate('ariaFilterInput', 'Filter Input')}`;\n }\n syncUpWithParentFilter(e) {\n const isEnterKey = e.key === KeyCode.ENTER;\n if (this.applyActive && !isEnterKey) {\n return;\n }\n let value = this.floatingFilterInputService.getValue();\n if (this.params.filterParams.trimInput) {\n value = TextFilter.trimInput(value);\n this.floatingFilterInputService.setValue(value, true); // ensure visible value is trimmed\n }\n this.params.parentFilterInstance(filterInstance => {\n if (filterInstance) {\n // NumberFilter is typed as number, but actually receives string values\n filterInstance.onFloatingFilterChanged(this.getLastType() || null, value || null);\n }\n });\n }\n setEditable(editable) {\n this.floatingFilterInputService.setEditable(editable);\n }\n}\n__decorate([\n Autowired('columnModel')\n], TextInputFloatingFilter.prototype, \"columnModel\", void 0);\n__decorate([\n RefSelector('eFloatingFilterInputContainer')\n], TextInputFloatingFilter.prototype, \"eFloatingFilterInputContainer\", void 0);\n__decorate([\n PostConstruct\n], TextInputFloatingFilter.prototype, \"postConstruct\", null);\n","import { getAllowedCharPattern, NumberFilter, NumberFilterModelFormatter } from './numberFilter.mjs';\nimport { FloatingFilterTextInputService, TextInputFloatingFilter } from '../../floating/provided/textInputFloatingFilter.mjs';\nimport { AgInputNumberField } from '../../../widgets/agInputNumberField.mjs';\nimport { AgInputTextField } from '../../../widgets/agInputTextField.mjs';\nimport { BeanStub } from '../../../context/beanStub.mjs';\nclass FloatingFilterNumberInputService extends BeanStub {\n constructor() {\n super(...arguments);\n this.valueChangedListener = () => { };\n this.numberInputActive = true;\n }\n setupGui(parentElement) {\n this.eFloatingFilterNumberInput = this.createManagedBean(new AgInputNumberField());\n this.eFloatingFilterTextInput = this.createManagedBean(new AgInputTextField());\n this.eFloatingFilterTextInput.setDisabled(true);\n const eNumberInput = this.eFloatingFilterNumberInput.getGui();\n const eTextInput = this.eFloatingFilterTextInput.getGui();\n parentElement.appendChild(eNumberInput);\n parentElement.appendChild(eTextInput);\n this.setupListeners(eNumberInput, (e) => this.valueChangedListener(e));\n this.setupListeners(eTextInput, (e) => this.valueChangedListener(e));\n }\n setEditable(editable) {\n this.numberInputActive = editable;\n this.eFloatingFilterNumberInput.setDisplayed(this.numberInputActive);\n this.eFloatingFilterTextInput.setDisplayed(!this.numberInputActive);\n }\n setAutoComplete(autoComplete) {\n this.eFloatingFilterNumberInput.setAutoComplete(autoComplete);\n this.eFloatingFilterTextInput.setAutoComplete(autoComplete);\n }\n getValue() {\n return this.getActiveInputElement().getValue();\n }\n setValue(value, silent) {\n this.getActiveInputElement().setValue(value, silent);\n }\n getActiveInputElement() {\n return this.numberInputActive ? this.eFloatingFilterNumberInput : this.eFloatingFilterTextInput;\n }\n setValueChangedListener(listener) {\n this.valueChangedListener = listener;\n }\n setupListeners(element, listener) {\n this.addManagedListener(element, 'input', listener);\n this.addManagedListener(element, 'keydown', listener);\n }\n setParams(params) {\n this.setAriaLabel(params.ariaLabel);\n if (params.autoComplete !== undefined) {\n this.setAutoComplete(params.autoComplete);\n }\n }\n setAriaLabel(ariaLabel) {\n this.eFloatingFilterNumberInput.setInputAriaLabel(ariaLabel);\n this.eFloatingFilterTextInput.setInputAriaLabel(ariaLabel);\n }\n}\nexport class NumberFloatingFilter extends TextInputFloatingFilter {\n init(params) {\n var _a;\n super.init(params);\n this.filterModelFormatter = new NumberFilterModelFormatter(this.localeService, this.optionsFactory, (_a = params.filterParams) === null || _a === void 0 ? void 0 : _a.numberFormatter);\n }\n onParamsUpdated(params) {\n const allowedCharPattern = getAllowedCharPattern(params.filterParams);\n if (allowedCharPattern !== this.allowedCharPattern) {\n this.recreateFloatingFilterInputService(params);\n }\n super.onParamsUpdated(params);\n this.filterModelFormatter.updateParams({ optionsFactory: this.optionsFactory });\n }\n getDefaultFilterOptions() {\n return NumberFilter.DEFAULT_FILTER_OPTIONS;\n }\n getFilterModelFormatter() {\n return this.filterModelFormatter;\n }\n createFloatingFilterInputService(params) {\n this.allowedCharPattern = getAllowedCharPattern(params.filterParams);\n if (this.allowedCharPattern) {\n // need to use text input\n return this.createManagedBean(new FloatingFilterTextInputService({\n config: { allowedCharPattern: this.allowedCharPattern },\n }));\n }\n return this.createManagedBean(new FloatingFilterNumberInputService());\n }\n}\n","import { TextFilter, TextFilterModelFormatter } from './textFilter.mjs';\nimport { FloatingFilterTextInputService, TextInputFloatingFilter } from '../../floating/provided/textInputFloatingFilter.mjs';\nexport class TextFloatingFilter extends TextInputFloatingFilter {\n init(params) {\n super.init(params);\n this.filterModelFormatter = new TextFilterModelFormatter(this.localeService, this.optionsFactory);\n }\n onParamsUpdated(params) {\n super.onParamsUpdated(params);\n this.filterModelFormatter.updateParams({ optionsFactory: this.optionsFactory });\n }\n getDefaultFilterOptions() {\n return TextFilter.DEFAULT_FILTER_OPTIONS;\n }\n getFilterModelFormatter() {\n return this.filterModelFormatter;\n }\n createFloatingFilterInputService() {\n return this.createManagedBean(new FloatingFilterTextInputService());\n }\n}\n","import { EventService } from \"../eventService.mjs\";\nimport { areEventsNear } from \"../utils/mouse.mjs\";\nexport class TouchListener {\n constructor(eElement, preventMouseClick = false) {\n this.destroyFuncs = [];\n this.touching = false;\n this.eventService = new EventService();\n this.eElement = eElement;\n this.preventMouseClick = preventMouseClick;\n const startListener = this.onTouchStart.bind(this);\n const moveListener = this.onTouchMove.bind(this);\n const endListener = this.onTouchEnd.bind(this);\n this.eElement.addEventListener(\"touchstart\", startListener, { passive: true });\n this.eElement.addEventListener(\"touchmove\", moveListener, { passive: true });\n // we set passive=false, as we want to prevent default on this event\n this.eElement.addEventListener(\"touchend\", endListener, { passive: false });\n this.destroyFuncs.push(() => {\n this.eElement.removeEventListener(\"touchstart\", startListener, { passive: true });\n this.eElement.removeEventListener(\"touchmove\", moveListener, { passive: true });\n this.eElement.removeEventListener(\"touchend\", endListener, { passive: false });\n });\n }\n getActiveTouch(touchList) {\n for (let i = 0; i < touchList.length; i++) {\n const matches = touchList[i].identifier === this.touchStart.identifier;\n if (matches) {\n return touchList[i];\n }\n }\n return null;\n }\n addEventListener(eventType, listener) {\n this.eventService.addEventListener(eventType, listener);\n }\n removeEventListener(eventType, listener) {\n this.eventService.removeEventListener(eventType, listener);\n }\n onTouchStart(touchEvent) {\n // only looking at one touch point at any time\n if (this.touching) {\n return;\n }\n this.touchStart = touchEvent.touches[0];\n this.touching = true;\n this.moved = false;\n const touchStartCopy = this.touchStart;\n window.setTimeout(() => {\n const touchesMatch = this.touchStart === touchStartCopy;\n if (this.touching && touchesMatch && !this.moved) {\n this.moved = true;\n const event = {\n type: TouchListener.EVENT_LONG_TAP,\n touchStart: this.touchStart,\n touchEvent: touchEvent\n };\n this.eventService.dispatchEvent(event);\n }\n }, 500);\n }\n onTouchMove(touchEvent) {\n if (!this.touching) {\n return;\n }\n const touch = this.getActiveTouch(touchEvent.touches);\n if (!touch) {\n return;\n }\n const eventIsFarAway = !areEventsNear(touch, this.touchStart, 4);\n if (eventIsFarAway) {\n this.moved = true;\n }\n }\n onTouchEnd(touchEvent) {\n if (!this.touching) {\n return;\n }\n if (!this.moved) {\n const event = {\n type: TouchListener.EVENT_TAP,\n touchStart: this.touchStart\n };\n this.eventService.dispatchEvent(event);\n this.checkForDoubleTap();\n }\n // stops the tap from also been processed as a mouse click\n if (this.preventMouseClick && touchEvent.cancelable) {\n touchEvent.preventDefault();\n }\n this.touching = false;\n }\n checkForDoubleTap() {\n const now = new Date().getTime();\n if (this.lastTapTime && this.lastTapTime > 0) {\n // if previous tap, see if duration is short enough to be considered double tap\n const interval = now - this.lastTapTime;\n if (interval > TouchListener.DOUBLE_TAP_MILLIS) {\n // dispatch double tap event\n const event = {\n type: TouchListener.EVENT_DOUBLE_TAP,\n touchStart: this.touchStart\n };\n this.eventService.dispatchEvent(event);\n // this stops a tripple tap ending up as two double taps\n this.lastTapTime = null;\n }\n else {\n this.lastTapTime = now;\n }\n }\n else {\n this.lastTapTime = now;\n }\n }\n destroy() {\n this.destroyFuncs.forEach(func => func());\n }\n}\nTouchListener.EVENT_TAP = \"tap\";\nTouchListener.EVENT_DOUBLE_TAP = \"doubleTap\";\nTouchListener.EVENT_LONG_TAP = \"longTap\";\nTouchListener.DOUBLE_TAP_MILLIS = 500;\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Events } from \"../../../eventKeys.mjs\";\nimport { setDisplayed, clearElement } from \"../../../utils/dom.mjs\";\nimport { Autowired } from \"../../../context/context.mjs\";\nimport { RefSelector } from \"../../../widgets/componentAnnotations.mjs\";\nimport { Component } from \"../../../widgets/component.mjs\";\nimport { createIconNoSpan } from \"../../../utils/icon.mjs\";\nexport class SortIndicatorComp extends Component {\n constructor(skipTemplate) {\n super();\n if (!skipTemplate) {\n this.setTemplate(SortIndicatorComp.TEMPLATE);\n }\n }\n attachCustomElements(eSortOrder, eSortAsc, eSortDesc, eSortMixed, eSortNone) {\n this.eSortOrder = eSortOrder;\n this.eSortAsc = eSortAsc;\n this.eSortDesc = eSortDesc;\n this.eSortMixed = eSortMixed;\n this.eSortNone = eSortNone;\n }\n setupSort(column, suppressOrder = false) {\n this.column = column;\n this.suppressOrder = suppressOrder;\n this.setupMultiSortIndicator();\n const canSort = !!this.column.getColDef().sortable;\n if (!canSort) {\n return;\n }\n this.addInIcon('sortAscending', this.eSortAsc, column);\n this.addInIcon('sortDescending', this.eSortDesc, column);\n this.addInIcon('sortUnSort', this.eSortNone, column);\n // Watch global events, as row group columns can effect their display column.\n this.addManagedListener(this.eventService, Events.EVENT_SORT_CHANGED, () => this.onSortChanged());\n // when grouping changes so can sort indexes and icons\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, () => this.onSortChanged());\n this.onSortChanged();\n }\n addInIcon(iconName, eParent, column) {\n if (eParent == null) {\n return;\n }\n const eIcon = createIconNoSpan(iconName, this.gridOptionsService, column);\n if (eIcon) {\n eParent.appendChild(eIcon);\n }\n }\n onSortChanged() {\n this.updateIcons();\n if (!this.suppressOrder) {\n this.updateSortOrder();\n }\n }\n updateIcons() {\n const sortDirection = this.sortController.getDisplaySortForColumn(this.column);\n if (this.eSortAsc) {\n const isAscending = sortDirection === 'asc';\n setDisplayed(this.eSortAsc, isAscending, { skipAriaHidden: true });\n }\n if (this.eSortDesc) {\n const isDescending = sortDirection === 'desc';\n setDisplayed(this.eSortDesc, isDescending, { skipAriaHidden: true });\n }\n if (this.eSortNone) {\n const alwaysHideNoSort = !this.column.getColDef().unSortIcon && !this.gridOptionsService.is('unSortIcon');\n const isNone = sortDirection === null || sortDirection === undefined;\n setDisplayed(this.eSortNone, !alwaysHideNoSort && isNone, { skipAriaHidden: true });\n }\n }\n setupMultiSortIndicator() {\n this.addInIcon('sortUnSort', this.eSortMixed, this.column);\n const isColumnShowingRowGroup = this.column.getColDef().showRowGroup;\n const areGroupsCoupled = this.gridOptionsService.isColumnsSortingCoupledToGroup();\n if (areGroupsCoupled && isColumnShowingRowGroup) {\n // Watch global events, as row group columns can effect their display column.\n this.addManagedListener(this.eventService, Events.EVENT_SORT_CHANGED, () => this.updateMultiSortIndicator());\n // when grouping changes so can sort indexes and icons\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, () => this.updateMultiSortIndicator());\n this.updateMultiSortIndicator();\n }\n }\n updateMultiSortIndicator() {\n if (this.eSortMixed) {\n const isMixedSort = this.sortController.getDisplaySortForColumn(this.column) === 'mixed';\n setDisplayed(this.eSortMixed, isMixedSort, { skipAriaHidden: true });\n }\n }\n // we listen here for global sort events, NOT column sort events, as we want to do this\n // when sorting has been set on all column (if we listened just for our col (where we\n // set the asc / desc icons) then it's possible other cols are yet to get their sorting state.\n updateSortOrder() {\n var _a;\n if (!this.eSortOrder) {\n return;\n }\n const allColumnsWithSorting = this.sortController.getColumnsWithSortingOrdered();\n const indexThisCol = (_a = this.sortController.getDisplaySortIndexForColumn(this.column)) !== null && _a !== void 0 ? _a : -1;\n const moreThanOneColSorting = allColumnsWithSorting.some(col => { var _a; return (_a = this.sortController.getDisplaySortIndexForColumn(col)) !== null && _a !== void 0 ? _a : -1 >= 1; });\n const showIndex = indexThisCol >= 0 && moreThanOneColSorting;\n setDisplayed(this.eSortOrder, showIndex, { skipAriaHidden: true });\n if (indexThisCol >= 0) {\n this.eSortOrder.innerHTML = (indexThisCol + 1).toString();\n }\n else {\n clearElement(this.eSortOrder);\n }\n }\n}\nSortIndicatorComp.TEMPLATE = `\n \n \n \n \n \n `;\n__decorate([\n RefSelector('eSortOrder')\n], SortIndicatorComp.prototype, \"eSortOrder\", void 0);\n__decorate([\n RefSelector('eSortAsc')\n], SortIndicatorComp.prototype, \"eSortAsc\", void 0);\n__decorate([\n RefSelector('eSortDesc')\n], SortIndicatorComp.prototype, \"eSortDesc\", void 0);\n__decorate([\n RefSelector('eSortMixed')\n], SortIndicatorComp.prototype, \"eSortMixed\", void 0);\n__decorate([\n RefSelector('eSortNone')\n], SortIndicatorComp.prototype, \"eSortNone\", void 0);\n__decorate([\n Autowired('columnModel')\n], SortIndicatorComp.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('sortController')\n], SortIndicatorComp.prototype, \"sortController\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired } from \"../../../context/context.mjs\";\nimport { Column } from \"../../../entities/column.mjs\";\nimport { firstExistingValue } from \"../../../utils/array.mjs\";\nimport { isIOSUserAgent } from \"../../../utils/browser.mjs\";\nimport { removeFromParent, setDisplayed } from \"../../../utils/dom.mjs\";\nimport { exists } from \"../../../utils/generic.mjs\";\nimport { createIconNoSpan } from \"../../../utils/icon.mjs\";\nimport { escapeString } from \"../../../utils/string.mjs\";\nimport { Component } from \"../../../widgets/component.mjs\";\nimport { RefSelector } from \"../../../widgets/componentAnnotations.mjs\";\nimport { TouchListener } from \"../../../widgets/touchListener.mjs\";\nimport { SortIndicatorComp } from \"./sortIndicatorComp.mjs\";\nimport { Events } from \"../../../eventKeys.mjs\";\nexport class HeaderComp extends Component {\n constructor() {\n super(...arguments);\n this.lastMovingChanged = 0;\n }\n // this is a user component, and IComponent has \"public destroy()\" as part of the interface.\n // so we need to override destroy() just to make the method public.\n destroy() {\n super.destroy();\n }\n refresh(params) {\n this.params = params;\n // if template changed, then recreate the whole comp, the code required to manage\n // a changing template is to difficult for what it's worth.\n if (this.workOutTemplate() != this.currentTemplate) {\n return false;\n }\n if (this.workOutShowMenu() != this.currentShowMenu) {\n return false;\n }\n if (this.workOutSort() != this.currentSort) {\n return false;\n }\n this.setDisplayName(params);\n return true;\n }\n workOutTemplate() {\n let template = firstExistingValue(this.params.template, HeaderComp.TEMPLATE);\n // take account of any newlines & whitespace before/after the actual template\n template = template && template.trim ? template.trim() : template;\n return template;\n }\n init(params) {\n this.params = params;\n this.currentTemplate = this.workOutTemplate();\n this.setTemplate(this.currentTemplate);\n this.setupTap();\n this.setupIcons(params.column);\n this.setMenu();\n this.setupSort();\n this.setupFilterIcon();\n this.setDisplayName(params);\n }\n setDisplayName(params) {\n if (this.currentDisplayName != params.displayName) {\n this.currentDisplayName = params.displayName;\n const displayNameSanitised = escapeString(this.currentDisplayName);\n if (this.eText) {\n this.eText.innerHTML = displayNameSanitised;\n }\n }\n }\n setupIcons(column) {\n this.addInIcon('menu', this.eMenu, column);\n this.addInIcon('filter', this.eFilter, column);\n }\n addInIcon(iconName, eParent, column) {\n if (eParent == null) {\n return;\n }\n const eIcon = createIconNoSpan(iconName, this.gridOptionsService, column);\n if (eIcon) {\n eParent.appendChild(eIcon);\n }\n }\n setupTap() {\n const { gridOptionsService } = this;\n if (gridOptionsService.is('suppressTouch')) {\n return;\n }\n const touchListener = new TouchListener(this.getGui(), true);\n const suppressMenuHide = gridOptionsService.is('suppressMenuHide');\n const tapMenuButton = suppressMenuHide && exists(this.eMenu);\n const menuTouchListener = tapMenuButton ? new TouchListener(this.eMenu, true) : touchListener;\n if (this.params.enableMenu) {\n const eventType = tapMenuButton ? 'EVENT_TAP' : 'EVENT_LONG_TAP';\n const showMenuFn = (event) => {\n gridOptionsService.api.showColumnMenuAfterMouseClick(this.params.column, event.touchStart);\n };\n this.addManagedListener(menuTouchListener, TouchListener[eventType], showMenuFn);\n }\n if (this.params.enableSorting) {\n const tapListener = (event) => {\n const target = event.touchStart.target;\n // When suppressMenuHide is true, a tap on the menu icon will bubble up\n // to the header container, in that case we should not sort\n if (suppressMenuHide && this.eMenu.contains(target)) {\n return;\n }\n this.sortController.progressSort(this.params.column, false, \"uiColumnSorted\");\n };\n this.addManagedListener(touchListener, TouchListener.EVENT_TAP, tapListener);\n }\n // if tapMenuButton is true `touchListener` and `menuTouchListener` are different\n // so we need to make sure to destroy both listeners here\n this.addDestroyFunc(() => touchListener.destroy());\n if (tapMenuButton) {\n this.addDestroyFunc(() => menuTouchListener.destroy());\n }\n }\n workOutShowMenu() {\n // we don't show the menu if on an iPad/iPhone, as the user cannot have a pointer device/\n // However if suppressMenuHide is set to true the menu will be displayed alwasys, so it's ok\n // to show it on iPad in this case (as hover isn't needed). If suppressMenuHide\n // is false (default) user will need to use longpress to display the menu.\n const menuHides = !this.gridOptionsService.is('suppressMenuHide');\n const onIpadAndMenuHides = isIOSUserAgent() && menuHides;\n const showMenu = this.params.enableMenu && !onIpadAndMenuHides;\n return showMenu;\n }\n setMenu() {\n // if no menu provided in template, do nothing\n if (!this.eMenu) {\n return;\n }\n this.currentShowMenu = this.workOutShowMenu();\n if (!this.currentShowMenu) {\n removeFromParent(this.eMenu);\n return;\n }\n const suppressMenuHide = this.gridOptionsService.is('suppressMenuHide');\n this.addManagedListener(this.eMenu, 'click', () => this.showMenu(this.eMenu));\n this.eMenu.classList.toggle('ag-header-menu-always-show', suppressMenuHide);\n }\n showMenu(eventSource) {\n if (!eventSource) {\n eventSource = this.eMenu;\n }\n this.menuFactory.showMenuAfterButtonClick(this.params.column, eventSource, 'columnMenu');\n }\n workOutSort() {\n return this.params.enableSorting;\n }\n setupSort() {\n this.currentSort = this.params.enableSorting;\n // eSortIndicator will not be present when customers provided custom header\n // templates, in that case, we need to look for provided sort elements and\n // manually create eSortIndicator.\n if (!this.eSortIndicator) {\n this.eSortIndicator = this.context.createBean(new SortIndicatorComp(true));\n this.eSortIndicator.attachCustomElements(this.eSortOrder, this.eSortAsc, this.eSortDesc, this.eSortMixed, this.eSortNone);\n }\n this.eSortIndicator.setupSort(this.params.column);\n // we set up the indicator prior to the check for whether this column is sortable, as it allows the indicator to\n // set up the multi sort indicator which can appear irrelevant of whether this column can itself be sorted.\n // this can occur in the case of a non-sortable group display column.\n if (!this.currentSort) {\n return;\n }\n const sortUsingCtrl = this.gridOptionsService.get('multiSortKey') === 'ctrl';\n // keep track of last time the moving changed flag was set\n this.addManagedListener(this.params.column, Column.EVENT_MOVING_CHANGED, () => {\n this.lastMovingChanged = new Date().getTime();\n });\n // add the event on the header, so when clicked, we do sorting\n if (this.eLabel) {\n this.addManagedListener(this.eLabel, 'click', (event) => {\n // sometimes when moving a column via dragging, this was also firing a clicked event.\n // here is issue raised by user: https://ag-grid.zendesk.com/agent/tickets/1076\n // this check stops sort if a) column is moving or b) column moved less than 200ms ago (so caters for race condition)\n const moving = this.params.column.isMoving();\n const nowTime = new Date().getTime();\n // typically there is <2ms if moving flag was set recently, as it would be done in same VM turn\n const movedRecently = (nowTime - this.lastMovingChanged) < 50;\n const columnMoving = moving || movedRecently;\n if (!columnMoving) {\n const multiSort = sortUsingCtrl ? (event.ctrlKey || event.metaKey) : event.shiftKey;\n this.params.progressSort(multiSort);\n }\n });\n }\n const onSortingChanged = () => {\n this.addOrRemoveCssClass('ag-header-cell-sorted-asc', this.params.column.isSortAscending());\n this.addOrRemoveCssClass('ag-header-cell-sorted-desc', this.params.column.isSortDescending());\n this.addOrRemoveCssClass('ag-header-cell-sorted-none', this.params.column.isSortNone());\n if (this.params.column.getColDef().showRowGroup) {\n const sourceColumns = this.columnModel.getSourceColumnsForGroupColumn(this.params.column);\n // this == is intentional, as it allows null and undefined to match, which are both unsorted states\n const sortDirectionsMatch = sourceColumns === null || sourceColumns === void 0 ? void 0 : sourceColumns.every(sourceCol => this.params.column.getSort() == sourceCol.getSort());\n const isMultiSorting = !sortDirectionsMatch;\n this.addOrRemoveCssClass('ag-header-cell-sorted-mixed', isMultiSorting);\n }\n };\n this.addManagedListener(this.eventService, Events.EVENT_SORT_CHANGED, onSortingChanged);\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, onSortingChanged);\n }\n setupFilterIcon() {\n if (!this.eFilter) {\n return;\n }\n this.addManagedListener(this.params.column, Column.EVENT_FILTER_CHANGED, this.onFilterChanged.bind(this));\n this.onFilterChanged();\n }\n onFilterChanged() {\n const filterPresent = this.params.column.isFilterActive();\n setDisplayed(this.eFilter, filterPresent, { skipAriaHidden: true });\n }\n}\nHeaderComp.TEMPLATE = `
\n \n
\n \n \n \n
\n
`;\n__decorate([\n Autowired('sortController')\n], HeaderComp.prototype, \"sortController\", void 0);\n__decorate([\n Autowired('menuFactory')\n], HeaderComp.prototype, \"menuFactory\", void 0);\n__decorate([\n Autowired('columnModel')\n], HeaderComp.prototype, \"columnModel\", void 0);\n__decorate([\n RefSelector('eFilter')\n], HeaderComp.prototype, \"eFilter\", void 0);\n__decorate([\n RefSelector('eSortIndicator')\n], HeaderComp.prototype, \"eSortIndicator\", void 0);\n__decorate([\n RefSelector('eMenu')\n], HeaderComp.prototype, \"eMenu\", void 0);\n__decorate([\n RefSelector('eLabel')\n], HeaderComp.prototype, \"eLabel\", void 0);\n__decorate([\n RefSelector('eText')\n], HeaderComp.prototype, \"eText\", void 0);\n__decorate([\n RefSelector('eSortOrder')\n], HeaderComp.prototype, \"eSortOrder\", void 0);\n__decorate([\n RefSelector('eSortAsc')\n], HeaderComp.prototype, \"eSortAsc\", void 0);\n__decorate([\n RefSelector('eSortDesc')\n], HeaderComp.prototype, \"eSortDesc\", void 0);\n__decorate([\n RefSelector('eSortMixed')\n], HeaderComp.prototype, \"eSortMixed\", void 0);\n__decorate([\n RefSelector('eSortNone')\n], HeaderComp.prototype, \"eSortNone\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired } from \"../../../context/context.mjs\";\nimport { ProvidedColumnGroup } from \"../../../entities/providedColumnGroup.mjs\";\nimport { setDisplayed } from \"../../../utils/dom.mjs\";\nimport { isStopPropagationForAgGrid, stopPropagationForAgGrid } from \"../../../utils/event.mjs\";\nimport { doOnce } from \"../../../utils/function.mjs\";\nimport { exists } from \"../../../utils/generic.mjs\";\nimport { createIconNoSpan } from \"../../../utils/icon.mjs\";\nimport { escapeString } from \"../../../utils/string.mjs\";\nimport { Component } from \"../../../widgets/component.mjs\";\nimport { RefSelector } from \"../../../widgets/componentAnnotations.mjs\";\nimport { TouchListener } from \"../../../widgets/touchListener.mjs\";\nexport class HeaderGroupComp extends Component {\n constructor() {\n super(HeaderGroupComp.TEMPLATE);\n }\n // this is a user component, and IComponent has \"public destroy()\" as part of the interface.\n // so we need to override destroy() just to make the method public.\n destroy() {\n super.destroy();\n }\n init(params) {\n this.params = params;\n this.checkWarnings();\n this.setupLabel();\n this.addGroupExpandIcon();\n this.setupExpandIcons();\n }\n checkWarnings() {\n const paramsAny = this.params;\n if (paramsAny.template) {\n const message = `AG Grid: A template was provided for Header Group Comp - templates are only supported for Header Comps (not groups)`;\n doOnce(() => console.warn(message), 'HeaderGroupComp.templateNotSupported');\n }\n }\n setupExpandIcons() {\n this.addInIcon(\"columnGroupOpened\", \"agOpened\");\n this.addInIcon(\"columnGroupClosed\", \"agClosed\");\n const expandAction = (event) => {\n if (isStopPropagationForAgGrid(event)) {\n return;\n }\n const newExpandedValue = !this.params.columnGroup.isExpanded();\n this.columnModel.setColumnGroupOpened(this.params.columnGroup.getProvidedColumnGroup(), newExpandedValue, \"uiColumnExpanded\");\n };\n this.addTouchAndClickListeners(this.eCloseIcon, expandAction);\n this.addTouchAndClickListeners(this.eOpenIcon, expandAction);\n const stopPropagationAction = (event) => {\n stopPropagationForAgGrid(event);\n };\n // adding stopPropagation to the double click for the icons prevents double click action happening\n // when the icons are clicked. if the icons are double clicked, then the groups should open and\n // then close again straight away. if we also listened to double click, then the group would open,\n // close, then open, which is not what we want. double click should only action if the user double\n // clicks outside of the icons.\n this.addManagedListener(this.eCloseIcon, \"dblclick\", stopPropagationAction);\n this.addManagedListener(this.eOpenIcon, \"dblclick\", stopPropagationAction);\n this.addManagedListener(this.getGui(), \"dblclick\", expandAction);\n this.updateIconVisibility();\n const providedColumnGroup = this.params.columnGroup.getProvidedColumnGroup();\n this.addManagedListener(providedColumnGroup, ProvidedColumnGroup.EVENT_EXPANDED_CHANGED, this.updateIconVisibility.bind(this));\n this.addManagedListener(providedColumnGroup, ProvidedColumnGroup.EVENT_EXPANDABLE_CHANGED, this.updateIconVisibility.bind(this));\n }\n addTouchAndClickListeners(eElement, action) {\n const touchListener = new TouchListener(eElement, true);\n this.addManagedListener(touchListener, TouchListener.EVENT_TAP, action);\n this.addDestroyFunc(() => touchListener.destroy());\n this.addManagedListener(eElement, \"click\", action);\n }\n updateIconVisibility() {\n const columnGroup = this.params.columnGroup;\n if (columnGroup.isExpandable()) {\n const expanded = this.params.columnGroup.isExpanded();\n setDisplayed(this.eOpenIcon, expanded);\n setDisplayed(this.eCloseIcon, !expanded);\n }\n else {\n setDisplayed(this.eOpenIcon, false);\n setDisplayed(this.eCloseIcon, false);\n }\n }\n addInIcon(iconName, refName) {\n const eIcon = createIconNoSpan(iconName, this.gridOptionsService, null);\n if (eIcon) {\n this.getRefElement(refName).appendChild(eIcon);\n }\n }\n addGroupExpandIcon() {\n if (!this.params.columnGroup.isExpandable()) {\n setDisplayed(this.eOpenIcon, false);\n setDisplayed(this.eCloseIcon, false);\n return;\n }\n }\n setupLabel() {\n var _a;\n // no renderer, default text render\n const { displayName, columnGroup } = this.params;\n if (exists(displayName)) {\n const displayNameSanitised = escapeString(displayName);\n this.getRefElement('agLabel').innerHTML = displayNameSanitised;\n }\n this.addOrRemoveCssClass('ag-sticky-label', !((_a = columnGroup.getColGroupDef()) === null || _a === void 0 ? void 0 : _a.suppressStickyLabel));\n }\n}\nHeaderGroupComp.TEMPLATE = `
\n \n \n \n
`;\n__decorate([\n Autowired(\"columnModel\")\n], HeaderGroupComp.prototype, \"columnModel\", void 0);\n__decorate([\n RefSelector(\"agOpened\")\n], HeaderGroupComp.prototype, \"eOpenIcon\", void 0);\n__decorate([\n RefSelector(\"agClosed\")\n], HeaderGroupComp.prototype, \"eCloseIcon\", void 0);\n","import { Component } from \"./component.mjs\";\nexport class PopupComponent extends Component {\n isPopup() {\n return true;\n }\n setParentComponent(container) {\n container.addCssClass('ag-has-popup');\n super.setParentComponent(container);\n }\n destroy() {\n const parentComp = this.parentComponent;\n const hasParent = parentComp && parentComp.isAlive();\n if (hasParent) {\n parentComp.getGui().classList.remove('ag-has-popup');\n }\n super.destroy();\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PopupComponent } from \"../../widgets/popupComponent.mjs\";\nimport { RefSelector } from \"../../widgets/componentAnnotations.mjs\";\nimport { exists } from \"../../utils/generic.mjs\";\nimport { KeyCode } from '../../constants/keyCode.mjs';\nexport class LargeTextCellEditor extends PopupComponent {\n constructor() {\n super(LargeTextCellEditor.TEMPLATE);\n }\n init(params) {\n this.params = params;\n this.focusAfterAttached = params.cellStartedEdit;\n this.eTextArea\n .setMaxLength(params.maxLength || 200)\n .setCols(params.cols || 60)\n .setRows(params.rows || 10);\n if (exists(params.value, true)) {\n this.eTextArea.setValue(params.value.toString(), true);\n }\n this.addGuiEventListener('keydown', this.onKeyDown.bind(this));\n this.activateTabIndex();\n }\n onKeyDown(event) {\n const key = event.key;\n if (key === KeyCode.LEFT ||\n key === KeyCode.UP ||\n key === KeyCode.RIGHT ||\n key === KeyCode.DOWN ||\n (event.shiftKey && key === KeyCode.ENTER)) { // shift+enter allows for newlines\n event.stopPropagation();\n }\n }\n afterGuiAttached() {\n const translate = this.localeService.getLocaleTextFunc();\n this.eTextArea.setInputAriaLabel(translate('ariaInputEditor', 'Input Editor'));\n if (this.focusAfterAttached) {\n this.eTextArea.getFocusableElement().focus();\n }\n }\n getValue() {\n const value = this.eTextArea.getValue();\n if (!exists(value) && !exists(this.params.value)) {\n return this.params.value;\n }\n return this.params.parseValue(value);\n }\n}\nLargeTextCellEditor.TEMPLATE = `
\n \n
`;\n__decorate([\n RefSelector(\"eTextArea\")\n], LargeTextCellEditor.prototype, \"eTextArea\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { AgSelect } from \"../../widgets/agSelect.mjs\";\nimport { Autowired } from \"../../context/context.mjs\";\nimport { PopupComponent } from \"../../widgets/popupComponent.mjs\";\nimport { RefSelector } from \"../../widgets/componentAnnotations.mjs\";\nimport { missing } from \"../../utils/generic.mjs\";\nimport { KeyCode } from '../../constants/keyCode.mjs';\nexport class SelectCellEditor extends PopupComponent {\n constructor() {\n super(/* html */ `
\n \n
`);\n this.startedByEnter = false;\n }\n init(params) {\n this.focusAfterAttached = params.cellStartedEdit;\n const { eSelect, valueFormatterService, gridOptionsService } = this;\n const { values, value, eventKey } = params;\n if (missing(values)) {\n console.warn('AG Grid: no values found for select cellEditor');\n return;\n }\n this.startedByEnter = eventKey != null ? eventKey === KeyCode.ENTER : false;\n let hasValue = false;\n values.forEach((currentValue) => {\n const option = { value: currentValue };\n const valueFormatted = valueFormatterService.formatValue(params.column, null, currentValue);\n const valueFormattedExits = valueFormatted !== null && valueFormatted !== undefined;\n option.text = valueFormattedExits ? valueFormatted : currentValue;\n eSelect.addOption(option);\n hasValue = hasValue || value === currentValue;\n });\n if (hasValue) {\n eSelect.setValue(params.value, true);\n }\n else if (params.values.length) {\n eSelect.setValue(params.values[0], true);\n }\n const { valueListGap, valueListMaxWidth, valueListMaxHeight } = params;\n if (valueListGap != null) {\n eSelect.setPickerGap(valueListGap);\n }\n if (valueListMaxHeight != null) {\n eSelect.setPickerMaxHeight(valueListMaxHeight);\n }\n if (valueListMaxWidth != null) {\n eSelect.setPickerMaxWidth(valueListMaxWidth);\n }\n // we don't want to add this if full row editing, otherwise selecting will stop the\n // full row editing.\n if (gridOptionsService.get('editType') !== 'fullRow') {\n this.addManagedListener(this.eSelect, AgSelect.EVENT_ITEM_SELECTED, () => params.stopEditing());\n }\n }\n afterGuiAttached() {\n if (this.focusAfterAttached) {\n this.eSelect.getFocusableElement().focus();\n }\n if (this.startedByEnter) {\n setTimeout(() => {\n if (this.isAlive()) {\n this.eSelect.showPicker();\n }\n });\n }\n }\n focusIn() {\n this.eSelect.getFocusableElement().focus();\n }\n getValue() {\n return this.eSelect.getValue();\n }\n isPopup() {\n return false;\n }\n}\n__decorate([\n Autowired('valueFormatterService')\n], SelectCellEditor.prototype, \"valueFormatterService\", void 0);\n__decorate([\n RefSelector('eSelect')\n], SelectCellEditor.prototype, \"eSelect\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PopupComponent } from \"../../widgets/popupComponent.mjs\";\nimport { RefSelector } from \"../../widgets/componentAnnotations.mjs\";\nimport { isBrowserSafari } from \"../../utils/browser.mjs\";\nimport { KeyCode } from '../../constants/keyCode.mjs';\nexport class SimpleCellEditor extends PopupComponent {\n constructor(cellEditorInput) {\n super(/* html */ `\n
\n ${cellEditorInput.getTemplate()}\n
`);\n this.cellEditorInput = cellEditorInput;\n }\n init(params) {\n this.params = params;\n const eInput = this.eInput;\n this.cellEditorInput.init(eInput, params);\n let startValue;\n // cellStartedEdit is only false if we are doing fullRow editing\n if (params.cellStartedEdit) {\n this.focusAfterAttached = true;\n const eventKey = params.eventKey;\n if (eventKey === KeyCode.BACKSPACE || params.eventKey === KeyCode.DELETE) {\n startValue = '';\n }\n else if (eventKey && eventKey.length === 1) {\n startValue = eventKey;\n }\n else {\n startValue = this.cellEditorInput.getStartValue();\n if (eventKey !== KeyCode.F2) {\n this.highlightAllOnFocus = true;\n }\n }\n }\n else {\n this.focusAfterAttached = false;\n startValue = this.cellEditorInput.getStartValue();\n }\n if (startValue != null) {\n eInput.setStartValue(startValue);\n }\n this.addManagedListener(eInput.getGui(), 'keydown', (event) => {\n const { key } = event;\n if (key === KeyCode.PAGE_UP || key === KeyCode.PAGE_DOWN) {\n event.preventDefault();\n }\n });\n }\n afterGuiAttached() {\n var _a, _b;\n const translate = this.localeService.getLocaleTextFunc();\n const eInput = this.eInput;\n eInput.setInputAriaLabel(translate('ariaInputEditor', 'Input Editor'));\n if (!this.focusAfterAttached) {\n return;\n }\n // Added for AG-3238. We can't remove this explicit focus() because Chrome requires an input\n // to be focused before setSelectionRange will work. But it triggers a bug in Safari where\n // explicitly focusing then blurring an empty field will cause the parent container to scroll.\n if (!isBrowserSafari()) {\n eInput.getFocusableElement().focus();\n }\n const inputEl = eInput.getInputElement();\n if (this.highlightAllOnFocus) {\n inputEl.select();\n }\n else {\n (_b = (_a = this.cellEditorInput).setCaret) === null || _b === void 0 ? void 0 : _b.call(_a);\n }\n }\n // gets called when tabbing through cells and in full row edit mode\n focusIn() {\n const eInput = this.eInput;\n const focusEl = eInput.getFocusableElement();\n const inputEl = eInput.getInputElement();\n focusEl.focus();\n inputEl.select();\n }\n getValue() {\n return this.cellEditorInput.getValue();\n }\n isPopup() {\n return false;\n }\n}\n__decorate([\n RefSelector('eInput')\n], SimpleCellEditor.prototype, \"eInput\", void 0);\n","import { SimpleCellEditor } from \"./simpleCellEditor.mjs\";\nimport { exists } from \"../../utils/generic.mjs\";\nclass TextCellEditorInput {\n getTemplate() {\n return /* html */ ``;\n }\n init(eInput, params) {\n this.eInput = eInput;\n this.params = params;\n if (params.maxLength != null) {\n eInput.setMaxLength(params.maxLength);\n }\n }\n getValue() {\n const value = this.eInput.getValue();\n if (!exists(value) && !exists(this.params.value)) {\n return this.params.value;\n }\n return this.params.parseValue(value);\n }\n getStartValue() {\n const formatValue = this.params.useFormatter || this.params.column.getColDef().refData;\n return formatValue ? this.params.formatValue(this.params.value) : this.params.value;\n }\n setCaret() {\n // when we started editing, we want the caret at the end, not the start.\n // this comes into play in two scenarios:\n // a) when user hits F2\n // b) when user hits a printable character\n const value = this.eInput.getValue();\n const len = (exists(value) && value.length) || 0;\n if (len) {\n this.eInput.getInputElement().setSelectionRange(len, len);\n }\n }\n}\nexport class TextCellEditor extends SimpleCellEditor {\n constructor() {\n super(new TextCellEditorInput());\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired } from \"../../context/context.mjs\";\nimport { Component } from \"../../widgets/component.mjs\";\nimport { exists } from \"../../utils/generic.mjs\";\nimport { clearElement } from \"../../utils/dom.mjs\";\nconst ARROW_UP = '\\u2191';\nconst ARROW_DOWN = '\\u2193';\nexport class AnimateShowChangeCellRenderer extends Component {\n constructor() {\n super(AnimateShowChangeCellRenderer.TEMPLATE);\n this.refreshCount = 0;\n }\n init(params) {\n // this.params = params;\n this.eValue = this.queryForHtmlElement('.ag-value-change-value');\n this.eDelta = this.queryForHtmlElement('.ag-value-change-delta');\n this.refresh(params);\n }\n showDelta(params, delta) {\n const absDelta = Math.abs(delta);\n const valueFormatted = params.formatValue(absDelta);\n const valueToUse = exists(valueFormatted) ? valueFormatted : absDelta;\n const deltaUp = (delta >= 0);\n if (deltaUp) {\n this.eDelta.innerHTML = ARROW_UP + valueToUse;\n }\n else {\n // because negative, use ABS to remove sign\n this.eDelta.innerHTML = ARROW_DOWN + valueToUse;\n }\n this.eDelta.classList.toggle('ag-value-change-delta-up', deltaUp);\n this.eDelta.classList.toggle('ag-value-change-delta-down', !deltaUp);\n }\n setTimerToRemoveDelta() {\n // the refreshCount makes sure that if the value updates again while\n // the below timer is waiting, then the below timer will realise it\n // is not the most recent and will not try to remove the delta value.\n this.refreshCount++;\n const refreshCountCopy = this.refreshCount;\n window.setTimeout(() => {\n if (refreshCountCopy === this.refreshCount) {\n this.hideDeltaValue();\n }\n }, 2000);\n }\n hideDeltaValue() {\n this.eValue.classList.remove('ag-value-change-value-highlight');\n clearElement(this.eDelta);\n }\n refresh(params) {\n const value = params.value;\n if (value === this.lastValue) {\n return false;\n }\n if (exists(params.valueFormatted)) {\n this.eValue.innerHTML = params.valueFormatted;\n }\n else if (exists(params.value)) {\n this.eValue.innerHTML = value;\n }\n else {\n clearElement(this.eValue);\n }\n // we don't show the delta if we are in the middle of a filter. see comment on FilterManager\n // with regards processingFilterChange\n if (this.filterManager.isSuppressFlashingCellsBecauseFiltering()) {\n return false;\n }\n if (typeof value === 'number' && typeof this.lastValue === 'number') {\n const delta = value - this.lastValue;\n this.showDelta(params, delta);\n }\n // highlight the current value, but only if it's not new, otherwise it\n // would get highlighted first time the value is shown\n if (this.lastValue) {\n this.eValue.classList.add('ag-value-change-value-highlight');\n }\n this.setTimerToRemoveDelta();\n this.lastValue = value;\n return true;\n }\n}\nAnimateShowChangeCellRenderer.TEMPLATE = '' +\n '' +\n '' +\n '';\n__decorate([\n Autowired('filterManager')\n], AnimateShowChangeCellRenderer.prototype, \"filterManager\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired } from \"../../context/context.mjs\";\nimport { Component } from \"../../widgets/component.mjs\";\nimport { loadTemplate, clearElement } from \"../../utils/dom.mjs\";\nimport { missing, exists } from \"../../utils/generic.mjs\";\nexport class AnimateSlideCellRenderer extends Component {\n constructor() {\n super(AnimateSlideCellRenderer.TEMPLATE);\n this.refreshCount = 0;\n this.eCurrent = this.queryForHtmlElement('.ag-value-slide-current');\n }\n init(params) {\n this.refresh(params);\n }\n addSlideAnimation() {\n this.refreshCount++;\n // below we keep checking this, and stop working on the animation\n // if it no longer matches - this means another animation has started\n // and this one is stale.\n const refreshCountCopy = this.refreshCount;\n // if old animation, remove it\n if (this.ePrevious) {\n this.getGui().removeChild(this.ePrevious);\n }\n this.ePrevious = loadTemplate('');\n this.ePrevious.innerHTML = this.eCurrent.innerHTML;\n this.getGui().insertBefore(this.ePrevious, this.eCurrent);\n // having timeout of 0 allows use to skip to the next css turn,\n // so we know the previous css classes have been applied. so the\n // complex set of setTimeout below creates the animation\n window.setTimeout(() => {\n if (refreshCountCopy !== this.refreshCount) {\n return;\n }\n this.ePrevious.classList.add('ag-value-slide-out-end');\n }, 50);\n window.setTimeout(() => {\n if (refreshCountCopy !== this.refreshCount) {\n return;\n }\n this.getGui().removeChild(this.ePrevious);\n this.ePrevious = null;\n }, 3000);\n }\n refresh(params) {\n let value = params.value;\n if (missing(value)) {\n value = '';\n }\n if (value === this.lastValue) {\n return false;\n }\n // we don't show the delta if we are in the middle of a filter. see comment on FilterManager\n // with regards processingFilterChange\n if (this.filterManager.isSuppressFlashingCellsBecauseFiltering()) {\n return false;\n }\n this.addSlideAnimation();\n this.lastValue = value;\n if (exists(params.valueFormatted)) {\n this.eCurrent.innerHTML = params.valueFormatted;\n }\n else if (exists(params.value)) {\n this.eCurrent.innerHTML = value;\n }\n else {\n clearElement(this.eCurrent);\n }\n return true;\n }\n}\nAnimateSlideCellRenderer.TEMPLATE = `\n \n `;\n__decorate([\n Autowired('filterManager')\n], AnimateSlideCellRenderer.prototype, \"filterManager\", void 0);\n","import { Events } from \"../events.mjs\";\nimport { EventService } from \"../eventService.mjs\";\nimport { debounce } from \"../utils/function.mjs\";\nimport { exists, missing, missingOrEmpty } from \"../utils/generic.mjs\";\nimport { getAllKeysInObjects } from \"../utils/object.mjs\";\nexport class RowNode {\n constructor(beans) {\n /** The current row index. If the row is filtered out or in a collapsed group, this value will be `null`. */\n this.rowIndex = null;\n /** The key for the group eg Ireland, UK, USA */\n this.key = null;\n /** Children mapped by the pivot columns. */\n this.childrenMapped = {};\n /**\n * This will be `true` if it has a rowIndex assigned, otherwise `false`.\n */\n this.displayed = false;\n /** The row top position in pixels. */\n this.rowTop = null;\n /** The top pixel for this row last time, makes sense if data set was ordered or filtered,\n * it is used so new rows can animate in from their old position. */\n this.oldRowTop = null;\n /** `true` by default - can be overridden via gridOptions.isRowSelectable(rowNode) */\n this.selectable = true;\n /** Used by sorting service - to give deterministic sort to groups. Previously we\n * just id for this, however id is a string and had slower sorting compared to numbers. */\n this.__objectId = RowNode.OBJECT_ID_SEQUENCE++;\n /** When one or more Columns are using autoHeight, this keeps track of height of each autoHeight Cell,\n * indexed by the Column ID. */\n this.__autoHeights = {};\n /** `true` when nodes with the same id are being removed and added as part of the same batch transaction */\n this.alreadyRendered = false;\n this.highlighted = null;\n this.hovered = false;\n this.selected = false;\n this.beans = beans;\n }\n /**\n * Replaces the data on the `rowNode`. When this method is called, the grid will refresh the entire rendered row if it is displayed.\n */\n setData(data) {\n this.setDataCommon(data, false);\n }\n // similar to setRowData, however it is expected that the data is the same data item. this\n // is intended to be used with Redux type stores, where the whole data can be changed. we are\n // guaranteed that the data is the same entity (so grid doesn't need to worry about the id of the\n // underlying data changing, hence doesn't need to worry about selection). the grid, upon receiving\n // dataChanged event, will refresh the cells rather than rip them all out (so user can show transitions).\n /**\n * Updates the data on the `rowNode`. When this method is called, the grid will refresh the entire rendered row if it is displayed.\n */\n updateData(data) {\n this.setDataCommon(data, true);\n }\n setDataCommon(data, update) {\n const oldData = this.data;\n this.data = data;\n this.beans.valueCache.onDataChanged();\n this.updateDataOnDetailNode();\n this.checkRowSelectable();\n this.resetQuickFilterAggregateText();\n const event = this.createDataChangedEvent(data, oldData, update);\n this.dispatchLocalEvent(event);\n }\n // when we are doing master / detail, the detail node is lazy created, but then kept around.\n // so if we show / hide the detail, the same detail rowNode is used. so we need to keep the data\n // in sync, otherwise expand/collapse of the detail would still show the old values.\n updateDataOnDetailNode() {\n if (this.detailNode) {\n this.detailNode.data = this.data;\n }\n }\n createDataChangedEvent(newData, oldData, update) {\n return {\n type: RowNode.EVENT_DATA_CHANGED,\n node: this,\n oldData: oldData,\n newData: newData,\n update: update\n };\n }\n createLocalRowEvent(type) {\n return {\n type: type,\n node: this\n };\n }\n getRowIndexString() {\n if (this.rowPinned === 'top') {\n return 't-' + this.rowIndex;\n }\n if (this.rowPinned === 'bottom') {\n return 'b-' + this.rowIndex;\n }\n return this.rowIndex.toString();\n }\n createDaemonNode() {\n const oldNode = new RowNode(this.beans);\n // just copy the id and data, this is enough for the node to be used\n // in the selection controller (the selection controller is the only\n // place where daemon nodes can live).\n oldNode.id = this.id;\n oldNode.data = this.data;\n oldNode.__daemon = true;\n oldNode.selected = this.selected;\n oldNode.level = this.level;\n return oldNode;\n }\n setDataAndId(data, id) {\n const oldNode = exists(this.id) ? this.createDaemonNode() : null;\n const oldData = this.data;\n this.data = data;\n this.updateDataOnDetailNode();\n this.setId(id);\n this.checkRowSelectable();\n this.beans.selectionService.syncInRowNode(this, oldNode);\n const event = this.createDataChangedEvent(data, oldData, false);\n this.dispatchLocalEvent(event);\n }\n checkRowSelectable() {\n const isRowSelectableFunc = this.beans.gridOptionsService.get('isRowSelectable');\n this.setRowSelectable(isRowSelectableFunc ? isRowSelectableFunc(this) : true);\n }\n setRowSelectable(newVal) {\n if (this.selectable !== newVal) {\n this.selectable = newVal;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_SELECTABLE_CHANGED));\n }\n const isGroupSelectsChildren = this.beans.gridOptionsService.is('groupSelectsChildren');\n if (isGroupSelectsChildren) {\n const selected = this.calculateSelectedFromChildren();\n this.setSelectedParams({\n newValue: selected !== null && selected !== void 0 ? selected : false,\n source: 'selectableChanged',\n });\n }\n }\n }\n setId(id) {\n // see if user is providing the id's\n const getRowIdFunc = this.beans.gridOptionsService.getCallback('getRowId');\n if (getRowIdFunc) {\n // if user is providing the id's, then we set the id only after the data has been set.\n // this is important for virtual pagination and viewport, where empty rows exist.\n if (this.data) {\n // we pass 'true' as we skip this level when generating keys,\n // as we don't always have the key for this level (eg when updating\n // data via transaction on SSRM, we are getting key to look up the\n // RowNode, don't have the RowNode yet, thus no way to get the current key)\n const parentKeys = this.getGroupKeys(true);\n this.id = getRowIdFunc({\n data: this.data,\n parentKeys: parentKeys.length > 0 ? parentKeys : undefined,\n level: this.level\n });\n // make sure id provided doesn't start with 'row-group-' as this is reserved. also check that\n // it has 'startsWith' in case the user provided a number.\n if (this.id !== null && typeof this.id === 'string' && this.id.startsWith(RowNode.ID_PREFIX_ROW_GROUP)) {\n console.error(`AG Grid: Row IDs cannot start with ${RowNode.ID_PREFIX_ROW_GROUP}, this is a reserved prefix for AG Grid's row grouping feature.`);\n }\n // force id to be a string\n if (this.id !== null && typeof this.id !== 'string') {\n this.id = '' + this.id;\n }\n }\n else {\n // this can happen if user has set blank into the rowNode after the row previously\n // having data. this happens in virtual page row model, when data is delete and\n // the page is refreshed.\n this.id = undefined;\n }\n }\n else {\n this.id = id;\n }\n }\n getGroupKeys(excludeSelf = false) {\n const keys = [];\n let pointer = this;\n if (excludeSelf) {\n pointer = pointer.parent;\n }\n while (pointer && pointer.level >= 0) {\n keys.push(pointer.key);\n pointer = pointer.parent;\n }\n keys.reverse();\n return keys;\n }\n isPixelInRange(pixel) {\n if (!exists(this.rowTop) || !exists(this.rowHeight)) {\n return false;\n }\n return pixel >= this.rowTop && pixel < (this.rowTop + this.rowHeight);\n }\n setFirstChild(firstChild) {\n if (this.firstChild === firstChild) {\n return;\n }\n this.firstChild = firstChild;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_FIRST_CHILD_CHANGED));\n }\n }\n setLastChild(lastChild) {\n if (this.lastChild === lastChild) {\n return;\n }\n this.lastChild = lastChild;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_LAST_CHILD_CHANGED));\n }\n }\n setChildIndex(childIndex) {\n if (this.childIndex === childIndex) {\n return;\n }\n this.childIndex = childIndex;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_CHILD_INDEX_CHANGED));\n }\n }\n setRowTop(rowTop) {\n this.oldRowTop = this.rowTop;\n if (this.rowTop === rowTop) {\n return;\n }\n this.rowTop = rowTop;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_TOP_CHANGED));\n }\n this.setDisplayed(rowTop !== null);\n }\n clearRowTopAndRowIndex() {\n this.oldRowTop = null;\n this.setRowTop(null);\n this.setRowIndex(null);\n }\n setDisplayed(displayed) {\n if (this.displayed === displayed) {\n return;\n }\n this.displayed = displayed;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_DISPLAYED_CHANGED));\n }\n }\n setDragging(dragging) {\n if (this.dragging === dragging) {\n return;\n }\n this.dragging = dragging;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_DRAGGING_CHANGED));\n }\n }\n setHighlighted(highlighted) {\n if (highlighted === this.highlighted) {\n return;\n }\n this.highlighted = highlighted;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_HIGHLIGHT_CHANGED));\n }\n }\n setHovered(hovered) {\n if (this.hovered === hovered) {\n return;\n }\n this.hovered = hovered;\n }\n isHovered() {\n return this.hovered;\n }\n setAllChildrenCount(allChildrenCount) {\n if (this.allChildrenCount === allChildrenCount) {\n return;\n }\n this.allChildrenCount = allChildrenCount;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_ALL_CHILDREN_COUNT_CHANGED));\n }\n }\n setMaster(master) {\n if (this.master === master) {\n return;\n }\n // if changing AWAY from master, then unexpand, otherwise\n // next time it's shown it is expanded again\n if (this.master && !master) {\n this.expanded = false;\n }\n this.master = master;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_MASTER_CHANGED));\n }\n }\n setGroup(group) {\n if (this.group === group) {\n return;\n }\n // if we used to be a group, and no longer, then close the node\n if (this.group && !group) {\n this.expanded = false;\n }\n this.group = group;\n this.updateHasChildren();\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_GROUP_CHANGED));\n }\n }\n /**\n * Sets the row height.\n * Call if you want to change the height initially assigned to the row.\n * After calling, you must call `api.onRowHeightChanged()` so the grid knows it needs to work out the placement of the rows. */\n setRowHeight(rowHeight, estimated = false) {\n this.rowHeight = rowHeight;\n this.rowHeightEstimated = estimated;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_HEIGHT_CHANGED));\n }\n }\n setRowAutoHeight(cellHeight, column) {\n if (!this.__autoHeights) {\n this.__autoHeights = {};\n }\n this.__autoHeights[column.getId()] = cellHeight;\n if (cellHeight != null) {\n if (this.checkAutoHeightsDebounced == null) {\n this.checkAutoHeightsDebounced = debounce(this.checkAutoHeights.bind(this), 1);\n }\n this.checkAutoHeightsDebounced();\n }\n }\n checkAutoHeights() {\n let notAllPresent = false;\n let nonePresent = true;\n let newRowHeight = 0;\n const autoHeights = this.__autoHeights;\n if (autoHeights == null) {\n return;\n }\n const displayedAutoHeightCols = this.beans.columnModel.getAllDisplayedAutoHeightCols();\n displayedAutoHeightCols.forEach(col => {\n let cellHeight = autoHeights[col.getId()];\n if (cellHeight == null) {\n // If column spanning is active a column may not provide auto height for a row if that\n // cell is not present for the given row due to a previous cell spanning over the auto height column.\n if (this.beans.columnModel.isColSpanActive()) {\n let activeColsForRow = [];\n switch (col.getPinned()) {\n case 'left':\n activeColsForRow = this.beans.columnModel.getDisplayedLeftColumnsForRow(this);\n break;\n case 'right':\n activeColsForRow = this.beans.columnModel.getDisplayedRightColumnsForRow(this);\n break;\n case null:\n activeColsForRow = this.beans.columnModel.getViewportCenterColumnsForRow(this);\n break;\n }\n if (activeColsForRow.includes(col)) {\n // Column is present in the row, i.e not spanned over, but no auto height was provided so we cannot calculate the row height\n notAllPresent = true;\n return;\n }\n // Ignore this column as it is spanned over and not present in the row\n cellHeight = -1;\n }\n else {\n notAllPresent = true;\n return;\n }\n }\n else {\n // At least one auto height is present\n nonePresent = false;\n }\n if (cellHeight > newRowHeight) {\n newRowHeight = cellHeight;\n }\n });\n if (notAllPresent) {\n return;\n }\n // we take min of 10, so we don't adjust for empty rows. if <10, we put to default.\n // this prevents the row starting very small when waiting for async components,\n // which would then mean the grid squashes in far to many rows (as small heights\n // means more rows fit in) which looks crap. so best ignore small values and assume\n // we are still waiting for values to render.\n if (nonePresent || newRowHeight < 10) {\n newRowHeight = this.beans.gridOptionsService.getRowHeightForNode(this).height;\n }\n if (newRowHeight == this.rowHeight) {\n return;\n }\n this.setRowHeight(newRowHeight);\n const rowModel = this.beans.rowModel;\n if (rowModel.onRowHeightChangedDebounced) {\n rowModel.onRowHeightChangedDebounced();\n }\n }\n setRowIndex(rowIndex) {\n if (this.rowIndex === rowIndex) {\n return;\n }\n this.rowIndex = rowIndex;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_ROW_INDEX_CHANGED));\n }\n }\n setUiLevel(uiLevel) {\n if (this.uiLevel === uiLevel) {\n return;\n }\n this.uiLevel = uiLevel;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_UI_LEVEL_CHANGED));\n }\n }\n /**\n * Set the expanded state of this rowNode. Pass `true` to expand and `false` to collapse.\n */\n setExpanded(expanded, e) {\n if (this.expanded === expanded) {\n return;\n }\n this.expanded = expanded;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_EXPANDED_CHANGED));\n }\n const event = Object.assign({}, this.createGlobalRowEvent(Events.EVENT_ROW_GROUP_OPENED), {\n expanded,\n event: e || null\n });\n this.beans.rowNodeEventThrottle.dispatchExpanded(event);\n // when using footers we need to refresh the group row, as the aggregation\n // values jump between group and footer\n if (this.sibling) {\n this.beans.rowRenderer.refreshCells({ rowNodes: [this] });\n }\n }\n createGlobalRowEvent(type) {\n return {\n type: type,\n node: this,\n data: this.data,\n rowIndex: this.rowIndex,\n rowPinned: this.rowPinned,\n context: this.beans.gridOptionsService.context,\n api: this.beans.gridOptionsService.api,\n columnApi: this.beans.gridOptionsService.columnApi\n };\n }\n dispatchLocalEvent(event) {\n if (this.eventService) {\n this.eventService.dispatchEvent(event);\n }\n }\n /**\n * Replaces the value on the `rowNode` for the specified column. When complete,\n * the grid will refresh the rendered cell on the required row only.\n * **Note**: This method only fires `onCellEditRequest` when the Grid is in **Read Only** mode.\n *\n * @param colKey The column where the value should be updated\n * @param newValue The new value\n * @param eventSource The source of the event\n * @returns `true` if the value was changed, otherwise `false`.\n */\n setDataValue(colKey, newValue, eventSource) {\n const getColumnFromKey = () => {\n var _a;\n if (typeof colKey !== 'string') {\n return colKey;\n }\n // if in pivot mode, grid columns wont include primary columns\n return (_a = this.beans.columnModel.getGridColumn(colKey)) !== null && _a !== void 0 ? _a : this.beans.columnModel.getPrimaryColumn(colKey);\n };\n // When it is done via the editors, no 'cell changed' event gets fired, as it's assumed that\n // the cell knows about the change given it's in charge of the editing.\n // this method is for the client to call, so the cell listens for the change\n // event, and also flashes the cell when the change occurs.\n const column = getColumnFromKey();\n const oldValue = this.getValueFromValueService(column);\n if (this.beans.gridOptionsService.is('readOnlyEdit')) {\n this.dispatchEventForSaveValueReadOnly(column, oldValue, newValue, eventSource);\n return false;\n }\n const valueChanged = this.beans.valueService.setValue(this, column, newValue, eventSource);\n this.dispatchCellChangedEvent(column, newValue, oldValue);\n this.checkRowSelectable();\n return valueChanged;\n }\n getValueFromValueService(column) {\n // if we don't check this, then the grid will render leaf groups as open even if we are not\n // allowing the user to open leaf groups. confused? remember for pivot mode we don't allow\n // opening leaf groups, so we have to force leafGroups to be closed in case the user expanded\n // them via the API, or user user expanded them in the UI before turning on pivot mode\n const lockedClosedGroup = this.leafGroup && this.beans.columnModel.isPivotMode();\n const isOpenGroup = this.group && this.expanded && !this.footer && !lockedClosedGroup;\n // are we showing group footers\n const getGroupIncludeFooter = this.beans.gridOptionsService.getGroupIncludeFooter();\n const groupFootersEnabled = getGroupIncludeFooter({ node: this });\n // if doing footers, we normally don't show agg data at group level when group is open\n const groupAlwaysShowAggData = this.beans.gridOptionsService.is('groupSuppressBlankHeader');\n // if doing grouping and footers, we don't want to include the agg value\n // in the header when the group is open\n const ignoreAggData = (isOpenGroup && groupFootersEnabled) && !groupAlwaysShowAggData;\n const value = this.beans.valueService.getValue(column, this, false, ignoreAggData);\n return value;\n }\n dispatchEventForSaveValueReadOnly(column, oldValue, newValue, eventSource) {\n const event = {\n type: Events.EVENT_CELL_EDIT_REQUEST,\n event: null,\n rowIndex: this.rowIndex,\n rowPinned: this.rowPinned,\n column: column,\n colDef: column.getColDef(),\n context: this.beans.gridOptionsService.context,\n api: this.beans.gridOptionsService.api,\n columnApi: this.beans.gridOptionsService.columnApi,\n data: this.data,\n node: this,\n oldValue,\n newValue,\n value: newValue,\n source: eventSource\n };\n this.beans.eventService.dispatchEvent(event);\n }\n setGroupValue(colKey, newValue) {\n const column = this.beans.columnModel.getGridColumn(colKey);\n if (missing(this.groupData)) {\n this.groupData = {};\n }\n const columnId = column.getColId();\n const oldValue = this.groupData[columnId];\n if (oldValue === newValue) {\n return;\n }\n this.groupData[columnId] = newValue;\n this.dispatchCellChangedEvent(column, newValue, oldValue);\n }\n // sets the data for an aggregation\n setAggData(newAggData) {\n // find out all keys that could potentially change\n const colIds = getAllKeysInObjects([this.aggData, newAggData]);\n const oldAggData = this.aggData;\n this.aggData = newAggData;\n // if no event service, nobody has registered for events, so no need fire event\n if (this.eventService) {\n colIds.forEach(colId => {\n const value = this.aggData ? this.aggData[colId] : undefined;\n const oldValue = oldAggData ? oldAggData[colId] : undefined;\n if (value === oldValue) {\n return;\n }\n // do a quick lookup - despite the event it's possible the column no longer exists\n const column = this.beans.columnModel.lookupGridColumn(colId);\n if (!column) {\n return;\n }\n this.dispatchCellChangedEvent(column, value, oldValue);\n });\n }\n }\n updateHasChildren() {\n // in CSRM, the group property will be set before the childrenAfterGroup property, check both to prevent flickering\n let newValue = (this.group && !this.footer) || (this.childrenAfterGroup && this.childrenAfterGroup.length > 0);\n const isSsrm = this.beans.gridOptionsService.isRowModelType('serverSide');\n if (isSsrm) {\n const isTreeData = this.beans.gridOptionsService.is('treeData');\n const isGroupFunc = this.beans.gridOptionsService.get('isServerSideGroup');\n // stubs and footers can never have children, as they're grid rows. if tree data the presence of children\n // is determined by the isServerSideGroup callback, if not tree data then the rows group property will be set.\n newValue = !this.stub && !this.footer && (isTreeData ? !!isGroupFunc && isGroupFunc(this.data) : !!this.group);\n }\n if (newValue !== this.__hasChildren) {\n this.__hasChildren = !!newValue;\n if (this.eventService) {\n this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_HAS_CHILDREN_CHANGED));\n }\n }\n }\n hasChildren() {\n if (this.__hasChildren == null) {\n this.updateHasChildren();\n }\n return this.__hasChildren;\n }\n isEmptyRowGroupNode() {\n return this.group && missingOrEmpty(this.childrenAfterGroup);\n }\n dispatchCellChangedEvent(column, newValue, oldValue) {\n const cellChangedEvent = {\n type: RowNode.EVENT_CELL_CHANGED,\n node: this,\n column: column,\n newValue: newValue,\n oldValue: oldValue\n };\n this.dispatchLocalEvent(cellChangedEvent);\n }\n /**\n * The first time `quickFilter` runs, the grid creates a one-off string representation of the row.\n * This string is then used for the quick filter instead of hitting each column separately.\n * When you edit, using grid editing, this string gets cleared down.\n * However if you edit without using grid editing, you will need to clear this string down for the row to be updated with the new values.\n * Otherwise new values will not work with the `quickFilter`. */\n resetQuickFilterAggregateText() {\n this.quickFilterAggregateText = null;\n }\n /** Returns:\n * - `true` if the node can be expanded, i.e it is a group or master row.\n * - `false` if the node cannot be expanded\n */\n isExpandable() {\n return (this.hasChildren() && !this.footer) || this.master ? true : false;\n }\n /** Returns:\n * - `true` if node is selected,\n * - `false` if the node isn't selected\n * - `undefined` if it's partially selected (group where not all children are selected). */\n isSelected() {\n // for footers, we just return what our sibling selected state is, as cannot select a footer\n if (this.footer) {\n return this.sibling.isSelected();\n }\n return this.selected;\n }\n /** Perform a depth-first search of this node and its children. */\n depthFirstSearch(callback) {\n if (this.childrenAfterGroup) {\n this.childrenAfterGroup.forEach(child => child.depthFirstSearch(callback));\n }\n callback(this);\n }\n // + selectionController.calculatedSelectedForAllGroupNodes()\n calculateSelectedFromChildren() {\n var _a;\n let atLeastOneSelected = false;\n let atLeastOneDeSelected = false;\n let atLeastOneMixed = false;\n if (!((_a = this.childrenAfterGroup) === null || _a === void 0 ? void 0 : _a.length)) {\n return this.selectable ? this.selected : null;\n }\n for (let i = 0; i < this.childrenAfterGroup.length; i++) {\n const child = this.childrenAfterGroup[i];\n let childState = child.isSelected();\n // non-selectable nodes must be calculated from their children, or ignored if no value results.\n if (!child.selectable) {\n const selectable = child.calculateSelectedFromChildren();\n if (selectable === null) {\n continue;\n }\n childState = selectable;\n }\n switch (childState) {\n case true:\n atLeastOneSelected = true;\n break;\n case false:\n atLeastOneDeSelected = true;\n break;\n default:\n atLeastOneMixed = true;\n break;\n }\n }\n if (atLeastOneMixed || (atLeastOneSelected && atLeastOneDeSelected)) {\n return undefined;\n }\n if (atLeastOneSelected) {\n return true;\n }\n if (atLeastOneDeSelected) {\n return false;\n }\n if (!this.selectable) {\n return null;\n }\n return this.selected;\n }\n setSelectedInitialValue(selected) {\n this.selected = selected;\n }\n selectThisNode(newValue, e, source = 'api') {\n // we only check selectable when newValue=true (ie selecting) to allow unselecting values,\n // as selectable is dynamic, need a way to unselect rows when selectable becomes false.\n const selectionNotAllowed = !this.selectable && newValue;\n const selectionNotChanged = this.selected === newValue;\n if (selectionNotAllowed || selectionNotChanged) {\n return false;\n }\n this.selected = newValue;\n if (this.eventService) {\n this.dispatchLocalEvent(this.createLocalRowEvent(RowNode.EVENT_ROW_SELECTED));\n const sibling = this.sibling;\n if (sibling && sibling.footer) {\n sibling.dispatchLocalEvent(sibling.createLocalRowEvent(RowNode.EVENT_ROW_SELECTED));\n }\n }\n const event = Object.assign(Object.assign({}, this.createGlobalRowEvent(Events.EVENT_ROW_SELECTED)), { event: e || null, source });\n this.beans.eventService.dispatchEvent(event);\n return true;\n }\n /**\n * Select (or deselect) the node.\n * @param newValue -`true` for selection, `false` for deselection.\n * @param clearSelection - If selecting, then passing `true` will select the node exclusively (i.e. NOT do multi select). If doing deselection, `clearSelection` has no impact.\n * @param source - Source property that will appear in the `selectionChanged` event.\n */\n setSelected(newValue, clearSelection = false, source = 'api') {\n if (typeof source === 'boolean') {\n console.warn('AG Grid: since version v30, rowNode.setSelected() property `suppressFinishActions` has been removed, please use `gridApi.setNodesSelected()` for bulk actions, and the event `source` property for ignoring events instead.');\n return;\n }\n this.setSelectedParams({\n newValue,\n clearSelection,\n rangeSelect: false,\n source\n });\n }\n // this is for internal use only. To make calling code more readable, this is the same method as setSelected except it takes names parameters\n setSelectedParams(params) {\n if (this.rowPinned) {\n console.warn('AG Grid: cannot select pinned rows');\n return 0;\n }\n if (this.id === undefined) {\n console.warn('AG Grid: cannot select node until id for node is known');\n return 0;\n }\n return this.beans.selectionService.setNodesSelected(Object.assign(Object.assign({}, params), { nodes: [this.footer ? this.sibling : this] }));\n }\n /**\n * Returns:\n * - `true` if node is either pinned to the `top` or `bottom`\n * - `false` if the node isn't pinned\n */\n isRowPinned() {\n return this.rowPinned === 'top' || this.rowPinned === 'bottom';\n }\n isParentOfNode(potentialParent) {\n let parentNode = this.parent;\n while (parentNode) {\n if (parentNode === potentialParent) {\n return true;\n }\n parentNode = parentNode.parent;\n }\n return false;\n }\n /** Add an event listener. */\n addEventListener(eventType, listener) {\n if (!this.eventService) {\n this.eventService = new EventService();\n }\n this.eventService.addEventListener(eventType, listener);\n }\n /** Remove event listener. */\n removeEventListener(eventType, listener) {\n if (!this.eventService) {\n return;\n }\n this.eventService.removeEventListener(eventType, listener);\n if (this.eventService.noRegisteredListenersExist()) {\n this.eventService = null;\n }\n }\n onMouseEnter() {\n this.dispatchLocalEvent(this.createLocalRowEvent(RowNode.EVENT_MOUSE_ENTER));\n }\n onMouseLeave() {\n this.dispatchLocalEvent(this.createLocalRowEvent(RowNode.EVENT_MOUSE_LEAVE));\n }\n getFirstChildOfFirstChild(rowGroupColumn) {\n let currentRowNode = this;\n let isCandidate = true;\n let foundFirstChildPath = false;\n let nodeToSwapIn = null;\n // if we are hiding groups, then if we are the first child, of the first child,\n // all the way up to the column we are interested in, then we show the group cell.\n while (isCandidate && !foundFirstChildPath) {\n const parentRowNode = currentRowNode.parent;\n const firstChild = exists(parentRowNode) && currentRowNode.firstChild;\n if (firstChild) {\n if (parentRowNode.rowGroupColumn === rowGroupColumn) {\n foundFirstChildPath = true;\n nodeToSwapIn = parentRowNode;\n }\n }\n else {\n isCandidate = false;\n }\n currentRowNode = parentRowNode;\n }\n return foundFirstChildPath ? nodeToSwapIn : null;\n }\n /**\n * Returns:\n * - `true` if the node is a full width cell\n * - `false` if the node is not a full width cell\n */\n isFullWidthCell() {\n if (this.detail) {\n return true;\n }\n const isFullWidthCellFunc = this.beans.gridOptionsService.getCallback('isFullWidthRow');\n return isFullWidthCellFunc ? isFullWidthCellFunc({ rowNode: this }) : false;\n }\n /**\n * Returns the route of the row node. If the Row Node is a group, it returns the route to that Row Node.\n * If the Row Node is not a group, it returns `undefined`.\n */\n getRoute() {\n if (this.key == null) {\n return;\n }\n const res = [];\n let pointer = this;\n while (pointer.key != null) {\n res.push(pointer.key);\n pointer = pointer.parent;\n }\n return res.reverse();\n }\n createFooter() {\n // only create footer node once, otherwise we have daemons and\n // the animate screws up with the daemons hanging around\n if (this.sibling) {\n return;\n }\n // we don't copy these properties as they cause the footer node\n // to have properties which should be unique to the row.\n const ignoredProperties = new Set([\n 'eventService',\n '__objectId',\n 'sticky',\n ]);\n const footerNode = new RowNode(this.beans);\n Object.keys(this).forEach(key => {\n if (ignoredProperties.has(key)) {\n return;\n }\n footerNode[key] = this[key];\n });\n footerNode.footer = true;\n footerNode.setRowTop(null);\n footerNode.setRowIndex(null);\n // manually set oldRowTop to null so we discard any\n // previous information about its position.\n footerNode.oldRowTop = null;\n footerNode.id = 'rowGroupFooter_' + this.id;\n // get both header and footer to reference each other as siblings. this is never undone,\n // only overwritten. so if a group is expanded, then contracted, it will have a ghost\n // sibling - but that's fine, as we can ignore this if the header is contracted.\n footerNode.sibling = this;\n this.sibling = footerNode;\n }\n // Only used by SSRM. In CSRM this is never used as footers should always be present for\n // the purpose of exporting collapsed groups. In SSRM it is not possible to export collapsed\n // groups anyway, so can destroy footers.\n destroyFooter() {\n if (!this.sibling) {\n return;\n }\n this.sibling.setRowTop(null);\n this.sibling.setRowIndex(null);\n this.sibling = undefined;\n }\n}\nRowNode.ID_PREFIX_ROW_GROUP = 'row-group-';\nRowNode.ID_PREFIX_TOP_PINNED = 't-';\nRowNode.ID_PREFIX_BOTTOM_PINNED = 'b-';\nRowNode.OBJECT_ID_SEQUENCE = 0;\nRowNode.EVENT_ROW_SELECTED = 'rowSelected';\nRowNode.EVENT_DATA_CHANGED = 'dataChanged';\nRowNode.EVENT_CELL_CHANGED = 'cellChanged';\nRowNode.EVENT_ALL_CHILDREN_COUNT_CHANGED = 'allChildrenCountChanged';\nRowNode.EVENT_MASTER_CHANGED = 'masterChanged';\nRowNode.EVENT_GROUP_CHANGED = 'groupChanged';\nRowNode.EVENT_MOUSE_ENTER = 'mouseEnter';\nRowNode.EVENT_MOUSE_LEAVE = 'mouseLeave';\nRowNode.EVENT_HEIGHT_CHANGED = 'heightChanged';\nRowNode.EVENT_TOP_CHANGED = 'topChanged';\nRowNode.EVENT_DISPLAYED_CHANGED = 'displayedChanged';\nRowNode.EVENT_FIRST_CHILD_CHANGED = 'firstChildChanged';\nRowNode.EVENT_LAST_CHILD_CHANGED = 'lastChildChanged';\nRowNode.EVENT_CHILD_INDEX_CHANGED = 'childIndexChanged';\nRowNode.EVENT_ROW_INDEX_CHANGED = 'rowIndexChanged';\nRowNode.EVENT_EXPANDED_CHANGED = 'expandedChanged';\nRowNode.EVENT_HAS_CHILDREN_CHANGED = 'hasChildrenChanged';\nRowNode.EVENT_SELECTABLE_CHANGED = 'selectableChanged';\nRowNode.EVENT_UI_LEVEL_CHANGED = 'uiLevelChanged';\nRowNode.EVENT_HIGHLIGHT_CHANGED = 'rowHighlightChanged';\nRowNode.EVENT_DRAGGING_CHANGED = 'draggingChanged';\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PostConstruct } from '../context/context.mjs';\nimport { Component } from '../widgets/component.mjs';\nimport { Events } from '../events.mjs';\nimport { RefSelector } from '../widgets/componentAnnotations.mjs';\nimport { RowNode } from '../entities/rowNode.mjs';\nimport { stopPropagationForAgGrid } from '../utils/event.mjs';\nimport { getAriaCheckboxStateName, setAriaLive } from '../utils/aria.mjs';\nexport class CheckboxSelectionComponent extends Component {\n constructor() {\n super(/* html*/ `\n
\n \n
`);\n }\n postConstruct() {\n this.eCheckbox.setPassive(true);\n setAriaLive(this.eCheckbox.getInputElement(), 'polite');\n }\n getCheckboxId() {\n return this.eCheckbox.getInputElement().id;\n }\n onDataChanged() {\n // when rows are loaded for the second time, this can impact the selection, as a row\n // could be loaded as already selected (if user scrolls down, and then up again).\n this.onSelectionChanged();\n }\n onSelectableChanged() {\n this.showOrHideSelect();\n }\n onSelectionChanged() {\n const translate = this.localeService.getLocaleTextFunc();\n const state = this.rowNode.isSelected();\n const stateName = getAriaCheckboxStateName(translate, state);\n const ariaLabel = translate('ariaRowToggleSelection', 'Press Space to toggle row selection');\n this.eCheckbox.setValue(state, true);\n this.eCheckbox.setInputAriaLabel(`${ariaLabel} (${stateName})`);\n }\n onClicked(newValue, groupSelectsFiltered, event) {\n return this.rowNode.setSelectedParams({ newValue, rangeSelect: event.shiftKey, groupSelectsFiltered, event, source: 'checkboxSelected' });\n }\n init(params) {\n this.rowNode = params.rowNode;\n this.column = params.column;\n this.overrides = params.overrides;\n this.onSelectionChanged();\n // we don't want double click on this icon to open a group\n this.addManagedListener(this.eCheckbox.getInputElement(), 'dblclick', (event) => {\n stopPropagationForAgGrid(event);\n });\n this.addManagedListener(this.eCheckbox.getInputElement(), 'click', (event) => {\n // we don't want the row clicked event to fire when selecting the checkbox, otherwise the row\n // would possibly get selected twice\n stopPropagationForAgGrid(event);\n const groupSelectsFiltered = this.gridOptionsService.is('groupSelectsFiltered');\n const isSelected = this.eCheckbox.getValue();\n if (this.shouldHandleIndeterminateState(isSelected, groupSelectsFiltered)) {\n // try toggling children to determine action.\n const result = this.onClicked(true, groupSelectsFiltered, event || {});\n if (result === 0) {\n this.onClicked(false, groupSelectsFiltered, event);\n }\n }\n else if (isSelected) {\n this.onClicked(false, groupSelectsFiltered, event);\n }\n else {\n this.onClicked(true, groupSelectsFiltered, event || {});\n }\n });\n this.addManagedListener(this.rowNode, RowNode.EVENT_ROW_SELECTED, this.onSelectionChanged.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_DATA_CHANGED, this.onDataChanged.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_SELECTABLE_CHANGED, this.onSelectableChanged.bind(this));\n const isRowSelectableFunc = this.gridOptionsService.get('isRowSelectable');\n const checkboxVisibleIsDynamic = isRowSelectableFunc || typeof this.getIsVisible() === 'function';\n if (checkboxVisibleIsDynamic) {\n const showOrHideSelectListener = this.showOrHideSelect.bind(this);\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, showOrHideSelectListener);\n this.addManagedListener(this.rowNode, RowNode.EVENT_DATA_CHANGED, showOrHideSelectListener);\n this.addManagedListener(this.rowNode, RowNode.EVENT_CELL_CHANGED, showOrHideSelectListener);\n this.showOrHideSelect();\n }\n this.eCheckbox.getInputElement().setAttribute('tabindex', '-1');\n }\n shouldHandleIndeterminateState(isSelected, groupSelectsFiltered) {\n // for CSRM groupSelectsFiltered, we can get an indeterminate state where all filtered children are selected,\n // and we would expect clicking to deselect all rather than select all\n return groupSelectsFiltered &&\n (this.eCheckbox.getPreviousValue() === undefined || isSelected === undefined) &&\n this.gridOptionsService.isRowModelType('clientSide');\n }\n showOrHideSelect() {\n var _a, _b, _c, _d;\n // if the isRowSelectable() is not provided the row node is selectable by default\n let selectable = this.rowNode.selectable;\n // checkboxSelection callback is deemed a legacy solution however we will still consider it's result.\n // If selectable, then also check the colDef callback. if not selectable, this it short circuits - no need\n // to call the colDef callback.\n const isVisible = this.getIsVisible();\n if (selectable) {\n if (typeof isVisible === 'function') {\n const extraParams = (_a = this.overrides) === null || _a === void 0 ? void 0 : _a.callbackParams;\n const params = (_b = this.column) === null || _b === void 0 ? void 0 : _b.createColumnFunctionCallbackParams(this.rowNode);\n selectable = params ? isVisible(Object.assign(Object.assign({}, extraParams), params)) : false;\n }\n else {\n selectable = isVisible !== null && isVisible !== void 0 ? isVisible : false;\n }\n }\n const disableInsteadOfHide = (_c = this.column) === null || _c === void 0 ? void 0 : _c.getColDef().showDisabledCheckboxes;\n if (disableInsteadOfHide) {\n this.eCheckbox.setDisabled(!selectable);\n this.setVisible(true);\n this.setDisplayed(true);\n return;\n }\n if ((_d = this.overrides) === null || _d === void 0 ? void 0 : _d.removeHidden) {\n this.setDisplayed(selectable);\n return;\n }\n this.setVisible(selectable);\n }\n getIsVisible() {\n var _a, _b;\n if (this.overrides) {\n return this.overrides.isVisible;\n }\n // column will be missing if groupDisplayType = 'groupRows'\n return (_b = (_a = this.column) === null || _a === void 0 ? void 0 : _a.getColDef()) === null || _b === void 0 ? void 0 : _b.checkboxSelection;\n }\n}\n__decorate([\n RefSelector('eCheckbox')\n], CheckboxSelectionComponent.prototype, \"eCheckbox\", void 0);\n__decorate([\n PostConstruct\n], CheckboxSelectionComponent.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar DragAndDropService_1;\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { PostConstruct, Bean, Autowired, PreDestroy } from \"../context/context.mjs\";\nimport { escapeString } from \"../utils/string.mjs\";\nimport { createIcon } from \"../utils/icon.mjs\";\nimport { flatten, removeFromArray } from \"../utils/array.mjs\";\nimport { getBodyHeight, getBodyWidth } from \"../utils/browser.mjs\";\nimport { loadTemplate, clearElement, getElementRectWithOffset } from \"../utils/dom.mjs\";\nimport { isFunction } from \"../utils/function.mjs\";\nexport var DragSourceType;\n(function (DragSourceType) {\n DragSourceType[DragSourceType[\"ToolPanel\"] = 0] = \"ToolPanel\";\n DragSourceType[DragSourceType[\"HeaderCell\"] = 1] = \"HeaderCell\";\n DragSourceType[DragSourceType[\"RowDrag\"] = 2] = \"RowDrag\";\n DragSourceType[DragSourceType[\"ChartPanel\"] = 3] = \"ChartPanel\";\n DragSourceType[DragSourceType[\"AdvancedFilterBuilder\"] = 4] = \"AdvancedFilterBuilder\";\n})(DragSourceType || (DragSourceType = {}));\nexport var VerticalDirection;\n(function (VerticalDirection) {\n VerticalDirection[VerticalDirection[\"Up\"] = 0] = \"Up\";\n VerticalDirection[VerticalDirection[\"Down\"] = 1] = \"Down\";\n})(VerticalDirection || (VerticalDirection = {}));\nexport var HorizontalDirection;\n(function (HorizontalDirection) {\n HorizontalDirection[HorizontalDirection[\"Left\"] = 0] = \"Left\";\n HorizontalDirection[HorizontalDirection[\"Right\"] = 1] = \"Right\";\n})(HorizontalDirection || (HorizontalDirection = {}));\nlet DragAndDropService = DragAndDropService_1 = class DragAndDropService extends BeanStub {\n constructor() {\n super(...arguments);\n this.dragSourceAndParamsList = [];\n this.dropTargets = [];\n }\n init() {\n this.ePinnedIcon = createIcon('columnMovePin', this.gridOptionsService, null);\n this.eHideIcon = createIcon('columnMoveHide', this.gridOptionsService, null);\n this.eMoveIcon = createIcon('columnMoveMove', this.gridOptionsService, null);\n this.eLeftIcon = createIcon('columnMoveLeft', this.gridOptionsService, null);\n this.eRightIcon = createIcon('columnMoveRight', this.gridOptionsService, null);\n this.eGroupIcon = createIcon('columnMoveGroup', this.gridOptionsService, null);\n this.eAggregateIcon = createIcon('columnMoveValue', this.gridOptionsService, null);\n this.ePivotIcon = createIcon('columnMovePivot', this.gridOptionsService, null);\n this.eDropNotAllowedIcon = createIcon('dropNotAllowed', this.gridOptionsService, null);\n }\n addDragSource(dragSource, allowTouch = false) {\n const params = {\n eElement: dragSource.eElement,\n dragStartPixels: dragSource.dragStartPixels,\n onDragStart: this.onDragStart.bind(this, dragSource),\n onDragStop: this.onDragStop.bind(this),\n onDragging: this.onDragging.bind(this),\n includeTouch: allowTouch\n };\n this.dragSourceAndParamsList.push({ params: params, dragSource: dragSource });\n this.dragService.addDragSource(params);\n }\n removeDragSource(dragSource) {\n const sourceAndParams = this.dragSourceAndParamsList.find(item => item.dragSource === dragSource);\n if (sourceAndParams) {\n this.dragService.removeDragSource(sourceAndParams.params);\n removeFromArray(this.dragSourceAndParamsList, sourceAndParams);\n }\n }\n clearDragSourceParamsList() {\n this.dragSourceAndParamsList.forEach(sourceAndParams => this.dragService.removeDragSource(sourceAndParams.params));\n this.dragSourceAndParamsList.length = 0;\n this.dropTargets.length = 0;\n }\n nudge() {\n if (this.dragging) {\n this.onDragging(this.eventLastTime, true);\n }\n }\n onDragStart(dragSource, mouseEvent) {\n this.dragging = true;\n this.dragSource = dragSource;\n this.eventLastTime = mouseEvent;\n this.dragItem = this.dragSource.getDragItem();\n this.lastDropTarget = this.dragSource.dragSourceDropTarget;\n if (this.dragSource.onDragStarted) {\n this.dragSource.onDragStarted();\n }\n this.createGhost();\n }\n onDragStop(mouseEvent) {\n this.eventLastTime = null;\n this.dragging = false;\n if (this.dragSource.onDragStopped) {\n this.dragSource.onDragStopped();\n }\n if (this.lastDropTarget && this.lastDropTarget.onDragStop) {\n const draggingEvent = this.createDropTargetEvent(this.lastDropTarget, mouseEvent, null, null, false);\n this.lastDropTarget.onDragStop(draggingEvent);\n }\n this.lastDropTarget = null;\n this.dragItem = null;\n this.removeGhost();\n }\n onDragging(mouseEvent, fromNudge) {\n var _a, _b, _c, _d;\n const hDirection = this.getHorizontalDirection(mouseEvent);\n const vDirection = this.getVerticalDirection(mouseEvent);\n this.eventLastTime = mouseEvent;\n this.positionGhost(mouseEvent);\n // check if mouseEvent intersects with any of the drop targets\n const validDropTargets = this.dropTargets.filter(target => this.isMouseOnDropTarget(mouseEvent, target));\n const dropTarget = this.findCurrentDropTarget(mouseEvent, validDropTargets);\n if (dropTarget !== this.lastDropTarget) {\n this.leaveLastTargetIfExists(mouseEvent, hDirection, vDirection, fromNudge);\n if (this.lastDropTarget !== null && dropTarget === null) {\n (_b = (_a = this.dragSource).onGridExit) === null || _b === void 0 ? void 0 : _b.call(_a, this.dragItem);\n }\n if (this.lastDropTarget === null && dropTarget !== null) {\n (_d = (_c = this.dragSource).onGridEnter) === null || _d === void 0 ? void 0 : _d.call(_c, this.dragItem);\n }\n this.enterDragTargetIfExists(dropTarget, mouseEvent, hDirection, vDirection, fromNudge);\n this.lastDropTarget = dropTarget;\n }\n else if (dropTarget && dropTarget.onDragging) {\n const draggingEvent = this.createDropTargetEvent(dropTarget, mouseEvent, hDirection, vDirection, fromNudge);\n dropTarget.onDragging(draggingEvent);\n }\n }\n getAllContainersFromDropTarget(dropTarget) {\n const secondaryContainers = dropTarget.getSecondaryContainers ? dropTarget.getSecondaryContainers() : null;\n const containers = [[dropTarget.getContainer()]];\n return secondaryContainers ? containers.concat(secondaryContainers) : containers;\n }\n allContainersIntersect(mouseEvent, containers) {\n for (const container of containers) {\n const rect = container.getBoundingClientRect();\n // if element is not visible, then width and height are zero\n if (rect.width === 0 || rect.height === 0) {\n return false;\n }\n const horizontalFit = mouseEvent.clientX >= rect.left && mouseEvent.clientX < rect.right;\n const verticalFit = mouseEvent.clientY >= rect.top && mouseEvent.clientY < rect.bottom;\n if (!horizontalFit || !verticalFit) {\n return false;\n }\n }\n return true;\n }\n // checks if the mouse is on the drop target. it checks eContainer and eSecondaryContainers\n isMouseOnDropTarget(mouseEvent, dropTarget) {\n const allContainersFromDropTarget = this.getAllContainersFromDropTarget(dropTarget);\n let mouseOverTarget = false;\n for (const currentContainers of allContainersFromDropTarget) {\n if (this.allContainersIntersect(mouseEvent, currentContainers)) {\n mouseOverTarget = true;\n break;\n }\n }\n if (dropTarget.targetContainsSource && !dropTarget.getContainer().contains(this.dragSource.eElement)) {\n return false;\n }\n return mouseOverTarget && dropTarget.isInterestedIn(this.dragSource.type, this.dragSource.eElement);\n }\n findCurrentDropTarget(mouseEvent, validDropTargets) {\n const len = validDropTargets.length;\n if (len === 0) {\n return null;\n }\n if (len === 1) {\n return validDropTargets[0];\n }\n const rootNode = this.gridOptionsService.getRootNode();\n // elementsFromPoint return a list of elements under\n // the mouseEvent sorted from topMost to bottomMost\n const elementStack = rootNode.elementsFromPoint(mouseEvent.clientX, mouseEvent.clientY);\n // loop over the sorted elementStack to find which dropTarget comes first\n for (const el of elementStack) {\n for (const dropTarget of validDropTargets) {\n const containers = flatten(this.getAllContainersFromDropTarget(dropTarget));\n if (containers.indexOf(el) !== -1) {\n return dropTarget;\n }\n }\n }\n // we should never hit this point of the code because only\n // valid dropTargets should be provided to this method.\n return null;\n }\n enterDragTargetIfExists(dropTarget, mouseEvent, hDirection, vDirection, fromNudge) {\n if (!dropTarget) {\n return;\n }\n if (dropTarget.onDragEnter) {\n const dragEnterEvent = this.createDropTargetEvent(dropTarget, mouseEvent, hDirection, vDirection, fromNudge);\n dropTarget.onDragEnter(dragEnterEvent);\n }\n this.setGhostIcon(dropTarget.getIconName ? dropTarget.getIconName() : null);\n }\n leaveLastTargetIfExists(mouseEvent, hDirection, vDirection, fromNudge) {\n if (!this.lastDropTarget) {\n return;\n }\n if (this.lastDropTarget.onDragLeave) {\n const dragLeaveEvent = this.createDropTargetEvent(this.lastDropTarget, mouseEvent, hDirection, vDirection, fromNudge);\n this.lastDropTarget.onDragLeave(dragLeaveEvent);\n }\n this.setGhostIcon(null);\n }\n addDropTarget(dropTarget) {\n this.dropTargets.push(dropTarget);\n }\n removeDropTarget(dropTarget) {\n this.dropTargets = this.dropTargets.filter(target => target.getContainer() !== dropTarget.getContainer());\n }\n hasExternalDropZones() {\n return this.dropTargets.some(zones => zones.external);\n }\n findExternalZone(params) {\n const externalTargets = this.dropTargets.filter(target => target.external);\n return externalTargets.find(zone => zone.getContainer() === params.getContainer()) || null;\n }\n getHorizontalDirection(event) {\n const clientX = this.eventLastTime && this.eventLastTime.clientX;\n const eClientX = event.clientX;\n if (clientX === eClientX) {\n return null;\n }\n return clientX > eClientX ? HorizontalDirection.Left : HorizontalDirection.Right;\n }\n getVerticalDirection(event) {\n const clientY = this.eventLastTime && this.eventLastTime.clientY;\n const eClientY = event.clientY;\n if (clientY === eClientY) {\n return null;\n }\n return clientY > eClientY ? VerticalDirection.Up : VerticalDirection.Down;\n }\n createDropTargetEvent(dropTarget, event, hDirection, vDirection, fromNudge) {\n // localise x and y to the target\n const dropZoneTarget = dropTarget.getContainer();\n const rect = dropZoneTarget.getBoundingClientRect();\n const { gridApi: api, columnApi, dragItem, dragSource } = this;\n const x = event.clientX - rect.left;\n const y = event.clientY - rect.top;\n return { event, x, y, vDirection, hDirection, dragSource, fromNudge, dragItem: dragItem, api, columnApi, dropZoneTarget };\n }\n positionGhost(event) {\n const ghost = this.eGhost;\n if (!ghost) {\n return;\n }\n const ghostRect = ghost.getBoundingClientRect();\n const ghostHeight = ghostRect.height;\n const browserWidth = getBodyWidth() - 2; // 2px for 1px borderLeft and 1px borderRight\n const browserHeight = getBodyHeight() - 2; // 2px for 1px borderTop and 1px borderBottom\n const offsetParentSize = getElementRectWithOffset(ghost.offsetParent);\n const { clientY, clientX } = event;\n let top = (clientY - offsetParentSize.top) - (ghostHeight / 2);\n let left = (clientX - offsetParentSize.left) - 10;\n const eDocument = this.gridOptionsService.getDocument();\n const win = (eDocument.defaultView || window);\n const windowScrollY = win.pageYOffset || eDocument.documentElement.scrollTop;\n const windowScrollX = win.pageXOffset || eDocument.documentElement.scrollLeft;\n // check ghost is not positioned outside of the browser\n if (browserWidth > 0 && ((left + ghost.clientWidth) > (browserWidth + windowScrollX))) {\n left = browserWidth + windowScrollX - ghost.clientWidth;\n }\n if (left < 0) {\n left = 0;\n }\n if (browserHeight > 0 && ((top + ghost.clientHeight) > (browserHeight + windowScrollY))) {\n top = browserHeight + windowScrollY - ghost.clientHeight;\n }\n if (top < 0) {\n top = 0;\n }\n ghost.style.left = `${left}px`;\n ghost.style.top = `${top}px`;\n }\n removeGhost() {\n if (this.eGhost && this.eGhostParent) {\n this.eGhostParent.removeChild(this.eGhost);\n }\n this.eGhost = null;\n }\n createGhost() {\n this.eGhost = loadTemplate(DragAndDropService_1.GHOST_TEMPLATE);\n this.mouseEventService.stampTopLevelGridCompWithGridInstance(this.eGhost);\n const { theme } = this.environment.getTheme();\n if (theme) {\n this.eGhost.classList.add(theme);\n }\n this.eGhostIcon = this.eGhost.querySelector('.ag-dnd-ghost-icon');\n this.setGhostIcon(null);\n const eText = this.eGhost.querySelector('.ag-dnd-ghost-label');\n let dragItemName = this.dragSource.dragItemName;\n if (isFunction(dragItemName)) {\n dragItemName = dragItemName();\n }\n eText.innerHTML = escapeString(dragItemName) || '';\n this.eGhost.style.height = '25px';\n this.eGhost.style.top = '20px';\n this.eGhost.style.left = '20px';\n const eDocument = this.gridOptionsService.getDocument();\n let targetEl = null;\n try {\n targetEl = eDocument.fullscreenElement;\n }\n catch (e) {\n // some environments like SalesForce will throw errors\n // simply by trying to read the fullscreenElement property\n }\n finally {\n if (!targetEl) {\n const rootNode = this.gridOptionsService.getRootNode();\n const body = rootNode.querySelector('body');\n if (body) {\n targetEl = body;\n }\n else if (rootNode instanceof ShadowRoot) {\n targetEl = rootNode;\n }\n else {\n targetEl = rootNode === null || rootNode === void 0 ? void 0 : rootNode.documentElement;\n }\n }\n }\n this.eGhostParent = targetEl;\n if (!this.eGhostParent) {\n console.warn('AG Grid: could not find document body, it is needed for dragging columns');\n }\n else {\n this.eGhostParent.appendChild(this.eGhost);\n }\n }\n setGhostIcon(iconName, shake = false) {\n clearElement(this.eGhostIcon);\n let eIcon = null;\n if (!iconName) {\n iconName = this.dragSource.getDefaultIconName ? this.dragSource.getDefaultIconName() : DragAndDropService_1.ICON_NOT_ALLOWED;\n }\n switch (iconName) {\n case DragAndDropService_1.ICON_PINNED:\n eIcon = this.ePinnedIcon;\n break;\n case DragAndDropService_1.ICON_MOVE:\n eIcon = this.eMoveIcon;\n break;\n case DragAndDropService_1.ICON_LEFT:\n eIcon = this.eLeftIcon;\n break;\n case DragAndDropService_1.ICON_RIGHT:\n eIcon = this.eRightIcon;\n break;\n case DragAndDropService_1.ICON_GROUP:\n eIcon = this.eGroupIcon;\n break;\n case DragAndDropService_1.ICON_AGGREGATE:\n eIcon = this.eAggregateIcon;\n break;\n case DragAndDropService_1.ICON_PIVOT:\n eIcon = this.ePivotIcon;\n break;\n case DragAndDropService_1.ICON_NOT_ALLOWED:\n eIcon = this.eDropNotAllowedIcon;\n break;\n case DragAndDropService_1.ICON_HIDE:\n eIcon = this.eHideIcon;\n break;\n }\n this.eGhostIcon.classList.toggle('ag-shake-left-to-right', shake);\n if (eIcon === this.eHideIcon && this.gridOptionsService.is('suppressDragLeaveHidesColumns')) {\n return;\n }\n if (eIcon) {\n this.eGhostIcon.appendChild(eIcon);\n }\n }\n};\nDragAndDropService.ICON_PINNED = 'pinned';\nDragAndDropService.ICON_MOVE = 'move';\nDragAndDropService.ICON_LEFT = 'left';\nDragAndDropService.ICON_RIGHT = 'right';\nDragAndDropService.ICON_GROUP = 'group';\nDragAndDropService.ICON_AGGREGATE = 'aggregate';\nDragAndDropService.ICON_PIVOT = 'pivot';\nDragAndDropService.ICON_NOT_ALLOWED = 'notAllowed';\nDragAndDropService.ICON_HIDE = 'hide';\nDragAndDropService.GHOST_TEMPLATE = `
\n \n
\n
`;\n__decorate([\n Autowired('dragService')\n], DragAndDropService.prototype, \"dragService\", void 0);\n__decorate([\n Autowired('mouseEventService')\n], DragAndDropService.prototype, \"mouseEventService\", void 0);\n__decorate([\n Autowired('columnApi')\n], DragAndDropService.prototype, \"columnApi\", void 0);\n__decorate([\n Autowired('gridApi')\n], DragAndDropService.prototype, \"gridApi\", void 0);\n__decorate([\n PostConstruct\n], DragAndDropService.prototype, \"init\", null);\n__decorate([\n PreDestroy\n], DragAndDropService.prototype, \"clearDragSourceParamsList\", null);\nDragAndDropService = DragAndDropService_1 = __decorate([\n Bean('dragAndDropService')\n], DragAndDropService);\nexport { DragAndDropService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from \"../../widgets/component.mjs\";\nimport { Autowired, PostConstruct, PreDestroy } from \"../../context/context.mjs\";\nimport { RowNode } from \"../../entities/rowNode.mjs\";\nimport { DragSourceType } from \"../../dragAndDrop/dragAndDropService.mjs\";\nimport { Events } from \"../../eventKeys.mjs\";\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nimport { createIconNoSpan } from \"../../utils/icon.mjs\";\nimport { doOnce, isFunction } from \"../../utils/function.mjs\";\nexport class RowDragComp extends Component {\n constructor(cellValueFn, rowNode, column, customGui, dragStartPixels, suppressVisibilityChange) {\n super();\n this.cellValueFn = cellValueFn;\n this.rowNode = rowNode;\n this.column = column;\n this.customGui = customGui;\n this.dragStartPixels = dragStartPixels;\n this.suppressVisibilityChange = suppressVisibilityChange;\n this.dragSource = null;\n }\n isCustomGui() {\n return this.customGui != null;\n }\n postConstruct() {\n if (!this.customGui) {\n this.setTemplate(/* html */ `
`);\n this.getGui().appendChild(createIconNoSpan('rowDrag', this.gridOptionsService, null));\n this.addDragSource();\n }\n else {\n this.setDragElement(this.customGui, this.dragStartPixels);\n }\n this.checkCompatibility();\n if (!this.suppressVisibilityChange) {\n const strategy = this.gridOptionsService.is('rowDragManaged') ?\n new ManagedVisibilityStrategy(this, this.beans, this.rowNode, this.column) :\n new NonManagedVisibilityStrategy(this, this.beans, this.rowNode, this.column);\n this.createManagedBean(strategy, this.beans.context);\n }\n }\n setDragElement(dragElement, dragStartPixels) {\n this.setTemplateFromElement(dragElement);\n this.addDragSource(dragStartPixels);\n }\n getSelectedNodes() {\n const isRowDragMultiRow = this.gridOptionsService.is('rowDragMultiRow');\n if (!isRowDragMultiRow) {\n return [this.rowNode];\n }\n const selection = this.beans.selectionService.getSelectedNodes();\n return selection.indexOf(this.rowNode) !== -1 ? selection : [this.rowNode];\n }\n // returns true if all compatibility items work out\n checkCompatibility() {\n const managed = this.gridOptionsService.is('rowDragManaged');\n const treeData = this.gridOptionsService.is('treeData');\n if (treeData && managed) {\n doOnce(() => console.warn('AG Grid: If using row drag with tree data, you cannot have rowDragManaged=true'), 'RowDragComp.managedAndTreeData');\n }\n }\n getDragItem() {\n return {\n rowNode: this.rowNode,\n rowNodes: this.getSelectedNodes(),\n columns: this.column ? [this.column] : undefined,\n defaultTextValue: this.cellValueFn(),\n };\n }\n getRowDragText(column) {\n if (column) {\n const colDef = column.getColDef();\n if (colDef.rowDragText) {\n return colDef.rowDragText;\n }\n }\n return this.gridOptionsService.get('rowDragText');\n }\n addDragSource(dragStartPixels = 4) {\n // if this is changing the drag element, delete the previous dragSource\n if (this.dragSource) {\n this.removeDragSource();\n }\n const rowDragText = this.getRowDragText(this.column);\n const translate = this.localeService.getLocaleTextFunc();\n this.dragSource = {\n type: DragSourceType.RowDrag,\n eElement: this.getGui(),\n dragItemName: () => {\n var _a;\n const dragItem = this.getDragItem();\n const dragItemCount = ((_a = dragItem.rowNodes) === null || _a === void 0 ? void 0 : _a.length) || 1;\n if (rowDragText) {\n return rowDragText(dragItem, dragItemCount);\n }\n return dragItemCount === 1 ? this.cellValueFn() : `${dragItemCount} ${translate('rowDragRows', 'rows')}`;\n },\n getDragItem: () => this.getDragItem(),\n dragStartPixels,\n dragSourceDomDataKey: this.gridOptionsService.getDomDataKey()\n };\n this.beans.dragAndDropService.addDragSource(this.dragSource, true);\n }\n removeDragSource() {\n if (this.dragSource) {\n this.beans.dragAndDropService.removeDragSource(this.dragSource);\n }\n this.dragSource = null;\n }\n}\n__decorate([\n Autowired('beans')\n], RowDragComp.prototype, \"beans\", void 0);\n__decorate([\n PostConstruct\n], RowDragComp.prototype, \"postConstruct\", null);\n__decorate([\n PreDestroy\n], RowDragComp.prototype, \"removeDragSource\", null);\nclass VisibilityStrategy extends BeanStub {\n constructor(parent, rowNode, column) {\n super();\n this.parent = parent;\n this.rowNode = rowNode;\n this.column = column;\n }\n setDisplayedOrVisible(neverDisplayed) {\n const displayedOptions = { skipAriaHidden: true };\n if (neverDisplayed) {\n this.parent.setDisplayed(false, displayedOptions);\n }\n else {\n let shown = true;\n let isShownSometimes = false;\n if (this.column) {\n shown = this.column.isRowDrag(this.rowNode) || this.parent.isCustomGui();\n isShownSometimes = isFunction(this.column.getColDef().rowDrag);\n }\n // if shown sometimes, them some rows can have drag handle while other don't,\n // so we use setVisible to keep the handles horizontally aligned (as setVisible\n // keeps the empty space, whereas setDisplayed looses the space)\n if (isShownSometimes) {\n this.parent.setDisplayed(true, displayedOptions);\n this.parent.setVisible(shown, displayedOptions);\n }\n else {\n this.parent.setDisplayed(shown, displayedOptions);\n this.parent.setVisible(true, displayedOptions);\n }\n }\n }\n}\n// when non managed, the visibility depends on suppressRowDrag property only\nclass NonManagedVisibilityStrategy extends VisibilityStrategy {\n constructor(parent, beans, rowNode, column) {\n super(parent, rowNode, column);\n this.beans = beans;\n }\n postConstruct() {\n this.addManagedPropertyListener('suppressRowDrag', this.onSuppressRowDrag.bind(this));\n // in case data changes, then we need to update visibility of drag item\n this.addManagedListener(this.rowNode, RowNode.EVENT_DATA_CHANGED, this.workOutVisibility.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_CELL_CHANGED, this.workOutVisibility.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_CELL_CHANGED, this.workOutVisibility.bind(this));\n this.addManagedListener(this.beans.eventService, Events.EVENT_NEW_COLUMNS_LOADED, this.workOutVisibility.bind(this));\n this.workOutVisibility();\n }\n onSuppressRowDrag() {\n this.workOutVisibility();\n }\n workOutVisibility() {\n // only show the drag if both sort and filter are not present\n const neverDisplayed = this.gridOptionsService.is('suppressRowDrag');\n this.setDisplayedOrVisible(neverDisplayed);\n }\n}\n__decorate([\n PostConstruct\n], NonManagedVisibilityStrategy.prototype, \"postConstruct\", null);\n// when managed, the visibility depends on sort, filter and row group, as well as suppressRowDrag property\nclass ManagedVisibilityStrategy extends VisibilityStrategy {\n constructor(parent, beans, rowNode, column) {\n super(parent, rowNode, column);\n this.beans = beans;\n }\n postConstruct() {\n // we do not show the component if sort, filter or grouping is active\n this.addManagedListener(this.beans.eventService, Events.EVENT_SORT_CHANGED, this.workOutVisibility.bind(this));\n this.addManagedListener(this.beans.eventService, Events.EVENT_FILTER_CHANGED, this.workOutVisibility.bind(this));\n this.addManagedListener(this.beans.eventService, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, this.workOutVisibility.bind(this));\n this.addManagedListener(this.beans.eventService, Events.EVENT_NEW_COLUMNS_LOADED, this.workOutVisibility.bind(this));\n // in case data changes, then we need to update visibility of drag item\n this.addManagedListener(this.rowNode, RowNode.EVENT_DATA_CHANGED, this.workOutVisibility.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_CELL_CHANGED, this.workOutVisibility.bind(this));\n this.addManagedPropertyListener('suppressRowDrag', this.onSuppressRowDrag.bind(this));\n this.workOutVisibility();\n }\n onSuppressRowDrag() {\n this.workOutVisibility();\n }\n workOutVisibility() {\n // only show the drag if both sort and filter are not present\n const gridBodyCon = this.beans.ctrlsService.getGridBodyCtrl();\n const rowDragFeature = gridBodyCon.getRowDragFeature();\n const shouldPreventRowMove = rowDragFeature && rowDragFeature.shouldPreventRowMove();\n const suppressRowDrag = this.gridOptionsService.is('suppressRowDrag');\n const hasExternalDropZones = this.beans.dragAndDropService.hasExternalDropZones();\n const neverDisplayed = (shouldPreventRowMove && !hasExternalDropZones) || suppressRowDrag;\n this.setDisplayedOrVisible(neverDisplayed);\n }\n}\n__decorate([\n PostConstruct\n], ManagedVisibilityStrategy.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { KeyCode } from \"../../constants/keyCode.mjs\";\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nimport { Autowired } from \"../../context/context.mjs\";\nimport { RowNode } from \"../../entities/rowNode.mjs\";\nimport { removeAriaExpanded, setAriaExpanded } from \"../../utils/aria.mjs\";\nimport { isElementInEventPath, isStopPropagationForAgGrid, stopPropagationForAgGrid } from \"../../utils/event.mjs\";\nimport { missing } from \"../../utils/generic.mjs\";\nimport { createIconNoSpan } from \"../../utils/icon.mjs\";\nimport { cloneObject } from \"../../utils/object.mjs\";\nimport { CheckboxSelectionComponent } from \"../checkboxSelectionComponent.mjs\";\nimport { RowDragComp } from \"../row/rowDragComp.mjs\";\nexport class GroupCellRendererCtrl extends BeanStub {\n init(comp, eGui, eCheckbox, eExpanded, eContracted, compClass, params) {\n this.params = params;\n this.eGui = eGui;\n this.eCheckbox = eCheckbox;\n this.eExpanded = eExpanded;\n this.eContracted = eContracted;\n this.comp = comp;\n this.compClass = compClass;\n const { node, value, colDef } = params;\n const topLevelFooter = this.isTopLevelFooter();\n // logic for skipping cells follows, never skip top level footer cell.\n if (!topLevelFooter) {\n const embeddedRowMismatch = this.isEmbeddedRowMismatch();\n if (embeddedRowMismatch) {\n return;\n }\n // when group column is multiple group columns, don't render for empty checkboxes\n // as UX becomes overloaded with empty cells including checkboxes.\n const isSingleGroupColumn = (colDef === null || colDef === void 0 ? void 0 : colDef.showRowGroup) === true;\n const isNullValueAndNotMaster = value == null && !node.master;\n if (!isSingleGroupColumn && isNullValueAndNotMaster) {\n return;\n }\n // this footer should only be non-top level. Don't need to check groupIncludeFooter\n // as we won't have footer rows in that instance.\n if (node.footer && this.gridOptionsService.is('groupHideOpenParents')) {\n const showRowGroup = colDef && colDef.showRowGroup;\n const rowGroupColumnId = node.rowGroupColumn && node.rowGroupColumn.getColId();\n // if the groupCellRenderer is inside of a footer and groupHideOpenParents is true\n // we should only display the groupCellRenderer if the current column is the rowGroupedColumn\n if (showRowGroup !== rowGroupColumnId) {\n return;\n }\n }\n }\n this.setupShowingValueForOpenedParent();\n this.findDisplayedGroupNode();\n this.addFullWidthRowDraggerIfNeeded();\n this.addExpandAndContract();\n this.addCheckboxIfNeeded();\n this.addValueElement();\n this.setupIndent();\n this.refreshAriaExpanded();\n }\n destroy() {\n super.destroy();\n // property cleanup to avoid memory leaks\n this.expandListener = null;\n }\n refreshAriaExpanded() {\n const { node, eParentOfValue } = this.params;\n if (this.expandListener) {\n this.expandListener = this.expandListener();\n }\n if (!this.isExpandable()) {\n removeAriaExpanded(eParentOfValue);\n return;\n }\n const listener = () => {\n // for react, we don't use JSX, as setting attributes via jsx is slower\n setAriaExpanded(eParentOfValue, !!node.expanded);\n };\n this.expandListener = this.addManagedListener(node, RowNode.EVENT_EXPANDED_CHANGED, listener) || null;\n listener();\n }\n isTopLevelFooter() {\n if (!this.gridOptionsService.is('groupIncludeTotalFooter')) {\n return false;\n }\n if (this.params.value != null || this.params.node.level != -1) {\n return false;\n }\n // at this point, we know it's the root node and there is no value present, so it's a footer cell.\n // the only thing to work out is if we are displaying groups across multiple\n // columns (groupDisplayType: 'multipleColumns'), we only want 'total' to appear in the first column.\n const colDef = this.params.colDef;\n const doingFullWidth = colDef == null;\n if (doingFullWidth) {\n return true;\n }\n if (colDef.showRowGroup === true) {\n return true;\n }\n const rowGroupCols = this.columnModel.getRowGroupColumns();\n // this is a sanity check, rowGroupCols should always be present\n if (!rowGroupCols || rowGroupCols.length === 0) {\n return true;\n }\n const firstRowGroupCol = rowGroupCols[0];\n return firstRowGroupCol.getId() === colDef.showRowGroup;\n }\n // if we are doing embedded full width rows, we only show the renderer when\n // in the body, or if pinning in the pinned section, or if pinning and RTL,\n // in the right section. otherwise we would have the cell repeated in each section.\n isEmbeddedRowMismatch() {\n if (!this.params.fullWidth || !this.gridOptionsService.is('embedFullWidthRows')) {\n return false;\n }\n const pinnedLeftCell = this.params.pinned === 'left';\n const pinnedRightCell = this.params.pinned === 'right';\n const bodyCell = !pinnedLeftCell && !pinnedRightCell;\n if (this.gridOptionsService.is('enableRtl')) {\n if (this.columnModel.isPinningLeft()) {\n return !pinnedRightCell;\n }\n return !bodyCell;\n }\n if (this.columnModel.isPinningLeft()) {\n return !pinnedLeftCell;\n }\n return !bodyCell;\n }\n findDisplayedGroupNode() {\n const column = this.params.column;\n const rowNode = this.params.node;\n if (this.showingValueForOpenedParent) {\n let pointer = rowNode.parent;\n while (pointer != null) {\n if (pointer.rowGroupColumn && column.isRowGroupDisplayed(pointer.rowGroupColumn.getId())) {\n this.displayedGroupNode = pointer;\n break;\n }\n pointer = pointer.parent;\n }\n }\n // if we didn't find a displayed group, set it to the row node\n if (missing(this.displayedGroupNode)) {\n this.displayedGroupNode = rowNode;\n }\n }\n setupShowingValueForOpenedParent() {\n // note - this code depends on sortService.updateGroupDataForHiddenOpenParents, where group data\n // is updated to reflect the dragged down parents\n const rowNode = this.params.node;\n const column = this.params.column;\n if (!this.gridOptionsService.is('groupHideOpenParents')) {\n this.showingValueForOpenedParent = false;\n return;\n }\n // hideOpenParents means rowNode.groupData can have data for the group this column is displaying, even though\n // this rowNode isn't grouping by the column we are displaying\n // if no groupData at all, we are not showing a parent value\n if (!rowNode.groupData) {\n this.showingValueForOpenedParent = false;\n return;\n }\n // this is the normal case, in that we are showing a group for which this column is configured. note that\n // this means the Row Group is closed (if it was open, we would not be displaying it)\n const showingGroupNode = rowNode.rowGroupColumn != null;\n if (showingGroupNode) {\n const keyOfGroupingColumn = rowNode.rowGroupColumn.getId();\n const configuredToShowThisGroupLevel = column.isRowGroupDisplayed(keyOfGroupingColumn);\n // if showing group as normal, we didn't take group info from parent\n if (configuredToShowThisGroupLevel) {\n this.showingValueForOpenedParent = false;\n return;\n }\n }\n // see if we are showing a Group Value for the Displayed Group. if we are showing a group value, and this Row Node\n // is not grouping by this Displayed Group, we must of gotten the value from a parent node\n const valPresent = rowNode.groupData[column.getId()] != null;\n this.showingValueForOpenedParent = valPresent;\n }\n addValueElement() {\n if (this.displayedGroupNode.footer) {\n this.addFooterValue();\n }\n else {\n this.addGroupValue();\n this.addChildCount();\n }\n }\n addGroupValue() {\n // we try and use the cellRenderer of the column used for the grouping if we can\n const paramsAdjusted = this.adjustParamsWithDetailsFromRelatedColumn();\n const innerCompDetails = this.getInnerCompDetails(paramsAdjusted);\n const { valueFormatted, value } = paramsAdjusted;\n let valueWhenNoRenderer = valueFormatted;\n if (valueWhenNoRenderer == null) {\n if (value === '' && this.params.node.group) {\n const localeTextFunc = this.localeService.getLocaleTextFunc();\n valueWhenNoRenderer = localeTextFunc('blanks', '(Blanks)');\n }\n else {\n valueWhenNoRenderer = value !== null && value !== void 0 ? value : null;\n }\n }\n this.comp.setInnerRenderer(innerCompDetails, valueWhenNoRenderer);\n }\n adjustParamsWithDetailsFromRelatedColumn() {\n const relatedColumn = this.displayedGroupNode.rowGroupColumn;\n const column = this.params.column;\n if (!relatedColumn) {\n return this.params;\n }\n const notFullWidth = column != null;\n if (notFullWidth) {\n const showingThisRowGroup = column.isRowGroupDisplayed(relatedColumn.getId());\n if (!showingThisRowGroup) {\n return this.params;\n }\n }\n const params = this.params;\n const { value, node } = this.params;\n const valueFormatted = this.valueFormatterService.formatValue(relatedColumn, node, value);\n // we don't update the original params, as they could of come through React,\n // as react has RowGroupCellRenderer, which means the params could be props which\n // would be read only\n const paramsAdjusted = Object.assign(Object.assign({}, params), { valueFormatted: valueFormatted });\n return paramsAdjusted;\n }\n addFooterValue() {\n const footerValueGetter = this.params.footerValueGetter;\n let footerValue = '';\n if (footerValueGetter) {\n // params is same as we were given, except we set the value as the item to display\n const paramsClone = cloneObject(this.params);\n paramsClone.value = this.params.value;\n if (typeof footerValueGetter === 'function') {\n footerValue = footerValueGetter(paramsClone);\n }\n else if (typeof footerValueGetter === 'string') {\n footerValue = this.expressionService.evaluate(footerValueGetter, paramsClone);\n }\n else {\n console.warn('AG Grid: footerValueGetter should be either a function or a string (expression)');\n }\n }\n else {\n footerValue = 'Total ' + (this.params.value != null ? this.params.value : '');\n }\n const innerCompDetails = this.getInnerCompDetails(this.params);\n this.comp.setInnerRenderer(innerCompDetails, footerValue);\n }\n getInnerCompDetails(params) {\n // for full width rows, we don't do any of the below\n if (params.fullWidth) {\n return this.userComponentFactory.getFullWidthGroupRowInnerCellRenderer(this.gridOptionsService.get('groupRowRendererParams'), params);\n }\n // when grouping, the normal case is we use the cell renderer of the grouped column. eg if grouping by country\n // and then rating, we will use the country cell renderer for each country group row and likewise the rating\n // cell renderer for each rating group row.\n //\n // however if the user has innerCellRenderer defined, this gets preference and we don't use cell renderers\n // of the grouped columns.\n //\n // so we check and use in the following order:\n //\n // 1) thisColDef.cellRendererParams.innerRenderer of the column showing the groups (eg auto group column)\n // 2) groupedColDef.cellRenderer of the grouped column\n // 3) groupedColDef.cellRendererParams.innerRenderer\n // we check if cell renderer provided for the group cell renderer, eg colDef.cellRendererParams.innerRenderer\n const innerCompDetails = this.userComponentFactory\n .getInnerRendererDetails(params, params);\n // avoid using GroupCellRenderer again, otherwise stack overflow, as we insert same renderer again and again.\n // this covers off chance user is grouping by a column that is also configured with GroupCellRenderer\n const isGroupRowRenderer = (details) => details && details.componentClass == this.compClass;\n if (innerCompDetails && !isGroupRowRenderer(innerCompDetails)) {\n // use the renderer defined in cellRendererParams.innerRenderer\n return innerCompDetails;\n }\n const relatedColumn = this.displayedGroupNode.rowGroupColumn;\n const relatedColDef = relatedColumn ? relatedColumn.getColDef() : undefined;\n if (!relatedColDef) {\n return;\n }\n // otherwise see if we can use the cellRenderer of the column we are grouping by\n const relatedCompDetails = this.userComponentFactory\n .getCellRendererDetails(relatedColDef, params);\n if (relatedCompDetails && !isGroupRowRenderer(relatedCompDetails)) {\n // Only if the original column is using a specific renderer, it it is a using a DEFAULT one ignore it\n return relatedCompDetails;\n }\n if (isGroupRowRenderer(relatedCompDetails) &&\n relatedColDef.cellRendererParams &&\n relatedColDef.cellRendererParams.innerRenderer) {\n // edge case - this comes from a column which has been grouped dynamically, that has a renderer 'group'\n // and has an inner cell renderer\n const res = this.userComponentFactory.getInnerRendererDetails(relatedColDef.cellRendererParams, params);\n return res;\n }\n }\n addChildCount() {\n // only include the child count if it's included, eg if user doing custom aggregation,\n // then this could be left out, or set to -1, ie no child count\n if (this.params.suppressCount) {\n return;\n }\n this.addManagedListener(this.displayedGroupNode, RowNode.EVENT_ALL_CHILDREN_COUNT_CHANGED, this.updateChildCount.bind(this));\n // filtering changes the child count, so need to cater for it\n this.updateChildCount();\n }\n updateChildCount() {\n const allChildrenCount = this.displayedGroupNode.allChildrenCount;\n const showingGroupForThisNode = this.isShowRowGroupForThisRow();\n const showCount = showingGroupForThisNode && allChildrenCount != null && allChildrenCount >= 0;\n const countString = showCount ? `(${allChildrenCount})` : ``;\n this.comp.setChildCount(countString);\n }\n isShowRowGroupForThisRow() {\n if (this.gridOptionsService.is('treeData')) {\n return true;\n }\n const rowGroupColumn = this.displayedGroupNode.rowGroupColumn;\n if (!rowGroupColumn) {\n return false;\n }\n // column is null for fullWidthRows\n const column = this.params.column;\n const thisColumnIsInterested = column == null || column.isRowGroupDisplayed(rowGroupColumn.getId());\n return thisColumnIsInterested;\n }\n addExpandAndContract() {\n var _a;\n const params = this.params;\n const eExpandedIcon = createIconNoSpan('groupExpanded', this.gridOptionsService, null);\n const eContractedIcon = createIconNoSpan('groupContracted', this.gridOptionsService, null);\n if (eExpandedIcon) {\n this.eExpanded.appendChild(eExpandedIcon);\n }\n if (eContractedIcon) {\n this.eContracted.appendChild(eContractedIcon);\n }\n const eGroupCell = params.eGridCell;\n // if editing groups, then double click is to start editing\n const isDoubleClickEdit = ((_a = this.params.column) === null || _a === void 0 ? void 0 : _a.isCellEditable(params.node)) && this.gridOptionsService.is('enableGroupEdit');\n if (!isDoubleClickEdit && this.isExpandable() && !params.suppressDoubleClickExpand) {\n this.addManagedListener(eGroupCell, 'dblclick', this.onCellDblClicked.bind(this));\n }\n this.addManagedListener(this.eExpanded, 'click', this.onExpandClicked.bind(this));\n this.addManagedListener(this.eContracted, 'click', this.onExpandClicked.bind(this));\n // expand / contract as the user hits enter\n this.addManagedListener(eGroupCell, 'keydown', this.onKeyDown.bind(this));\n this.addManagedListener(params.node, RowNode.EVENT_EXPANDED_CHANGED, this.showExpandAndContractIcons.bind(this));\n this.showExpandAndContractIcons();\n // because we don't show the expand / contract when there are no children, we need to check every time\n // the number of children change.\n const expandableChangedListener = this.onRowNodeIsExpandableChanged.bind(this);\n this.addManagedListener(this.displayedGroupNode, RowNode.EVENT_ALL_CHILDREN_COUNT_CHANGED, expandableChangedListener);\n this.addManagedListener(this.displayedGroupNode, RowNode.EVENT_MASTER_CHANGED, expandableChangedListener);\n this.addManagedListener(this.displayedGroupNode, RowNode.EVENT_GROUP_CHANGED, expandableChangedListener);\n this.addManagedListener(this.displayedGroupNode, RowNode.EVENT_HAS_CHILDREN_CHANGED, expandableChangedListener);\n }\n onExpandClicked(mouseEvent) {\n if (isStopPropagationForAgGrid(mouseEvent)) {\n return;\n }\n // so if we expand a node, it does not also get selected.\n stopPropagationForAgGrid(mouseEvent);\n this.onExpandOrContract(mouseEvent);\n }\n onExpandOrContract(e) {\n // must use the displayedGroup, so if data was dragged down, we expand the parent, not this row\n const rowNode = this.displayedGroupNode;\n const nextExpandState = !rowNode.expanded;\n if (!nextExpandState && rowNode.sticky) {\n this.scrollToStickyNode(rowNode);\n }\n rowNode.setExpanded(nextExpandState, e);\n }\n scrollToStickyNode(rowNode) {\n const gridBodyCtrl = this.ctrlsService.getGridBodyCtrl();\n const scrollFeature = gridBodyCtrl.getScrollFeature();\n scrollFeature.setVerticalScrollPosition(rowNode.rowTop - rowNode.stickyRowTop);\n }\n isExpandable() {\n if (this.showingValueForOpenedParent) {\n return true;\n }\n const rowNode = this.displayedGroupNode;\n const reducedLeafNode = this.columnModel.isPivotMode() && rowNode.leafGroup;\n const expandableGroup = rowNode.isExpandable() && !rowNode.footer && !reducedLeafNode;\n if (!expandableGroup) {\n return false;\n }\n // column is null for fullWidthRows\n const column = this.params.column;\n const displayingForOneColumnOnly = column != null && typeof column.getColDef().showRowGroup === 'string';\n if (displayingForOneColumnOnly) {\n const showing = this.isShowRowGroupForThisRow();\n return showing;\n }\n return true;\n }\n showExpandAndContractIcons() {\n const { params, displayedGroupNode: displayedGroup, columnModel } = this;\n const { node } = params;\n const isExpandable = this.isExpandable();\n if (isExpandable) {\n // if expandable, show one based on expand state.\n // if we were dragged down, means our parent is always expanded\n const expanded = this.showingValueForOpenedParent ? true : node.expanded;\n this.comp.setExpandedDisplayed(expanded);\n this.comp.setContractedDisplayed(!expanded);\n }\n else {\n // it not expandable, show neither\n this.comp.setExpandedDisplayed(false);\n this.comp.setContractedDisplayed(false);\n }\n // compensation padding for leaf nodes, so there is blank space instead of the expand icon\n const pivotMode = columnModel.isPivotMode();\n const pivotModeAndLeafGroup = pivotMode && displayedGroup.leafGroup;\n const addExpandableCss = isExpandable && !pivotModeAndLeafGroup;\n const isTotalFooterNode = node.footer && node.level === -1;\n this.comp.addOrRemoveCssClass('ag-cell-expandable', addExpandableCss);\n this.comp.addOrRemoveCssClass('ag-row-group', addExpandableCss);\n if (pivotMode) {\n this.comp.addOrRemoveCssClass('ag-pivot-leaf-group', pivotModeAndLeafGroup);\n }\n else if (!isTotalFooterNode) {\n this.comp.addOrRemoveCssClass('ag-row-group-leaf-indent', !addExpandableCss);\n }\n }\n onRowNodeIsExpandableChanged() {\n // maybe if no children now, we should hide the expand / contract icons\n this.showExpandAndContractIcons();\n // if we have no children, this impacts the indent\n this.setIndent();\n this.refreshAriaExpanded();\n }\n setupIndent() {\n // only do this if an indent - as this overwrites the padding that\n // the theme set, which will make things look 'not aligned' for the\n // first group level.\n const node = this.params.node;\n const suppressPadding = this.params.suppressPadding;\n if (!suppressPadding) {\n this.addManagedListener(node, RowNode.EVENT_UI_LEVEL_CHANGED, this.setIndent.bind(this));\n this.setIndent();\n }\n }\n setIndent() {\n if (this.gridOptionsService.is('groupHideOpenParents')) {\n return;\n }\n const params = this.params;\n const rowNode = params.node;\n // if we are only showing one group column, we don't want to be indenting based on level\n const fullWithRow = !!params.colDef;\n const treeData = this.gridOptionsService.is('treeData');\n const manyDimensionThisColumn = !fullWithRow || treeData || params.colDef.showRowGroup === true;\n const paddingCount = manyDimensionThisColumn ? rowNode.uiLevel : 0;\n if (this.indentClass) {\n this.comp.addOrRemoveCssClass(this.indentClass, false);\n }\n this.indentClass = 'ag-row-group-indent-' + paddingCount;\n this.comp.addOrRemoveCssClass(this.indentClass, true);\n }\n addFullWidthRowDraggerIfNeeded() {\n if (!this.params.fullWidth || !this.params.rowDrag) {\n return;\n }\n const rowDragComp = new RowDragComp(() => this.params.value, this.params.node);\n this.createManagedBean(rowDragComp, this.context);\n this.eGui.insertAdjacentElement('afterbegin', rowDragComp.getGui());\n }\n isUserWantsSelected() {\n const paramsCheckbox = this.params.checkbox;\n // if a function, we always return true as change detection can show or hide the checkbox.\n return typeof paramsCheckbox === 'function' || paramsCheckbox === true;\n }\n addCheckboxIfNeeded() {\n const rowNode = this.displayedGroupNode;\n const checkboxNeeded = this.isUserWantsSelected() &&\n // footers cannot be selected\n !rowNode.footer &&\n // pinned rows cannot be selected\n !rowNode.rowPinned &&\n // details cannot be selected\n !rowNode.detail;\n if (checkboxNeeded) {\n const cbSelectionComponent = new CheckboxSelectionComponent();\n this.getContext().createBean(cbSelectionComponent);\n cbSelectionComponent.init({\n rowNode: this.params.node,\n column: this.params.column,\n overrides: {\n isVisible: this.params.checkbox,\n callbackParams: this.params,\n removeHidden: true,\n },\n });\n this.eCheckbox.appendChild(cbSelectionComponent.getGui());\n this.addDestroyFunc(() => this.getContext().destroyBean(cbSelectionComponent));\n }\n this.comp.setCheckboxVisible(checkboxNeeded);\n }\n onKeyDown(event) {\n const isEnterKey = event.key === KeyCode.ENTER;\n if (!isEnterKey || this.params.suppressEnterExpand) {\n return;\n }\n const cellEditable = this.params.column && this.params.column.isCellEditable(this.params.node);\n if (cellEditable) {\n return;\n }\n this.onExpandOrContract(event);\n }\n onCellDblClicked(mouseEvent) {\n if (isStopPropagationForAgGrid(mouseEvent)) {\n return;\n }\n // we want to avoid acting on double click events on the expand / contract icon,\n // as that icons already has expand / collapse functionality on it. otherwise if\n // the icon was double clicked, we would get 'click', 'click', 'dblclick' which\n // is open->close->open, however double click should be open->close only.\n const targetIsExpandIcon = isElementInEventPath(this.eExpanded, mouseEvent)\n || isElementInEventPath(this.eContracted, mouseEvent);\n if (!targetIsExpandIcon) {\n this.onExpandOrContract(mouseEvent);\n }\n }\n}\n__decorate([\n Autowired('expressionService')\n], GroupCellRendererCtrl.prototype, \"expressionService\", void 0);\n__decorate([\n Autowired('valueFormatterService')\n], GroupCellRendererCtrl.prototype, \"valueFormatterService\", void 0);\n__decorate([\n Autowired('columnModel')\n], GroupCellRendererCtrl.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('userComponentFactory')\n], GroupCellRendererCtrl.prototype, \"userComponentFactory\", void 0);\n__decorate([\n Autowired(\"ctrlsService\")\n], GroupCellRendererCtrl.prototype, \"ctrlsService\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { setAriaRole } from \"../../utils/aria.mjs\";\nimport { setDisplayed } from \"../../utils/dom.mjs\";\nimport { Component } from \"../../widgets/component.mjs\";\nimport { RefSelector } from \"../../widgets/componentAnnotations.mjs\";\nimport { GroupCellRendererCtrl } from \"./groupCellRendererCtrl.mjs\";\nexport class GroupCellRenderer extends Component {\n constructor() {\n super(GroupCellRenderer.TEMPLATE);\n }\n init(params) {\n const compProxy = {\n setInnerRenderer: (compDetails, valueToDisplay) => this.setRenderDetails(compDetails, valueToDisplay),\n setChildCount: count => this.eChildCount.innerHTML = count,\n addOrRemoveCssClass: (cssClass, value) => this.addOrRemoveCssClass(cssClass, value),\n setContractedDisplayed: expanded => setDisplayed(this.eContracted, expanded),\n setExpandedDisplayed: expanded => setDisplayed(this.eExpanded, expanded),\n setCheckboxVisible: visible => this.eCheckbox.classList.toggle('ag-invisible', !visible)\n };\n const ctrl = this.createManagedBean(new GroupCellRendererCtrl());\n const fullWidth = !params.colDef;\n const eGui = this.getGui();\n ctrl.init(compProxy, eGui, this.eCheckbox, this.eExpanded, this.eContracted, this.constructor, params);\n if (fullWidth) {\n setAriaRole(eGui, 'gridcell');\n }\n }\n setRenderDetails(compDetails, valueToDisplay) {\n if (compDetails) {\n const componentPromise = compDetails.newAgStackInstance();\n if (!componentPromise) {\n return;\n }\n componentPromise.then(comp => {\n if (!comp) {\n return;\n }\n const destroyComp = () => this.context.destroyBean(comp);\n if (this.isAlive()) {\n this.eValue.appendChild(comp.getGui());\n this.addDestroyFunc(destroyComp);\n }\n else {\n destroyComp();\n }\n });\n }\n else {\n this.eValue.innerText = valueToDisplay;\n }\n }\n // this is a user component, and IComponent has \"public destroy()\" as part of the interface.\n // so we need to have public here instead of private or protected\n destroy() {\n this.getContext().destroyBean(this.innerCellRenderer);\n super.destroy();\n }\n refresh() {\n return false;\n }\n}\nGroupCellRenderer.TEMPLATE = `\n \n \n \n \n \n `;\n__decorate([\n RefSelector('eExpanded')\n], GroupCellRenderer.prototype, \"eExpanded\", void 0);\n__decorate([\n RefSelector('eContracted')\n], GroupCellRenderer.prototype, \"eContracted\", void 0);\n__decorate([\n RefSelector('eCheckbox')\n], GroupCellRenderer.prototype, \"eCheckbox\", void 0);\n__decorate([\n RefSelector('eValue')\n], GroupCellRenderer.prototype, \"eValue\", void 0);\n__decorate([\n RefSelector('eChildCount')\n], GroupCellRenderer.prototype, \"eChildCount\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from \"../../widgets/component.mjs\";\nimport { RefSelector } from \"../../widgets/componentAnnotations.mjs\";\nimport { createIconNoSpan } from \"../../utils/icon.mjs\";\nexport class LoadingCellRenderer extends Component {\n constructor() {\n super(LoadingCellRenderer.TEMPLATE);\n }\n init(params) {\n params.node.failedLoad ? this.setupFailed() : this.setupLoading();\n }\n setupFailed() {\n const localeTextFunc = this.localeService.getLocaleTextFunc();\n this.eLoadingText.innerText = localeTextFunc('loadingError', 'ERR');\n }\n setupLoading() {\n const eLoadingIcon = createIconNoSpan('groupLoading', this.gridOptionsService, null);\n if (eLoadingIcon) {\n this.eLoadingIcon.appendChild(eLoadingIcon);\n }\n const localeTextFunc = this.localeService.getLocaleTextFunc();\n this.eLoadingText.innerText = localeTextFunc('loadingOoo', 'Loading');\n }\n refresh(params) {\n return false;\n }\n // this is a user component, and IComponent has \"public destroy()\" as part of the interface.\n // so we need to override destroy() just to make the method public.\n destroy() {\n super.destroy();\n }\n}\nLoadingCellRenderer.TEMPLATE = `
\n \n \n
`;\n__decorate([\n RefSelector('eLoadingIcon')\n], LoadingCellRenderer.prototype, \"eLoadingIcon\", void 0);\n__decorate([\n RefSelector('eLoadingText')\n], LoadingCellRenderer.prototype, \"eLoadingText\", void 0);\n","import { Component } from \"../../widgets/component.mjs\";\nexport class LoadingOverlayComponent extends Component {\n constructor() {\n super();\n }\n // this is a user component, and IComponent has \"public destroy()\" as part of the interface.\n // so we need to override destroy() just to make the method public.\n destroy() {\n super.destroy();\n }\n init(params) {\n var _a;\n const template = (_a = this.gridOptionsService.get('overlayLoadingTemplate')) !== null && _a !== void 0 ? _a : LoadingOverlayComponent.DEFAULT_LOADING_OVERLAY_TEMPLATE;\n const localeTextFunc = this.localeService.getLocaleTextFunc();\n const localisedTemplate = template.replace('[LOADING...]', localeTextFunc('loadingOoo', 'Loading...'));\n this.setTemplate(localisedTemplate);\n }\n}\nLoadingOverlayComponent.DEFAULT_LOADING_OVERLAY_TEMPLATE = '[LOADING...]';\n","import { Component } from \"../../widgets/component.mjs\";\nexport class NoRowsOverlayComponent extends Component {\n constructor() {\n super();\n }\n // this is a user component, and IComponent has \"public destroy()\" as part of the interface.\n // so we need to override destroy() just to make the method public.\n destroy() {\n super.destroy();\n }\n init(params) {\n var _a;\n const template = (_a = this.gridOptionsService.get('overlayNoRowsTemplate')) !== null && _a !== void 0 ? _a : NoRowsOverlayComponent.DEFAULT_NO_ROWS_TEMPLATE;\n const localeTextFunc = this.localeService.getLocaleTextFunc();\n const localisedTemplate = template.replace('[NO_ROWS_TO_SHOW]', localeTextFunc('noRowsToShow', 'No Rows To Show'));\n this.setTemplate(localisedTemplate);\n }\n}\nNoRowsOverlayComponent.DEFAULT_NO_ROWS_TEMPLATE = '[NO_ROWS_TO_SHOW]';\n","import { PopupComponent } from '../widgets/popupComponent.mjs';\nimport { escapeString } from '../utils/string.mjs';\nexport class TooltipComponent extends PopupComponent {\n constructor() {\n super(/* html */ `
`);\n }\n // will need to type params\n init(params) {\n const { value } = params;\n this.getGui().innerHTML = escapeString(value);\n }\n}\n","import { SimpleCellEditor } from \"./simpleCellEditor.mjs\";\nimport { exists } from \"../../utils/generic.mjs\";\nclass NumberCellEditorInput {\n getTemplate() {\n return /* html */ ``;\n }\n init(eInput, params) {\n this.eInput = eInput;\n this.params = params;\n if (params.max != null) {\n eInput.setMax(params.max);\n }\n if (params.min != null) {\n eInput.setMin(params.min);\n }\n if (params.precision != null) {\n eInput.setPrecision(params.precision);\n }\n if (params.step != null) {\n eInput.setStep(params.step);\n }\n if (params.showStepperButtons) {\n eInput.getInputElement().classList.add('ag-number-field-input-stepper');\n }\n }\n getValue() {\n const value = this.eInput.getValue();\n if (!exists(value) && !exists(this.params.value)) {\n return this.params.value;\n }\n let parsedValue = this.params.parseValue(value);\n if (parsedValue == null) {\n return parsedValue;\n }\n if (typeof parsedValue === 'string') {\n if (parsedValue === '') {\n return null;\n }\n parsedValue = Number(parsedValue);\n }\n return isNaN(parsedValue) ? null : parsedValue;\n }\n getStartValue() {\n return this.params.value;\n }\n}\nexport class NumberCellEditor extends SimpleCellEditor {\n constructor() {\n super(new NumberCellEditorInput());\n }\n}\n","import { serialiseDate } from \"../../utils/date.mjs\";\nimport { SimpleCellEditor } from \"./simpleCellEditor.mjs\";\nimport { exists } from \"../../utils/generic.mjs\";\nclass DateCellEditorInput {\n getTemplate() {\n return /* html */ ``;\n }\n init(eInput, params) {\n this.eInput = eInput;\n this.params = params;\n if (params.min != null) {\n eInput.setMin(params.min);\n }\n if (params.max != null) {\n eInput.setMax(params.max);\n }\n if (params.step != null) {\n eInput.setStep(params.step);\n }\n }\n getValue() {\n const value = this.eInput.getDate();\n if (!exists(value) && !exists(this.params.value)) {\n return this.params.value;\n }\n return value !== null && value !== void 0 ? value : null;\n }\n getStartValue() {\n const { value } = this.params;\n if (!(value instanceof Date)) {\n return undefined;\n }\n return serialiseDate(value, false);\n }\n}\nexport class DateCellEditor extends SimpleCellEditor {\n constructor() {\n super(new DateCellEditorInput());\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired } from \"../../context/context.mjs\";\nimport { serialiseDate } from \"../../utils/date.mjs\";\nimport { SimpleCellEditor } from \"./simpleCellEditor.mjs\";\nimport { exists } from \"../../utils/generic.mjs\";\nclass DateStringCellEditorInput {\n constructor(getDataTypeService) {\n this.getDataTypeService = getDataTypeService;\n }\n getTemplate() {\n return /* html */ ``;\n }\n init(eInput, params) {\n this.eInput = eInput;\n this.params = params;\n if (params.min != null) {\n eInput.setMin(params.min);\n }\n if (params.max != null) {\n eInput.setMax(params.max);\n }\n if (params.step != null) {\n eInput.setStep(params.step);\n }\n }\n getValue() {\n const value = this.formatDate(this.eInput.getDate());\n if (!exists(value) && !exists(this.params.value)) {\n return this.params.value;\n }\n return this.params.parseValue(value !== null && value !== void 0 ? value : '');\n }\n getStartValue() {\n var _a, _b;\n return serialiseDate((_b = this.parseDate((_a = this.params.value) !== null && _a !== void 0 ? _a : undefined)) !== null && _b !== void 0 ? _b : null, false);\n }\n parseDate(value) {\n return this.getDataTypeService().getDateParserFunction()(value);\n }\n formatDate(value) {\n return this.getDataTypeService().getDateFormatterFunction()(value);\n }\n}\nexport class DateStringCellEditor extends SimpleCellEditor {\n constructor() {\n super(new DateStringCellEditorInput(() => this.dataTypeService));\n }\n}\n__decorate([\n Autowired('dataTypeService')\n], DateStringCellEditor.prototype, \"dataTypeService\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from \"../../widgets/component.mjs\";\nimport { RefSelector } from \"../../widgets/componentAnnotations.mjs\";\nimport { stopPropagationForAgGrid } from \"../../utils/event.mjs\";\nimport { Events } from \"../../events.mjs\";\nimport { KeyCode } from \"../../constants/keyCode.mjs\";\nimport { getAriaCheckboxStateName } from \"../../utils/aria.mjs\";\nimport { GROUP_AUTO_COLUMN_ID } from \"../../columns/autoGroupColService.mjs\";\nexport class CheckboxCellRenderer extends Component {\n constructor() {\n super(CheckboxCellRenderer.TEMPLATE);\n }\n init(params) {\n this.params = params;\n this.updateCheckbox(params);\n this.eCheckbox.getInputElement().setAttribute('tabindex', '-1');\n this.addManagedListener(this.eCheckbox.getInputElement(), 'click', (event) => {\n stopPropagationForAgGrid(event);\n if (this.eCheckbox.isDisabled()) {\n return;\n }\n const isSelected = this.eCheckbox.getValue();\n this.onCheckboxChanged(isSelected);\n });\n this.addManagedListener(this.eCheckbox.getInputElement(), 'dblclick', (event) => {\n stopPropagationForAgGrid(event);\n });\n const eDocument = this.gridOptionsService.getDocument();\n this.addManagedListener(this.params.eGridCell, 'keydown', (event) => {\n if (event.key === KeyCode.SPACE && !this.eCheckbox.isDisabled()) {\n if (this.params.eGridCell === eDocument.activeElement) {\n this.eCheckbox.toggle();\n }\n const isSelected = this.eCheckbox.getValue();\n this.onCheckboxChanged(isSelected);\n event.preventDefault();\n }\n });\n }\n refresh(params) {\n this.params = params;\n this.updateCheckbox(params);\n return true;\n }\n updateCheckbox(params) {\n var _a, _b, _c;\n let isSelected;\n let displayed = true;\n if (params.node.group && params.column) {\n const colId = params.column.getColId();\n if (colId.startsWith(GROUP_AUTO_COLUMN_ID)) {\n // if we're grouping by this column then the value is a string and we need to parse it\n isSelected = params.value == null || params.value === '' ? undefined : params.value === 'true';\n }\n else if (params.node.aggData && params.node.aggData[colId] !== undefined) {\n isSelected = (_a = params.value) !== null && _a !== void 0 ? _a : undefined;\n }\n else {\n displayed = false;\n }\n }\n else {\n isSelected = (_b = params.value) !== null && _b !== void 0 ? _b : undefined;\n }\n if (!displayed) {\n this.eCheckbox.setDisplayed(false);\n return;\n }\n this.eCheckbox.setValue(isSelected);\n const disabled = params.disabled != null ? params.disabled : !((_c = params.column) === null || _c === void 0 ? void 0 : _c.isCellEditable(params.node));\n this.eCheckbox.setDisabled(disabled);\n const translate = this.localeService.getLocaleTextFunc();\n const stateName = getAriaCheckboxStateName(translate, isSelected);\n const ariaLabel = disabled\n ? stateName\n : `${translate('ariaToggleCellValue', 'Press SPACE to toggle cell value')} (${stateName})`;\n this.eCheckbox.setInputAriaLabel(ariaLabel);\n }\n onCheckboxChanged(isSelected) {\n const { column, node, rowIndex, value } = this.params;\n const eventStarted = {\n type: Events.EVENT_CELL_EDITING_STARTED,\n column: column,\n colDef: column === null || column === void 0 ? void 0 : column.getColDef(),\n data: node.data,\n node,\n rowIndex,\n rowPinned: node.rowPinned,\n value\n };\n this.eventService.dispatchEvent(eventStarted);\n const valueChanged = this.params.node.setDataValue(this.params.column, isSelected, 'edit');\n const eventStopped = {\n type: Events.EVENT_CELL_EDITING_STOPPED,\n column: column,\n colDef: column === null || column === void 0 ? void 0 : column.getColDef(),\n data: node.data,\n node,\n rowIndex,\n rowPinned: node.rowPinned,\n value,\n oldValue: value,\n newValue: isSelected,\n valueChanged\n };\n this.eventService.dispatchEvent(eventStopped);\n }\n}\nCheckboxCellRenderer.TEMPLATE = `\n
\n \n
`;\n__decorate([\n RefSelector('eCheckbox')\n], CheckboxCellRenderer.prototype, \"eCheckbox\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PopupComponent } from \"../../widgets/popupComponent.mjs\";\nimport { RefSelector } from \"../../widgets/componentAnnotations.mjs\";\nimport { getAriaCheckboxStateName } from \"../../utils/aria.mjs\";\nimport { Events } from \"../../eventKeys.mjs\";\nexport class CheckboxCellEditor extends PopupComponent {\n constructor() {\n super(/* html */ `\n
\n \n
`);\n }\n init(params) {\n var _a;\n this.params = params;\n const isSelected = (_a = params.value) !== null && _a !== void 0 ? _a : undefined;\n this.eCheckbox.setValue(isSelected);\n this.eCheckbox.getInputElement().setAttribute('tabindex', '-1');\n this.setAriaLabel(isSelected);\n this.addManagedListener(this.eCheckbox, Events.EVENT_FIELD_VALUE_CHANGED, (event) => this.setAriaLabel(event.selected));\n }\n getValue() {\n return this.eCheckbox.getValue();\n }\n focusIn() {\n this.eCheckbox.getFocusableElement().focus();\n }\n afterGuiAttached() {\n if (this.params.cellStartedEdit) {\n this.focusIn();\n }\n }\n isPopup() {\n return false;\n }\n setAriaLabel(isSelected) {\n const translate = this.localeService.getLocaleTextFunc();\n const stateName = getAriaCheckboxStateName(translate, isSelected);\n const ariaLabel = translate('ariaToggleCellValue', 'Press SPACE to toggle cell value');\n this.eCheckbox.setInputAriaLabel(`${ariaLabel} (${stateName})`);\n }\n}\n__decorate([\n RefSelector('eCheckbox')\n], CheckboxCellEditor.prototype, \"eCheckbox\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nimport { Autowired, Bean, PostConstruct } from \"../../context/context.mjs\";\nimport { ReadOnlyFloatingFilter } from \"../../filter/floating/provided/readOnlyFloatingFilter.mjs\";\nimport { DateFilter } from \"../../filter/provided/date/dateFilter.mjs\";\nimport { DateFloatingFilter } from \"../../filter/provided/date/dateFloatingFilter.mjs\";\nimport { DefaultDateComponent } from \"../../filter/provided/date/defaultDateComponent.mjs\";\nimport { NumberFilter } from \"../../filter/provided/number/numberFilter.mjs\";\nimport { NumberFloatingFilter } from \"../../filter/provided/number/numberFloatingFilter.mjs\";\nimport { TextFilter } from \"../../filter/provided/text/textFilter.mjs\";\nimport { TextFloatingFilter } from \"../../filter/provided/text/textFloatingFilter.mjs\";\nimport { HeaderComp } from \"../../headerRendering/cells/column/headerComp.mjs\";\nimport { SortIndicatorComp } from \"../../headerRendering/cells/column/sortIndicatorComp.mjs\";\nimport { HeaderGroupComp } from \"../../headerRendering/cells/columnGroup/headerGroupComp.mjs\";\nimport { ModuleNames } from \"../../modules/moduleNames.mjs\";\nimport { ModuleRegistry } from \"../../modules/moduleRegistry.mjs\";\nimport { LargeTextCellEditor } from \"../../rendering/cellEditors/largeTextCellEditor.mjs\";\nimport { SelectCellEditor } from \"../../rendering/cellEditors/selectCellEditor.mjs\";\nimport { TextCellEditor } from \"../../rendering/cellEditors/textCellEditor.mjs\";\nimport { AnimateShowChangeCellRenderer } from \"../../rendering/cellRenderers/animateShowChangeCellRenderer.mjs\";\nimport { AnimateSlideCellRenderer } from \"../../rendering/cellRenderers/animateSlideCellRenderer.mjs\";\nimport { GroupCellRenderer } from \"../../rendering/cellRenderers/groupCellRenderer.mjs\";\nimport { LoadingCellRenderer } from \"../../rendering/cellRenderers/loadingCellRenderer.mjs\";\nimport { LoadingOverlayComponent } from \"../../rendering/overlays/loadingOverlayComponent.mjs\";\nimport { NoRowsOverlayComponent } from \"../../rendering/overlays/noRowsOverlayComponent.mjs\";\nimport { TooltipComponent } from \"../../rendering/tooltipComponent.mjs\";\nimport { doOnce } from \"../../utils/function.mjs\";\nimport { iterateObject } from '../../utils/object.mjs';\nimport { fuzzySuggestions } from '../../utils/fuzzyMatch.mjs';\nimport { NumberCellEditor } from \"../../rendering/cellEditors/numberCellEditor.mjs\";\nimport { DateCellEditor } from \"../../rendering/cellEditors/dateCellEditor.mjs\";\nimport { DateStringCellEditor } from \"../../rendering/cellEditors/dateStringCellEditor.mjs\";\nimport { CheckboxCellRenderer } from \"../../rendering/cellRenderers/checkboxCellRenderer.mjs\";\nimport { CheckboxCellEditor } from \"../../rendering/cellEditors/checkboxCellEditor.mjs\";\nlet UserComponentRegistry = class UserComponentRegistry extends BeanStub {\n constructor() {\n super(...arguments);\n this.agGridDefaults = {\n //date\n agDateInput: DefaultDateComponent,\n //header\n agColumnHeader: HeaderComp,\n agColumnGroupHeader: HeaderGroupComp,\n agSortIndicator: SortIndicatorComp,\n //floating filters\n agTextColumnFloatingFilter: TextFloatingFilter,\n agNumberColumnFloatingFilter: NumberFloatingFilter,\n agDateColumnFloatingFilter: DateFloatingFilter,\n agReadOnlyFloatingFilter: ReadOnlyFloatingFilter,\n // renderers\n agAnimateShowChangeCellRenderer: AnimateShowChangeCellRenderer,\n agAnimateSlideCellRenderer: AnimateSlideCellRenderer,\n agGroupCellRenderer: GroupCellRenderer,\n agGroupRowRenderer: GroupCellRenderer,\n agLoadingCellRenderer: LoadingCellRenderer,\n agCheckboxCellRenderer: CheckboxCellRenderer,\n //editors\n agCellEditor: TextCellEditor,\n agTextCellEditor: TextCellEditor,\n agNumberCellEditor: NumberCellEditor,\n agDateCellEditor: DateCellEditor,\n agDateStringCellEditor: DateStringCellEditor,\n agSelectCellEditor: SelectCellEditor,\n agLargeTextCellEditor: LargeTextCellEditor,\n agCheckboxCellEditor: CheckboxCellEditor,\n //filter\n agTextColumnFilter: TextFilter,\n agNumberColumnFilter: NumberFilter,\n agDateColumnFilter: DateFilter,\n //overlays\n agLoadingOverlay: LoadingOverlayComponent,\n agNoRowsOverlay: NoRowsOverlayComponent,\n // tooltips\n agTooltipComponent: TooltipComponent\n };\n /** Used to provide useful error messages if a user is trying to use an enterprise component without loading the module. */\n this.enterpriseAgDefaultCompsModule = {\n agSetColumnFilter: ModuleNames.SetFilterModule,\n agSetColumnFloatingFilter: ModuleNames.SetFilterModule,\n agMultiColumnFilter: ModuleNames.MultiFilterModule,\n agMultiColumnFloatingFilter: ModuleNames.MultiFilterModule,\n agGroupColumnFilter: ModuleNames.RowGroupingModule,\n agGroupColumnFloatingFilter: ModuleNames.RowGroupingModule,\n agRichSelect: ModuleNames.RichSelectModule,\n agRichSelectCellEditor: ModuleNames.RichSelectModule,\n agDetailCellRenderer: ModuleNames.MasterDetailModule,\n agSparklineCellRenderer: ModuleNames.SparklinesModule\n };\n this.jsComps = {};\n }\n init() {\n if (this.gridOptions.components != null) {\n iterateObject(this.gridOptions.components, (key, component) => this.registerJsComponent(key, component));\n }\n }\n registerDefaultComponent(name, component) {\n if (this.agGridDefaults[name]) {\n console.error(`Trying to overwrite a default component. You should call registerComponent`);\n return;\n }\n this.agGridDefaults[name] = component;\n }\n registerJsComponent(name, component) {\n this.jsComps[name] = component;\n }\n retrieve(propertyName, name) {\n const createResult = (component, componentFromFramework) => ({ componentFromFramework, component });\n // FrameworkOverrides.frameworkComponent() is used in two locations:\n // 1) for Vue, user provided components get registered via a framework specific way.\n // 2) for React, it's how the React UI provides alternative default components (eg GroupCellRenderer and DetailCellRenderer)\n const registeredViaFrameworkComp = this.getFrameworkOverrides().frameworkComponent(name, this.gridOptions.components);\n if (registeredViaFrameworkComp != null) {\n return createResult(registeredViaFrameworkComp, true);\n }\n const jsComponent = this.jsComps[name];\n if (jsComponent) {\n const isFwkComp = this.getFrameworkOverrides().isFrameworkComponent(jsComponent);\n return createResult(jsComponent, isFwkComp);\n }\n const defaultComponent = this.agGridDefaults[name];\n if (defaultComponent) {\n return createResult(defaultComponent, false);\n }\n const moduleForComponent = this.enterpriseAgDefaultCompsModule[name];\n if (moduleForComponent) {\n ModuleRegistry.__assertRegistered(moduleForComponent, `AG Grid '${propertyName}' component: ${name}`, this.context.getGridId());\n }\n else {\n doOnce(() => { this.warnAboutMissingComponent(propertyName, name); }, \"MissingComp\" + name);\n }\n return null;\n }\n warnAboutMissingComponent(propertyName, componentName) {\n const validComponents = [\n // Don't include the old names / internals in potential suggestions\n ...Object.keys(this.agGridDefaults).filter(k => !['agCellEditor', 'agGroupRowRenderer', 'agSortIndicator'].includes(k)),\n ...Object.keys(this.jsComps)\n ];\n const suggestions = fuzzySuggestions(componentName, validComponents, true, 0.8).values;\n console.warn(`AG Grid: Could not find '${componentName}' component. It was configured as \"${propertyName}: '${componentName}'\" but it wasn't found in the list of registered components.`);\n if (suggestions.length > 0) {\n console.warn(` Did you mean: [${suggestions.slice(0, 3)}]?`);\n }\n console.warn(`If using a custom component check it has been registered as described in: https://ag-grid.com/javascript-data-grid/components/`);\n }\n};\n__decorate([\n Autowired('gridOptions')\n], UserComponentRegistry.prototype, \"gridOptions\", void 0);\n__decorate([\n PostConstruct\n], UserComponentRegistry.prototype, \"init\", null);\nUserComponentRegistry = __decorate([\n Bean('userComponentRegistry')\n], UserComponentRegistry);\nexport { UserComponentRegistry };\n","export const DateComponent = {\n propertyName: 'dateComponent',\n cellRenderer: false\n};\nexport const HeaderComponent = {\n propertyName: 'headerComponent',\n cellRenderer: false\n};\nexport const HeaderGroupComponent = {\n propertyName: 'headerGroupComponent',\n cellRenderer: false\n};\nexport const CellRendererComponent = {\n propertyName: 'cellRenderer',\n cellRenderer: true\n};\nexport const CellEditorComponent = {\n propertyName: 'cellEditor',\n cellRenderer: false\n};\nexport const InnerRendererComponent = {\n propertyName: 'innerRenderer',\n cellRenderer: true\n};\nexport const LoadingOverlayComponent = {\n propertyName: 'loadingOverlayComponent',\n cellRenderer: false\n};\nexport const NoRowsOverlayComponent = {\n propertyName: 'noRowsOverlayComponent',\n cellRenderer: false\n};\nexport const TooltipComponent = {\n propertyName: 'tooltipComponent',\n cellRenderer: false\n};\nexport const FilterComponent = {\n propertyName: 'filter',\n cellRenderer: false\n};\nexport const FloatingFilterComponent = {\n propertyName: 'floatingFilterComponent',\n cellRenderer: false\n};\nexport const ToolPanelComponent = {\n propertyName: 'toolPanel',\n cellRenderer: false\n};\nexport const StatusPanelComponent = {\n propertyName: 'statusPanel',\n cellRenderer: false\n};\nexport const FullWidth = {\n propertyName: 'fullWidthCellRenderer',\n cellRenderer: true\n};\nexport const FullWidthLoading = {\n propertyName: 'loadingCellRenderer',\n cellRenderer: true\n};\nexport const FullWidthGroup = {\n propertyName: 'groupRowRenderer',\n cellRenderer: true\n};\nexport const FullWidthDetail = {\n propertyName: 'detailCellRenderer',\n cellRenderer: true\n};\n","export class FloatingFilterMapper {\n static getFloatingFilterType(filterType) {\n return this.filterToFloatingFilterMapping[filterType];\n }\n}\nFloatingFilterMapper.filterToFloatingFilterMapping = {\n set: 'agSetColumnFloatingFilter',\n agSetColumnFilter: 'agSetColumnFloatingFilter',\n multi: 'agMultiColumnFloatingFilter',\n agMultiColumnFilter: 'agMultiColumnFloatingFilter',\n group: 'agGroupColumnFloatingFilter',\n agGroupColumnFilter: 'agGroupColumnFloatingFilter',\n number: 'agNumberColumnFloatingFilter',\n agNumberColumnFilter: 'agNumberColumnFloatingFilter',\n date: 'agDateColumnFloatingFilter',\n agDateColumnFilter: 'agDateColumnFloatingFilter',\n text: 'agTextColumnFloatingFilter',\n agTextColumnFilter: 'agTextColumnFloatingFilter'\n};\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nimport { Autowired, Bean, Optional } from \"../../context/context.mjs\";\nimport { AgPromise } from \"../../utils/index.mjs\";\nimport { mergeDeep } from '../../utils/object.mjs';\nimport { CellEditorComponent, CellRendererComponent, DateComponent, FilterComponent, FloatingFilterComponent, FullWidth, FullWidthDetail, FullWidthGroup, FullWidthLoading, HeaderComponent, HeaderGroupComponent, InnerRendererComponent, LoadingOverlayComponent, NoRowsOverlayComponent, StatusPanelComponent, ToolPanelComponent, TooltipComponent } from \"./componentTypes.mjs\";\nimport { FloatingFilterMapper } from '../../filter/floating/floatingFilterMapper.mjs';\nlet UserComponentFactory = class UserComponentFactory extends BeanStub {\n getHeaderCompDetails(colDef, params) {\n return this.getCompDetails(colDef, HeaderComponent, 'agColumnHeader', params);\n }\n getHeaderGroupCompDetails(params) {\n const colGroupDef = params.columnGroup.getColGroupDef();\n return this.getCompDetails(colGroupDef, HeaderGroupComponent, 'agColumnGroupHeader', params);\n }\n // this one is unusual, as it can be LoadingCellRenderer, DetailCellRenderer, FullWidthCellRenderer or GroupRowRenderer.\n // so we have to pass the type in.\n getFullWidthCellRendererDetails(params) {\n return this.getCompDetails(this.gridOptions, FullWidth, null, params, true);\n }\n getFullWidthLoadingCellRendererDetails(params) {\n return this.getCompDetails(this.gridOptions, FullWidthLoading, 'agLoadingCellRenderer', params, true);\n }\n getFullWidthGroupCellRendererDetails(params) {\n return this.getCompDetails(this.gridOptions, FullWidthGroup, 'agGroupRowRenderer', params, true);\n }\n getFullWidthDetailCellRendererDetails(params) {\n return this.getCompDetails(this.gridOptions, FullWidthDetail, 'agDetailCellRenderer', params, true);\n }\n // CELL RENDERER\n getInnerRendererDetails(def, params) {\n return this.getCompDetails(def, InnerRendererComponent, null, params);\n }\n getFullWidthGroupRowInnerCellRenderer(def, params) {\n return this.getCompDetails(def, InnerRendererComponent, null, params);\n }\n getCellRendererDetails(def, params) {\n return this.getCompDetails(def, CellRendererComponent, null, params);\n }\n // CELL EDITOR\n getCellEditorDetails(def, params) {\n return this.getCompDetails(def, CellEditorComponent, 'agCellEditor', params, true);\n }\n // FILTER\n getFilterDetails(def, params, defaultFilter) {\n return this.getCompDetails(def, FilterComponent, defaultFilter, params, true);\n }\n getDateCompDetails(params) {\n return this.getCompDetails(this.gridOptions, DateComponent, 'agDateInput', params, true);\n }\n getLoadingOverlayCompDetails(params) {\n return this.getCompDetails(this.gridOptions, LoadingOverlayComponent, 'agLoadingOverlay', params, true);\n }\n getNoRowsOverlayCompDetails(params) {\n return this.getCompDetails(this.gridOptions, NoRowsOverlayComponent, 'agNoRowsOverlay', params, true);\n }\n getTooltipCompDetails(params) {\n return this.getCompDetails(params.colDef, TooltipComponent, 'agTooltipComponent', params, true);\n }\n getSetFilterCellRendererDetails(def, params) {\n return this.getCompDetails(def, CellRendererComponent, null, params);\n }\n getFloatingFilterCompDetails(def, params, defaultFloatingFilter) {\n return this.getCompDetails(def, FloatingFilterComponent, defaultFloatingFilter, params);\n }\n getToolPanelCompDetails(toolPanelDef, params) {\n return this.getCompDetails(toolPanelDef, ToolPanelComponent, null, params, true);\n }\n getStatusPanelCompDetails(def, params) {\n return this.getCompDetails(def, StatusPanelComponent, null, params, true);\n }\n getCompDetails(defObject, type, defaultName, params, mandatory = false) {\n const { propertyName, cellRenderer } = type;\n let { compName, jsComp, fwComp, paramsFromSelector, popupFromSelector, popupPositionFromSelector } = this.getCompKeys(defObject, type, params);\n const lookupFromRegistry = (key) => {\n const item = this.userComponentRegistry.retrieve(propertyName, key);\n if (item) {\n jsComp = !item.componentFromFramework ? item.component : undefined;\n fwComp = item.componentFromFramework ? item.component : undefined;\n }\n };\n // if compOption is a string, means we need to look the item up\n if (compName != null) {\n lookupFromRegistry(compName);\n }\n // if lookup brought nothing back, and we have a default, lookup the default\n if (jsComp == null && fwComp == null && defaultName != null) {\n lookupFromRegistry(defaultName);\n }\n // if we have a comp option, and it's a function, replace it with an object equivalent adaptor\n if (jsComp && cellRenderer && !this.agComponentUtils.doesImplementIComponent(jsComp)) {\n jsComp = this.agComponentUtils.adaptFunction(propertyName, jsComp);\n }\n if (!jsComp && !fwComp) {\n if (mandatory) {\n console.error(`AG Grid: Could not find component ${compName}, did you forget to configure this component?`);\n }\n return;\n }\n const paramsMerged = this.mergeParamsWithApplicationProvidedParams(defObject, type, params, paramsFromSelector);\n const componentFromFramework = jsComp == null;\n const componentClass = jsComp ? jsComp : fwComp;\n return {\n componentFromFramework,\n componentClass,\n params: paramsMerged,\n type: type,\n popupFromSelector,\n popupPositionFromSelector,\n newAgStackInstance: () => this.newAgStackInstance(componentClass, componentFromFramework, paramsMerged, type)\n };\n }\n getCompKeys(defObject, type, params) {\n const { propertyName } = type;\n let compName;\n let jsComp;\n let fwComp;\n let paramsFromSelector;\n let popupFromSelector;\n let popupPositionFromSelector;\n // there are two types of js comps, class based and func based. we can only check for\n // class based, by checking if getGui() exists. no way to differentiate js func based vs eg react func based\n // const isJsClassComp = (comp: any) => this.agComponentUtils.doesImplementIComponent(comp);\n // const fwActive = this.frameworkComponentWrapper != null;\n // pull from defObject if available\n if (defObject) {\n const defObjectAny = defObject;\n // if selector, use this\n const selectorFunc = defObjectAny[propertyName + 'Selector'];\n const selectorRes = selectorFunc ? selectorFunc(params) : null;\n const assignComp = (providedJsComp) => {\n if (typeof providedJsComp === 'string') {\n compName = providedJsComp;\n }\n else if (providedJsComp != null && providedJsComp !== true) {\n const isFwkComp = this.getFrameworkOverrides().isFrameworkComponent(providedJsComp);\n if (isFwkComp) {\n fwComp = providedJsComp;\n }\n else {\n jsComp = providedJsComp;\n }\n }\n };\n if (selectorRes) {\n assignComp(selectorRes.component);\n paramsFromSelector = selectorRes.params;\n popupFromSelector = selectorRes.popup;\n popupPositionFromSelector = selectorRes.popupPosition;\n }\n else {\n // if no selector, or result of selector is empty, take from defObject\n assignComp(defObjectAny[propertyName]);\n }\n }\n return { compName, jsComp, fwComp, paramsFromSelector, popupFromSelector, popupPositionFromSelector };\n }\n newAgStackInstance(ComponentClass, componentFromFramework, params, type) {\n const propertyName = type.propertyName;\n const jsComponent = !componentFromFramework;\n // using javascript component\n let instance;\n if (jsComponent) {\n instance = new ComponentClass();\n }\n else {\n // Using framework component\n const thisComponentConfig = this.componentMetadataProvider.retrieve(propertyName);\n instance = this.frameworkComponentWrapper.wrap(ComponentClass, thisComponentConfig.mandatoryMethodList, thisComponentConfig.optionalMethodList, type);\n }\n const deferredInit = this.initComponent(instance, params);\n if (deferredInit == null) {\n return AgPromise.resolve(instance);\n }\n return deferredInit.then(() => instance);\n }\n // used by Floating Filter\n mergeParamsWithApplicationProvidedParams(defObject, type, paramsFromGrid, paramsFromSelector = null) {\n const params = {\n context: this.gridOptionsService.context,\n columnApi: this.gridOptionsService.columnApi,\n api: this.gridOptionsService.api\n };\n mergeDeep(params, paramsFromGrid);\n // pull user params from either the old prop name and new prop name\n // eg either cellRendererParams and cellCompParams\n const defObjectAny = defObject;\n const userParams = defObjectAny && defObjectAny[type.propertyName + 'Params'];\n if (typeof userParams === 'function') {\n const userParamsFromFunc = userParams(paramsFromGrid);\n mergeDeep(params, userParamsFromFunc);\n }\n else if (typeof userParams === 'object') {\n mergeDeep(params, userParams);\n }\n mergeDeep(params, paramsFromSelector);\n return params;\n }\n initComponent(component, params) {\n this.context.createBean(component);\n if (component.init == null) {\n return;\n }\n return component.init(params);\n }\n getDefaultFloatingFilterType(def, getFromDefault) {\n if (def == null) {\n return null;\n }\n let defaultFloatingFilterType = null;\n let { compName, jsComp, fwComp } = this.getCompKeys(def, FilterComponent);\n if (compName) {\n // will be undefined if not in the map\n defaultFloatingFilterType = FloatingFilterMapper.getFloatingFilterType(compName);\n }\n else {\n const usingDefaultFilter = (jsComp == null && fwComp == null) && (def.filter === true);\n if (usingDefaultFilter) {\n defaultFloatingFilterType = getFromDefault();\n }\n }\n return defaultFloatingFilterType;\n }\n};\n__decorate([\n Autowired('gridOptions')\n], UserComponentFactory.prototype, \"gridOptions\", void 0);\n__decorate([\n Autowired('agComponentUtils')\n], UserComponentFactory.prototype, \"agComponentUtils\", void 0);\n__decorate([\n Autowired('componentMetadataProvider')\n], UserComponentFactory.prototype, \"componentMetadataProvider\", void 0);\n__decorate([\n Autowired('userComponentRegistry')\n], UserComponentFactory.prototype, \"userComponentRegistry\", void 0);\n__decorate([\n Optional('frameworkComponentWrapper')\n], UserComponentFactory.prototype, \"frameworkComponentWrapper\", void 0);\nUserComponentFactory = __decorate([\n Bean('userComponentFactory')\n], UserComponentFactory);\nexport { UserComponentFactory };\n","// Excel Export\nexport var ExcelFactoryMode;\n(function (ExcelFactoryMode) {\n ExcelFactoryMode[ExcelFactoryMode[\"SINGLE_SHEET\"] = 0] = \"SINGLE_SHEET\";\n ExcelFactoryMode[ExcelFactoryMode[\"MULTI_SHEET\"] = 1] = \"MULTI_SHEET\";\n})(ExcelFactoryMode || (ExcelFactoryMode = {}));\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean, PreDestroy, Autowired } from \"../context/context.mjs\";\nimport { Events } from \"../events.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { exists } from \"../utils/generic.mjs\";\nimport { removeFromArray } from \"../utils/array.mjs\";\nimport { areEventsNear } from \"../utils/mouse.mjs\";\nimport { isBrowserSafari } from \"../utils/browser.mjs\";\nimport { isFocusableFormField } from \"../utils/dom.mjs\";\n/** Adds drag listening onto an element. In AG Grid this is used twice, first is resizing columns,\n * second is moving the columns and column groups around (ie the 'drag' part of Drag and Drop. */\nlet DragService = class DragService extends BeanStub {\n constructor() {\n super(...arguments);\n this.dragEndFunctions = [];\n this.dragSources = [];\n }\n removeAllListeners() {\n this.dragSources.forEach(this.removeListener.bind(this));\n this.dragSources.length = 0;\n }\n removeListener(dragSourceAndListener) {\n const element = dragSourceAndListener.dragSource.eElement;\n const mouseDownListener = dragSourceAndListener.mouseDownListener;\n element.removeEventListener('mousedown', mouseDownListener);\n // remove touch listener only if it exists\n if (dragSourceAndListener.touchEnabled) {\n const touchStartListener = dragSourceAndListener.touchStartListener;\n element.removeEventListener('touchstart', touchStartListener, { passive: true });\n }\n }\n removeDragSource(params) {\n const dragSourceAndListener = this.dragSources.find(item => item.dragSource === params);\n if (!dragSourceAndListener) {\n return;\n }\n this.removeListener(dragSourceAndListener);\n removeFromArray(this.dragSources, dragSourceAndListener);\n }\n isDragging() {\n return this.dragging;\n }\n addDragSource(params) {\n const mouseListener = this.onMouseDown.bind(this, params);\n const { eElement, includeTouch, stopPropagationForTouch } = params;\n eElement.addEventListener('mousedown', mouseListener);\n let touchListener = null;\n const suppressTouch = this.gridOptionsService.is('suppressTouch');\n if (includeTouch && !suppressTouch) {\n touchListener = (touchEvent) => {\n if (isFocusableFormField(touchEvent.target)) {\n return;\n }\n if (touchEvent.cancelable) {\n touchEvent.preventDefault();\n if (stopPropagationForTouch) {\n touchEvent.stopPropagation();\n }\n }\n this.onTouchStart(params, touchEvent);\n };\n // we set passive=false, as we want to prevent default on this event\n eElement.addEventListener('touchstart', touchListener, { passive: false });\n }\n this.dragSources.push({\n dragSource: params,\n mouseDownListener: mouseListener,\n touchStartListener: touchListener,\n touchEnabled: !!includeTouch\n });\n }\n getStartTarget() {\n return this.startTarget;\n }\n // gets called whenever mouse down on any drag source\n onTouchStart(params, touchEvent) {\n this.currentDragParams = params;\n this.dragging = false;\n const touch = touchEvent.touches[0];\n this.touchLastTime = touch;\n this.touchStart = touch;\n const touchMoveEvent = (e) => this.onTouchMove(e, params.eElement);\n const touchEndEvent = (e) => this.onTouchUp(e, params.eElement);\n const documentTouchMove = (e) => { if (e.cancelable) {\n e.preventDefault();\n } };\n const target = touchEvent.target;\n const events = [\n // Prevents the page document from moving while we are dragging items around.\n // preventDefault needs to be called in the touchmove listener and never inside the\n // touchstart, because using touchstart causes the click event to be cancelled on touch devices.\n { target: this.gridOptionsService.getRootNode(), type: 'touchmove', listener: documentTouchMove, options: { passive: false } },\n { target, type: 'touchmove', listener: touchMoveEvent, options: { passive: true } },\n { target, type: 'touchend', listener: touchEndEvent, options: { passive: true } },\n { target, type: 'touchcancel', listener: touchEndEvent, options: { passive: true } }\n ];\n // temporally add these listeners, for the duration of the drag\n this.addTemporaryEvents(events);\n // see if we want to start dragging straight away\n if (params.dragStartPixels === 0) {\n this.onCommonMove(touch, this.touchStart, params.eElement);\n }\n }\n // gets called whenever mouse down on any drag source\n onMouseDown(params, mouseEvent) {\n const e = mouseEvent;\n if (params.skipMouseEvent && params.skipMouseEvent(mouseEvent)) {\n return;\n }\n // if there are two elements with parent / child relationship, and both are draggable,\n // when we drag the child, we should NOT drag the parent. an example of this is row moving\n // and range selection - row moving should get preference when use drags the rowDrag component.\n if (e._alreadyProcessedByDragService) {\n return;\n }\n e._alreadyProcessedByDragService = true;\n // only interested in left button clicks\n if (mouseEvent.button !== 0) {\n return;\n }\n if (this.shouldPreventMouseEvent(mouseEvent)) {\n mouseEvent.preventDefault();\n }\n this.currentDragParams = params;\n this.dragging = false;\n this.mouseStartEvent = mouseEvent;\n this.startTarget = mouseEvent.target;\n const mouseMoveEvent = (event) => this.onMouseMove(event, params.eElement);\n const mouseUpEvent = (event) => this.onMouseUp(event, params.eElement);\n const contextEvent = (event) => event.preventDefault();\n const target = this.gridOptionsService.getRootNode();\n const events = [\n { target, type: 'mousemove', listener: mouseMoveEvent },\n { target, type: 'mouseup', listener: mouseUpEvent },\n { target, type: 'contextmenu', listener: contextEvent }\n ];\n // temporally add these listeners, for the duration of the drag\n this.addTemporaryEvents(events);\n //see if we want to start dragging straight away\n if (params.dragStartPixels === 0) {\n this.onMouseMove(mouseEvent, params.eElement);\n }\n }\n addTemporaryEvents(events) {\n events.forEach((currentEvent) => {\n const { target, type, listener, options } = currentEvent;\n target.addEventListener(type, listener, options);\n });\n this.dragEndFunctions.push(() => {\n events.forEach((currentEvent) => {\n const { target, type, listener, options } = currentEvent;\n target.removeEventListener(type, listener, options);\n });\n });\n }\n // returns true if the event is close to the original event by X pixels either vertically or horizontally.\n // we only start dragging after X pixels so this allows us to know if we should start dragging yet.\n isEventNearStartEvent(currentEvent, startEvent) {\n // by default, we wait 4 pixels before starting the drag\n const { dragStartPixels } = this.currentDragParams;\n const requiredPixelDiff = exists(dragStartPixels) ? dragStartPixels : 4;\n return areEventsNear(currentEvent, startEvent, requiredPixelDiff);\n }\n getFirstActiveTouch(touchList) {\n for (let i = 0; i < touchList.length; i++) {\n if (touchList[i].identifier === this.touchStart.identifier) {\n return touchList[i];\n }\n }\n return null;\n }\n onCommonMove(currentEvent, startEvent, el) {\n if (!this.dragging) {\n // if mouse hasn't travelled from the start position enough, do nothing\n if (!this.dragging && this.isEventNearStartEvent(currentEvent, startEvent)) {\n return;\n }\n this.dragging = true;\n const event = {\n type: Events.EVENT_DRAG_STARTED,\n target: el\n };\n this.eventService.dispatchEvent(event);\n this.currentDragParams.onDragStart(startEvent);\n // we need ONE drag action at the startEvent, so that we are guaranteed the drop target\n // at the start gets notified. this is because the drag can start outside of the element\n // that started it, as the mouse is allowed drag away from the mouse down before it's\n // considered a drag (the isEventNearStartEvent() above). if we didn't do this, then\n // it would be possible to click a column by the edge, then drag outside of the drop zone\n // in less than 4 pixels and the drag officially starts outside of the header but the header\n // wouldn't be notified of the dragging.\n this.currentDragParams.onDragging(startEvent);\n }\n this.currentDragParams.onDragging(currentEvent);\n }\n onTouchMove(touchEvent, el) {\n const touch = this.getFirstActiveTouch(touchEvent.touches);\n if (!touch) {\n return;\n }\n // this.___statusPanel.setInfoText(Math.random() + ' onTouchMove preventDefault stopPropagation');\n this.onCommonMove(touch, this.touchStart, el);\n }\n // only gets called after a mouse down - as this is only added after mouseDown\n // and is removed when mouseUp happens\n onMouseMove(mouseEvent, el) {\n if (this.shouldPreventMouseEvent(mouseEvent)) {\n mouseEvent.preventDefault();\n }\n this.onCommonMove(mouseEvent, this.mouseStartEvent, el);\n }\n shouldPreventMouseEvent(mouseEvent) {\n const isEnableCellTextSelect = this.gridOptionsService.is('enableCellTextSelection');\n const isSafari = isBrowserSafari();\n const isMouseMove = mouseEvent.type === 'mousemove';\n return (\n // when `isEnableCellTextSelect` is `true`, we need to preventDefault on mouseMove\n // to avoid the grid text being selected while dragging components.\n // Note: Safari also has an issue, where `user-select: none` is not being respected, so also\n // prevent it on MouseDown.\n ((isEnableCellTextSelect && isMouseMove) || isSafari) &&\n mouseEvent.cancelable &&\n this.mouseEventService.isEventFromThisGrid(mouseEvent) &&\n !this.isOverFormFieldElement(mouseEvent));\n }\n isOverFormFieldElement(mouseEvent) {\n const el = mouseEvent.target;\n const tagName = el === null || el === void 0 ? void 0 : el.tagName.toLocaleLowerCase();\n return !!(tagName === null || tagName === void 0 ? void 0 : tagName.match('^a$|textarea|input|select|button'));\n }\n onTouchUp(touchEvent, el) {\n let touch = this.getFirstActiveTouch(touchEvent.changedTouches);\n // i haven't worked this out yet, but there is no matching touch\n // when we get the touch up event. to get around this, we swap in\n // the last touch. this is a hack to 'get it working' while we\n // figure out what's going on, why we are not getting a touch in\n // current event.\n if (!touch) {\n touch = this.touchLastTime;\n }\n // if mouse was left up before we started to move, then this is a tap.\n // we check this before onUpCommon as onUpCommon resets the dragging\n // let tap = !this.dragging;\n // let tapTarget = this.currentDragParams.eElement;\n this.onUpCommon(touch, el);\n // if tap, tell user\n // console.log(`${Math.random()} tap = ${tap}`);\n // if (tap) {\n // tapTarget.click();\n // }\n }\n onMouseUp(mouseEvent, el) {\n this.onUpCommon(mouseEvent, el);\n }\n onUpCommon(eventOrTouch, el) {\n if (this.dragging) {\n this.dragging = false;\n this.currentDragParams.onDragStop(eventOrTouch);\n const event = {\n type: Events.EVENT_DRAG_STOPPED,\n target: el\n };\n this.eventService.dispatchEvent(event);\n }\n this.mouseStartEvent = null;\n this.startTarget = null;\n this.touchStart = null;\n this.touchLastTime = null;\n this.currentDragParams = null;\n this.dragEndFunctions.forEach(func => func());\n this.dragEndFunctions.length = 0;\n }\n};\n__decorate([\n Autowired('mouseEventService')\n], DragService.prototype, \"mouseEventService\", void 0);\n__decorate([\n PreDestroy\n], DragService.prototype, \"removeAllListeners\", null);\nDragService = __decorate([\n Bean('dragService')\n], DragService);\nexport { DragService };\n","export class AutoScrollService {\n constructor(params) {\n this.tickingInterval = null;\n this.onScrollCallback = null;\n this.scrollContainer = params.scrollContainer;\n this.scrollHorizontally = params.scrollAxis.indexOf('x') !== -1;\n this.scrollVertically = params.scrollAxis.indexOf('y') !== -1;\n this.scrollByTick = params.scrollByTick != null ? params.scrollByTick : 20;\n if (params.onScrollCallback) {\n this.onScrollCallback = params.onScrollCallback;\n }\n if (this.scrollVertically) {\n this.getVerticalPosition = params.getVerticalPosition;\n this.setVerticalPosition = params.setVerticalPosition;\n }\n if (this.scrollHorizontally) {\n this.getHorizontalPosition = params.getHorizontalPosition;\n this.setHorizontalPosition = params.setHorizontalPosition;\n }\n this.shouldSkipVerticalScroll = params.shouldSkipVerticalScroll || (() => false);\n this.shouldSkipHorizontalScroll = params.shouldSkipHorizontalScroll || (() => false);\n }\n check(mouseEvent, forceSkipVerticalScroll = false) {\n const skipVerticalScroll = forceSkipVerticalScroll || this.shouldSkipVerticalScroll();\n if (skipVerticalScroll && this.shouldSkipHorizontalScroll()) {\n return;\n }\n const rect = this.scrollContainer.getBoundingClientRect();\n const scrollTick = this.scrollByTick;\n this.tickLeft = mouseEvent.clientX < (rect.left + scrollTick);\n this.tickRight = mouseEvent.clientX > (rect.right - scrollTick);\n this.tickUp = mouseEvent.clientY < (rect.top + scrollTick) && !skipVerticalScroll;\n this.tickDown = mouseEvent.clientY > (rect.bottom - scrollTick) && !skipVerticalScroll;\n if (this.tickLeft || this.tickRight || this.tickUp || this.tickDown) {\n this.ensureTickingStarted();\n }\n else {\n this.ensureCleared();\n }\n }\n ensureTickingStarted() {\n if (this.tickingInterval === null) {\n this.tickingInterval = window.setInterval(this.doTick.bind(this), 100);\n this.tickCount = 0;\n }\n }\n doTick() {\n this.tickCount++;\n let tickAmount;\n tickAmount = this.tickCount > 20 ? 200 : (this.tickCount > 10 ? 80 : 40);\n if (this.scrollVertically) {\n const vScrollPosition = this.getVerticalPosition();\n if (this.tickUp) {\n this.setVerticalPosition(vScrollPosition - tickAmount);\n }\n if (this.tickDown) {\n this.setVerticalPosition(vScrollPosition + tickAmount);\n }\n }\n if (this.scrollHorizontally) {\n const hScrollPosition = this.getHorizontalPosition();\n if (this.tickLeft) {\n this.setHorizontalPosition(hScrollPosition - tickAmount);\n }\n if (this.tickRight) {\n this.setHorizontalPosition(hScrollPosition + tickAmount);\n }\n }\n if (this.onScrollCallback) {\n this.onScrollCallback();\n }\n }\n ensureCleared() {\n if (this.tickingInterval) {\n window.clearInterval(this.tickingInterval);\n this.tickingInterval = null;\n }\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { AutoScrollService } from \"../autoScrollService.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { Autowired, PostConstruct } from \"../context/context.mjs\";\nimport { radioCssClass } from \"../utils/dom.mjs\";\nimport { DragAndDropService } from \"./dragAndDropService.mjs\";\nconst LIST_ITEM_HOVERED = 'ag-list-item-hovered';\nexport class VirtualListDragFeature extends BeanStub {\n constructor(comp, virtualList, params) {\n super();\n this.comp = comp;\n this.virtualList = virtualList;\n this.params = params;\n this.currentDragValue = null;\n this.lastHoveredListItem = null;\n }\n postConstruct() {\n this.addManagedListener(this.params.eventSource, this.params.listItemDragStartEvent, this.listItemDragStart.bind(this));\n this.addManagedListener(this.params.eventSource, this.params.listItemDragEndEvent, this.listItemDragEnd.bind(this));\n this.createDropTarget();\n this.createAutoScrollService();\n }\n listItemDragStart(event) {\n this.currentDragValue = this.params.getCurrentDragValue(event);\n this.moveBlocked = this.params.isMoveBlocked(this.currentDragValue);\n }\n listItemDragEnd() {\n window.setTimeout(() => {\n this.currentDragValue = null;\n this.moveBlocked = false;\n }, 10);\n }\n createDropTarget() {\n const dropTarget = {\n isInterestedIn: (type) => type === this.params.dragSourceType,\n getIconName: () => DragAndDropService[this.moveBlocked ? 'ICON_NOT_ALLOWED' : 'ICON_MOVE'],\n getContainer: () => this.comp.getGui(),\n onDragging: (e) => this.onDragging(e),\n onDragStop: () => this.onDragStop(),\n onDragLeave: () => this.onDragLeave()\n };\n this.dragAndDropService.addDropTarget(dropTarget);\n }\n createAutoScrollService() {\n const virtualListGui = this.virtualList.getGui();\n this.autoScrollService = new AutoScrollService({\n scrollContainer: virtualListGui,\n scrollAxis: 'y',\n getVerticalPosition: () => virtualListGui.scrollTop,\n setVerticalPosition: (position) => virtualListGui.scrollTop = position\n });\n }\n onDragging(e) {\n if (!this.currentDragValue || this.moveBlocked) {\n return;\n }\n const hoveredListItem = this.getListDragItem(e);\n const comp = this.virtualList.getComponentAt(hoveredListItem.rowIndex);\n if (!comp) {\n return;\n }\n const el = comp.getGui().parentElement;\n if (this.lastHoveredListItem &&\n this.lastHoveredListItem.rowIndex === hoveredListItem.rowIndex &&\n this.lastHoveredListItem.position === hoveredListItem.position) {\n return;\n }\n this.autoScrollService.check(e.event);\n this.clearHoveredItems();\n this.lastHoveredListItem = hoveredListItem;\n radioCssClass(el, LIST_ITEM_HOVERED);\n radioCssClass(el, `ag-item-highlight-${hoveredListItem.position}`);\n }\n getListDragItem(e) {\n const virtualListGui = this.virtualList.getGui();\n const paddingTop = parseFloat(window.getComputedStyle(virtualListGui).paddingTop);\n const rowHeight = this.virtualList.getRowHeight();\n const scrollTop = this.virtualList.getScrollTop();\n const rowIndex = Math.max(0, (e.y - paddingTop + scrollTop) / rowHeight);\n const maxLen = this.params.getNumRows(this.comp) - 1;\n const normalizedRowIndex = Math.min(maxLen, rowIndex) | 0;\n return {\n rowIndex: normalizedRowIndex,\n position: (Math.round(rowIndex) > rowIndex || rowIndex > maxLen) ? 'bottom' : 'top',\n component: this.virtualList.getComponentAt(normalizedRowIndex)\n };\n }\n onDragStop() {\n if (this.moveBlocked) {\n return;\n }\n this.params.moveItem(this.currentDragValue, this.lastHoveredListItem);\n this.clearHoveredItems();\n this.autoScrollService.ensureCleared();\n }\n onDragLeave() {\n this.clearHoveredItems();\n this.autoScrollService.ensureCleared();\n }\n clearHoveredItems() {\n const virtualListGui = this.virtualList.getGui();\n virtualListGui.querySelectorAll(`.${LIST_ITEM_HOVERED}`).forEach(el => {\n [\n LIST_ITEM_HOVERED,\n 'ag-item-highlight-top',\n 'ag-item-highlight-bottom'\n ].forEach(cls => {\n el.classList.remove(cls);\n });\n });\n this.lastHoveredListItem = null;\n }\n}\n__decorate([\n Autowired('dragAndDropService')\n], VirtualListDragFeature.prototype, \"dragAndDropService\", void 0);\n__decorate([\n PostConstruct\n], VirtualListDragFeature.prototype, \"postConstruct\", null);\n","export var RowHighlightPosition;\n(function (RowHighlightPosition) {\n RowHighlightPosition[RowHighlightPosition[\"Above\"] = 0] = \"Above\";\n RowHighlightPosition[RowHighlightPosition[\"Below\"] = 1] = \"Below\";\n})(RowHighlightPosition || (RowHighlightPosition = {}));\n","export var ClientSideRowModelSteps;\n(function (ClientSideRowModelSteps) {\n ClientSideRowModelSteps[\"EVERYTHING\"] = \"group\";\n ClientSideRowModelSteps[\"FILTER\"] = \"filter\";\n ClientSideRowModelSteps[\"SORT\"] = \"sort\";\n ClientSideRowModelSteps[\"MAP\"] = \"map\";\n ClientSideRowModelSteps[\"AGGREGATE\"] = \"aggregate\";\n ClientSideRowModelSteps[\"FILTER_AGGREGATES\"] = \"filter_aggregates\";\n ClientSideRowModelSteps[\"PIVOT\"] = \"pivot\";\n ClientSideRowModelSteps[\"NOTHING\"] = \"nothing\";\n})(ClientSideRowModelSteps || (ClientSideRowModelSteps = {}));\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, Optional, PostConstruct, PreDestroy } from \"./context/context.mjs\";\nimport { logDeprecation } from \"./gridOptionsValidator.mjs\";\nimport { ClientSideRowModelSteps } from \"./interfaces/iClientSideRowModel.mjs\";\nimport { ExcelFactoryMode } from \"./interfaces/iExcelCreator.mjs\";\nimport { ModuleNames } from \"./modules/moduleNames.mjs\";\nimport { ModuleRegistry } from \"./modules/moduleRegistry.mjs\";\nimport { exists, missing } from \"./utils/generic.mjs\";\nimport { iterateObject, removeAllReferences } from \"./utils/object.mjs\";\nimport { Events } from './eventKeys.mjs';\nexport function unwrapUserComp(comp) {\n const compAsAny = comp;\n const isProxy = compAsAny != null && compAsAny.getFrameworkComponentInstance != null;\n return isProxy ? compAsAny.getFrameworkComponentInstance() : comp;\n}\nlet GridApi = class GridApi {\n constructor() {\n this.detailGridInfoMap = {};\n this.destroyCalled = false;\n }\n registerOverlayWrapperComp(overlayWrapperComp) {\n this.overlayWrapperComp = overlayWrapperComp;\n }\n registerSideBarComp(sideBarComp) {\n this.sideBarComp = sideBarComp;\n }\n init() {\n switch (this.rowModel.getType()) {\n case 'clientSide':\n this.clientSideRowModel = this.rowModel;\n break;\n case 'infinite':\n this.infiniteRowModel = this.rowModel;\n break;\n case 'serverSide':\n this.serverSideRowModel = this.rowModel;\n break;\n }\n this.ctrlsService.whenReady(() => {\n this.gridBodyCtrl = this.ctrlsService.getGridBodyCtrl();\n });\n }\n /** Used internally by grid. Not intended to be used by the client. Interface may change between releases. */\n __getAlignedGridService() {\n return this.alignedGridsService;\n }\n /** Used internally by grid. Not intended to be used by the client. Interface may change between releases. */\n __getContext() {\n return this.context;\n }\n getSetterMethod(key) {\n return `set${key.charAt(0).toUpperCase()}${key.substring(1)}`;\n }\n /** Used internally by grid. Not intended to be used by the client. Interface may change between releases. */\n __setPropertyOnly(propertyName, value) {\n return this.gos.__setPropertyOnly(propertyName, value);\n }\n /** Used internally by grid. Not intended to be used by the client. Interface may change between releases. */\n __updateProperty(propertyName, value, force, changeSet = undefined) {\n // Ensure the GridOptions property gets updated and fires the change event as we\n // cannot assume that the dynamic Api call will updated GridOptions.\n this.gos.set(propertyName, value, force, {}, changeSet);\n // If the dynamic api does update GridOptions then change detection in the\n // GridOptionsService will prevent the event being fired twice.\n const setterName = this.getSetterMethod(propertyName);\n const dynamicApi = this;\n if (dynamicApi[setterName]) {\n dynamicApi[setterName](value);\n }\n }\n /** Returns the `gridId` for the current grid as specified via the gridOptions property `gridId` or the auto assigned grid id if none was provided. */\n getGridId() {\n return this.context.getGridId();\n }\n /** Register a detail grid with the master grid when it is created. */\n addDetailGridInfo(id, gridInfo) {\n this.detailGridInfoMap[id] = gridInfo;\n }\n /** Unregister a detail grid from the master grid when it is destroyed. */\n removeDetailGridInfo(id) {\n this.detailGridInfoMap[id] = undefined;\n }\n /** Returns the `DetailGridInfo` corresponding to the supplied `detailGridId`. */\n getDetailGridInfo(id) {\n return this.detailGridInfoMap[id];\n }\n /** Iterates through each `DetailGridInfo` in the grid and calls the supplied callback on each. */\n forEachDetailGridInfo(callback) {\n let index = 0;\n iterateObject(this.detailGridInfoMap, (id, gridInfo) => {\n // check for undefined, as old references will still be lying around\n if (exists(gridInfo)) {\n callback(gridInfo, index);\n index++;\n }\n });\n }\n /** Similar to `exportDataAsCsv`, except returns the result as a string rather than download it. */\n getDataAsCsv(params) {\n if (ModuleRegistry.__assertRegistered(ModuleNames.CsvExportModule, 'api.getDataAsCsv', this.context.getGridId())) {\n return this.csvCreator.getDataAsCsv(params);\n }\n }\n /** Downloads a CSV export of the grid's data. */\n exportDataAsCsv(params) {\n if (ModuleRegistry.__assertRegistered(ModuleNames.CsvExportModule, 'api.exportDataAsCSv', this.context.getGridId())) {\n this.csvCreator.exportDataAsCsv(params);\n }\n }\n getExcelExportMode(params) {\n const baseParams = this.gos.get('defaultExcelExportParams');\n const mergedParams = Object.assign({ exportMode: 'xlsx' }, baseParams, params);\n return mergedParams.exportMode;\n }\n assertNotExcelMultiSheet(method, params) {\n if (!ModuleRegistry.__assertRegistered(ModuleNames.ExcelExportModule, 'api.' + method, this.context.getGridId())) {\n return false;\n }\n const exportMode = this.getExcelExportMode(params);\n if (this.excelCreator.getFactoryMode(exportMode) === ExcelFactoryMode.MULTI_SHEET) {\n console.warn(\"AG Grid: The Excel Exporter is currently on Multi Sheet mode. End that operation by calling 'api.getMultipleSheetAsExcel()' or 'api.exportMultipleSheetsAsExcel()'\");\n return false;\n }\n return true;\n }\n /** Similar to `exportDataAsExcel`, except instead of downloading a file, it will return a [Blob](https://developer.mozilla.org/en-US/docs/Web/API/Blob) to be processed by the user. */\n getDataAsExcel(params) {\n if (this.assertNotExcelMultiSheet('getDataAsExcel', params)) {\n return this.excelCreator.getDataAsExcel(params);\n }\n }\n /** Downloads an Excel export of the grid's data. */\n exportDataAsExcel(params) {\n if (this.assertNotExcelMultiSheet('exportDataAsExcel', params)) {\n this.excelCreator.exportDataAsExcel(params);\n }\n }\n /** This is method to be used to get the grid's data as a sheet, that will later be exported either by `getMultipleSheetsAsExcel()` or `exportMultipleSheetsAsExcel()`. */\n getSheetDataForExcel(params) {\n if (!ModuleRegistry.__assertRegistered(ModuleNames.ExcelExportModule, 'api.getSheetDataForExcel', this.context.getGridId())) {\n return;\n }\n const exportMode = this.getExcelExportMode(params);\n this.excelCreator.setFactoryMode(ExcelFactoryMode.MULTI_SHEET, exportMode);\n return this.excelCreator.getSheetDataForExcel(params);\n }\n /** Similar to `exportMultipleSheetsAsExcel`, except instead of downloading a file, it will return a [Blob](https://developer.mozilla.org/en-US/docs/Web/API/Blob) to be processed by the user. */\n getMultipleSheetsAsExcel(params) {\n if (ModuleRegistry.__assertRegistered(ModuleNames.ExcelExportModule, 'api.getMultipleSheetsAsExcel', this.context.getGridId())) {\n return this.excelCreator.getMultipleSheetsAsExcel(params);\n }\n }\n /** Downloads an Excel export of multiple sheets in one file. */\n exportMultipleSheetsAsExcel(params) {\n if (ModuleRegistry.__assertRegistered(ModuleNames.ExcelExportModule, 'api.exportMultipleSheetsAsExcel', this.context.getGridId())) {\n return this.excelCreator.exportMultipleSheetsAsExcel(params);\n }\n }\n /** Sets the `treeData` property. */\n setTreeData(newTreeData) {\n this.gos.set('treeData', newTreeData);\n }\n /**\n * Sets an ARIA property in the grid panel (element with `role=\\\"grid\\\"`), and removes an ARIA property when the value is null.\n *\n * Example: `api.setGridAriaProperty('label', 'my grid')` will set `aria-label=\\\"my grid\\\"`.\n *\n * `api.setGridAriaProperty('label', null)` will remove the `aria-label` attribute from the grid element.\n */\n setGridAriaProperty(property, value) {\n if (!property) {\n return;\n }\n const eGrid = this.ctrlsService.getGridBodyCtrl().getGui();\n const ariaProperty = `aria-${property}`;\n if (value === null) {\n eGrid.removeAttribute(ariaProperty);\n }\n else {\n eGrid.setAttribute(ariaProperty, value);\n }\n }\n logMissingRowModel(apiMethod, ...requiredRowModels) {\n console.error(`AG Grid: api.${apiMethod} can only be called when gridOptions.rowModelType is ${requiredRowModels.join(' or ')}`);\n }\n /** Set new datasource for Server-Side Row Model. */\n setServerSideDatasource(datasource) {\n if (this.serverSideRowModel) {\n this.serverSideRowModel.setDatasource(datasource);\n }\n else {\n this.logMissingRowModel('setServerSideDatasource', 'serverSide');\n }\n }\n /**\n * Updates the `cacheBlockSize` when requesting data from the server if `suppressServerSideInfiniteScroll` is not enabled.\n *\n * Note this purges all the cached data and reloads all the rows of the grid.\n * */\n setCacheBlockSize(blockSize) {\n if (this.serverSideRowModel) {\n this.gos.set('cacheBlockSize', blockSize);\n this.serverSideRowModel.resetRootStore();\n }\n else {\n this.logMissingRowModel('setCacheBlockSize', 'serverSide');\n }\n }\n /** Set new datasource for Infinite Row Model. */\n setDatasource(datasource) {\n if (this.gos.isRowModelType('infinite')) {\n this.rowModel.setDatasource(datasource);\n }\n else {\n this.logMissingRowModel('setDatasource', 'infinite');\n }\n }\n /** Set new datasource for Viewport Row Model. */\n setViewportDatasource(viewportDatasource) {\n if (this.gos.isRowModelType('viewport')) {\n // this is bad coding, because it's using an interface that's exposed in the enterprise.\n // really we should create an interface in the core for viewportDatasource and let\n // the enterprise implement it, rather than casting to 'any' here\n this.rowModel.setViewportDatasource(viewportDatasource);\n }\n else {\n this.logMissingRowModel('setViewportDatasource', 'viewport');\n }\n }\n /** Set the row data. */\n setRowData(rowData) {\n // immutable service is part of the CSRM module, if missing, no CSRM\n const missingImmutableService = this.immutableService == null;\n if (missingImmutableService) {\n this.logMissingRowModel('setRowData', 'clientSide');\n return;\n }\n // if no keys provided provided for rows, then we can tread the operation as Immutable\n if (this.immutableService.isActive()) {\n this.immutableService.setRowData(rowData);\n }\n else {\n this.selectionService.reset();\n this.clientSideRowModel.setRowData(rowData);\n }\n }\n /** Set the top pinned rows. Call with no rows / undefined to clear top pinned rows. */\n setPinnedTopRowData(rows) {\n this.pinnedRowModel.setPinnedTopRowData(rows);\n }\n /** Set the bottom pinned rows. Call with no rows / undefined to clear bottom pinned rows. */\n setPinnedBottomRowData(rows) {\n this.pinnedRowModel.setPinnedBottomRowData(rows);\n }\n /** Gets the number of top pinned rows. */\n getPinnedTopRowCount() {\n return this.pinnedRowModel.getPinnedTopRowCount();\n }\n /** Gets the number of bottom pinned rows. */\n getPinnedBottomRowCount() {\n return this.pinnedRowModel.getPinnedBottomRowCount();\n }\n /** Gets the top pinned row with the specified index. */\n getPinnedTopRow(index) {\n return this.pinnedRowModel.getPinnedTopRow(index);\n }\n /** Gets the bottom pinned row with the specified index. */\n getPinnedBottomRow(index) {\n return this.pinnedRowModel.getPinnedBottomRow(index);\n }\n /**\n * Call to set new column definitions. The grid will redraw all the column headers, and then redraw all of the rows.\n */\n setColumnDefs(colDefs, source = \"api\") {\n this.columnModel.setColumnDefs(colDefs, source);\n // Keep gridOptions.columnDefs in sync\n this.gos.set('columnDefs', colDefs, true, { source });\n }\n /** Call to set new auto group column definition. The grid will recreate any auto-group columns if present. */\n setAutoGroupColumnDef(colDef, source = \"api\") {\n this.gos.set('autoGroupColumnDef', colDef, true, { source });\n }\n /** Call to set new Default Column Definition. */\n setDefaultColDef(colDef, source = \"api\") {\n this.gos.set('defaultColDef', colDef, true, { source });\n }\n /** Call to set new Column Types. */\n setColumnTypes(columnTypes, source = \"api\") {\n this.gos.set('columnTypes', columnTypes, true, { source });\n }\n expireValueCache() {\n this.valueCache.expire();\n }\n /**\n * Returns an object with two properties:\n * - `top`: The top pixel position of the current scroll in the grid\n * - `bottom`: The bottom pixel position of the current scroll in the grid\n */\n getVerticalPixelRange() {\n return this.gridBodyCtrl.getScrollFeature().getVScrollPosition();\n }\n /**\n * Returns an object with two properties:\n * - `left`: The left pixel position of the current scroll in the grid\n * - `right`: The right pixel position of the current scroll in the grid\n */\n getHorizontalPixelRange() {\n return this.gridBodyCtrl.getScrollFeature().getHScrollPosition();\n }\n /** If `true`, the horizontal scrollbar will always be present, even if not required. Otherwise, it will only be displayed when necessary. */\n setAlwaysShowHorizontalScroll(show) {\n this.gos.set('alwaysShowHorizontalScroll', show);\n }\n /** If `true`, the vertical scrollbar will always be present, even if not required. Otherwise it will only be displayed when necessary. */\n setAlwaysShowVerticalScroll(show) {\n this.gos.set('alwaysShowVerticalScroll', show);\n }\n /** Performs change detection on all cells, refreshing cells where required. */\n refreshCells(params = {}) {\n this.rowRenderer.refreshCells(params);\n }\n /** Flash rows, columns or individual cells. */\n flashCells(params = {}) {\n this.rowRenderer.flashCells(params);\n }\n /** Remove row(s) from the DOM and recreate them again from scratch. */\n redrawRows(params = {}) {\n const rowNodes = params ? params.rowNodes : undefined;\n this.rowRenderer.redrawRows(rowNodes);\n }\n setFunctionsReadOnly(readOnly) {\n this.gos.set('functionsReadOnly', readOnly);\n }\n /** Redraws the header. Useful if a column name changes, or something else that changes how the column header is displayed. */\n refreshHeader() {\n this.ctrlsService.getHeaderRowContainerCtrls().forEach(c => c.refresh());\n }\n /** Returns `true` if any filter is set. This includes quick filter, column filter, external filter or advanced filter. */\n isAnyFilterPresent() {\n return this.filterManager.isAnyFilterPresent();\n }\n /** Returns `true` if any column filter is set, otherwise `false`. */\n isColumnFilterPresent() {\n return this.filterManager.isColumnFilterPresent() || this.filterManager.isAggregateFilterPresent();\n }\n /** Returns `true` if the Quick Filter is set, otherwise `false`. */\n isQuickFilterPresent() {\n return this.filterManager.isQuickFilterPresent();\n }\n /**\n * Returns the row model inside the table.\n * From here you can see the original rows, rows after filter has been applied,\n * rows after aggregation has been applied, and the final set of 'to be displayed' rows.\n */\n getModel() {\n return this.rowModel;\n }\n /** Expand or collapse a specific row node, optionally expanding/collapsing all of its parent nodes. */\n setRowNodeExpanded(rowNode, expanded, expandParents) {\n if (rowNode) {\n // expand all parents recursively, except root node.\n if (expandParents && rowNode.parent && rowNode.parent.level !== -1) {\n this.setRowNodeExpanded(rowNode.parent, expanded, expandParents);\n }\n rowNode.setExpanded(expanded);\n }\n }\n /**\n * Informs the grid that row group expanded state has changed and it needs to rerender the group nodes.\n * Typically called after updating the row node expanded state explicitly, i.e `rowNode.expanded = false`,\n * across multiple groups and you want to update the grid view in a single rerender instead of on every group change.\n */\n onGroupExpandedOrCollapsed() {\n if (missing(this.clientSideRowModel)) {\n this.logMissingRowModel('onGroupExpandedOrCollapsed', 'clientSide');\n return;\n }\n // we don't really want the user calling this if only one rowNode was expanded, instead they should be\n // calling rowNode.setExpanded(boolean) - this way we do a 'keepRenderedRows=false' so that the whole\n // grid gets refreshed again - otherwise the row with the rowNodes that were changed won't get updated,\n // and thus the expand icon in the group cell won't get 'opened' or 'closed'.\n this.clientSideRowModel.refreshModel({ step: ClientSideRowModelSteps.MAP });\n }\n /**\n * Refresh the Client-Side Row Model, executing the grouping, filtering and sorting again.\n * Optionally provide the step you wish the refresh to apply from. Defaults to `everything`.\n */\n refreshClientSideRowModel(step) {\n if (missing(this.clientSideRowModel)) {\n this.logMissingRowModel('refreshClientSideRowModel', 'clientSide');\n return;\n }\n this.clientSideRowModel.refreshModel(step);\n }\n /** Returns `true` when there are no more animation frames left to process. */\n isAnimationFrameQueueEmpty() {\n return this.animationFrameService.isQueueEmpty();\n }\n flushAllAnimationFrames() {\n this.animationFrameService.flushAllFrames();\n }\n /**\n * Returns the row node with the given ID.\n * The row node ID is the one you provide from the callback `getRowId(params)`,\n * otherwise the ID is a number (cast as string) auto-generated by the grid when\n * the row data is set.\n */\n getRowNode(id) {\n return this.rowModel.getRowNode(id);\n }\n /**\n * Gets the sizes that various UI elements will be rendered at with the current theme.\n * If you override the row or header height using `gridOptions`, the override value you provided will be returned.\n */\n getSizesForCurrentTheme() {\n return {\n rowHeight: this.gos.getRowHeightAsNumber(),\n headerHeight: this.columnModel.getHeaderHeight()\n };\n }\n /** Expand all groups. */\n expandAll() {\n if (this.clientSideRowModel) {\n this.clientSideRowModel.expandOrCollapseAll(true);\n }\n else if (this.serverSideRowModel) {\n this.serverSideRowModel.expandAll(true);\n }\n else {\n this.logMissingRowModel('expandAll', 'clientSide', 'serverSide');\n }\n }\n /** Collapse all groups. */\n collapseAll() {\n if (this.clientSideRowModel) {\n this.clientSideRowModel.expandOrCollapseAll(false);\n }\n else if (this.serverSideRowModel) {\n this.serverSideRowModel.expandAll(false);\n }\n else {\n this.logMissingRowModel('expandAll', 'clientSide', 'serverSide');\n }\n }\n /**\n * Registers a callback to a virtual row.\n * A virtual row is a row that is visually rendered on the screen (rows that are not visible because of the scroll position are not rendered).\n * Unlike normal events, you do not need to unregister rendered row listeners.\n * When the rendered row is removed from the grid, all associated rendered row listeners will also be removed.\n * listen for this event if your `cellRenderer` needs to do cleanup when the row no longer exists.\n */\n addRenderedRowListener(eventName, rowIndex, callback) {\n this.rowRenderer.addRenderedRowListener(eventName, rowIndex, callback);\n }\n /** Get the current Quick Filter text from the grid, or `undefined` if none is set. */\n getQuickFilter() {\n return this.gos.get('quickFilterText');\n }\n /** Pass a Quick Filter text into the grid for filtering. */\n setQuickFilter(newFilter) {\n this.gos.set('quickFilterText', newFilter);\n }\n /**\n * @deprecated As of v30, hidden columns are excluded from the Quick Filter by default. To include hidden columns, use `setIncludeHiddenColumnsInQuickFilter` instead.\n */\n setExcludeHiddenColumnsFromQuickFilter(value) {\n logDeprecation('30', 'setExcludeHiddenColumnsFromQuickFilter', undefined, 'Hidden columns are now excluded from the Quick Filter by default. This can be toggled using `setIncludeHiddenColumnsInQuickFilter`');\n this.setIncludeHiddenColumnsInQuickFilter(!value);\n }\n /**\n * Updates the `includeHiddenColumnsInQuickFilter` grid option.\n * By default hidden columns are excluded from the Quick Filter.\n * Set to `true` to include them.\n */\n setIncludeHiddenColumnsInQuickFilter(value) {\n this.gos.set('includeHiddenColumnsInQuickFilter', value);\n }\n /**\n * Updates the `quickFilterParser` grid option,\n * which changes how the Quick Filter splits the Quick Filter text into search terms.\n */\n setQuickFilterParser(quickFilterParser) {\n this.gos.set('quickFilterParser', quickFilterParser);\n }\n /**\n * Updates the `quickFilterMatcher` grid option,\n * which changes the matching logic for whether a row passes the Quick Filter.\n */\n setQuickFilterMatcher(quickFilterMatcher) {\n this.gos.set('quickFilterMatcher', quickFilterMatcher);\n }\n /** Get the state of the Advanced Filter. Used for saving Advanced Filter state */\n getAdvancedFilterModel() {\n if (ModuleRegistry.__assertRegistered(ModuleNames.AdvancedFilterModule, 'api.getAdvancedFilterModel', this.context.getGridId())) {\n return this.filterManager.getAdvancedFilterModel();\n }\n return null;\n }\n /** Set the state of the Advanced Filter. Used for restoring Advanced Filter state */\n setAdvancedFilterModel(advancedFilterModel) {\n this.gos.set('advancedFilterModel', advancedFilterModel);\n }\n /** Enable/disable the Advanced Filter */\n setEnableAdvancedFilter(enabled) {\n this.gos.set('enableAdvancedFilter', enabled);\n }\n /**\n * Updates the `includeHiddenColumnsInAdvancedFilter` grid option.\n * By default hidden columns are excluded from the Advanced Filter.\n * Set to `true` to include them.\n */\n setIncludeHiddenColumnsInAdvancedFilter(value) {\n this.gos.set('includeHiddenColumnsInAdvancedFilter', value);\n }\n /**\n * DOM element to use as the parent for the Advanced Filter, to allow it to appear outside of the grid.\n * Set to `null` to appear inside the grid.\n */\n setAdvancedFilterParent(advancedFilterParent) {\n this.gos.set('advancedFilterParent', advancedFilterParent);\n }\n /** Updates the Advanced Filter Builder parameters. */\n setAdvancedFilterBuilderParams(params) {\n this.gos.set('advancedFilterBuilderParams', params);\n }\n /** Open the Advanced Filter Builder dialog (if enabled). */\n showAdvancedFilterBuilder() {\n if (ModuleRegistry.__assertRegistered(ModuleNames.AdvancedFilterModule, 'api.setAdvancedFilterModel', this.context.getGridId())) {\n this.filterManager.showAdvancedFilterBuilder('api');\n }\n }\n /**\n * Set all of the provided nodes selection state to the provided value.\n */\n setNodesSelected(params) {\n const allNodesValid = params.nodes.every(node => {\n if (node.rowPinned) {\n console.warn('AG Grid: cannot select pinned rows');\n return false;\n }\n if (node.id === undefined) {\n console.warn('AG Grid: cannot select node until id for node is known');\n return false;\n }\n return true;\n });\n if (!allNodesValid) {\n return;\n }\n const { nodes, source, newValue } = params;\n const nodesAsRowNode = nodes;\n this.selectionService.setNodesSelected({ nodes: nodesAsRowNode, source: source !== null && source !== void 0 ? source : 'api', newValue });\n }\n /**\n * Select all rows, regardless of filtering and rows that are not visible due to grouping being enabled and their groups not expanded.\n * @param source Source property that will appear in the `selectionChanged` event, defaults to `'apiSelectAll'`\n */\n selectAll(source = 'apiSelectAll') {\n this.selectionService.selectAllRowNodes({ source });\n }\n /**\n * Clear all row selections, regardless of filtering.\n * @param source Source property that will appear in the `selectionChanged` event, defaults to `'apiSelectAll'`\n */\n deselectAll(source = 'apiSelectAll') {\n this.selectionService.deselectAllRowNodes({ source });\n }\n /**\n * Select all filtered rows.\n * @param source Source property that will appear in the `selectionChanged` event, defaults to `'apiSelectAllFiltered'`\n */\n selectAllFiltered(source = 'apiSelectAllFiltered') {\n this.selectionService.selectAllRowNodes({ source, justFiltered: true });\n }\n /**\n * Clear all filtered selections.\n * @param source Source property that will appear in the `selectionChanged` event, defaults to `'apiSelectAllFiltered'`\n */\n deselectAllFiltered(source = 'apiSelectAllFiltered') {\n this.selectionService.deselectAllRowNodes({ source, justFiltered: true });\n }\n /**\n * Returns an object containing rules matching the selected rows in the SSRM.\n *\n * If `groupSelectsChildren=false` the returned object will be flat, and will conform to IServerSideSelectionState.\n * If `groupSelectsChildren=true` the returned object will be hierarchical, and will conform to IServerSideGroupSelectionState.\n */\n getServerSideSelectionState() {\n if (missing(this.serverSideRowModel)) {\n this.logMissingRowModel('getServerSideSelectionState', 'serverSide');\n return null;\n }\n return this.selectionService.getServerSideSelectionState();\n }\n /**\n * Set the rules matching the selected rows in the SSRM.\n *\n * If `groupSelectsChildren=false` the param will be flat, and should conform to IServerSideSelectionState.\n * If `groupSelectsChildren=true` the param will be hierarchical, and should conform to IServerSideGroupSelectionState.\n */\n setServerSideSelectionState(state) {\n if (missing(this.serverSideRowModel)) {\n this.logMissingRowModel('setServerSideSelectionState', 'serverSide');\n return;\n }\n this.selectionService.setServerSideSelectionState(state);\n }\n /**\n * Select all rows on the current page.\n * @param source Source property that will appear in the `selectionChanged` event, defaults to `'apiSelectAllCurrentPage'`\n */\n selectAllOnCurrentPage(source = 'apiSelectAllCurrentPage') {\n this.selectionService.selectAllRowNodes({ source, justCurrentPage: true });\n }\n /**\n * Clear all filtered on the current page.\n * @param source Source property that will appear in the `selectionChanged` event, defaults to `'apiSelectAllCurrentPage'`\n */\n deselectAllOnCurrentPage(source = 'apiSelectAllCurrentPage') {\n this.selectionService.deselectAllRowNodes({ source, justCurrentPage: true });\n }\n /**\n * Sets columns to adjust in size to fit the grid horizontally. If inferring cell data types with custom column types\n * and row data is provided asynchronously, the column sizing will happen asynchronously when row data is added.\n * To always perform this synchronously, set `cellDataType = false` on the default column definition.\n **/\n sizeColumnsToFit(params) {\n this.gridBodyCtrl.sizeColumnsToFit(params);\n }\n /** Show the 'loading' overlay. */\n showLoadingOverlay() {\n this.overlayWrapperComp.showLoadingOverlay();\n }\n /** Show the 'no rows' overlay. */\n showNoRowsOverlay() {\n this.overlayWrapperComp.showNoRowsOverlay();\n }\n /** Hides the overlay if showing. */\n hideOverlay() {\n this.overlayWrapperComp.hideOverlay();\n }\n /**\n * Returns an unsorted list of selected nodes.\n * Getting the underlying node (rather than the data) is useful when working with tree / aggregated data,\n * as the node can be traversed.\n */\n getSelectedNodes() {\n return this.selectionService.getSelectedNodes();\n }\n /** Returns an unsorted list of selected rows (i.e. row data that you provided). */\n getSelectedRows() {\n return this.selectionService.getSelectedRows();\n }\n /**\n * Returns a list of all selected nodes at 'best cost', a feature to be used with groups / trees.\n * If a group has all its children selected, then the group appears in the result, but not the children.\n * Designed for use with `'children'` as the group selection type, where groups don't actually appear in the selection normally.\n */\n getBestCostNodeSelection() {\n if (missing(this.clientSideRowModel)) {\n this.logMissingRowModel('getBestCostNodeSelection', 'clientSide');\n return;\n }\n return this.selectionService.getBestCostNodeSelection();\n }\n /** Retrieve rendered nodes. Due to virtualisation this will contain only the current visible rows and those in the buffer. */\n getRenderedNodes() {\n return this.rowRenderer.getRenderedNodes();\n }\n /**\n * Ensures the column is visible by scrolling the table if needed.\n *\n * This will have no effect before the firstDataRendered event has fired.\n *\n * @param key - The column to ensure visible\n * @param position - Where the column will be positioned.\n * - `auto` - Scrolls the minimum amount to make sure the column is visible.\n * - `start` - Scrolls the column to the start of the viewport.\n * - `middle` - Scrolls the column to the middle of the viewport.\n * - `end` - Scrolls the column to the end of the viewport.\n */\n ensureColumnVisible(key, position = 'auto') {\n this.gridBodyCtrl.getScrollFeature().ensureColumnVisible(key, position);\n }\n /**\n * Vertically scrolls the grid until the provided row index is inside the visible viewport.\n * If a position is provided, the grid will attempt to scroll until the row is at the given position within the viewport.\n * This will have no effect before the firstDataRendered event has fired.\n */\n ensureIndexVisible(index, position) {\n this.gridBodyCtrl.getScrollFeature().ensureIndexVisible(index, position);\n }\n /**\n * Vertically scrolls the grid until the provided row (or a row matching the provided comparator) is inside the visible viewport.\n * If a position is provided, the grid will attempt to scroll until the row is at the given position within the viewport.\n * This will have no effect before the firstDataRendered event has fired.\n */\n ensureNodeVisible(nodeSelector, position = null) {\n this.gridBodyCtrl.getScrollFeature().ensureNodeVisible(nodeSelector, position);\n }\n /**\n * Similar to `forEachNode`, except lists all the leaf nodes.\n * This effectively goes through all the data that you provided to the grid before the grid performed any grouping.\n * If using tree data, goes through all the nodes for the data you provided, including nodes that have children,\n * but excluding groups the grid created where gaps were missing in the hierarchy.\n */\n forEachLeafNode(callback) {\n if (missing(this.clientSideRowModel)) {\n this.logMissingRowModel('forEachLeafNode', 'clientSide');\n return;\n }\n this.clientSideRowModel.forEachLeafNode(callback);\n }\n /**\n * Iterates through each node (row) in the grid and calls the callback for each node.\n * This works similar to the `forEach` method on a JavaScript array.\n * This is called for every node, ignoring any filtering or sorting applied within the grid.\n * If using the Infinite Row Model, then this gets called for each page loaded in the page cache.\n */\n forEachNode(callback, includeFooterNodes) {\n this.rowModel.forEachNode(callback, includeFooterNodes);\n }\n /** Similar to `forEachNode`, except skips any filtered out data. */\n forEachNodeAfterFilter(callback) {\n if (missing(this.clientSideRowModel)) {\n this.logMissingRowModel('forEachNodeAfterFilter', 'clientSide');\n return;\n }\n this.clientSideRowModel.forEachNodeAfterFilter(callback);\n }\n /** Similar to `forEachNodeAfterFilter`, except the callbacks are called in the order the rows are displayed in the grid. */\n forEachNodeAfterFilterAndSort(callback) {\n if (missing(this.clientSideRowModel)) {\n this.logMissingRowModel('forEachNodeAfterFilterAndSort', 'clientSide');\n return;\n }\n this.clientSideRowModel.forEachNodeAfterFilterAndSort(callback);\n }\n /**\n * Returns the filter component instance for a column.\n * `key` can be a string field name or a ColDef object (matches on object reference, useful if field names are not unique).\n * If your filter is created asynchronously, `getFilterInstance` will return `null` so you will need to use the `callback` to access the filter instance instead.\n */\n getFilterInstance(key, callback) {\n return this.filterManager.getFilterInstance(key, callback);\n }\n /** Destroys a filter. Useful to force a particular filter to be created from scratch again. */\n destroyFilter(key) {\n const column = this.columnModel.getPrimaryColumn(key);\n if (column) {\n return this.filterManager.destroyFilter(column, 'api');\n }\n }\n /** Gets the status panel instance corresponding to the supplied `id`. */\n getStatusPanel(key) {\n if (!ModuleRegistry.__assertRegistered(ModuleNames.StatusBarModule, 'api.getStatusPanel', this.context.getGridId())) {\n return;\n }\n const comp = this.statusBarService.getStatusPanel(key);\n return unwrapUserComp(comp);\n }\n getColumnDef(key) {\n const column = this.columnModel.getPrimaryColumn(key);\n if (column) {\n return column.getColDef();\n }\n return null;\n }\n /**\n * Returns the current column definitions.\n */\n getColumnDefs() { return this.columnModel.getColumnDefs(); }\n /**\n * Informs the grid that a filter has changed. This is typically called after a filter change through one of the filter APIs.\n * @param source The source of the filter change event. If not specified defaults to `'api'`.\n */\n onFilterChanged(source = 'api') {\n this.filterManager.onFilterChanged({ source });\n }\n /**\n * Gets the grid to act as if the sort was changed.\n * Useful if you update some values and want to get the grid to reorder them according to the new values.\n */\n onSortChanged() {\n this.sortController.onSortChanged('api');\n }\n /**\n * Sets the state of all the column filters. Provide it with what you get from `getFilterModel()` to restore filter state.\n * If inferring cell data types, and row data is provided asynchronously and is yet to be set,\n * the filter model will be applied asynchronously after row data is added.\n * To always perform this synchronously, set `cellDataType = false` on the default column definition,\n * or provide cell data types for every column.\n */\n setFilterModel(model) {\n this.filterManager.setFilterModel(model);\n }\n /** Gets the current state of all the column filters. Used for saving filter state. */\n getFilterModel() {\n return this.filterManager.getFilterModel();\n }\n /** Returns the focused cell (or the last focused cell if the grid lost focus). */\n getFocusedCell() {\n return this.focusService.getFocusedCell();\n }\n /** Clears the focused cell. */\n clearFocusedCell() {\n return this.focusService.clearFocusedCell();\n }\n /** Sets the focus to the specified cell. `rowPinned` can be either 'top', 'bottom' or null (for not pinned). */\n setFocusedCell(rowIndex, colKey, rowPinned) {\n this.focusService.setFocusedCell({ rowIndex, column: colKey, rowPinned, forceBrowserFocus: true });\n }\n /** Sets the `suppressRowDrag` property. */\n setSuppressRowDrag(value) {\n this.gos.set('suppressRowDrag', value);\n }\n /** Sets the `suppressMoveWhenRowDragging` property. */\n setSuppressMoveWhenRowDragging(value) {\n this.gos.set('suppressMoveWhenRowDragging', value);\n }\n /** Sets the `suppressRowClickSelection` property. */\n setSuppressRowClickSelection(value) {\n this.gos.set('suppressRowClickSelection', value);\n }\n /** Adds a drop zone outside of the grid where rows can be dropped. */\n addRowDropZone(params) {\n this.gridBodyCtrl.getRowDragFeature().addRowDropZone(params);\n }\n /** Removes an external drop zone added by `addRowDropZone`. */\n removeRowDropZone(params) {\n const activeDropTarget = this.dragAndDropService.findExternalZone(params);\n if (activeDropTarget) {\n this.dragAndDropService.removeDropTarget(activeDropTarget);\n }\n }\n /** Returns the `RowDropZoneParams` to be used by another grid's `addRowDropZone` method. */\n getRowDropZoneParams(events) {\n return this.gridBodyCtrl.getRowDragFeature().getRowDropZone(events);\n }\n /** Sets the height in pixels for the row containing the column label header. */\n setHeaderHeight(headerHeight) {\n this.gos.set('headerHeight', headerHeight);\n }\n /**\n * Switch between layout options: `normal`, `autoHeight`, `print`.\n * Defaults to `normal` if no domLayout provided.\n */\n setDomLayout(domLayout) {\n this.gos.set('domLayout', domLayout);\n }\n /** Sets the `enableCellTextSelection` property. */\n setEnableCellTextSelection(selectable) {\n this.gridBodyCtrl.setCellTextSelection(selectable);\n }\n /** Sets the preferred direction for the selection fill handle. */\n setFillHandleDirection(direction) {\n this.gos.set('fillHandleDirection', direction);\n }\n /** Sets the height in pixels for the rows containing header column groups. */\n setGroupHeaderHeight(headerHeight) {\n this.gos.set('groupHeaderHeight', headerHeight);\n }\n /** Sets the height in pixels for the row containing the floating filters. */\n setFloatingFiltersHeight(headerHeight) {\n this.gos.set('floatingFiltersHeight', headerHeight);\n }\n /** Sets the height in pixels for the row containing the columns when in pivot mode. */\n setPivotHeaderHeight(headerHeight) {\n this.gos.set('pivotHeaderHeight', headerHeight);\n }\n /** Sets the height in pixels for the row containing header column groups when in pivot mode. */\n setPivotGroupHeaderHeight(headerHeight) {\n this.gos.set('pivotGroupHeaderHeight', headerHeight);\n }\n setPivotMode(pivotMode) {\n this.columnModel.setPivotMode(pivotMode);\n }\n setAnimateRows(animateRows) {\n this.gos.set('animateRows', animateRows);\n }\n setIsExternalFilterPresent(isExternalFilterPresentFunc) {\n this.gos.set('isExternalFilterPresent', isExternalFilterPresentFunc);\n }\n setDoesExternalFilterPass(doesExternalFilterPassFunc) {\n this.gos.set('doesExternalFilterPass', doesExternalFilterPassFunc);\n }\n setNavigateToNextCell(navigateToNextCellFunc) {\n this.gos.set('navigateToNextCell', navigateToNextCellFunc);\n }\n setTabToNextCell(tabToNextCellFunc) {\n this.gos.set('tabToNextCell', tabToNextCellFunc);\n }\n setTabToNextHeader(tabToNextHeaderFunc) {\n this.gos.set('tabToNextHeader', tabToNextHeaderFunc);\n }\n setNavigateToNextHeader(navigateToNextHeaderFunc) {\n this.gos.set('navigateToNextHeader', navigateToNextHeaderFunc);\n }\n setRowGroupPanelShow(rowGroupPanelShow) {\n this.gos.set('rowGroupPanelShow', rowGroupPanelShow);\n }\n setGetGroupRowAgg(getGroupRowAggFunc) {\n this.gos.set('getGroupRowAgg', getGroupRowAggFunc);\n }\n setGetBusinessKeyForNode(getBusinessKeyForNodeFunc) {\n this.gos.set('getBusinessKeyForNode', getBusinessKeyForNodeFunc);\n }\n setGetChildCount(getChildCountFunc) {\n this.gos.set('getChildCount', getChildCountFunc);\n }\n setProcessRowPostCreate(processRowPostCreateFunc) {\n this.gos.set('processRowPostCreate', processRowPostCreateFunc);\n }\n setGetRowId(getRowIdFunc) {\n this.gos.set('getRowId', getRowIdFunc);\n }\n setGetRowClass(rowClassFunc) {\n this.gos.set('getRowClass', rowClassFunc);\n }\n setIsFullWidthRow(isFullWidthRowFunc) {\n this.gos.set('isFullWidthRow', isFullWidthRowFunc);\n }\n setIsRowSelectable(isRowSelectableFunc) {\n this.gos.set('isRowSelectable', isRowSelectableFunc);\n }\n setIsRowMaster(isRowMasterFunc) {\n this.gos.set('isRowMaster', isRowMasterFunc);\n }\n setPostSortRows(postSortRowsFunc) {\n this.gos.set('postSortRows', postSortRowsFunc);\n }\n setGetDocument(getDocumentFunc) {\n this.gos.set('getDocument', getDocumentFunc);\n }\n setGetContextMenuItems(getContextMenuItemsFunc) {\n this.gos.set('getContextMenuItems', getContextMenuItemsFunc);\n }\n setGetMainMenuItems(getMainMenuItemsFunc) {\n this.gos.set('getMainMenuItems', getMainMenuItemsFunc);\n }\n setProcessCellForClipboard(processCellForClipboardFunc) {\n this.gos.set('processCellForClipboard', processCellForClipboardFunc);\n }\n setSendToClipboard(sendToClipboardFunc) {\n this.gos.set('sendToClipboard', sendToClipboardFunc);\n }\n setProcessCellFromClipboard(processCellFromClipboardFunc) {\n this.gos.set('processCellFromClipboard', processCellFromClipboardFunc);\n }\n /** @deprecated v28 use `setProcessPivotResultColDef` instead */\n setProcessSecondaryColDef(processSecondaryColDefFunc) {\n logDeprecation('28.0', 'setProcessSecondaryColDef', 'setProcessPivotResultColDef');\n this.setProcessPivotResultColDef(processSecondaryColDefFunc);\n }\n /** @deprecated v28 use `setProcessPivotResultColGroupDef` instead */\n setProcessSecondaryColGroupDef(processSecondaryColGroupDefFunc) {\n logDeprecation('28.0', 'setProcessSecondaryColGroupDef', 'setProcessPivotResultColGroupDef');\n this.setProcessPivotResultColGroupDef(processSecondaryColGroupDefFunc);\n }\n setProcessPivotResultColDef(processPivotResultColDefFunc) {\n this.gos.set('processPivotResultColDef', processPivotResultColDefFunc);\n }\n setProcessPivotResultColGroupDef(processPivotResultColGroupDefFunc) {\n this.gos.set('processPivotResultColGroupDef', processPivotResultColGroupDefFunc);\n }\n setPostProcessPopup(postProcessPopupFunc) {\n this.gos.set('postProcessPopup', postProcessPopupFunc);\n }\n setInitialGroupOrderComparator(initialGroupOrderComparatorFunc) {\n this.gos.set('initialGroupOrderComparator', initialGroupOrderComparatorFunc);\n }\n setGetChartToolbarItems(getChartToolbarItemsFunc) {\n this.gos.set('getChartToolbarItems', getChartToolbarItemsFunc);\n }\n setPaginationNumberFormatter(paginationNumberFormatterFunc) {\n this.gos.set('paginationNumberFormatter', paginationNumberFormatterFunc);\n }\n /** @deprecated v28 use setGetServerSideGroupLevelParams instead */\n setGetServerSideStoreParams(getServerSideStoreParamsFunc) {\n logDeprecation('28.0', 'setGetServerSideStoreParams', 'setGetServerSideGroupLevelParams');\n this.setGetServerSideGroupLevelParams(getServerSideStoreParamsFunc);\n }\n setGetServerSideGroupLevelParams(getServerSideGroupLevelParamsFunc) {\n this.gos.set('getServerSideGroupLevelParams', getServerSideGroupLevelParamsFunc);\n }\n setIsServerSideGroupOpenByDefault(isServerSideGroupOpenByDefaultFunc) {\n this.gos.set('isServerSideGroupOpenByDefault', isServerSideGroupOpenByDefaultFunc);\n }\n setIsApplyServerSideTransaction(isApplyServerSideTransactionFunc) {\n this.gos.set('isApplyServerSideTransaction', isApplyServerSideTransactionFunc);\n }\n setIsServerSideGroup(isServerSideGroupFunc) {\n this.gos.set('isServerSideGroup', isServerSideGroupFunc);\n }\n setGetServerSideGroupKey(getServerSideGroupKeyFunc) {\n this.gos.set('getServerSideGroupKey', getServerSideGroupKeyFunc);\n }\n setGetRowStyle(rowStyleFunc) {\n this.gos.set('getRowStyle', rowStyleFunc);\n }\n setGetRowHeight(rowHeightFunc) {\n this.gos.set('getRowHeight', rowHeightFunc);\n }\n assertSideBarLoaded(apiMethod) {\n return ModuleRegistry.__assertRegistered(ModuleNames.SideBarModule, 'api.' + apiMethod, this.context.getGridId());\n }\n /** Returns `true` if the side bar is visible. */\n isSideBarVisible() {\n return this.assertSideBarLoaded('isSideBarVisible') && this.sideBarComp.isDisplayed();\n }\n /** Show/hide the entire side bar, including any visible panel and the tab buttons. */\n setSideBarVisible(show) {\n if (this.assertSideBarLoaded('setSideBarVisible')) {\n this.sideBarComp.setDisplayed(show);\n }\n }\n /** Sets the side bar position relative to the grid. Possible values are `'left'` or `'right'`. */\n setSideBarPosition(position) {\n if (this.assertSideBarLoaded('setSideBarPosition')) {\n this.sideBarComp.setSideBarPosition(position);\n }\n }\n /** Opens a particular tool panel. Provide the ID of the tool panel to open. */\n openToolPanel(key) {\n if (this.assertSideBarLoaded('openToolPanel')) {\n this.sideBarComp.openToolPanel(key, 'api');\n }\n }\n /** Closes the currently open tool panel (if any). */\n closeToolPanel() {\n if (this.assertSideBarLoaded('closeToolPanel')) {\n this.sideBarComp.close('api');\n }\n }\n /** Returns the ID of the currently shown tool panel if any, otherwise `null`. */\n getOpenedToolPanel() {\n if (this.assertSideBarLoaded('getOpenedToolPanel')) {\n return this.sideBarComp.openedItem();\n }\n return null;\n }\n /** Force refresh all tool panels by calling their `refresh` method. */\n refreshToolPanel() {\n if (this.assertSideBarLoaded('refreshToolPanel')) {\n this.sideBarComp.refresh();\n }\n }\n /** Returns `true` if the tool panel is showing, otherwise `false`. */\n isToolPanelShowing() {\n return this.assertSideBarLoaded('isToolPanelShowing') && this.sideBarComp.isToolPanelShowing();\n }\n /** Gets the tool panel instance corresponding to the supplied `id`. */\n getToolPanelInstance(id) {\n if (this.assertSideBarLoaded('getToolPanelInstance')) {\n const comp = this.sideBarComp.getToolPanelInstance(id);\n return unwrapUserComp(comp);\n }\n }\n /** Returns the current side bar configuration. If a shortcut was used, returns the detailed long form. */\n getSideBar() {\n if (this.assertSideBarLoaded('getSideBar')) {\n return this.sideBarComp.getDef();\n }\n return undefined;\n }\n /** Resets the side bar to the provided configuration. The parameter is the same as the sideBar grid property. The side bar is re-created from scratch with the new config. */\n setSideBar(def) {\n this.gos.set('sideBar', def);\n }\n setSuppressClipboardPaste(value) {\n this.gos.set('suppressClipboardPaste', value);\n }\n /** Tells the grid to recalculate the row heights. */\n resetRowHeights() {\n if (exists(this.clientSideRowModel)) {\n if (this.columnModel.isAutoRowHeightActive()) {\n console.warn('AG Grid: calling gridApi.resetRowHeights() makes no sense when using Auto Row Height.');\n return;\n }\n this.clientSideRowModel.resetRowHeights();\n }\n }\n setGroupRemoveSingleChildren(value) {\n this.gos.set('groupRemoveSingleChildren', value);\n }\n setGroupRemoveLowestSingleChildren(value) {\n this.gos.set('groupRemoveLowestSingleChildren', value);\n }\n setGroupDisplayType(value) {\n this.gos.set('groupDisplayType', value);\n }\n /**\n * Sets the `groupIncludeFooter` property\n */\n setGroupIncludeFooter(value) {\n this.gos.set('groupIncludeFooter', value);\n }\n /**\n * Sets the `groupIncludeTotalFooter` property\n */\n setGroupIncludeTotalFooter(value) {\n this.gos.set('groupIncludeTotalFooter', value);\n }\n setRowClass(className) {\n this.gos.set('rowClass', className);\n }\n /** Sets the `deltaSort` property */\n setDeltaSort(enable) {\n this.gos.set('deltaSort', enable);\n }\n /**\n * Sets the `rowCount` and `maxRowFound` properties.\n * The second parameter, `maxRowFound`, is optional and if left out, only `rowCount` is set.\n * Set `rowCount` to adjust the height of the vertical scroll.\n * Set `maxRowFound` to enable / disable searching for more rows.\n * Use this method if you add or remove rows into the dataset and need to reset the number of rows or instruct the grid that the entire row count is no longer known.\n */\n setRowCount(rowCount, maxRowFound) {\n if (this.serverSideRowModel) {\n if (this.columnModel.isRowGroupEmpty()) {\n this.serverSideRowModel.setRowCount(rowCount, maxRowFound);\n return;\n }\n console.error('AG Grid: setRowCount cannot be used while using row grouping.');\n return;\n }\n if (this.infiniteRowModel) {\n this.infiniteRowModel.setRowCount(rowCount, maxRowFound);\n return;\n }\n this.logMissingRowModel('setRowCount', 'infinite', 'serverSide');\n }\n /** Tells the grid a row height has changed. To be used after calling `rowNode.setRowHeight(newHeight)`. */\n onRowHeightChanged() {\n if (this.clientSideRowModel) {\n this.clientSideRowModel.onRowHeightChanged();\n }\n else if (this.serverSideRowModel) {\n this.serverSideRowModel.onRowHeightChanged();\n }\n }\n /**\n * Gets the value for a column for a particular `rowNode` (row).\n * This is useful if you want the raw value of a cell e.g. if implementing your own CSV export.\n */\n getValue(colKey, rowNode) {\n let column = this.columnModel.getPrimaryColumn(colKey);\n if (missing(column)) {\n column = this.columnModel.getGridColumn(colKey);\n }\n if (missing(column)) {\n return null;\n }\n return this.valueService.getValue(column, rowNode);\n }\n /** Add an event listener for the specified `eventType`. Works similar to `addEventListener` for a browser DOM element. */\n addEventListener(eventType, listener) {\n const async = this.gos.useAsyncEvents();\n this.eventService.addEventListener(eventType, listener, async);\n }\n /** Add an event listener for all event types coming from the grid. */\n addGlobalListener(listener) {\n const async = this.gos.useAsyncEvents();\n this.eventService.addGlobalListener(listener, async);\n }\n /** Remove an event listener. */\n removeEventListener(eventType, listener) {\n const async = this.gos.useAsyncEvents();\n this.eventService.removeEventListener(eventType, listener, async);\n }\n /** Remove a global event listener. */\n removeGlobalListener(listener) {\n const async = this.gos.useAsyncEvents();\n this.eventService.removeGlobalListener(listener, async);\n }\n dispatchEvent(event) {\n this.eventService.dispatchEvent(event);\n }\n /** Will destroy the grid and release resources. If you are using a framework you do not need to call this, as the grid links in with the framework lifecycle. However if you are using Web Components or native JavaScript, you do need to call this, to avoid a memory leak in your application. */\n destroy() {\n // this is needed as GridAPI is a bean, and GridAPI.destroy() is called as part\n // of context.destroy(). so we need to stop the infinite loop.\n if (this.destroyCalled) {\n return;\n }\n this.destroyCalled = true;\n this.dispatchEvent({ type: Events.EVENT_GRID_PRE_DESTROYED });\n // destroy the UI first (as they use the services)\n const gridCtrl = this.ctrlsService.getGridCtrl();\n if (gridCtrl) {\n gridCtrl.destroyGridUi();\n }\n // destroy the services\n this.context.destroy();\n }\n cleanDownReferencesToAvoidMemoryLeakInCaseApplicationIsKeepingReferenceToDestroyedGrid() {\n // some users were raising support issues with regards memory leaks. the problem was the customers applications\n // were keeping references to the API. trying to educate them all would be difficult, easier to just remove\n // all references in the API so at least the core grid can be garbage collected.\n //\n // wait about 100ms before clearing down the references, in case user has some cleanup to do,\n // and needs to deference the API first\n setTimeout(removeAllReferences.bind(window, this, 'Grid API'), 100);\n }\n warnIfDestroyed(methodName) {\n if (this.destroyCalled) {\n console.warn(`AG Grid: Grid API method ${methodName} was called on a grid that was destroyed.`);\n }\n return this.destroyCalled;\n }\n /** Reset the Quick Filter cache text on every rowNode. */\n resetQuickFilter() {\n if (this.warnIfDestroyed('resetQuickFilter')) {\n return;\n }\n this.filterManager.resetQuickFilterCache();\n }\n /** Returns the list of selected cell ranges. */\n getCellRanges() {\n if (this.rangeService) {\n return this.rangeService.getCellRanges();\n }\n ModuleRegistry.__assertRegistered(ModuleNames.RangeSelectionModule, 'api.getCellRanges', this.context.getGridId());\n return null;\n }\n /** Adds the provided cell range to the selected ranges. */\n addCellRange(params) {\n if (this.rangeService) {\n this.rangeService.addCellRange(params);\n return;\n }\n ModuleRegistry.__assertRegistered(ModuleNames.RangeSelectionModule, 'api.addCellRange', this.context.getGridId());\n }\n /** Clears the selected ranges. */\n clearRangeSelection() {\n if (this.rangeService) {\n this.rangeService.removeAllCellRanges();\n }\n ModuleRegistry.__assertRegistered(ModuleNames.RangeSelectionModule, 'gridApi.clearRangeSelection', this.context.getGridId());\n }\n /** Reverts the last cell edit. */\n undoCellEditing() {\n this.undoRedoService.undo('api');\n }\n /** Re-applies the most recently undone cell edit. */\n redoCellEditing() {\n this.undoRedoService.redo('api');\n }\n /** Returns current number of available cell edit undo operations. */\n getCurrentUndoSize() {\n return this.undoRedoService.getCurrentUndoStackSize();\n }\n /** Returns current number of available cell edit redo operations. */\n getCurrentRedoSize() {\n return this.undoRedoService.getCurrentRedoStackSize();\n }\n /** Returns a list of models with information about the charts that are currently rendered from the grid. */\n getChartModels() {\n if (ModuleRegistry.__assertRegistered(ModuleNames.GridChartsModule, 'api.getChartModels', this.context.getGridId())) {\n return this.chartService.getChartModels();\n }\n }\n /** Returns the `ChartRef` using the supplied `chartId`. */\n getChartRef(chartId) {\n if (ModuleRegistry.__assertRegistered(ModuleNames.GridChartsModule, 'api.getChartRef', this.context.getGridId())) {\n return this.chartService.getChartRef(chartId);\n }\n }\n /** Returns a base64-encoded image data URL for the referenced chartId. */\n getChartImageDataURL(params) {\n if (ModuleRegistry.__assertRegistered(ModuleNames.GridChartsModule, 'api.getChartImageDataURL', this.context.getGridId())) {\n return this.chartService.getChartImageDataURL(params);\n }\n }\n /** Starts a browser-based image download for the referenced chartId. */\n downloadChart(params) {\n if (ModuleRegistry.__assertRegistered(ModuleNames.GridChartsModule, 'api.downloadChart', this.context.getGridId())) {\n return this.chartService.downloadChart(params);\n }\n }\n /** Open the Chart Tool Panel. */\n openChartToolPanel(params) {\n if (ModuleRegistry.__assertRegistered(ModuleNames.GridChartsModule, 'api.openChartToolPanel', this.context.getGridId())) {\n return this.chartService.openChartToolPanel(params);\n }\n }\n /** Close the Chart Tool Panel. */\n closeChartToolPanel(params) {\n if (ModuleRegistry.__assertRegistered(ModuleNames.GridChartsModule, 'api.closeChartToolPanel', this.context.getGridId())) {\n return this.chartService.closeChartToolPanel(params.chartId);\n }\n }\n /** Used to programmatically create charts from a range. */\n createRangeChart(params) {\n if (ModuleRegistry.__assertRegistered(ModuleNames.GridChartsModule, 'api.createRangeChart', this.context.getGridId())) {\n return this.chartService.createRangeChart(params);\n }\n }\n /** Used to programmatically create pivot charts from a grid. */\n createPivotChart(params) {\n if (ModuleRegistry.__assertRegistered(ModuleNames.GridChartsModule, 'api.createPivotChart', this.context.getGridId())) {\n return this.chartService.createPivotChart(params);\n }\n }\n /** Used to programmatically create cross filter charts from a range. */\n createCrossFilterChart(params) {\n if (ModuleRegistry.__assertRegistered(ModuleNames.GridChartsModule, 'api.createCrossFilterChart', this.context.getGridId())) {\n return this.chartService.createCrossFilterChart(params);\n }\n }\n /** Used to programmatically update a chart. */\n updateChart(params) {\n if (ModuleRegistry.__assertRegistered(ModuleNames.GridChartsModule, 'api.updateChart', this.context.getGridId())) {\n this.chartService.updateChart(params);\n }\n }\n /** Restores a chart using the `ChartModel` that was previously obtained from `getChartModels()`. */\n restoreChart(chartModel, chartContainer) {\n if (ModuleRegistry.__assertRegistered(ModuleNames.GridChartsModule, 'api.restoreChart', this.context.getGridId())) {\n return this.chartService.restoreChart(chartModel, chartContainer);\n }\n }\n /** Copies data to clipboard by following the same rules as pressing Ctrl+C. */\n copyToClipboard(params) {\n if (ModuleRegistry.__assertRegistered(ModuleNames.ClipboardModule, 'api.copyToClipboard', this.context.getGridId())) {\n this.clipboardService.copyToClipboard(params);\n }\n }\n /** Cuts data to clipboard by following the same rules as pressing Ctrl+X. */\n cutToClipboard(params) {\n if (ModuleRegistry.__assertRegistered(ModuleNames.ClipboardModule, 'api.cutToClipboard', this.context.getGridId())) {\n this.clipboardService.cutToClipboard(params, 'api');\n }\n }\n /** Copies the selected rows to the clipboard. */\n copySelectedRowsToClipboard(params) {\n if (ModuleRegistry.__assertRegistered(ModuleNames.ClipboardModule, 'api.copySelectedRowsToClipboard', this.context.getGridId())) {\n this.clipboardService.copySelectedRowsToClipboard(params);\n }\n }\n /** Copies the selected ranges to the clipboard. */\n copySelectedRangeToClipboard(params) {\n if (ModuleRegistry.__assertRegistered(ModuleNames.ClipboardModule, 'api.copySelectedRangeToClipboard', this.context.getGridId())) {\n this.clipboardService.copySelectedRangeToClipboard(params);\n }\n }\n /** Copies the selected range down, similar to `Ctrl + D` in Excel. */\n copySelectedRangeDown() {\n if (ModuleRegistry.__assertRegistered(ModuleNames.ClipboardModule, 'api.copySelectedRangeDown', this.context.getGridId())) {\n this.clipboardService.copyRangeDown();\n }\n }\n /** Pastes the data from the Clipboard into the focused cell of the grid. If no grid cell is focused, calling this method has no effect. */\n pasteFromClipboard() {\n if (ModuleRegistry.__assertRegistered(ModuleNames.ClipboardModule, 'api.pasteFromClipboard', this.context.getGridId())) {\n this.clipboardService.pasteFromClipboard();\n }\n }\n /** Shows the column menu after and positions it relative to the provided button element. Use in conjunction with your own header template. */\n showColumnMenuAfterButtonClick(colKey, buttonElement) {\n // use grid column so works with pivot mode\n const column = this.columnModel.getGridColumn(colKey);\n this.menuFactory.showMenuAfterButtonClick(column, buttonElement, 'columnMenu');\n }\n /** Shows the column menu after and positions it relative to the mouse event. Use in conjunction with your own header template. */\n showColumnMenuAfterMouseClick(colKey, mouseEvent) {\n // use grid column so works with pivot mode\n let column = this.columnModel.getGridColumn(colKey);\n if (!column) {\n column = this.columnModel.getPrimaryColumn(colKey);\n }\n if (!column) {\n console.error(`AG Grid: column '${colKey}' not found`);\n return;\n }\n this.menuFactory.showMenuAfterMouseEvent(column, mouseEvent);\n }\n /** Hides any visible context menu or column menu. */\n hidePopupMenu() {\n // hide the context menu if in enterprise\n if (this.contextMenuFactory) {\n this.contextMenuFactory.hideActiveMenu();\n }\n // and hide the column menu always\n this.menuFactory.hideActiveMenu();\n }\n /** DOM element to use as the popup parent for grid popups (context menu, column menu etc). */\n setPopupParent(ePopupParent) {\n this.gos.set('popupParent', ePopupParent);\n }\n /** Navigates the grid focus to the next cell, as if tabbing. */\n tabToNextCell(event) {\n return this.navigationService.tabToNextCell(false, event);\n }\n /** Navigates the grid focus to the previous cell, as if shift-tabbing. */\n tabToPreviousCell(event) {\n return this.navigationService.tabToNextCell(true, event);\n }\n /** Returns the list of active cell renderer instances. */\n getCellRendererInstances(params = {}) {\n const res = this.rowRenderer.getCellRendererInstances(params);\n const unwrapped = res.map(unwrapUserComp);\n return unwrapped;\n }\n /** Returns the list of active cell editor instances. Optionally provide parameters to restrict to certain columns / row nodes. */\n getCellEditorInstances(params = {}) {\n const res = this.rowRenderer.getCellEditorInstances(params);\n const unwrapped = res.map(unwrapUserComp);\n return unwrapped;\n }\n /** If the grid is editing, returns back details of the editing cell(s). */\n getEditingCells() {\n return this.rowRenderer.getEditingCells();\n }\n /** If a cell is editing, it stops the editing. Pass `true` if you want to cancel the editing (i.e. don't accept changes). */\n stopEditing(cancel = false) {\n this.rowRenderer.stopEditing(cancel);\n }\n /** Start editing the provided cell. If another cell is editing, the editing will be stopped in that other cell. */\n startEditingCell(params) {\n const column = this.columnModel.getGridColumn(params.colKey);\n if (!column) {\n console.warn(`AG Grid: no column found for ${params.colKey}`);\n return;\n }\n const cellPosition = {\n rowIndex: params.rowIndex,\n rowPinned: params.rowPinned || null,\n column: column\n };\n const notPinned = params.rowPinned == null;\n if (notPinned) {\n this.gridBodyCtrl.getScrollFeature().ensureIndexVisible(params.rowIndex);\n }\n const cell = this.navigationService.getCellByPosition(cellPosition);\n if (!cell) {\n return;\n }\n if (!this.focusService.isCellFocused(cellPosition)) {\n this.focusService.setFocusedCell(cellPosition);\n }\n cell.startRowOrCellEdit(params.key);\n }\n /** Add an aggregation function with the specified key. */\n addAggFunc(key, aggFunc) {\n if (this.aggFuncService) {\n this.aggFuncService.addAggFunc(key, aggFunc);\n }\n }\n /** Add aggregations function with the specified keys. */\n addAggFuncs(aggFuncs) {\n if (this.aggFuncService) {\n this.aggFuncService.addAggFuncs(aggFuncs);\n }\n }\n /** Clears all aggregation functions (including those provided by the grid). */\n clearAggFuncs() {\n if (this.aggFuncService) {\n this.aggFuncService.clear();\n }\n }\n /** Apply transactions to the server side row model. */\n applyServerSideTransaction(transaction) {\n if (!this.serverSideTransactionManager) {\n this.logMissingRowModel('applyServerSideTransaction', 'serverSide');\n return;\n }\n return this.serverSideTransactionManager.applyTransaction(transaction);\n }\n /** Batch apply transactions to the server side row model. */\n applyServerSideTransactionAsync(transaction, callback) {\n if (!this.serverSideTransactionManager) {\n this.logMissingRowModel('applyServerSideTransactionAsync', 'serverSide');\n return;\n }\n return this.serverSideTransactionManager.applyTransactionAsync(transaction, callback);\n }\n /**\n * Applies row data to a server side store.\n * New rows will overwrite rows at the same index in the same way as if provided by a datasource success callback.\n *\n * startRow is only applicable when `suppressServerSideInfiniteScroll=true`\n */\n applyServerSideRowData(params) {\n var _a, _b;\n const startRow = (_a = params.startRow) !== null && _a !== void 0 ? _a : 0;\n const route = (_b = params.route) !== null && _b !== void 0 ? _b : [];\n if (startRow < 0) {\n console.warn(`AG Grid: invalid value ${params.startRow} for startRow, the value should be >= 0`);\n return;\n }\n if (this.serverSideRowModel) {\n this.serverSideRowModel.applyRowData(params.successParams, startRow, route);\n }\n else {\n this.logMissingRowModel('setServerSideDatasource', 'serverSide');\n }\n }\n /** Gets all failed server side loads to retry. */\n retryServerSideLoads() {\n if (!this.serverSideRowModel) {\n this.logMissingRowModel('retryServerSideLoads', 'serverSide');\n return;\n }\n this.serverSideRowModel.retryLoads();\n }\n flushServerSideAsyncTransactions() {\n if (!this.serverSideTransactionManager) {\n this.logMissingRowModel('flushServerSideAsyncTransactions', 'serverSide');\n return;\n }\n return this.serverSideTransactionManager.flushAsyncTransactions();\n }\n /** Update row data. Pass a transaction object with lists for `add`, `remove` and `update`. */\n applyTransaction(rowDataTransaction) {\n if (!this.clientSideRowModel) {\n this.logMissingRowModel('applyTransaction', 'clientSide');\n return;\n }\n return this.clientSideRowModel.updateRowData(rowDataTransaction);\n }\n /** Same as `applyTransaction` except executes asynchronously for efficiency. */\n applyTransactionAsync(rowDataTransaction, callback) {\n if (!this.clientSideRowModel) {\n this.logMissingRowModel('applyTransactionAsync', 'clientSide');\n return;\n }\n this.clientSideRowModel.batchUpdateRowData(rowDataTransaction, callback);\n }\n /** Executes any remaining asynchronous grid transactions, if any are waiting to be executed. */\n flushAsyncTransactions() {\n if (!this.clientSideRowModel) {\n this.logMissingRowModel('flushAsyncTransactions', 'clientSide');\n return;\n }\n this.clientSideRowModel.flushAsyncTransactions();\n }\n setSuppressModelUpdateAfterUpdateTransaction(value) {\n this.gos.set('suppressModelUpdateAfterUpdateTransaction', value);\n }\n /**\n * Marks all the currently loaded blocks in the cache for reload.\n * If you have 10 blocks in the cache, all 10 will be marked for reload.\n * The old data will continue to be displayed until the new data is loaded.\n */\n refreshInfiniteCache() {\n if (this.infiniteRowModel) {\n this.infiniteRowModel.refreshCache();\n }\n else {\n this.logMissingRowModel('refreshInfiniteCache', 'infinite');\n }\n }\n /**\n * Purges the cache.\n * The grid is then told to refresh. Only the blocks required to display the current data on screen are fetched (typically no more than 2).\n * The grid will display nothing while the new blocks are loaded.\n * Use this to immediately remove the old data from the user.\n */\n purgeInfiniteCache() {\n if (this.infiniteRowModel) {\n this.infiniteRowModel.purgeCache();\n }\n else {\n this.logMissingRowModel('purgeInfiniteCache', 'infinite');\n }\n }\n /**\n * Refresh a server-side store level.\n * If you pass no parameters, then the top level store is refreshed.\n * To refresh a child level, pass in the string of keys to get to the desired level.\n * Once the store refresh is complete, the storeRefreshed event is fired.\n */\n refreshServerSide(params) {\n if (!this.serverSideRowModel) {\n this.logMissingRowModel('refreshServerSide', 'serverSide');\n return;\n }\n this.serverSideRowModel.refreshStore(params);\n }\n /** @deprecated v28 use `refreshServerSide` instead */\n refreshServerSideStore(params) {\n logDeprecation('28.0', 'refreshServerSideStore', 'refreshServerSide');\n return this.refreshServerSide(params);\n }\n /** @deprecated v28 use `getServerSideGroupLevelState` instead */\n getServerSideStoreState() {\n logDeprecation('28.0', 'getServerSideStoreState', 'getServerSideGroupLevelState');\n return this.getServerSideGroupLevelState();\n }\n /** Returns info on all server side group levels. */\n getServerSideGroupLevelState() {\n if (!this.serverSideRowModel) {\n this.logMissingRowModel('getServerSideGroupLevelState', 'serverSide');\n return [];\n }\n return this.serverSideRowModel.getStoreState();\n }\n /** The row count defines how many rows the grid allows scrolling to. */\n getInfiniteRowCount() {\n if (this.infiniteRowModel) {\n return this.infiniteRowModel.getRowCount();\n }\n else {\n this.logMissingRowModel('getInfiniteRowCount', 'infinite');\n }\n }\n /** Returns `true` if grid allows for scrolling past the last row to load more rows, thus providing infinite scroll. */\n isLastRowIndexKnown() {\n if (this.infiniteRowModel) {\n return this.infiniteRowModel.isLastRowIndexKnown();\n }\n else {\n this.logMissingRowModel('isLastRowIndexKnown', 'infinite');\n }\n }\n /**\n * Returns an object representing the state of the cache. This is useful for debugging and understanding how the cache is working.\n */\n getCacheBlockState() {\n return this.rowNodeBlockLoader.getBlockState();\n }\n /** Get the index of the first displayed row due to scrolling (includes invisible rendered rows in the buffer). */\n getFirstDisplayedRow() {\n return this.rowRenderer.getFirstVirtualRenderedRow();\n }\n /** Get the index of the last displayed row due to scrolling (includes invisible rendered rows in the buffer). */\n getLastDisplayedRow() {\n return this.rowRenderer.getLastVirtualRenderedRow();\n }\n /** Returns the displayed `RowNode` at the given `index`. */\n getDisplayedRowAtIndex(index) {\n return this.rowModel.getRow(index);\n }\n /** Returns the total number of displayed rows. */\n getDisplayedRowCount() {\n return this.rowModel.getRowCount();\n }\n /** Resets the data type definitions. This will update the columns in the grid. */\n setDataTypeDefinitions(dataTypeDefinitions) {\n this.gos.set('dataTypeDefinitions', dataTypeDefinitions);\n }\n /**\n * Set whether the grid paginates the data or not.\n * - `true` to enable pagination\n * - `false` to disable pagination\n */\n setPagination(value) {\n this.gos.set('pagination', value);\n }\n /**\n * Returns `true` when the last page is known.\n * This will always be `true` if you are using the Client-Side Row Model for pagination.\n * Returns `false` when the last page is not known; this only happens when using Infinite Row Model.\n */\n paginationIsLastPageFound() {\n return this.paginationProxy.isLastPageFound();\n }\n /** Returns how many rows are being shown per page. */\n paginationGetPageSize() {\n return this.paginationProxy.getPageSize();\n }\n /** Sets the `paginationPageSize`, then re-paginates the grid so the changes are applied immediately. */\n paginationSetPageSize(size) {\n this.gos.set('paginationPageSize', size);\n }\n /** Returns the 0-based index of the page which is showing. */\n paginationGetCurrentPage() {\n return this.paginationProxy.getCurrentPage();\n }\n /** Returns the total number of pages. Returns `null` if `paginationIsLastPageFound() === false`. */\n paginationGetTotalPages() {\n return this.paginationProxy.getTotalPages();\n }\n /** The total number of rows. Returns `null` if `paginationIsLastPageFound() === false`. */\n paginationGetRowCount() {\n return this.paginationProxy.getMasterRowCount();\n }\n /** Navigates to the next page. */\n paginationGoToNextPage() {\n this.paginationProxy.goToNextPage();\n }\n /** Navigates to the previous page. */\n paginationGoToPreviousPage() {\n this.paginationProxy.goToPreviousPage();\n }\n /** Navigates to the first page. */\n paginationGoToFirstPage() {\n this.paginationProxy.goToFirstPage();\n }\n /** Navigates to the last page. */\n paginationGoToLastPage() {\n this.paginationProxy.goToLastPage();\n }\n /** Goes to the specified page. If the page requested doesn't exist, it will go to the last page. */\n paginationGoToPage(page) {\n this.paginationProxy.goToPage(page);\n }\n};\n__decorate([\n Optional('immutableService')\n], GridApi.prototype, \"immutableService\", void 0);\n__decorate([\n Optional('csvCreator')\n], GridApi.prototype, \"csvCreator\", void 0);\n__decorate([\n Optional('excelCreator')\n], GridApi.prototype, \"excelCreator\", void 0);\n__decorate([\n Autowired('rowRenderer')\n], GridApi.prototype, \"rowRenderer\", void 0);\n__decorate([\n Autowired('navigationService')\n], GridApi.prototype, \"navigationService\", void 0);\n__decorate([\n Autowired('filterManager')\n], GridApi.prototype, \"filterManager\", void 0);\n__decorate([\n Autowired('columnModel')\n], GridApi.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('selectionService')\n], GridApi.prototype, \"selectionService\", void 0);\n__decorate([\n Autowired('gridOptionsService')\n], GridApi.prototype, \"gos\", void 0);\n__decorate([\n Autowired('valueService')\n], GridApi.prototype, \"valueService\", void 0);\n__decorate([\n Autowired('alignedGridsService')\n], GridApi.prototype, \"alignedGridsService\", void 0);\n__decorate([\n Autowired('eventService')\n], GridApi.prototype, \"eventService\", void 0);\n__decorate([\n Autowired('pinnedRowModel')\n], GridApi.prototype, \"pinnedRowModel\", void 0);\n__decorate([\n Autowired('context')\n], GridApi.prototype, \"context\", void 0);\n__decorate([\n Autowired('rowModel')\n], GridApi.prototype, \"rowModel\", void 0);\n__decorate([\n Autowired('sortController')\n], GridApi.prototype, \"sortController\", void 0);\n__decorate([\n Autowired('paginationProxy')\n], GridApi.prototype, \"paginationProxy\", void 0);\n__decorate([\n Autowired('focusService')\n], GridApi.prototype, \"focusService\", void 0);\n__decorate([\n Autowired('dragAndDropService')\n], GridApi.prototype, \"dragAndDropService\", void 0);\n__decorate([\n Optional('rangeService')\n], GridApi.prototype, \"rangeService\", void 0);\n__decorate([\n Optional('clipboardService')\n], GridApi.prototype, \"clipboardService\", void 0);\n__decorate([\n Optional('aggFuncService')\n], GridApi.prototype, \"aggFuncService\", void 0);\n__decorate([\n Autowired('menuFactory')\n], GridApi.prototype, \"menuFactory\", void 0);\n__decorate([\n Optional('contextMenuFactory')\n], GridApi.prototype, \"contextMenuFactory\", void 0);\n__decorate([\n Autowired('valueCache')\n], GridApi.prototype, \"valueCache\", void 0);\n__decorate([\n Autowired('animationFrameService')\n], GridApi.prototype, \"animationFrameService\", void 0);\n__decorate([\n Optional('statusBarService')\n], GridApi.prototype, \"statusBarService\", void 0);\n__decorate([\n Optional('chartService')\n], GridApi.prototype, \"chartService\", void 0);\n__decorate([\n Optional('undoRedoService')\n], GridApi.prototype, \"undoRedoService\", void 0);\n__decorate([\n Optional('rowNodeBlockLoader')\n], GridApi.prototype, \"rowNodeBlockLoader\", void 0);\n__decorate([\n Optional('ssrmTransactionManager')\n], GridApi.prototype, \"serverSideTransactionManager\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], GridApi.prototype, \"ctrlsService\", void 0);\n__decorate([\n PostConstruct\n], GridApi.prototype, \"init\", null);\n__decorate([\n PreDestroy\n], GridApi.prototype, \"cleanDownReferencesToAvoidMemoryLeakInCaseApplicationIsKeepingReferenceToDestroyedGrid\", null);\nGridApi = __decorate([\n Bean('gridApi')\n], GridApi);\nexport { GridApi };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar QuickFilterService_1;\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { Autowired, Bean, PostConstruct } from \"../context/context.mjs\";\nimport { Events } from \"../eventKeys.mjs\";\nimport { exists } from \"../utils/generic.mjs\";\nlet QuickFilterService = QuickFilterService_1 = class QuickFilterService extends BeanStub {\n constructor() {\n super(...arguments);\n this.quickFilter = null;\n this.quickFilterParts = null;\n }\n postConstruct() {\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PIVOT_MODE_CHANGED, () => this.resetQuickFilterCache());\n this.addManagedListener(this.eventService, Events.EVENT_NEW_COLUMNS_LOADED, () => this.resetQuickFilterCache());\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, () => this.resetQuickFilterCache());\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_VISIBLE, () => {\n if (!this.gridOptionsService.is('includeHiddenColumnsInQuickFilter')) {\n this.resetQuickFilterCache();\n }\n });\n this.addManagedPropertyListener('quickFilterText', (e) => this.setQuickFilter(e.currentValue));\n this.addManagedPropertyListener('includeHiddenColumnsInQuickFilter', () => this.onIncludeHiddenColumnsInQuickFilterChanged());\n this.quickFilter = this.parseQuickFilter(this.gridOptionsService.get('quickFilterText'));\n this.parser = this.gridOptionsService.get('quickFilterParser');\n this.matcher = this.gridOptionsService.get('quickFilterMatcher');\n this.setQuickFilterParts();\n this.addManagedPropertyListeners(['quickFilterMatcher', 'quickFilterParser'], () => this.setQuickFilterParserAndMatcher());\n }\n isQuickFilterPresent() {\n return this.quickFilter !== null;\n }\n doesRowPassQuickFilter(node) {\n const usingCache = this.gridOptionsService.is('cacheQuickFilter');\n if (this.matcher) {\n return this.doesRowPassQuickFilterMatcher(usingCache, node);\n }\n // each part must pass, if any fails, then the whole filter fails\n return this.quickFilterParts.every(part => usingCache ? this.doesRowPassQuickFilterCache(node, part) : this.doesRowPassQuickFilterNoCache(node, part));\n }\n resetQuickFilterCache() {\n this.rowModel.forEachNode(node => node.quickFilterAggregateText = null);\n }\n setQuickFilterParts() {\n const { quickFilter, parser } = this;\n if (quickFilter) {\n this.quickFilterParts = parser ? parser(quickFilter) : quickFilter.split(' ');\n }\n else {\n this.quickFilterParts = null;\n }\n }\n parseQuickFilter(newFilter) {\n if (!exists(newFilter)) {\n return null;\n }\n if (!this.gridOptionsService.isRowModelType('clientSide')) {\n console.warn('AG Grid - Quick filtering only works with the Client-Side Row Model');\n return null;\n }\n return newFilter.toUpperCase();\n }\n setQuickFilter(newFilter) {\n if (newFilter != null && typeof newFilter !== 'string') {\n console.warn(`AG Grid - setQuickFilter() only supports string inputs, received: ${typeof newFilter}`);\n return;\n }\n const parsedFilter = this.parseQuickFilter(newFilter);\n if (this.quickFilter !== parsedFilter) {\n this.quickFilter = parsedFilter;\n this.setQuickFilterParts();\n this.dispatchEvent({ type: QuickFilterService_1.EVENT_QUICK_FILTER_CHANGED });\n }\n }\n setQuickFilterParserAndMatcher() {\n const parser = this.gridOptionsService.get('quickFilterParser');\n const matcher = this.gridOptionsService.get('quickFilterMatcher');\n const hasChanged = parser !== this.parser || matcher !== this.matcher;\n this.parser = parser;\n this.matcher = matcher;\n if (hasChanged) {\n this.setQuickFilterParts();\n this.dispatchEvent({ type: QuickFilterService_1.EVENT_QUICK_FILTER_CHANGED });\n }\n }\n onIncludeHiddenColumnsInQuickFilterChanged() {\n this.columnModel.refreshQuickFilterColumns();\n this.resetQuickFilterCache();\n if (this.isQuickFilterPresent()) {\n this.dispatchEvent({ type: QuickFilterService_1.EVENT_QUICK_FILTER_CHANGED });\n }\n }\n doesRowPassQuickFilterNoCache(node, filterPart) {\n const columns = this.columnModel.getAllColumnsForQuickFilter();\n return columns.some(column => {\n const part = this.getQuickFilterTextForColumn(column, node);\n return exists(part) && part.indexOf(filterPart) >= 0;\n });\n }\n doesRowPassQuickFilterCache(node, filterPart) {\n this.checkGenerateQuickFilterAggregateText(node);\n return node.quickFilterAggregateText.indexOf(filterPart) >= 0;\n }\n doesRowPassQuickFilterMatcher(usingCache, node) {\n let quickFilterAggregateText;\n if (usingCache) {\n this.checkGenerateQuickFilterAggregateText(node);\n quickFilterAggregateText = node.quickFilterAggregateText;\n }\n else {\n quickFilterAggregateText = this.getQuickFilterAggregateText(node);\n }\n const { quickFilterParts, matcher } = this;\n return matcher(quickFilterParts, quickFilterAggregateText);\n }\n checkGenerateQuickFilterAggregateText(node) {\n if (!node.quickFilterAggregateText) {\n node.quickFilterAggregateText = this.getQuickFilterAggregateText(node);\n }\n }\n getQuickFilterTextForColumn(column, node) {\n let value = this.valueService.getValue(column, node, true);\n const colDef = column.getColDef();\n if (colDef.getQuickFilterText) {\n const params = {\n value,\n node,\n data: node.data,\n column,\n colDef,\n api: this.gridOptionsService.api,\n columnApi: this.gridOptionsService.columnApi,\n context: this.gridOptionsService.context\n };\n value = colDef.getQuickFilterText(params);\n }\n return exists(value) ? value.toString().toUpperCase() : null;\n }\n getQuickFilterAggregateText(node) {\n const stringParts = [];\n const columns = this.columnModel.getAllColumnsForQuickFilter();\n columns.forEach(column => {\n const part = this.getQuickFilterTextForColumn(column, node);\n if (exists(part)) {\n stringParts.push(part);\n }\n });\n return stringParts.join(QuickFilterService_1.QUICK_FILTER_SEPARATOR);\n }\n};\nQuickFilterService.EVENT_QUICK_FILTER_CHANGED = 'quickFilterChanged';\nQuickFilterService.QUICK_FILTER_SEPARATOR = '\\n';\n__decorate([\n Autowired('valueService')\n], QuickFilterService.prototype, \"valueService\", void 0);\n__decorate([\n Autowired('columnModel')\n], QuickFilterService.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('rowModel')\n], QuickFilterService.prototype, \"rowModel\", void 0);\n__decorate([\n PostConstruct\n], QuickFilterService.prototype, \"postConstruct\", null);\nQuickFilterService = QuickFilterService_1 = __decorate([\n Bean('quickFilterService')\n], QuickFilterService);\nexport { QuickFilterService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { AgPromise, _ } from '../utils/index.mjs';\nimport { Column } from '../entities/column.mjs';\nimport { Autowired, Bean, Optional, PostConstruct } from '../context/context.mjs';\nimport { Events } from '../events.mjs';\nimport { ModuleNames } from '../modules/moduleNames.mjs';\nimport { ModuleRegistry } from '../modules/moduleRegistry.mjs';\nimport { BeanStub } from '../context/beanStub.mjs';\nimport { convertToSet } from '../utils/set.mjs';\nimport { exists } from '../utils/generic.mjs';\nimport { mergeDeep, cloneObject } from '../utils/object.mjs';\nimport { loadTemplate } from '../utils/dom.mjs';\nimport { FilterComponent } from '../components/framework/componentTypes.mjs';\nimport { unwrapUserComp } from '../gridApi.mjs';\nimport { doOnce } from '../utils/function.mjs';\nimport { QuickFilterService } from './quickFilterService.mjs';\nlet FilterManager = class FilterManager extends BeanStub {\n constructor() {\n super(...arguments);\n this.allColumnFilters = new Map();\n this.allColumnListeners = new Map();\n this.activeAggregateFilters = [];\n this.activeColumnFilters = [];\n // this is true when the grid is processing the filter change. this is used by the cell comps, so that they\n // don't flash when data changes due to filter changes. there is no need to flash when filter changes as the\n // user is in control, so doesn't make sense to show flashing changes. for example, go to main demo where\n // this feature is turned off (hack code to always return false for isSuppressFlashingCellsBecauseFiltering(), put in)\n // 100,000 rows and group by country. then do some filtering. all the cells flash, which is silly.\n this.processingFilterChange = false;\n // when we're waiting for cell data types to be inferred, we need to defer filter model updates\n this.filterModelUpdateQueue = [];\n }\n init() {\n this.addManagedListener(this.eventService, Events.EVENT_GRID_COLUMNS_CHANGED, () => this.onColumnsChanged());\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_VALUE_CHANGED, () => this.refreshFiltersForAggregations());\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PIVOT_CHANGED, () => this.refreshFiltersForAggregations());\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PIVOT_MODE_CHANGED, () => this.refreshFiltersForAggregations());\n this.addManagedListener(this.eventService, Events.EVENT_NEW_COLUMNS_LOADED, () => this.updateAdvancedFilterColumns());\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_VISIBLE, () => this.updateAdvancedFilterColumns());\n this.allowShowChangeAfterFilter = this.gridOptionsService.is('allowShowChangeAfterFilter');\n this.externalFilterPresent = this.isExternalFilterPresentCallback();\n this.updateAggFiltering();\n this.addManagedPropertyListener('groupAggFiltering', () => this.updateAggFiltering());\n this.addManagedPropertyListener('advancedFilterModel', (event) => this.setAdvancedFilterModel(event.currentValue));\n this.addManagedListener(this.eventService, Events.EVENT_ADVANCED_FILTER_ENABLED_CHANGED, ({ enabled }) => this.onAdvancedFilterEnabledChanged(enabled));\n this.addManagedListener(this.eventService, Events.EVENT_DATA_TYPES_INFERRED, () => this.processFilterModelUpdateQueue());\n this.addManagedListener(this.quickFilterService, QuickFilterService.EVENT_QUICK_FILTER_CHANGED, () => this.onFilterChanged({ source: 'quickFilter' }));\n }\n isExternalFilterPresentCallback() {\n const isFilterPresent = this.gridOptionsService.getCallback('isExternalFilterPresent');\n if (typeof isFilterPresent === 'function') {\n return isFilterPresent({});\n }\n return false;\n }\n doesExternalFilterPass(node) {\n const doesFilterPass = this.gridOptionsService.get('doesExternalFilterPass');\n if (typeof doesFilterPass === 'function') {\n return doesFilterPass(node);\n }\n return false;\n }\n setFilterModel(model) {\n if (this.isAdvancedFilterEnabled()) {\n this.warnAdvancedFilters();\n return;\n }\n if (this.dataTypeService.isPendingInference()) {\n this.filterModelUpdateQueue.push(model);\n return;\n }\n const allPromises = [];\n const previousModel = this.getFilterModel();\n if (model) {\n // mark the filters as we set them, so any active filters left over we stop\n const modelKeys = convertToSet(Object.keys(model));\n this.allColumnFilters.forEach((filterWrapper, colId) => {\n const newModel = model[colId];\n allPromises.push(this.setModelOnFilterWrapper(filterWrapper.filterPromise, newModel));\n modelKeys.delete(colId);\n });\n // at this point, processedFields contains data for which we don't have a filter working yet\n modelKeys.forEach(colId => {\n const column = this.columnModel.getPrimaryColumn(colId) || this.columnModel.getGridColumn(colId);\n if (!column) {\n console.warn('AG Grid: setFilterModel() - no column found for colId: ' + colId);\n return;\n }\n if (!column.isFilterAllowed()) {\n console.warn('AG Grid: setFilterModel() - unable to fully apply model, filtering disabled for colId: ' + colId);\n return;\n }\n const filterWrapper = this.getOrCreateFilterWrapper(column, 'NO_UI');\n if (!filterWrapper) {\n console.warn('AG-Grid: setFilterModel() - unable to fully apply model, unable to create filter for colId: ' + colId);\n return;\n }\n allPromises.push(this.setModelOnFilterWrapper(filterWrapper.filterPromise, model[colId]));\n });\n }\n else {\n this.allColumnFilters.forEach(filterWrapper => {\n allPromises.push(this.setModelOnFilterWrapper(filterWrapper.filterPromise, null));\n });\n }\n AgPromise.all(allPromises).then(() => {\n const currentModel = this.getFilterModel();\n const columns = [];\n this.allColumnFilters.forEach((filterWrapper, colId) => {\n const before = previousModel ? previousModel[colId] : null;\n const after = currentModel ? currentModel[colId] : null;\n if (!_.jsonEquals(before, after)) {\n columns.push(filterWrapper.column);\n }\n });\n if (columns.length > 0) {\n this.onFilterChanged({ columns, source: 'api' });\n }\n });\n }\n setModelOnFilterWrapper(filterPromise, newModel) {\n return new AgPromise(resolve => {\n filterPromise.then(filter => {\n if (typeof filter.setModel !== 'function') {\n console.warn('AG Grid: filter missing setModel method, which is needed for setFilterModel');\n resolve();\n }\n (filter.setModel(newModel) || AgPromise.resolve()).then(() => resolve());\n });\n });\n }\n getFilterModel() {\n const result = {};\n this.allColumnFilters.forEach((filterWrapper, key) => {\n // because user can provide filters, we provide useful error checking and messages\n const filterPromise = filterWrapper.filterPromise;\n const filter = filterPromise.resolveNow(null, promiseFilter => promiseFilter);\n if (filter == null) {\n return null;\n }\n if (typeof filter.getModel !== 'function') {\n console.warn('AG Grid: filter API missing getModel method, which is needed for getFilterModel');\n return;\n }\n const model = filter.getModel();\n if (exists(model)) {\n result[key] = model;\n }\n });\n return result;\n }\n isColumnFilterPresent() {\n return this.activeColumnFilters.length > 0;\n }\n isAggregateFilterPresent() {\n return !!this.activeAggregateFilters.length;\n }\n isExternalFilterPresent() {\n return this.externalFilterPresent;\n }\n isChildFilterPresent() {\n return this.isColumnFilterPresent()\n || this.isQuickFilterPresent()\n || this.isExternalFilterPresent()\n || this.isAdvancedFilterPresent();\n }\n isAdvancedFilterPresent() {\n return this.isAdvancedFilterEnabled() && this.advancedFilterService.isFilterPresent();\n }\n onAdvancedFilterEnabledChanged(enabled) {\n var _a;\n if (enabled) {\n if (this.allColumnFilters.size) {\n this.allColumnFilters.forEach(filterWrapper => this.disposeFilterWrapper(filterWrapper, 'advancedFilterEnabled'));\n this.onFilterChanged({ source: 'advancedFilter' });\n }\n }\n else {\n if ((_a = this.advancedFilterService) === null || _a === void 0 ? void 0 : _a.isFilterPresent()) {\n this.advancedFilterService.setModel(null);\n this.onFilterChanged({ source: 'advancedFilter' });\n }\n }\n }\n isAdvancedFilterEnabled() {\n var _a;\n return (_a = this.advancedFilterService) === null || _a === void 0 ? void 0 : _a.isEnabled();\n }\n isAdvancedFilterHeaderActive() {\n return this.isAdvancedFilterEnabled() && this.advancedFilterService.isHeaderActive();\n }\n doAggregateFiltersPass(node, filterToSkip) {\n return this.doColumnFiltersPass(node, filterToSkip, true);\n }\n // called by:\n // 1) onFilterChanged()\n // 2) onNewRowsLoaded()\n updateActiveFilters() {\n this.activeColumnFilters.length = 0;\n this.activeAggregateFilters.length = 0;\n const isFilterActive = (filter) => {\n if (!filter) {\n return false;\n } // this never happens, including to avoid compile error\n if (!filter.isFilterActive) {\n console.warn('AG Grid: Filter is missing isFilterActive() method');\n return false;\n }\n return filter.isFilterActive();\n };\n const groupFilterEnabled = !!this.gridOptionsService.getGroupAggFiltering();\n const isAggFilter = (column) => {\n const isSecondary = !column.isPrimary();\n // the only filters that can appear on secondary columns are groupAgg filters\n if (isSecondary) {\n return true;\n }\n const isShowingPrimaryColumns = !this.columnModel.isPivotActive();\n const isValueActive = column.isValueActive();\n // primary columns are only ever groupAgg filters if a) value is active and b) showing primary columns\n if (!isValueActive || !isShowingPrimaryColumns) {\n return false;\n }\n // from here on we know: isPrimary=true, isValueActive=true, isShowingPrimaryColumns=true\n if (this.columnModel.isPivotMode()) {\n // primary column is pretending to be a pivot column, ie pivotMode=true, but we are\n // still showing primary columns\n return true;\n }\n // we are not pivoting, so we groupFilter when it's an agg column\n return groupFilterEnabled;\n };\n this.allColumnFilters.forEach(filterWrapper => {\n if (filterWrapper.filterPromise.resolveNow(false, isFilterActive)) {\n const filterComp = filterWrapper.filterPromise.resolveNow(null, filter => filter);\n if (isAggFilter(filterWrapper.column)) {\n this.activeAggregateFilters.push(filterComp);\n }\n else {\n this.activeColumnFilters.push(filterComp);\n }\n }\n });\n }\n updateFilterFlagInColumns(source, additionalEventAttributes) {\n this.allColumnFilters.forEach(filterWrapper => {\n const isFilterActive = filterWrapper.filterPromise.resolveNow(false, filter => filter.isFilterActive());\n filterWrapper.column.setFilterActive(isFilterActive, source, additionalEventAttributes);\n });\n }\n isAnyFilterPresent() {\n return this.isQuickFilterPresent() || this.isColumnFilterPresent() || this.isAggregateFilterPresent() || this.isExternalFilterPresent();\n }\n doColumnFiltersPass(node, filterToSkip, targetAggregates) {\n const { data, aggData } = node;\n const targetedFilters = targetAggregates ? this.activeAggregateFilters : this.activeColumnFilters;\n const targetedData = targetAggregates ? aggData : data;\n for (let i = 0; i < targetedFilters.length; i++) {\n const filter = targetedFilters[i];\n if (filter == null || filter === filterToSkip) {\n continue;\n }\n if (typeof filter.doesFilterPass !== 'function') {\n // because users can do custom filters, give nice error message\n throw new Error('Filter is missing method doesFilterPass');\n }\n if (!filter.doesFilterPass({ node, data: targetedData })) {\n return false;\n }\n }\n return true;\n }\n resetQuickFilterCache() {\n this.quickFilterService.resetQuickFilterCache();\n }\n refreshFiltersForAggregations() {\n const isAggFiltering = this.gridOptionsService.getGroupAggFiltering();\n if (isAggFiltering) {\n this.onFilterChanged();\n }\n }\n // sometimes (especially in React) the filter can call onFilterChanged when we are in the middle\n // of a render cycle. this would be bad, so we wait for render cycle to complete when this happens.\n // this happens in react when we change React State in the grid (eg setting RowCtrl's in RowContainer)\n // which results in React State getting applied in the main application, triggering a useEffect() to\n // be kicked off adn then the application calling the grid's API. in AG-6554, the custom filter was\n // getting it's useEffect() triggered in this way.\n callOnFilterChangedOutsideRenderCycle(params) {\n const action = () => this.onFilterChanged(params);\n if (this.rowRenderer.isRefreshInProgress()) {\n setTimeout(action, 0);\n }\n else {\n action();\n }\n }\n onFilterChanged(params = {}) {\n const { source, filterInstance, additionalEventAttributes, columns } = params;\n this.updateDependantFilters();\n this.updateActiveFilters();\n this.updateFilterFlagInColumns('filterChanged', additionalEventAttributes);\n this.externalFilterPresent = this.isExternalFilterPresentCallback();\n this.allColumnFilters.forEach(filterWrapper => {\n if (!filterWrapper.filterPromise) {\n return;\n }\n filterWrapper.filterPromise.then(filter => {\n if (filter && filter !== filterInstance && filter.onAnyFilterChanged) {\n filter.onAnyFilterChanged();\n }\n });\n });\n const filterChangedEvent = {\n source,\n type: Events.EVENT_FILTER_CHANGED,\n columns: columns || [],\n };\n if (additionalEventAttributes) {\n mergeDeep(filterChangedEvent, additionalEventAttributes);\n }\n // because internal events are not async in ag-grid, when the dispatchEvent\n // method comes back, we know all listeners have finished executing.\n this.processingFilterChange = true;\n this.eventService.dispatchEvent(filterChangedEvent);\n this.processingFilterChange = false;\n }\n isSuppressFlashingCellsBecauseFiltering() {\n // if user has elected to always flash cell changes, then always return false, otherwise we suppress flashing\n // changes when filtering\n return !this.allowShowChangeAfterFilter && this.processingFilterChange;\n }\n isQuickFilterPresent() {\n return this.quickFilterService.isQuickFilterPresent();\n }\n updateAggFiltering() {\n this.aggFiltering = !!this.gridOptionsService.getGroupAggFiltering();\n }\n isAggregateQuickFilterPresent() {\n return this.isQuickFilterPresent() && (this.aggFiltering || this.columnModel.isPivotMode());\n }\n isNonAggregateQuickFilterPresent() {\n return this.isQuickFilterPresent() && !(this.aggFiltering || this.columnModel.isPivotMode());\n }\n doesRowPassOtherFilters(filterToSkip, node) {\n return this.doesRowPassFilter({ rowNode: node, filterInstanceToSkip: filterToSkip });\n }\n doesRowPassAggregateFilters(params) {\n // check quick filter\n if (this.isAggregateQuickFilterPresent() && !this.quickFilterService.doesRowPassQuickFilter(params.rowNode)) {\n return false;\n }\n if (this.isAggregateFilterPresent() && !this.doAggregateFiltersPass(params.rowNode, params.filterInstanceToSkip)) {\n return false;\n }\n // got this far, all filters pass\n return true;\n }\n doesRowPassFilter(params) {\n // the row must pass ALL of the filters, so if any of them fail,\n // we return true. that means if a row passes the quick filter,\n // but fails the column filter, it fails overall\n // first up, check quick filter\n if (this.isNonAggregateQuickFilterPresent() && !this.quickFilterService.doesRowPassQuickFilter(params.rowNode)) {\n return false;\n }\n // secondly, give the client a chance to reject this row\n if (this.isExternalFilterPresent() && !this.doesExternalFilterPass(params.rowNode)) {\n return false;\n }\n // lastly, check column filter\n if (this.isColumnFilterPresent() && !this.doColumnFiltersPass(params.rowNode, params.filterInstanceToSkip)) {\n return false;\n }\n if (this.isAdvancedFilterPresent() && !this.advancedFilterService.doesFilterPass(params.rowNode)) {\n return false;\n }\n // got this far, all filters pass\n return true;\n }\n onNewRowsLoaded(source) {\n this.allColumnFilters.forEach(filterWrapper => {\n filterWrapper.filterPromise.then(filter => {\n if (filter.onNewRowsLoaded) {\n filter.onNewRowsLoaded();\n }\n });\n });\n this.updateFilterFlagInColumns(source, { afterDataChange: true });\n this.updateActiveFilters();\n }\n createValueGetter(column) {\n return ({ node }) => this.valueService.getValue(column, node, true);\n }\n getFilterComponent(column, source, createIfDoesNotExist = true) {\n var _a;\n if (createIfDoesNotExist) {\n return ((_a = this.getOrCreateFilterWrapper(column, source)) === null || _a === void 0 ? void 0 : _a.filterPromise) || null;\n }\n const filterWrapper = this.cachedFilter(column);\n return filterWrapper ? filterWrapper.filterPromise : null;\n }\n isFilterActive(column) {\n const filterWrapper = this.cachedFilter(column);\n return !!filterWrapper && filterWrapper.filterPromise.resolveNow(false, filter => filter.isFilterActive());\n }\n getOrCreateFilterWrapper(column, source) {\n if (!column.isFilterAllowed()) {\n return null;\n }\n let filterWrapper = this.cachedFilter(column);\n if (!filterWrapper) {\n filterWrapper = this.createFilterWrapper(column, source);\n const colId = column.getColId();\n this.allColumnFilters.set(colId, filterWrapper);\n this.allColumnListeners.set(colId, this.addManagedListener(column, Column.EVENT_COL_DEF_CHANGED, () => this.checkDestroyFilter(colId)));\n }\n else if (source !== 'NO_UI') {\n this.putIntoGui(filterWrapper, source);\n }\n return filterWrapper;\n }\n cachedFilter(column) {\n return this.allColumnFilters.get(column.getColId());\n }\n getDefaultFilter(column) {\n let defaultFilter;\n if (ModuleRegistry.__isRegistered(ModuleNames.SetFilterModule, this.context.getGridId())) {\n defaultFilter = 'agSetColumnFilter';\n }\n else {\n const cellDataType = column.getColDef().cellDataType;\n if (cellDataType === 'number') {\n defaultFilter = 'agNumberColumnFilter';\n }\n else if (cellDataType === 'date' || cellDataType === 'dateString') {\n defaultFilter = 'agDateColumnFilter';\n }\n else {\n defaultFilter = 'agTextColumnFilter';\n }\n }\n return defaultFilter;\n }\n getDefaultFloatingFilter(column) {\n let defaultFloatingFilterType;\n if (ModuleRegistry.__isRegistered(ModuleNames.SetFilterModule, this.context.getGridId())) {\n defaultFloatingFilterType = 'agSetColumnFloatingFilter';\n }\n else {\n const cellDataType = column.getColDef().cellDataType;\n if (cellDataType === 'number') {\n defaultFloatingFilterType = 'agNumberColumnFloatingFilter';\n }\n else if (cellDataType === 'date' || cellDataType === 'dateString') {\n defaultFloatingFilterType = 'agDateColumnFloatingFilter';\n }\n else {\n defaultFloatingFilterType = 'agTextColumnFloatingFilter';\n }\n }\n return defaultFloatingFilterType;\n }\n createFilterInstance(column) {\n const defaultFilter = this.getDefaultFilter(column);\n const colDef = column.getColDef();\n let filterInstance;\n const params = Object.assign(Object.assign({}, this.createFilterParams(column, colDef)), { filterModifiedCallback: () => {\n const event = {\n type: Events.EVENT_FILTER_MODIFIED,\n column,\n filterInstance\n };\n this.eventService.dispatchEvent(event);\n }, filterChangedCallback: (additionalEventAttributes) => {\n var _a;\n const source = (_a = additionalEventAttributes === null || additionalEventAttributes === void 0 ? void 0 : additionalEventAttributes.source) !== null && _a !== void 0 ? _a : 'api';\n const params = {\n filterInstance,\n additionalEventAttributes,\n columns: [column],\n source,\n };\n this.callOnFilterChangedOutsideRenderCycle(params);\n }, doesRowPassOtherFilter: node => this.doesRowPassOtherFilters(filterInstance, node) });\n const compDetails = this.userComponentFactory.getFilterDetails(colDef, params, defaultFilter);\n if (!compDetails) {\n return { filterPromise: null, compDetails: null };\n }\n return {\n filterPromise: () => {\n const filterPromise = compDetails.newAgStackInstance();\n if (filterPromise) {\n filterPromise.then(r => filterInstance = r);\n }\n return filterPromise;\n },\n compDetails\n };\n }\n createFilterParams(column, colDef) {\n const params = {\n column,\n colDef: cloneObject(colDef),\n rowModel: this.rowModel,\n filterChangedCallback: () => { },\n filterModifiedCallback: () => { },\n valueGetter: this.createValueGetter(column),\n doesRowPassOtherFilter: () => true,\n api: this.gridOptionsService.api,\n columnApi: this.gridOptionsService.columnApi,\n context: this.gridOptionsService.context,\n };\n return params;\n }\n createFilterWrapper(column, source) {\n var _a;\n const filterWrapper = {\n column: column,\n filterPromise: null,\n compiledElement: null,\n guiPromise: AgPromise.resolve(null),\n compDetails: null\n };\n const { filterPromise, compDetails } = this.createFilterInstance(column);\n filterWrapper.filterPromise = (_a = filterPromise === null || filterPromise === void 0 ? void 0 : filterPromise()) !== null && _a !== void 0 ? _a : null;\n filterWrapper.compDetails = compDetails;\n if (filterPromise) {\n this.putIntoGui(filterWrapper, source);\n }\n return filterWrapper;\n }\n putIntoGui(filterWrapper, source) {\n const eFilterGui = document.createElement('div');\n eFilterGui.className = 'ag-filter';\n filterWrapper.guiPromise = new AgPromise(resolve => {\n filterWrapper.filterPromise.then(filter => {\n let guiFromFilter = filter.getGui();\n if (!exists(guiFromFilter)) {\n console.warn(`AG Grid: getGui method from filter returned ${guiFromFilter}, it should be a DOM element or an HTML template string.`);\n }\n // for backwards compatibility with Angular 1 - we\n // used to allow providing back HTML from getGui().\n // once we move away from supporting Angular 1\n // directly, we can change this.\n if (typeof guiFromFilter === 'string') {\n guiFromFilter = loadTemplate(guiFromFilter);\n }\n eFilterGui.appendChild(guiFromFilter);\n resolve(eFilterGui);\n const event = {\n type: Events.EVENT_FILTER_OPENED,\n column: filterWrapper.column,\n source,\n eGui: eFilterGui\n };\n this.eventService.dispatchEvent(event);\n });\n });\n }\n onColumnsChanged() {\n const columns = [];\n this.allColumnFilters.forEach((wrapper, colId) => {\n let currentColumn;\n if (wrapper.column.isPrimary()) {\n currentColumn = this.columnModel.getPrimaryColumn(colId);\n }\n else {\n currentColumn = this.columnModel.getGridColumn(colId);\n }\n if (currentColumn) {\n return;\n }\n columns.push(wrapper.column);\n this.disposeFilterWrapper(wrapper, 'columnChanged');\n this.disposeColumnListener(colId);\n });\n if (columns.length > 0) {\n // When a filter changes as a side effect of a column changes,\n // we report 'api' as the source, so that the client can distinguish\n this.onFilterChanged({ columns, source: 'api' });\n }\n else {\n // onFilterChanged does this already\n this.updateDependantFilters();\n }\n }\n updateDependantFilters() {\n // Group column filters can be dependant on underlying column filters, but don't normally get created until they're used for the first time.\n // Instead, create them by default when any filter changes.\n const groupColumns = this.columnModel.getGroupAutoColumns();\n groupColumns === null || groupColumns === void 0 ? void 0 : groupColumns.forEach(groupColumn => {\n if (groupColumn.getColDef().filter === 'agGroupColumnFilter') {\n this.getOrCreateFilterWrapper(groupColumn, 'NO_UI');\n }\n });\n }\n // for group filters, can change dynamically whether they are allowed or not\n isFilterAllowed(column) {\n var _a, _b;\n if (this.isAdvancedFilterEnabled()) {\n return false;\n }\n const isFilterAllowed = column.isFilterAllowed();\n if (!isFilterAllowed) {\n return false;\n }\n const filterWrapper = this.allColumnFilters.get(column.getColId());\n return (_b = (_a = filterWrapper === null || filterWrapper === void 0 ? void 0 : filterWrapper.filterPromise) === null || _a === void 0 ? void 0 : _a.resolveNow(true, \n // defer to filter component isFilterAllowed if it exists\n filter => {\n var _a, _b;\n return (typeof ((_a = filter) === null || _a === void 0 ? void 0 : _a.isFilterAllowed) === 'function')\n ? (_b = filter) === null || _b === void 0 ? void 0 : _b.isFilterAllowed()\n : true;\n })) !== null && _b !== void 0 ? _b : true;\n }\n getFloatingFilterCompDetails(column, showParentFilter) {\n const colDef = column.getColDef();\n const filterParams = this.createFilterParams(column, colDef);\n const finalFilterParams = this.userComponentFactory.mergeParamsWithApplicationProvidedParams(colDef, FilterComponent, filterParams);\n let defaultFloatingFilterType = this.userComponentFactory.getDefaultFloatingFilterType(colDef, () => this.getDefaultFloatingFilter(column));\n if (defaultFloatingFilterType == null) {\n defaultFloatingFilterType = 'agReadOnlyFloatingFilter';\n }\n const parentFilterInstance = (callback) => {\n const filterComponent = this.getFilterComponent(column, 'NO_UI');\n if (filterComponent == null) {\n return;\n }\n filterComponent.then(instance => {\n callback(unwrapUserComp(instance));\n });\n };\n const params = {\n column: column,\n filterParams: finalFilterParams,\n currentParentModel: () => this.getCurrentFloatingFilterParentModel(column),\n parentFilterInstance,\n showParentFilter,\n suppressFilterButton: false // This one might be overridden from the colDef\n };\n return this.userComponentFactory.getFloatingFilterCompDetails(colDef, params, defaultFloatingFilterType);\n }\n getCurrentFloatingFilterParentModel(column) {\n const filterComponent = this.getFilterComponent(column, 'NO_UI', false);\n return filterComponent ? filterComponent.resolveNow(null, filter => filter && filter.getModel()) : null;\n }\n // destroys the filter, so it no longer takes part\n destroyFilter(column, source = 'api') {\n const colId = column.getColId();\n const filterWrapper = this.allColumnFilters.get(colId);\n this.disposeColumnListener(colId);\n if (filterWrapper) {\n this.disposeFilterWrapper(filterWrapper, source);\n this.onFilterChanged({\n columns: [column],\n source: 'api',\n });\n }\n }\n disposeColumnListener(colId) {\n const columnListener = this.allColumnListeners.get(colId);\n if (columnListener) {\n this.allColumnListeners.delete(colId);\n columnListener();\n }\n }\n disposeFilterWrapper(filterWrapper, source) {\n filterWrapper.filterPromise.then(filter => {\n (filter.setModel(null) || AgPromise.resolve()).then(() => {\n this.getContext().destroyBean(filter);\n filterWrapper.column.setFilterActive(false, 'filterDestroyed');\n this.allColumnFilters.delete(filterWrapper.column.getColId());\n const event = {\n type: Events.EVENT_FILTER_DESTROYED,\n source,\n column: filterWrapper.column,\n };\n this.eventService.dispatchEvent(event);\n });\n });\n }\n checkDestroyFilter(colId) {\n const filterWrapper = this.allColumnFilters.get(colId);\n if (!filterWrapper) {\n return;\n }\n const column = filterWrapper.column;\n const { compDetails } = column.isFilterAllowed()\n ? this.createFilterInstance(column)\n : { compDetails: null };\n if (this.areFilterCompsDifferent(filterWrapper.compDetails, compDetails)) {\n this.destroyFilter(column, 'columnChanged');\n }\n }\n areFilterCompsDifferent(oldCompDetails, newCompDetails) {\n if (!newCompDetails || !oldCompDetails) {\n return true;\n }\n const { componentClass: oldComponentClass } = oldCompDetails;\n const { componentClass: newComponentClass } = newCompDetails;\n const isSameComponentClass = oldComponentClass === newComponentClass ||\n // react hooks returns new wrappers, so check nested render method\n ((oldComponentClass === null || oldComponentClass === void 0 ? void 0 : oldComponentClass.render) && (newComponentClass === null || newComponentClass === void 0 ? void 0 : newComponentClass.render) &&\n oldComponentClass.render === newComponentClass.render);\n return !isSameComponentClass;\n }\n getAdvancedFilterModel() {\n return this.isAdvancedFilterEnabled() ? this.advancedFilterService.getModel() : null;\n }\n setAdvancedFilterModel(expression) {\n if (!this.isAdvancedFilterEnabled()) {\n return;\n }\n this.advancedFilterService.setModel(expression !== null && expression !== void 0 ? expression : null);\n this.onFilterChanged({ source: 'advancedFilter' });\n }\n showAdvancedFilterBuilder(source) {\n if (!this.isAdvancedFilterEnabled()) {\n return;\n }\n this.advancedFilterService.getCtrl().toggleFilterBuilder(source, true);\n }\n updateAdvancedFilterColumns() {\n if (!this.isAdvancedFilterEnabled()) {\n return;\n }\n if (this.advancedFilterService.updateValidity()) {\n this.onFilterChanged({ source: 'advancedFilter' });\n }\n }\n hasFloatingFilters() {\n if (this.isAdvancedFilterEnabled()) {\n return false;\n }\n const gridColumns = this.columnModel.getAllGridColumns();\n if (!gridColumns) {\n return false;\n }\n return gridColumns.some(col => col.getColDef().floatingFilter);\n }\n getFilterInstance(key, callback) {\n if (this.isAdvancedFilterEnabled()) {\n this.warnAdvancedFilters();\n return undefined;\n }\n const res = this.getFilterInstanceImpl(key, instance => {\n if (!callback) {\n return;\n }\n const unwrapped = unwrapUserComp(instance);\n callback(unwrapped);\n });\n const unwrapped = unwrapUserComp(res);\n return unwrapped;\n }\n getFilterInstanceImpl(key, callback) {\n const column = this.columnModel.getPrimaryColumn(key);\n if (!column) {\n return undefined;\n }\n const filterPromise = this.getFilterComponent(column, 'NO_UI');\n const currentValue = filterPromise && filterPromise.resolveNow(null, filterComp => filterComp);\n if (currentValue) {\n setTimeout(callback, 0, currentValue);\n }\n else if (filterPromise) {\n filterPromise.then(comp => {\n callback(comp);\n });\n }\n return currentValue;\n }\n warnAdvancedFilters() {\n doOnce(() => {\n console.warn('AG Grid: Column Filter API methods have been disabled as Advanced Filters are enabled.');\n }, 'advancedFiltersCompatibility');\n }\n setupAdvancedFilterHeaderComp(eCompToInsertBefore) {\n var _a;\n (_a = this.advancedFilterService) === null || _a === void 0 ? void 0 : _a.getCtrl().setupHeaderComp(eCompToInsertBefore);\n }\n getHeaderRowCount() {\n return this.isAdvancedFilterHeaderActive() ? 1 : 0;\n }\n getHeaderHeight() {\n return this.isAdvancedFilterHeaderActive() ? this.advancedFilterService.getCtrl().getHeaderHeight() : 0;\n }\n processFilterModelUpdateQueue() {\n this.filterModelUpdateQueue.forEach(model => this.setFilterModel(model));\n this.filterModelUpdateQueue = [];\n }\n destroy() {\n super.destroy();\n this.allColumnFilters.forEach(filterWrapper => this.disposeFilterWrapper(filterWrapper, 'gridDestroyed'));\n // don't need to destroy the listeners as they are managed listeners\n this.allColumnListeners.clear();\n }\n};\n__decorate([\n Autowired('valueService')\n], FilterManager.prototype, \"valueService\", void 0);\n__decorate([\n Autowired('columnModel')\n], FilterManager.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('rowModel')\n], FilterManager.prototype, \"rowModel\", void 0);\n__decorate([\n Autowired('userComponentFactory')\n], FilterManager.prototype, \"userComponentFactory\", void 0);\n__decorate([\n Autowired('rowRenderer')\n], FilterManager.prototype, \"rowRenderer\", void 0);\n__decorate([\n Autowired('dataTypeService')\n], FilterManager.prototype, \"dataTypeService\", void 0);\n__decorate([\n Autowired('quickFilterService')\n], FilterManager.prototype, \"quickFilterService\", void 0);\n__decorate([\n Optional('advancedFilterService')\n], FilterManager.prototype, \"advancedFilterService\", void 0);\n__decorate([\n PostConstruct\n], FilterManager.prototype, \"init\", null);\nFilterManager = __decorate([\n Bean('filterManager')\n], FilterManager);\nexport { FilterManager };\n","import { Component } from \"../../../widgets/component.mjs\";\nexport class AbstractHeaderCellComp extends Component {\n constructor(template, ctrl) {\n super(template);\n this.ctrl = ctrl;\n }\n getCtrl() {\n return this.ctrl;\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PostConstruct, PreDestroy } from '../../../context/context.mjs';\nimport { setDisplayed } from \"../../../utils/dom.mjs\";\nimport { RefSelector } from '../../../widgets/componentAnnotations.mjs';\nimport { AbstractHeaderCellComp } from '../abstractCell/abstractHeaderCellComp.mjs';\nexport class HeaderFilterCellComp extends AbstractHeaderCellComp {\n constructor(ctrl) {\n super(HeaderFilterCellComp.TEMPLATE, ctrl);\n }\n postConstruct() {\n const eGui = this.getGui();\n const compProxy = {\n addOrRemoveCssClass: (cssClassName, on) => this.addOrRemoveCssClass(cssClassName, on),\n addOrRemoveBodyCssClass: (cssClassName, on) => this.eFloatingFilterBody.classList.toggle(cssClassName, on),\n setButtonWrapperDisplayed: (displayed) => setDisplayed(this.eButtonWrapper, displayed),\n setCompDetails: compDetails => this.setCompDetails(compDetails),\n getFloatingFilterComp: () => this.compPromise,\n setWidth: width => eGui.style.width = width,\n setMenuIcon: eIcon => this.eButtonShowMainFilter.appendChild(eIcon)\n };\n this.ctrl.setComp(compProxy, eGui, this.eButtonShowMainFilter, this.eFloatingFilterBody);\n }\n setCompDetails(compDetails) {\n if (!compDetails) {\n this.destroyFloatingFilterComp();\n this.compPromise = null;\n return;\n }\n // because we are providing defaultFloatingFilterType, we know it will never be undefined;\n this.compPromise = compDetails.newAgStackInstance();\n this.compPromise.then(comp => this.afterCompCreated(comp));\n }\n destroyFloatingFilterComp() {\n if (this.floatingFilterComp) {\n this.eFloatingFilterBody.removeChild(this.floatingFilterComp.getGui());\n this.floatingFilterComp = this.destroyBean(this.floatingFilterComp);\n }\n }\n afterCompCreated(comp) {\n if (!comp) {\n return;\n }\n if (!this.isAlive()) {\n this.destroyBean(comp);\n return;\n }\n this.destroyFloatingFilterComp();\n this.floatingFilterComp = comp;\n this.eFloatingFilterBody.appendChild(comp.getGui());\n if (comp.afterGuiAttached) {\n comp.afterGuiAttached();\n }\n }\n}\nHeaderFilterCellComp.TEMPLATE = `
\n
\n
\n \n
\n
`;\n__decorate([\n RefSelector('eFloatingFilterBody')\n], HeaderFilterCellComp.prototype, \"eFloatingFilterBody\", void 0);\n__decorate([\n RefSelector('eButtonWrapper')\n], HeaderFilterCellComp.prototype, \"eButtonWrapper\", void 0);\n__decorate([\n RefSelector('eButtonShowMainFilter')\n], HeaderFilterCellComp.prototype, \"eButtonShowMainFilter\", void 0);\n__decorate([\n PostConstruct\n], HeaderFilterCellComp.prototype, \"postConstruct\", null);\n__decorate([\n PreDestroy\n], HeaderFilterCellComp.prototype, \"destroyFloatingFilterComp\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PostConstruct } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { doOnce } from \"../utils/function.mjs\";\nexport var LayoutCssClasses;\n(function (LayoutCssClasses) {\n LayoutCssClasses[\"AUTO_HEIGHT\"] = \"ag-layout-auto-height\";\n LayoutCssClasses[\"NORMAL\"] = \"ag-layout-normal\";\n LayoutCssClasses[\"PRINT\"] = \"ag-layout-print\";\n})(LayoutCssClasses || (LayoutCssClasses = {}));\nexport class LayoutFeature extends BeanStub {\n constructor(view) {\n super();\n this.view = view;\n }\n postConstruct() {\n this.addManagedPropertyListener('domLayout', this.updateLayoutClasses.bind(this));\n this.updateLayoutClasses();\n }\n updateLayoutClasses() {\n const domLayout = this.getDomLayout();\n const params = {\n autoHeight: domLayout === 'autoHeight',\n normal: domLayout === 'normal',\n print: domLayout === 'print'\n };\n const cssClass = params.autoHeight ? LayoutCssClasses.AUTO_HEIGHT :\n params.print ? LayoutCssClasses.PRINT : LayoutCssClasses.NORMAL;\n this.view.updateLayoutClasses(cssClass, params);\n }\n // returns either 'print', 'autoHeight' or 'normal' (normal is the default)\n getDomLayout() {\n var _a;\n const domLayout = (_a = this.gridOptionsService.get('domLayout')) !== null && _a !== void 0 ? _a : 'normal';\n const validLayouts = ['normal', 'print', 'autoHeight'];\n if (validLayouts.indexOf(domLayout) === -1) {\n doOnce(() => console.warn(`AG Grid: ${domLayout} is not valid for DOM Layout, valid values are 'normal', 'autoHeight', 'print'.`), 'warn about dom layout values');\n return 'normal';\n }\n return domLayout;\n }\n}\n__decorate([\n PostConstruct\n], LayoutFeature.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { Events } from \"../eventKeys.mjs\";\nimport { debounce } from \"../utils/function.mjs\";\nimport { isIOSUserAgent } from \"../utils/browser.mjs\";\nimport { getInnerHeight, getScrollLeft, isRtlNegativeScroll, setScrollLeft } from \"../utils/dom.mjs\";\nvar ScrollDirection;\n(function (ScrollDirection) {\n ScrollDirection[ScrollDirection[\"Vertical\"] = 0] = \"Vertical\";\n ScrollDirection[ScrollDirection[\"Horizontal\"] = 1] = \"Horizontal\";\n})(ScrollDirection || (ScrollDirection = {}));\n;\nvar ScrollSource;\n(function (ScrollSource) {\n ScrollSource[ScrollSource[\"Container\"] = 0] = \"Container\";\n ScrollSource[ScrollSource[\"FakeContainer\"] = 1] = \"FakeContainer\";\n})(ScrollSource || (ScrollSource = {}));\n;\nexport class GridBodyScrollFeature extends BeanStub {\n constructor(eBodyViewport) {\n super();\n this.lastScrollSource = [null, null];\n this.scrollLeft = -1;\n this.nextScrollTop = -1;\n this.scrollTop = -1;\n this.eBodyViewport = eBodyViewport;\n this.resetLastHScrollDebounced = debounce(() => this.lastScrollSource[ScrollDirection.Horizontal] = null, 500);\n this.resetLastVScrollDebounced = debounce(() => this.lastScrollSource[ScrollDirection.Vertical] = null, 500);\n }\n postConstruct() {\n this.enableRtl = this.gridOptionsService.is('enableRtl');\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, this.onDisplayedColumnsWidthChanged.bind(this));\n this.ctrlsService.whenReady(p => {\n this.centerRowContainerCtrl = p.centerRowContainerCtrl;\n this.onDisplayedColumnsWidthChanged();\n this.addScrollListener();\n });\n }\n addScrollListener() {\n const fakeHScroll = this.ctrlsService.getFakeHScrollComp();\n const fakeVScroll = this.ctrlsService.getFakeVScrollComp();\n this.addManagedListener(this.centerRowContainerCtrl.getViewportElement(), 'scroll', this.onHScroll.bind(this));\n fakeHScroll.onScrollCallback(this.onFakeHScroll.bind(this));\n const isDebounce = this.gridOptionsService.is('debounceVerticalScrollbar');\n const onVScroll = isDebounce ?\n debounce(this.onVScroll.bind(this), 100) : this.onVScroll.bind(this);\n const onFakeVScroll = isDebounce ?\n debounce(this.onFakeVScroll.bind(this), 100) : this.onFakeVScroll.bind(this);\n this.addManagedListener(this.eBodyViewport, 'scroll', onVScroll);\n fakeVScroll.onScrollCallback(onFakeVScroll);\n }\n onDisplayedColumnsWidthChanged() {\n if (this.enableRtl) {\n // because RTL is all backwards, a change in the width of the row\n // can cause a change in the scroll position, without a scroll event,\n // because the scroll position in RTL is a function that depends on\n // the width. to be convinced of this, take out this line, enable RTL,\n // scroll all the way to the left and then resize a column\n this.horizontallyScrollHeaderCenterAndFloatingCenter();\n }\n }\n horizontallyScrollHeaderCenterAndFloatingCenter(scrollLeft) {\n // when doing RTL, this method gets called once prematurely\n const notYetInitialised = this.centerRowContainerCtrl == null;\n if (notYetInitialised) {\n return;\n }\n if (scrollLeft === undefined) {\n scrollLeft = this.centerRowContainerCtrl.getCenterViewportScrollLeft();\n }\n const offset = this.enableRtl ? scrollLeft : -scrollLeft;\n const topCenterContainer = this.ctrlsService.getTopCenterRowContainerCtrl();\n const stickyTopCenterContainer = this.ctrlsService.getStickyTopCenterRowContainerCtrl();\n const bottomCenterContainer = this.ctrlsService.getBottomCenterRowContainerCtrl();\n const fakeHScroll = this.ctrlsService.getFakeHScrollComp();\n const centerHeaderContainer = this.ctrlsService.getHeaderRowContainerCtrl();\n centerHeaderContainer.setHorizontalScroll(-offset);\n bottomCenterContainer.setContainerTranslateX(offset);\n topCenterContainer.setContainerTranslateX(offset);\n stickyTopCenterContainer.setContainerTranslateX(offset);\n const centerViewport = this.centerRowContainerCtrl.getViewportElement();\n const isCenterViewportLastHorizontal = this.lastScrollSource[ScrollDirection.Horizontal] === ScrollSource.Container;\n scrollLeft = Math.abs(scrollLeft);\n if (isCenterViewportLastHorizontal) {\n fakeHScroll.setScrollPosition(scrollLeft);\n }\n else {\n setScrollLeft(centerViewport, scrollLeft, this.enableRtl);\n }\n }\n isControllingScroll(source, direction) {\n if (this.lastScrollSource[direction] == null) {\n this.lastScrollSource[direction] = source;\n return true;\n }\n return this.lastScrollSource[direction] === source;\n }\n onFakeHScroll() {\n if (!this.isControllingScroll(ScrollSource.FakeContainer, ScrollDirection.Horizontal)) {\n return;\n }\n this.onHScrollCommon(ScrollSource.FakeContainer);\n }\n onHScroll() {\n if (!this.isControllingScroll(ScrollSource.Container, ScrollDirection.Horizontal)) {\n return;\n }\n this.onHScrollCommon(ScrollSource.Container);\n }\n onHScrollCommon(source) {\n const centerContainerViewport = this.centerRowContainerCtrl.getViewportElement();\n const { scrollLeft } = centerContainerViewport;\n if (this.shouldBlockScrollUpdate(ScrollDirection.Horizontal, scrollLeft, true)) {\n return;\n }\n let newScrollLeft;\n if (source === ScrollSource.Container) {\n newScrollLeft = getScrollLeft(centerContainerViewport, this.enableRtl);\n }\n else {\n newScrollLeft = this.ctrlsService.getFakeHScrollComp().getScrollPosition();\n }\n // we do Math.round() rather than Math.floor(), to mirror how scroll values are applied.\n // eg if a scale is applied (ie user has zoomed the browser), then applying scroll=200\n // could result in 199.88, which then floor(199.88) = 199, however round(199.88) = 200.\n // initially Math.floor() was used, however this caused (almost) infinite loop with aligned grids,\n // as the scroll would move 1px at at time bouncing from one grid to the next (eg one grid would cause\n // scroll to 200px, the next to 199px, then the first back to 198px and so on).\n this.doHorizontalScroll(Math.round(newScrollLeft));\n this.resetLastHScrollDebounced();\n }\n onFakeVScroll() {\n if (!this.isControllingScroll(ScrollSource.FakeContainer, ScrollDirection.Vertical)) {\n return;\n }\n this.onVScrollCommon(ScrollSource.FakeContainer);\n }\n onVScroll() {\n if (!this.isControllingScroll(ScrollSource.Container, ScrollDirection.Vertical)) {\n return;\n }\n this.onVScrollCommon(ScrollSource.Container);\n }\n onVScrollCommon(source) {\n let scrollTop;\n if (source === ScrollSource.Container) {\n scrollTop = this.eBodyViewport.scrollTop;\n }\n else {\n scrollTop = this.ctrlsService.getFakeVScrollComp().getScrollPosition();\n }\n if (this.shouldBlockScrollUpdate(ScrollDirection.Vertical, scrollTop, true)) {\n return;\n }\n this.animationFrameService.setScrollTop(scrollTop);\n this.nextScrollTop = scrollTop;\n if (source === ScrollSource.Container) {\n this.ctrlsService.getFakeVScrollComp().setScrollPosition(scrollTop);\n }\n else {\n this.eBodyViewport.scrollTop = scrollTop;\n }\n // the `scrollGridIfNeeded` will recalculate the rows to be rendered by the grid\n // so it should only be called after `eBodyViewport` has been scrolled to the correct\n // position, otherwise the `first` and `last` row could be miscalculated.\n if (this.gridOptionsService.is('suppressAnimationFrame')) {\n this.scrollGridIfNeeded();\n }\n else {\n this.animationFrameService.schedule();\n }\n this.resetLastVScrollDebounced();\n }\n doHorizontalScroll(scrollLeft) {\n const fakeScrollLeft = this.ctrlsService.getFakeHScrollComp().getScrollPosition();\n if (this.scrollLeft === scrollLeft && scrollLeft === fakeScrollLeft) {\n return;\n }\n this.scrollLeft = scrollLeft;\n this.fireScrollEvent(ScrollDirection.Horizontal);\n this.horizontallyScrollHeaderCenterAndFloatingCenter(scrollLeft);\n this.centerRowContainerCtrl.onHorizontalViewportChanged(true);\n }\n fireScrollEvent(direction) {\n const bodyScrollEvent = {\n type: Events.EVENT_BODY_SCROLL,\n direction: direction === ScrollDirection.Horizontal ? 'horizontal' : 'vertical',\n left: this.scrollLeft,\n top: this.scrollTop\n };\n this.eventService.dispatchEvent(bodyScrollEvent);\n window.clearTimeout(this.scrollTimer);\n this.scrollTimer = undefined;\n this.scrollTimer = window.setTimeout(() => {\n const bodyScrollEndEvent = Object.assign(Object.assign({}, bodyScrollEvent), { type: Events.EVENT_BODY_SCROLL_END });\n this.eventService.dispatchEvent(bodyScrollEndEvent);\n }, 100);\n }\n shouldBlockScrollUpdate(direction, scrollTo, touchOnly = false) {\n // touch devices allow elastic scroll - which temporally scrolls the panel outside of the viewport\n // (eg user uses touch to go to the left of the grid, but drags past the left, the rows will actually\n // scroll past the left until the user releases the mouse). when this happens, we want ignore the scroll,\n // as otherwise it was causing the rows and header to flicker.\n // sometimes when scrolling, we got values that extended the maximum scroll allowed. we used to\n // ignore these scrolls. problem is the max scroll position could be skipped (eg the previous scroll event\n // could be 10px before the max position, and then current scroll event could be 20px after the max position).\n // if we just ignored the last event, we would be setting the scroll to 10px before the max position, when in\n // actual fact the user has exceeded the max scroll and thus scroll should be set to the max.\n if (touchOnly && !isIOSUserAgent()) {\n return false;\n }\n if (direction === ScrollDirection.Vertical) {\n return this.shouldBlockVerticalScroll(scrollTo);\n }\n return this.shouldBlockHorizontalScroll(scrollTo);\n }\n shouldBlockVerticalScroll(scrollTo) {\n const clientHeight = getInnerHeight(this.eBodyViewport);\n const { scrollHeight } = this.eBodyViewport;\n if (scrollTo < 0 || (scrollTo + clientHeight > scrollHeight)) {\n return true;\n }\n return false;\n }\n shouldBlockHorizontalScroll(scrollTo) {\n const clientWidth = this.centerRowContainerCtrl.getCenterWidth();\n const { scrollWidth } = this.centerRowContainerCtrl.getViewportElement();\n if (this.enableRtl && isRtlNegativeScroll()) {\n if (scrollTo > 0) {\n return true;\n }\n }\n else if (scrollTo < 0) {\n return true;\n }\n if (Math.abs(scrollTo) + clientWidth > scrollWidth) {\n return true;\n }\n return false;\n }\n redrawRowsAfterScroll() {\n this.fireScrollEvent(ScrollDirection.Vertical);\n }\n // this is to cater for AG-3274, where grid is removed from the dom and then inserted back in again.\n // (which happens with some implementations of tabbing). this can result in horizontal scroll getting\n // reset back to the left, however no scroll event is fired. so we need to get header to also scroll\n // back to the left to be kept in sync.\n // adding and removing the grid from the DOM both resets the scroll position and\n // triggers a resize event, so notify listeners if the scroll position has changed\n checkScrollLeft() {\n if (this.scrollLeft !== this.centerRowContainerCtrl.getCenterViewportScrollLeft()) {\n this.onHScrollCommon(ScrollSource.Container);\n }\n }\n scrollGridIfNeeded() {\n const frameNeeded = this.scrollTop != this.nextScrollTop;\n if (frameNeeded) {\n this.scrollTop = this.nextScrollTop;\n this.redrawRowsAfterScroll();\n }\n return frameNeeded;\n }\n // called by scrollHorizontally method and alignedGridsService\n setHorizontalScrollPosition(hScrollPosition, fromAlignedGridsService = false) {\n const minScrollLeft = 0;\n const maxScrollLeft = this.centerRowContainerCtrl.getViewportElement().scrollWidth - this.centerRowContainerCtrl.getCenterWidth();\n // if this is call is coming from the alignedGridsService, we don't need to validate the\n // scroll, because it has already been validated by the grid firing the scroll event.\n if (!fromAlignedGridsService && this.shouldBlockScrollUpdate(ScrollDirection.Horizontal, hScrollPosition)) {\n if (this.enableRtl && isRtlNegativeScroll()) {\n hScrollPosition = hScrollPosition > 0 ? 0 : maxScrollLeft;\n }\n else {\n hScrollPosition = Math.min(Math.max(hScrollPosition, minScrollLeft), maxScrollLeft);\n }\n }\n setScrollLeft(this.centerRowContainerCtrl.getViewportElement(), Math.abs(hScrollPosition), this.enableRtl);\n // we need to manually do the event handling (rather than wait for the event)\n // for the alignedGridsService, as if we don't, the aligned grid service gets\n // notified async, and then it's 'consuming' flag doesn't get used right, and\n // we can end up with an infinite loop\n this.doHorizontalScroll(hScrollPosition);\n }\n setVerticalScrollPosition(vScrollPosition) {\n this.eBodyViewport.scrollTop = vScrollPosition;\n }\n getVScrollPosition() {\n const result = {\n top: this.eBodyViewport.scrollTop,\n bottom: this.eBodyViewport.scrollTop + this.eBodyViewport.offsetHeight\n };\n return result;\n }\n getHScrollPosition() {\n return this.centerRowContainerCtrl.getHScrollPosition();\n }\n isHorizontalScrollShowing() {\n return this.centerRowContainerCtrl.isHorizontalScrollShowing();\n }\n // called by the headerRootComp and moveColumnController\n scrollHorizontally(pixels) {\n const oldScrollPosition = this.centerRowContainerCtrl.getViewportElement().scrollLeft;\n this.setHorizontalScrollPosition(oldScrollPosition + pixels);\n return this.centerRowContainerCtrl.getViewportElement().scrollLeft - oldScrollPosition;\n }\n // gets called by rowRenderer when new data loaded, as it will want to scroll to the top\n scrollToTop() {\n this.eBodyViewport.scrollTop = 0;\n }\n // Valid values for position are bottom, middle and top\n ensureNodeVisible(comparator, position = null) {\n // look for the node index we want to display\n const rowCount = this.rowModel.getRowCount();\n let indexToSelect = -1;\n // go through all the nodes, find the one we want to show\n for (let i = 0; i < rowCount; i++) {\n const node = this.rowModel.getRow(i);\n if (typeof comparator === 'function') {\n // Have to assert type here, as type could be TData & Function\n const predicate = comparator;\n if (node && predicate(node)) {\n indexToSelect = i;\n break;\n }\n }\n else {\n // check object equality against node and data\n if (comparator === node || comparator === node.data) {\n indexToSelect = i;\n break;\n }\n }\n }\n if (indexToSelect >= 0) {\n this.ensureIndexVisible(indexToSelect, position);\n }\n }\n // Valid values for position are bottom, middle and top\n // position should be {'top','middle','bottom', or undefined/null}.\n // if undefined/null, then the grid will to the minimal amount of scrolling,\n // eg if grid needs to scroll up, it scrolls until row is on top,\n // if grid needs to scroll down, it scrolls until row is on bottom,\n // if row is already in view, grid does not scroll\n ensureIndexVisible(index, position) {\n // if for print or auto height, everything is always visible\n if (this.gridOptionsService.isDomLayout('print')) {\n return;\n }\n const rowCount = this.paginationProxy.getRowCount();\n if (typeof index !== 'number' || index < 0 || index >= rowCount) {\n console.warn('AG Grid: Invalid row index for ensureIndexVisible: ' + index);\n return;\n }\n const isPaging = this.gridOptionsService.is('pagination');\n const paginationPanelEnabled = isPaging && !this.gridOptionsService.is('suppressPaginationPanel');\n if (!paginationPanelEnabled) {\n this.paginationProxy.goToPageWithIndex(index);\n }\n const gridBodyCtrl = this.ctrlsService.getGridBodyCtrl();\n const stickyTopHeight = gridBodyCtrl.getStickyTopHeight();\n const rowNode = this.paginationProxy.getRow(index);\n let rowGotShiftedDuringOperation;\n do {\n const startingRowTop = rowNode.rowTop;\n const startingRowHeight = rowNode.rowHeight;\n const paginationOffset = this.paginationProxy.getPixelOffset();\n const rowTopPixel = rowNode.rowTop - paginationOffset;\n const rowBottomPixel = rowTopPixel + rowNode.rowHeight;\n const scrollPosition = this.getVScrollPosition();\n const heightOffset = this.heightScaler.getDivStretchOffset();\n const vScrollTop = scrollPosition.top + heightOffset;\n const vScrollBottom = scrollPosition.bottom + heightOffset;\n const viewportHeight = vScrollBottom - vScrollTop;\n // work out the pixels for top, middle and bottom up front,\n // make the if/else below easier to read\n const pxTop = this.heightScaler.getScrollPositionForPixel(rowTopPixel);\n const pxBottom = this.heightScaler.getScrollPositionForPixel(rowBottomPixel - viewportHeight);\n // make sure if middle, the row is not outside the top of the grid\n const pxMiddle = Math.min((pxTop + pxBottom) / 2, rowTopPixel);\n const rowAboveViewport = (vScrollTop + stickyTopHeight) > rowTopPixel;\n const rowBelowViewport = vScrollBottom < rowBottomPixel;\n let newScrollPosition = null;\n if (position === 'top') {\n newScrollPosition = pxTop;\n }\n else if (position === 'bottom') {\n newScrollPosition = pxBottom;\n }\n else if (position === 'middle') {\n newScrollPosition = pxMiddle;\n }\n else if (rowAboveViewport) {\n // if row is before, scroll up with row at top\n newScrollPosition = pxTop - stickyTopHeight;\n }\n else if (rowBelowViewport) {\n // if row is after, scroll down with row at bottom\n newScrollPosition = pxBottom;\n }\n if (newScrollPosition !== null) {\n this.setVerticalScrollPosition(newScrollPosition);\n this.rowRenderer.redraw({ afterScroll: true });\n }\n // the row can get shifted if during the rendering (during rowRenderer.redraw()),\n // the height of a row changes due to lazy calculation of row heights when using\n // colDef.autoHeight or gridOptions.getRowHeight.\n // if row was shifted, then the position we scrolled to is incorrect.\n rowGotShiftedDuringOperation = (startingRowTop !== rowNode.rowTop)\n || (startingRowHeight !== rowNode.rowHeight);\n } while (rowGotShiftedDuringOperation);\n // so when we return back to user, the cells have rendered\n this.animationFrameService.flushAllFrames();\n }\n ensureColumnVisible(key, position = 'auto') {\n const column = this.columnModel.getGridColumn(key);\n if (!column) {\n return;\n }\n // calling ensureColumnVisible on a pinned column doesn't make sense\n if (column.isPinned()) {\n return;\n }\n // defensive\n if (!this.columnModel.isColumnDisplayed(column)) {\n return;\n }\n const newHorizontalScroll = this.getPositionedHorizontalScroll(column, position);\n if (newHorizontalScroll !== null) {\n this.centerRowContainerCtrl.setCenterViewportScrollLeft(newHorizontalScroll);\n }\n // this will happen anyway, as the move will cause a 'scroll' event on the body, however\n // it is possible that the ensureColumnVisible method is called from within AG Grid and\n // the caller will need to have the columns rendered to continue, which will be before\n // the event has been worked on (which is the case for cell navigation).\n this.centerRowContainerCtrl.onHorizontalViewportChanged();\n // so when we return back to user, the cells have rendered\n this.animationFrameService.flushAllFrames();\n }\n getPositionedHorizontalScroll(column, position) {\n const { columnBeforeStart, columnAfterEnd } = this.isColumnOutsideViewport(column);\n const viewportTooSmallForColumn = this.centerRowContainerCtrl.getCenterWidth() < column.getActualWidth();\n const viewportWidth = this.centerRowContainerCtrl.getCenterWidth();\n const isRtl = this.enableRtl;\n let alignColToStart = (isRtl ? columnBeforeStart : columnAfterEnd) || viewportTooSmallForColumn;\n let alignColToEnd = isRtl ? columnAfterEnd : columnBeforeStart;\n if (position !== 'auto') {\n alignColToStart = position === 'start';\n alignColToEnd = position === 'end';\n }\n const isMiddle = position === 'middle';\n if (alignColToStart || alignColToEnd || isMiddle) {\n const { colLeft, colMiddle, colRight } = this.getColumnBounds(column);\n if (isMiddle) {\n return colMiddle - viewportWidth / 2;\n }\n if (alignColToStart) {\n return isRtl ? colRight : colLeft;\n }\n return isRtl ? (colLeft - viewportWidth) : (colRight - viewportWidth);\n }\n return null;\n }\n isColumnOutsideViewport(column) {\n const { start: viewportStart, end: viewportEnd } = this.getViewportBounds();\n const { colLeft, colRight } = this.getColumnBounds(column);\n const isRtl = this.enableRtl;\n const columnBeforeStart = isRtl ? (viewportStart > colRight) : (viewportEnd < colRight);\n const columnAfterEnd = isRtl ? (viewportEnd < colLeft) : (viewportStart > colLeft);\n return { columnBeforeStart, columnAfterEnd };\n }\n getColumnBounds(column) {\n const isRtl = this.enableRtl;\n const bodyWidth = this.columnModel.getBodyContainerWidth();\n const colWidth = column.getActualWidth();\n const colLeft = column.getLeft();\n const multiplier = isRtl ? -1 : 1;\n const colLeftPixel = isRtl ? (bodyWidth - colLeft) : colLeft;\n const colRightPixel = colLeftPixel + colWidth * multiplier;\n const colMidPixel = colLeftPixel + colWidth / 2 * multiplier;\n return { colLeft: colLeftPixel, colMiddle: colMidPixel, colRight: colRightPixel };\n }\n getViewportBounds() {\n const viewportWidth = this.centerRowContainerCtrl.getCenterWidth();\n const scrollPosition = this.centerRowContainerCtrl.getCenterViewportScrollLeft();\n const viewportStartPixel = scrollPosition;\n const viewportEndPixel = viewportWidth + scrollPosition;\n return { start: viewportStartPixel, end: viewportEndPixel, width: viewportWidth };\n }\n}\n__decorate([\n Autowired('ctrlsService')\n], GridBodyScrollFeature.prototype, \"ctrlsService\", void 0);\n__decorate([\n Autowired('animationFrameService')\n], GridBodyScrollFeature.prototype, \"animationFrameService\", void 0);\n__decorate([\n Autowired('paginationProxy')\n], GridBodyScrollFeature.prototype, \"paginationProxy\", void 0);\n__decorate([\n Autowired('rowModel')\n], GridBodyScrollFeature.prototype, \"rowModel\", void 0);\n__decorate([\n Autowired('rowContainerHeightService')\n], GridBodyScrollFeature.prototype, \"heightScaler\", void 0);\n__decorate([\n Autowired('rowRenderer')\n], GridBodyScrollFeature.prototype, \"rowRenderer\", void 0);\n__decorate([\n Autowired('columnModel')\n], GridBodyScrollFeature.prototype, \"columnModel\", void 0);\n__decorate([\n PostConstruct\n], GridBodyScrollFeature.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { DragAndDropService, DragSourceType, VerticalDirection } from \"../dragAndDrop/dragAndDropService.mjs\";\nimport { Autowired, Optional, PostConstruct } from \"../context/context.mjs\";\nimport { Events } from \"../eventKeys.mjs\";\nimport { RowHighlightPosition } from \"../interfaces/iRowNode.mjs\";\nimport { last } from '../utils/array.mjs';\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { missingOrEmpty } from \"../utils/generic.mjs\";\nimport { doOnce } from \"../utils/function.mjs\";\nimport { AutoScrollService } from \"../autoScrollService.mjs\";\nexport class RowDragFeature extends BeanStub {\n constructor(eContainer) {\n super();\n this.isMultiRowDrag = false;\n this.isGridSorted = false;\n this.isGridFiltered = false;\n this.isRowGroupActive = false;\n this.eContainer = eContainer;\n }\n postConstruct() {\n if (this.gridOptionsService.isRowModelType('clientSide')) {\n this.clientSideRowModel = this.rowModel;\n }\n const refreshStatus = () => {\n this.onSortChanged();\n this.onFilterChanged();\n this.onRowGroupChanged();\n };\n this.addManagedListener(this.eventService, Events.EVENT_SORT_CHANGED, this.onSortChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_FILTER_CHANGED, this.onFilterChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, this.onRowGroupChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_MODEL_UPDATED, () => {\n refreshStatus();\n });\n refreshStatus();\n this.ctrlsService.whenReady(() => {\n const gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n this.autoScrollService = new AutoScrollService({\n scrollContainer: gridBodyCon.getBodyViewportElement(),\n scrollAxis: 'y',\n getVerticalPosition: () => gridBodyCon.getScrollFeature().getVScrollPosition().top,\n setVerticalPosition: (position) => gridBodyCon.getScrollFeature().setVerticalScrollPosition(position),\n onScrollCallback: () => { this.onDragging(this.lastDraggingEvent); }\n });\n });\n }\n onSortChanged() {\n this.isGridSorted = this.sortController.isSortActive();\n }\n onFilterChanged() {\n this.isGridFiltered = this.filterManager.isAnyFilterPresent();\n }\n onRowGroupChanged() {\n const rowGroups = this.columnModel.getRowGroupColumns();\n this.isRowGroupActive = !missingOrEmpty(rowGroups);\n }\n getContainer() {\n return this.eContainer;\n }\n isInterestedIn(type) {\n return type === DragSourceType.RowDrag;\n }\n getIconName() {\n const managedDrag = this.gridOptionsService.is('rowDragManaged');\n if (managedDrag && this.shouldPreventRowMove()) {\n return DragAndDropService.ICON_NOT_ALLOWED;\n }\n return DragAndDropService.ICON_MOVE;\n }\n shouldPreventRowMove() {\n return this.isGridSorted || this.isGridFiltered || this.isRowGroupActive;\n }\n getRowNodes(draggingEvent) {\n if (!this.isFromThisGrid(draggingEvent)) {\n return (draggingEvent.dragItem.rowNodes || []);\n }\n const isRowDragMultiRow = this.gridOptionsService.is('rowDragMultiRow');\n const selectedNodes = [...this.selectionService.getSelectedNodes()].sort((a, b) => {\n if (a.rowIndex == null || b.rowIndex == null) {\n return 0;\n }\n return this.getRowIndexNumber(a) - this.getRowIndexNumber(b);\n });\n const currentNode = draggingEvent.dragItem.rowNode;\n if (isRowDragMultiRow && selectedNodes.indexOf(currentNode) !== -1) {\n this.isMultiRowDrag = true;\n return selectedNodes;\n }\n this.isMultiRowDrag = false;\n return [currentNode];\n }\n onDragEnter(draggingEvent) {\n // builds a lits of all rows being dragged before firing events\n draggingEvent.dragItem.rowNodes = this.getRowNodes(draggingEvent);\n // when entering, we fire the enter event, then in onEnterOrDragging,\n // we also fire the move event. so we get both events when entering.\n this.dispatchGridEvent(Events.EVENT_ROW_DRAG_ENTER, draggingEvent);\n this.getRowNodes(draggingEvent).forEach(rowNode => {\n rowNode.setDragging(true);\n });\n this.onEnterOrDragging(draggingEvent);\n }\n onDragging(draggingEvent) {\n this.onEnterOrDragging(draggingEvent);\n }\n isFromThisGrid(draggingEvent) {\n const { dragSourceDomDataKey } = draggingEvent.dragSource;\n return dragSourceDomDataKey === this.gridOptionsService.getDomDataKey();\n }\n isDropZoneWithinThisGrid(draggingEvent) {\n const gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n const gridGui = gridBodyCon.getGui();\n const { dropZoneTarget } = draggingEvent;\n return !gridGui.contains(dropZoneTarget);\n }\n onEnterOrDragging(draggingEvent) {\n // this event is fired for enter and move\n this.dispatchGridEvent(Events.EVENT_ROW_DRAG_MOVE, draggingEvent);\n this.lastDraggingEvent = draggingEvent;\n const pixel = this.mouseEventService.getNormalisedPosition(draggingEvent).y;\n const managedDrag = this.gridOptionsService.is('rowDragManaged');\n if (managedDrag) {\n this.doManagedDrag(draggingEvent, pixel);\n }\n this.autoScrollService.check(draggingEvent.event);\n }\n doManagedDrag(draggingEvent, pixel) {\n const isFromThisGrid = this.isFromThisGrid(draggingEvent);\n const managedDrag = this.gridOptionsService.is('rowDragManaged');\n const rowNodes = draggingEvent.dragItem.rowNodes;\n if (managedDrag && this.shouldPreventRowMove()) {\n return;\n }\n if (this.gridOptionsService.is('suppressMoveWhenRowDragging') || !isFromThisGrid) {\n if (!this.isDropZoneWithinThisGrid(draggingEvent)) {\n this.clientSideRowModel.highlightRowAtPixel(rowNodes[0], pixel);\n }\n }\n else {\n this.moveRows(rowNodes, pixel);\n }\n }\n getRowIndexNumber(rowNode) {\n return parseInt(last(rowNode.getRowIndexString().split('-')), 10);\n }\n moveRowAndClearHighlight(draggingEvent) {\n const lastHighlightedRowNode = this.clientSideRowModel.getLastHighlightedRowNode();\n const isBelow = lastHighlightedRowNode && lastHighlightedRowNode.highlighted === RowHighlightPosition.Below;\n const pixel = this.mouseEventService.getNormalisedPosition(draggingEvent).y;\n const rowNodes = draggingEvent.dragItem.rowNodes;\n let increment = isBelow ? 1 : 0;\n if (this.isFromThisGrid(draggingEvent)) {\n rowNodes.forEach(rowNode => {\n if (rowNode.rowTop < pixel) {\n increment -= 1;\n }\n });\n this.moveRows(rowNodes, pixel, increment);\n }\n else {\n const getRowIdFunc = this.gridOptionsService.getCallback('getRowId');\n let addIndex = this.clientSideRowModel.getRowIndexAtPixel(pixel) + 1;\n if (this.clientSideRowModel.getHighlightPosition(pixel) === RowHighlightPosition.Above) {\n addIndex--;\n }\n this.clientSideRowModel.updateRowData({\n add: rowNodes\n .map(node => node.data)\n .filter(data => !this.clientSideRowModel.getRowNode(getRowIdFunc ? getRowIdFunc({ data, level: 0 }) : data.id)),\n addIndex\n });\n }\n this.clearRowHighlight();\n }\n clearRowHighlight() {\n this.clientSideRowModel.highlightRowAtPixel(null);\n }\n moveRows(rowNodes, pixel, increment = 0) {\n const rowWasMoved = this.clientSideRowModel.ensureRowsAtPixel(rowNodes, pixel, increment);\n if (rowWasMoved) {\n this.focusService.clearFocusedCell();\n if (this.rangeService) {\n this.rangeService.removeAllCellRanges();\n }\n }\n }\n addRowDropZone(params) {\n if (!params.getContainer()) {\n doOnce(() => console.warn('AG Grid: addRowDropZone - A container target needs to be provided'), 'add-drop-zone-empty-target');\n return;\n }\n if (this.dragAndDropService.findExternalZone(params)) {\n console.warn('AG Grid: addRowDropZone - target already exists in the list of DropZones. Use `removeRowDropZone` before adding it again.');\n return;\n }\n let processedParams = {\n getContainer: params.getContainer\n };\n if (params.fromGrid) {\n params.fromGrid = undefined;\n processedParams = params;\n }\n else {\n if (params.onDragEnter) {\n processedParams.onDragEnter = (e) => {\n params.onDragEnter(this.draggingToRowDragEvent(Events.EVENT_ROW_DRAG_ENTER, e));\n };\n }\n if (params.onDragLeave) {\n processedParams.onDragLeave = (e) => {\n params.onDragLeave(this.draggingToRowDragEvent(Events.EVENT_ROW_DRAG_LEAVE, e));\n };\n }\n if (params.onDragging) {\n processedParams.onDragging = (e) => {\n params.onDragging(this.draggingToRowDragEvent(Events.EVENT_ROW_DRAG_MOVE, e));\n };\n }\n if (params.onDragStop) {\n processedParams.onDragStop = (e) => {\n params.onDragStop(this.draggingToRowDragEvent(Events.EVENT_ROW_DRAG_END, e));\n };\n }\n }\n this.dragAndDropService.addDropTarget(Object.assign({ isInterestedIn: (type) => type === DragSourceType.RowDrag, getIconName: () => DragAndDropService.ICON_MOVE, external: true }, processedParams));\n }\n getRowDropZone(events) {\n const getContainer = this.getContainer.bind(this);\n const onDragEnter = this.onDragEnter.bind(this);\n const onDragLeave = this.onDragLeave.bind(this);\n const onDragging = this.onDragging.bind(this);\n const onDragStop = this.onDragStop.bind(this);\n if (!events) {\n return { getContainer, onDragEnter, onDragLeave, onDragging, onDragStop, /* @private */ fromGrid: true };\n }\n return {\n getContainer,\n onDragEnter: events.onDragEnter\n ? ((e) => {\n onDragEnter(e);\n events.onDragEnter(this.draggingToRowDragEvent(Events.EVENT_ROW_DRAG_ENTER, e));\n })\n : onDragEnter,\n onDragLeave: events.onDragLeave\n ? ((e) => {\n onDragLeave(e);\n events.onDragLeave(this.draggingToRowDragEvent(Events.EVENT_ROW_DRAG_LEAVE, e));\n })\n : onDragLeave,\n onDragging: events.onDragging\n ? ((e) => {\n onDragging(e);\n events.onDragging(this.draggingToRowDragEvent(Events.EVENT_ROW_DRAG_MOVE, e));\n })\n : onDragging,\n onDragStop: events.onDragStop\n ? ((e) => {\n onDragStop(e);\n events.onDragStop(this.draggingToRowDragEvent(Events.EVENT_ROW_DRAG_END, e));\n })\n : onDragStop,\n fromGrid: true /* @private */\n };\n }\n draggingToRowDragEvent(type, draggingEvent) {\n const yNormalised = this.mouseEventService.getNormalisedPosition(draggingEvent).y;\n const mouseIsPastLastRow = yNormalised > this.paginationProxy.getCurrentPageHeight();\n let overIndex = -1;\n let overNode;\n if (!mouseIsPastLastRow) {\n overIndex = this.rowModel.getRowIndexAtPixel(yNormalised);\n overNode = this.rowModel.getRow(overIndex);\n }\n let vDirectionString;\n switch (draggingEvent.vDirection) {\n case VerticalDirection.Down:\n vDirectionString = 'down';\n break;\n case VerticalDirection.Up:\n vDirectionString = 'up';\n break;\n default:\n vDirectionString = null;\n break;\n }\n const event = {\n type: type,\n api: this.gridOptionsService.api,\n columnApi: this.gridOptionsService.columnApi,\n context: this.gridOptionsService.context,\n event: draggingEvent.event,\n node: draggingEvent.dragItem.rowNode,\n nodes: draggingEvent.dragItem.rowNodes,\n overIndex: overIndex,\n overNode: overNode,\n y: yNormalised,\n vDirection: vDirectionString\n };\n return event;\n }\n dispatchGridEvent(type, draggingEvent) {\n const event = this.draggingToRowDragEvent(type, draggingEvent);\n this.eventService.dispatchEvent(event);\n }\n onDragLeave(draggingEvent) {\n this.dispatchGridEvent(Events.EVENT_ROW_DRAG_LEAVE, draggingEvent);\n this.stopDragging(draggingEvent);\n if (this.gridOptionsService.is('rowDragManaged')) {\n this.clearRowHighlight();\n }\n if (this.isFromThisGrid(draggingEvent)) {\n this.isMultiRowDrag = false;\n }\n }\n onDragStop(draggingEvent) {\n this.dispatchGridEvent(Events.EVENT_ROW_DRAG_END, draggingEvent);\n this.stopDragging(draggingEvent);\n if (this.gridOptionsService.is('rowDragManaged') &&\n (this.gridOptionsService.is('suppressMoveWhenRowDragging') || !this.isFromThisGrid(draggingEvent)) &&\n !this.isDropZoneWithinThisGrid(draggingEvent)) {\n this.moveRowAndClearHighlight(draggingEvent);\n }\n }\n stopDragging(draggingEvent) {\n this.autoScrollService.ensureCleared();\n this.getRowNodes(draggingEvent).forEach(rowNode => {\n rowNode.setDragging(false);\n });\n }\n}\n__decorate([\n Autowired('dragAndDropService')\n], RowDragFeature.prototype, \"dragAndDropService\", void 0);\n__decorate([\n Autowired('rowModel')\n], RowDragFeature.prototype, \"rowModel\", void 0);\n__decorate([\n Autowired('paginationProxy')\n], RowDragFeature.prototype, \"paginationProxy\", void 0);\n__decorate([\n Autowired('columnModel')\n], RowDragFeature.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('focusService')\n], RowDragFeature.prototype, \"focusService\", void 0);\n__decorate([\n Autowired('sortController')\n], RowDragFeature.prototype, \"sortController\", void 0);\n__decorate([\n Autowired('filterManager')\n], RowDragFeature.prototype, \"filterManager\", void 0);\n__decorate([\n Autowired('selectionService')\n], RowDragFeature.prototype, \"selectionService\", void 0);\n__decorate([\n Autowired('mouseEventService')\n], RowDragFeature.prototype, \"mouseEventService\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], RowDragFeature.prototype, \"ctrlsService\", void 0);\n__decorate([\n Optional('rangeService')\n], RowDragFeature.prototype, \"rangeService\", void 0);\n__decorate([\n PostConstruct\n], RowDragFeature.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { Autowired, Optional } from \"../context/context.mjs\";\nimport { LayoutFeature } from \"../styling/layoutFeature.mjs\";\nimport { Events } from \"../eventKeys.mjs\";\nimport { GridBodyScrollFeature } from \"./gridBodyScrollFeature.mjs\";\nimport { getInnerWidth, isElementChildOfClass, isVerticalScrollShowing } from \"../utils/dom.mjs\";\nimport { RowDragFeature } from \"./rowDragFeature.mjs\";\nimport { getTabIndex, isInvisibleScrollbar, isIOSUserAgent } from \"../utils/browser.mjs\";\nimport { TouchListener } from \"../widgets/touchListener.mjs\";\nexport var RowAnimationCssClasses;\n(function (RowAnimationCssClasses) {\n RowAnimationCssClasses[\"ANIMATION_ON\"] = \"ag-row-animation\";\n RowAnimationCssClasses[\"ANIMATION_OFF\"] = \"ag-row-no-animation\";\n})(RowAnimationCssClasses || (RowAnimationCssClasses = {}));\nexport const CSS_CLASS_FORCE_VERTICAL_SCROLL = 'ag-force-vertical-scroll';\nconst CSS_CLASS_CELL_SELECTABLE = 'ag-selectable';\nconst CSS_CLASS_COLUMN_MOVING = 'ag-column-moving';\nexport class GridBodyCtrl extends BeanStub {\n constructor() {\n super(...arguments);\n this.stickyTopHeight = 0;\n }\n getScrollFeature() {\n return this.bodyScrollFeature;\n }\n getBodyViewportElement() {\n return this.eBodyViewport;\n }\n setComp(comp, eGridBody, eBodyViewport, eTop, eBottom, eStickyTop) {\n this.comp = comp;\n this.eGridBody = eGridBody;\n this.eBodyViewport = eBodyViewport;\n this.eTop = eTop;\n this.eBottom = eBottom;\n this.eStickyTop = eStickyTop;\n this.setCellTextSelection(this.gridOptionsService.is('enableCellTextSelection'));\n this.createManagedBean(new LayoutFeature(this.comp));\n this.bodyScrollFeature = this.createManagedBean(new GridBodyScrollFeature(this.eBodyViewport));\n this.addRowDragListener();\n this.setupRowAnimationCssClass();\n this.addEventListeners();\n this.addFocusListeners([eTop, eBodyViewport, eBottom, eStickyTop]);\n this.onGridColumnsChanged();\n this.addBodyViewportListener();\n this.setFloatingHeights();\n this.disableBrowserDragging();\n this.addStopEditingWhenGridLosesFocus();\n this.filterManager.setupAdvancedFilterHeaderComp(eTop);\n this.ctrlsService.registerGridBodyCtrl(this);\n }\n getComp() {\n return this.comp;\n }\n addEventListeners() {\n this.addManagedListener(this.eventService, Events.EVENT_GRID_COLUMNS_CHANGED, this.onGridColumnsChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_SCROLL_VISIBILITY_CHANGED, this.onScrollVisibilityChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_PINNED_ROW_DATA_CHANGED, this.onPinnedRowDataChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_HEADER_HEIGHT_CHANGED, this.onHeaderHeightChanged.bind(this));\n }\n addFocusListeners(elements) {\n elements.forEach(element => {\n this.addManagedListener(element, 'focusin', (e) => {\n const { target } = e;\n // element being focused is nested?\n const isFocusedElementNested = isElementChildOfClass(target, 'ag-root', element);\n element.classList.toggle('ag-has-focus', !isFocusedElementNested);\n });\n this.addManagedListener(element, 'focusout', (e) => {\n const { target, relatedTarget } = e;\n const gridContainRelatedTarget = element.contains(relatedTarget);\n const isNestedRelatedTarget = isElementChildOfClass(relatedTarget, 'ag-root', element);\n const isNestedTarget = isElementChildOfClass(target, 'ag-root', element);\n // element losing focus belongs to a nested grid,\n // it should not be handled here.\n if (isNestedTarget) {\n return;\n }\n // the grid does not contain, or the focus element is within\n // a nested grid\n if (!gridContainRelatedTarget || isNestedRelatedTarget) {\n element.classList.remove('ag-has-focus');\n }\n });\n });\n }\n // used by ColumnAnimationService\n setColumnMovingCss(moving) {\n this.comp.setColumnMovingCss(CSS_CLASS_COLUMN_MOVING, moving);\n }\n setCellTextSelection(selectable = false) {\n this.comp.setCellSelectableCss(CSS_CLASS_CELL_SELECTABLE, selectable);\n }\n onScrollVisibilityChanged() {\n const visible = this.scrollVisibleService.isVerticalScrollShowing();\n this.setVerticalScrollPaddingVisible(visible);\n this.setStickyTopWidth(visible);\n const scrollbarWidth = visible ? (this.gridOptionsService.getScrollbarWidth() || 0) : 0;\n const pad = isInvisibleScrollbar() ? 16 : 0;\n const width = `calc(100% + ${scrollbarWidth + pad}px)`;\n this.animationFrameService.requestAnimationFrame(() => this.comp.setBodyViewportWidth(width));\n }\n onGridColumnsChanged() {\n const columns = this.columnModel.getAllGridColumns();\n this.comp.setColumnCount(columns ? columns.length : 0);\n }\n // if we do not do this, then the user can select a pic in the grid (eg an image in a custom cell renderer)\n // and then that will start the browser native drag n' drop, which messes up with our own drag and drop.\n disableBrowserDragging() {\n this.addManagedListener(this.eGridBody, 'dragstart', (event) => {\n if (event.target instanceof HTMLImageElement) {\n event.preventDefault();\n return false;\n }\n });\n }\n addStopEditingWhenGridLosesFocus() {\n if (!this.gridOptionsService.is('stopEditingWhenCellsLoseFocus')) {\n return;\n }\n const focusOutListener = (event) => {\n // this is the element the focus is moving to\n const elementWithFocus = event.relatedTarget;\n if (getTabIndex(elementWithFocus) === null) {\n this.rowRenderer.stopEditing();\n return;\n }\n let clickInsideGrid = \n // see if click came from inside the viewports\n viewports.some(viewport => viewport.contains(elementWithFocus))\n // and also that it's not from a detail grid\n && this.mouseEventService.isElementInThisGrid(elementWithFocus);\n if (!clickInsideGrid) {\n const popupService = this.popupService;\n clickInsideGrid =\n popupService.getActivePopups().some(popup => popup.contains(elementWithFocus)) ||\n popupService.isElementWithinCustomPopup(elementWithFocus);\n }\n if (!clickInsideGrid) {\n this.rowRenderer.stopEditing();\n }\n };\n const viewports = [this.eBodyViewport, this.eBottom, this.eTop, this.eStickyTop];\n viewports.forEach(viewport => this.addManagedListener(viewport, 'focusout', focusOutListener));\n }\n updateRowCount() {\n const headerCount = this.headerNavigationService.getHeaderRowCount() + this.filterManager.getHeaderRowCount();\n const rowCount = this.rowModel.isLastRowIndexKnown() ? this.rowModel.getRowCount() : -1;\n const total = rowCount === -1 ? -1 : (headerCount + rowCount);\n this.comp.setRowCount(total);\n }\n registerBodyViewportResizeListener(listener) {\n this.comp.registerBodyViewportResizeListener(listener);\n }\n setVerticalScrollPaddingVisible(visible) {\n const overflowY = visible ? 'scroll' : 'hidden';\n this.comp.setPinnedTopBottomOverflowY(overflowY);\n }\n isVerticalScrollShowing() {\n const show = this.gridOptionsService.is('alwaysShowVerticalScroll');\n const cssClass = show ? CSS_CLASS_FORCE_VERTICAL_SCROLL : null;\n const allowVerticalScroll = this.gridOptionsService.isDomLayout('normal');\n this.comp.setAlwaysVerticalScrollClass(cssClass, show);\n return show || (allowVerticalScroll && isVerticalScrollShowing(this.eBodyViewport));\n }\n setupRowAnimationCssClass() {\n const listener = () => {\n // we don't want to use row animation if scaling, as rows jump strangely as you scroll,\n // when scaling and doing row animation.\n const animateRows = this.gridOptionsService.isAnimateRows() && !this.rowContainerHeightService.isStretching();\n const animateRowsCssClass = animateRows ? RowAnimationCssClasses.ANIMATION_ON : RowAnimationCssClasses.ANIMATION_OFF;\n this.comp.setRowAnimationCssOnBodyViewport(animateRowsCssClass, animateRows);\n };\n listener();\n this.addManagedListener(this.eventService, Events.EVENT_HEIGHT_SCALE_CHANGED, listener);\n this.addManagedPropertyListener('animateRows', listener);\n }\n getGridBodyElement() {\n return this.eGridBody;\n }\n addBodyViewportListener() {\n // we want to listen for clicks directly on the eBodyViewport, so the user has a way of showing\n // the context menu if no rows or columns are displayed, or user simply clicks outside of a cell\n const listener = this.onBodyViewportContextMenu.bind(this);\n this.addManagedListener(this.eBodyViewport, 'contextmenu', listener);\n this.mockContextMenuForIPad(listener);\n this.addManagedListener(this.eBodyViewport, 'wheel', this.onBodyViewportWheel.bind(this));\n this.addManagedListener(this.eStickyTop, 'wheel', this.onStickyTopWheel.bind(this));\n // allow mouseWheel on the Full Width Container to Scroll the Viewport\n this.addFullWidthContainerWheelListener();\n }\n addFullWidthContainerWheelListener() {\n const fullWidthContainer = this.eBodyViewport.querySelector('.ag-full-width-container');\n const eCenterColsViewport = this.eBodyViewport.querySelector('.ag-center-cols-viewport');\n if (fullWidthContainer && eCenterColsViewport) {\n this.addManagedListener(fullWidthContainer, 'wheel', (e) => this.onFullWidthContainerWheel(e, eCenterColsViewport));\n }\n }\n onFullWidthContainerWheel(e, eCenterColsViewport) {\n if (!e.deltaX ||\n Math.abs(e.deltaY) > Math.abs(e.deltaX) ||\n !this.mouseEventService.isEventFromThisGrid(e)) {\n return;\n }\n e.preventDefault();\n eCenterColsViewport.scrollBy({ left: e.deltaX });\n }\n onBodyViewportContextMenu(mouseEvent, touch, touchEvent) {\n if (!mouseEvent && !touchEvent) {\n return;\n }\n if (this.gridOptionsService.is('preventDefaultOnContextMenu')) {\n const event = (mouseEvent || touchEvent);\n event.preventDefault();\n }\n const { target } = (mouseEvent || touch);\n if (target === this.eBodyViewport || target === this.ctrlsService.getCenterRowContainerCtrl().getViewportElement()) {\n // show it\n if (!this.contextMenuFactory) {\n return;\n }\n if (mouseEvent) {\n this.contextMenuFactory.onContextMenu(mouseEvent, null, null, null, null, this.eGridBody);\n }\n else if (touchEvent) {\n this.contextMenuFactory.onContextMenu(null, touchEvent, null, null, null, this.eGridBody);\n }\n }\n }\n mockContextMenuForIPad(listener) {\n // we do NOT want this when not in iPad\n if (!isIOSUserAgent()) {\n return;\n }\n const touchListener = new TouchListener(this.eBodyViewport);\n const longTapListener = (event) => {\n listener(undefined, event.touchStart, event.touchEvent);\n };\n this.addManagedListener(touchListener, TouchListener.EVENT_LONG_TAP, longTapListener);\n this.addDestroyFunc(() => touchListener.destroy());\n }\n onBodyViewportWheel(e) {\n if (!this.gridOptionsService.is('suppressScrollWhenPopupsAreOpen')) {\n return;\n }\n if (this.popupService.hasAnchoredPopup()) {\n e.preventDefault();\n }\n }\n onStickyTopWheel(e) {\n e.preventDefault();\n if (e.offsetY) {\n this.scrollVertically(e.deltaY);\n }\n }\n getGui() {\n return this.eGridBody;\n }\n // called by rowDragFeature\n scrollVertically(pixels) {\n const oldScrollPosition = this.eBodyViewport.scrollTop;\n this.bodyScrollFeature.setVerticalScrollPosition(oldScrollPosition + pixels);\n return this.eBodyViewport.scrollTop - oldScrollPosition;\n }\n addRowDragListener() {\n this.rowDragFeature = this.createManagedBean(new RowDragFeature(this.eBodyViewport));\n this.dragAndDropService.addDropTarget(this.rowDragFeature);\n }\n getRowDragFeature() {\n return this.rowDragFeature;\n }\n onPinnedRowDataChanged() {\n this.setFloatingHeights();\n }\n setFloatingHeights() {\n const { pinnedRowModel } = this;\n let floatingTopHeight = pinnedRowModel.getPinnedTopTotalHeight();\n if (floatingTopHeight) {\n // adding 1px for cell bottom border\n floatingTopHeight += 1;\n }\n let floatingBottomHeight = pinnedRowModel.getPinnedBottomTotalHeight();\n if (floatingBottomHeight) {\n // adding 1px for cell bottom border\n floatingBottomHeight += 1;\n }\n this.comp.setTopHeight(floatingTopHeight);\n this.comp.setBottomHeight(floatingBottomHeight);\n this.comp.setTopDisplay(floatingTopHeight ? 'inherit' : 'none');\n this.comp.setBottomDisplay(floatingBottomHeight ? 'inherit' : 'none');\n this.setStickyTopOffsetTop();\n }\n setStickyTopHeight(height = 0) {\n // console.log('setting sticky top height ' + height);\n this.comp.setStickyTopHeight(`${height}px`);\n this.stickyTopHeight = height;\n }\n getStickyTopHeight() {\n return this.stickyTopHeight;\n }\n setStickyTopWidth(vScrollVisible) {\n if (!vScrollVisible) {\n this.comp.setStickyTopWidth('100%');\n }\n else {\n const scrollbarWidth = this.gridOptionsService.getScrollbarWidth();\n this.comp.setStickyTopWidth(`calc(100% - ${scrollbarWidth}px)`);\n }\n }\n onHeaderHeightChanged() {\n this.setStickyTopOffsetTop();\n }\n setStickyTopOffsetTop() {\n const headerCtrl = this.ctrlsService.getGridHeaderCtrl();\n const headerHeight = headerCtrl.getHeaderHeight() + this.filterManager.getHeaderHeight();\n const pinnedTopHeight = this.pinnedRowModel.getPinnedTopTotalHeight();\n let height = 0;\n if (headerHeight > 0) {\n height += headerHeight + 1;\n }\n if (pinnedTopHeight > 0) {\n height += pinnedTopHeight + 1;\n }\n this.comp.setStickyTopTop(`${height}px`);\n }\n // method will call itself if no available width. this covers if the grid\n // isn't visible, but is just about to be visible.\n sizeColumnsToFit(params, nextTimeout) {\n const removeScrollWidth = this.isVerticalScrollShowing();\n const scrollWidthToRemove = removeScrollWidth ? this.gridOptionsService.getScrollbarWidth() : 0;\n // bodyViewportWidth should be calculated from eGridBody, not eBodyViewport\n // because we change the width of the bodyViewport to hide the real browser scrollbar\n const bodyViewportWidth = getInnerWidth(this.eGridBody);\n const availableWidth = bodyViewportWidth - scrollWidthToRemove;\n if (availableWidth > 0) {\n this.columnModel.sizeColumnsToFit(availableWidth, \"sizeColumnsToFit\", false, params);\n return;\n }\n if (nextTimeout === undefined) {\n window.setTimeout(() => {\n this.sizeColumnsToFit(params, 100);\n }, 0);\n }\n else if (nextTimeout === 100) {\n window.setTimeout(() => {\n this.sizeColumnsToFit(params, 500);\n }, 100);\n }\n else if (nextTimeout === 500) {\n window.setTimeout(() => {\n this.sizeColumnsToFit(params, -1);\n }, 500);\n }\n else {\n console.warn('AG Grid: tried to call sizeColumnsToFit() but the grid is coming back with ' +\n 'zero width, maybe the grid is not visible yet on the screen?');\n }\n }\n // + rangeService\n addScrollEventListener(listener) {\n this.eBodyViewport.addEventListener('scroll', listener, { passive: true });\n }\n // + focusService\n removeScrollEventListener(listener) {\n this.eBodyViewport.removeEventListener('scroll', listener);\n }\n}\n__decorate([\n Autowired('animationFrameService')\n], GridBodyCtrl.prototype, \"animationFrameService\", void 0);\n__decorate([\n Autowired('rowContainerHeightService')\n], GridBodyCtrl.prototype, \"rowContainerHeightService\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], GridBodyCtrl.prototype, \"ctrlsService\", void 0);\n__decorate([\n Autowired('columnModel')\n], GridBodyCtrl.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('scrollVisibleService')\n], GridBodyCtrl.prototype, \"scrollVisibleService\", void 0);\n__decorate([\n Optional('contextMenuFactory')\n], GridBodyCtrl.prototype, \"contextMenuFactory\", void 0);\n__decorate([\n Autowired('headerNavigationService')\n], GridBodyCtrl.prototype, \"headerNavigationService\", void 0);\n__decorate([\n Autowired('dragAndDropService')\n], GridBodyCtrl.prototype, \"dragAndDropService\", void 0);\n__decorate([\n Autowired('pinnedRowModel')\n], GridBodyCtrl.prototype, \"pinnedRowModel\", void 0);\n__decorate([\n Autowired('rowRenderer')\n], GridBodyCtrl.prototype, \"rowRenderer\", void 0);\n__decorate([\n Autowired('popupService')\n], GridBodyCtrl.prototype, \"popupService\", void 0);\n__decorate([\n Autowired('mouseEventService')\n], GridBodyCtrl.prototype, \"mouseEventService\", void 0);\n__decorate([\n Autowired('rowModel')\n], GridBodyCtrl.prototype, \"rowModel\", void 0);\n__decorate([\n Autowired('filterManager')\n], GridBodyCtrl.prototype, \"filterManager\", void 0);\n","export var SelectionHandleType;\n(function (SelectionHandleType) {\n SelectionHandleType[SelectionHandleType[\"FILL\"] = 0] = \"FILL\";\n SelectionHandleType[SelectionHandleType[\"RANGE\"] = 1] = \"RANGE\";\n})(SelectionHandleType || (SelectionHandleType = {}));\nexport var CellRangeType;\n(function (CellRangeType) {\n CellRangeType[CellRangeType[\"VALUE\"] = 0] = \"VALUE\";\n CellRangeType[CellRangeType[\"DIMENSION\"] = 1] = \"DIMENSION\";\n})(CellRangeType || (CellRangeType = {}));\n","import { includes, last } from \"../../utils/array.mjs\";\nimport { CellRangeType, SelectionHandleType } from \"../../interfaces/IRangeService.mjs\";\nimport { missing } from \"../../utils/generic.mjs\";\nimport { setAriaSelected } from \"../../utils/aria.mjs\";\nconst CSS_CELL_RANGE_SELECTED = 'ag-cell-range-selected';\nconst CSS_CELL_RANGE_CHART = 'ag-cell-range-chart';\nconst CSS_CELL_RANGE_SINGLE_CELL = 'ag-cell-range-single-cell';\nconst CSS_CELL_RANGE_CHART_CATEGORY = 'ag-cell-range-chart-category';\nconst CSS_CELL_RANGE_HANDLE = 'ag-cell-range-handle';\nconst CSS_CELL_RANGE_TOP = 'ag-cell-range-top';\nconst CSS_CELL_RANGE_RIGHT = 'ag-cell-range-right';\nconst CSS_CELL_RANGE_BOTTOM = 'ag-cell-range-bottom';\nconst CSS_CELL_RANGE_LEFT = 'ag-cell-range-left';\nexport class CellRangeFeature {\n constructor(beans, ctrl) {\n this.beans = beans;\n this.cellCtrl = ctrl;\n }\n setComp(cellComp, eGui) {\n this.cellComp = cellComp;\n this.eGui = eGui;\n this.onRangeSelectionChanged();\n }\n onRangeSelectionChanged() {\n // when using reactUi, given UI is async, it's possible this method is called before the comp is registered\n if (!this.cellComp) {\n return;\n }\n this.rangeCount = this.beans.rangeService.getCellRangeCount(this.cellCtrl.getCellPosition());\n this.hasChartRange = this.getHasChartRange();\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_SELECTED, this.rangeCount !== 0);\n this.cellComp.addOrRemoveCssClass(`${CSS_CELL_RANGE_SELECTED}-1`, this.rangeCount === 1);\n this.cellComp.addOrRemoveCssClass(`${CSS_CELL_RANGE_SELECTED}-2`, this.rangeCount === 2);\n this.cellComp.addOrRemoveCssClass(`${CSS_CELL_RANGE_SELECTED}-3`, this.rangeCount === 3);\n this.cellComp.addOrRemoveCssClass(`${CSS_CELL_RANGE_SELECTED}-4`, this.rangeCount >= 4);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_CHART, this.hasChartRange);\n setAriaSelected(this.eGui, this.rangeCount > 0 ? true : undefined);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_SINGLE_CELL, this.isSingleCell());\n this.updateRangeBorders();\n this.refreshHandle();\n }\n updateRangeBorders() {\n const rangeBorders = this.getRangeBorders();\n const isSingleCell = this.isSingleCell();\n const isTop = !isSingleCell && rangeBorders.top;\n const isRight = !isSingleCell && rangeBorders.right;\n const isBottom = !isSingleCell && rangeBorders.bottom;\n const isLeft = !isSingleCell && rangeBorders.left;\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_TOP, isTop);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_RIGHT, isRight);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_BOTTOM, isBottom);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_LEFT, isLeft);\n }\n isSingleCell() {\n const { rangeService } = this.beans;\n return this.rangeCount === 1 && rangeService && !rangeService.isMoreThanOneCell();\n }\n getHasChartRange() {\n const { rangeService } = this.beans;\n if (!this.rangeCount || !rangeService) {\n return false;\n }\n const cellRanges = rangeService.getCellRanges();\n return cellRanges.length > 0 && cellRanges.every(range => includes([CellRangeType.DIMENSION, CellRangeType.VALUE], range.type));\n }\n updateRangeBordersIfRangeCount() {\n // we only need to update range borders if we are in a range\n if (this.rangeCount > 0) {\n this.updateRangeBorders();\n this.refreshHandle();\n }\n }\n getRangeBorders() {\n const isRtl = this.beans.gridOptionsService.is('enableRtl');\n let top = false;\n let right = false;\n let bottom = false;\n let left = false;\n const thisCol = this.cellCtrl.getCellPosition().column;\n const { rangeService, columnModel } = this.beans;\n let leftCol;\n let rightCol;\n if (isRtl) {\n leftCol = columnModel.getDisplayedColAfter(thisCol);\n rightCol = columnModel.getDisplayedColBefore(thisCol);\n }\n else {\n leftCol = columnModel.getDisplayedColBefore(thisCol);\n rightCol = columnModel.getDisplayedColAfter(thisCol);\n }\n const ranges = rangeService.getCellRanges().filter(range => rangeService.isCellInSpecificRange(this.cellCtrl.getCellPosition(), range));\n // this means we are the first column in the grid\n if (!leftCol) {\n left = true;\n }\n // this means we are the last column in the grid\n if (!rightCol) {\n right = true;\n }\n for (let i = 0; i < ranges.length; i++) {\n if (top && right && bottom && left) {\n break;\n }\n const range = ranges[i];\n const startRow = rangeService.getRangeStartRow(range);\n const endRow = rangeService.getRangeEndRow(range);\n if (!top && this.beans.rowPositionUtils.sameRow(startRow, this.cellCtrl.getCellPosition())) {\n top = true;\n }\n if (!bottom && this.beans.rowPositionUtils.sameRow(endRow, this.cellCtrl.getCellPosition())) {\n bottom = true;\n }\n if (!left && leftCol && range.columns.indexOf(leftCol) < 0) {\n left = true;\n }\n if (!right && rightCol && range.columns.indexOf(rightCol) < 0) {\n right = true;\n }\n }\n return { top, right, bottom, left };\n }\n refreshHandle() {\n if (!this.beans.rangeService) {\n return;\n }\n const shouldHaveSelectionHandle = this.shouldHaveSelectionHandle();\n if (this.selectionHandle && !shouldHaveSelectionHandle) {\n this.selectionHandle = this.beans.context.destroyBean(this.selectionHandle);\n }\n if (shouldHaveSelectionHandle) {\n this.addSelectionHandle();\n }\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_HANDLE, !!this.selectionHandle);\n }\n shouldHaveSelectionHandle() {\n const { gridOptionsService, rangeService } = this.beans;\n const cellRanges = rangeService.getCellRanges();\n const rangesLen = cellRanges.length;\n if (this.rangeCount < 1 || rangesLen < 1) {\n return false;\n }\n const cellRange = last(cellRanges);\n const cellPosition = this.cellCtrl.getCellPosition();\n const isFillHandleAvailable = gridOptionsService.is('enableFillHandle') && !this.cellCtrl.isSuppressFillHandle();\n const isRangeHandleAvailable = gridOptionsService.is('enableRangeHandle');\n let handleIsAvailable = rangesLen === 1 && !this.cellCtrl.isEditing() && (isFillHandleAvailable || isRangeHandleAvailable);\n if (this.hasChartRange) {\n const hasCategoryRange = cellRanges[0].type === CellRangeType.DIMENSION;\n const isCategoryCell = hasCategoryRange && rangeService.isCellInSpecificRange(cellPosition, cellRanges[0]);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_RANGE_CHART_CATEGORY, isCategoryCell);\n handleIsAvailable = cellRange.type === CellRangeType.VALUE;\n }\n return handleIsAvailable &&\n cellRange.endRow != null &&\n rangeService.isContiguousRange(cellRange) &&\n rangeService.isBottomRightCell(cellRange, cellPosition);\n }\n addSelectionHandle() {\n const { gridOptionsService, rangeService } = this.beans;\n const cellRangeType = last(rangeService.getCellRanges()).type;\n const selectionHandleFill = gridOptionsService.is('enableFillHandle') && missing(cellRangeType);\n const type = selectionHandleFill ? SelectionHandleType.FILL : SelectionHandleType.RANGE;\n if (this.selectionHandle && this.selectionHandle.getType() !== type) {\n this.selectionHandle = this.beans.context.destroyBean(this.selectionHandle);\n }\n if (!this.selectionHandle) {\n this.selectionHandle = this.beans.selectionHandleFactory.createSelectionHandle(type);\n }\n this.selectionHandle.refresh(this.cellCtrl);\n }\n destroy() {\n this.beans.context.destroyBean(this.selectionHandle);\n }\n}\n","import { areEqual, last } from \"../../utils/array.mjs\";\nimport { Events } from \"../../eventKeys.mjs\";\nimport { missing } from \"../../utils/generic.mjs\";\nimport { BeanStub } from \"../../context/beanStub.mjs\";\n/**\n * Takes care of:\n * #) Cell Width (including when doing cell spanning, which makes width cover many columns)\n * #) Cell Height (when doing row span, otherwise we don't touch the height as it's just row height)\n * #) Cell Left (the horizontal positioning of the cell, the vertical positioning is on the row)\n */\nexport class CellPositionFeature extends BeanStub {\n constructor(ctrl, beans) {\n super();\n this.cellCtrl = ctrl;\n this.beans = beans;\n this.column = ctrl.getColumn();\n this.rowNode = ctrl.getRowNode();\n this.setupColSpan();\n this.setupRowSpan();\n }\n setupRowSpan() {\n this.rowSpan = this.column.getRowSpan(this.rowNode);\n }\n setComp(eGui) {\n this.eGui = eGui;\n this.onLeftChanged();\n this.onWidthChanged();\n this.applyRowSpan();\n }\n onDisplayColumnsChanged() {\n const colsSpanning = this.getColSpanningList();\n if (!areEqual(this.colsSpanning, colsSpanning)) {\n this.colsSpanning = colsSpanning;\n this.onWidthChanged();\n this.onLeftChanged(); // left changes when doing RTL\n }\n }\n setupColSpan() {\n // if no col span is active, then we don't set it up, as it would be wasteful of CPU\n if (this.column.getColDef().colSpan == null) {\n return;\n }\n this.colsSpanning = this.getColSpanningList();\n // because we are col spanning, a reorder of the cols can change what cols we are spanning over\n this.addManagedListener(this.beans.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayColumnsChanged.bind(this));\n // because we are spanning over multiple cols, we check for width any time any cols width changes.\n // this is expensive - really we should be explicitly checking only the cols we are spanning over\n // instead of every col, however it would be tricky code to track the cols we are spanning over, so\n // because hardly anyone will be using colSpan, am favouring this easier way for more maintainable code.\n this.addManagedListener(this.beans.eventService, Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, this.onWidthChanged.bind(this));\n }\n onWidthChanged() {\n if (!this.eGui) {\n return;\n }\n const width = this.getCellWidth();\n this.eGui.style.width = `${width}px`;\n }\n getCellWidth() {\n if (!this.colsSpanning) {\n return this.column.getActualWidth();\n }\n return this.colsSpanning.reduce((width, col) => width + col.getActualWidth(), 0);\n }\n getColSpanningList() {\n const colSpan = this.column.getColSpan(this.rowNode);\n const colsSpanning = [];\n // if just one col, the col span is just the column we are in\n if (colSpan === 1) {\n colsSpanning.push(this.column);\n }\n else {\n let pointer = this.column;\n const pinned = this.column.getPinned();\n for (let i = 0; pointer && i < colSpan; i++) {\n colsSpanning.push(pointer);\n pointer = this.beans.columnModel.getDisplayedColAfter(pointer);\n if (!pointer || missing(pointer)) {\n break;\n }\n // we do not allow col spanning to span outside of pinned areas\n if (pinned !== pointer.getPinned()) {\n break;\n }\n }\n }\n return colsSpanning;\n }\n onLeftChanged() {\n if (!this.eGui) {\n return;\n }\n const left = this.modifyLeftForPrintLayout(this.getCellLeft());\n this.eGui.style.left = left + 'px';\n }\n getCellLeft() {\n let mostLeftCol;\n if (this.beans.gridOptionsService.is('enableRtl') && this.colsSpanning) {\n mostLeftCol = last(this.colsSpanning);\n }\n else {\n mostLeftCol = this.column;\n }\n return mostLeftCol.getLeft();\n }\n modifyLeftForPrintLayout(leftPosition) {\n if (!this.cellCtrl.isPrintLayout() || this.column.getPinned() === 'left') {\n return leftPosition;\n }\n const leftWidth = this.beans.columnModel.getDisplayedColumnsLeftWidth();\n if (this.column.getPinned() === 'right') {\n const bodyWidth = this.beans.columnModel.getBodyContainerWidth();\n return leftWidth + bodyWidth + (leftPosition || 0);\n }\n // is in body\n return leftWidth + (leftPosition || 0);\n }\n applyRowSpan() {\n if (this.rowSpan === 1) {\n return;\n }\n const singleRowHeight = this.beans.gridOptionsService.getRowHeightAsNumber();\n const totalRowHeight = singleRowHeight * this.rowSpan;\n this.eGui.style.height = `${totalRowHeight}px`;\n this.eGui.style.zIndex = '1';\n }\n // overriding to make public, as we don't dispose this bean via context\n destroy() {\n super.destroy();\n }\n}\n","import { BeanStub } from \"../../context/beanStub.mjs\";\nexport class CellCustomStyleFeature extends BeanStub {\n constructor(ctrl, beans) {\n super();\n this.staticClasses = [];\n this.cellCtrl = ctrl;\n this.beans = beans;\n this.column = ctrl.getColumn();\n this.rowNode = ctrl.getRowNode();\n }\n setComp(comp) {\n this.cellComp = comp;\n this.applyUserStyles();\n this.applyCellClassRules();\n this.applyClassesFromColDef();\n }\n applyCellClassRules() {\n const colDef = this.column.getColDef();\n const cellClassParams = {\n value: this.cellCtrl.getValue(),\n data: this.rowNode.data,\n node: this.rowNode,\n colDef: colDef,\n column: this.column,\n rowIndex: this.rowNode.rowIndex,\n api: this.beans.gridOptionsService.api,\n columnApi: this.beans.gridOptionsService.columnApi,\n context: this.beans.gridOptionsService.context\n };\n this.beans.stylingService.processClassRules(colDef.cellClassRules, cellClassParams, className => this.cellComp.addOrRemoveCssClass(className, true), className => this.cellComp.addOrRemoveCssClass(className, false));\n }\n applyUserStyles() {\n const colDef = this.column.getColDef();\n if (!colDef.cellStyle) {\n return;\n }\n let styles;\n if (typeof colDef.cellStyle === 'function') {\n const cellStyleParams = {\n column: this.column,\n value: this.cellCtrl.getValue(),\n colDef: colDef,\n data: this.rowNode.data,\n node: this.rowNode,\n rowIndex: this.rowNode.rowIndex,\n api: this.beans.gridOptionsService.api,\n columnApi: this.beans.gridOptionsService.columnApi,\n context: this.beans.gridOptionsService.context,\n };\n const cellStyleFunc = colDef.cellStyle;\n styles = cellStyleFunc(cellStyleParams);\n }\n else {\n styles = colDef.cellStyle;\n }\n if (styles) {\n this.cellComp.setUserStyles(styles);\n }\n }\n applyClassesFromColDef() {\n const colDef = this.column.getColDef();\n const cellClassParams = {\n value: this.cellCtrl.getValue(),\n data: this.rowNode.data,\n node: this.rowNode,\n column: this.column,\n colDef: colDef,\n rowIndex: this.rowNode.rowIndex,\n api: this.beans.gridOptionsService.api,\n columnApi: this.beans.gridOptionsService.columnApi,\n context: this.beans.gridOptionsService.context\n };\n if (this.staticClasses.length) {\n this.staticClasses.forEach(className => this.cellComp.addOrRemoveCssClass(className, false));\n }\n this.staticClasses = this.beans.stylingService.getStaticCellClasses(colDef, cellClassParams);\n if (this.staticClasses.length) {\n this.staticClasses.forEach(className => this.cellComp.addOrRemoveCssClass(className, true));\n }\n }\n // overriding to make public, as we don't dispose this bean via context\n destroy() {\n super.destroy();\n }\n}\n","import { BeanStub } from \"../context/beanStub.mjs\";\nimport { CustomTooltipFeature } from \"./customTooltipFeature.mjs\";\nexport class TooltipFeature extends BeanStub {\n constructor(ctrl, beans) {\n super();\n this.ctrl = ctrl;\n this.beans = beans;\n }\n setComp(eGui) {\n this.eGui = eGui;\n this.setupTooltip();\n }\n setBrowserTooltip(tooltip) {\n const name = 'title';\n if (tooltip != null && tooltip != '') {\n this.eGui.setAttribute(name, tooltip);\n }\n else {\n this.eGui.removeAttribute(name);\n }\n }\n setupTooltip() {\n this.browserTooltips = this.beans.gridOptionsService.is('enableBrowserTooltips');\n this.updateTooltipText();\n if (this.browserTooltips) {\n this.setBrowserTooltip(this.tooltip);\n }\n else {\n this.createTooltipFeatureIfNeeded();\n }\n }\n updateTooltipText() {\n this.tooltip = this.ctrl.getTooltipValue();\n }\n createTooltipFeatureIfNeeded() {\n var _a, _b, _c, _d;\n if (this.genericTooltipFeature != null) {\n return;\n }\n const parent = {\n getTooltipParams: () => this.getTooltipParams(),\n getGui: () => this.ctrl.getGui()\n };\n this.genericTooltipFeature = this.createManagedBean(new CustomTooltipFeature(parent, (_b = (_a = this.ctrl).getTooltipShowDelayOverride) === null || _b === void 0 ? void 0 : _b.call(_a), (_d = (_c = this.ctrl).getTooltipHideDelayOverride) === null || _d === void 0 ? void 0 : _d.call(_c)), this.beans.context);\n }\n refreshToolTip() {\n this.updateTooltipText();\n if (this.browserTooltips) {\n this.setBrowserTooltip(this.tooltip);\n }\n }\n getTooltipParams() {\n const ctrl = this.ctrl;\n const column = ctrl.getColumn ? ctrl.getColumn() : undefined;\n const colDef = ctrl.getColDef ? ctrl.getColDef() : undefined;\n const rowNode = ctrl.getRowNode ? ctrl.getRowNode() : undefined;\n return {\n location: ctrl.getLocation(),\n colDef: colDef,\n column: column,\n rowIndex: ctrl.getRowIndex ? ctrl.getRowIndex() : undefined,\n node: rowNode,\n data: rowNode ? rowNode.data : undefined,\n value: this.getTooltipText(),\n valueFormatted: ctrl.getValueFormatted ? ctrl.getValueFormatted() : undefined,\n hideTooltipCallback: () => this.genericTooltipFeature.hideTooltip(true)\n };\n }\n getTooltipText() {\n return this.tooltip;\n }\n // overriding to make public, as we don't dispose this bean via context\n destroy() {\n super.destroy();\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, Optional, PostConstruct } from \"../context/context.mjs\";\n/** Using the IoC has a slight performance consideration, which is no problem most of the\n * time, unless we are trashing objects - which is the case when scrolling and rowComp\n * and cellComp. So for performance reasons, RowComp and CellComp do not get autowired\n * with the IoC. Instead they get passed this object which is all the beans the RowComp\n * and CellComp need. Not autowiring all the cells gives performance improvement. */\nlet Beans = class Beans {\n postConstruct() {\n this.doingMasterDetail = this.gridOptionsService.is('masterDetail');\n if (this.gridOptionsService.isRowModelType('clientSide')) {\n this.clientSideRowModel = this.rowModel;\n }\n if (this.gridOptionsService.isRowModelType('serverSide')) {\n this.serverSideRowModel = this.rowModel;\n }\n }\n};\n__decorate([\n Autowired('resizeObserverService')\n], Beans.prototype, \"resizeObserverService\", void 0);\n__decorate([\n Autowired('paginationProxy')\n], Beans.prototype, \"paginationProxy\", void 0);\n__decorate([\n Autowired('context')\n], Beans.prototype, \"context\", void 0);\n__decorate([\n Autowired('columnApi')\n], Beans.prototype, \"columnApi\", void 0);\n__decorate([\n Autowired('gridApi')\n], Beans.prototype, \"gridApi\", void 0);\n__decorate([\n Autowired('gridOptionsService')\n], Beans.prototype, \"gridOptionsService\", void 0);\n__decorate([\n Autowired('expressionService')\n], Beans.prototype, \"expressionService\", void 0);\n__decorate([\n Autowired('environment')\n], Beans.prototype, \"environment\", void 0);\n__decorate([\n Autowired('rowRenderer')\n], Beans.prototype, \"rowRenderer\", void 0);\n__decorate([\n Autowired('templateService')\n], Beans.prototype, \"templateService\", void 0);\n__decorate([\n Autowired('valueService')\n], Beans.prototype, \"valueService\", void 0);\n__decorate([\n Autowired('eventService')\n], Beans.prototype, \"eventService\", void 0);\n__decorate([\n Autowired('columnModel')\n], Beans.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('headerNavigationService')\n], Beans.prototype, \"headerNavigationService\", void 0);\n__decorate([\n Autowired('navigationService')\n], Beans.prototype, \"navigationService\", void 0);\n__decorate([\n Autowired('columnAnimationService')\n], Beans.prototype, \"columnAnimationService\", void 0);\n__decorate([\n Optional('rangeService')\n], Beans.prototype, \"rangeService\", void 0);\n__decorate([\n Autowired('focusService')\n], Beans.prototype, \"focusService\", void 0);\n__decorate([\n Optional('contextMenuFactory')\n], Beans.prototype, \"contextMenuFactory\", void 0);\n__decorate([\n Autowired('popupService')\n], Beans.prototype, \"popupService\", void 0);\n__decorate([\n Autowired('valueFormatterService')\n], Beans.prototype, \"valueFormatterService\", void 0);\n__decorate([\n Autowired('stylingService')\n], Beans.prototype, \"stylingService\", void 0);\n__decorate([\n Autowired('columnHoverService')\n], Beans.prototype, \"columnHoverService\", void 0);\n__decorate([\n Autowired('userComponentFactory')\n], Beans.prototype, \"userComponentFactory\", void 0);\n__decorate([\n Autowired('userComponentRegistry')\n], Beans.prototype, \"userComponentRegistry\", void 0);\n__decorate([\n Autowired('animationFrameService')\n], Beans.prototype, \"animationFrameService\", void 0);\n__decorate([\n Autowired('dragService')\n], Beans.prototype, \"dragService\", void 0);\n__decorate([\n Autowired('dragAndDropService')\n], Beans.prototype, \"dragAndDropService\", void 0);\n__decorate([\n Autowired('sortController')\n], Beans.prototype, \"sortController\", void 0);\n__decorate([\n Autowired('filterManager')\n], Beans.prototype, \"filterManager\", void 0);\n__decorate([\n Autowired('rowContainerHeightService')\n], Beans.prototype, \"rowContainerHeightService\", void 0);\n__decorate([\n Autowired('frameworkOverrides')\n], Beans.prototype, \"frameworkOverrides\", void 0);\n__decorate([\n Autowired('cellPositionUtils')\n], Beans.prototype, \"cellPositionUtils\", void 0);\n__decorate([\n Autowired('rowPositionUtils')\n], Beans.prototype, \"rowPositionUtils\", void 0);\n__decorate([\n Autowired('selectionService')\n], Beans.prototype, \"selectionService\", void 0);\n__decorate([\n Optional('selectionHandleFactory')\n], Beans.prototype, \"selectionHandleFactory\", void 0);\n__decorate([\n Autowired('rowCssClassCalculator')\n], Beans.prototype, \"rowCssClassCalculator\", void 0);\n__decorate([\n Autowired('rowModel')\n], Beans.prototype, \"rowModel\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], Beans.prototype, \"ctrlsService\", void 0);\n__decorate([\n Autowired('ctrlsFactory')\n], Beans.prototype, \"ctrlsFactory\", void 0);\n__decorate([\n Autowired('agStackComponentsRegistry')\n], Beans.prototype, \"agStackComponentsRegistry\", void 0);\n__decorate([\n Autowired('valueCache')\n], Beans.prototype, \"valueCache\", void 0);\n__decorate([\n Autowired('rowNodeEventThrottle')\n], Beans.prototype, \"rowNodeEventThrottle\", void 0);\n__decorate([\n Autowired('localeService')\n], Beans.prototype, \"localeService\", void 0);\n__decorate([\n Autowired('valueParserService')\n], Beans.prototype, \"valueParserService\", void 0);\n__decorate([\n PostConstruct\n], Beans.prototype, \"postConstruct\", null);\nBeans = __decorate([\n Bean('beans')\n], Beans);\nexport { Beans };\n","import { Events } from \"../../events.mjs\";\nimport { isBrowserSafari, isIOSUserAgent } from \"../../utils/browser.mjs\";\nimport { isElementChildOfClass, isFocusableFormField } from \"../../utils/dom.mjs\";\nimport { isEventSupported, isStopPropagationForAgGrid } from \"../../utils/event.mjs\";\nimport { Beans } from \"../beans.mjs\";\nexport class CellMouseListenerFeature extends Beans {\n constructor(ctrl, beans, column) {\n super();\n this.cellCtrl = ctrl;\n this.beans = beans;\n this.column = column;\n }\n onMouseEvent(eventName, mouseEvent) {\n if (isStopPropagationForAgGrid(mouseEvent)) {\n return;\n }\n switch (eventName) {\n case 'click':\n this.onCellClicked(mouseEvent);\n break;\n case 'mousedown':\n case 'touchstart':\n this.onMouseDown(mouseEvent);\n break;\n case 'dblclick':\n this.onCellDoubleClicked(mouseEvent);\n break;\n case 'mouseout':\n this.onMouseOut(mouseEvent);\n break;\n case 'mouseover':\n this.onMouseOver(mouseEvent);\n break;\n }\n }\n onCellClicked(mouseEvent) {\n // iPad doesn't have double click - so we need to mimic it to enable editing for iPad.\n if (this.isDoubleClickOnIPad()) {\n this.onCellDoubleClicked(mouseEvent);\n mouseEvent.preventDefault(); // if we don't do this, then iPad zooms in\n return;\n }\n const { eventService, rangeService, gridOptionsService } = this.beans;\n const isMultiKey = mouseEvent.ctrlKey || mouseEvent.metaKey;\n if (rangeService && isMultiKey) {\n // the mousedown event has created the range already, so we only intersect if there is more than one\n // range on this cell\n if (rangeService.getCellRangeCount(this.cellCtrl.getCellPosition()) > 1) {\n rangeService.intersectLastRange(true);\n }\n }\n const cellClickedEvent = this.cellCtrl.createEvent(mouseEvent, Events.EVENT_CELL_CLICKED);\n eventService.dispatchEvent(cellClickedEvent);\n const colDef = this.column.getColDef();\n if (colDef.onCellClicked) {\n // to make callback async, do in a timeout\n window.setTimeout(() => colDef.onCellClicked(cellClickedEvent), 0);\n }\n const editOnSingleClick = (gridOptionsService.is('singleClickEdit') || colDef.singleClickEdit)\n && !gridOptionsService.is('suppressClickEdit');\n // edit on single click, but not if extending a range\n if (editOnSingleClick && !(mouseEvent.shiftKey && (rangeService === null || rangeService === void 0 ? void 0 : rangeService.getCellRanges().length) != 0)) {\n this.cellCtrl.startRowOrCellEdit();\n }\n }\n // returns true if on iPad and this is second 'click' event in 200ms\n isDoubleClickOnIPad() {\n if (!isIOSUserAgent() || isEventSupported('dblclick')) {\n return false;\n }\n const nowMillis = new Date().getTime();\n const res = nowMillis - this.lastIPadMouseClickEvent < 200;\n this.lastIPadMouseClickEvent = nowMillis;\n return res;\n }\n onCellDoubleClicked(mouseEvent) {\n const colDef = this.column.getColDef();\n // always dispatch event to eventService\n const cellDoubleClickedEvent = this.cellCtrl.createEvent(mouseEvent, Events.EVENT_CELL_DOUBLE_CLICKED);\n this.beans.eventService.dispatchEvent(cellDoubleClickedEvent);\n // check if colDef also wants to handle event\n if (typeof colDef.onCellDoubleClicked === 'function') {\n // to make the callback async, do in a timeout\n window.setTimeout(() => colDef.onCellDoubleClicked(cellDoubleClickedEvent), 0);\n }\n const editOnDoubleClick = !this.beans.gridOptionsService.is('singleClickEdit')\n && !this.beans.gridOptionsService.is('suppressClickEdit');\n if (editOnDoubleClick) {\n this.cellCtrl.startRowOrCellEdit(null, mouseEvent);\n }\n }\n onMouseDown(mouseEvent) {\n const { ctrlKey, metaKey, shiftKey } = mouseEvent;\n const target = mouseEvent.target;\n const { cellCtrl, beans } = this;\n const { eventService, rangeService, focusService } = beans;\n // do not change the range for right-clicks inside an existing range\n if (this.isRightClickInExistingRange(mouseEvent)) {\n return;\n }\n const ranges = rangeService && rangeService.getCellRanges().length != 0;\n if (!shiftKey || !ranges) {\n // We only need to pass true to focusCell when the browser is Safari and we are trying\n // to focus the cell itself. This should never be true if the mousedown was triggered\n // due to a click on a cell editor for example.\n const forceBrowserFocus = (isBrowserSafari()) && !cellCtrl.isEditing() && !isFocusableFormField(target);\n cellCtrl.focusCell(forceBrowserFocus);\n }\n // if shift clicking, and a range exists, we keep the focus on the cell that started the\n // range as the user then changes the range selection.\n if (shiftKey && ranges && !focusService.isCellFocused(cellCtrl.getCellPosition())) {\n // this stops the cell from getting focused\n mouseEvent.preventDefault();\n const focusedCellPosition = focusService.getFocusedCell();\n if (focusedCellPosition) {\n const { column, rowIndex, rowPinned } = focusedCellPosition;\n const focusedRowCtrl = beans.rowRenderer.getRowByPosition({ rowIndex, rowPinned });\n const focusedCellCtrl = focusedRowCtrl === null || focusedRowCtrl === void 0 ? void 0 : focusedRowCtrl.getCellCtrl(column);\n // if the focused cell is editing, need to stop editing first\n if (focusedCellCtrl === null || focusedCellCtrl === void 0 ? void 0 : focusedCellCtrl.isEditing()) {\n focusedCellCtrl.stopEditing();\n }\n // focus could have been lost, so restore it to the starting cell in the range if needed\n focusService.setFocusedCell({\n column,\n rowIndex,\n rowPinned,\n forceBrowserFocus: true,\n preventScrollOnBrowserFocus: true,\n });\n }\n }\n // if we are clicking on a checkbox, we need to make sure the cell wrapping that checkbox\n // is focused but we don't want to change the range selection, so return here.\n if (this.containsWidget(target)) {\n return;\n }\n if (rangeService) {\n const thisCell = this.cellCtrl.getCellPosition();\n if (shiftKey) {\n rangeService.extendLatestRangeToCell(thisCell);\n }\n else {\n const isMultiKey = ctrlKey || metaKey;\n rangeService.setRangeToCell(thisCell, isMultiKey);\n }\n }\n eventService.dispatchEvent(this.cellCtrl.createEvent(mouseEvent, Events.EVENT_CELL_MOUSE_DOWN));\n }\n isRightClickInExistingRange(mouseEvent) {\n const { rangeService } = this.beans;\n if (rangeService) {\n const cellInRange = rangeService.isCellInAnyRange(this.cellCtrl.getCellPosition());\n const isRightClick = mouseEvent.button === 2 || (mouseEvent.ctrlKey && this.beans.gridOptionsService.is('allowContextMenuWithControlKey'));\n if (cellInRange && isRightClick) {\n return true;\n }\n }\n return false;\n }\n containsWidget(target) {\n return isElementChildOfClass(target, 'ag-selection-checkbox', 3);\n }\n onMouseOut(mouseEvent) {\n if (this.mouseStayingInsideCell(mouseEvent)) {\n return;\n }\n const cellMouseOutEvent = this.cellCtrl.createEvent(mouseEvent, Events.EVENT_CELL_MOUSE_OUT);\n this.beans.eventService.dispatchEvent(cellMouseOutEvent);\n this.beans.columnHoverService.clearMouseOver();\n }\n onMouseOver(mouseEvent) {\n if (this.mouseStayingInsideCell(mouseEvent)) {\n return;\n }\n const cellMouseOverEvent = this.cellCtrl.createEvent(mouseEvent, Events.EVENT_CELL_MOUSE_OVER);\n this.beans.eventService.dispatchEvent(cellMouseOverEvent);\n this.beans.columnHoverService.setMouseOver([this.column]);\n }\n mouseStayingInsideCell(e) {\n if (!e.target || !e.relatedTarget) {\n return false;\n }\n const eGui = this.cellCtrl.getGui();\n const cellContainsTarget = eGui.contains(e.target);\n const cellContainsRelatedTarget = eGui.contains(e.relatedTarget);\n return cellContainsTarget && cellContainsRelatedTarget;\n }\n destroy() {\n }\n}\n","import { BeanStub } from \"../../context/beanStub.mjs\";\nimport { KeyCode } from \"../../constants/keyCode.mjs\";\nimport { isDeleteKey } from \"../../utils/keyboard.mjs\";\nimport { Events } from \"../../eventKeys.mjs\";\nexport class CellKeyboardListenerFeature extends BeanStub {\n constructor(ctrl, beans, column, rowNode, rowCtrl) {\n super();\n this.cellCtrl = ctrl;\n this.beans = beans;\n this.rowNode = rowNode;\n this.rowCtrl = rowCtrl;\n }\n setComp(eGui) {\n this.eGui = eGui;\n }\n onKeyDown(event) {\n const key = event.key;\n switch (key) {\n case KeyCode.ENTER:\n this.onEnterKeyDown(event);\n break;\n case KeyCode.F2:\n this.onF2KeyDown(event);\n break;\n case KeyCode.ESCAPE:\n this.onEscapeKeyDown(event);\n break;\n case KeyCode.TAB:\n this.onTabKeyDown(event);\n break;\n case KeyCode.BACKSPACE:\n case KeyCode.DELETE:\n this.onBackspaceOrDeleteKeyDown(key, event);\n break;\n case KeyCode.DOWN:\n case KeyCode.UP:\n case KeyCode.RIGHT:\n case KeyCode.LEFT:\n this.onNavigationKeyDown(event, key);\n break;\n }\n }\n onNavigationKeyDown(event, key) {\n if (this.cellCtrl.isEditing()) {\n return;\n }\n if (event.shiftKey && this.cellCtrl.isRangeSelectionEnabled()) {\n this.onShiftRangeSelect(event);\n }\n else {\n this.beans.navigationService.navigateToNextCell(event, key, this.cellCtrl.getCellPosition(), true);\n }\n // if we don't prevent default, the grid will scroll with the navigation keys\n event.preventDefault();\n }\n onShiftRangeSelect(event) {\n if (!this.beans.rangeService) {\n return;\n }\n const endCell = this.beans.rangeService.extendLatestRangeInDirection(event);\n if (endCell) {\n this.beans.navigationService.ensureCellVisible(endCell);\n }\n }\n onTabKeyDown(event) {\n this.beans.navigationService.onTabKeyDown(this.cellCtrl, event);\n }\n onBackspaceOrDeleteKeyDown(key, event) {\n const { cellCtrl, beans, rowNode } = this;\n const { gridOptionsService, rangeService, eventService } = beans;\n if (cellCtrl.isEditing()) {\n return;\n }\n eventService.dispatchEvent({ type: Events.EVENT_KEY_SHORTCUT_CHANGED_CELL_START });\n if (isDeleteKey(key, gridOptionsService.is('enableCellEditingOnBackspace'))) {\n if (rangeService && gridOptionsService.is('enableRangeSelection')) {\n rangeService.clearCellRangeCellValues({ dispatchWrapperEvents: true, wrapperEventSource: 'deleteKey' });\n }\n else if (cellCtrl.isCellEditable()) {\n rowNode.setDataValue(cellCtrl.getColumn(), null, 'cellClear');\n }\n }\n else {\n cellCtrl.startRowOrCellEdit(key, event);\n }\n eventService.dispatchEvent({ type: Events.EVENT_KEY_SHORTCUT_CHANGED_CELL_END });\n }\n onEnterKeyDown(e) {\n if (this.cellCtrl.isEditing() || this.rowCtrl.isEditing()) {\n this.cellCtrl.stopEditingAndFocus(false, e.shiftKey);\n }\n else {\n if (this.beans.gridOptionsService.is('enterNavigatesVertically')) {\n const key = e.shiftKey ? KeyCode.UP : KeyCode.DOWN;\n this.beans.navigationService.navigateToNextCell(null, key, this.cellCtrl.getCellPosition(), false);\n }\n else {\n this.cellCtrl.startRowOrCellEdit(KeyCode.ENTER, e);\n if (this.cellCtrl.isEditing()) {\n // if we started editing, then we need to prevent default, otherwise the Enter action can get\n // applied to the cell editor. this happened, for example, with largeTextCellEditor where not\n // preventing default results in a 'new line' character getting inserted in the text area\n // when the editing was started\n e.preventDefault();\n }\n }\n }\n }\n onF2KeyDown(event) {\n if (!this.cellCtrl.isEditing()) {\n this.cellCtrl.startRowOrCellEdit(KeyCode.F2, event);\n }\n }\n onEscapeKeyDown(event) {\n if (this.cellCtrl.isEditing()) {\n this.cellCtrl.stopRowOrCellEdit(true);\n this.cellCtrl.focusCell(true);\n }\n }\n processCharacter(event) {\n // check this, in case focus is on a (for example) a text field inside the cell,\n // in which cse we should not be listening for these key pressed\n const eventTarget = event.target;\n const eventOnChildComponent = eventTarget !== this.eGui;\n if (eventOnChildComponent || this.cellCtrl.isEditing()) {\n return;\n }\n const key = event.key;\n if (key === ' ') {\n this.onSpaceKeyDown(event);\n }\n else {\n this.cellCtrl.startRowOrCellEdit(key, event);\n // if we don't prevent default, then the event also gets applied to the text field\n // (at least when doing the default editor), but we need to allow the editor to decide\n // what it wants to do. we only do this IF editing was started - otherwise it messes\n // up when the use is not doing editing, but using rendering with text fields in cellRenderer\n // (as it would block the the user from typing into text fields).\n event.preventDefault();\n }\n }\n onSpaceKeyDown(event) {\n const { gridOptionsService } = this.beans;\n if (!this.cellCtrl.isEditing() && gridOptionsService.isRowSelection()) {\n const currentSelection = this.rowNode.isSelected();\n const newSelection = !currentSelection;\n if (newSelection || !gridOptionsService.is('suppressRowDeselection')) {\n const groupSelectsFiltered = this.beans.gridOptionsService.is('groupSelectsFiltered');\n const updatedCount = this.rowNode.setSelectedParams({\n newValue: newSelection,\n rangeSelect: event.shiftKey,\n groupSelectsFiltered: groupSelectsFiltered,\n event,\n source: 'spaceKey',\n });\n if (currentSelection === undefined && updatedCount === 0) {\n this.rowNode.setSelectedParams({\n newValue: false,\n rangeSelect: event.shiftKey,\n groupSelectsFiltered: groupSelectsFiltered,\n event,\n source: 'spaceKey',\n });\n }\n }\n }\n // prevent default as space key, by default, moves browser scroll down\n event.preventDefault();\n }\n destroy() {\n super.destroy();\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from \"../widgets/component.mjs\";\nimport { PostConstruct } from \"../context/context.mjs\";\nimport { createIconNoSpan } from \"../utils/icon.mjs\";\nexport class DndSourceComp extends Component {\n constructor(rowNode, column, eCell) {\n super(/* html */ `
`);\n this.rowNode = rowNode;\n this.column = column;\n this.eCell = eCell;\n }\n postConstruct() {\n const eGui = this.getGui();\n eGui.appendChild(createIconNoSpan('rowDrag', this.gridOptionsService, null));\n // we need to stop the event propagation here to avoid starting a range selection while dragging\n this.addGuiEventListener('mousedown', (e) => {\n e.stopPropagation();\n });\n this.addDragSource();\n this.checkVisibility();\n }\n addDragSource() {\n this.addGuiEventListener('dragstart', this.onDragStart.bind(this));\n }\n onDragStart(dragEvent) {\n const providedOnRowDrag = this.column.getColDef().dndSourceOnRowDrag;\n dragEvent.dataTransfer.setDragImage(this.eCell, 0, 0);\n // default behaviour is to convert data to json and set into drag component\n const defaultOnRowDrag = () => {\n try {\n const jsonData = JSON.stringify(this.rowNode.data);\n dragEvent.dataTransfer.setData('application/json', jsonData);\n dragEvent.dataTransfer.setData('text/plain', jsonData);\n }\n catch (e) {\n // if we cannot convert the data to json, then we do not set the type\n }\n };\n if (providedOnRowDrag) {\n const params = {\n rowNode: this.rowNode, dragEvent: dragEvent,\n api: this.gridOptionsService.api,\n columnApi: this.gridOptionsService.columnApi,\n context: this.gridOptionsService.context\n };\n providedOnRowDrag(params);\n }\n else {\n defaultOnRowDrag();\n }\n }\n checkVisibility() {\n const visible = this.column.isDndSource(this.rowNode);\n this.setDisplayed(visible);\n }\n}\n__decorate([\n PostConstruct\n], DndSourceComp.prototype, \"postConstruct\", null);\n","import { Events } from \"../../events.mjs\";\nimport { CellRangeFeature } from \"./cellRangeFeature.mjs\";\nimport { exists, makeNull } from \"../../utils/generic.mjs\";\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nimport { CellPositionFeature } from \"./cellPositionFeature.mjs\";\nimport { escapeString } from \"../../utils/string.mjs\";\nimport { CellCustomStyleFeature } from \"./cellCustomStyleFeature.mjs\";\nimport { TooltipFeature } from \"../../widgets/tooltipFeature.mjs\";\nimport { CellMouseListenerFeature } from \"./cellMouseListenerFeature.mjs\";\nimport { CellKeyboardListenerFeature } from \"./cellKeyboardListenerFeature.mjs\";\nimport { KeyCode } from \"../../constants/keyCode.mjs\";\nimport { CheckboxSelectionComponent } from \"../checkboxSelectionComponent.mjs\";\nimport { DndSourceComp } from \"../dndSourceComp.mjs\";\nimport { doOnce } from \"../../utils/function.mjs\";\nimport { RowDragComp } from \"../row/rowDragComp.mjs\";\nimport { getValueUsingField } from \"../../utils/object.mjs\";\nimport { getElementSize } from \"../../utils/dom.mjs\";\nimport { setAriaColIndex } from \"../../utils/aria.mjs\";\nconst CSS_CELL = 'ag-cell';\nconst CSS_AUTO_HEIGHT = 'ag-cell-auto-height';\nconst CSS_NORMAL_HEIGHT = 'ag-cell-normal-height';\nconst CSS_CELL_FOCUS = 'ag-cell-focus';\nconst CSS_CELL_FIRST_RIGHT_PINNED = 'ag-cell-first-right-pinned';\nconst CSS_CELL_LAST_LEFT_PINNED = 'ag-cell-last-left-pinned';\nconst CSS_CELL_NOT_INLINE_EDITING = 'ag-cell-not-inline-editing';\nconst CSS_COLUMN_HOVER = 'ag-column-hover';\nconst CSS_CELL_WRAP_TEXT = 'ag-cell-wrap-text';\nlet instanceIdSequence = 0;\nexport class CellCtrl extends BeanStub {\n constructor(column, rowNode, beans, rowCtrl) {\n super();\n this.cellRangeFeature = null;\n this.cellPositionFeature = null;\n this.cellCustomStyleFeature = null;\n this.tooltipFeature = null;\n this.cellMouseListenerFeature = null;\n this.cellKeyboardListenerFeature = null;\n this.suppressRefreshCell = false;\n this.onCellCompAttachedFuncs = [];\n this.column = column;\n this.rowNode = rowNode;\n this.beans = beans;\n this.rowCtrl = rowCtrl;\n // unique id to this instance, including the column ID to help with debugging in React as it's used in 'key'\n this.instanceId = column.getId() + '-' + instanceIdSequence++;\n const colDef = this.column.getColDef();\n this.colIdSanitised = escapeString(this.column.getId());\n if (!this.beans.gridOptionsService.is('suppressCellFocus')) {\n this.tabIndex = -1;\n }\n this.isCellRenderer = colDef.cellRenderer != null || colDef.cellRendererSelector != null;\n this.createCellPosition();\n this.addFeatures();\n this.updateAndFormatValue(true);\n }\n shouldRestoreFocus() {\n return this.beans.focusService.shouldRestoreFocus(this.cellPosition);\n }\n addFeatures() {\n this.cellPositionFeature = new CellPositionFeature(this, this.beans);\n this.addDestroyFunc(() => { var _a; (_a = this.cellPositionFeature) === null || _a === void 0 ? void 0 : _a.destroy(); this.cellPositionFeature = null; });\n this.cellCustomStyleFeature = new CellCustomStyleFeature(this, this.beans);\n this.addDestroyFunc(() => { var _a; (_a = this.cellCustomStyleFeature) === null || _a === void 0 ? void 0 : _a.destroy(); this.cellCustomStyleFeature = null; });\n this.cellMouseListenerFeature = new CellMouseListenerFeature(this, this.beans, this.column);\n this.addDestroyFunc(() => { var _a; (_a = this.cellMouseListenerFeature) === null || _a === void 0 ? void 0 : _a.destroy(); this.cellMouseListenerFeature = null; });\n this.cellKeyboardListenerFeature = new CellKeyboardListenerFeature(this, this.beans, this.column, this.rowNode, this.rowCtrl);\n this.addDestroyFunc(() => { var _a; (_a = this.cellKeyboardListenerFeature) === null || _a === void 0 ? void 0 : _a.destroy(); this.cellKeyboardListenerFeature = null; });\n const rangeSelectionEnabled = this.beans.rangeService && this.beans.gridOptionsService.is('enableRangeSelection');\n if (rangeSelectionEnabled) {\n this.cellRangeFeature = new CellRangeFeature(this.beans, this);\n this.addDestroyFunc(() => { var _a; (_a = this.cellRangeFeature) === null || _a === void 0 ? void 0 : _a.destroy(); this.cellRangeFeature = null; });\n }\n if (this.column.isTooltipEnabled()) {\n this.addTooltipFeature();\n }\n }\n addTooltipFeature() {\n const getTooltipValue = () => {\n const colDef = this.column.getColDef();\n const data = this.rowNode.data;\n if (colDef.tooltipField && exists(data)) {\n return getValueUsingField(data, colDef.tooltipField, this.column.isTooltipFieldContainsDots());\n }\n const valueGetter = colDef.tooltipValueGetter;\n if (valueGetter) {\n return valueGetter({\n location: 'cell',\n api: this.beans.gridOptionsService.api,\n columnApi: this.beans.gridOptionsService.columnApi,\n context: this.beans.gridOptionsService.context,\n colDef: this.column.getColDef(),\n column: this.column,\n rowIndex: this.cellPosition.rowIndex,\n node: this.rowNode,\n data: this.rowNode.data,\n value: this.value,\n valueFormatted: this.valueFormatted,\n });\n }\n return null;\n };\n const tooltipCtrl = {\n getColumn: () => this.column,\n getColDef: () => this.column.getColDef(),\n getRowIndex: () => this.cellPosition.rowIndex,\n getRowNode: () => this.rowNode,\n getGui: () => this.getGui(),\n getLocation: () => 'cell',\n getTooltipValue: getTooltipValue,\n // this makes no sense, why is the cell formatted value passed to the tooltip???\n getValueFormatted: () => this.valueFormatted\n };\n this.tooltipFeature = new TooltipFeature(tooltipCtrl, this.beans);\n this.addDestroyFunc(() => { var _a; (_a = this.tooltipFeature) === null || _a === void 0 ? void 0 : _a.destroy(); this.tooltipFeature = null; });\n }\n setComp(comp, eGui, eCellWrapper, printLayout, startEditing) {\n var _a, _b, _c, _d;\n this.cellComp = comp;\n this.eGui = eGui;\n this.printLayout = printLayout;\n this.addDomData();\n this.onCellFocused(this.focusEventToRestore);\n this.applyStaticCssClasses();\n this.setWrapText();\n this.onFirstRightPinnedChanged();\n this.onLastLeftPinnedChanged();\n this.onColumnHover();\n this.setupControlComps();\n if (eCellWrapper) {\n this.setupAutoHeight(eCellWrapper);\n }\n this.setAriaColIndex();\n (_a = this.cellPositionFeature) === null || _a === void 0 ? void 0 : _a.setComp(eGui);\n (_b = this.cellCustomStyleFeature) === null || _b === void 0 ? void 0 : _b.setComp(comp);\n (_c = this.tooltipFeature) === null || _c === void 0 ? void 0 : _c.setComp(eGui);\n (_d = this.cellKeyboardListenerFeature) === null || _d === void 0 ? void 0 : _d.setComp(this.eGui);\n if (this.cellRangeFeature) {\n this.cellRangeFeature.setComp(comp, eGui);\n }\n if (startEditing && this.isCellEditable()) {\n this.startEditing();\n }\n else {\n this.showValue();\n }\n if (this.onCellCompAttachedFuncs.length) {\n this.onCellCompAttachedFuncs.forEach(func => func());\n this.onCellCompAttachedFuncs = [];\n }\n }\n setupAutoHeight(eCellWrapper) {\n if (!this.column.isAutoHeight()) {\n return;\n }\n const eParentCell = eCellWrapper.parentElement;\n // taking minRowHeight from getRowHeightForNode means the getRowHeight() callback is used,\n // thus allowing different min heights for different rows.\n const minRowHeight = this.beans.gridOptionsService.getRowHeightForNode(this.rowNode).height;\n const measureHeight = (timesCalled) => {\n if (this.editing) {\n return;\n }\n // because of the retry's below, it's possible the retry's go beyond\n // the rows life.\n if (!this.isAlive()) {\n return;\n }\n const { paddingTop, paddingBottom, borderBottomWidth, borderTopWidth } = getElementSize(eParentCell);\n const extraHeight = paddingTop + paddingBottom + borderBottomWidth + borderTopWidth;\n const wrapperHeight = eCellWrapper.offsetHeight;\n const autoHeight = wrapperHeight + extraHeight;\n if (timesCalled < 5) {\n // if not in doc yet, means framework not yet inserted, so wait for next VM turn,\n // maybe it will be ready next VM turn\n const doc = this.beans.gridOptionsService.getDocument();\n const notYetInDom = !doc || !doc.contains(eCellWrapper);\n // this happens in React, where React hasn't put any content in. we say 'possibly'\n // as a) may not be React and b) the cell could be empty anyway\n const possiblyNoContentYet = autoHeight == 0;\n if (notYetInDom || possiblyNoContentYet) {\n this.beans.frameworkOverrides.setTimeout(() => measureHeight(timesCalled + 1), 0);\n return;\n }\n }\n const newHeight = Math.max(autoHeight, minRowHeight);\n this.rowNode.setRowAutoHeight(newHeight, this.column);\n };\n const listener = () => measureHeight(0);\n // do once to set size in case size doesn't change, common when cell is blank\n listener();\n const destroyResizeObserver = this.beans.resizeObserverService.observeResize(eCellWrapper, listener);\n this.addDestroyFunc(() => {\n destroyResizeObserver();\n this.rowNode.setRowAutoHeight(undefined, this.column);\n });\n }\n getInstanceId() {\n return this.instanceId;\n }\n getIncludeSelection() {\n return this.includeSelection;\n }\n getIncludeRowDrag() {\n return this.includeRowDrag;\n }\n getIncludeDndSource() {\n return this.includeDndSource;\n }\n getColumnIdSanitised() {\n return this.colIdSanitised;\n }\n getTabIndex() {\n return this.tabIndex;\n }\n getIsCellRenderer() {\n return this.isCellRenderer;\n }\n getValueToDisplay() {\n return this.valueFormatted != null ? this.valueFormatted : this.value;\n }\n showValue(forceNewCellRendererInstance = false) {\n const valueToDisplay = this.getValueToDisplay();\n let compDetails;\n if (this.isCellRenderer) {\n const params = this.createCellRendererParams();\n compDetails = this.beans.userComponentFactory.getCellRendererDetails(this.column.getColDef(), params);\n }\n this.cellComp.setRenderDetails(compDetails, valueToDisplay, forceNewCellRendererInstance);\n this.refreshHandle();\n }\n setupControlComps() {\n const colDef = this.column.getColDef();\n this.includeSelection = this.isIncludeControl(colDef.checkboxSelection);\n this.includeRowDrag = this.isIncludeControl(colDef.rowDrag);\n this.includeDndSource = this.isIncludeControl(colDef.dndSource);\n this.cellComp.setIncludeSelection(this.includeSelection);\n this.cellComp.setIncludeDndSource(this.includeDndSource);\n this.cellComp.setIncludeRowDrag(this.includeRowDrag);\n }\n isForceWrapper() {\n // text selection requires the value to be wrapped in another element\n const forceWrapper = this.beans.gridOptionsService.is('enableCellTextSelection') || this.column.isAutoHeight();\n return forceWrapper;\n }\n isIncludeControl(value) {\n const rowNodePinned = this.rowNode.rowPinned != null;\n const isFunc = typeof value === 'function';\n const res = rowNodePinned ? false : isFunc || value === true;\n return res;\n }\n refreshShouldDestroy() {\n const colDef = this.column.getColDef();\n const selectionChanged = this.includeSelection != this.isIncludeControl(colDef.checkboxSelection);\n const rowDragChanged = this.includeRowDrag != this.isIncludeControl(colDef.rowDrag);\n const dndSourceChanged = this.includeDndSource != this.isIncludeControl(colDef.dndSource);\n return selectionChanged || rowDragChanged || dndSourceChanged;\n }\n // either called internally if single cell editing, or called by rowRenderer if row editing\n startEditing(key = null, cellStartedEdit = false, event = null) {\n if (!this.isCellEditable() || this.editing) {\n return;\n }\n // because of async in React, the cellComp may not be set yet, if no cellComp then we are\n // yet to initialise the cell, so we re-schedule this operation for when celLComp is attached\n if (!this.cellComp) {\n this.onCellCompAttachedFuncs.push(() => { this.startEditing(key, cellStartedEdit, event); });\n return;\n }\n const editorParams = this.createCellEditorParams(key, cellStartedEdit);\n const colDef = this.column.getColDef();\n const compDetails = this.beans.userComponentFactory.getCellEditorDetails(colDef, editorParams);\n // if cellEditorSelector was used, we give preference to popup and popupPosition from the selector\n const popup = (compDetails === null || compDetails === void 0 ? void 0 : compDetails.popupFromSelector) != null ? compDetails.popupFromSelector : !!colDef.cellEditorPopup;\n const position = (compDetails === null || compDetails === void 0 ? void 0 : compDetails.popupPositionFromSelector) != null ? compDetails.popupPositionFromSelector : colDef.cellEditorPopupPosition;\n this.setEditing(true);\n this.cellComp.setEditDetails(compDetails, popup, position);\n const e = this.createEvent(event, Events.EVENT_CELL_EDITING_STARTED);\n this.beans.eventService.dispatchEvent(e);\n }\n setEditing(editing) {\n if (this.editing === editing) {\n return;\n }\n this.editing = editing;\n this.refreshHandle();\n }\n // pass in 'true' to cancel the editing.\n stopRowOrCellEdit(cancel = false) {\n if (this.beans.gridOptionsService.get('editType') === 'fullRow') {\n this.rowCtrl.stopRowEditing(cancel);\n }\n else {\n this.stopEditing(cancel);\n }\n }\n onPopupEditorClosed() {\n if (!this.isEditing()) {\n return;\n }\n // note: this happens because of a click outside of the grid or if the popupEditor\n // is closed with `Escape` key. if another cell was clicked, then the editing will\n // have already stopped and returned on the conditional above.\n this.stopEditingAndFocus();\n }\n takeValueFromCellEditor(cancel) {\n const noValueResult = { newValueExists: false };\n if (cancel) {\n return noValueResult;\n }\n const cellEditor = this.cellComp.getCellEditor();\n if (!cellEditor) {\n return noValueResult;\n }\n const userWantsToCancel = cellEditor.isCancelAfterEnd && cellEditor.isCancelAfterEnd();\n if (userWantsToCancel) {\n return noValueResult;\n }\n const newValue = cellEditor.getValue();\n return {\n newValue: newValue,\n newValueExists: true\n };\n }\n /**\n * @returns `True` if the value changes, otherwise `False`.\n */\n saveNewValue(oldValue, newValue) {\n if (newValue === oldValue) {\n return false;\n }\n // we suppressRefreshCell because the call to rowNode.setDataValue() results in change detection\n // getting triggered, which results in all cells getting refreshed. we do not want this refresh\n // to happen on this call as we want to call it explicitly below. otherwise refresh gets called twice.\n // if we only did this refresh (and not the one below) then the cell would flash and not be forced.\n this.suppressRefreshCell = true;\n const valueChanged = this.rowNode.setDataValue(this.column, newValue, 'edit');\n this.suppressRefreshCell = false;\n return valueChanged;\n }\n /**\n * Ends the Cell Editing\n * @param cancel `True` if the edit process is being canceled.\n * @returns `True` if the value of the `GridCell` has been updated, otherwise `False`.\n */\n stopEditing(cancel = false) {\n if (!this.editing) {\n return false;\n }\n const { newValue, newValueExists } = this.takeValueFromCellEditor(cancel);\n const oldValue = this.rowNode.getValueFromValueService(this.column);\n let valueChanged = false;\n if (newValueExists) {\n valueChanged = this.saveNewValue(oldValue, newValue);\n }\n this.setEditing(false);\n this.cellComp.setEditDetails(); // passing nothing stops editing\n this.updateAndFormatValue();\n this.refreshCell({ forceRefresh: true, suppressFlash: true });\n this.dispatchEditingStoppedEvent(oldValue, newValue, !cancel && !!valueChanged);\n return valueChanged;\n }\n dispatchEditingStoppedEvent(oldValue, newValue, valueChanged) {\n const editingStoppedEvent = Object.assign(Object.assign({}, this.createEvent(null, Events.EVENT_CELL_EDITING_STOPPED)), { oldValue,\n newValue,\n valueChanged });\n this.beans.eventService.dispatchEvent(editingStoppedEvent);\n }\n createCellEditorParams(key, cellStartedEdit) {\n return {\n value: this.rowNode.getValueFromValueService(this.column),\n eventKey: key,\n column: this.column,\n colDef: this.column.getColDef(),\n rowIndex: this.getCellPosition().rowIndex,\n node: this.rowNode,\n data: this.rowNode.data,\n api: this.beans.gridOptionsService.api,\n cellStartedEdit: cellStartedEdit,\n columnApi: this.beans.gridOptionsService.columnApi,\n context: this.beans.gridOptionsService.context,\n onKeyDown: this.onKeyDown.bind(this),\n stopEditing: this.stopEditingAndFocus.bind(this),\n eGridCell: this.getGui(),\n parseValue: this.parseValue.bind(this),\n formatValue: this.formatValue.bind(this)\n };\n }\n createCellRendererParams() {\n const res = {\n value: this.value,\n valueFormatted: this.valueFormatted,\n getValue: () => this.rowNode.getValueFromValueService(this.column),\n setValue: (value) => this.beans.valueService.setValue(this.rowNode, this.column, value),\n formatValue: this.formatValue.bind(this),\n data: this.rowNode.data,\n node: this.rowNode,\n pinned: this.column.getPinned(),\n colDef: this.column.getColDef(),\n column: this.column,\n rowIndex: this.getCellPosition().rowIndex,\n api: this.beans.gridOptionsService.api,\n columnApi: this.beans.gridOptionsService.columnApi,\n context: this.beans.gridOptionsService.context,\n refreshCell: this.refreshCell.bind(this),\n eGridCell: this.getGui(),\n eParentOfValue: this.cellComp.getParentOfValue(),\n registerRowDragger: (rowDraggerElement, dragStartPixels, value, suppressVisibilityChange) => this.registerRowDragger(rowDraggerElement, dragStartPixels, suppressVisibilityChange),\n };\n return res;\n }\n parseValue(newValue) {\n return this.beans.valueParserService.parseValue(this.column, this.rowNode, newValue, this.getValue());\n }\n setFocusOutOnEditor() {\n if (!this.editing) {\n return;\n }\n const cellEditor = this.cellComp.getCellEditor();\n if (cellEditor && cellEditor.focusOut) {\n cellEditor.focusOut();\n }\n }\n setFocusInOnEditor() {\n if (!this.editing) {\n return;\n }\n const cellEditor = this.cellComp.getCellEditor();\n if (cellEditor && cellEditor.focusIn) {\n // if the editor is present, then we just focus it\n cellEditor.focusIn();\n }\n else {\n // if the editor is not present, it means async cell editor (eg React fibre)\n // and we are trying to set focus before the cell editor is present, so we\n // focus the cell instead\n this.focusCell(true);\n }\n }\n onCellChanged(event) {\n // because of async in React, the cellComp may not be set yet, if no cellComp then we are\n // yet to initialise the cell, so no need to refresh.\n if (!this.cellComp) {\n return;\n }\n const eventImpactsThisCell = event.column === this.column;\n if (eventImpactsThisCell) {\n this.refreshCell({});\n }\n }\n // + stop editing {forceRefresh: true, suppressFlash: true}\n // + event cellChanged {}\n // + cellRenderer.params.refresh() {} -> method passes 'as is' to the cellRenderer, so params could be anything\n // + rowCtrl: event dataChanged {suppressFlash: !update, newData: !update}\n // + rowCtrl: api refreshCells() {animate: true/false}\n // + rowRenderer: api softRefreshView() {}\n refreshCell(params) {\n var _a, _b, _c;\n // if we are in the middle of 'stopEditing', then we don't refresh here, as refresh gets called explicitly\n if (this.suppressRefreshCell || this.editing) {\n return;\n }\n // In React, due to async, it's possible a refresh was asked for before the CellComp\n // has been set. If this happens, we skip the refresh, as the cell is going to be\n // initialised anyway once the CellComp is set.\n if (!this.cellComp) {\n return;\n }\n const colDef = this.column.getColDef();\n const newData = params != null && !!params.newData;\n const suppressFlash = (params != null && !!params.suppressFlash) || !!colDef.suppressCellFlash;\n // we always refresh if cell has no value - this can happen when user provides Cell Renderer and the\n // cell renderer doesn't rely on a value, instead it could be looking directly at the data, or maybe\n // printing the current time (which would be silly)???. Generally speaking\n // non of {field, valueGetter, showRowGroup} is bad in the users application, however for this edge case, it's\n // best always refresh and take the performance hit rather than never refresh and users complaining in support\n // that cells are not updating.\n const noValueProvided = colDef.field == null && colDef.valueGetter == null && colDef.showRowGroup == null;\n const forceRefresh = (params && params.forceRefresh) || noValueProvided || newData;\n const valuesDifferent = this.updateAndFormatValue();\n const dataNeedsUpdating = forceRefresh || valuesDifferent;\n if (dataNeedsUpdating) {\n // if it's 'new data', then we don't refresh the cellRenderer, even if refresh method is available.\n // this is because if the whole data is new (ie we are showing stock price 'BBA' now and not 'SSD')\n // then we are not showing a movement in the stock price, rather we are showing different stock.\n this.showValue(newData);\n // we don't want to flash the cells when processing a filter change, as otherwise the UI would\n // be to busy. see comment in FilterManager with regards processingFilterChange\n const processingFilterChange = this.beans.filterManager.isSuppressFlashingCellsBecauseFiltering();\n const flashCell = !suppressFlash && !processingFilterChange &&\n (this.beans.gridOptionsService.is('enableCellChangeFlash') || colDef.enableCellChangeFlash);\n if (flashCell) {\n this.flashCell();\n }\n (_a = this.cellCustomStyleFeature) === null || _a === void 0 ? void 0 : _a.applyUserStyles();\n (_b = this.cellCustomStyleFeature) === null || _b === void 0 ? void 0 : _b.applyClassesFromColDef();\n }\n this.refreshToolTip();\n // we do cellClassRules even if the value has not changed, so that users who have rules that\n // look at other parts of the row (where the other part of the row might of changed) will work.\n (_c = this.cellCustomStyleFeature) === null || _c === void 0 ? void 0 : _c.applyCellClassRules();\n }\n // cell editors call this, when they want to stop for reasons other\n // than what we pick up on. eg selecting from a dropdown ends editing.\n stopEditingAndFocus(suppressNavigateAfterEdit = false, shiftKey = false) {\n this.stopRowOrCellEdit();\n this.focusCell(true);\n if (!suppressNavigateAfterEdit) {\n this.navigateAfterEdit(shiftKey);\n }\n }\n navigateAfterEdit(shiftKey) {\n const enterNavigatesVerticallyAfterEdit = this.beans.gridOptionsService.is('enterNavigatesVerticallyAfterEdit');\n if (enterNavigatesVerticallyAfterEdit) {\n const key = shiftKey ? KeyCode.UP : KeyCode.DOWN;\n this.beans.navigationService.navigateToNextCell(null, key, this.getCellPosition(), false);\n }\n }\n // user can also call this via API\n flashCell(delays) {\n const flashDelay = delays && delays.flashDelay;\n const fadeDelay = delays && delays.fadeDelay;\n this.animateCell('data-changed', flashDelay, fadeDelay);\n }\n animateCell(cssName, flashDelay, fadeDelay) {\n var _a, _b;\n if (!this.cellComp) {\n return;\n }\n const fullName = `ag-cell-${cssName}`;\n const animationFullName = `ag-cell-${cssName}-animation`;\n const { gridOptionsService } = this.beans;\n if (!flashDelay) {\n flashDelay = (_a = gridOptionsService.getNum('cellFlashDelay')) !== null && _a !== void 0 ? _a : 500;\n }\n if (!exists(fadeDelay)) {\n fadeDelay = (_b = gridOptionsService.getNum('cellFadeDelay')) !== null && _b !== void 0 ? _b : 1000;\n }\n // we want to highlight the cells, without any animation\n this.cellComp.addOrRemoveCssClass(fullName, true);\n this.cellComp.addOrRemoveCssClass(animationFullName, false);\n // then once that is applied, we remove the highlight with animation\n window.setTimeout(() => {\n if (!this.isAlive()) {\n return;\n }\n this.cellComp.addOrRemoveCssClass(fullName, false);\n this.cellComp.addOrRemoveCssClass(animationFullName, true);\n this.eGui.style.transition = `background-color ${fadeDelay}ms`;\n window.setTimeout(() => {\n if (!this.isAlive()) {\n return;\n }\n // and then to leave things as we got them, we remove the animation\n this.cellComp.addOrRemoveCssClass(animationFullName, false);\n this.eGui.style.transition = '';\n }, fadeDelay);\n }, flashDelay);\n }\n onFlashCells(event) {\n if (!this.cellComp) {\n return;\n }\n const cellId = this.beans.cellPositionUtils.createId(this.getCellPosition());\n const shouldFlash = event.cells[cellId];\n if (shouldFlash) {\n this.animateCell('highlight');\n }\n }\n isCellEditable() {\n return this.column.isCellEditable(this.rowNode);\n }\n isSuppressFillHandle() {\n return this.column.isSuppressFillHandle();\n }\n formatValue(value) {\n var _a;\n return (_a = this.callValueFormatter(value)) !== null && _a !== void 0 ? _a : value;\n }\n callValueFormatter(value) {\n return this.beans.valueFormatterService.formatValue(this.column, this.rowNode, value);\n }\n updateAndFormatValue(force = false) {\n const oldValue = this.value;\n const oldValueFormatted = this.valueFormatted;\n this.value = this.rowNode.getValueFromValueService(this.column);\n this.valueFormatted = this.callValueFormatter(this.value);\n const valuesDifferent = force ? true :\n !this.valuesAreEqual(oldValue, this.value) || this.valueFormatted != oldValueFormatted;\n return valuesDifferent;\n }\n valuesAreEqual(val1, val2) {\n // if the user provided an equals method, use that, otherwise do simple comparison\n const colDef = this.column.getColDef();\n return colDef.equals ? colDef.equals(val1, val2) : val1 === val2;\n }\n getComp() {\n return this.cellComp;\n }\n getValue() {\n return this.value;\n }\n getValueFormatted() {\n return this.valueFormatted;\n }\n addDomData() {\n const element = this.getGui();\n this.beans.gridOptionsService.setDomData(element, CellCtrl.DOM_DATA_KEY_CELL_CTRL, this);\n this.addDestroyFunc(() => this.beans.gridOptionsService.setDomData(element, CellCtrl.DOM_DATA_KEY_CELL_CTRL, null));\n }\n createEvent(domEvent, eventType) {\n const event = {\n type: eventType,\n node: this.rowNode,\n data: this.rowNode.data,\n value: this.value,\n column: this.column,\n colDef: this.column.getColDef(),\n context: this.beans.gridOptionsService.context,\n api: this.beans.gridApi,\n columnApi: this.beans.columnApi,\n rowPinned: this.rowNode.rowPinned,\n event: domEvent,\n rowIndex: this.rowNode.rowIndex\n };\n return event;\n }\n processCharacter(event) {\n var _a;\n (_a = this.cellKeyboardListenerFeature) === null || _a === void 0 ? void 0 : _a.processCharacter(event);\n }\n onKeyDown(event) {\n var _a;\n (_a = this.cellKeyboardListenerFeature) === null || _a === void 0 ? void 0 : _a.onKeyDown(event);\n }\n onMouseEvent(eventName, mouseEvent) {\n var _a;\n (_a = this.cellMouseListenerFeature) === null || _a === void 0 ? void 0 : _a.onMouseEvent(eventName, mouseEvent);\n }\n getGui() {\n return this.eGui;\n }\n refreshToolTip() {\n var _a;\n (_a = this.tooltipFeature) === null || _a === void 0 ? void 0 : _a.refreshToolTip();\n }\n getColSpanningList() {\n return this.cellPositionFeature.getColSpanningList();\n }\n onLeftChanged() {\n var _a;\n if (!this.cellComp) {\n return;\n }\n (_a = this.cellPositionFeature) === null || _a === void 0 ? void 0 : _a.onLeftChanged();\n }\n onDisplayedColumnsChanged() {\n if (!this.eGui) {\n return;\n }\n this.setAriaColIndex();\n }\n setAriaColIndex() {\n const colIdx = this.beans.columnModel.getAriaColumnIndex(this.column);\n setAriaColIndex(this.getGui(), colIdx); // for react, we don't use JSX, as it slowed down column moving\n }\n isSuppressNavigable() {\n return this.column.isSuppressNavigable(this.rowNode);\n }\n onWidthChanged() {\n var _a;\n return (_a = this.cellPositionFeature) === null || _a === void 0 ? void 0 : _a.onWidthChanged();\n }\n getColumn() {\n return this.column;\n }\n getRowNode() {\n return this.rowNode;\n }\n getBeans() {\n return this.beans;\n }\n isPrintLayout() {\n return this.printLayout;\n }\n appendChild(htmlElement) {\n this.eGui.appendChild(htmlElement);\n }\n refreshHandle() {\n if (this.cellRangeFeature) {\n this.cellRangeFeature.refreshHandle();\n }\n }\n getCellPosition() {\n return this.cellPosition;\n }\n isEditing() {\n return this.editing;\n }\n // called by rowRenderer when user navigates via tab key\n startRowOrCellEdit(key, event = null) {\n if (!this.cellComp) {\n return;\n }\n if (this.beans.gridOptionsService.get('editType') === 'fullRow') {\n this.rowCtrl.startRowEditing(key, this);\n }\n else {\n this.startEditing(key, true, event);\n }\n }\n getRowCtrl() {\n return this.rowCtrl;\n }\n getRowPosition() {\n return {\n rowIndex: this.cellPosition.rowIndex,\n rowPinned: this.cellPosition.rowPinned\n };\n }\n updateRangeBordersIfRangeCount() {\n if (!this.cellComp) {\n return;\n }\n if (this.cellRangeFeature) {\n this.cellRangeFeature.updateRangeBordersIfRangeCount();\n }\n }\n onRangeSelectionChanged() {\n if (!this.cellComp) {\n return;\n }\n if (this.cellRangeFeature) {\n this.cellRangeFeature.onRangeSelectionChanged();\n }\n }\n isRangeSelectionEnabled() {\n return this.cellRangeFeature != null;\n }\n focusCell(forceBrowserFocus = false) {\n this.beans.focusService.setFocusedCell({\n rowIndex: this.getCellPosition().rowIndex,\n column: this.column,\n rowPinned: this.rowNode.rowPinned,\n forceBrowserFocus\n });\n }\n onRowIndexChanged() {\n // when index changes, this influences items that need the index, so we update the\n // grid cell so they are working off the new index.\n this.createCellPosition();\n // when the index of the row changes, ie means the cell may have lost or gained focus\n this.onCellFocused();\n // check range selection\n if (this.cellRangeFeature) {\n this.cellRangeFeature.onRangeSelectionChanged();\n }\n }\n onFirstRightPinnedChanged() {\n if (!this.cellComp) {\n return;\n }\n const firstRightPinned = this.column.isFirstRightPinned();\n this.cellComp.addOrRemoveCssClass(CSS_CELL_FIRST_RIGHT_PINNED, firstRightPinned);\n }\n onLastLeftPinnedChanged() {\n if (!this.cellComp) {\n return;\n }\n const lastLeftPinned = this.column.isLastLeftPinned();\n this.cellComp.addOrRemoveCssClass(CSS_CELL_LAST_LEFT_PINNED, lastLeftPinned);\n }\n onCellFocused(event) {\n if (this.beans.gridOptionsService.is('suppressCellFocus')) {\n return;\n }\n const cellFocused = this.beans.focusService.isCellFocused(this.cellPosition);\n if (!this.cellComp) {\n if (cellFocused && (event === null || event === void 0 ? void 0 : event.forceBrowserFocus)) {\n // The cell comp has not been rendered yet, but the browser focus is being forced for this cell\n // so lets save the event to apply it when setComp is called in the next turn.\n this.focusEventToRestore = event;\n }\n return;\n }\n // Clear the saved focus event\n this.focusEventToRestore = undefined;\n this.cellComp.addOrRemoveCssClass(CSS_CELL_FOCUS, cellFocused);\n // see if we need to force browser focus - this can happen if focus is programmatically set\n if (cellFocused && event && event.forceBrowserFocus) {\n const focusEl = this.cellComp.getFocusableElement();\n focusEl.focus({ preventScroll: !!event.preventScrollOnBrowserFocus });\n }\n // if another cell was focused, and we are editing, then stop editing\n const fullRowEdit = this.beans.gridOptionsService.get('editType') === 'fullRow';\n if (!cellFocused && !fullRowEdit && this.editing) {\n this.stopRowOrCellEdit();\n }\n }\n createCellPosition() {\n this.cellPosition = {\n rowIndex: this.rowNode.rowIndex,\n rowPinned: makeNull(this.rowNode.rowPinned),\n column: this.column\n };\n }\n // CSS Classes that only get applied once, they never change\n applyStaticCssClasses() {\n this.cellComp.addOrRemoveCssClass(CSS_CELL, true);\n this.cellComp.addOrRemoveCssClass(CSS_CELL_NOT_INLINE_EDITING, true);\n // normal cells fill the height of the row. autoHeight cells have no height to let them\n // fit the height of content.\n const autoHeight = this.column.isAutoHeight() == true;\n this.cellComp.addOrRemoveCssClass(CSS_AUTO_HEIGHT, autoHeight);\n this.cellComp.addOrRemoveCssClass(CSS_NORMAL_HEIGHT, !autoHeight);\n }\n onColumnHover() {\n if (!this.cellComp) {\n return;\n }\n if (!this.beans.gridOptionsService.is('columnHoverHighlight')) {\n return;\n }\n const isHovered = this.beans.columnHoverService.isHovered(this.column);\n this.cellComp.addOrRemoveCssClass(CSS_COLUMN_HOVER, isHovered);\n }\n onColDefChanged() {\n if (!this.cellComp) {\n return;\n }\n this.setWrapText();\n if (!this.editing) {\n this.refreshCell({ forceRefresh: true, suppressFlash: true });\n }\n }\n setWrapText() {\n const value = this.column.getColDef().wrapText == true;\n this.cellComp.addOrRemoveCssClass(CSS_CELL_WRAP_TEXT, value);\n }\n dispatchCellContextMenuEvent(event) {\n const colDef = this.column.getColDef();\n const cellContextMenuEvent = this.createEvent(event, Events.EVENT_CELL_CONTEXT_MENU);\n this.beans.eventService.dispatchEvent(cellContextMenuEvent);\n if (colDef.onCellContextMenu) {\n // to make the callback async, do in a timeout\n window.setTimeout(() => colDef.onCellContextMenu(cellContextMenuEvent), 0);\n }\n }\n getCellRenderer() {\n return this.cellComp ? this.cellComp.getCellRenderer() : null;\n }\n getCellEditor() {\n return this.cellComp ? this.cellComp.getCellEditor() : null;\n }\n destroy() {\n this.onCellCompAttachedFuncs = [];\n super.destroy();\n }\n createSelectionCheckbox() {\n const cbSelectionComponent = new CheckboxSelectionComponent();\n this.beans.context.createBean(cbSelectionComponent);\n cbSelectionComponent.init({ rowNode: this.rowNode, column: this.column });\n // put the checkbox in before the value\n return cbSelectionComponent;\n }\n createDndSource() {\n const dndSourceComp = new DndSourceComp(this.rowNode, this.column, this.eGui);\n this.beans.context.createBean(dndSourceComp);\n return dndSourceComp;\n }\n registerRowDragger(customElement, dragStartPixels, suppressVisibilityChange) {\n // if previously existed, then we are only updating\n if (this.customRowDragComp) {\n this.customRowDragComp.setDragElement(customElement, dragStartPixels);\n return;\n }\n const newComp = this.createRowDragComp(customElement, dragStartPixels, suppressVisibilityChange);\n if (newComp) {\n this.customRowDragComp = newComp;\n this.addDestroyFunc(() => { this.beans.context.destroyBean(newComp); this.customRowDragComp = null; });\n }\n }\n createRowDragComp(customElement, dragStartPixels, suppressVisibilityChange) {\n const pagination = this.beans.gridOptionsService.is('pagination');\n const rowDragManaged = this.beans.gridOptionsService.is('rowDragManaged');\n const clientSideRowModelActive = this.beans.gridOptionsService.isRowModelType('clientSide');\n if (rowDragManaged) {\n // row dragging only available in default row model\n if (!clientSideRowModelActive) {\n doOnce(() => console.warn('AG Grid: managed row dragging is only allowed in the Client Side Row Model'), 'CellComp.addRowDragging');\n return;\n }\n if (pagination) {\n doOnce(() => console.warn('AG Grid: managed row dragging is not possible when doing pagination'), 'CellComp.addRowDragging');\n return;\n }\n }\n // otherwise (normal case) we are creating a RowDraggingComp for the first time\n const rowDragComp = new RowDragComp(() => this.value, this.rowNode, this.column, customElement, dragStartPixels, suppressVisibilityChange);\n this.beans.context.createBean(rowDragComp);\n return rowDragComp;\n }\n}\nCellCtrl.DOM_DATA_KEY_CELL_CTRL = 'cellCtrl';\n","import { BeanStub } from \"../../context/beanStub.mjs\";\nimport { RowNode } from \"../../entities/rowNode.mjs\";\nimport { RowHighlightPosition } from \"../../interfaces/iRowNode.mjs\";\nimport { Events } from \"../../events.mjs\";\nimport { RowContainerType } from \"../../gridBodyComp/rowContainer/rowContainerCtrl.mjs\";\nimport { ModuleNames } from \"../../modules/moduleNames.mjs\";\nimport { ModuleRegistry } from \"../../modules/moduleRegistry.mjs\";\nimport { setAriaExpanded, setAriaLabel, setAriaRowIndex, setAriaSelected } from \"../../utils/aria.mjs\";\nimport { isElementChildOfClass } from \"../../utils/dom.mjs\";\nimport { isStopPropagationForAgGrid } from \"../../utils/event.mjs\";\nimport { doOnce, executeNextVMTurn } from \"../../utils/function.mjs\";\nimport { exists, makeNull } from \"../../utils/generic.mjs\";\nimport { escapeString } from \"../../utils/string.mjs\";\nimport { CellCtrl } from \"../cell/cellCtrl.mjs\";\nimport { RowDragComp } from \"./rowDragComp.mjs\";\nvar RowType;\n(function (RowType) {\n RowType[\"Normal\"] = \"Normal\";\n RowType[\"FullWidth\"] = \"FullWidth\";\n RowType[\"FullWidthLoading\"] = \"FullWidthLoading\";\n RowType[\"FullWidthGroup\"] = \"FullWidthGroup\";\n RowType[\"FullWidthDetail\"] = \"FullWidthDetail\";\n})(RowType || (RowType = {}));\nlet instanceIdSequence = 0;\nexport class RowCtrl extends BeanStub {\n constructor(rowNode, beans, animateIn, useAnimationFrameForCreate, printLayout) {\n super();\n this.allRowGuis = [];\n this.active = true;\n this.centerCellCtrls = { list: [], map: {} };\n this.leftCellCtrls = { list: [], map: {} };\n this.rightCellCtrls = { list: [], map: {} };\n this.slideInAnimation = {\n left: false,\n center: false,\n right: false,\n fullWidth: false\n };\n this.fadeInAnimation = {\n left: false,\n center: false,\n right: false,\n fullWidth: false\n };\n this.lastMouseDownOnDragger = false;\n this.emptyStyle = {};\n this.updateColumnListsPending = false;\n this.rowId = null;\n this.businessKeySanitised = null;\n this.beans = beans;\n this.gridOptionsService = beans.gridOptionsService;\n this.rowNode = rowNode;\n this.paginationPage = beans.paginationProxy.getCurrentPage();\n this.useAnimationFrameForCreate = useAnimationFrameForCreate;\n this.printLayout = printLayout;\n this.instanceId = rowNode.id + '-' + instanceIdSequence++;\n this.rowId = escapeString(rowNode.id);\n this.initRowBusinessKey();\n this.rowFocused = beans.focusService.isRowFocused(this.rowNode.rowIndex, this.rowNode.rowPinned);\n this.rowLevel = beans.rowCssClassCalculator.calculateRowLevel(this.rowNode);\n this.setRowType();\n this.setAnimateFlags(animateIn);\n this.rowStyles = this.processStylesFromGridOptions();\n // calls to `isFullWidth()` only work after `setRowType` has been called.\n if (this.isFullWidth() && !this.gridOptionsService.is('suppressCellFocus')) {\n this.tabIndex = -1;\n }\n this.addListeners();\n }\n initRowBusinessKey() {\n this.businessKeyForNodeFunc = this.gridOptionsService.get('getBusinessKeyForNode');\n this.updateRowBusinessKey();\n }\n updateRowBusinessKey() {\n if (typeof this.businessKeyForNodeFunc !== 'function') {\n return;\n }\n const businessKey = this.businessKeyForNodeFunc(this.rowNode);\n this.businessKeySanitised = escapeString(businessKey);\n }\n getRowId() {\n return this.rowId;\n }\n getRowStyles() {\n return this.rowStyles;\n }\n getTabIndex() {\n return this.tabIndex;\n }\n isSticky() {\n return this.rowNode.sticky;\n }\n getBeans() {\n return this.beans;\n }\n getInstanceId() {\n return this.instanceId;\n }\n setComp(rowComp, element, containerType) {\n const gui = { rowComp, element, containerType };\n this.allRowGuis.push(gui);\n if (containerType === RowContainerType.LEFT) {\n this.leftGui = gui;\n }\n else if (containerType === RowContainerType.RIGHT) {\n this.rightGui = gui;\n }\n else if (containerType === RowContainerType.FULL_WIDTH) {\n this.fullWidthGui = gui;\n }\n else {\n this.centerGui = gui;\n }\n this.initialiseRowComp(gui);\n // pinned rows render before the main grid body in the SSRM, only fire the event after the main body has rendered.\n if (this.rowType !== 'FullWidthLoading' && !this.rowNode.rowPinned) {\n // this is fired within setComp as we know that the component renderer is now trying to render.\n // linked with the fact the function implementation queues behind requestAnimationFrame should allow\n // us to be certain that all rendering is done by the time the event fires.\n this.beans.rowRenderer.dispatchFirstDataRenderedEvent();\n }\n }\n unsetComp(containerType) {\n this.allRowGuis = this.allRowGuis\n .filter(rowGui => rowGui.containerType !== containerType);\n switch (containerType) {\n case RowContainerType.LEFT:\n this.leftGui = undefined;\n break;\n case RowContainerType.RIGHT:\n this.rightGui = undefined;\n break;\n case RowContainerType.FULL_WIDTH:\n this.fullWidthGui = undefined;\n break;\n case RowContainerType.CENTER:\n this.centerGui = undefined;\n break;\n default:\n }\n }\n isCacheable() {\n return this.rowType === RowType.FullWidthDetail\n && this.gridOptionsService.is('keepDetailRows');\n }\n setCached(cached) {\n const displayValue = cached ? 'none' : '';\n this.allRowGuis.forEach(rg => rg.element.style.display = displayValue);\n }\n initialiseRowComp(gui) {\n const gos = this.gridOptionsService;\n this.listenOnDomOrder(gui);\n this.onRowHeightChanged(gui);\n this.updateRowIndexes(gui);\n this.setFocusedClasses(gui);\n this.setStylesFromGridOptions(false, gui); // no need to calculate styles already set in constructor\n if (gos.isRowSelection() && this.rowNode.selectable) {\n this.onRowSelected(gui);\n }\n this.updateColumnLists(!this.useAnimationFrameForCreate);\n const comp = gui.rowComp;\n const initialRowClasses = this.getInitialRowClasses(gui.containerType);\n initialRowClasses.forEach(name => comp.addOrRemoveCssClass(name, true));\n this.executeSlideAndFadeAnimations(gui);\n if (this.rowNode.group) {\n setAriaExpanded(gui.element, this.rowNode.expanded == true);\n }\n this.setRowCompRowId(comp);\n this.setRowCompRowBusinessKey(comp);\n // DOM DATA\n gos.setDomData(gui.element, RowCtrl.DOM_DATA_KEY_ROW_CTRL, this);\n this.addDestroyFunc(() => gos.setDomData(gui.element, RowCtrl.DOM_DATA_KEY_ROW_CTRL, null));\n // adding hover functionality adds listener to this row, so we\n // do it lazily in an animation frame\n if (this.useAnimationFrameForCreate) {\n this.beans.animationFrameService.createTask(this.addHoverFunctionality.bind(this, gui.element), this.rowNode.rowIndex, 'createTasksP2');\n }\n else {\n this.addHoverFunctionality(gui.element);\n }\n if (this.isFullWidth()) {\n this.setupFullWidth(gui);\n }\n if (gos.is('rowDragEntireRow')) {\n this.addRowDraggerToRow(gui);\n }\n if (this.useAnimationFrameForCreate) {\n // the height animation we only want active after the row is alive for 1 second.\n // this stops the row animation working when rows are initially created. otherwise\n // auto-height rows get inserted into the dom and resized immediately, which gives\n // very bad UX (eg 10 rows get inserted, then all 10 expand, look particularly bad\n // when scrolling). so this makes sure when rows are shown for the first time, they\n // are resized immediately without animation.\n this.beans.animationFrameService.addDestroyTask(() => {\n if (!this.isAlive()) {\n return;\n }\n gui.rowComp.addOrRemoveCssClass('ag-after-created', true);\n });\n }\n this.executeProcessRowPostCreateFunc();\n }\n setRowCompRowBusinessKey(comp) {\n if (this.businessKeySanitised == null) {\n return;\n }\n comp.setRowBusinessKey(this.businessKeySanitised);\n }\n getBusinessKey() {\n return this.businessKeySanitised;\n }\n setRowCompRowId(comp) {\n this.rowId = escapeString(this.rowNode.id);\n if (this.rowId == null) {\n return;\n }\n comp.setRowId(this.rowId);\n }\n executeSlideAndFadeAnimations(gui) {\n const { containerType } = gui;\n const shouldSlide = this.slideInAnimation[containerType];\n if (shouldSlide) {\n executeNextVMTurn(() => {\n this.onTopChanged();\n });\n this.slideInAnimation[containerType] = false;\n }\n const shouldFade = this.fadeInAnimation[containerType];\n if (shouldFade) {\n executeNextVMTurn(() => {\n gui.rowComp.addOrRemoveCssClass('ag-opacity-zero', false);\n });\n this.fadeInAnimation[containerType] = false;\n }\n }\n addRowDraggerToRow(gui) {\n if (this.gridOptionsService.is('enableRangeSelection')) {\n doOnce(() => {\n console.warn('AG Grid: Setting `rowDragEntireRow: true` in the gridOptions doesn\\'t work with `enableRangeSelection: true`');\n }, 'rowDragAndRangeSelectionEnabled');\n return;\n }\n const translate = this.beans.localeService.getLocaleTextFunc();\n const rowDragComp = new RowDragComp(() => `1 ${translate('rowDragRow', 'row')}`, this.rowNode, undefined, gui.element, undefined, true);\n this.createManagedBean(rowDragComp, this.beans.context);\n }\n setupFullWidth(gui) {\n const pinned = this.getPinnedForContainer(gui.containerType);\n const params = this.createFullWidthParams(gui.element, pinned);\n if (this.rowType == RowType.FullWidthDetail) {\n if (!ModuleRegistry.__assertRegistered(ModuleNames.MasterDetailModule, \"cell renderer 'agDetailCellRenderer' (for master detail)\", this.beans.context.getGridId())) {\n return;\n }\n }\n let compDetails;\n switch (this.rowType) {\n case RowType.FullWidthDetail:\n compDetails = this.beans.userComponentFactory.getFullWidthDetailCellRendererDetails(params);\n break;\n case RowType.FullWidthGroup:\n compDetails = this.beans.userComponentFactory.getFullWidthGroupCellRendererDetails(params);\n break;\n case RowType.FullWidthLoading:\n compDetails = this.beans.userComponentFactory.getFullWidthLoadingCellRendererDetails(params);\n break;\n default:\n compDetails = this.beans.userComponentFactory.getFullWidthCellRendererDetails(params);\n break;\n }\n gui.rowComp.showFullWidth(compDetails);\n }\n isPrintLayout() {\n return this.printLayout;\n }\n getFullWidthCellRenderer() {\n var _a, _b;\n return (_b = (_a = this.fullWidthGui) === null || _a === void 0 ? void 0 : _a.rowComp) === null || _b === void 0 ? void 0 : _b.getFullWidthCellRenderer();\n }\n // use by autoWidthCalculator, as it clones the elements\n getCellElement(column) {\n const cellCtrl = this.getCellCtrl(column);\n return cellCtrl ? cellCtrl.getGui() : null;\n }\n executeProcessRowPostCreateFunc() {\n const func = this.gridOptionsService.getCallback('processRowPostCreate');\n if (!func || !this.areAllContainersReady()) {\n return;\n }\n const params = {\n // areAllContainersReady asserts that centerGui is not null\n eRow: this.centerGui.element,\n ePinnedLeftRow: this.leftGui ? this.leftGui.element : undefined,\n ePinnedRightRow: this.rightGui ? this.rightGui.element : undefined,\n node: this.rowNode,\n rowIndex: this.rowNode.rowIndex,\n addRenderedRowListener: this.addEventListener.bind(this),\n };\n func(params);\n }\n areAllContainersReady() {\n const isLeftReady = !!this.leftGui || !this.beans.columnModel.isPinningLeft();\n const isCenterReady = !!this.centerGui;\n const isRightReady = !!this.rightGui || !this.beans.columnModel.isPinningRight();\n return isLeftReady && isCenterReady && isRightReady;\n }\n setRowType() {\n const isStub = this.rowNode.stub;\n const isFullWidthCell = this.rowNode.isFullWidthCell();\n const isDetailCell = this.beans.doingMasterDetail && this.rowNode.detail;\n const pivotMode = this.beans.columnModel.isPivotMode();\n // we only use full width for groups, not footers. it wouldn't make sense to include footers if not looking\n // for totals. if users complain about this, then we should introduce a new property 'footerUseEntireRow'\n // so each can be set independently (as a customer complained about footers getting full width, hence\n // introducing this logic)\n const isGroupRow = !!this.rowNode.group && !this.rowNode.footer;\n const isFullWidthGroup = isGroupRow && this.gridOptionsService.isGroupUseEntireRow(pivotMode);\n if (isStub) {\n this.rowType = RowType.FullWidthLoading;\n }\n else if (isDetailCell) {\n this.rowType = RowType.FullWidthDetail;\n }\n else if (isFullWidthCell) {\n this.rowType = RowType.FullWidth;\n }\n else if (isFullWidthGroup) {\n this.rowType = RowType.FullWidthGroup;\n }\n else {\n this.rowType = RowType.Normal;\n }\n }\n updateColumnLists(suppressAnimationFrame = false, useFlushSync = false) {\n if (this.isFullWidth()) {\n return;\n }\n const noAnimation = suppressAnimationFrame\n || this.gridOptionsService.is('suppressAnimationFrame')\n || this.printLayout;\n if (noAnimation) {\n this.updateColumnListsImpl(useFlushSync);\n return;\n }\n if (this.updateColumnListsPending) {\n return;\n }\n this.beans.animationFrameService.createTask(() => {\n if (!this.active) {\n return;\n }\n this.updateColumnListsImpl(true);\n }, this.rowNode.rowIndex, 'createTasksP1');\n this.updateColumnListsPending = true;\n }\n createCellCtrls(prev, cols, pinned = null) {\n const res = {\n list: [],\n map: {}\n };\n const addCell = (colInstanceId, cellCtrl) => {\n res.list.push(cellCtrl);\n res.map[colInstanceId] = cellCtrl;\n };\n cols.forEach(col => {\n // we use instanceId's rather than colId as it's possible there is a Column with same Id,\n // but it's referring to a different column instance. Happens a lot with pivot, as pivot col id's are\n // reused eg pivot_0, pivot_1 etc\n const colInstanceId = col.getInstanceId();\n let cellCtrl = prev.map[colInstanceId];\n if (!cellCtrl) {\n cellCtrl = new CellCtrl(col, this.rowNode, this.beans, this);\n }\n addCell(colInstanceId, cellCtrl);\n });\n prev.list.forEach(prevCellCtrl => {\n const cellInResult = res.map[prevCellCtrl.getColumn().getInstanceId()] != null;\n if (cellInResult) {\n return;\n }\n const keepCell = !this.isCellEligibleToBeRemoved(prevCellCtrl, pinned);\n if (keepCell) {\n addCell(prevCellCtrl.getColumn().getInstanceId(), prevCellCtrl);\n return;\n }\n prevCellCtrl.destroy();\n });\n return res;\n }\n updateColumnListsImpl(useFlushSync) {\n this.updateColumnListsPending = false;\n this.createAllCellCtrls();\n this.setCellCtrls(useFlushSync);\n }\n setCellCtrls(useFlushSync) {\n this.allRowGuis.forEach(item => {\n const cellControls = this.getCellCtrlsForContainer(item.containerType);\n item.rowComp.setCellCtrls(cellControls, useFlushSync);\n });\n }\n getCellCtrlsForContainer(containerType) {\n switch (containerType) {\n case RowContainerType.LEFT:\n return this.leftCellCtrls.list;\n case RowContainerType.RIGHT:\n return this.rightCellCtrls.list;\n case RowContainerType.FULL_WIDTH:\n return [];\n case RowContainerType.CENTER:\n return this.centerCellCtrls.list;\n default:\n const exhaustiveCheck = containerType;\n throw new Error(`Unhandled case: ${exhaustiveCheck}`);\n }\n }\n createAllCellCtrls() {\n const columnModel = this.beans.columnModel;\n if (this.printLayout) {\n this.centerCellCtrls = this.createCellCtrls(this.centerCellCtrls, columnModel.getAllDisplayedColumns());\n this.leftCellCtrls = { list: [], map: {} };\n this.rightCellCtrls = { list: [], map: {} };\n }\n else {\n const centerCols = columnModel.getViewportCenterColumnsForRow(this.rowNode);\n this.centerCellCtrls = this.createCellCtrls(this.centerCellCtrls, centerCols);\n const leftCols = columnModel.getDisplayedLeftColumnsForRow(this.rowNode);\n this.leftCellCtrls = this.createCellCtrls(this.leftCellCtrls, leftCols, 'left');\n const rightCols = columnModel.getDisplayedRightColumnsForRow(this.rowNode);\n this.rightCellCtrls = this.createCellCtrls(this.rightCellCtrls, rightCols, 'right');\n }\n }\n isCellEligibleToBeRemoved(cellCtrl, nextContainerPinned) {\n const REMOVE_CELL = true;\n const KEEP_CELL = false;\n // always remove the cell if it's not rendered or if it's in the wrong pinned location\n const column = cellCtrl.getColumn();\n if (column.getPinned() != nextContainerPinned) {\n return REMOVE_CELL;\n }\n // we want to try and keep editing and focused cells\n const editing = cellCtrl.isEditing();\n const focused = this.beans.focusService.isCellFocused(cellCtrl.getCellPosition());\n const mightWantToKeepCell = editing || focused;\n if (mightWantToKeepCell) {\n const column = cellCtrl.getColumn();\n const displayedColumns = this.beans.columnModel.getAllDisplayedColumns();\n const cellStillDisplayed = displayedColumns.indexOf(column) >= 0;\n return cellStillDisplayed ? KEEP_CELL : REMOVE_CELL;\n }\n return REMOVE_CELL;\n }\n getDomOrder() {\n const isEnsureDomOrder = this.gridOptionsService.is('ensureDomOrder');\n return isEnsureDomOrder || this.gridOptionsService.isDomLayout('print');\n }\n listenOnDomOrder(gui) {\n const listener = () => {\n gui.rowComp.setDomOrder(this.getDomOrder());\n };\n this.addManagedPropertyListener('domLayout', listener);\n this.addManagedPropertyListener('ensureDomOrder', listener);\n }\n setAnimateFlags(animateIn) {\n if (this.isSticky() || !animateIn) {\n return;\n }\n const oldRowTopExists = exists(this.rowNode.oldRowTop);\n const pinningLeft = this.beans.columnModel.isPinningLeft();\n const pinningRight = this.beans.columnModel.isPinningRight();\n if (oldRowTopExists) {\n if (this.isFullWidth() && !this.gridOptionsService.is('embedFullWidthRows')) {\n this.slideInAnimation.fullWidth = true;\n return;\n }\n // if the row had a previous position, we slide it in\n this.slideInAnimation.center = true;\n this.slideInAnimation.left = pinningLeft;\n this.slideInAnimation.right = pinningRight;\n }\n else {\n if (this.isFullWidth() && !this.gridOptionsService.is('embedFullWidthRows')) {\n this.fadeInAnimation.fullWidth = true;\n return;\n }\n // if the row had no previous position, we fade it in\n this.fadeInAnimation.center = true;\n this.fadeInAnimation.left = pinningLeft;\n this.fadeInAnimation.right = pinningRight;\n }\n }\n isEditing() {\n return this.editingRow;\n }\n stopRowEditing(cancel) {\n this.stopEditing(cancel);\n }\n isFullWidth() {\n return this.rowType !== RowType.Normal;\n }\n getRowType() {\n return this.rowType;\n }\n refreshFullWidth() {\n // returns 'true' if refresh succeeded\n const tryRefresh = (gui, pinned) => {\n if (!gui) {\n return true;\n } // no refresh needed\n const cellRenderer = gui.rowComp.getFullWidthCellRenderer();\n // no cell renderer, either means comp not yet ready, or comp ready but now reference\n // to it (happens in react when comp is stateless). if comp not ready, we don't need to\n // refresh, however we don't know which one, so we refresh to cover the case where it's\n // react comp without reference so need to force a refresh\n if (!cellRenderer) {\n return false;\n }\n // no refresh method present, so can't refresh, hard refresh needed\n if (!cellRenderer.refresh) {\n return false;\n }\n const params = this.createFullWidthParams(gui.element, pinned);\n const refreshSucceeded = cellRenderer.refresh(params);\n return refreshSucceeded;\n };\n const fullWidthSuccess = tryRefresh(this.fullWidthGui, null);\n const centerSuccess = tryRefresh(this.centerGui, null);\n const leftSuccess = tryRefresh(this.leftGui, 'left');\n const rightSuccess = tryRefresh(this.rightGui, 'right');\n const allFullWidthRowsRefreshed = fullWidthSuccess && centerSuccess && leftSuccess && rightSuccess;\n return allFullWidthRowsRefreshed;\n }\n addListeners() {\n this.addManagedListener(this.rowNode, RowNode.EVENT_HEIGHT_CHANGED, () => this.onRowHeightChanged());\n this.addManagedListener(this.rowNode, RowNode.EVENT_ROW_SELECTED, () => this.onRowSelected());\n this.addManagedListener(this.rowNode, RowNode.EVENT_ROW_INDEX_CHANGED, this.onRowIndexChanged.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_TOP_CHANGED, this.onTopChanged.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_EXPANDED_CHANGED, this.updateExpandedCss.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_HAS_CHILDREN_CHANGED, this.updateExpandedCss.bind(this));\n if (this.rowNode.detail) {\n // if the master row node has updated data, we also want to try to refresh the detail row\n this.addManagedListener(this.rowNode.parent, RowNode.EVENT_DATA_CHANGED, this.onRowNodeDataChanged.bind(this));\n }\n this.addManagedListener(this.rowNode, RowNode.EVENT_DATA_CHANGED, this.onRowNodeDataChanged.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_CELL_CHANGED, this.onRowNodeCellChanged.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_HIGHLIGHT_CHANGED, this.onRowNodeHighlightChanged.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_DRAGGING_CHANGED, this.onRowNodeDraggingChanged.bind(this));\n this.addManagedListener(this.rowNode, RowNode.EVENT_UI_LEVEL_CHANGED, this.onUiLevelChanged.bind(this));\n const eventService = this.beans.eventService;\n this.addManagedListener(eventService, Events.EVENT_PAGINATION_PIXEL_OFFSET_CHANGED, this.onPaginationPixelOffsetChanged.bind(this));\n this.addManagedListener(eventService, Events.EVENT_HEIGHT_SCALE_CHANGED, this.onTopChanged.bind(this));\n this.addManagedListener(eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this));\n this.addManagedListener(eventService, Events.EVENT_VIRTUAL_COLUMNS_CHANGED, this.onVirtualColumnsChanged.bind(this));\n this.addManagedListener(eventService, Events.EVENT_CELL_FOCUSED, this.onCellFocused.bind(this));\n this.addManagedListener(eventService, Events.EVENT_CELL_FOCUS_CLEARED, this.onCellFocusCleared.bind(this));\n this.addManagedListener(eventService, Events.EVENT_PAGINATION_CHANGED, this.onPaginationChanged.bind(this));\n this.addManagedListener(eventService, Events.EVENT_MODEL_UPDATED, this.onModelUpdated.bind(this));\n this.addManagedListener(eventService, Events.EVENT_COLUMN_MOVED, this.onColumnMoved.bind(this));\n this.addListenersForCellComps();\n }\n onColumnMoved() {\n this.updateColumnLists();\n }\n addListenersForCellComps() {\n this.addManagedListener(this.rowNode, RowNode.EVENT_ROW_INDEX_CHANGED, () => {\n this.getAllCellCtrls().forEach(cellCtrl => cellCtrl.onRowIndexChanged());\n });\n this.addManagedListener(this.rowNode, RowNode.EVENT_CELL_CHANGED, event => {\n this.getAllCellCtrls().forEach(cellCtrl => cellCtrl.onCellChanged(event));\n });\n }\n onRowNodeDataChanged(event) {\n // if the row is rendered incorrectly, as the requirements for whether this is a FW row have changed, we force re-render this row.\n const fullWidthChanged = this.isFullWidth() !== !!this.rowNode.isFullWidthCell();\n if (fullWidthChanged) {\n this.beans.rowRenderer.redrawRow(this.rowNode);\n return;\n }\n // this bit of logic handles trying to refresh the FW row ctrl, or delegating to removing/recreating it if unsupported.\n if (this.isFullWidth()) {\n const refresh = this.refreshFullWidth();\n if (!refresh) {\n this.beans.rowRenderer.redrawRow(this.rowNode);\n }\n return;\n }\n // if this is an update, we want to refresh, as this will allow the user to put in a transition\n // into the cellRenderer refresh method. otherwise this might be completely new data, in which case\n // we will want to completely replace the cells\n this.getAllCellCtrls().forEach(cellCtrl => cellCtrl.refreshCell({\n suppressFlash: !event.update,\n newData: !event.update\n }));\n // as data has changed update the dom row id attributes\n this.allRowGuis.forEach(gui => {\n this.setRowCompRowId(gui.rowComp);\n this.updateRowBusinessKey();\n this.setRowCompRowBusinessKey(gui.rowComp);\n });\n // check for selected also, as this could be after lazy loading of the row data, in which case\n // the id might of just gotten set inside the row and the row selected state may of changed\n // as a result. this is what happens when selected rows are loaded in virtual pagination.\n // - niall note - since moving to the stub component, this may no longer be true, as replacing\n // the stub component now replaces the entire row\n this.onRowSelected();\n // as data has changed, then the style and class needs to be recomputed\n this.postProcessCss();\n }\n onRowNodeCellChanged() {\n // as data has changed, then the style and class needs to be recomputed\n this.postProcessCss();\n }\n postProcessCss() {\n this.setStylesFromGridOptions(true);\n this.postProcessClassesFromGridOptions();\n this.postProcessRowClassRules();\n this.postProcessRowDragging();\n }\n onRowNodeHighlightChanged() {\n const highlighted = this.rowNode.highlighted;\n this.allRowGuis.forEach(gui => {\n const aboveOn = highlighted === RowHighlightPosition.Above;\n const belowOn = highlighted === RowHighlightPosition.Below;\n gui.rowComp.addOrRemoveCssClass('ag-row-highlight-above', aboveOn);\n gui.rowComp.addOrRemoveCssClass('ag-row-highlight-below', belowOn);\n });\n }\n onRowNodeDraggingChanged() {\n this.postProcessRowDragging();\n }\n postProcessRowDragging() {\n const dragging = this.rowNode.dragging;\n this.allRowGuis.forEach(gui => gui.rowComp.addOrRemoveCssClass('ag-row-dragging', dragging));\n }\n updateExpandedCss() {\n const expandable = this.rowNode.isExpandable();\n const expanded = this.rowNode.expanded == true;\n this.allRowGuis.forEach(gui => {\n gui.rowComp.addOrRemoveCssClass('ag-row-group', expandable);\n gui.rowComp.addOrRemoveCssClass('ag-row-group-expanded', expandable && expanded);\n gui.rowComp.addOrRemoveCssClass('ag-row-group-contracted', expandable && !expanded);\n setAriaExpanded(gui.element, expandable && expanded);\n });\n }\n onDisplayedColumnsChanged() {\n // we skip animations for onDisplayedColumnChanged, as otherwise the client could remove columns and\n // then set data, and any old valueGetter's (ie from cols that were removed) would still get called.\n this.updateColumnLists(true);\n if (this.beans.columnModel.wasAutoRowHeightEverActive()) {\n this.rowNode.checkAutoHeights();\n }\n }\n onVirtualColumnsChanged() {\n this.updateColumnLists(false, true);\n }\n getRowPosition() {\n return {\n rowPinned: makeNull(this.rowNode.rowPinned),\n rowIndex: this.rowNode.rowIndex\n };\n }\n onKeyboardNavigate(keyboardEvent) {\n const currentFullWidthComp = this.allRowGuis.find(c => c.element.contains(keyboardEvent.target));\n const currentFullWidthContainer = currentFullWidthComp ? currentFullWidthComp.element : null;\n const isFullWidthContainerFocused = currentFullWidthContainer === keyboardEvent.target;\n if (!isFullWidthContainerFocused) {\n return;\n }\n const node = this.rowNode;\n const lastFocusedCell = this.beans.focusService.getFocusedCell();\n const cellPosition = {\n rowIndex: node.rowIndex,\n rowPinned: node.rowPinned,\n column: (lastFocusedCell && lastFocusedCell.column)\n };\n this.beans.navigationService.navigateToNextCell(keyboardEvent, keyboardEvent.key, cellPosition, true);\n keyboardEvent.preventDefault();\n }\n onTabKeyDown(keyboardEvent) {\n if (keyboardEvent.defaultPrevented || isStopPropagationForAgGrid(keyboardEvent)) {\n return;\n }\n const currentFullWidthComp = this.allRowGuis.find(c => c.element.contains(keyboardEvent.target));\n const currentFullWidthContainer = currentFullWidthComp ? currentFullWidthComp.element : null;\n const isFullWidthContainerFocused = currentFullWidthContainer === keyboardEvent.target;\n let nextEl = null;\n if (!isFullWidthContainerFocused) {\n nextEl = this.beans.focusService.findNextFocusableElement(currentFullWidthContainer, false, keyboardEvent.shiftKey);\n }\n if ((this.isFullWidth() && isFullWidthContainerFocused) || !nextEl) {\n this.beans.navigationService.onTabKeyDown(this, keyboardEvent);\n }\n }\n onFullWidthRowFocused(event) {\n var _a;\n const node = this.rowNode;\n const isFocused = !event ? false : this.isFullWidth() && event.rowIndex === node.rowIndex && event.rowPinned == node.rowPinned;\n const element = this.fullWidthGui ? this.fullWidthGui.element : (_a = this.centerGui) === null || _a === void 0 ? void 0 : _a.element;\n if (!element) {\n return;\n } // can happen with react ui, comp not yet ready\n element.classList.toggle('ag-full-width-focus', isFocused);\n if (isFocused) {\n // we don't scroll normal rows into view when we focus them, so we don't want\n // to scroll Full Width rows either.\n element.focus({ preventScroll: true });\n }\n }\n refreshCell(cellCtrl) {\n this.centerCellCtrls = this.removeCellCtrl(this.centerCellCtrls, cellCtrl);\n this.leftCellCtrls = this.removeCellCtrl(this.leftCellCtrls, cellCtrl);\n this.rightCellCtrls = this.removeCellCtrl(this.rightCellCtrls, cellCtrl);\n this.updateColumnLists();\n }\n removeCellCtrl(prev, cellCtrlToRemove) {\n const res = {\n list: [],\n map: {}\n };\n prev.list.forEach(cellCtrl => {\n if (cellCtrl === cellCtrlToRemove) {\n return;\n }\n res.list.push(cellCtrl);\n res.map[cellCtrl.getInstanceId()] = cellCtrl;\n });\n return res;\n }\n onMouseEvent(eventName, mouseEvent) {\n switch (eventName) {\n case 'dblclick':\n this.onRowDblClick(mouseEvent);\n break;\n case 'click':\n this.onRowClick(mouseEvent);\n break;\n case 'touchstart':\n case 'mousedown':\n this.onRowMouseDown(mouseEvent);\n break;\n }\n }\n createRowEvent(type, domEvent) {\n return {\n type: type,\n node: this.rowNode,\n data: this.rowNode.data,\n rowIndex: this.rowNode.rowIndex,\n rowPinned: this.rowNode.rowPinned,\n context: this.gridOptionsService.context,\n api: this.gridOptionsService.api,\n columnApi: this.gridOptionsService.columnApi,\n event: domEvent\n };\n }\n createRowEventWithSource(type, domEvent) {\n const event = this.createRowEvent(type, domEvent);\n // when first developing this, we included the rowComp in the event.\n // this seems very weird. so when introducing the event types, i left the 'source'\n // out of the type, and just include the source in the two places where this event\n // was fired (rowClicked and rowDoubleClicked). it doesn't make sense for any\n // users to be using this, as the rowComp isn't an object we expose, so would be\n // very surprising if a user was using it.\n event.source = this;\n return event;\n }\n onRowDblClick(mouseEvent) {\n if (isStopPropagationForAgGrid(mouseEvent)) {\n return;\n }\n const agEvent = this.createRowEventWithSource(Events.EVENT_ROW_DOUBLE_CLICKED, mouseEvent);\n this.beans.eventService.dispatchEvent(agEvent);\n }\n onRowMouseDown(mouseEvent) {\n this.lastMouseDownOnDragger = isElementChildOfClass(mouseEvent.target, 'ag-row-drag', 3);\n if (!this.isFullWidth()) {\n return;\n }\n const node = this.rowNode;\n const columnModel = this.beans.columnModel;\n if (this.beans.rangeService) {\n this.beans.rangeService.removeAllCellRanges();\n }\n this.beans.focusService.setFocusedCell({\n rowIndex: node.rowIndex,\n column: columnModel.getAllDisplayedColumns()[0],\n rowPinned: node.rowPinned,\n forceBrowserFocus: true\n });\n }\n onRowClick(mouseEvent) {\n const stop = isStopPropagationForAgGrid(mouseEvent) || this.lastMouseDownOnDragger;\n if (stop) {\n return;\n }\n const agEvent = this.createRowEventWithSource(Events.EVENT_ROW_CLICKED, mouseEvent);\n this.beans.eventService.dispatchEvent(agEvent);\n // ctrlKey for windows, metaKey for Apple\n const isMultiKey = mouseEvent.ctrlKey || mouseEvent.metaKey;\n const isShiftKey = mouseEvent.shiftKey;\n // we do not allow selecting the group by clicking, when groupSelectChildren, as the logic to\n // handle this is broken. to observe, change the logic below and allow groups to be selected.\n // you will see the group gets selected, then all children get selected, then the grid unselects\n // the children (as the default behaviour when clicking is to unselect other rows) which results\n // in the group getting unselected (as all children are unselected). the correct thing would be\n // to change this, so that children of the selected group are not then subsequently un-selected.\n const groupSelectsChildren = this.gridOptionsService.is('groupSelectsChildren');\n if (\n // we do not allow selecting groups by clicking (as the click here expands the group), or if it's a detail row,\n // so return if it's a group row\n (groupSelectsChildren && this.rowNode.group) ||\n // this is needed so we don't unselect other rows when we click this row, eg if this row is not selectable,\n // and we click it, the selection should not change (ie any currently selected row should stay selected)\n !this.rowNode.selectable ||\n // we also don't allow selection of pinned rows\n this.rowNode.rowPinned ||\n // if no selection method enabled, do nothing\n !this.gridOptionsService.isRowSelection() ||\n // if click selection suppressed, do nothing\n this.gridOptionsService.is('suppressRowClickSelection')) {\n return;\n }\n const multiSelectOnClick = this.gridOptionsService.is('rowMultiSelectWithClick');\n const rowDeselectionWithCtrl = !this.gridOptionsService.is('suppressRowDeselection');\n const source = 'rowClicked';\n if (this.rowNode.isSelected()) {\n if (multiSelectOnClick) {\n this.rowNode.setSelectedParams({ newValue: false, event: mouseEvent, source });\n }\n else if (isMultiKey) {\n if (rowDeselectionWithCtrl) {\n this.rowNode.setSelectedParams({ newValue: false, event: mouseEvent, source });\n }\n }\n else {\n // selected with no multi key, must make sure anything else is unselected\n this.rowNode.setSelectedParams({ newValue: true, clearSelection: !isShiftKey, rangeSelect: isShiftKey, event: mouseEvent, source });\n }\n }\n else {\n const clearSelection = multiSelectOnClick ? false : !isMultiKey;\n this.rowNode.setSelectedParams({ newValue: true, clearSelection: clearSelection, rangeSelect: isShiftKey, event: mouseEvent, source });\n }\n }\n setupDetailRowAutoHeight(eDetailGui) {\n if (this.rowType !== RowType.FullWidthDetail) {\n return;\n }\n if (!this.gridOptionsService.is('detailRowAutoHeight')) {\n return;\n }\n const checkRowSizeFunc = () => {\n const clientHeight = eDetailGui.clientHeight;\n // if the UI is not ready, the height can be 0, which we ignore, as otherwise a flicker will occur\n // as UI goes from the default height, to 0, then to the real height as UI becomes ready. this means\n // it's not possible for have 0 as auto-height, however this is an improbable use case, as even an\n // empty detail grid would still have some styling around it giving at least a few pixels.\n if (clientHeight != null && clientHeight > 0) {\n // we do the update in a timeout, to make sure we are not calling from inside the grid\n // doing another update\n const updateRowHeightFunc = () => {\n this.rowNode.setRowHeight(clientHeight);\n if (this.beans.clientSideRowModel) {\n this.beans.clientSideRowModel.onRowHeightChanged();\n }\n else if (this.beans.serverSideRowModel) {\n this.beans.serverSideRowModel.onRowHeightChanged();\n }\n };\n this.beans.frameworkOverrides.setTimeout(updateRowHeightFunc, 0);\n }\n };\n const resizeObserverDestroyFunc = this.beans.resizeObserverService.observeResize(eDetailGui, checkRowSizeFunc);\n this.addDestroyFunc(resizeObserverDestroyFunc);\n checkRowSizeFunc();\n }\n createFullWidthParams(eRow, pinned) {\n const params = {\n fullWidth: true,\n data: this.rowNode.data,\n node: this.rowNode,\n value: this.rowNode.key,\n valueFormatted: this.rowNode.key,\n rowIndex: this.rowNode.rowIndex,\n api: this.gridOptionsService.api,\n columnApi: this.gridOptionsService.columnApi,\n context: this.gridOptionsService.context,\n // these need to be taken out, as part of 'afterAttached' now\n eGridCell: eRow,\n eParentOfValue: eRow,\n pinned: pinned,\n addRenderedRowListener: this.addEventListener.bind(this),\n registerRowDragger: (rowDraggerElement, dragStartPixels, value, suppressVisibilityChange) => this.addFullWidthRowDragging(rowDraggerElement, dragStartPixels, value, suppressVisibilityChange)\n };\n return params;\n }\n addFullWidthRowDragging(rowDraggerElement, dragStartPixels, value = '', suppressVisibilityChange) {\n if (!this.isFullWidth()) {\n return;\n }\n const rowDragComp = new RowDragComp(() => value, this.rowNode, undefined, rowDraggerElement, dragStartPixels, suppressVisibilityChange);\n this.createManagedBean(rowDragComp, this.beans.context);\n }\n onUiLevelChanged() {\n const newLevel = this.beans.rowCssClassCalculator.calculateRowLevel(this.rowNode);\n if (this.rowLevel != newLevel) {\n const classToAdd = 'ag-row-level-' + newLevel;\n const classToRemove = 'ag-row-level-' + this.rowLevel;\n this.allRowGuis.forEach(gui => {\n gui.rowComp.addOrRemoveCssClass(classToAdd, true);\n gui.rowComp.addOrRemoveCssClass(classToRemove, false);\n });\n }\n this.rowLevel = newLevel;\n }\n isFirstRowOnPage() {\n return this.rowNode.rowIndex === this.beans.paginationProxy.getPageFirstRow();\n }\n isLastRowOnPage() {\n return this.rowNode.rowIndex === this.beans.paginationProxy.getPageLastRow();\n }\n onModelUpdated() {\n this.refreshFirstAndLastRowStyles();\n }\n refreshFirstAndLastRowStyles() {\n const newFirst = this.isFirstRowOnPage();\n const newLast = this.isLastRowOnPage();\n if (this.firstRowOnPage !== newFirst) {\n this.firstRowOnPage = newFirst;\n this.allRowGuis.forEach(gui => gui.rowComp.addOrRemoveCssClass('ag-row-first', newFirst));\n }\n if (this.lastRowOnPage !== newLast) {\n this.lastRowOnPage = newLast;\n this.allRowGuis.forEach(gui => gui.rowComp.addOrRemoveCssClass('ag-row-last', newLast));\n }\n }\n stopEditing(cancel = false) {\n // if we are already stopping row edit, there is\n // no need to start this process again.\n if (this.stoppingRowEdit) {\n return;\n }\n const cellControls = this.getAllCellCtrls();\n const isRowEdit = this.editingRow;\n this.stoppingRowEdit = true;\n let fireRowEditEvent = false;\n for (const ctrl of cellControls) {\n const valueChanged = ctrl.stopEditing(cancel);\n if (isRowEdit && !cancel && !fireRowEditEvent && valueChanged) {\n fireRowEditEvent = true;\n }\n }\n if (fireRowEditEvent) {\n const event = this.createRowEvent(Events.EVENT_ROW_VALUE_CHANGED);\n this.beans.eventService.dispatchEvent(event);\n }\n if (isRowEdit) {\n this.setEditingRow(false);\n }\n this.stoppingRowEdit = false;\n }\n setInlineEditingCss(editing) {\n this.allRowGuis.forEach(gui => {\n gui.rowComp.addOrRemoveCssClass(\"ag-row-inline-editing\", editing);\n gui.rowComp.addOrRemoveCssClass(\"ag-row-not-inline-editing\", !editing);\n });\n }\n setEditingRow(value) {\n this.editingRow = value;\n this.allRowGuis.forEach(gui => gui.rowComp.addOrRemoveCssClass('ag-row-editing', value));\n const event = value ?\n this.createRowEvent(Events.EVENT_ROW_EDITING_STARTED)\n : this.createRowEvent(Events.EVENT_ROW_EDITING_STOPPED);\n this.beans.eventService.dispatchEvent(event);\n }\n startRowEditing(key = null, sourceRenderedCell = null, event = null) {\n // don't do it if already editing\n if (this.editingRow) {\n return;\n }\n const atLeastOneEditing = this.getAllCellCtrls().reduce((prev, cellCtrl) => {\n const cellStartedEdit = cellCtrl === sourceRenderedCell;\n if (cellStartedEdit) {\n cellCtrl.startEditing(key, cellStartedEdit, event);\n }\n else {\n cellCtrl.startEditing(null, cellStartedEdit, event);\n }\n if (prev) {\n return true;\n }\n return cellCtrl.isEditing();\n }, false);\n if (atLeastOneEditing) {\n this.setEditingRow(true);\n }\n }\n getAllCellCtrls() {\n if (this.leftCellCtrls.list.length === 0 && this.rightCellCtrls.list.length === 0) {\n return this.centerCellCtrls.list;\n }\n const res = [...this.centerCellCtrls.list, ...this.leftCellCtrls.list, ...this.rightCellCtrls.list];\n return res;\n }\n postProcessClassesFromGridOptions() {\n const cssClasses = this.beans.rowCssClassCalculator.processClassesFromGridOptions(this.rowNode);\n if (!cssClasses || !cssClasses.length) {\n return;\n }\n cssClasses.forEach(classStr => {\n this.allRowGuis.forEach(c => c.rowComp.addOrRemoveCssClass(classStr, true));\n });\n }\n postProcessRowClassRules() {\n this.beans.rowCssClassCalculator.processRowClassRules(this.rowNode, (className) => {\n this.allRowGuis.forEach(gui => gui.rowComp.addOrRemoveCssClass(className, true));\n }, (className) => {\n this.allRowGuis.forEach(gui => gui.rowComp.addOrRemoveCssClass(className, false));\n });\n }\n setStylesFromGridOptions(updateStyles, gui) {\n if (updateStyles) {\n this.rowStyles = this.processStylesFromGridOptions();\n }\n this.forEachGui(gui, gui => gui.rowComp.setUserStyles(this.rowStyles));\n }\n getPinnedForContainer(rowContainerType) {\n const pinned = rowContainerType === RowContainerType.LEFT\n ? 'left'\n : rowContainerType === RowContainerType.RIGHT\n ? 'right'\n : null;\n return pinned;\n }\n getInitialRowClasses(rowContainerType) {\n const pinned = this.getPinnedForContainer(rowContainerType);\n const params = {\n rowNode: this.rowNode,\n rowFocused: this.rowFocused,\n fadeRowIn: this.fadeInAnimation[rowContainerType],\n rowIsEven: this.rowNode.rowIndex % 2 === 0,\n rowLevel: this.rowLevel,\n fullWidthRow: this.isFullWidth(),\n firstRowOnPage: this.isFirstRowOnPage(),\n lastRowOnPage: this.isLastRowOnPage(),\n printLayout: this.printLayout,\n expandable: this.rowNode.isExpandable(),\n pinned: pinned\n };\n return this.beans.rowCssClassCalculator.getInitialRowClasses(params);\n }\n processStylesFromGridOptions() {\n // part 1 - rowStyle\n const rowStyle = this.gridOptionsService.get('rowStyle');\n if (rowStyle && typeof rowStyle === 'function') {\n console.warn('AG Grid: rowStyle should be an object of key/value styles, not be a function, use getRowStyle() instead');\n return;\n }\n // part 1 - rowStyleFunc\n const rowStyleFunc = this.gridOptionsService.getCallback('getRowStyle');\n let rowStyleFuncResult;\n if (rowStyleFunc) {\n const params = {\n data: this.rowNode.data,\n node: this.rowNode,\n rowIndex: this.rowNode.rowIndex\n };\n rowStyleFuncResult = rowStyleFunc(params);\n }\n if (rowStyleFuncResult || rowStyle) {\n return Object.assign({}, rowStyle, rowStyleFuncResult);\n }\n // Return constant reference for React\n return this.emptyStyle;\n }\n onRowSelected(gui) {\n // Treat undefined as false, if we pass undefined down it gets treated as toggle class, rather than explicitly\n // setting the required value\n const selected = !!this.rowNode.isSelected();\n this.forEachGui(gui, gui => {\n gui.rowComp.addOrRemoveCssClass('ag-row-selected', selected);\n setAriaSelected(gui.element, selected ? true : undefined);\n const ariaLabel = this.createAriaLabel();\n setAriaLabel(gui.element, ariaLabel == null ? '' : ariaLabel);\n });\n }\n createAriaLabel() {\n const selected = this.rowNode.isSelected();\n if (selected && this.gridOptionsService.is('suppressRowDeselection')) {\n return undefined;\n }\n const translate = this.beans.localeService.getLocaleTextFunc();\n const label = translate(selected ? 'ariaRowDeselect' : 'ariaRowSelect', `Press SPACE to ${selected ? 'deselect' : 'select'} this row.`);\n return label;\n }\n isUseAnimationFrameForCreate() {\n return this.useAnimationFrameForCreate;\n }\n addHoverFunctionality(eRow) {\n // because we use animation frames to do this, it's possible the row no longer exists\n // by the time we get to add it\n if (!this.active) {\n return;\n }\n // because mouseenter and mouseleave do not propagate, we cannot listen on the gridPanel\n // like we do for all the other mouse events.\n // because of the pinning, we cannot simply add / remove the class based on the eRow. we\n // have to check all eRow's (body & pinned). so the trick is if any of the rows gets a\n // mouse hover, it sets such in the rowNode, and then all three reflect the change as\n // all are listening for event on the row node.\n // step 1 - add listener, to set flag on row node\n this.addManagedListener(eRow, 'mouseenter', () => this.rowNode.onMouseEnter());\n this.addManagedListener(eRow, 'mouseleave', () => this.rowNode.onMouseLeave());\n // step 2 - listen for changes on row node (which any eRow can trigger)\n this.addManagedListener(this.rowNode, RowNode.EVENT_MOUSE_ENTER, () => {\n // if hover turned off, we don't add the class. we do this here so that if the application\n // toggles this property mid way, we remove the hover form the last row, but we stop\n // adding hovers from that point onwards. Also, do not highlight while dragging elements around.\n if (!this.beans.dragService.isDragging() &&\n !this.gridOptionsService.is('suppressRowHoverHighlight')) {\n eRow.classList.add('ag-row-hover');\n this.rowNode.setHovered(true);\n }\n });\n this.addManagedListener(this.rowNode, RowNode.EVENT_MOUSE_LEAVE, () => {\n eRow.classList.remove('ag-row-hover');\n this.rowNode.setHovered(false);\n });\n }\n // for animation, we don't want to animate entry or exit to a very far away pixel,\n // otherwise the row would move so fast, it would appear to disappear. so this method\n // moves the row closer to the viewport if it is far away, so the row slide in / out\n // at a speed the user can see.\n roundRowTopToBounds(rowTop) {\n const gridBodyCon = this.beans.ctrlsService.getGridBodyCtrl();\n const range = gridBodyCon.getScrollFeature().getVScrollPosition();\n const minPixel = this.applyPaginationOffset(range.top, true) - 100;\n const maxPixel = this.applyPaginationOffset(range.bottom, true) + 100;\n return Math.min(Math.max(minPixel, rowTop), maxPixel);\n }\n getFrameworkOverrides() {\n return this.beans.frameworkOverrides;\n }\n forEachGui(gui, callback) {\n if (gui) {\n callback(gui);\n }\n else {\n this.allRowGuis.forEach(callback);\n }\n }\n onRowHeightChanged(gui) {\n // check for exists first - if the user is resetting the row height, then\n // it will be null (or undefined) momentarily until the next time the flatten\n // stage is called where the row will then update again with a new height\n if (this.rowNode.rowHeight == null) {\n return;\n }\n const rowHeight = this.rowNode.rowHeight;\n const defaultRowHeight = this.beans.environment.getDefaultRowHeight();\n const isHeightFromFunc = this.gridOptionsService.isGetRowHeightFunction();\n const heightFromFunc = isHeightFromFunc ? this.gridOptionsService.getRowHeightForNode(this.rowNode).height : undefined;\n const lineHeight = heightFromFunc ? `${Math.min(defaultRowHeight, heightFromFunc) - 2}px` : undefined;\n this.forEachGui(gui, gui => {\n gui.element.style.height = `${rowHeight}px`;\n // If the row height is coming from a function, this means some rows can\n // be smaller than the theme had intended. so we set --ag-line-height on\n // the row, which is picked up by the theme CSS and is used in a calc\n // for the CSS line-height property, which makes sure the line-height is\n // not bigger than the row height, otherwise the row text would not fit.\n // We do not use rowNode.rowHeight here, as this could be the result of autoHeight,\n // and we found using the autoHeight result causes a loop, where changing the\n // line-height them impacts the cell height, resulting in a new autoHeight,\n // resulting in a new line-height and so on loop.\n // const heightFromFunc = this.gridOptionsService.getRowHeightForNode(this.rowNode).height;\n if (lineHeight) {\n gui.element.style.setProperty('--ag-line-height', lineHeight);\n }\n });\n }\n addEventListener(eventType, listener) {\n super.addEventListener(eventType, listener);\n }\n removeEventListener(eventType, listener) {\n super.removeEventListener(eventType, listener);\n }\n // note - this is NOT called by context, as we don't wire / unwire the CellComp for performance reasons.\n destroyFirstPass() {\n this.active = false;\n // why do we have this method? shouldn't everything below be added as a destroy func beside\n // the corresponding create logic?\n if (this.gridOptionsService.isAnimateRows()) {\n this.setupRemoveAnimation();\n }\n this.rowNode.setHovered(false);\n const event = this.createRowEvent(Events.EVENT_VIRTUAL_ROW_REMOVED);\n this.dispatchEvent(event);\n this.beans.eventService.dispatchEvent(event);\n super.destroy();\n }\n setupRemoveAnimation() {\n // we don't animate sticky rows\n if (this.isSticky()) {\n return;\n }\n const rowStillVisibleJustNotInViewport = this.rowNode.rowTop != null;\n if (rowStillVisibleJustNotInViewport) {\n // if the row is not rendered, but in viewport, it means it has moved,\n // so we animate the row out. if the new location is very far away,\n // the animation will be so fast the row will look like it's just disappeared,\n // so instead we animate to a position just outside the viewport.\n const rowTop = this.roundRowTopToBounds(this.rowNode.rowTop);\n this.setRowTop(rowTop);\n }\n else {\n this.allRowGuis.forEach(gui => gui.rowComp.addOrRemoveCssClass('ag-opacity-zero', true));\n }\n }\n destroySecondPass() {\n this.allRowGuis.length = 0;\n const destroyCellCtrls = (ctrls) => {\n ctrls.list.forEach(c => c.destroy());\n return { list: [], map: {} };\n };\n this.centerCellCtrls = destroyCellCtrls(this.centerCellCtrls);\n this.leftCellCtrls = destroyCellCtrls(this.leftCellCtrls);\n this.rightCellCtrls = destroyCellCtrls(this.rightCellCtrls);\n }\n setFocusedClasses(gui) {\n this.forEachGui(gui, gui => {\n gui.rowComp.addOrRemoveCssClass('ag-row-focus', this.rowFocused);\n gui.rowComp.addOrRemoveCssClass('ag-row-no-focus', !this.rowFocused);\n });\n }\n onCellFocused() {\n this.onCellFocusChanged();\n }\n onCellFocusCleared() {\n this.onCellFocusChanged();\n }\n onCellFocusChanged() {\n const rowFocused = this.beans.focusService.isRowFocused(this.rowNode.rowIndex, this.rowNode.rowPinned);\n if (rowFocused !== this.rowFocused) {\n this.rowFocused = rowFocused;\n this.setFocusedClasses();\n }\n // if we are editing, then moving the focus out of a row will stop editing\n if (!rowFocused && this.editingRow) {\n this.stopEditing(false);\n }\n }\n onPaginationChanged() {\n const currentPage = this.beans.paginationProxy.getCurrentPage();\n // it is possible this row is in the new page, but the page number has changed, which means\n // it needs to reposition itself relative to the new page\n if (this.paginationPage !== currentPage) {\n this.paginationPage = currentPage;\n this.onTopChanged();\n }\n this.refreshFirstAndLastRowStyles();\n }\n onTopChanged() {\n this.setRowTop(this.rowNode.rowTop);\n }\n onPaginationPixelOffsetChanged() {\n // the pixel offset is used when calculating rowTop to set on the row DIV\n this.onTopChanged();\n }\n // applies pagination offset, eg if on second page, and page height is 500px, then removes\n // 500px from the top position, so a row with rowTop 600px is displayed at location 100px.\n // reverse will take the offset away rather than add.\n applyPaginationOffset(topPx, reverse = false) {\n if (this.rowNode.isRowPinned() || this.rowNode.sticky) {\n return topPx;\n }\n const pixelOffset = this.beans.paginationProxy.getPixelOffset();\n const multiplier = reverse ? 1 : -1;\n return topPx + (pixelOffset * multiplier);\n }\n setRowTop(pixels) {\n // print layout uses normal flow layout for row positioning\n if (this.printLayout) {\n return;\n }\n // need to make sure rowTop is not null, as this can happen if the node was once\n // visible (ie parent group was expanded) but is now not visible\n if (exists(pixels)) {\n const afterPaginationPixels = this.applyPaginationOffset(pixels);\n const skipScaling = this.rowNode.isRowPinned() || this.rowNode.sticky;\n const afterScalingPixels = skipScaling ? afterPaginationPixels : this.beans.rowContainerHeightService.getRealPixelPosition(afterPaginationPixels);\n const topPx = `${afterScalingPixels}px`;\n this.setRowTopStyle(topPx);\n }\n }\n // the top needs to be set into the DOM element when the element is created, not updated afterwards.\n // otherwise the transition would not work, as it would be transitioning from zero (the unset value).\n // for example, suppose a row that is outside the viewport, then user does a filter to remove other rows\n // and this row now appears in the viewport, and the row moves up (ie it was under the viewport and not rendered,\n // but now is in the viewport) then a new RowComp is created, however it should have it's position initialised\n // to below the viewport, so the row will appear to animate up. if we didn't set the initial position at creation\n // time, the row would animate down (ie from position zero).\n getInitialRowTop(rowContainerType) {\n const suppressRowTransform = this.gridOptionsService.is('suppressRowTransform');\n return suppressRowTransform ? this.getInitialRowTopShared(rowContainerType) : undefined;\n }\n getInitialTransform(rowContainerType) {\n const suppressRowTransform = this.gridOptionsService.is('suppressRowTransform');\n return suppressRowTransform ? undefined : `translateY(${this.getInitialRowTopShared(rowContainerType)})`;\n }\n getInitialRowTopShared(rowContainerType) {\n // print layout uses normal flow layout for row positioning\n if (this.printLayout) {\n return '';\n }\n let rowTop;\n if (this.isSticky()) {\n rowTop = this.rowNode.stickyRowTop;\n }\n else {\n // if sliding in, we take the old row top. otherwise we just set the current row top.\n const pixels = this.slideInAnimation[rowContainerType] ? this.roundRowTopToBounds(this.rowNode.oldRowTop) : this.rowNode.rowTop;\n const afterPaginationPixels = this.applyPaginationOffset(pixels);\n // we don't apply scaling if row is pinned\n rowTop = this.rowNode.isRowPinned() ? afterPaginationPixels : this.beans.rowContainerHeightService.getRealPixelPosition(afterPaginationPixels);\n }\n return rowTop + 'px';\n }\n setRowTopStyle(topPx) {\n const suppressRowTransform = this.gridOptionsService.is('suppressRowTransform');\n this.allRowGuis.forEach(gui => suppressRowTransform ?\n gui.rowComp.setTop(topPx) :\n gui.rowComp.setTransform(`translateY(${topPx})`));\n }\n getRowNode() {\n return this.rowNode;\n }\n getCellCtrl(column) {\n // first up, check for cell directly linked to this column\n let res = null;\n this.getAllCellCtrls().forEach(cellCtrl => {\n if (cellCtrl.getColumn() == column) {\n res = cellCtrl;\n }\n });\n if (res != null) {\n return res;\n }\n // second up, if not found, then check for spanned cols.\n // we do this second (and not at the same time) as this is\n // more expensive, as spanning cols is a\n // infrequently used feature so we don't need to do this most\n // of the time\n this.getAllCellCtrls().forEach(cellCtrl => {\n if (cellCtrl.getColSpanningList().indexOf(column) >= 0) {\n res = cellCtrl;\n }\n });\n return res;\n }\n onRowIndexChanged() {\n // we only bother updating if the rowIndex is present. if it is not present, it means this row\n // is child of a group node, and the group node was closed, it's the only way to have no row index.\n // when this happens, row is about to be de-rendered, so we don't care, rowComp is about to die!\n if (this.rowNode.rowIndex != null) {\n this.onCellFocusChanged();\n this.updateRowIndexes();\n this.postProcessCss();\n }\n }\n getRowIndex() {\n return this.rowNode.getRowIndexString();\n }\n updateRowIndexes(gui) {\n const rowIndexStr = this.rowNode.getRowIndexString();\n const headerRowCount = this.beans.headerNavigationService.getHeaderRowCount() + this.beans.filterManager.getHeaderRowCount();\n const rowIsEven = this.rowNode.rowIndex % 2 === 0;\n const ariaRowIndex = headerRowCount + this.rowNode.rowIndex + 1;\n this.forEachGui(gui, c => {\n c.rowComp.setRowIndex(rowIndexStr);\n c.rowComp.addOrRemoveCssClass('ag-row-even', rowIsEven);\n c.rowComp.addOrRemoveCssClass('ag-row-odd', !rowIsEven);\n setAriaRowIndex(c.element, ariaRowIndex);\n });\n }\n // returns the pinned left container, either the normal one, or the embedded full with one if exists\n getPinnedLeftRowElement() {\n return this.leftGui ? this.leftGui.element : undefined;\n }\n // returns the pinned right container, either the normal one, or the embedded full with one if exists\n getPinnedRightRowElement() {\n return this.rightGui ? this.rightGui.element : undefined;\n }\n // returns the body container, either the normal one, or the embedded full with one if exists\n getBodyRowElement() {\n return this.centerGui ? this.centerGui.element : undefined;\n }\n // returns the full width container\n getFullWidthRowElement() {\n return this.fullWidthGui ? this.fullWidthGui.element : undefined;\n }\n}\nRowCtrl.DOM_DATA_KEY_ROW_CTRL = 'renderedRow';\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nimport { getCtrlForEventTarget, isStopPropagationForAgGrid, isEventSupported } from \"../../utils/event.mjs\";\nimport { Autowired, Optional, PostConstruct } from \"../../context/context.mjs\";\nimport { RowCtrl } from \"../../rendering/row/rowCtrl.mjs\";\nimport { isIOSUserAgent } from \"../../utils/browser.mjs\";\nimport { TouchListener } from \"../../widgets/touchListener.mjs\";\nimport { isEventFromPrintableCharacter, isUserSuppressingKeyboardEvent } from \"../../utils/keyboard.mjs\";\nimport { Events } from \"../../events.mjs\";\nimport { KeyCode } from \"../../constants/keyCode.mjs\";\nimport { missingOrEmpty } from \"../../utils/generic.mjs\";\nimport { last } from \"../../utils/array.mjs\";\nimport { normaliseQwertyAzerty } from \"../../utils/keyboard.mjs\";\nimport { CellCtrl } from \"../../rendering/cell/cellCtrl.mjs\";\nexport class RowContainerEventsFeature extends BeanStub {\n constructor(element) {\n super();\n this.element = element;\n }\n postConstruct() {\n this.addKeyboardListeners();\n this.addMouseListeners();\n this.mockContextMenuForIPad();\n }\n addKeyboardListeners() {\n const eventName = 'keydown';\n const listener = this.processKeyboardEvent.bind(this, eventName);\n this.addManagedListener(this.element, eventName, listener);\n }\n addMouseListeners() {\n const mouseDownEvent = isEventSupported('touchstart') ? 'touchstart' : 'mousedown';\n const eventNames = ['dblclick', 'contextmenu', 'mouseover', 'mouseout', 'click', mouseDownEvent];\n eventNames.forEach(eventName => {\n const listener = this.processMouseEvent.bind(this, eventName);\n this.addManagedListener(this.element, eventName, listener);\n });\n }\n processMouseEvent(eventName, mouseEvent) {\n if (!this.mouseEventService.isEventFromThisGrid(mouseEvent) ||\n isStopPropagationForAgGrid(mouseEvent)) {\n return;\n }\n const rowComp = this.getRowForEvent(mouseEvent);\n const cellCtrl = this.mouseEventService.getRenderedCellForEvent(mouseEvent);\n if (eventName === \"contextmenu\") {\n this.handleContextMenuMouseEvent(mouseEvent, null, rowComp, cellCtrl);\n }\n else {\n if (cellCtrl) {\n cellCtrl.onMouseEvent(eventName, mouseEvent);\n }\n if (rowComp) {\n rowComp.onMouseEvent(eventName, mouseEvent);\n }\n }\n }\n mockContextMenuForIPad() {\n // we do NOT want this when not in iPad, otherwise we will be doing\n if (!isIOSUserAgent()) {\n return;\n }\n const touchListener = new TouchListener(this.element);\n const longTapListener = (event) => {\n const rowComp = this.getRowForEvent(event.touchEvent);\n const cellComp = this.mouseEventService.getRenderedCellForEvent(event.touchEvent);\n this.handleContextMenuMouseEvent(null, event.touchEvent, rowComp, cellComp);\n };\n this.addManagedListener(touchListener, TouchListener.EVENT_LONG_TAP, longTapListener);\n this.addDestroyFunc(() => touchListener.destroy());\n }\n getRowForEvent(event) {\n let sourceElement = event.target;\n while (sourceElement) {\n const rowCon = this.gridOptionsService.getDomData(sourceElement, RowCtrl.DOM_DATA_KEY_ROW_CTRL);\n if (rowCon) {\n return rowCon;\n }\n sourceElement = sourceElement.parentElement;\n }\n return null;\n }\n handleContextMenuMouseEvent(mouseEvent, touchEvent, rowComp, cellCtrl) {\n const rowNode = rowComp ? rowComp.getRowNode() : null;\n const column = cellCtrl ? cellCtrl.getColumn() : null;\n let value = null;\n if (column) {\n const event = mouseEvent ? mouseEvent : touchEvent;\n cellCtrl.dispatchCellContextMenuEvent(event);\n value = this.valueService.getValue(column, rowNode);\n }\n // if user clicked on a cell, anchor to that cell, otherwise anchor to the grid panel\n const gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n const anchorToElement = cellCtrl ? cellCtrl.getGui() : gridBodyCon.getGridBodyElement();\n if (this.contextMenuFactory) {\n this.contextMenuFactory.onContextMenu(mouseEvent, touchEvent, rowNode, column, value, anchorToElement);\n }\n }\n getControlsForEventTarget(target) {\n return {\n cellCtrl: getCtrlForEventTarget(this.gridOptionsService, target, CellCtrl.DOM_DATA_KEY_CELL_CTRL),\n rowCtrl: getCtrlForEventTarget(this.gridOptionsService, target, RowCtrl.DOM_DATA_KEY_ROW_CTRL)\n };\n }\n processKeyboardEvent(eventName, keyboardEvent) {\n const { cellCtrl, rowCtrl } = this.getControlsForEventTarget(keyboardEvent.target);\n if (keyboardEvent.defaultPrevented) {\n return;\n }\n if (cellCtrl) {\n this.processCellKeyboardEvent(cellCtrl, eventName, keyboardEvent);\n }\n else if (rowCtrl && rowCtrl.isFullWidth()) {\n this.processFullWidthRowKeyboardEvent(rowCtrl, eventName, keyboardEvent);\n }\n }\n processCellKeyboardEvent(cellCtrl, eventName, keyboardEvent) {\n const rowNode = cellCtrl.getRowNode();\n const column = cellCtrl.getColumn();\n const editing = cellCtrl.isEditing();\n const gridProcessingAllowed = !isUserSuppressingKeyboardEvent(this.gridOptionsService, keyboardEvent, rowNode, column, editing);\n if (gridProcessingAllowed) {\n if (eventName === 'keydown') {\n // first see if it's a scroll key, page up / down, home / end etc\n const wasScrollKey = !editing && this.navigationService.handlePageScrollingKey(keyboardEvent);\n // if not a scroll key, then we pass onto cell\n if (!wasScrollKey) {\n cellCtrl.onKeyDown(keyboardEvent);\n }\n // perform clipboard and undo / redo operations\n this.doGridOperations(keyboardEvent, cellCtrl.isEditing());\n if (isEventFromPrintableCharacter(keyboardEvent)) {\n cellCtrl.processCharacter(keyboardEvent);\n }\n }\n }\n if (eventName === 'keydown') {\n const cellKeyDownEvent = cellCtrl.createEvent(keyboardEvent, Events.EVENT_CELL_KEY_DOWN);\n this.eventService.dispatchEvent(cellKeyDownEvent);\n }\n }\n processFullWidthRowKeyboardEvent(rowComp, eventName, keyboardEvent) {\n const rowNode = rowComp.getRowNode();\n const focusedCell = this.focusService.getFocusedCell();\n const column = (focusedCell && focusedCell.column);\n const gridProcessingAllowed = !isUserSuppressingKeyboardEvent(this.gridOptionsService, keyboardEvent, rowNode, column, false);\n if (gridProcessingAllowed) {\n const key = keyboardEvent.key;\n if (eventName === 'keydown') {\n switch (key) {\n case KeyCode.PAGE_HOME:\n case KeyCode.PAGE_END:\n case KeyCode.PAGE_UP:\n case KeyCode.PAGE_DOWN:\n this.navigationService.handlePageScrollingKey(keyboardEvent, true);\n break;\n case KeyCode.UP:\n case KeyCode.DOWN:\n rowComp.onKeyboardNavigate(keyboardEvent);\n break;\n case KeyCode.TAB:\n rowComp.onTabKeyDown(keyboardEvent);\n break;\n default:\n }\n }\n }\n if (eventName === 'keydown') {\n const cellKeyDownEvent = rowComp.createRowEvent(Events.EVENT_CELL_KEY_DOWN, keyboardEvent);\n this.eventService.dispatchEvent(cellKeyDownEvent);\n }\n }\n doGridOperations(keyboardEvent, editing) {\n // check if ctrl or meta key pressed\n if (!keyboardEvent.ctrlKey && !keyboardEvent.metaKey) {\n return;\n }\n // if the cell the event came from is editing, then we do not\n // want to do the default shortcut keys, otherwise the editor\n // (eg a text field) would not be able to do the normal cut/copy/paste\n if (editing) {\n return;\n }\n // for copy / paste, we don't want to execute when the event\n // was from a child grid (happens in master detail)\n if (!this.mouseEventService.isEventFromThisGrid(keyboardEvent)) {\n return;\n }\n const keyCode = normaliseQwertyAzerty(keyboardEvent);\n if (keyCode === KeyCode.A) {\n return this.onCtrlAndA(keyboardEvent);\n }\n if (keyCode === KeyCode.C) {\n return this.onCtrlAndC(keyboardEvent);\n }\n if (keyCode === KeyCode.D) {\n return this.onCtrlAndD(keyboardEvent);\n }\n if (keyCode === KeyCode.V) {\n return this.onCtrlAndV(keyboardEvent);\n }\n if (keyCode === KeyCode.X) {\n return this.onCtrlAndX(keyboardEvent);\n }\n if (keyCode === KeyCode.Y) {\n return this.onCtrlAndY();\n }\n if (keyCode === KeyCode.Z) {\n return this.onCtrlAndZ(keyboardEvent);\n }\n }\n onCtrlAndA(event) {\n const { pinnedRowModel, paginationProxy, rangeService } = this;\n if (rangeService && paginationProxy.isRowsToRender()) {\n const [isEmptyPinnedTop, isEmptyPinnedBottom] = [\n pinnedRowModel.isEmpty('top'),\n pinnedRowModel.isEmpty('bottom')\n ];\n const floatingStart = isEmptyPinnedTop ? null : 'top';\n let floatingEnd;\n let rowEnd;\n if (isEmptyPinnedBottom) {\n floatingEnd = null;\n rowEnd = this.paginationProxy.getRowCount() - 1;\n }\n else {\n floatingEnd = 'bottom';\n rowEnd = pinnedRowModel.getPinnedBottomRowData().length - 1;\n }\n const allDisplayedColumns = this.columnModel.getAllDisplayedColumns();\n if (missingOrEmpty(allDisplayedColumns)) {\n return;\n }\n rangeService.setCellRange({\n rowStartIndex: 0,\n rowStartPinned: floatingStart,\n rowEndIndex: rowEnd,\n rowEndPinned: floatingEnd,\n columnStart: allDisplayedColumns[0],\n columnEnd: last(allDisplayedColumns)\n });\n }\n event.preventDefault();\n }\n onCtrlAndC(event) {\n if (!this.clipboardService || this.gridOptionsService.is('enableCellTextSelection')) {\n return;\n }\n const { cellCtrl, rowCtrl } = this.getControlsForEventTarget(event.target);\n if ((cellCtrl === null || cellCtrl === void 0 ? void 0 : cellCtrl.isEditing()) || (rowCtrl === null || rowCtrl === void 0 ? void 0 : rowCtrl.isEditing())) {\n return;\n }\n event.preventDefault();\n this.clipboardService.copyToClipboard();\n }\n onCtrlAndX(event) {\n if (!this.clipboardService ||\n this.gridOptionsService.is('enableCellTextSelection') ||\n this.gridOptionsService.is('suppressCutToClipboard')) {\n return;\n }\n const { cellCtrl, rowCtrl } = this.getControlsForEventTarget(event.target);\n if ((cellCtrl === null || cellCtrl === void 0 ? void 0 : cellCtrl.isEditing()) || (rowCtrl === null || rowCtrl === void 0 ? void 0 : rowCtrl.isEditing())) {\n return;\n }\n event.preventDefault();\n this.clipboardService.cutToClipboard(undefined, 'ui');\n }\n onCtrlAndV(event) {\n const { cellCtrl, rowCtrl } = this.getControlsForEventTarget(event.target);\n if ((cellCtrl === null || cellCtrl === void 0 ? void 0 : cellCtrl.isEditing()) || (rowCtrl === null || rowCtrl === void 0 ? void 0 : rowCtrl.isEditing())) {\n return;\n }\n if (this.clipboardService && !this.gridOptionsService.is('suppressClipboardPaste')) {\n this.clipboardService.pasteFromClipboard();\n }\n }\n onCtrlAndD(event) {\n if (this.clipboardService && !this.gridOptionsService.is('suppressClipboardPaste')) {\n this.clipboardService.copyRangeDown();\n }\n event.preventDefault();\n }\n onCtrlAndZ(event) {\n if (!this.gridOptionsService.is('undoRedoCellEditing')) {\n return;\n }\n event.preventDefault();\n if (event.shiftKey) {\n this.undoRedoService.redo('ui');\n }\n else {\n this.undoRedoService.undo('ui');\n }\n }\n onCtrlAndY() {\n this.undoRedoService.redo('ui');\n }\n}\n__decorate([\n Autowired('mouseEventService')\n], RowContainerEventsFeature.prototype, \"mouseEventService\", void 0);\n__decorate([\n Autowired('valueService')\n], RowContainerEventsFeature.prototype, \"valueService\", void 0);\n__decorate([\n Optional('contextMenuFactory')\n], RowContainerEventsFeature.prototype, \"contextMenuFactory\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], RowContainerEventsFeature.prototype, \"ctrlsService\", void 0);\n__decorate([\n Autowired('navigationService')\n], RowContainerEventsFeature.prototype, \"navigationService\", void 0);\n__decorate([\n Autowired('focusService')\n], RowContainerEventsFeature.prototype, \"focusService\", void 0);\n__decorate([\n Autowired('undoRedoService')\n], RowContainerEventsFeature.prototype, \"undoRedoService\", void 0);\n__decorate([\n Autowired('columnModel')\n], RowContainerEventsFeature.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('paginationProxy')\n], RowContainerEventsFeature.prototype, \"paginationProxy\", void 0);\n__decorate([\n Autowired('pinnedRowModel')\n], RowContainerEventsFeature.prototype, \"pinnedRowModel\", void 0);\n__decorate([\n Optional('rangeService')\n], RowContainerEventsFeature.prototype, \"rangeService\", void 0);\n__decorate([\n Optional('clipboardService')\n], RowContainerEventsFeature.prototype, \"clipboardService\", void 0);\n__decorate([\n PostConstruct\n], RowContainerEventsFeature.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { Autowired, PostConstruct } from \"../context/context.mjs\";\nimport { Events } from \"../events.mjs\";\nimport { getInnerHeight } from \"../utils/dom.mjs\";\n// listens to changes in the center viewport size, for column and row virtualisation,\n// and adjusts grid as necessary. there are two viewports, one for horizontal and one for\n// vertical scrolling.\nexport class ViewportSizeFeature extends BeanStub {\n constructor(centerContainerCtrl) {\n super();\n this.centerContainerCtrl = centerContainerCtrl;\n }\n postConstruct() {\n this.ctrlsService.whenReady(() => {\n this.gridBodyCtrl = this.ctrlsService.getGridBodyCtrl();\n this.listenForResize();\n });\n this.addManagedListener(this.eventService, Events.EVENT_SCROLLBAR_WIDTH_CHANGED, this.onScrollbarWidthChanged.bind(this));\n }\n listenForResize() {\n const listener = () => this.onCenterViewportResized();\n // centerContainer gets horizontal resizes\n this.centerContainerCtrl.registerViewportResizeListener(listener);\n // eBodyViewport gets vertical resizes\n this.gridBodyCtrl.registerBodyViewportResizeListener(listener);\n }\n onScrollbarWidthChanged() {\n this.checkViewportAndScrolls();\n }\n onCenterViewportResized() {\n if (this.centerContainerCtrl.isViewportVisible()) {\n this.checkViewportAndScrolls();\n const newWidth = this.centerContainerCtrl.getCenterWidth();\n if (newWidth !== this.centerWidth) {\n this.centerWidth = newWidth;\n this.columnModel.refreshFlexedColumns({ viewportWidth: this.centerWidth, updateBodyWidths: true, fireResizedEvent: true });\n }\n }\n else {\n this.bodyHeight = 0;\n }\n }\n // gets called every time the viewport size changes. we use this to check visibility of scrollbars\n // in the grid panel, and also to check size and position of viewport for row and column virtualisation.\n checkViewportAndScrolls() {\n // results in updating anything that depends on scroll showing\n this.updateScrollVisibleService();\n // fires event if height changes, used by PaginationService, HeightScalerService, RowRenderer\n this.checkBodyHeight();\n // check for virtual columns for ColumnController\n this.onHorizontalViewportChanged();\n this.gridBodyCtrl.getScrollFeature().checkScrollLeft();\n }\n getBodyHeight() {\n return this.bodyHeight;\n }\n checkBodyHeight() {\n const eBodyViewport = this.gridBodyCtrl.getBodyViewportElement();\n const bodyHeight = getInnerHeight(eBodyViewport);\n if (this.bodyHeight !== bodyHeight) {\n this.bodyHeight = bodyHeight;\n const event = {\n type: Events.EVENT_BODY_HEIGHT_CHANGED\n };\n this.eventService.dispatchEvent(event);\n }\n }\n updateScrollVisibleService() {\n // because of column animation (which takes 200ms), we have to do this twice.\n // eg if user removes cols anywhere except at the RHS, then the cols on the RHS\n // will animate to the left to fill the gap. this animation means just after\n // the cols are removed, the remaining cols are still in the original location\n // at the start of the animation, so pre animation the H scrollbar is still needed,\n // but post animation it is not.\n this.updateScrollVisibleServiceImpl();\n setTimeout(this.updateScrollVisibleServiceImpl.bind(this), 500);\n }\n updateScrollVisibleServiceImpl() {\n const params = {\n horizontalScrollShowing: this.isHorizontalScrollShowing(),\n verticalScrollShowing: this.gridBodyCtrl.isVerticalScrollShowing()\n };\n this.scrollVisibleService.setScrollsVisible(params);\n }\n isHorizontalScrollShowing() {\n return this.centerContainerCtrl.isHorizontalScrollShowing();\n }\n // this gets called whenever a change in the viewport, so we can inform column controller it has to work\n // out the virtual columns again. gets called from following locations:\n // + ensureColVisible, scroll, init, layoutChanged, displayedColumnsChanged\n onHorizontalViewportChanged() {\n const scrollWidth = this.centerContainerCtrl.getCenterWidth();\n const scrollPosition = this.centerContainerCtrl.getViewportScrollLeft();\n this.columnModel.setViewportPosition(scrollWidth, scrollPosition);\n }\n}\n__decorate([\n Autowired('ctrlsService')\n], ViewportSizeFeature.prototype, \"ctrlsService\", void 0);\n__decorate([\n Autowired('columnModel')\n], ViewportSizeFeature.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('scrollVisibleService')\n], ViewportSizeFeature.prototype, \"scrollVisibleService\", void 0);\n__decorate([\n PostConstruct\n], ViewportSizeFeature.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nimport { Autowired, PostConstruct } from \"../../context/context.mjs\";\nimport { Events } from \"../../eventKeys.mjs\";\nimport { setDisplayed, setFixedWidth } from \"../../utils/dom.mjs\";\nexport class SetPinnedLeftWidthFeature extends BeanStub {\n constructor(element) {\n super();\n this.element = element;\n }\n postConstruct() {\n this.addManagedListener(this.eventService, Events.EVENT_LEFT_PINNED_WIDTH_CHANGED, this.onPinnedLeftWidthChanged.bind(this));\n }\n onPinnedLeftWidthChanged() {\n const leftWidth = this.pinnedWidthService.getPinnedLeftWidth();\n const displayed = leftWidth > 0;\n setDisplayed(this.element, displayed);\n setFixedWidth(this.element, leftWidth);\n }\n getWidth() {\n return this.pinnedWidthService.getPinnedLeftWidth();\n }\n}\n__decorate([\n Autowired('pinnedWidthService')\n], SetPinnedLeftWidthFeature.prototype, \"pinnedWidthService\", void 0);\n__decorate([\n PostConstruct\n], SetPinnedLeftWidthFeature.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from \"../../context/context.mjs\";\nimport { Events } from \"../../eventKeys.mjs\";\nimport { setDisplayed, setFixedWidth } from \"../../utils/dom.mjs\";\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nexport class SetPinnedRightWidthFeature extends BeanStub {\n constructor(element) {\n super();\n this.element = element;\n }\n postConstruct() {\n this.addManagedListener(this.eventService, Events.EVENT_RIGHT_PINNED_WIDTH_CHANGED, this.onPinnedRightWidthChanged.bind(this));\n }\n onPinnedRightWidthChanged() {\n const rightWidth = this.pinnedWidthService.getPinnedRightWidth();\n const displayed = rightWidth > 0;\n setDisplayed(this.element, displayed);\n setFixedWidth(this.element, rightWidth);\n }\n getWidth() {\n return this.pinnedWidthService.getPinnedRightWidth();\n }\n}\n__decorate([\n Autowired('pinnedWidthService')\n], SetPinnedRightWidthFeature.prototype, \"pinnedWidthService\", void 0);\n__decorate([\n PostConstruct\n], SetPinnedRightWidthFeature.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nimport { Autowired, PostConstruct } from \"../../context/context.mjs\";\nimport { Events } from \"../../eventKeys.mjs\";\nexport class SetHeightFeature extends BeanStub {\n constructor(eContainer, eViewport) {\n super();\n this.eContainer = eContainer;\n this.eViewport = eViewport;\n }\n postConstruct() {\n this.addManagedListener(this.eventService, Events.EVENT_ROW_CONTAINER_HEIGHT_CHANGED, this.onHeightChanged.bind(this));\n }\n onHeightChanged() {\n const height = this.maxDivHeightScaler.getUiContainerHeight();\n const heightString = height != null ? `${height}px` : ``;\n this.eContainer.style.height = heightString;\n if (this.eViewport) {\n this.eViewport.style.height = heightString;\n }\n }\n}\n__decorate([\n Autowired(\"rowContainerHeightService\")\n], SetHeightFeature.prototype, \"maxDivHeightScaler\", void 0);\n__decorate([\n PostConstruct\n], SetHeightFeature.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nimport { missing } from \"../../utils/generic.mjs\";\nimport { Autowired, Optional, PostConstruct } from \"../../context/context.mjs\";\nexport class DragListenerFeature extends BeanStub {\n constructor(eContainer) {\n super();\n this.eContainer = eContainer;\n }\n postConstruct() {\n if (!this.gridOptionsService.is('enableRangeSelection') || // no range selection if no property\n missing(this.rangeService) // no range selection if not enterprise version\n ) {\n return;\n }\n const params = {\n eElement: this.eContainer,\n onDragStart: this.rangeService.onDragStart.bind(this.rangeService),\n onDragStop: this.rangeService.onDragStop.bind(this.rangeService),\n onDragging: this.rangeService.onDragging.bind(this.rangeService)\n };\n this.dragService.addDragSource(params);\n this.addDestroyFunc(() => this.dragService.removeDragSource(params));\n }\n}\n__decorate([\n Optional('rangeService')\n], DragListenerFeature.prototype, \"rangeService\", void 0);\n__decorate([\n Autowired('dragService')\n], DragListenerFeature.prototype, \"dragService\", void 0);\n__decorate([\n PostConstruct\n], DragListenerFeature.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { Autowired, PostConstruct } from \"../context/context.mjs\";\nimport { Events } from \"../eventKeys.mjs\";\nexport class CenterWidthFeature extends BeanStub {\n constructor(callback, addSpacer = false) {\n super();\n this.callback = callback;\n this.addSpacer = addSpacer;\n }\n postConstruct() {\n const listener = this.setWidth.bind(this);\n this.addManagedPropertyListener('domLayout', listener);\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, listener);\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, listener);\n this.addManagedListener(this.eventService, Events.EVENT_LEFT_PINNED_WIDTH_CHANGED, listener);\n if (this.addSpacer) {\n this.addManagedListener(this.eventService, Events.EVENT_RIGHT_PINNED_WIDTH_CHANGED, listener);\n this.addManagedListener(this.eventService, Events.EVENT_SCROLL_VISIBILITY_CHANGED, listener);\n this.addManagedListener(this.eventService, Events.EVENT_SCROLLBAR_WIDTH_CHANGED, listener);\n }\n this.setWidth();\n }\n setWidth() {\n const { columnModel } = this;\n const printLayout = this.gridOptionsService.isDomLayout('print');\n const centerWidth = columnModel.getBodyContainerWidth();\n const leftWidth = columnModel.getDisplayedColumnsLeftWidth();\n const rightWidth = columnModel.getDisplayedColumnsRightWidth();\n let totalWidth;\n if (printLayout) {\n totalWidth = centerWidth + leftWidth + rightWidth;\n }\n else {\n totalWidth = centerWidth;\n if (this.addSpacer) {\n const relevantWidth = this.gridOptionsService.is('enableRtl') ? leftWidth : rightWidth;\n if (relevantWidth === 0 && this.scrollVisibleService.isVerticalScrollShowing()) {\n totalWidth += this.gridOptionsService.getScrollbarWidth();\n }\n }\n }\n this.callback(totalWidth);\n }\n}\n__decorate([\n Autowired('columnModel')\n], CenterWidthFeature.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('scrollVisibleService')\n], CenterWidthFeature.prototype, \"scrollVisibleService\", void 0);\n__decorate([\n PostConstruct\n], CenterWidthFeature.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nimport { Autowired, PostConstruct } from \"../../context/context.mjs\";\nimport { Events } from \"../../eventKeys.mjs\";\nimport { RowContainerEventsFeature } from \"./rowContainerEventsFeature.mjs\";\nimport { getInnerWidth, getScrollLeft, isHorizontalScrollShowing, isVisible, setScrollLeft } from \"../../utils/dom.mjs\";\nimport { ViewportSizeFeature } from \"../viewportSizeFeature.mjs\";\nimport { convertToMap } from \"../../utils/map.mjs\";\nimport { SetPinnedLeftWidthFeature } from \"./setPinnedLeftWidthFeature.mjs\";\nimport { SetPinnedRightWidthFeature } from \"./setPinnedRightWidthFeature.mjs\";\nimport { SetHeightFeature } from \"./setHeightFeature.mjs\";\nimport { DragListenerFeature } from \"./dragListenerFeature.mjs\";\nimport { CenterWidthFeature } from \"../centerWidthFeature.mjs\";\nimport { isInvisibleScrollbar } from \"../../utils/browser.mjs\";\nexport var RowContainerName;\n(function (RowContainerName) {\n RowContainerName[\"LEFT\"] = \"left\";\n RowContainerName[\"RIGHT\"] = \"right\";\n RowContainerName[\"CENTER\"] = \"center\";\n RowContainerName[\"FULL_WIDTH\"] = \"fullWidth\";\n RowContainerName[\"TOP_LEFT\"] = \"topLeft\";\n RowContainerName[\"TOP_RIGHT\"] = \"topRight\";\n RowContainerName[\"TOP_CENTER\"] = \"topCenter\";\n RowContainerName[\"TOP_FULL_WIDTH\"] = \"topFullWidth\";\n RowContainerName[\"STICKY_TOP_LEFT\"] = \"stickyTopLeft\";\n RowContainerName[\"STICKY_TOP_RIGHT\"] = \"stickyTopRight\";\n RowContainerName[\"STICKY_TOP_CENTER\"] = \"stickyTopCenter\";\n RowContainerName[\"STICKY_TOP_FULL_WIDTH\"] = \"stickyTopFullWidth\";\n RowContainerName[\"BOTTOM_LEFT\"] = \"bottomLeft\";\n RowContainerName[\"BOTTOM_RIGHT\"] = \"bottomRight\";\n RowContainerName[\"BOTTOM_CENTER\"] = \"bottomCenter\";\n RowContainerName[\"BOTTOM_FULL_WIDTH\"] = \"bottomFullWidth\";\n})(RowContainerName || (RowContainerName = {}));\nexport var RowContainerType;\n(function (RowContainerType) {\n RowContainerType[\"LEFT\"] = \"left\";\n RowContainerType[\"RIGHT\"] = \"right\";\n RowContainerType[\"CENTER\"] = \"center\";\n RowContainerType[\"FULL_WIDTH\"] = \"fullWidth\";\n})(RowContainerType || (RowContainerType = {}));\nexport function getRowContainerTypeForName(name) {\n switch (name) {\n case RowContainerName.CENTER:\n case RowContainerName.TOP_CENTER:\n case RowContainerName.STICKY_TOP_CENTER:\n case RowContainerName.BOTTOM_CENTER:\n return RowContainerType.CENTER;\n case RowContainerName.LEFT:\n case RowContainerName.TOP_LEFT:\n case RowContainerName.STICKY_TOP_LEFT:\n case RowContainerName.BOTTOM_LEFT:\n return RowContainerType.LEFT;\n case RowContainerName.RIGHT:\n case RowContainerName.TOP_RIGHT:\n case RowContainerName.STICKY_TOP_RIGHT:\n case RowContainerName.BOTTOM_RIGHT:\n return RowContainerType.RIGHT;\n case RowContainerName.FULL_WIDTH:\n case RowContainerName.TOP_FULL_WIDTH:\n case RowContainerName.STICKY_TOP_FULL_WIDTH:\n case RowContainerName.BOTTOM_FULL_WIDTH:\n return RowContainerType.FULL_WIDTH;\n default:\n throw Error('Invalid Row Container Type');\n }\n}\nconst ContainerCssClasses = convertToMap([\n [RowContainerName.CENTER, 'ag-center-cols-container'],\n [RowContainerName.LEFT, 'ag-pinned-left-cols-container'],\n [RowContainerName.RIGHT, 'ag-pinned-right-cols-container'],\n [RowContainerName.FULL_WIDTH, 'ag-full-width-container'],\n [RowContainerName.TOP_CENTER, 'ag-floating-top-container'],\n [RowContainerName.TOP_LEFT, 'ag-pinned-left-floating-top'],\n [RowContainerName.TOP_RIGHT, 'ag-pinned-right-floating-top'],\n [RowContainerName.TOP_FULL_WIDTH, 'ag-floating-top-full-width-container'],\n [RowContainerName.STICKY_TOP_CENTER, 'ag-sticky-top-container'],\n [RowContainerName.STICKY_TOP_LEFT, 'ag-pinned-left-sticky-top'],\n [RowContainerName.STICKY_TOP_RIGHT, 'ag-pinned-right-sticky-top'],\n [RowContainerName.STICKY_TOP_FULL_WIDTH, 'ag-sticky-top-full-width-container'],\n [RowContainerName.BOTTOM_CENTER, 'ag-floating-bottom-container'],\n [RowContainerName.BOTTOM_LEFT, 'ag-pinned-left-floating-bottom'],\n [RowContainerName.BOTTOM_RIGHT, 'ag-pinned-right-floating-bottom'],\n [RowContainerName.BOTTOM_FULL_WIDTH, 'ag-floating-bottom-full-width-container'],\n]);\nconst ViewportCssClasses = convertToMap([\n [RowContainerName.CENTER, 'ag-center-cols-viewport'],\n [RowContainerName.TOP_CENTER, 'ag-floating-top-viewport'],\n [RowContainerName.STICKY_TOP_CENTER, 'ag-sticky-top-viewport'],\n [RowContainerName.BOTTOM_CENTER, 'ag-floating-bottom-viewport'],\n]);\nexport class RowContainerCtrl extends BeanStub {\n constructor(name) {\n super();\n this.visible = true;\n // Maintaining a constant reference enables optimization in React.\n this.EMPTY_CTRLS = [];\n this.name = name;\n this.isFullWithContainer =\n this.name === RowContainerName.TOP_FULL_WIDTH\n || this.name === RowContainerName.STICKY_TOP_FULL_WIDTH\n || this.name === RowContainerName.BOTTOM_FULL_WIDTH\n || this.name === RowContainerName.FULL_WIDTH;\n }\n static getRowContainerCssClasses(name) {\n const containerClass = ContainerCssClasses.get(name);\n const viewportClass = ViewportCssClasses.get(name);\n return { container: containerClass, viewport: viewportClass };\n }\n static getPinned(name) {\n switch (name) {\n case RowContainerName.BOTTOM_LEFT:\n case RowContainerName.TOP_LEFT:\n case RowContainerName.STICKY_TOP_LEFT:\n case RowContainerName.LEFT:\n return 'left';\n case RowContainerName.BOTTOM_RIGHT:\n case RowContainerName.TOP_RIGHT:\n case RowContainerName.STICKY_TOP_RIGHT:\n case RowContainerName.RIGHT:\n return 'right';\n default:\n return null;\n }\n }\n postConstruct() {\n this.enableRtl = this.gridOptionsService.is('enableRtl');\n this.embedFullWidthRows = this.gridOptionsService.is('embedFullWidthRows');\n this.forContainers([RowContainerName.CENTER], () => this.viewportSizeFeature = this.createManagedBean(new ViewportSizeFeature(this)));\n }\n registerWithCtrlsService() {\n switch (this.name) {\n case RowContainerName.CENTER:\n this.ctrlsService.registerCenterRowContainerCtrl(this);\n break;\n case RowContainerName.LEFT:\n this.ctrlsService.registerLeftRowContainerCtrl(this);\n break;\n case RowContainerName.RIGHT:\n this.ctrlsService.registerRightRowContainerCtrl(this);\n break;\n case RowContainerName.TOP_CENTER:\n this.ctrlsService.registerTopCenterRowContainerCtrl(this);\n break;\n case RowContainerName.TOP_LEFT:\n this.ctrlsService.registerTopLeftRowContainerCon(this);\n break;\n case RowContainerName.TOP_RIGHT:\n this.ctrlsService.registerTopRightRowContainerCtrl(this);\n break;\n case RowContainerName.STICKY_TOP_CENTER:\n this.ctrlsService.registerStickyTopCenterRowContainerCtrl(this);\n break;\n case RowContainerName.STICKY_TOP_LEFT:\n this.ctrlsService.registerStickyTopLeftRowContainerCon(this);\n break;\n case RowContainerName.STICKY_TOP_RIGHT:\n this.ctrlsService.registerStickyTopRightRowContainerCtrl(this);\n break;\n case RowContainerName.BOTTOM_CENTER:\n this.ctrlsService.registerBottomCenterRowContainerCtrl(this);\n break;\n case RowContainerName.BOTTOM_LEFT:\n this.ctrlsService.registerBottomLeftRowContainerCtrl(this);\n break;\n case RowContainerName.BOTTOM_RIGHT:\n this.ctrlsService.registerBottomRightRowContainerCtrl(this);\n break;\n }\n }\n forContainers(names, callback) {\n if (names.indexOf(this.name) >= 0) {\n callback();\n }\n }\n getContainerElement() {\n return this.eContainer;\n }\n getViewportSizeFeature() {\n return this.viewportSizeFeature;\n }\n setComp(view, eContainer, eViewport) {\n this.comp = view;\n this.eContainer = eContainer;\n this.eViewport = eViewport;\n this.createManagedBean(new RowContainerEventsFeature(this.eContainer));\n this.addPreventScrollWhileDragging();\n this.listenOnDomOrder();\n this.stopHScrollOnPinnedRows();\n const allTopNoFW = [RowContainerName.TOP_CENTER, RowContainerName.TOP_LEFT, RowContainerName.TOP_RIGHT];\n const allStickyTopNoFW = [RowContainerName.STICKY_TOP_CENTER, RowContainerName.STICKY_TOP_LEFT, RowContainerName.STICKY_TOP_RIGHT];\n const allBottomNoFW = [RowContainerName.BOTTOM_CENTER, RowContainerName.BOTTOM_LEFT, RowContainerName.BOTTOM_RIGHT];\n const allMiddleNoFW = [RowContainerName.CENTER, RowContainerName.LEFT, RowContainerName.RIGHT];\n const allNoFW = [...allTopNoFW, ...allBottomNoFW, ...allMiddleNoFW, ...allStickyTopNoFW];\n const allMiddle = [RowContainerName.CENTER, RowContainerName.LEFT, RowContainerName.RIGHT, RowContainerName.FULL_WIDTH];\n const allCenter = [RowContainerName.CENTER, RowContainerName.TOP_CENTER, RowContainerName.STICKY_TOP_CENTER, RowContainerName.BOTTOM_CENTER];\n const allLeft = [RowContainerName.LEFT, RowContainerName.BOTTOM_LEFT, RowContainerName.TOP_LEFT, RowContainerName.STICKY_TOP_LEFT];\n const allRight = [RowContainerName.RIGHT, RowContainerName.BOTTOM_RIGHT, RowContainerName.TOP_RIGHT, RowContainerName.STICKY_TOP_RIGHT];\n this.forContainers(allLeft, () => {\n this.pinnedWidthFeature = this.createManagedBean(new SetPinnedLeftWidthFeature(this.eContainer));\n this.addManagedListener(this.eventService, Events.EVENT_LEFT_PINNED_WIDTH_CHANGED, () => this.onPinnedWidthChanged());\n });\n this.forContainers(allRight, () => {\n this.pinnedWidthFeature = this.createManagedBean(new SetPinnedRightWidthFeature(this.eContainer));\n this.addManagedListener(this.eventService, Events.EVENT_RIGHT_PINNED_WIDTH_CHANGED, () => this.onPinnedWidthChanged());\n });\n this.forContainers(allMiddle, () => this.createManagedBean(new SetHeightFeature(this.eContainer, this.name === RowContainerName.CENTER ? eViewport : undefined)));\n this.forContainers(allNoFW, () => this.createManagedBean(new DragListenerFeature(this.eContainer)));\n this.forContainers(allCenter, () => this.createManagedBean(new CenterWidthFeature(width => this.comp.setContainerWidth(`${width}px`))));\n if (isInvisibleScrollbar()) {\n this.forContainers([RowContainerName.CENTER], () => {\n const pinnedWidthChangedEvent = this.enableRtl ? Events.EVENT_LEFT_PINNED_WIDTH_CHANGED : Events.EVENT_RIGHT_PINNED_WIDTH_CHANGED;\n this.addManagedListener(this.eventService, pinnedWidthChangedEvent, () => this.refreshPaddingForFakeScrollbar());\n });\n this.refreshPaddingForFakeScrollbar();\n }\n this.addListeners();\n this.registerWithCtrlsService();\n }\n refreshPaddingForFakeScrollbar() {\n const { enableRtl, columnModel, eContainer } = this;\n const sideToCheck = enableRtl ? RowContainerName.LEFT : RowContainerName.RIGHT;\n this.forContainers([RowContainerName.CENTER, sideToCheck], () => {\n const pinnedWidth = columnModel.getContainerWidth(sideToCheck);\n const marginSide = enableRtl ? 'marginLeft' : 'marginRight';\n eContainer.style[marginSide] = pinnedWidth ? '16px' : '0px';\n });\n }\n addListeners() {\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, () => this.onDisplayedColumnsChanged());\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, () => this.onDisplayedColumnsWidthChanged());\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_ROWS_CHANGED, (params) => this.onDisplayedRowsChanged(params.afterScroll));\n this.onDisplayedColumnsChanged();\n this.onDisplayedColumnsWidthChanged();\n this.onDisplayedRowsChanged();\n }\n listenOnDomOrder() {\n // sticky section must show rows in set order\n const allStickyContainers = [RowContainerName.STICKY_TOP_CENTER, RowContainerName.STICKY_TOP_LEFT, RowContainerName.STICKY_TOP_RIGHT, RowContainerName.STICKY_TOP_FULL_WIDTH];\n const isStickContainer = allStickyContainers.indexOf(this.name) >= 0;\n if (isStickContainer) {\n this.comp.setDomOrder(true);\n return;\n }\n const listener = () => {\n const isEnsureDomOrder = this.gridOptionsService.is('ensureDomOrder');\n const isPrintLayout = this.gridOptionsService.isDomLayout('print');\n this.comp.setDomOrder(isEnsureDomOrder || isPrintLayout);\n };\n this.addManagedPropertyListener('domLayout', listener);\n listener();\n }\n // when editing a pinned row, if the cell is half outside the scrollable area, the browser can\n // scroll the column into view. we do not want this, the pinned sections should never scroll.\n // so we listen to scrolls on these containers and reset the scroll if we find one.\n stopHScrollOnPinnedRows() {\n this.forContainers([RowContainerName.TOP_CENTER, RowContainerName.STICKY_TOP_CENTER, RowContainerName.BOTTOM_CENTER], () => {\n const resetScrollLeft = () => this.eViewport.scrollLeft = 0;\n this.addManagedListener(this.eViewport, 'scroll', resetScrollLeft);\n });\n }\n onDisplayedColumnsChanged() {\n this.forContainers([RowContainerName.CENTER], () => this.onHorizontalViewportChanged());\n }\n onDisplayedColumnsWidthChanged() {\n this.forContainers([RowContainerName.CENTER], () => this.onHorizontalViewportChanged());\n }\n // this methods prevents the grid views from being scrolled while the dragService is being used\n // eg. the view should not scroll up and down while dragging rows using the rowDragComp.\n addPreventScrollWhileDragging() {\n const preventScroll = (e) => {\n if (this.dragService.isDragging()) {\n if (e.cancelable) {\n e.preventDefault();\n }\n }\n };\n this.eContainer.addEventListener('touchmove', preventScroll, { passive: false });\n this.addDestroyFunc(() => this.eContainer.removeEventListener('touchmove', preventScroll));\n }\n // this gets called whenever a change in the viewport, so we can inform column controller it has to work\n // out the virtual columns again. gets called from following locations:\n // + ensureColVisible, scroll, init, layoutChanged, displayedColumnsChanged\n onHorizontalViewportChanged(afterScroll = false) {\n const scrollWidth = this.getCenterWidth();\n const scrollPosition = this.getCenterViewportScrollLeft();\n this.columnModel.setViewportPosition(scrollWidth, scrollPosition, afterScroll);\n }\n getCenterWidth() {\n return getInnerWidth(this.eViewport);\n }\n getCenterViewportScrollLeft() {\n // we defer to a util, as how you calculated scrollLeft when doing RTL depends on the browser\n return getScrollLeft(this.eViewport, this.enableRtl);\n }\n registerViewportResizeListener(listener) {\n const unsubscribeFromResize = this.resizeObserverService.observeResize(this.eViewport, listener);\n this.addDestroyFunc(() => unsubscribeFromResize());\n }\n isViewportVisible() {\n return isVisible(this.eViewport);\n }\n getViewportScrollLeft() {\n return getScrollLeft(this.eViewport, this.enableRtl);\n }\n isHorizontalScrollShowing() {\n const isAlwaysShowHorizontalScroll = this.gridOptionsService.is('alwaysShowHorizontalScroll');\n return isAlwaysShowHorizontalScroll || isHorizontalScrollShowing(this.eViewport);\n }\n getViewportElement() {\n return this.eViewport;\n }\n setContainerTranslateX(amount) {\n this.eContainer.style.transform = `translateX(${amount}px)`;\n }\n getHScrollPosition() {\n const res = {\n left: this.eViewport.scrollLeft,\n right: this.eViewport.scrollLeft + this.eViewport.offsetWidth\n };\n return res;\n }\n setCenterViewportScrollLeft(value) {\n // we defer to a util, as how you calculated scrollLeft when doing RTL depends on the browser\n setScrollLeft(this.eViewport, value, this.enableRtl);\n }\n isContainerVisible() {\n const pinned = RowContainerCtrl.getPinned(this.name);\n return !pinned || (!!this.pinnedWidthFeature && this.pinnedWidthFeature.getWidth() > 0);\n }\n onPinnedWidthChanged() {\n const visible = this.isContainerVisible();\n if (this.visible != visible) {\n this.visible = visible;\n this.onDisplayedRowsChanged();\n }\n if (isInvisibleScrollbar()) {\n this.refreshPaddingForFakeScrollbar();\n }\n }\n onDisplayedRowsChanged(useFlushSync = false) {\n if (this.visible) {\n const printLayout = this.gridOptionsService.isDomLayout('print');\n // this just justifies if the ctrl is in the correct place, this will be fed with zombie rows by the\n // row renderer, so should not block them as they still need to animate - the row renderer\n // will clean these up when they finish animating\n const doesRowMatch = (rowCtrl) => {\n const fullWidthRow = rowCtrl.isFullWidth();\n const embedFW = this.embedFullWidthRows || printLayout;\n const match = this.isFullWithContainer ?\n !embedFW && fullWidthRow\n : embedFW || !fullWidthRow;\n return match;\n };\n // this list contains either all pinned top, center or pinned bottom rows\n // this filters out rows not for this container, eg if it's a full with row, but we are not full with container\n const rowsThisContainer = this.getRowCtrls().filter(doesRowMatch);\n this.comp.setRowCtrls(rowsThisContainer, useFlushSync);\n }\n else {\n this.comp.setRowCtrls(this.EMPTY_CTRLS, false);\n }\n }\n getRowCtrls() {\n switch (this.name) {\n case RowContainerName.TOP_CENTER:\n case RowContainerName.TOP_LEFT:\n case RowContainerName.TOP_RIGHT:\n case RowContainerName.TOP_FULL_WIDTH:\n return this.rowRenderer.getTopRowCtrls();\n case RowContainerName.STICKY_TOP_CENTER:\n case RowContainerName.STICKY_TOP_LEFT:\n case RowContainerName.STICKY_TOP_RIGHT:\n case RowContainerName.STICKY_TOP_FULL_WIDTH:\n return this.rowRenderer.getStickyTopRowCtrls();\n case RowContainerName.BOTTOM_CENTER:\n case RowContainerName.BOTTOM_LEFT:\n case RowContainerName.BOTTOM_RIGHT:\n case RowContainerName.BOTTOM_FULL_WIDTH:\n return this.rowRenderer.getBottomRowCtrls();\n default:\n return this.rowRenderer.getCentreRowCtrls();\n }\n }\n}\n__decorate([\n Autowired('scrollVisibleService')\n], RowContainerCtrl.prototype, \"scrollVisibleService\", void 0);\n__decorate([\n Autowired('dragService')\n], RowContainerCtrl.prototype, \"dragService\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], RowContainerCtrl.prototype, \"ctrlsService\", void 0);\n__decorate([\n Autowired('columnModel')\n], RowContainerCtrl.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('resizeObserverService')\n], RowContainerCtrl.prototype, \"resizeObserverService\", void 0);\n__decorate([\n Autowired('animationFrameService')\n], RowContainerCtrl.prototype, \"animationFrameService\", void 0);\n__decorate([\n Autowired('rowRenderer')\n], RowContainerCtrl.prototype, \"rowRenderer\", void 0);\n__decorate([\n PostConstruct\n], RowContainerCtrl.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Optional, PostConstruct } from '../context/context.mjs';\nimport { LayoutCssClasses } from \"../styling/layoutFeature.mjs\";\nimport { setAriaColCount, setAriaMultiSelectable, setAriaRowCount } from '../utils/aria.mjs';\nimport { Component } from '../widgets/component.mjs';\nimport { RefSelector } from '../widgets/componentAnnotations.mjs';\nimport { CSS_CLASS_FORCE_VERTICAL_SCROLL, GridBodyCtrl, RowAnimationCssClasses } from \"./gridBodyCtrl.mjs\";\nimport { RowContainerName } from \"./rowContainer/rowContainerCtrl.mjs\";\nconst GRID_BODY_TEMPLATE = /* html */ `
\n \n
\n \n \n \n \n
\n
\n
\n \n \n \n \n
\n \n
\n
\n \n \n \n \n
\n
\n \n \n \n \n
\n \n \n
`;\nexport class GridBodyComp extends Component {\n constructor() {\n super(GRID_BODY_TEMPLATE);\n }\n init() {\n const setHeight = (height, element) => {\n const heightString = `${height}px`;\n element.style.minHeight = heightString;\n element.style.height = heightString;\n };\n const compProxy = {\n setRowAnimationCssOnBodyViewport: (cssClass, animate) => this.setRowAnimationCssOnBodyViewport(cssClass, animate),\n setColumnCount: count => setAriaColCount(this.getGui(), count),\n setRowCount: count => setAriaRowCount(this.getGui(), count),\n setTopHeight: height => setHeight(height, this.eTop),\n setBottomHeight: height => setHeight(height, this.eBottom),\n setTopDisplay: display => this.eTop.style.display = display,\n setBottomDisplay: display => this.eBottom.style.display = display,\n setStickyTopHeight: height => this.eStickyTop.style.height = height,\n setStickyTopTop: top => this.eStickyTop.style.top = top,\n setStickyTopWidth: width => this.eStickyTop.style.width = width,\n setColumnMovingCss: (cssClass, flag) => this.addOrRemoveCssClass(cssClass, flag),\n updateLayoutClasses: (cssClass, params) => {\n const classLists = [\n this.eBodyViewport.classList,\n this.eBody.classList\n ];\n classLists.forEach(classList => {\n classList.toggle(LayoutCssClasses.AUTO_HEIGHT, params.autoHeight);\n classList.toggle(LayoutCssClasses.NORMAL, params.normal);\n classList.toggle(LayoutCssClasses.PRINT, params.print);\n });\n this.addOrRemoveCssClass(LayoutCssClasses.AUTO_HEIGHT, params.autoHeight);\n this.addOrRemoveCssClass(LayoutCssClasses.NORMAL, params.normal);\n this.addOrRemoveCssClass(LayoutCssClasses.PRINT, params.print);\n },\n setAlwaysVerticalScrollClass: (cssClass, on) => this.eBodyViewport.classList.toggle(CSS_CLASS_FORCE_VERTICAL_SCROLL, on),\n registerBodyViewportResizeListener: listener => {\n const unsubscribeFromResize = this.resizeObserverService.observeResize(this.eBodyViewport, listener);\n this.addDestroyFunc(() => unsubscribeFromResize());\n },\n setPinnedTopBottomOverflowY: overflow => this.eTop.style.overflowY = this.eBottom.style.overflowY = overflow,\n setCellSelectableCss: (cssClass, selectable) => {\n [this.eTop, this.eBodyViewport, this.eBottom]\n .forEach(ct => ct.classList.toggle(cssClass, selectable));\n },\n setBodyViewportWidth: width => this.eBodyViewport.style.width = width\n };\n this.ctrl = this.createManagedBean(new GridBodyCtrl());\n this.ctrl.setComp(compProxy, this.getGui(), this.eBodyViewport, this.eTop, this.eBottom, this.eStickyTop);\n if (this.rangeService || this.gridOptionsService.get('rowSelection') === 'multiple') {\n setAriaMultiSelectable(this.getGui(), true);\n }\n }\n setRowAnimationCssOnBodyViewport(cssClass, animateRows) {\n const bodyViewportClassList = this.eBodyViewport.classList;\n bodyViewportClassList.toggle(RowAnimationCssClasses.ANIMATION_ON, animateRows);\n bodyViewportClassList.toggle(RowAnimationCssClasses.ANIMATION_OFF, !animateRows);\n }\n getFloatingTopBottom() {\n return [this.eTop, this.eBottom];\n }\n}\n__decorate([\n Autowired('resizeObserverService')\n], GridBodyComp.prototype, \"resizeObserverService\", void 0);\n__decorate([\n Optional('rangeService')\n], GridBodyComp.prototype, \"rangeService\", void 0);\n__decorate([\n RefSelector('eBodyViewport')\n], GridBodyComp.prototype, \"eBodyViewport\", void 0);\n__decorate([\n RefSelector('eStickyTop')\n], GridBodyComp.prototype, \"eStickyTop\", void 0);\n__decorate([\n RefSelector('eTop')\n], GridBodyComp.prototype, \"eTop\", void 0);\n__decorate([\n RefSelector('eBottom')\n], GridBodyComp.prototype, \"eBottom\", void 0);\n__decorate([\n RefSelector('gridHeader')\n], GridBodyComp.prototype, \"headerRootComp\", void 0);\n__decorate([\n RefSelector('eBody')\n], GridBodyComp.prototype, \"eBody\", void 0);\n__decorate([\n PostConstruct\n], GridBodyComp.prototype, \"init\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean, Autowired, PostConstruct } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { Events } from \"../events.mjs\";\nlet ScrollVisibleService = class ScrollVisibleService extends BeanStub {\n postConstruct() {\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, this.onDisplayedColumnsWidthChanged.bind(this));\n }\n onDisplayedColumnsChanged() {\n this.update();\n }\n onDisplayedColumnsWidthChanged() {\n this.update();\n }\n update() {\n // because of column animation (which takes 200ms), we have to do this twice.\n // eg if user removes cols anywhere except at the RHS, then the cols on the RHS\n // will animate to the left to fill the gap. this animation means just after\n // the cols are removed, the remaining cols are still in the original location\n // at the start of the animation, so pre animation the H scrollbar is still needed,\n // but post animation it is not.\n this.updateImpl();\n setTimeout(this.updateImpl.bind(this), 500);\n }\n updateImpl() {\n const centerRowCtrl = this.ctrlsService.getCenterRowContainerCtrl();\n if (!centerRowCtrl) {\n return;\n }\n const params = {\n horizontalScrollShowing: centerRowCtrl.isHorizontalScrollShowing(),\n verticalScrollShowing: this.isVerticalScrollShowing()\n };\n this.setScrollsVisible(params);\n }\n setScrollsVisible(params) {\n const atLeastOneDifferent = this.horizontalScrollShowing !== params.horizontalScrollShowing ||\n this.verticalScrollShowing !== params.verticalScrollShowing;\n if (atLeastOneDifferent) {\n this.horizontalScrollShowing = params.horizontalScrollShowing;\n this.verticalScrollShowing = params.verticalScrollShowing;\n const event = {\n type: Events.EVENT_SCROLL_VISIBILITY_CHANGED\n };\n this.eventService.dispatchEvent(event);\n }\n }\n // used by pagination service - to know page height\n isHorizontalScrollShowing() {\n return this.horizontalScrollShowing;\n }\n // used by header container\n isVerticalScrollShowing() {\n return this.verticalScrollShowing;\n }\n};\n__decorate([\n Autowired('ctrlsService')\n], ScrollVisibleService.prototype, \"ctrlsService\", void 0);\n__decorate([\n PostConstruct\n], ScrollVisibleService.prototype, \"postConstruct\", null);\nScrollVisibleService = __decorate([\n Bean('scrollVisibleService')\n], ScrollVisibleService);\nexport { ScrollVisibleService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar MouseEventService_1;\nimport { Bean } from \"../context/context.mjs\";\nimport { Autowired } from \"../context/context.mjs\";\nimport { NumberSequence } from '../utils/index.mjs';\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { getCtrlForEventTarget } from \"../utils/event.mjs\";\nimport { exists } from \"../utils/generic.mjs\";\nimport { CellCtrl } from \"../rendering/cell/cellCtrl.mjs\";\nlet MouseEventService = MouseEventService_1 = class MouseEventService extends BeanStub {\n constructor() {\n super(...arguments);\n this.gridInstanceId = MouseEventService_1.gridInstanceSequence.next();\n }\n // we put the instance id onto the main DOM element. this is used for events, when grids are inside grids,\n // so the grid can work out if the even came from this grid or a grid inside this one. see the ctrl+v logic\n // for where this is used.\n stampTopLevelGridCompWithGridInstance(eGridDiv) {\n eGridDiv[MouseEventService_1.GRID_DOM_KEY] = this.gridInstanceId;\n }\n getRenderedCellForEvent(event) {\n return getCtrlForEventTarget(this.gridOptionsService, event.target, CellCtrl.DOM_DATA_KEY_CELL_CTRL);\n }\n // walks the path of the event, and returns true if this grid is the first one that it finds. if doing\n // master / detail grids, and a child grid is found, then it returns false. this stops things like copy/paste\n // getting executed on many grids at the same time.\n isEventFromThisGrid(event) {\n const res = this.isElementInThisGrid(event.target);\n return res;\n }\n isElementInThisGrid(element) {\n let pointer = element;\n while (pointer) {\n const instanceId = pointer[MouseEventService_1.GRID_DOM_KEY];\n if (exists(instanceId)) {\n const eventFromThisGrid = instanceId === this.gridInstanceId;\n return eventFromThisGrid;\n }\n pointer = pointer.parentElement;\n }\n return false;\n }\n getCellPositionForEvent(event) {\n const cellComp = this.getRenderedCellForEvent(event);\n return cellComp ? cellComp.getCellPosition() : null;\n }\n getNormalisedPosition(event) {\n const gridPanelHasScrolls = this.gridOptionsService.isDomLayout('normal');\n const e = event;\n let x;\n let y;\n if (e.clientX != null || e.clientY != null) {\n x = e.clientX;\n y = e.clientY;\n }\n else {\n x = e.x;\n y = e.y;\n }\n if (gridPanelHasScrolls) {\n const gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n const vRange = gridBodyCon.getScrollFeature().getVScrollPosition();\n const hRange = gridBodyCon.getScrollFeature().getHScrollPosition();\n x += hRange.left;\n y += vRange.top;\n }\n return { x, y };\n }\n};\nMouseEventService.gridInstanceSequence = new NumberSequence();\nMouseEventService.GRID_DOM_KEY = '__ag_grid_instance';\n__decorate([\n Autowired('ctrlsService')\n], MouseEventService.prototype, \"ctrlsService\", void 0);\nMouseEventService = MouseEventService_1 = __decorate([\n Bean('mouseEventService')\n], MouseEventService);\nexport { MouseEventService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, Optional, PostConstruct } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { exists, missing } from \"../utils/generic.mjs\";\nimport { last } from \"../utils/array.mjs\";\nimport { KeyCode } from '../constants/keyCode.mjs';\nimport { CellCtrl } from \"../rendering/cell/cellCtrl.mjs\";\nimport { RowCtrl } from \"../rendering/row/rowCtrl.mjs\";\nimport { doOnce, throttle } from \"../utils/function.mjs\";\nimport { Events } from \"../eventKeys.mjs\";\nlet NavigationService = class NavigationService extends BeanStub {\n constructor() {\n super();\n this.onPageDown = throttle(this.onPageDown, 100);\n this.onPageUp = throttle(this.onPageUp, 100);\n }\n postConstruct() {\n this.ctrlsService.whenReady(p => {\n this.gridBodyCon = p.gridBodyCtrl;\n });\n }\n handlePageScrollingKey(event, fromFullWidth = false) {\n const key = event.key;\n const alt = event.altKey;\n const ctrl = event.ctrlKey || event.metaKey;\n const rangeServiceShouldHandleShift = !!this.rangeService && event.shiftKey;\n // home and end can be processed without knowing the currently selected cell, this can occur for full width rows.\n const currentCell = this.mouseEventService.getCellPositionForEvent(event);\n let processed = false;\n switch (key) {\n case KeyCode.PAGE_HOME:\n case KeyCode.PAGE_END:\n // handle home and end when ctrl & alt are NOT pressed\n if (!ctrl && !alt) {\n this.onHomeOrEndKey(key);\n processed = true;\n }\n break;\n case KeyCode.LEFT:\n case KeyCode.RIGHT:\n case KeyCode.UP:\n case KeyCode.DOWN:\n if (!currentCell) {\n return false;\n }\n // handle when ctrl is pressed only, if shift is pressed\n // it will be handled by the rangeService\n if (ctrl && !alt && !rangeServiceShouldHandleShift) {\n this.onCtrlUpDownLeftRight(key, currentCell);\n processed = true;\n }\n break;\n case KeyCode.PAGE_DOWN:\n case KeyCode.PAGE_UP:\n // handle page up and page down when ctrl & alt are NOT pressed\n if (!ctrl && !alt) {\n processed = this.handlePageUpDown(key, currentCell, fromFullWidth);\n }\n break;\n }\n if (processed) {\n event.preventDefault();\n }\n return processed;\n }\n handlePageUpDown(key, currentCell, fromFullWidth) {\n if (fromFullWidth) {\n currentCell = this.focusService.getFocusedCell();\n }\n if (!currentCell) {\n return false;\n }\n if (key === KeyCode.PAGE_UP) {\n this.onPageUp(currentCell);\n }\n else {\n this.onPageDown(currentCell);\n }\n return true;\n }\n navigateTo(navigateParams) {\n const { scrollIndex, scrollType, scrollColumn, focusIndex, focusColumn } = navigateParams;\n if (exists(scrollColumn) && !scrollColumn.isPinned()) {\n this.gridBodyCon.getScrollFeature().ensureColumnVisible(scrollColumn);\n }\n if (exists(scrollIndex)) {\n this.gridBodyCon.getScrollFeature().ensureIndexVisible(scrollIndex, scrollType);\n }\n // setFocusedCell relies on the browser default focus behavior to scroll the focused cell into view,\n // however, this behavior will cause the cell border to be cut off, or if we have sticky rows, the\n // cell will be completely hidden, so we call ensureIndexVisible without a position to guarantee\n // minimal scroll to get the row into view.\n if (!navigateParams.isAsync) {\n this.gridBodyCon.getScrollFeature().ensureIndexVisible(focusIndex);\n }\n // if we don't do this, the range will be left on the last cell, which will leave the last focused cell\n // highlighted.\n this.focusService.setFocusedCell({ rowIndex: focusIndex, column: focusColumn, rowPinned: null, forceBrowserFocus: true });\n if (this.rangeService) {\n const cellPosition = { rowIndex: focusIndex, rowPinned: null, column: focusColumn };\n this.rangeService.setRangeToCell(cellPosition);\n }\n }\n // this method is throttled, see the `constructor`\n onPageDown(gridCell) {\n const gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n const scrollPosition = gridBodyCon.getScrollFeature().getVScrollPosition();\n const pixelsInOnePage = this.getViewportHeight();\n const pagingPixelOffset = this.paginationProxy.getPixelOffset();\n const currentPageBottomPixel = scrollPosition.top + pixelsInOnePage;\n const currentPageBottomRow = this.paginationProxy.getRowIndexAtPixel(currentPageBottomPixel + pagingPixelOffset);\n if (this.columnModel.isAutoRowHeightActive()) {\n this.navigateToNextPageWithAutoHeight(gridCell, currentPageBottomRow);\n }\n else {\n this.navigateToNextPage(gridCell, currentPageBottomRow);\n }\n }\n // this method is throttled, see the `constructor`\n onPageUp(gridCell) {\n const gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n const scrollPosition = gridBodyCon.getScrollFeature().getVScrollPosition();\n const pagingPixelOffset = this.paginationProxy.getPixelOffset();\n const currentPageTopPixel = scrollPosition.top;\n const currentPageTopRow = this.paginationProxy.getRowIndexAtPixel(currentPageTopPixel + pagingPixelOffset);\n if (this.columnModel.isAutoRowHeightActive()) {\n this.navigateToNextPageWithAutoHeight(gridCell, currentPageTopRow, true);\n }\n else {\n this.navigateToNextPage(gridCell, currentPageTopRow, true);\n }\n }\n navigateToNextPage(gridCell, scrollIndex, up = false) {\n const pixelsInOnePage = this.getViewportHeight();\n const firstRow = this.paginationProxy.getPageFirstRow();\n const lastRow = this.paginationProxy.getPageLastRow();\n const pagingPixelOffset = this.paginationProxy.getPixelOffset();\n const currentRowNode = this.paginationProxy.getRow(gridCell.rowIndex);\n const rowPixelDiff = up\n ? ((currentRowNode === null || currentRowNode === void 0 ? void 0 : currentRowNode.rowHeight) - pixelsInOnePage - pagingPixelOffset)\n : (pixelsInOnePage - pagingPixelOffset);\n const nextCellPixel = (currentRowNode === null || currentRowNode === void 0 ? void 0 : currentRowNode.rowTop) + rowPixelDiff;\n let focusIndex = this.paginationProxy.getRowIndexAtPixel(nextCellPixel + pagingPixelOffset);\n if (focusIndex === gridCell.rowIndex) {\n const diff = up ? -1 : 1;\n scrollIndex = focusIndex = gridCell.rowIndex + diff;\n }\n let scrollType;\n if (up) {\n scrollType = 'bottom';\n if (focusIndex < firstRow) {\n focusIndex = firstRow;\n }\n if (scrollIndex < firstRow) {\n scrollIndex = firstRow;\n }\n }\n else {\n scrollType = 'top';\n if (focusIndex > lastRow) {\n focusIndex = lastRow;\n }\n if (scrollIndex > lastRow) {\n scrollIndex = lastRow;\n }\n }\n if (this.isRowTallerThanView(focusIndex)) {\n scrollIndex = focusIndex;\n scrollType = 'top';\n }\n this.navigateTo({\n scrollIndex,\n scrollType,\n scrollColumn: null,\n focusIndex,\n focusColumn: gridCell.column\n });\n }\n navigateToNextPageWithAutoHeight(gridCell, scrollIndex, up = false) {\n // because autoHeight will calculate the height of rows after scroll\n // first we scroll towards the required point, then we add a small\n // delay to allow the height to be recalculated, check which index\n // should be focused and then finally navigate to that index.\n // TODO: we should probably have an event fired once to scrollbar has\n // settled and all rowHeights have been calculated instead of relying\n // on a setTimeout of 50ms.\n this.navigateTo({\n scrollIndex: scrollIndex,\n scrollType: up ? 'bottom' : 'top',\n scrollColumn: null,\n focusIndex: scrollIndex,\n focusColumn: gridCell.column\n });\n setTimeout(() => {\n const focusIndex = this.getNextFocusIndexForAutoHeight(gridCell, up);\n this.navigateTo({\n scrollIndex: scrollIndex,\n scrollType: up ? 'bottom' : 'top',\n scrollColumn: null,\n focusIndex: focusIndex,\n focusColumn: gridCell.column,\n isAsync: true\n });\n }, 50);\n }\n getNextFocusIndexForAutoHeight(gridCell, up = false) {\n var _a;\n const step = up ? -1 : 1;\n const pixelsInOnePage = this.getViewportHeight();\n const lastRowIndex = this.paginationProxy.getPageLastRow();\n let pixelSum = 0;\n let currentIndex = gridCell.rowIndex;\n while (currentIndex >= 0 && currentIndex <= lastRowIndex) {\n const currentCell = this.paginationProxy.getRow(currentIndex);\n if (currentCell) {\n const currentCellHeight = (_a = currentCell.rowHeight) !== null && _a !== void 0 ? _a : 0;\n if (pixelSum + currentCellHeight > pixelsInOnePage) {\n break;\n }\n pixelSum += currentCellHeight;\n }\n currentIndex += step;\n }\n return Math.max(0, Math.min(currentIndex, lastRowIndex));\n }\n getViewportHeight() {\n const gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n const scrollPosition = gridBodyCon.getScrollFeature().getVScrollPosition();\n const scrollbarWidth = this.gridOptionsService.getScrollbarWidth();\n let pixelsInOnePage = scrollPosition.bottom - scrollPosition.top;\n if (this.ctrlsService.getCenterRowContainerCtrl().isHorizontalScrollShowing()) {\n pixelsInOnePage -= scrollbarWidth;\n }\n return pixelsInOnePage;\n }\n isRowTallerThanView(rowIndex) {\n const rowNode = this.paginationProxy.getRow(rowIndex);\n if (!rowNode) {\n return false;\n }\n const rowHeight = rowNode.rowHeight;\n if (typeof rowHeight !== 'number') {\n return false;\n }\n return rowHeight > this.getViewportHeight();\n }\n onCtrlUpDownLeftRight(key, gridCell) {\n const cellToFocus = this.cellNavigationService.getNextCellToFocus(key, gridCell, true);\n const { rowIndex, column } = cellToFocus;\n this.navigateTo({\n scrollIndex: rowIndex,\n scrollType: null,\n scrollColumn: column,\n focusIndex: rowIndex,\n focusColumn: column\n });\n }\n // home brings focus to top left cell, end brings focus to bottom right, grid scrolled to bring\n // same cell into view (which means either scroll all the way up, or all the way down).\n onHomeOrEndKey(key) {\n const homeKey = key === KeyCode.PAGE_HOME;\n const allColumns = this.columnModel.getAllDisplayedColumns();\n const columnToSelect = homeKey ? allColumns[0] : last(allColumns);\n const scrollIndex = homeKey ? this.paginationProxy.getPageFirstRow() : this.paginationProxy.getPageLastRow();\n this.navigateTo({\n scrollIndex: scrollIndex,\n scrollType: null,\n scrollColumn: columnToSelect,\n focusIndex: scrollIndex,\n focusColumn: columnToSelect\n });\n }\n // result of keyboard event\n onTabKeyDown(previous, keyboardEvent) {\n const backwards = keyboardEvent.shiftKey;\n const movedToNextCell = this.tabToNextCellCommon(previous, backwards, keyboardEvent);\n if (movedToNextCell) {\n // only prevent default if we found a cell. so if user is on last cell and hits tab, then we default\n // to the normal tabbing so user can exit the grid.\n keyboardEvent.preventDefault();\n return;\n }\n // if we didn't move to next cell, then need to tab out of the cells, ie to the header (if going\n // backwards)\n if (backwards) {\n const { rowIndex, rowPinned } = previous.getRowPosition();\n const firstRow = rowPinned ? rowIndex === 0 : rowIndex === this.paginationProxy.getPageFirstRow();\n if (firstRow) {\n if (this.gridOptionsService.getNum('headerHeight') === 0) {\n this.focusService.focusNextGridCoreContainer(true, true);\n }\n else {\n keyboardEvent.preventDefault();\n this.focusService.focusPreviousFromFirstCell(keyboardEvent);\n }\n }\n }\n else {\n // if the case it's a popup editor, the focus is on the editor and not the previous cell.\n // in order for the tab navigation to work, we need to focus the browser back onto the\n // previous cell.\n if (previous instanceof CellCtrl) {\n previous.focusCell(true);\n }\n if (this.focusService.focusNextGridCoreContainer(backwards)) {\n keyboardEvent.preventDefault();\n }\n }\n }\n // comes from API\n tabToNextCell(backwards, event) {\n const focusedCell = this.focusService.getFocusedCell();\n // if no focus, then cannot navigate\n if (!focusedCell) {\n return false;\n }\n let cellOrRow = this.getCellByPosition(focusedCell);\n // if cell is not rendered, means user has scrolled away from the cell\n // or that the focusedCell is a Full Width Row\n if (!cellOrRow) {\n cellOrRow = this.rowRenderer.getRowByPosition(focusedCell);\n if (!cellOrRow || !cellOrRow.isFullWidth()) {\n return false;\n }\n }\n return this.tabToNextCellCommon(cellOrRow, backwards, event);\n }\n tabToNextCellCommon(previous, backwards, event) {\n let editing = previous.isEditing();\n // if cell is not editing, there is still chance row is editing if it's Full Row Editing\n if (!editing && previous instanceof CellCtrl) {\n const cell = previous;\n const row = cell.getRowCtrl();\n if (row) {\n editing = row.isEditing();\n }\n }\n let res;\n if (editing) {\n // if we are editing, we know it's not a Full Width Row (RowComp)\n if (this.gridOptionsService.get('editType') === 'fullRow') {\n res = this.moveToNextEditingRow(previous, backwards, event);\n }\n else {\n res = this.moveToNextEditingCell(previous, backwards, event);\n }\n }\n else {\n res = this.moveToNextCellNotEditing(previous, backwards);\n }\n // if a cell wasn't found, it's possible that focus was moved to the header\n return res || !!this.focusService.getFocusedHeader();\n }\n moveToNextEditingCell(previousCell, backwards, event = null) {\n const previousPos = previousCell.getCellPosition();\n // before we stop editing, we need to focus the cell element\n // so the grid doesn't detect that focus has left the grid\n previousCell.getGui().focus();\n // need to do this before getting next cell to edit, in case the next cell\n // has editable function (eg colDef.editable=func() ) and it depends on the\n // result of this cell, so need to save updates from the first edit, in case\n // the value is referenced in the function.\n previousCell.stopEditing();\n // find the next cell to start editing\n const nextCell = this.findNextCellToFocusOn(previousPos, backwards, true);\n if (nextCell == null) {\n return false;\n }\n // only prevent default if we found a cell. so if user is on last cell and hits tab, then we default\n // to the normal tabbing so user can exit the grid.\n nextCell.startEditing(null, true, event);\n nextCell.focusCell(false);\n return true;\n }\n moveToNextEditingRow(previousCell, backwards, event = null) {\n const previousPos = previousCell.getCellPosition();\n // find the next cell to start editing\n const nextCell = this.findNextCellToFocusOn(previousPos, backwards, true);\n if (nextCell == null) {\n return false;\n }\n const nextPos = nextCell.getCellPosition();\n const previousEditable = this.isCellEditable(previousPos);\n const nextEditable = this.isCellEditable(nextPos);\n const rowsMatch = nextPos && previousPos.rowIndex === nextPos.rowIndex && previousPos.rowPinned === nextPos.rowPinned;\n if (previousEditable) {\n previousCell.setFocusOutOnEditor();\n }\n if (!rowsMatch) {\n const pRow = previousCell.getRowCtrl();\n pRow.stopEditing();\n const nRow = nextCell.getRowCtrl();\n nRow.startRowEditing(undefined, undefined, event);\n }\n if (nextEditable) {\n nextCell.setFocusInOnEditor();\n nextCell.focusCell();\n }\n else {\n nextCell.focusCell(true);\n }\n return true;\n }\n moveToNextCellNotEditing(previousCell, backwards) {\n const displayedColumns = this.columnModel.getAllDisplayedColumns();\n let cellPos;\n if (previousCell instanceof RowCtrl) {\n cellPos = Object.assign(Object.assign({}, previousCell.getRowPosition()), { column: backwards ? displayedColumns[0] : last(displayedColumns) });\n }\n else {\n cellPos = previousCell.getCellPosition();\n }\n // find the next cell to start editing\n const nextCell = this.findNextCellToFocusOn(cellPos, backwards, false);\n // only prevent default if we found a cell. so if user is on last cell and hits tab, then we default\n // to the normal tabbing so user can exit the grid.\n if (nextCell instanceof CellCtrl) {\n nextCell.focusCell(true);\n }\n else if (nextCell) {\n return this.tryToFocusFullWidthRow(nextCell.getRowPosition(), backwards);\n }\n return exists(nextCell);\n }\n // called by the cell, when tab is pressed while editing.\n // @return: RenderedCell when navigation successful, otherwise null\n findNextCellToFocusOn(previousPosition, backwards, startEditing) {\n let nextPosition = previousPosition;\n while (true) {\n if (previousPosition !== nextPosition) {\n previousPosition = nextPosition;\n }\n if (!backwards) {\n nextPosition = this.getLastCellOfColSpan(nextPosition);\n }\n nextPosition = this.cellNavigationService.getNextTabbedCell(nextPosition, backwards);\n // allow user to override what cell to go to next\n const userFunc = this.gridOptionsService.getCallback('tabToNextCell');\n if (exists(userFunc)) {\n const params = {\n backwards: backwards,\n editing: startEditing,\n previousCellPosition: previousPosition,\n nextCellPosition: nextPosition ? nextPosition : null\n };\n const userCell = userFunc(params);\n if (exists(userCell)) {\n if (userCell.floating) {\n doOnce(() => { console.warn(`AG Grid: tabToNextCellFunc return type should have attributes: rowIndex, rowPinned, column. However you had 'floating', maybe you meant 'rowPinned'?`); }, 'no floating in userCell');\n userCell.rowPinned = userCell.floating;\n }\n nextPosition = {\n rowIndex: userCell.rowIndex,\n column: userCell.column,\n rowPinned: userCell.rowPinned\n };\n }\n else {\n nextPosition = null;\n }\n }\n // if no 'next cell', means we have got to last cell of grid, so nothing to move to,\n // so bottom right cell going forwards, or top left going backwards\n if (!nextPosition) {\n return null;\n }\n if (nextPosition.rowIndex < 0) {\n const headerLen = this.headerNavigationService.getHeaderRowCount();\n this.focusService.focusHeaderPosition({\n headerPosition: {\n headerRowIndex: headerLen + (nextPosition.rowIndex),\n column: nextPosition.column\n },\n fromCell: true\n });\n return null;\n }\n // if editing, but cell not editable, skip cell. we do this before we do all of\n // the 'ensure index visible' and 'flush all frames', otherwise if we are skipping\n // a bunch of cells (eg 10 rows) then all the work on ensuring cell visible is useless\n // (except for the last one) which causes grid to stall for a while.\n // note - for full row edit, we do focus non-editable cells, as the row stays in edit mode.\n const fullRowEdit = this.gridOptionsService.get('editType') === 'fullRow';\n if (startEditing && !fullRowEdit) {\n const cellIsEditable = this.isCellEditable(nextPosition);\n if (!cellIsEditable) {\n continue;\n }\n }\n this.ensureCellVisible(nextPosition);\n // we have to call this after ensureColumnVisible - otherwise it could be a virtual column\n // or row that is not currently in view, hence the renderedCell would not exist\n const nextCell = this.getCellByPosition(nextPosition);\n // if next cell is fullWidth row, then no rendered cell,\n // as fullWidth rows have no cells, so we skip it\n if (!nextCell) {\n const row = this.rowRenderer.getRowByPosition(nextPosition);\n if (!row || !row.isFullWidth() || startEditing) {\n continue;\n }\n return row;\n }\n if (nextCell.isSuppressNavigable()) {\n continue;\n }\n // by default, when we click a cell, it gets selected into a range, so to keep keyboard navigation\n // consistent, we set into range here also.\n if (this.rangeService) {\n this.rangeService.setRangeToCell(nextPosition);\n }\n // we successfully tabbed onto a grid cell, so return true\n return nextCell;\n }\n }\n isCellEditable(cell) {\n const rowNode = this.lookupRowNodeForCell(cell);\n if (rowNode) {\n return cell.column.isCellEditable(rowNode);\n }\n return false;\n }\n getCellByPosition(cellPosition) {\n const rowCtrl = this.rowRenderer.getRowByPosition(cellPosition);\n if (!rowCtrl) {\n return null;\n }\n return rowCtrl.getCellCtrl(cellPosition.column);\n }\n lookupRowNodeForCell(cell) {\n if (cell.rowPinned === 'top') {\n return this.pinnedRowModel.getPinnedTopRow(cell.rowIndex);\n }\n if (cell.rowPinned === 'bottom') {\n return this.pinnedRowModel.getPinnedBottomRow(cell.rowIndex);\n }\n return this.paginationProxy.getRow(cell.rowIndex);\n }\n // we use index for rows, but column object for columns, as the next column (by index) might not\n // be visible (header grouping) so it's not reliable, so using the column object instead.\n navigateToNextCell(event, key, currentCell, allowUserOverride) {\n // we keep searching for a next cell until we find one. this is how the group rows get skipped\n let nextCell = currentCell;\n let hitEdgeOfGrid = false;\n while (nextCell && (nextCell === currentCell || !this.isValidNavigateCell(nextCell))) {\n // if the current cell is spanning across multiple columns, we need to move\n // our current position to be the last cell on the right before finding the\n // the next target.\n if (this.gridOptionsService.is('enableRtl')) {\n if (key === KeyCode.LEFT) {\n nextCell = this.getLastCellOfColSpan(nextCell);\n }\n }\n else if (key === KeyCode.RIGHT) {\n nextCell = this.getLastCellOfColSpan(nextCell);\n }\n nextCell = this.cellNavigationService.getNextCellToFocus(key, nextCell);\n // eg if going down, and nextCell=undefined, means we are gone past the last row\n hitEdgeOfGrid = missing(nextCell);\n }\n if (hitEdgeOfGrid && event && event.key === KeyCode.UP) {\n nextCell = {\n rowIndex: -1,\n rowPinned: null,\n column: currentCell.column\n };\n }\n // allow user to override what cell to go to next. when doing normal cell navigation (with keys)\n // we allow this, however if processing 'enter after edit' we don't allow override\n if (allowUserOverride) {\n const userFunc = this.gridOptionsService.getCallback('navigateToNextCell');\n if (exists(userFunc)) {\n const params = {\n key: key,\n previousCellPosition: currentCell,\n nextCellPosition: nextCell ? nextCell : null,\n event: event\n };\n const userCell = userFunc(params);\n if (exists(userCell)) {\n if (userCell.floating) {\n doOnce(() => { console.warn(`AG Grid: tabToNextCellFunc return type should have attributes: rowIndex, rowPinned, column. However you had 'floating', maybe you meant 'rowPinned'?`); }, 'no floating in userCell');\n userCell.rowPinned = userCell.floating;\n }\n nextCell = {\n rowPinned: userCell.rowPinned,\n rowIndex: userCell.rowIndex,\n column: userCell.column\n };\n }\n else {\n nextCell = null;\n }\n }\n }\n // no next cell means we have reached a grid boundary, eg left, right, top or bottom of grid\n if (!nextCell) {\n return;\n }\n if (nextCell.rowIndex < 0) {\n const headerLen = this.headerNavigationService.getHeaderRowCount();\n this.focusService.focusHeaderPosition({\n headerPosition: { headerRowIndex: headerLen + (nextCell.rowIndex), column: currentCell.column },\n event: event || undefined,\n fromCell: true\n });\n return;\n }\n // in case we have col spanning we get the cellComp and use it to get the\n // position. This was we always focus the first cell inside the spanning.\n const normalisedPosition = this.getNormalisedPosition(nextCell);\n if (normalisedPosition) {\n this.focusPosition(normalisedPosition);\n }\n else {\n this.tryToFocusFullWidthRow(nextCell);\n }\n }\n getNormalisedPosition(cellPosition) {\n // ensureCellVisible first, to make sure cell at position is rendered.\n this.ensureCellVisible(cellPosition);\n const cellCtrl = this.getCellByPosition(cellPosition);\n // not guaranteed to have a cellComp when using the SSRM as blocks are loading.\n if (!cellCtrl) {\n return null;\n }\n cellPosition = cellCtrl.getCellPosition();\n // we call this again, as nextCell can be different to it's previous value due to Column Spanning\n // (ie if cursor moving from right to left, and cell is spanning columns, then nextCell was the\n // last column in the group, however now it's the first column in the group). if we didn't do\n // ensureCellVisible again, then we could only be showing the last portion (last column) of the\n // merged cells.\n this.ensureCellVisible(cellPosition);\n return cellPosition;\n }\n tryToFocusFullWidthRow(position, backwards = false) {\n const displayedColumns = this.columnModel.getAllDisplayedColumns();\n const rowComp = this.rowRenderer.getRowByPosition(position);\n if (!rowComp || !rowComp.isFullWidth()) {\n return false;\n }\n const currentCellFocused = this.focusService.getFocusedCell();\n const cellPosition = {\n rowIndex: position.rowIndex,\n rowPinned: position.rowPinned,\n column: position.column || (backwards ? last(displayedColumns) : displayedColumns[0])\n };\n this.focusPosition(cellPosition);\n const fromBelow = currentCellFocused != null ? this.rowPositionUtils.before(cellPosition, currentCellFocused) : false;\n const focusEvent = {\n type: Events.EVENT_FULL_WIDTH_ROW_FOCUSED,\n rowIndex: cellPosition.rowIndex,\n rowPinned: cellPosition.rowPinned,\n column: cellPosition.column,\n isFullWidthCell: true,\n floating: cellPosition.rowPinned,\n fromBelow\n };\n this.eventService.dispatchEvent(focusEvent);\n return true;\n }\n focusPosition(cellPosition) {\n this.focusService.setFocusedCell({\n rowIndex: cellPosition.rowIndex,\n column: cellPosition.column,\n rowPinned: cellPosition.rowPinned,\n forceBrowserFocus: true\n });\n if (this.rangeService) {\n this.rangeService.setRangeToCell(cellPosition);\n }\n }\n isValidNavigateCell(cell) {\n const rowNode = this.rowPositionUtils.getRowNode(cell);\n // we do not allow focusing on detail rows and full width rows\n return !!rowNode;\n }\n getLastCellOfColSpan(cell) {\n const cellCtrl = this.getCellByPosition(cell);\n if (!cellCtrl) {\n return cell;\n }\n const colSpanningList = cellCtrl.getColSpanningList();\n if (colSpanningList.length === 1) {\n return cell;\n }\n return {\n rowIndex: cell.rowIndex,\n column: last(colSpanningList),\n rowPinned: cell.rowPinned\n };\n }\n ensureCellVisible(gridCell) {\n const isGroupStickyEnabled = this.gridOptionsService.isGroupRowsSticky();\n const rowNode = this.rowModel.getRow(gridCell.rowIndex);\n // sticky rows are always visible, so the grid shouldn't scroll to focus them.\n const skipScrollToRow = isGroupStickyEnabled && (rowNode === null || rowNode === void 0 ? void 0 : rowNode.sticky);\n // this scrolls the row into view\n if (!skipScrollToRow && missing(gridCell.rowPinned)) {\n this.gridBodyCon.getScrollFeature().ensureIndexVisible(gridCell.rowIndex);\n }\n if (!gridCell.column.isPinned()) {\n this.gridBodyCon.getScrollFeature().ensureColumnVisible(gridCell.column);\n }\n }\n};\n__decorate([\n Autowired('mouseEventService')\n], NavigationService.prototype, \"mouseEventService\", void 0);\n__decorate([\n Autowired('paginationProxy')\n], NavigationService.prototype, \"paginationProxy\", void 0);\n__decorate([\n Autowired('focusService')\n], NavigationService.prototype, \"focusService\", void 0);\n__decorate([\n Optional('rangeService')\n], NavigationService.prototype, \"rangeService\", void 0);\n__decorate([\n Autowired('columnModel')\n], NavigationService.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('rowModel')\n], NavigationService.prototype, \"rowModel\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], NavigationService.prototype, \"ctrlsService\", void 0);\n__decorate([\n Autowired('rowRenderer')\n], NavigationService.prototype, \"rowRenderer\", void 0);\n__decorate([\n Autowired('headerNavigationService')\n], NavigationService.prototype, \"headerNavigationService\", void 0);\n__decorate([\n Autowired(\"rowPositionUtils\")\n], NavigationService.prototype, \"rowPositionUtils\", void 0);\n__decorate([\n Autowired(\"cellNavigationService\")\n], NavigationService.prototype, \"cellNavigationService\", void 0);\n__decorate([\n Autowired(\"pinnedRowModel\")\n], NavigationService.prototype, \"pinnedRowModel\", void 0);\n__decorate([\n PostConstruct\n], NavigationService.prototype, \"postConstruct\", null);\nNavigationService = __decorate([\n Bean('navigationService')\n], NavigationService);\nexport { NavigationService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PopupComponent } from \"../../widgets/popupComponent.mjs\";\nimport { isUserSuppressingKeyboardEvent } from \"../../utils/keyboard.mjs\";\nimport { PostConstruct } from \"../../context/context.mjs\";\nexport class PopupEditorWrapper extends PopupComponent {\n constructor(params) {\n super(/* html */ `
`);\n this.params = params;\n }\n postConstruct() {\n this.gridOptionsService.setDomData(this.getGui(), PopupEditorWrapper.DOM_KEY_POPUP_EDITOR_WRAPPER, true);\n this.addKeyDownListener();\n }\n addKeyDownListener() {\n const eGui = this.getGui();\n const params = this.params;\n const listener = (event) => {\n if (!isUserSuppressingKeyboardEvent(this.gridOptionsService, event, params.node, params.column, true)) {\n params.onKeyDown(event);\n }\n };\n this.addManagedListener(eGui, 'keydown', listener);\n }\n}\nPopupEditorWrapper.DOM_KEY_POPUP_EDITOR_WRAPPER = 'popupEditorWrapper';\n__decorate([\n PostConstruct\n], PopupEditorWrapper.prototype, \"postConstruct\", null);\n","import { Component } from \"../../widgets/component.mjs\";\nimport { PopupEditorWrapper } from \"./../cellEditors/popupEditorWrapper.mjs\";\nimport { setAriaRole } from \"../../utils/aria.mjs\";\nimport { escapeString } from \"../../utils/string.mjs\";\nimport { missing } from \"../../utils/generic.mjs\";\nimport { addStylesToElement, clearElement, loadTemplate, removeFromParent } from \"../../utils/dom.mjs\";\nimport { browserSupportsPreventScroll } from \"../../utils/browser.mjs\";\nexport class CellComp extends Component {\n constructor(beans, cellCtrl, printLayout, eRow, editingRow) {\n super();\n // every time we go into edit mode, or back again, this gets incremented.\n // it's the components way of dealing with the async nature of framework components,\n // so if a framework component takes a while to be created, we know if the object\n // is still relevant when creating is finished. eg we could click edit / un-edit 20\n // times before the first React edit component comes back - we should discard\n // the first 19.\n this.rendererVersion = 0;\n this.editorVersion = 0;\n this.beans = beans;\n this.column = cellCtrl.getColumn();\n this.rowNode = cellCtrl.getRowNode();\n this.rowCtrl = cellCtrl.getRowCtrl();\n this.eRow = eRow;\n this.cellCtrl = cellCtrl;\n this.setTemplate(/* html */ `
`);\n const eGui = this.getGui();\n this.forceWrapper = cellCtrl.isForceWrapper();\n this.refreshWrapper(false);\n const setAttribute = (name, value) => {\n if (value != null && value != '') {\n eGui.setAttribute(name, value);\n }\n else {\n eGui.removeAttribute(name);\n }\n };\n setAriaRole(eGui, 'gridcell');\n setAttribute('col-id', cellCtrl.getColumnIdSanitised());\n const tabIndex = cellCtrl.getTabIndex();\n if (tabIndex !== undefined) {\n setAttribute('tabindex', tabIndex.toString());\n }\n const compProxy = {\n addOrRemoveCssClass: (cssClassName, on) => this.addOrRemoveCssClass(cssClassName, on),\n setUserStyles: (styles) => addStylesToElement(eGui, styles),\n getFocusableElement: () => this.getFocusableElement(),\n setIncludeSelection: include => this.includeSelection = include,\n setIncludeRowDrag: include => this.includeRowDrag = include,\n setIncludeDndSource: include => this.includeDndSource = include,\n setRenderDetails: (compDetails, valueToDisplay, force) => this.setRenderDetails(compDetails, valueToDisplay, force),\n setEditDetails: (compDetails, popup, position) => this.setEditDetails(compDetails, popup, position),\n getCellEditor: () => this.cellEditor || null,\n getCellRenderer: () => this.cellRenderer || null,\n getParentOfValue: () => this.getParentOfValue()\n };\n cellCtrl.setComp(compProxy, this.getGui(), this.eCellWrapper, printLayout, editingRow);\n }\n getParentOfValue() {\n if (this.eCellValue) {\n // if not editing, and using wrapper, then value goes in eCellValue\n return this.eCellValue;\n }\n if (this.eCellWrapper) {\n // if editing, and using wrapper, value (cell editor) goes in eCellWrapper\n return this.eCellWrapper;\n }\n // if editing or rendering, and not using wrapper, value (or comp) is directly inside cell\n return this.getGui();\n }\n setRenderDetails(compDetails, valueToDisplay, forceNewCellRendererInstance) {\n // this can happen if the users asks for the cell to refresh, but we are not showing the vale as we are editing\n const isInlineEditing = this.cellEditor && !this.cellEditorPopupWrapper;\n if (isInlineEditing) {\n return;\n }\n // this means firstRender will be true for one pass only, as it's initialised to undefined\n this.firstRender = this.firstRender == null;\n // if display template has changed, means any previous Cell Renderer is in the wrong location\n const controlWrapperChanged = this.refreshWrapper(false);\n this.refreshEditStyles(false);\n // all of these have dependencies on the eGui, so only do them after eGui is set\n if (compDetails) {\n const neverRefresh = forceNewCellRendererInstance || controlWrapperChanged;\n const cellRendererRefreshSuccessful = neverRefresh ? false : this.refreshCellRenderer(compDetails);\n if (!cellRendererRefreshSuccessful) {\n this.destroyRenderer();\n this.createCellRendererInstance(compDetails);\n }\n }\n else {\n this.destroyRenderer();\n this.insertValueWithoutCellRenderer(valueToDisplay);\n }\n }\n setEditDetails(compDetails, popup, position) {\n if (compDetails) {\n this.createCellEditorInstance(compDetails, popup, position);\n }\n else {\n this.destroyEditor();\n }\n }\n removeControls() {\n this.checkboxSelectionComp = this.beans.context.destroyBean(this.checkboxSelectionComp);\n this.dndSourceComp = this.beans.context.destroyBean(this.dndSourceComp);\n this.rowDraggingComp = this.beans.context.destroyBean(this.rowDraggingComp);\n }\n // returns true if wrapper was changed\n refreshWrapper(editing) {\n const providingControls = this.includeRowDrag || this.includeDndSource || this.includeSelection;\n const usingWrapper = providingControls || this.forceWrapper;\n const putWrapperIn = usingWrapper && this.eCellWrapper == null;\n if (putWrapperIn) {\n this.eCellWrapper = loadTemplate(/* html */ `
`);\n this.getGui().appendChild(this.eCellWrapper);\n }\n const takeWrapperOut = !usingWrapper && this.eCellWrapper != null;\n if (takeWrapperOut) {\n removeFromParent(this.eCellWrapper);\n this.eCellWrapper = undefined;\n }\n this.addOrRemoveCssClass('ag-cell-value', !usingWrapper);\n const usingCellValue = !editing && usingWrapper;\n const putCellValueIn = usingCellValue && this.eCellValue == null;\n if (putCellValueIn) {\n this.eCellValue = loadTemplate(/* html */ ``);\n this.eCellWrapper.appendChild(this.eCellValue);\n }\n const takeCellValueOut = !usingCellValue && this.eCellValue != null;\n if (takeCellValueOut) {\n removeFromParent(this.eCellValue);\n this.eCellValue = undefined;\n }\n const templateChanged = putWrapperIn || takeWrapperOut || putCellValueIn || takeCellValueOut;\n if (templateChanged) {\n this.removeControls();\n }\n if (!editing) {\n if (providingControls) {\n this.addControls();\n }\n }\n return templateChanged;\n }\n addControls() {\n if (this.includeRowDrag) {\n if (this.rowDraggingComp == null) {\n this.rowDraggingComp = this.cellCtrl.createRowDragComp();\n if (this.rowDraggingComp) {\n // put the checkbox in before the value\n this.eCellWrapper.insertBefore(this.rowDraggingComp.getGui(), this.eCellValue);\n }\n }\n }\n if (this.includeDndSource) {\n if (this.dndSourceComp == null) {\n this.dndSourceComp = this.cellCtrl.createDndSource();\n // put the checkbox in before the value\n this.eCellWrapper.insertBefore(this.dndSourceComp.getGui(), this.eCellValue);\n }\n }\n if (this.includeSelection) {\n if (this.checkboxSelectionComp == null) {\n this.checkboxSelectionComp = this.cellCtrl.createSelectionCheckbox();\n this.eCellWrapper.insertBefore(this.checkboxSelectionComp.getGui(), this.eCellValue);\n }\n }\n }\n createCellEditorInstance(compDetails, popup, position) {\n const versionCopy = this.editorVersion;\n const cellEditorPromise = compDetails.newAgStackInstance();\n if (!cellEditorPromise) {\n return;\n } // if empty, userComponentFactory already did a console message\n const { params } = compDetails;\n cellEditorPromise.then(c => this.afterCellEditorCreated(versionCopy, c, params, popup, position));\n // if we don't do this, and editor component is async, then there will be a period\n // when the component isn't present and keyboard navigation won't work - so example\n // of user hitting tab quickly (more quickly than renderers getting created) won't work\n const cellEditorAsync = missing(this.cellEditor);\n if (cellEditorAsync && params.cellStartedEdit) {\n this.cellCtrl.focusCell(true);\n }\n }\n insertValueWithoutCellRenderer(valueToDisplay) {\n const eParent = this.getParentOfValue();\n clearElement(eParent);\n const escapedValue = valueToDisplay != null ? escapeString(valueToDisplay) : null;\n if (escapedValue != null) {\n eParent.innerHTML = escapedValue;\n }\n }\n destroyEditorAndRenderer() {\n this.destroyRenderer();\n this.destroyEditor();\n }\n destroyRenderer() {\n const { context } = this.beans;\n this.cellRenderer = context.destroyBean(this.cellRenderer);\n removeFromParent(this.cellRendererGui);\n this.cellRendererGui = null;\n this.rendererVersion++;\n }\n destroyEditor() {\n const { context } = this.beans;\n if (this.hideEditorPopup) {\n this.hideEditorPopup();\n }\n this.hideEditorPopup = undefined;\n this.cellEditor = context.destroyBean(this.cellEditor);\n this.cellEditorPopupWrapper = context.destroyBean(this.cellEditorPopupWrapper);\n removeFromParent(this.cellEditorGui);\n this.cellEditorGui = null;\n this.editorVersion++;\n }\n refreshCellRenderer(compClassAndParams) {\n if (this.cellRenderer == null || this.cellRenderer.refresh == null) {\n return false;\n }\n // if different Cell Renderer configured this time (eg user is using selector, and\n // returns different component) then don't refresh, force recreate of Cell Renderer\n if (this.cellRendererClass !== compClassAndParams.componentClass) {\n return false;\n }\n // take any custom params off of the user\n const result = this.cellRenderer.refresh(compClassAndParams.params);\n // NOTE on undefined: previous version of the cellRenderer.refresh() interface\n // returned nothing, if the method existed, we assumed it refreshed. so for\n // backwards compatibility, we assume if method exists and returns nothing,\n // that it was successful.\n return result === true || result === undefined;\n }\n createCellRendererInstance(compDetails) {\n // never use task service if animation frame service is turned off.\n // and lastly we never use it if doing auto-height, as the auto-height service checks the\n // row height directly after the cell is created, it doesn't wait around for the tasks to complete \n const suppressAnimationFrame = this.beans.gridOptionsService.is('suppressAnimationFrame');\n const useTaskService = !suppressAnimationFrame;\n const displayComponentVersionCopy = this.rendererVersion;\n const { componentClass } = compDetails;\n const createCellRendererFunc = () => {\n const staleTask = this.rendererVersion !== displayComponentVersionCopy || !this.isAlive();\n if (staleTask) {\n return;\n }\n // this can return null in the event that the user has switched from a renderer component to nothing, for example\n // when using a cellRendererSelect to return a component or null depending on row data etc\n const componentPromise = compDetails.newAgStackInstance();\n const callback = this.afterCellRendererCreated.bind(this, displayComponentVersionCopy, componentClass);\n if (componentPromise) {\n componentPromise.then(callback);\n }\n };\n // we only use task service when rendering for first time, which means it is not used when doing edits.\n // if we changed this (always use task service) would make sense, however it would break tests, possibly\n // test of users.\n if (useTaskService && this.firstRender) {\n this.beans.animationFrameService.createTask(createCellRendererFunc, this.rowNode.rowIndex, 'createTasksP2');\n }\n else {\n createCellRendererFunc();\n }\n }\n getCtrl() {\n return this.cellCtrl;\n }\n getRowCtrl() {\n return this.rowCtrl;\n }\n getCellRenderer() {\n return this.cellRenderer;\n }\n getCellEditor() {\n return this.cellEditor;\n }\n afterCellRendererCreated(cellRendererVersion, cellRendererClass, cellRenderer) {\n const staleTask = !this.isAlive() || cellRendererVersion !== this.rendererVersion;\n if (staleTask) {\n this.beans.context.destroyBean(cellRenderer);\n return;\n }\n this.cellRenderer = cellRenderer;\n this.cellRendererClass = cellRendererClass;\n this.cellRendererGui = this.cellRenderer.getGui();\n if (this.cellRendererGui != null) {\n const eParent = this.getParentOfValue();\n clearElement(eParent);\n eParent.appendChild(this.cellRendererGui);\n }\n }\n afterCellEditorCreated(requestVersion, cellEditor, params, popup, position) {\n // if editingCell=false, means user cancelled the editor before component was ready.\n // if versionMismatch, then user cancelled the edit, then started the edit again, and this\n // is the first editor which is now stale.\n const staleComp = requestVersion !== this.editorVersion;\n if (staleComp) {\n this.beans.context.destroyBean(cellEditor);\n return;\n }\n const editingCancelledByUserComp = cellEditor.isCancelBeforeStart && cellEditor.isCancelBeforeStart();\n if (editingCancelledByUserComp) {\n this.beans.context.destroyBean(cellEditor);\n this.cellCtrl.stopEditing(true);\n return;\n }\n if (!cellEditor.getGui) {\n console.warn(`AG Grid: cellEditor for column ${this.column.getId()} is missing getGui() method`);\n this.beans.context.destroyBean(cellEditor);\n return;\n }\n this.cellEditor = cellEditor;\n this.cellEditorGui = cellEditor.getGui();\n const cellEditorInPopup = popup || (cellEditor.isPopup !== undefined && cellEditor.isPopup());\n if (cellEditorInPopup) {\n this.addPopupCellEditor(params, position);\n }\n else {\n this.addInCellEditor();\n }\n this.refreshEditStyles(true, cellEditorInPopup);\n if (cellEditor.afterGuiAttached) {\n cellEditor.afterGuiAttached();\n }\n }\n refreshEditStyles(editing, isPopup) {\n var _a;\n this.addOrRemoveCssClass('ag-cell-inline-editing', editing && !isPopup);\n this.addOrRemoveCssClass('ag-cell-popup-editing', editing && !!isPopup);\n this.addOrRemoveCssClass('ag-cell-not-inline-editing', !editing || !!isPopup);\n (_a = this.rowCtrl) === null || _a === void 0 ? void 0 : _a.setInlineEditingCss(editing);\n }\n addInCellEditor() {\n const eGui = this.getGui();\n // if focus is inside the cell, we move focus to the cell itself\n // before removing it's contents, otherwise errors could be thrown.\n const eDocument = this.beans.gridOptionsService.getDocument();\n if (eGui.contains(eDocument.activeElement)) {\n eGui.focus();\n }\n this.destroyRenderer();\n this.refreshWrapper(true);\n this.clearParentOfValue();\n if (this.cellEditorGui) {\n const eParent = this.getParentOfValue();\n eParent.appendChild(this.cellEditorGui);\n }\n }\n addPopupCellEditor(params, position) {\n if (this.beans.gridOptionsService.get('editType') === 'fullRow') {\n console.warn('AG Grid: popup cellEditor does not work with fullRowEdit - you cannot use them both ' +\n '- either turn off fullRowEdit, or stop using popup editors.');\n }\n const cellEditor = this.cellEditor;\n // if a popup, then we wrap in a popup editor and return the popup\n this.cellEditorPopupWrapper = this.beans.context.createBean(new PopupEditorWrapper(params));\n const ePopupGui = this.cellEditorPopupWrapper.getGui();\n if (this.cellEditorGui) {\n ePopupGui.appendChild(this.cellEditorGui);\n }\n const popupService = this.beans.popupService;\n const useModelPopup = this.beans.gridOptionsService.is('stopEditingWhenCellsLoseFocus');\n // see if position provided by colDef, if not then check old way of method on cellComp\n const positionToUse = position != null\n ? position\n : cellEditor.getPopupPosition\n ? cellEditor.getPopupPosition()\n : 'over';\n const isRtl = this.beans.gridOptionsService.is('enableRtl');\n const positionParams = {\n ePopup: ePopupGui,\n column: this.column,\n rowNode: this.rowNode,\n type: 'popupCellEditor',\n eventSource: this.getGui(),\n position: positionToUse,\n alignSide: isRtl ? 'right' : 'left',\n keepWithinBounds: true\n };\n const positionCallback = popupService.positionPopupByComponent.bind(popupService, positionParams);\n const translate = this.beans.localeService.getLocaleTextFunc();\n const addPopupRes = popupService.addPopup({\n modal: useModelPopup,\n eChild: ePopupGui,\n closeOnEsc: true,\n closedCallback: () => { this.cellCtrl.onPopupEditorClosed(); },\n anchorToElement: this.getGui(),\n positionCallback,\n ariaLabel: translate('ariaLabelCellEditor', 'Cell Editor')\n });\n if (addPopupRes) {\n this.hideEditorPopup = addPopupRes.hideFunc;\n }\n }\n detach() {\n this.eRow.removeChild(this.getGui());\n }\n // if the row is also getting destroyed, then we don't need to remove from dom,\n // as the row will also get removed, so no need to take out the cells from the row\n // if the row is going (removing is an expensive operation, so only need to remove\n // the top part)\n //\n // note - this is NOT called by context, as we don't wire / unwire the CellComp for performance reasons.\n destroy() {\n this.cellCtrl.stopEditing();\n this.destroyEditorAndRenderer();\n this.removeControls();\n super.destroy();\n }\n clearParentOfValue() {\n const eGui = this.getGui();\n // if focus is inside the cell, we move focus to the cell itself\n // before removing it's contents, otherwise errors could be thrown.\n const eDocument = this.beans.gridOptionsService.getDocument();\n if (eGui.contains(eDocument.activeElement) && browserSupportsPreventScroll()) {\n eGui.focus({ preventScroll: true });\n }\n clearElement(this.getParentOfValue());\n }\n}\n","import { Component } from \"../../widgets/component.mjs\";\nimport { addStylesToElement, setDomChildOrder } from \"../../utils/dom.mjs\";\nimport { CellComp } from \"../cell/cellComp.mjs\";\nimport { getAllValuesInObject } from \"../../utils/object.mjs\";\nimport { setAriaRole } from \"../../utils/aria.mjs\";\nexport class RowComp extends Component {\n constructor(ctrl, beans, containerType) {\n super();\n this.cellComps = {};\n this.beans = beans;\n this.rowCtrl = ctrl;\n this.setTemplate(/* html */ `
`);\n const eGui = this.getGui();\n const style = eGui.style;\n this.domOrder = this.rowCtrl.getDomOrder();\n setAriaRole(eGui, 'row');\n const tabIndex = this.rowCtrl.getTabIndex();\n if (tabIndex != null) {\n eGui.setAttribute('tabindex', tabIndex.toString());\n }\n const compProxy = {\n setDomOrder: domOrder => this.domOrder = domOrder,\n setCellCtrls: cellCtrls => this.setCellCtrls(cellCtrls),\n showFullWidth: compDetails => this.showFullWidth(compDetails),\n getFullWidthCellRenderer: () => this.getFullWidthCellRenderer(),\n addOrRemoveCssClass: (name, on) => this.addOrRemoveCssClass(name, on),\n setUserStyles: (styles) => addStylesToElement(eGui, styles),\n setTop: top => style.top = top,\n setTransform: transform => style.transform = transform,\n setRowIndex: rowIndex => eGui.setAttribute('row-index', rowIndex),\n setRowId: (rowId) => eGui.setAttribute('row-id', rowId),\n setRowBusinessKey: businessKey => eGui.setAttribute('row-business-key', businessKey),\n };\n ctrl.setComp(compProxy, this.getGui(), containerType);\n this.addDestroyFunc(() => {\n ctrl.unsetComp(containerType);\n });\n }\n getInitialStyle(containerType) {\n const transform = this.rowCtrl.getInitialTransform(containerType);\n const top = this.rowCtrl.getInitialRowTop(containerType);\n return transform ? `transform: ${transform}` : `top: ${top}`;\n }\n showFullWidth(compDetails) {\n const callback = (cellRenderer) => {\n if (this.isAlive()) {\n const eGui = cellRenderer.getGui();\n this.getGui().appendChild(eGui);\n this.rowCtrl.setupDetailRowAutoHeight(eGui);\n this.setFullWidthRowComp(cellRenderer);\n }\n else {\n this.beans.context.destroyBean(cellRenderer);\n }\n };\n // if not in cache, create new one\n const res = compDetails.newAgStackInstance();\n if (!res) {\n return;\n }\n res.then(callback);\n }\n setCellCtrls(cellCtrls) {\n const cellsToRemove = Object.assign({}, this.cellComps);\n cellCtrls.forEach(cellCtrl => {\n const key = cellCtrl.getInstanceId();\n const existingCellComp = this.cellComps[key];\n if (existingCellComp == null) {\n this.newCellComp(cellCtrl);\n }\n else {\n cellsToRemove[key] = null;\n }\n });\n const cellCompsToRemove = getAllValuesInObject(cellsToRemove)\n .filter(cellComp => cellComp != null);\n this.destroyCells(cellCompsToRemove);\n this.ensureDomOrder(cellCtrls);\n }\n ensureDomOrder(cellCtrls) {\n if (!this.domOrder) {\n return;\n }\n const elementsInOrder = [];\n cellCtrls.forEach(cellCtrl => {\n const cellComp = this.cellComps[cellCtrl.getInstanceId()];\n if (cellComp) {\n elementsInOrder.push(cellComp.getGui());\n }\n });\n setDomChildOrder(this.getGui(), elementsInOrder);\n }\n newCellComp(cellCtrl) {\n const cellComp = new CellComp(this.beans, cellCtrl, this.rowCtrl.isPrintLayout(), this.getGui(), this.rowCtrl.isEditing());\n this.cellComps[cellCtrl.getInstanceId()] = cellComp;\n this.getGui().appendChild(cellComp.getGui());\n }\n destroy() {\n super.destroy();\n this.destroyAllCells();\n }\n destroyAllCells() {\n const cellsToDestroy = getAllValuesInObject(this.cellComps).filter(cp => cp != null);\n this.destroyCells(cellsToDestroy);\n }\n setFullWidthRowComp(fullWidthRowComponent) {\n if (this.fullWidthCellRenderer) {\n console.error('AG Grid - should not be setting fullWidthRowComponent twice');\n }\n this.fullWidthCellRenderer = fullWidthRowComponent;\n this.addDestroyFunc(() => {\n this.fullWidthCellRenderer = this.beans.context.destroyBean(this.fullWidthCellRenderer);\n });\n }\n getFullWidthCellRenderer() {\n return this.fullWidthCellRenderer;\n }\n destroyCells(cellComps) {\n cellComps.forEach(cellComp => {\n // could be old reference, ie removed cell\n if (!cellComp) {\n return;\n }\n // check cellComp belongs in this container\n const instanceId = cellComp.getCtrl().getInstanceId();\n if (this.cellComps[instanceId] !== cellComp) {\n return;\n }\n cellComp.detach();\n cellComp.destroy();\n this.cellComps[instanceId] = null;\n });\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from \"../../widgets/component.mjs\";\nimport { RefSelector } from \"../../widgets/componentAnnotations.mjs\";\nimport { Autowired, PostConstruct, PreDestroy } from \"../../context/context.mjs\";\nimport { getRowContainerTypeForName, RowContainerCtrl, RowContainerName } from \"./rowContainerCtrl.mjs\";\nimport { ensureDomOrder, insertWithDomOrder } from \"../../utils/dom.mjs\";\nimport { RowComp } from \"../../rendering/row/rowComp.mjs\";\nimport { getAllValuesInObject } from \"../../utils/object.mjs\";\nimport { setAriaRole } from \"../../utils/aria.mjs\";\nfunction templateFactory() {\n const name = Component.elementGettingCreated.getAttribute('name');\n const cssClasses = RowContainerCtrl.getRowContainerCssClasses(name);\n let res;\n const centerTemplate = name === RowContainerName.CENTER ||\n name === RowContainerName.TOP_CENTER ||\n name === RowContainerName.STICKY_TOP_CENTER ||\n name === RowContainerName.BOTTOM_CENTER;\n if (centerTemplate) {\n res = /* html */\n `
\n
\n
`;\n }\n else {\n res = /* html */\n `
`;\n }\n return res;\n}\nexport class RowContainerComp extends Component {\n constructor() {\n super(templateFactory());\n this.rowComps = {};\n this.name = Component.elementGettingCreated.getAttribute('name');\n this.type = getRowContainerTypeForName(this.name);\n }\n postConstruct() {\n const compProxy = {\n setViewportHeight: height => this.eViewport.style.height = height,\n setRowCtrls: rowCtrls => this.setRowCtrls(rowCtrls),\n setDomOrder: domOrder => {\n this.domOrder = domOrder;\n },\n setContainerWidth: width => this.eContainer.style.width = width\n };\n const ctrl = this.createManagedBean(new RowContainerCtrl(this.name));\n ctrl.setComp(compProxy, this.eContainer, this.eViewport);\n }\n preDestroy() {\n // destroys all row comps\n this.setRowCtrls([]);\n }\n setRowCtrls(rowCtrls) {\n const oldRows = Object.assign({}, this.rowComps);\n this.rowComps = {};\n this.lastPlacedElement = null;\n const processRow = (rowCon) => {\n const instanceId = rowCon.getInstanceId();\n const existingRowComp = oldRows[instanceId];\n if (existingRowComp) {\n this.rowComps[instanceId] = existingRowComp;\n delete oldRows[instanceId];\n this.ensureDomOrder(existingRowComp.getGui());\n }\n else {\n // don't create new row comps for rows which are not displayed. still want the existing components\n // as they may be animating out.\n if (!rowCon.getRowNode().displayed) {\n return;\n }\n const rowComp = new RowComp(rowCon, this.beans, this.type);\n this.rowComps[instanceId] = rowComp;\n this.appendRow(rowComp.getGui());\n }\n };\n rowCtrls.forEach(processRow);\n getAllValuesInObject(oldRows).forEach(oldRowComp => {\n this.eContainer.removeChild(oldRowComp.getGui());\n oldRowComp.destroy();\n });\n setAriaRole(this.eContainer, rowCtrls.length ? \"rowgroup\" : \"presentation\");\n }\n appendRow(element) {\n if (this.domOrder) {\n insertWithDomOrder(this.eContainer, element, this.lastPlacedElement);\n }\n else {\n this.eContainer.appendChild(element);\n }\n this.lastPlacedElement = element;\n }\n ensureDomOrder(eRow) {\n if (this.domOrder) {\n ensureDomOrder(this.eContainer, eRow, this.lastPlacedElement);\n this.lastPlacedElement = eRow;\n }\n }\n}\n__decorate([\n Autowired('beans')\n], RowContainerComp.prototype, \"beans\", void 0);\n__decorate([\n RefSelector('eViewport')\n], RowContainerComp.prototype, \"eViewport\", void 0);\n__decorate([\n RefSelector('eContainer')\n], RowContainerComp.prototype, \"eContainer\", void 0);\n__decorate([\n PostConstruct\n], RowContainerComp.prototype, \"postConstruct\", null);\n__decorate([\n PreDestroy\n], RowContainerComp.prototype, \"preDestroy\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { DragAndDropService } from \"../../dragAndDrop/dragAndDropService.mjs\";\nimport { Autowired } from \"../../context/context.mjs\";\nexport class BodyDropPivotTarget {\n constructor(pinned) {\n this.columnsToAggregate = [];\n this.columnsToGroup = [];\n this.columnsToPivot = [];\n this.pinned = pinned;\n }\n /** Callback for when drag enters */\n onDragEnter(draggingEvent) {\n this.clearColumnsList();\n // in pivot mode, we don't accept any drops if functions are read only\n if (this.gridOptionsService.is('functionsReadOnly')) {\n return;\n }\n const dragColumns = draggingEvent.dragItem.columns;\n if (!dragColumns) {\n return;\n }\n dragColumns.forEach(column => {\n // we don't allow adding secondary columns\n if (!column.isPrimary()) {\n return;\n }\n if (column.isAnyFunctionActive()) {\n return;\n }\n if (column.isAllowValue()) {\n this.columnsToAggregate.push(column);\n }\n else if (column.isAllowRowGroup()) {\n this.columnsToGroup.push(column);\n }\n else if (column.isAllowPivot()) {\n this.columnsToPivot.push(column);\n }\n });\n }\n getIconName() {\n const totalColumns = this.columnsToAggregate.length + this.columnsToGroup.length + this.columnsToPivot.length;\n if (totalColumns > 0) {\n return this.pinned ? DragAndDropService.ICON_PINNED : DragAndDropService.ICON_MOVE;\n }\n return null;\n }\n /** Callback for when drag leaves */\n onDragLeave(draggingEvent) {\n // if we are taking columns out of the center, then we remove them from the report\n this.clearColumnsList();\n }\n clearColumnsList() {\n this.columnsToAggregate.length = 0;\n this.columnsToGroup.length = 0;\n this.columnsToPivot.length = 0;\n }\n /** Callback for when dragging */\n onDragging(draggingEvent) {\n }\n /** Callback for when drag stops */\n onDragStop(draggingEvent) {\n if (this.columnsToAggregate.length > 0) {\n this.columnModel.addValueColumns(this.columnsToAggregate, \"toolPanelDragAndDrop\");\n }\n if (this.columnsToGroup.length > 0) {\n this.columnModel.addRowGroupColumns(this.columnsToGroup, \"toolPanelDragAndDrop\");\n }\n if (this.columnsToPivot.length > 0) {\n this.columnModel.addPivotColumns(this.columnsToPivot, \"toolPanelDragAndDrop\");\n }\n }\n}\n__decorate([\n Autowired('columnModel')\n], BodyDropPivotTarget.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('gridOptionsService')\n], BodyDropPivotTarget.prototype, \"gridOptionsService\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from \"../../context/context.mjs\";\nimport { DragAndDropService, DragSourceType, HorizontalDirection } from \"../../dragAndDrop/dragAndDropService.mjs\";\nimport { missing, exists } from \"../../utils/generic.mjs\";\nimport { sortNumerically, last, includes } from \"../../utils/array.mjs\";\nimport { _ } from \"../../utils/index.mjs\";\nexport class MoveColumnFeature {\n constructor(pinned, eContainer) {\n this.needToMoveLeft = false;\n this.needToMoveRight = false;\n this.lastMovedInfo = null;\n this.pinned = pinned;\n this.eContainer = eContainer;\n this.centerContainer = !exists(pinned);\n }\n init() {\n this.ctrlsService.whenReady(() => {\n this.gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n });\n }\n getIconName() {\n return this.pinned ? DragAndDropService.ICON_PINNED : DragAndDropService.ICON_MOVE;\n }\n onDragEnter(draggingEvent) {\n // we do dummy drag, so make sure column appears in the right location when first placed\n const columns = draggingEvent.dragItem.columns;\n const dragCameFromToolPanel = draggingEvent.dragSource.type === DragSourceType.ToolPanel;\n if (dragCameFromToolPanel) {\n // the if statement doesn't work if drag leaves grid, then enters again\n this.setColumnsVisible(columns, true, \"uiColumnDragged\");\n }\n else {\n // restore previous state of visible columns upon re-entering. this means if the user drags\n // a group out, and then drags the group back in, only columns that were originally visible\n // will be visible again. otherwise a group with three columns (but only two visible) could\n // be dragged out, then when it's dragged in again, all three are visible. this stops that.\n const visibleState = draggingEvent.dragItem.visibleState;\n const visibleColumns = (columns || []).filter(column => visibleState[column.getId()]);\n this.setColumnsVisible(visibleColumns, true, \"uiColumnDragged\");\n }\n this.setColumnsPinned(columns, this.pinned, \"uiColumnDragged\");\n this.onDragging(draggingEvent, true, true);\n }\n onDragLeave() {\n this.ensureIntervalCleared();\n this.lastMovedInfo = null;\n }\n setColumnsVisible(columns, visible, source = \"api\") {\n if (columns) {\n const allowedCols = columns.filter(c => !c.getColDef().lockVisible);\n this.columnModel.setColumnsVisible(allowedCols, visible, source);\n }\n }\n setColumnsPinned(columns, pinned, source = \"api\") {\n if (columns) {\n const allowedCols = columns.filter(c => !c.getColDef().lockPinned);\n this.columnModel.setColumnsPinned(allowedCols, pinned, source);\n }\n }\n onDragStop() {\n this.onDragging(this.lastDraggingEvent, false, true, true);\n this.ensureIntervalCleared();\n this.lastMovedInfo = null;\n }\n normaliseX(x) {\n // flip the coordinate if doing RTL\n if (this.gridOptionsService.is('enableRtl')) {\n const clientWidth = this.eContainer.clientWidth;\n x = clientWidth - x;\n }\n // adjust for scroll only if centre container (the pinned containers don't scroll)\n if (this.centerContainer) {\n x += this.ctrlsService.getCenterRowContainerCtrl().getCenterViewportScrollLeft();\n }\n return x;\n }\n checkCenterForScrolling(xAdjustedForScroll) {\n if (this.centerContainer) {\n // scroll if the mouse has gone outside the grid (or just outside the scrollable part if pinning)\n // putting in 50 buffer, so even if user gets to edge of grid, a scroll will happen\n const firstVisiblePixel = this.ctrlsService.getCenterRowContainerCtrl().getCenterViewportScrollLeft();\n const lastVisiblePixel = firstVisiblePixel + this.ctrlsService.getCenterRowContainerCtrl().getCenterWidth();\n if (this.gridOptionsService.is('enableRtl')) {\n this.needToMoveRight = xAdjustedForScroll < (firstVisiblePixel + 50);\n this.needToMoveLeft = xAdjustedForScroll > (lastVisiblePixel - 50);\n }\n else {\n this.needToMoveLeft = xAdjustedForScroll < (firstVisiblePixel + 50);\n this.needToMoveRight = xAdjustedForScroll > (lastVisiblePixel - 50);\n }\n if (this.needToMoveLeft || this.needToMoveRight) {\n this.ensureIntervalStarted();\n }\n else {\n this.ensureIntervalCleared();\n }\n }\n }\n onDragging(draggingEvent = this.lastDraggingEvent, fromEnter = false, fakeEvent = false, finished = false) {\n var _a;\n if (finished) {\n if (this.lastMovedInfo) {\n const { columns, toIndex } = this.lastMovedInfo;\n this.moveColumns(columns, toIndex, 'uiColumnMoved', true);\n }\n return;\n }\n this.lastDraggingEvent = draggingEvent;\n // if moving up or down (ie not left or right) then do nothing\n if (missing(draggingEvent.hDirection)) {\n return;\n }\n const mouseX = this.normaliseX(draggingEvent.x);\n // if the user is dragging into the panel, ie coming from the side panel into the main grid,\n // we don't want to scroll the grid this time, it would appear like the table is jumping\n // each time a column is dragged in.\n if (!fromEnter) {\n this.checkCenterForScrolling(mouseX);\n }\n const hDirection = this.normaliseDirection(draggingEvent.hDirection);\n const dragSourceType = draggingEvent.dragSource.type;\n const allMovingColumns = ((_a = draggingEvent.dragSource.getDragItem().columns) === null || _a === void 0 ? void 0 : _a.filter(col => {\n if (col.getColDef().lockPinned) {\n // if locked return true only if both col and container are same pin type.\n // double equals (==) here on purpose so that null==undefined is true (for not pinned options)\n return col.getPinned() == this.pinned;\n }\n // if not pin locked, then always allowed to be in this container\n return true;\n })) || [];\n this.attemptMoveColumns({ dragSourceType, allMovingColumns, hDirection, mouseX, fromEnter, fakeEvent });\n }\n normaliseDirection(hDirection) {\n if (this.gridOptionsService.is('enableRtl')) {\n switch (hDirection) {\n case HorizontalDirection.Left: return HorizontalDirection.Right;\n case HorizontalDirection.Right: return HorizontalDirection.Left;\n default: console.error(`AG Grid: Unknown direction ${hDirection}`);\n }\n }\n else {\n return hDirection;\n }\n }\n attemptMoveColumns(params) {\n const { dragSourceType, hDirection, mouseX, fromEnter, fakeEvent } = params;\n const draggingLeft = hDirection === HorizontalDirection.Left;\n const draggingRight = hDirection === HorizontalDirection.Right;\n let { allMovingColumns } = params;\n if (dragSourceType === DragSourceType.HeaderCell) {\n // If the columns we're dragging are the only visible columns of their group, move the hidden ones too\n let newCols = [];\n allMovingColumns.forEach((col) => {\n var _a;\n let movingGroup = null;\n let parent = col.getParent();\n while (parent != null && parent.getDisplayedLeafColumns().length === 1) {\n movingGroup = parent;\n parent = parent.getParent();\n }\n if (movingGroup != null) {\n const isMarryChildren = !!((_a = movingGroup.getColGroupDef()) === null || _a === void 0 ? void 0 : _a.marryChildren);\n const columnsToMove = isMarryChildren\n // when marry children is true, we also have to move hidden\n // columns within the group, so grab them from the `providedColumnGroup`\n ? movingGroup.getProvidedColumnGroup().getLeafColumns()\n : movingGroup.getLeafColumns();\n columnsToMove.forEach((newCol) => {\n if (!newCols.includes(newCol)) {\n newCols.push(newCol);\n }\n });\n }\n else if (!newCols.includes(col)) {\n newCols.push(col);\n }\n });\n allMovingColumns = newCols;\n }\n // it is important to sort the moving columns as they are in grid columns, as the list of moving columns\n // could themselves be part of 'married children' groups, which means we need to maintain the order within\n // the moving list.\n const allMovingColumnsOrdered = allMovingColumns.slice();\n this.columnModel.sortColumnsLikeGridColumns(allMovingColumnsOrdered);\n const validMoves = this.calculateValidMoves(allMovingColumnsOrdered, draggingRight, mouseX);\n // if cols are not adjacent, then this returns null. when moving, we constrain the direction of the move\n // (ie left or right) to the mouse direction. however\n const oldIndex = this.calculateOldIndex(allMovingColumnsOrdered);\n if (validMoves.length === 0) {\n return;\n }\n const firstValidMove = validMoves[0];\n // the two check below stop an error when the user grabs a group my a middle column, then\n // it is possible the mouse pointer is to the right of a column while been dragged left.\n // so we need to make sure that the mouse pointer is actually left of the left most column\n // if moving left, and right of the right most column if moving right\n // we check 'fromEnter' below so we move the column to the new spot if the mouse is coming from\n // outside the grid, eg if the column is moving from side panel, mouse is moving left, then we should\n // place the column to the RHS even if the mouse is moving left and the column is already on\n // the LHS. otherwise we stick to the rule described above.\n let constrainDirection = oldIndex !== null && !fromEnter;\n // don't consider 'fromEnter' when dragging header cells, otherwise group can jump to opposite direction of drag\n if (dragSourceType == DragSourceType.HeaderCell) {\n constrainDirection = oldIndex !== null;\n }\n // if the event was faked by a change in column pin state, then the original location of the column\n // is not reliable for dictating where the column may now be placed.\n if (constrainDirection && !fakeEvent) {\n // only allow left drag if this column is moving left\n if (draggingLeft && firstValidMove >= oldIndex) {\n return;\n }\n // only allow right drag if this column is moving right\n if (draggingRight && firstValidMove <= oldIndex) {\n return;\n }\n }\n // From when we find a move that passes all the rules\n // Remember what that move would look like in terms of displayed cols\n // keep going with further moves until we find a different result in displayed output\n // In this way potentialMoves contains all potential moves over 'hidden' columns\n const displayedCols = this.columnModel.getAllDisplayedColumns();\n let potentialMoves = [];\n let targetOrder = null;\n for (let i = 0; i < validMoves.length; i++) {\n const move = validMoves[i];\n const order = this.columnModel.getProposedColumnOrder(allMovingColumnsOrdered, move);\n if (!this.columnModel.doesOrderPassRules(order)) {\n continue;\n }\n const displayedOrder = order.filter((col) => displayedCols.includes(col));\n if (targetOrder === null) {\n targetOrder = displayedOrder;\n }\n else if (!_.areEqual(displayedOrder, targetOrder)) {\n break; // Stop looking for potential moves if the displayed result changes from the target\n }\n const fragCount = this.groupFragCount(order);\n potentialMoves.push({ move, fragCount });\n }\n if (potentialMoves.length === 0) {\n return;\n }\n // The best move is the move with least group fragmentation\n potentialMoves.sort((a, b) => a.fragCount - b.fragCount);\n this.moveColumns(allMovingColumns, potentialMoves[0].move, 'uiColumnMoved', false);\n }\n // returns the index of the first column in the list ONLY if the cols are all beside\n // each other. if the cols are not beside each other, then returns null\n calculateOldIndex(movingCols) {\n const gridCols = this.columnModel.getAllGridColumns();\n const indexes = sortNumerically(movingCols.map(col => gridCols.indexOf(col)));\n const firstIndex = indexes[0];\n const lastIndex = last(indexes);\n const spread = lastIndex - firstIndex;\n const gapsExist = spread !== indexes.length - 1;\n return gapsExist ? null : firstIndex;\n }\n moveColumns(columns, toIndex, source, finished) {\n this.columnModel.moveColumns(columns, toIndex, source, finished);\n this.lastMovedInfo = finished ? null : { columns, toIndex };\n }\n // A measure of how fragmented in terms of groups an order of columns is\n groupFragCount(columns) {\n function parents(col) {\n let result = [];\n let parent = col.getOriginalParent();\n while (parent != null) {\n result.push(parent);\n parent = parent.getOriginalParent();\n }\n return result;\n }\n let count = 0;\n for (let i = 0; i < columns.length - 1; i++) {\n let a = parents(columns[i]);\n let b = parents(columns[i + 1]);\n // iterate over the longest one\n [a, b] = a.length > b.length ? [a, b] : [b, a];\n a.forEach((parent) => {\n if (b.indexOf(parent) === -1) {\n count++; // More fragmented if other column doesn't share the parent\n }\n });\n }\n return count;\n }\n calculateValidMoves(movingCols, draggingRight, mouseX) {\n const isMoveBlocked = this.gridOptionsService.is('suppressMovableColumns') || movingCols.some(col => col.getColDef().suppressMovable);\n if (isMoveBlocked) {\n return [];\n }\n // this is the list of cols on the screen, so it's these we use when comparing the x mouse position\n const allDisplayedCols = this.columnModel.getDisplayedColumns(this.pinned);\n // but this list is the list of all cols, when we move a col it's the index within this list that gets used,\n // so the result we return has to be and index location for this list\n const allGridCols = this.columnModel.getAllGridColumns();\n const movingDisplayedCols = allDisplayedCols.filter(col => includes(movingCols, col));\n const otherDisplayedCols = allDisplayedCols.filter(col => !includes(movingCols, col));\n const otherGridCols = allGridCols.filter(col => !includes(movingCols, col));\n // work out how many DISPLAYED columns fit before the 'x' position. this gives us the displayIndex.\n // for example, if cols are a,b,c,d and we find a,b fit before 'x', then we want to place the moving\n // col between b and c (so that it is under the mouse position).\n let displayIndex = 0;\n let availableWidth = mouseX;\n // if we are dragging right, then the columns will be to the left of the mouse, so we also want to\n // include the width of the moving columns\n if (draggingRight) {\n let widthOfMovingDisplayedCols = 0;\n movingDisplayedCols.forEach(col => widthOfMovingDisplayedCols += col.getActualWidth());\n availableWidth -= widthOfMovingDisplayedCols;\n }\n if (availableWidth > 0) {\n // now count how many of the displayed columns will fit to the left\n for (let i = 0; i < otherDisplayedCols.length; i++) {\n const col = otherDisplayedCols[i];\n availableWidth -= col.getActualWidth();\n if (availableWidth < 0) {\n break;\n }\n displayIndex++;\n }\n // trial and error, if going right, we adjust by one, i didn't manage to quantify why, but it works\n if (draggingRight) {\n displayIndex++;\n }\n }\n // the display index is with respect to all the showing columns, however when we move, it's with\n // respect to all grid columns, so we need to translate from display index to grid index\n let firstValidMove;\n if (displayIndex > 0) {\n const leftColumn = otherDisplayedCols[displayIndex - 1];\n firstValidMove = otherGridCols.indexOf(leftColumn) + 1;\n }\n else {\n firstValidMove = otherGridCols.indexOf(otherDisplayedCols[0]);\n if (firstValidMove === -1) {\n firstValidMove = 0;\n }\n }\n const validMoves = [firstValidMove];\n const numberComparator = (a, b) => a - b;\n // add in other valid moves due to hidden columns and married children. for example, a particular\n // move might break a group that has married children (so move isn't valid), however there could\n // be hidden columns (not displayed) that we could jump over to make the move valid. because\n // they are hidden, user doesn't see any different, however it allows moves that would otherwise\n // not work. for example imagine a group with 9 columns and all columns are hidden except the\n // middle one (so 4 hidden to left, 4 hidden to right), then when moving 'firstValidMove' will\n // be relative to the not-shown column, however we need to consider the move jumping over all the\n // hidden children. if we didn't do this, then if the group just described was at the end (RHS) of the\n // grid, there would be no way to put a column after it (as the grid would only consider beside the\n // visible column, which would fail valid move rules).\n if (draggingRight) {\n // if dragging right, then we add all the additional moves to the right. so in other words\n // if the next move is not valid, find the next move to the right that is valid.\n let pointer = firstValidMove + 1;\n const lastIndex = allGridCols.length - 1;\n while (pointer <= lastIndex) {\n validMoves.push(pointer);\n pointer++;\n }\n // adding columns here means the order is now messed up\n validMoves.sort(numberComparator);\n }\n else {\n // if dragging left we do the reverse of dragging right, we add in all the valid moves to the\n // left. however we also have to consider moves to the right for all hidden columns first.\n // (this logic is hard to reason with, it was worked out with trial and error,\n // more observation rather than science).\n // add moves to the right\n let pointer = firstValidMove;\n const lastIndex = allGridCols.length - 1;\n let displacedCol = allGridCols[pointer];\n while (pointer <= lastIndex && this.isColumnHidden(allDisplayedCols, displacedCol)) {\n pointer++;\n validMoves.push(pointer);\n displacedCol = allGridCols[pointer];\n }\n // add moves to the left\n pointer = firstValidMove - 1;\n const firstDisplayIndex = 0;\n while (pointer >= firstDisplayIndex) {\n validMoves.push(pointer);\n pointer--;\n }\n // adding columns here means the order is now messed up\n validMoves.sort(numberComparator).reverse();\n }\n return validMoves;\n }\n // isHidden takes into account visible=false and group=closed, ie it is not displayed\n isColumnHidden(displayedColumns, col) {\n return displayedColumns.indexOf(col) < 0;\n }\n ensureIntervalStarted() {\n if (!this.movingIntervalId) {\n this.intervalCount = 0;\n this.failedMoveAttempts = 0;\n this.movingIntervalId = window.setInterval(this.moveInterval.bind(this), 100);\n if (this.needToMoveLeft) {\n this.dragAndDropService.setGhostIcon(DragAndDropService.ICON_LEFT, true);\n }\n else {\n this.dragAndDropService.setGhostIcon(DragAndDropService.ICON_RIGHT, true);\n }\n }\n }\n ensureIntervalCleared() {\n if (this.movingIntervalId) {\n window.clearInterval(this.movingIntervalId);\n this.movingIntervalId = null;\n this.dragAndDropService.setGhostIcon(DragAndDropService.ICON_MOVE);\n }\n }\n moveInterval() {\n // the amounts we move get bigger at each interval, so the speed accelerates, starting a bit slow\n // and getting faster. this is to give smoother user experience. we max at 100px to limit the speed.\n let pixelsToMove;\n this.intervalCount++;\n pixelsToMove = 10 + (this.intervalCount * 5);\n if (pixelsToMove > 100) {\n pixelsToMove = 100;\n }\n let pixelsMoved = null;\n const scrollFeature = this.gridBodyCon.getScrollFeature();\n if (this.needToMoveLeft) {\n pixelsMoved = scrollFeature.scrollHorizontally(-pixelsToMove);\n }\n else if (this.needToMoveRight) {\n pixelsMoved = scrollFeature.scrollHorizontally(pixelsToMove);\n }\n if (pixelsMoved !== 0) {\n this.onDragging(this.lastDraggingEvent);\n this.failedMoveAttempts = 0;\n }\n else {\n // we count the failed move attempts. if we fail to move 7 times, then we pin the column.\n // this is how we achieve pining by dragging the column to the edge of the grid.\n this.failedMoveAttempts++;\n const columns = this.lastDraggingEvent.dragItem.columns;\n const columnsThatCanPin = columns.filter(c => !c.getColDef().lockPinned);\n if (columnsThatCanPin.length > 0) {\n this.dragAndDropService.setGhostIcon(DragAndDropService.ICON_PINNED);\n if (this.failedMoveAttempts > 7) {\n const pinType = this.needToMoveLeft ? 'left' : 'right';\n this.setColumnsPinned(columnsThatCanPin, pinType, \"uiColumnDragged\");\n this.dragAndDropService.nudge();\n }\n }\n }\n }\n}\n__decorate([\n Autowired('columnModel')\n], MoveColumnFeature.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('dragAndDropService')\n], MoveColumnFeature.prototype, \"dragAndDropService\", void 0);\n__decorate([\n Autowired('gridOptionsService')\n], MoveColumnFeature.prototype, \"gridOptionsService\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], MoveColumnFeature.prototype, \"ctrlsService\", void 0);\n__decorate([\n PostConstruct\n], MoveColumnFeature.prototype, \"init\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { DragSourceType } from \"../../dragAndDrop/dragAndDropService.mjs\";\nimport { Autowired, PostConstruct } from \"../../context/context.mjs\";\nimport { MoveColumnFeature } from \"./moveColumnFeature.mjs\";\nimport { BodyDropPivotTarget } from \"./bodyDropPivotTarget.mjs\";\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nexport class BodyDropTarget extends BeanStub {\n constructor(pinned, eContainer) {\n super();\n this.pinned = pinned;\n this.eContainer = eContainer;\n }\n postConstruct() {\n this.ctrlsService.whenReady(p => {\n switch (this.pinned) {\n case 'left':\n this.eSecondaryContainers = [\n [p.gridBodyCtrl.getBodyViewportElement(), p.leftRowContainerCtrl.getContainerElement()],\n [p.bottomLeftRowContainerCtrl.getContainerElement()],\n [p.topLeftRowContainerCtrl.getContainerElement()]\n ];\n break;\n case 'right':\n this.eSecondaryContainers = [\n [p.gridBodyCtrl.getBodyViewportElement(), p.rightRowContainerCtrl.getContainerElement()],\n [p.bottomRightRowContainerCtrl.getContainerElement()],\n [p.topRightRowContainerCtrl.getContainerElement()]\n ];\n break;\n default:\n this.eSecondaryContainers = [\n [p.gridBodyCtrl.getBodyViewportElement(), p.centerRowContainerCtrl.getViewportElement()],\n [p.bottomCenterRowContainerCtrl.getViewportElement()],\n [p.topCenterRowContainerCtrl.getViewportElement()]\n ];\n break;\n }\n });\n }\n isInterestedIn(type) {\n return type === DragSourceType.HeaderCell ||\n (type === DragSourceType.ToolPanel && this.gridOptionsService.is('allowDragFromColumnsToolPanel'));\n }\n getSecondaryContainers() {\n return this.eSecondaryContainers;\n }\n getContainer() {\n return this.eContainer;\n }\n init() {\n this.moveColumnFeature = this.createManagedBean(new MoveColumnFeature(this.pinned, this.eContainer));\n this.bodyDropPivotTarget = this.createManagedBean(new BodyDropPivotTarget(this.pinned));\n this.dragAndDropService.addDropTarget(this);\n }\n getIconName() {\n return this.currentDropListener.getIconName();\n }\n // we want to use the bodyPivotTarget if the user is dragging columns in from the toolPanel\n // and we are in pivot mode, as it has to logic to set pivot/value/group on the columns when\n // dropped into the grid's body.\n isDropColumnInPivotMode(draggingEvent) {\n // in pivot mode, then if moving a column (ie didn't come from toolpanel) then it's\n // a standard column move, however if it came from the toolpanel, then we are introducing\n // dimensions or values to the grid\n return this.columnModel.isPivotMode() && draggingEvent.dragSource.type === DragSourceType.ToolPanel;\n }\n onDragEnter(draggingEvent) {\n // we pick the drop listener depending on whether we are in pivot mode are not. if we are\n // in pivot mode, then dropping cols changes the row group, pivot, value stats. otherwise\n // we change visibility state and position.\n this.currentDropListener = this.isDropColumnInPivotMode(draggingEvent) ? this.bodyDropPivotTarget : this.moveColumnFeature;\n this.currentDropListener.onDragEnter(draggingEvent);\n }\n onDragLeave(params) {\n this.currentDropListener.onDragLeave(params);\n }\n onDragging(params) {\n this.currentDropListener.onDragging(params);\n }\n onDragStop(params) {\n this.currentDropListener.onDragStop(params);\n }\n}\n__decorate([\n Autowired('dragAndDropService')\n], BodyDropTarget.prototype, \"dragAndDropService\", void 0);\n__decorate([\n Autowired('columnModel')\n], BodyDropTarget.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], BodyDropTarget.prototype, \"ctrlsService\", void 0);\n__decorate([\n PostConstruct\n], BodyDropTarget.prototype, \"postConstruct\", null);\n__decorate([\n PostConstruct\n], BodyDropTarget.prototype, \"init\", null);\n","import { missing } from \"../../utils/generic.mjs\";\nexport class CssClassApplier {\n static getHeaderClassesFromColDef(abstractColDef, gridOptionsService, column, columnGroup) {\n if (missing(abstractColDef)) {\n return [];\n }\n return this.getColumnClassesFromCollDef(abstractColDef.headerClass, abstractColDef, gridOptionsService, column, columnGroup);\n }\n static getToolPanelClassesFromColDef(abstractColDef, gridOptionsService, column, columnGroup) {\n if (missing(abstractColDef)) {\n return [];\n }\n return this.getColumnClassesFromCollDef(abstractColDef.toolPanelClass, abstractColDef, gridOptionsService, column, columnGroup);\n }\n static getClassParams(abstractColDef, gridOptionsService, column, columnGroup) {\n return {\n // bad naming, as colDef here can be a group or a column,\n // however most people won't appreciate the difference,\n // so keeping it as colDef to avoid confusion.\n colDef: abstractColDef,\n column: column,\n columnGroup: columnGroup,\n api: gridOptionsService.api,\n columnApi: gridOptionsService.columnApi,\n context: gridOptionsService.context\n };\n }\n static getColumnClassesFromCollDef(classesOrFunc, abstractColDef, gridOptionsService, column, columnGroup) {\n if (missing(classesOrFunc)) {\n return [];\n }\n let classToUse;\n if (typeof classesOrFunc === 'function') {\n const params = this.getClassParams(abstractColDef, gridOptionsService, column, columnGroup);\n classToUse = classesOrFunc(params);\n }\n else {\n classToUse = classesOrFunc;\n }\n if (typeof classToUse === 'string') {\n return [classToUse];\n }\n if (Array.isArray(classToUse)) {\n return [...classToUse];\n }\n return [];\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PostConstruct, PreDestroy } from \"../../../context/context.mjs\";\nimport { removeAriaSort, setAriaDescription, setAriaSort } from \"../../../utils/aria.mjs\";\nimport { RefSelector } from \"../../../widgets/componentAnnotations.mjs\";\nimport { AbstractHeaderCellComp } from \"../abstractCell/abstractHeaderCellComp.mjs\";\nexport class HeaderCellComp extends AbstractHeaderCellComp {\n constructor(ctrl) {\n super(HeaderCellComp.TEMPLATE, ctrl);\n this.headerCompVersion = 0;\n this.column = ctrl.getColumnGroupChild();\n this.pinned = ctrl.getPinned();\n }\n postConstruct() {\n const eGui = this.getGui();\n const setAttribute = (name, value) => {\n if (value != null && value != '') {\n eGui.setAttribute(name, value);\n }\n else {\n eGui.removeAttribute(name);\n }\n };\n setAttribute('col-id', this.column.getColId());\n const compProxy = {\n setWidth: width => eGui.style.width = width,\n addOrRemoveCssClass: (cssClassName, on) => this.addOrRemoveCssClass(cssClassName, on),\n setAriaDescription: label => setAriaDescription(eGui, label),\n setAriaSort: sort => sort ? setAriaSort(eGui, sort) : removeAriaSort(eGui),\n setUserCompDetails: compDetails => this.setUserCompDetails(compDetails),\n getUserCompInstance: () => this.headerComp\n };\n this.ctrl.setComp(compProxy, this.getGui(), this.eResize, this.eHeaderCompWrapper);\n const selectAllGui = this.ctrl.getSelectAllGui();\n this.eResize.insertAdjacentElement('afterend', selectAllGui);\n }\n destroyHeaderComp() {\n if (this.headerComp) {\n this.eHeaderCompWrapper.removeChild(this.headerCompGui);\n this.headerComp = this.destroyBean(this.headerComp);\n this.headerCompGui = undefined;\n }\n }\n setUserCompDetails(compDetails) {\n this.headerCompVersion++;\n const versionCopy = this.headerCompVersion;\n compDetails.newAgStackInstance().then(comp => this.afterCompCreated(versionCopy, comp));\n }\n afterCompCreated(version, headerComp) {\n if (version != this.headerCompVersion || !this.isAlive()) {\n this.destroyBean(headerComp);\n return;\n }\n this.destroyHeaderComp();\n this.headerComp = headerComp;\n this.headerCompGui = headerComp.getGui();\n this.eHeaderCompWrapper.appendChild(this.headerCompGui);\n this.ctrl.setDragSource(this.getGui());\n }\n}\nHeaderCellComp.TEMPLATE = `
\n
\n
\n
`;\n__decorate([\n RefSelector('eResize')\n], HeaderCellComp.prototype, \"eResize\", void 0);\n__decorate([\n RefSelector('eHeaderCompWrapper')\n], HeaderCellComp.prototype, \"eHeaderCompWrapper\", void 0);\n__decorate([\n PostConstruct\n], HeaderCellComp.prototype, \"postConstruct\", null);\n__decorate([\n PreDestroy\n], HeaderCellComp.prototype, \"destroyHeaderComp\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from \"../../../context/context.mjs\";\nimport { setDisplayed } from \"../../../utils/dom.mjs\";\nimport { RefSelector } from \"../../../widgets/componentAnnotations.mjs\";\nimport { AbstractHeaderCellComp } from \"../abstractCell/abstractHeaderCellComp.mjs\";\nexport class HeaderGroupCellComp extends AbstractHeaderCellComp {\n constructor(ctrl) {\n super(HeaderGroupCellComp.TEMPLATE, ctrl);\n }\n postConstruct() {\n const eGui = this.getGui();\n const setAttribute = (key, value) => value != undefined ? eGui.setAttribute(key, value) : eGui.removeAttribute(key);\n eGui.setAttribute(\"col-id\", this.ctrl.getColId());\n const compProxy = {\n addOrRemoveCssClass: (cssClassName, on) => this.addOrRemoveCssClass(cssClassName, on),\n setResizableDisplayed: (displayed) => setDisplayed(this.eResize, displayed),\n setWidth: width => eGui.style.width = width,\n setAriaExpanded: expanded => setAttribute('aria-expanded', expanded),\n setUserCompDetails: details => this.setUserCompDetails(details)\n };\n this.ctrl.setComp(compProxy, eGui, this.eResize);\n }\n setUserCompDetails(details) {\n details.newAgStackInstance().then(comp => this.afterHeaderCompCreated(comp));\n }\n afterHeaderCompCreated(headerGroupComp) {\n const destroyFunc = () => this.destroyBean(headerGroupComp);\n if (!this.isAlive()) {\n destroyFunc();\n return;\n }\n const eGui = this.getGui();\n const eHeaderGroupGui = headerGroupComp.getGui();\n eGui.appendChild(eHeaderGroupGui);\n this.addDestroyFunc(destroyFunc);\n this.ctrl.setDragSource(eGui);\n }\n}\nHeaderGroupCellComp.TEMPLATE = `
\n
\n
`;\n__decorate([\n Autowired('userComponentFactory')\n], HeaderGroupCellComp.prototype, \"userComponentFactory\", void 0);\n__decorate([\n RefSelector('eResize')\n], HeaderGroupCellComp.prototype, \"eResize\", void 0);\n__decorate([\n PostConstruct\n], HeaderGroupCellComp.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PostConstruct, PreDestroy } from '../../context/context.mjs';\nimport { setAriaRowIndex } from '../../utils/aria.mjs';\nimport { setDomChildOrder } from '../../utils/dom.mjs';\nimport { getAllValuesInObject, iterateObject } from '../../utils/object.mjs';\nimport { Component } from '../../widgets/component.mjs';\nimport { HeaderCellComp } from '../cells/column/headerCellComp.mjs';\nimport { HeaderGroupCellComp } from '../cells/columnGroup/headerGroupCellComp.mjs';\nimport { HeaderFilterCellComp } from '../cells/floatingFilter/headerFilterCellComp.mjs';\nexport var HeaderRowType;\n(function (HeaderRowType) {\n HeaderRowType[\"COLUMN_GROUP\"] = \"group\";\n HeaderRowType[\"COLUMN\"] = \"column\";\n HeaderRowType[\"FLOATING_FILTER\"] = \"filter\";\n})(HeaderRowType || (HeaderRowType = {}));\nexport class HeaderRowComp extends Component {\n constructor(ctrl) {\n super();\n this.headerComps = {};\n this.ctrl = ctrl;\n this.setTemplate(/* html */ `
`);\n }\n //noinspection JSUnusedLocalSymbols\n init() {\n this.getGui().style.transform = this.ctrl.getTransform();\n setAriaRowIndex(this.getGui(), this.ctrl.getAriaRowIndex());\n const compProxy = {\n setHeight: height => this.getGui().style.height = height,\n setTop: top => this.getGui().style.top = top,\n setHeaderCtrls: (ctrls, forceOrder) => this.setHeaderCtrls(ctrls, forceOrder),\n setWidth: width => this.getGui().style.width = width,\n };\n this.ctrl.setComp(compProxy);\n }\n destroyHeaderCtrls() {\n this.setHeaderCtrls([], false);\n }\n setHeaderCtrls(ctrls, forceOrder) {\n if (!this.isAlive()) {\n return;\n }\n const oldComps = this.headerComps;\n this.headerComps = {};\n ctrls.forEach(ctrl => {\n const id = ctrl.getInstanceId();\n let comp = oldComps[id];\n delete oldComps[id];\n if (comp == null) {\n comp = this.createHeaderComp(ctrl);\n this.getGui().appendChild(comp.getGui());\n }\n this.headerComps[id] = comp;\n });\n iterateObject(oldComps, (id, comp) => {\n this.getGui().removeChild(comp.getGui());\n this.destroyBean(comp);\n });\n if (forceOrder) {\n const comps = getAllValuesInObject(this.headerComps);\n // ordering the columns by left position orders them in the order they appear on the screen\n comps.sort((a, b) => {\n const leftA = a.getCtrl().getColumnGroupChild().getLeft();\n const leftB = b.getCtrl().getColumnGroupChild().getLeft();\n return leftA - leftB;\n });\n const elementsInOrder = comps.map(c => c.getGui());\n setDomChildOrder(this.getGui(), elementsInOrder);\n }\n }\n createHeaderComp(headerCtrl) {\n let result;\n switch (this.ctrl.getType()) {\n case HeaderRowType.COLUMN_GROUP:\n result = new HeaderGroupCellComp(headerCtrl);\n break;\n case HeaderRowType.FLOATING_FILTER:\n result = new HeaderFilterCellComp(headerCtrl);\n break;\n default:\n result = new HeaderCellComp(headerCtrl);\n break;\n }\n this.createBean(result);\n result.setParentComponent(this);\n return result;\n }\n}\n__decorate([\n PostConstruct\n], HeaderRowComp.prototype, \"init\", null);\n__decorate([\n PreDestroy\n], HeaderRowComp.prototype, \"destroyHeaderCtrls\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../../context/beanStub.mjs\";\nimport { Autowired } from \"../../../context/context.mjs\";\nimport { isUserSuppressingHeaderKeyboardEvent } from \"../../../utils/keyboard.mjs\";\nimport { KeyCode } from \"../.././../constants/keyCode.mjs\";\nlet instanceIdSequence = 0;\nexport class AbstractHeaderCellCtrl extends BeanStub {\n constructor(columnGroupChild, parentRowCtrl) {\n super();\n this.lastFocusEvent = null;\n this.columnGroupChild = columnGroupChild;\n this.parentRowCtrl = parentRowCtrl;\n // unique id to this instance, including the column ID to help with debugging in React as it's used in 'key'\n this.instanceId = columnGroupChild.getUniqueId() + '-' + instanceIdSequence++;\n }\n shouldStopEventPropagation(e) {\n const { headerRowIndex, column } = this.focusService.getFocusedHeader();\n return isUserSuppressingHeaderKeyboardEvent(this.gridOptionsService, e, headerRowIndex, column);\n }\n getWrapperHasFocus() {\n const eDocument = this.gridOptionsService.getDocument();\n const activeEl = eDocument.activeElement;\n return activeEl === this.eGui;\n }\n setGui(eGui) {\n this.eGui = eGui;\n this.addDomData();\n }\n handleKeyDown(e) {\n const wrapperHasFocus = this.getWrapperHasFocus();\n switch (e.key) {\n case KeyCode.PAGE_DOWN:\n case KeyCode.PAGE_UP:\n case KeyCode.PAGE_HOME:\n case KeyCode.PAGE_END:\n if (wrapperHasFocus) {\n e.preventDefault();\n }\n }\n }\n addDomData() {\n const key = AbstractHeaderCellCtrl.DOM_DATA_KEY_HEADER_CTRL;\n this.gridOptionsService.setDomData(this.eGui, key, this);\n this.addDestroyFunc(() => this.gridOptionsService.setDomData(this.eGui, key, null));\n }\n getGui() {\n return this.eGui;\n }\n focus(event) {\n if (!this.eGui) {\n return false;\n }\n this.lastFocusEvent = event || null;\n this.eGui.focus();\n return true;\n }\n getRowIndex() {\n return this.parentRowCtrl.getRowIndex();\n }\n getParentRowCtrl() {\n return this.parentRowCtrl;\n }\n getPinned() {\n return this.parentRowCtrl.getPinned();\n }\n getInstanceId() {\n return this.instanceId;\n }\n getColumnGroupChild() {\n return this.columnGroupChild;\n }\n}\nAbstractHeaderCellCtrl.DOM_DATA_KEY_HEADER_CTRL = 'headerCtrl';\n__decorate([\n Autowired('focusService')\n], AbstractHeaderCellCtrl.prototype, \"focusService\", void 0);\n__decorate([\n Autowired('beans')\n], AbstractHeaderCellCtrl.prototype, \"beans\", void 0);\n__decorate([\n Autowired('userComponentFactory')\n], AbstractHeaderCellCtrl.prototype, \"userComponentFactory\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Column } from \"../../entities/column.mjs\";\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nimport { PostConstruct } from \"../../context/context.mjs\";\nimport { setAriaColIndex, setAriaColSpan } from \"../../utils/aria.mjs\";\nimport { last } from \"../../utils/array.mjs\";\nimport { exists } from \"../../utils/generic.mjs\";\nimport { Events } from \"../../eventKeys.mjs\";\nexport class SetLeftFeature extends BeanStub {\n constructor(columnOrGroup, eCell, beans, colsSpanning) {\n super();\n this.columnOrGroup = columnOrGroup;\n this.eCell = eCell;\n this.ariaEl = this.eCell.querySelector('[role=columnheader]') || this.eCell;\n this.colsSpanning = colsSpanning;\n this.beans = beans;\n }\n setColsSpanning(colsSpanning) {\n this.colsSpanning = colsSpanning;\n this.onLeftChanged();\n }\n getColumnOrGroup() {\n if (this.beans.gridOptionsService.is('enableRtl') && this.colsSpanning) {\n return last(this.colsSpanning);\n }\n return this.columnOrGroup;\n }\n postConstruct() {\n this.addManagedListener(this.columnOrGroup, Column.EVENT_LEFT_CHANGED, this.onLeftChanged.bind(this));\n this.setLeftFirstTime();\n // when in print layout, the left position is also dependent on the width of the pinned sections.\n // so additionally update left if any column width changes.\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, this.onLeftChanged.bind(this));\n // setting left has a dependency on print layout\n this.addManagedPropertyListener('domLayout', this.onLeftChanged.bind(this));\n }\n setLeftFirstTime() {\n const suppressMoveAnimation = this.beans.gridOptionsService.is('suppressColumnMoveAnimation');\n const oldLeftExists = exists(this.columnOrGroup.getOldLeft());\n const animateColumnMove = this.beans.columnAnimationService.isActive() && oldLeftExists && !suppressMoveAnimation;\n if (animateColumnMove) {\n this.animateInLeft();\n }\n else {\n this.onLeftChanged();\n }\n }\n animateInLeft() {\n const colOrGroup = this.getColumnOrGroup();\n const left = colOrGroup.getLeft();\n const oldLeft = colOrGroup.getOldLeft();\n const oldActualLeft = this.modifyLeftForPrintLayout(colOrGroup, oldLeft);\n const actualLeft = this.modifyLeftForPrintLayout(colOrGroup, left);\n this.setLeft(oldActualLeft);\n // we must keep track of the left we want to set to, as this would otherwise lead to a race\n // condition, if the user changed the left value many times in one VM turn, then we want to make\n // make sure the actualLeft we set in the timeout below (in the next VM turn) is the correct left\n // position. eg if user changes column position twice, then setLeft() below executes twice in next\n // VM turn, but only one (the correct one) should get applied.\n this.actualLeft = actualLeft;\n this.beans.columnAnimationService.executeNextVMTurn(() => {\n // test this left value is the latest one to be applied, and if not, do nothing\n if (this.actualLeft === actualLeft) {\n this.setLeft(actualLeft);\n }\n });\n }\n onLeftChanged() {\n const colOrGroup = this.getColumnOrGroup();\n const left = colOrGroup.getLeft();\n this.actualLeft = this.modifyLeftForPrintLayout(colOrGroup, left);\n this.setLeft(this.actualLeft);\n }\n modifyLeftForPrintLayout(colOrGroup, leftPosition) {\n const printLayout = this.beans.gridOptionsService.isDomLayout('print');\n if (!printLayout) {\n return leftPosition;\n }\n if (colOrGroup.getPinned() === 'left') {\n return leftPosition;\n }\n const leftWidth = this.beans.columnModel.getDisplayedColumnsLeftWidth();\n if (colOrGroup.getPinned() === 'right') {\n const bodyWidth = this.beans.columnModel.getBodyContainerWidth();\n return leftWidth + bodyWidth + leftPosition;\n }\n // is in body\n return leftWidth + leftPosition;\n }\n setLeft(value) {\n // if the value is null, then that means the column is no longer\n // displayed. there is logic in the rendering to fade these columns\n // out, so we don't try and change their left positions.\n if (exists(value)) {\n this.eCell.style.left = `${value}px`;\n }\n let indexColumn;\n if (this.columnOrGroup instanceof Column) {\n indexColumn = this.columnOrGroup;\n }\n else {\n const columnGroup = this.columnOrGroup;\n const children = columnGroup.getLeafColumns();\n if (!children.length) {\n return;\n }\n if (children.length > 1) {\n setAriaColSpan(this.ariaEl, children.length);\n }\n indexColumn = children[0];\n }\n const index = this.beans.columnModel.getAriaColumnIndex(indexColumn);\n setAriaColIndex(this.ariaEl, index);\n }\n}\n__decorate([\n PostConstruct\n], SetLeftFeature.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nimport { Autowired, PostConstruct } from \"../../context/context.mjs\";\nexport class HoverFeature extends BeanStub {\n constructor(columns, element) {\n super();\n this.columns = columns;\n this.element = element;\n }\n postConstruct() {\n if (this.gridOptionsService.is('columnHoverHighlight')) {\n this.addMouseHoverListeners();\n }\n }\n addMouseHoverListeners() {\n this.addManagedListener(this.element, 'mouseout', this.onMouseOut.bind(this));\n this.addManagedListener(this.element, 'mouseover', this.onMouseOver.bind(this));\n }\n onMouseOut() {\n this.columnHoverService.clearMouseOver();\n }\n onMouseOver() {\n this.columnHoverService.setMouseOver(this.columns);\n }\n}\n__decorate([\n Autowired('columnHoverService')\n], HoverFeature.prototype, \"columnHoverService\", void 0);\n__decorate([\n PostConstruct\n], HoverFeature.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { AbstractHeaderCellCtrl } from \"../abstractCell/abstractHeaderCellCtrl.mjs\";\nimport { KeyCode } from '../../../constants/keyCode.mjs';\nimport { Autowired } from '../../../context/context.mjs';\nimport { Column } from '../../../entities/column.mjs';\nimport { Events } from '../../../events.mjs';\nimport { SetLeftFeature } from '../../../rendering/features/setLeftFeature.mjs';\nimport { isElementChildOfClass } from '../../../utils/dom.mjs';\nimport { createIconNoSpan } from '../../../utils/icon.mjs';\nimport { ManagedFocusFeature } from '../../../widgets/managedFocusFeature.mjs';\nimport { HoverFeature } from '../hoverFeature.mjs';\nimport { setAriaLabel } from \"../../../utils/aria.mjs\";\nexport class HeaderFilterCellCtrl extends AbstractHeaderCellCtrl {\n constructor(column, parentRowCtrl) {\n super(column, parentRowCtrl);\n this.iconCreated = false;\n this.column = column;\n }\n setComp(comp, eGui, eButtonShowMainFilter, eFloatingFilterBody) {\n super.setGui(eGui);\n this.comp = comp;\n this.eButtonShowMainFilter = eButtonShowMainFilter;\n this.eFloatingFilterBody = eFloatingFilterBody;\n this.setupActive();\n this.setupWidth();\n this.setupLeft();\n this.setupHover();\n this.setupFocus();\n this.setupAria();\n this.setupFilterButton();\n this.setupUserComp();\n this.setupSyncWithFilter();\n this.setupUi();\n this.addManagedListener(this.eButtonShowMainFilter, 'click', this.showParentFilter.bind(this));\n this.setupFilterChangedListener();\n this.addManagedListener(this.column, Column.EVENT_COL_DEF_CHANGED, this.onColDefChanged.bind(this));\n }\n setupActive() {\n const colDef = this.column.getColDef();\n const filterExists = !!colDef.filter;\n const floatingFilterExists = !!colDef.floatingFilter;\n this.active = filterExists && floatingFilterExists;\n }\n setupUi() {\n this.comp.setButtonWrapperDisplayed(!this.suppressFilterButton && this.active);\n this.comp.addOrRemoveBodyCssClass('ag-floating-filter-full-body', this.suppressFilterButton);\n this.comp.addOrRemoveBodyCssClass('ag-floating-filter-body', !this.suppressFilterButton);\n if (!this.active || this.iconCreated) {\n return;\n }\n const eMenuIcon = createIconNoSpan('filter', this.gridOptionsService, this.column);\n if (eMenuIcon) {\n this.iconCreated = true;\n this.eButtonShowMainFilter.appendChild(eMenuIcon);\n }\n }\n setupFocus() {\n this.createManagedBean(new ManagedFocusFeature(this.eGui, {\n shouldStopEventPropagation: this.shouldStopEventPropagation.bind(this),\n onTabKeyDown: this.onTabKeyDown.bind(this),\n handleKeyDown: this.handleKeyDown.bind(this),\n onFocusIn: this.onFocusIn.bind(this)\n }));\n }\n setupAria() {\n const localeTextFunc = this.localeService.getLocaleTextFunc();\n setAriaLabel(this.eButtonShowMainFilter, localeTextFunc('ariaFilterMenuOpen', 'Open Filter Menu'));\n }\n onTabKeyDown(e) {\n const eDocument = this.gridOptionsService.getDocument();\n const activeEl = eDocument.activeElement;\n const wrapperHasFocus = activeEl === this.eGui;\n if (wrapperHasFocus) {\n return;\n }\n const nextFocusableEl = this.focusService.findNextFocusableElement(this.eGui, null, e.shiftKey);\n if (nextFocusableEl) {\n this.beans.headerNavigationService.scrollToColumn(this.column);\n e.preventDefault();\n nextFocusableEl.focus();\n return;\n }\n const nextFocusableColumn = this.findNextColumnWithFloatingFilter(e.shiftKey);\n if (!nextFocusableColumn) {\n return;\n }\n if (this.focusService.focusHeaderPosition({\n headerPosition: {\n headerRowIndex: this.getParentRowCtrl().getRowIndex(),\n column: nextFocusableColumn\n },\n event: e\n })) {\n e.preventDefault();\n }\n }\n findNextColumnWithFloatingFilter(backwards) {\n const columModel = this.beans.columnModel;\n let nextCol = this.column;\n do {\n nextCol = backwards\n ? columModel.getDisplayedColBefore(nextCol)\n : columModel.getDisplayedColAfter(nextCol);\n if (!nextCol) {\n break;\n }\n } while (!nextCol.getColDef().filter || !nextCol.getColDef().floatingFilter);\n return nextCol;\n }\n handleKeyDown(e) {\n super.handleKeyDown(e);\n const wrapperHasFocus = this.getWrapperHasFocus();\n switch (e.key) {\n case KeyCode.UP:\n case KeyCode.DOWN:\n if (!wrapperHasFocus) {\n e.preventDefault();\n }\n case KeyCode.LEFT:\n case KeyCode.RIGHT:\n if (wrapperHasFocus) {\n return;\n }\n e.stopPropagation();\n case KeyCode.ENTER:\n if (wrapperHasFocus) {\n if (this.focusService.focusInto(this.eGui)) {\n e.preventDefault();\n }\n }\n break;\n case KeyCode.ESCAPE:\n if (!wrapperHasFocus) {\n this.eGui.focus();\n }\n }\n }\n onFocusIn(e) {\n const isRelatedWithin = this.eGui.contains(e.relatedTarget);\n // when the focus is already within the component,\n // we default to the browser's behavior\n if (isRelatedWithin) {\n return;\n }\n const notFromHeaderWrapper = !!e.relatedTarget && !e.relatedTarget.classList.contains('ag-floating-filter');\n const fromWithinHeader = !!e.relatedTarget && isElementChildOfClass(e.relatedTarget, 'ag-floating-filter');\n if (notFromHeaderWrapper && fromWithinHeader && e.target === this.eGui) {\n const lastFocusEvent = this.lastFocusEvent;\n const fromTab = !!(lastFocusEvent && lastFocusEvent.key === KeyCode.TAB);\n if (lastFocusEvent && fromTab) {\n const shouldFocusLast = lastFocusEvent.shiftKey;\n this.focusService.focusInto(this.eGui, shouldFocusLast);\n }\n }\n const rowIndex = this.getRowIndex();\n this.beans.focusService.setFocusedHeader(rowIndex, this.column);\n }\n setupHover() {\n this.createManagedBean(new HoverFeature([this.column], this.eGui));\n const listener = () => {\n if (!this.gridOptionsService.is('columnHoverHighlight')) {\n return;\n }\n const hovered = this.columnHoverService.isHovered(this.column);\n this.comp.addOrRemoveCssClass('ag-column-hover', hovered);\n };\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_HOVER_CHANGED, listener);\n listener();\n }\n setupLeft() {\n const setLeftFeature = new SetLeftFeature(this.column, this.eGui, this.beans);\n this.createManagedBean(setLeftFeature);\n }\n setupFilterButton() {\n const colDef = this.column.getColDef();\n // this is unusual - we need a params value OUTSIDE the component the params are for.\n // the params are for the floating filter component, but this property is actually for the wrapper.\n this.suppressFilterButton = colDef.floatingFilterComponentParams ? !!colDef.floatingFilterComponentParams.suppressFilterButton : false;\n }\n setupUserComp() {\n if (!this.active) {\n return;\n }\n const compDetails = this.filterManager.getFloatingFilterCompDetails(this.column, () => this.showParentFilter());\n if (compDetails) {\n this.setCompDetails(compDetails);\n }\n }\n setCompDetails(compDetails) {\n this.userCompDetails = compDetails;\n this.comp.setCompDetails(compDetails);\n }\n showParentFilter() {\n const eventSource = this.suppressFilterButton ? this.eFloatingFilterBody : this.eButtonShowMainFilter;\n this.menuFactory.showMenuAfterButtonClick(this.column, eventSource, 'floatingFilter', 'filterMenuTab', ['filterMenuTab']);\n }\n setupSyncWithFilter() {\n if (!this.active) {\n return;\n }\n const syncWithFilter = (filterChangedEvent) => {\n const compPromise = this.comp.getFloatingFilterComp();\n if (!compPromise) {\n return;\n }\n compPromise.then(comp => {\n if (comp) {\n const parentModel = this.filterManager.getCurrentFloatingFilterParentModel(this.column);\n comp.onParentModelChanged(parentModel, filterChangedEvent);\n }\n });\n };\n this.destroySyncListener = this.addManagedListener(this.column, Column.EVENT_FILTER_CHANGED, syncWithFilter);\n if (this.filterManager.isFilterActive(this.column)) {\n syncWithFilter(null);\n }\n }\n setupWidth() {\n const listener = () => {\n const width = `${this.column.getActualWidth()}px`;\n this.comp.setWidth(width);\n };\n this.addManagedListener(this.column, Column.EVENT_WIDTH_CHANGED, listener);\n listener();\n }\n setupFilterChangedListener() {\n if (this.active) {\n this.destroyFilterChangedListener = this.addManagedListener(this.column, Column.EVENT_FILTER_CHANGED, this.updateFilterButton.bind(this));\n }\n }\n updateFilterButton() {\n if (!this.suppressFilterButton && this.comp) {\n this.comp.setButtonWrapperDisplayed(this.filterManager.isFilterAllowed(this.column));\n }\n }\n onColDefChanged() {\n var _a, _b;\n const wasActive = this.active;\n this.setupActive();\n const becomeActive = !wasActive && this.active;\n if (wasActive && !this.active) {\n (_a = this.destroySyncListener) === null || _a === void 0 ? void 0 : _a.call(this);\n (_b = this.destroyFilterChangedListener) === null || _b === void 0 ? void 0 : _b.call(this);\n }\n const newCompDetails = this.active\n ? this.filterManager.getFloatingFilterCompDetails(this.column, () => this.showParentFilter())\n : null;\n const compPromise = this.comp.getFloatingFilterComp();\n if (!compPromise || !newCompDetails) {\n this.updateCompDetails(newCompDetails, becomeActive);\n }\n else {\n compPromise.then(compInstance => {\n var _a;\n if (!compInstance || this.filterManager.areFilterCompsDifferent((_a = this.userCompDetails) !== null && _a !== void 0 ? _a : null, newCompDetails)) {\n this.updateCompDetails(newCompDetails, becomeActive);\n }\n else {\n this.updateFloatingFilterParams(newCompDetails);\n }\n });\n }\n }\n updateCompDetails(compDetails, becomeActive) {\n this.setCompDetails(compDetails);\n // filter button and UI can change based on params, so always want to update\n this.setupFilterButton();\n this.setupUi();\n if (becomeActive) {\n this.setupSyncWithFilter();\n this.setupFilterChangedListener();\n }\n }\n updateFloatingFilterParams(userCompDetails) {\n var _a;\n if (!userCompDetails) {\n return;\n }\n const params = userCompDetails.params;\n (_a = this.comp.getFloatingFilterComp()) === null || _a === void 0 ? void 0 : _a.then(floatingFilter => {\n if ((floatingFilter === null || floatingFilter === void 0 ? void 0 : floatingFilter.onParamsUpdated) && typeof floatingFilter.onParamsUpdated === 'function') {\n floatingFilter.onParamsUpdated(params);\n }\n });\n }\n}\n__decorate([\n Autowired('filterManager')\n], HeaderFilterCellCtrl.prototype, \"filterManager\", void 0);\n__decorate([\n Autowired('columnHoverService')\n], HeaderFilterCellCtrl.prototype, \"columnHoverService\", void 0);\n__decorate([\n Autowired('menuFactory')\n], HeaderFilterCellCtrl.prototype, \"menuFactory\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../../context/beanStub.mjs\";\nimport { Autowired, PostConstruct } from \"../../../context/context.mjs\";\nimport { setDisplayed } from \"../../../utils/dom.mjs\";\nimport { TouchListener } from \"../../../widgets/touchListener.mjs\";\nexport class ResizeFeature extends BeanStub {\n constructor(pinned, column, eResize, comp, ctrl) {\n super();\n this.pinned = pinned;\n this.column = column;\n this.eResize = eResize;\n this.comp = comp;\n this.ctrl = ctrl;\n }\n postConstruct() {\n const colDef = this.column.getColDef();\n const destroyResizeFuncs = [];\n let canResize;\n let canAutosize;\n const addResize = () => {\n setDisplayed(this.eResize, canResize);\n if (!canResize) {\n return;\n }\n const finishedWithResizeFunc = this.horizontalResizeService.addResizeBar({\n eResizeBar: this.eResize,\n onResizeStart: this.onResizeStart.bind(this),\n onResizing: this.onResizing.bind(this, false),\n onResizeEnd: this.onResizing.bind(this, true)\n });\n destroyResizeFuncs.push(finishedWithResizeFunc);\n if (canAutosize) {\n const skipHeaderOnAutoSize = this.gridOptionsService.is('skipHeaderOnAutoSize');\n const autoSizeColListener = () => {\n this.columnModel.autoSizeColumn(this.column, skipHeaderOnAutoSize, \"uiColumnResized\");\n };\n this.eResize.addEventListener('dblclick', autoSizeColListener);\n const touchListener = new TouchListener(this.eResize);\n touchListener.addEventListener(TouchListener.EVENT_DOUBLE_TAP, autoSizeColListener);\n this.addDestroyFunc(() => {\n this.eResize.removeEventListener('dblclick', autoSizeColListener);\n touchListener.removeEventListener(TouchListener.EVENT_DOUBLE_TAP, autoSizeColListener);\n touchListener.destroy();\n });\n }\n };\n const removeResize = () => {\n destroyResizeFuncs.forEach(f => f());\n destroyResizeFuncs.length = 0;\n };\n const refresh = () => {\n const resize = this.column.isResizable();\n const autoSize = !this.gridOptionsService.is('suppressAutoSize') && !colDef.suppressAutoSize;\n const propertyChange = resize !== canResize || autoSize !== canAutosize;\n if (propertyChange) {\n canResize = resize;\n canAutosize = autoSize;\n removeResize();\n addResize();\n }\n };\n refresh();\n this.addDestroyFunc(removeResize);\n this.ctrl.addRefreshFunction(refresh);\n }\n onResizing(finished, resizeAmount) {\n const resizeAmountNormalised = this.normaliseResizeAmount(resizeAmount);\n const columnWidths = [{ key: this.column, newWidth: this.resizeStartWidth + resizeAmountNormalised }];\n this.columnModel.setColumnWidths(columnWidths, this.resizeWithShiftKey, finished, \"uiColumnResized\");\n if (finished) {\n this.comp.addOrRemoveCssClass('ag-column-resizing', false);\n }\n }\n onResizeStart(shiftKey) {\n this.resizeStartWidth = this.column.getActualWidth();\n this.resizeWithShiftKey = shiftKey;\n this.comp.addOrRemoveCssClass('ag-column-resizing', true);\n }\n // optionally inverts the drag, depending on pinned and RTL\n // note - this method is duplicated in RenderedHeaderGroupCell - should refactor out?\n normaliseResizeAmount(dragChange) {\n let result = dragChange;\n const notPinningLeft = this.pinned !== 'left';\n const pinningRight = this.pinned === 'right';\n if (this.gridOptionsService.is('enableRtl')) {\n // for RTL, dragging left makes the col bigger, except when pinning left\n if (notPinningLeft) {\n result *= -1;\n }\n }\n else {\n // for LTR (ie normal), dragging left makes the col smaller, except when pinning right\n if (pinningRight) {\n result *= -1;\n }\n }\n return result;\n }\n}\n__decorate([\n Autowired('horizontalResizeService')\n], ResizeFeature.prototype, \"horizontalResizeService\", void 0);\n__decorate([\n Autowired('columnModel')\n], ResizeFeature.prototype, \"columnModel\", void 0);\n__decorate([\n PostConstruct\n], ResizeFeature.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { AgCheckbox } from \"../../../widgets/agCheckbox.mjs\";\nimport { BeanStub } from \"../../../context/beanStub.mjs\";\nimport { Autowired } from \"../../../context/context.mjs\";\nimport { Events } from \"../../../events.mjs\";\nimport { setAriaHidden, setAriaRole } from \"../../../utils/aria.mjs\";\nexport class SelectAllFeature extends BeanStub {\n constructor(column) {\n super();\n this.cbSelectAllVisible = false;\n this.processingEventFromCheckbox = false;\n this.column = column;\n const colDef = column.getColDef();\n this.filteredOnly = !!(colDef === null || colDef === void 0 ? void 0 : colDef.headerCheckboxSelectionFilteredOnly);\n this.currentPageOnly = !!(colDef === null || colDef === void 0 ? void 0 : colDef.headerCheckboxSelectionCurrentPageOnly);\n }\n onSpaceKeyDown(e) {\n const checkbox = this.cbSelectAll;\n const eDocument = this.gridOptionsService.getDocument();\n if (checkbox.isDisplayed() && !checkbox.getGui().contains(eDocument.activeElement)) {\n e.preventDefault();\n checkbox.setValue(!checkbox.getValue());\n }\n }\n getCheckboxGui() {\n return this.cbSelectAll.getGui();\n }\n setComp(ctrl) {\n this.headerCellCtrl = ctrl;\n this.cbSelectAll = this.createManagedBean(new AgCheckbox());\n this.cbSelectAll.addCssClass('ag-header-select-all');\n setAriaRole(this.cbSelectAll.getGui(), 'presentation');\n this.showOrHideSelectAll();\n this.addManagedListener(this.eventService, Events.EVENT_NEW_COLUMNS_LOADED, this.showOrHideSelectAll.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, this.showOrHideSelectAll.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_SELECTION_CHANGED, this.onSelectionChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_PAGINATION_CHANGED, this.onSelectionChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_MODEL_UPDATED, this.onModelChanged.bind(this));\n this.addManagedListener(this.cbSelectAll, Events.EVENT_FIELD_VALUE_CHANGED, this.onCbSelectAll.bind(this));\n setAriaHidden(this.cbSelectAll.getGui(), true);\n this.cbSelectAll.getInputElement().setAttribute('tabindex', '-1');\n this.refreshSelectAllLabel();\n }\n showOrHideSelectAll() {\n this.cbSelectAllVisible = this.isCheckboxSelection();\n this.cbSelectAll.setDisplayed(this.cbSelectAllVisible, { skipAriaHidden: true });\n if (this.cbSelectAllVisible) {\n // in case user is trying this feature with the wrong model type\n this.checkRightRowModelType('selectAllCheckbox');\n // in case user is trying this feature with the wrong model type\n this.checkSelectionType('selectAllCheckbox');\n // make sure checkbox is showing the right state\n this.updateStateOfCheckbox();\n }\n this.refreshSelectAllLabel();\n }\n onModelChanged() {\n if (!this.cbSelectAllVisible) {\n return;\n }\n this.updateStateOfCheckbox();\n }\n onSelectionChanged() {\n if (!this.cbSelectAllVisible) {\n return;\n }\n this.updateStateOfCheckbox();\n }\n updateStateOfCheckbox() {\n if (this.processingEventFromCheckbox) {\n return;\n }\n this.processingEventFromCheckbox = true;\n const allSelected = this.selectionService.getSelectAllState(this.filteredOnly, this.currentPageOnly);\n this.cbSelectAll.setValue(allSelected);\n this.refreshSelectAllLabel();\n this.processingEventFromCheckbox = false;\n }\n refreshSelectAllLabel() {\n const translate = this.localeService.getLocaleTextFunc();\n const checked = this.cbSelectAll.getValue();\n const ariaStatus = checked ? translate('ariaChecked', 'checked') : translate('ariaUnchecked', 'unchecked');\n const ariaLabel = translate('ariaRowSelectAll', 'Press Space to toggle all rows selection');\n if (!this.cbSelectAllVisible) {\n this.headerCellCtrl.setAriaDescriptionProperty('selectAll', null);\n }\n else {\n this.headerCellCtrl.setAriaDescriptionProperty('selectAll', `${ariaLabel} (${ariaStatus})`);\n }\n this.cbSelectAll.setInputAriaLabel(`${ariaLabel} (${ariaStatus})`);\n this.headerCellCtrl.refreshAriaDescription();\n }\n checkSelectionType(feature) {\n const isMultiSelect = this.gridOptionsService.get('rowSelection') === 'multiple';\n if (!isMultiSelect) {\n console.warn(`AG Grid: ${feature} is only available if using 'multiple' rowSelection.`);\n return false;\n }\n return true;\n }\n checkRightRowModelType(feature) {\n const rowModelType = this.rowModel.getType();\n const rowModelMatches = rowModelType === 'clientSide' || rowModelType === 'serverSide';\n if (!rowModelMatches) {\n console.warn(`AG Grid: ${feature} is only available if using 'clientSide' or 'serverSide' rowModelType, you are using ${rowModelType}.`);\n return false;\n }\n return true;\n }\n onCbSelectAll() {\n if (this.processingEventFromCheckbox) {\n return;\n }\n if (!this.cbSelectAllVisible) {\n return;\n }\n const value = this.cbSelectAll.getValue();\n let source = 'uiSelectAll';\n if (this.currentPageOnly)\n source = 'uiSelectAllCurrentPage';\n else if (this.filteredOnly)\n source = 'uiSelectAllFiltered';\n const params = {\n source,\n justFiltered: this.filteredOnly,\n justCurrentPage: this.currentPageOnly,\n };\n if (value) {\n this.selectionService.selectAllRowNodes(params);\n }\n else {\n this.selectionService.deselectAllRowNodes(params);\n }\n }\n isCheckboxSelection() {\n let result = this.column.getColDef().headerCheckboxSelection;\n if (typeof result === 'function') {\n const func = result;\n const params = {\n column: this.column,\n colDef: this.column.getColDef(),\n columnApi: this.columnApi,\n api: this.gridApi,\n context: this.gridOptionsService.context\n };\n result = func(params);\n }\n if (result) {\n return this.checkRightRowModelType('headerCheckboxSelection') && this.checkSelectionType('headerCheckboxSelection');\n }\n return false;\n }\n}\n__decorate([\n Autowired('gridApi')\n], SelectAllFeature.prototype, \"gridApi\", void 0);\n__decorate([\n Autowired('columnApi')\n], SelectAllFeature.prototype, \"columnApi\", void 0);\n__decorate([\n Autowired('rowModel')\n], SelectAllFeature.prototype, \"rowModel\", void 0);\n__decorate([\n Autowired('selectionService')\n], SelectAllFeature.prototype, \"selectionService\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { Autowired, PostConstruct } from \"../context/context.mjs\";\nimport { ManagedFocusFeature } from \"./managedFocusFeature.mjs\";\nexport var TabGuardClassNames;\n(function (TabGuardClassNames) {\n TabGuardClassNames[\"TAB_GUARD\"] = \"ag-tab-guard\";\n TabGuardClassNames[\"TAB_GUARD_TOP\"] = \"ag-tab-guard-top\";\n TabGuardClassNames[\"TAB_GUARD_BOTTOM\"] = \"ag-tab-guard-bottom\";\n})(TabGuardClassNames || (TabGuardClassNames = {}));\n;\nexport class TabGuardCtrl extends BeanStub {\n constructor(params) {\n super();\n this.skipTabGuardFocus = false;\n const { comp, eTopGuard, eBottomGuard, focusInnerElement, onFocusIn, onFocusOut, shouldStopEventPropagation, onTabKeyDown, handleKeyDown, eFocusableElement } = params;\n this.comp = comp;\n this.eTopGuard = eTopGuard;\n this.eBottomGuard = eBottomGuard;\n this.providedFocusInnerElement = focusInnerElement;\n this.eFocusableElement = eFocusableElement;\n this.providedFocusIn = onFocusIn;\n this.providedFocusOut = onFocusOut;\n this.providedShouldStopEventPropagation = shouldStopEventPropagation;\n this.providedOnTabKeyDown = onTabKeyDown;\n this.providedHandleKeyDown = handleKeyDown;\n }\n postConstruct() {\n this.createManagedBean(new ManagedFocusFeature(this.eFocusableElement, {\n shouldStopEventPropagation: () => this.shouldStopEventPropagation(),\n onTabKeyDown: e => this.onTabKeyDown(e),\n handleKeyDown: e => this.handleKeyDown(e),\n onFocusIn: e => this.onFocusIn(e),\n onFocusOut: e => this.onFocusOut(e)\n }));\n this.activateTabGuards();\n [this.eTopGuard, this.eBottomGuard].forEach(guard => this.addManagedListener(guard, 'focus', this.onFocus.bind(this)));\n }\n handleKeyDown(e) {\n if (this.providedHandleKeyDown) {\n this.providedHandleKeyDown(e);\n }\n }\n tabGuardsAreActive() {\n return !!this.eTopGuard && this.eTopGuard.hasAttribute('tabIndex');\n }\n shouldStopEventPropagation() {\n if (this.providedShouldStopEventPropagation) {\n return this.providedShouldStopEventPropagation();\n }\n return false;\n }\n activateTabGuards() {\n const tabIndex = this.gridOptionsService.getNum('tabIndex') || 0;\n this.comp.setTabIndex(tabIndex.toString());\n }\n deactivateTabGuards() {\n this.comp.setTabIndex();\n }\n onFocus(e) {\n if (this.skipTabGuardFocus) {\n this.skipTabGuardFocus = false;\n return;\n }\n const fromBottom = e.target === this.eBottomGuard;\n if (this.providedFocusInnerElement) {\n this.providedFocusInnerElement(fromBottom);\n }\n else {\n this.focusInnerElement(fromBottom);\n }\n }\n onFocusIn(e) {\n if (this.providedFocusIn && this.providedFocusIn(e)) {\n return;\n }\n this.deactivateTabGuards();\n }\n onFocusOut(e) {\n if (this.providedFocusOut && this.providedFocusOut(e)) {\n return;\n }\n if (!this.eFocusableElement.contains(e.relatedTarget)) {\n this.activateTabGuards();\n }\n }\n onTabKeyDown(e) {\n if (this.providedOnTabKeyDown) {\n this.providedOnTabKeyDown(e);\n return;\n }\n if (e.defaultPrevented) {\n return;\n }\n const tabGuardsAreActive = this.tabGuardsAreActive();\n if (tabGuardsAreActive) {\n this.deactivateTabGuards();\n }\n const nextRoot = this.getNextFocusableElement(e.shiftKey);\n if (tabGuardsAreActive) {\n // ensure the tab guards are only re-instated once the event has finished processing, to avoid the browser\n // tabbing to the tab guard from inside the component\n setTimeout(() => this.activateTabGuards(), 0);\n }\n if (!nextRoot) {\n return;\n }\n nextRoot.focus();\n e.preventDefault();\n }\n focusInnerElement(fromBottom = false) {\n const focusable = this.focusService.findFocusableElements(this.eFocusableElement);\n if (this.tabGuardsAreActive()) {\n // remove tab guards from this component from list of focusable elements\n focusable.splice(0, 1);\n focusable.splice(focusable.length - 1, 1);\n }\n if (!focusable.length) {\n return;\n }\n focusable[fromBottom ? focusable.length - 1 : 0].focus({ preventScroll: true });\n }\n getNextFocusableElement(backwards) {\n return this.focusService.findNextFocusableElement(this.eFocusableElement, false, backwards);\n }\n forceFocusOutOfContainer(up = false) {\n const tabGuardToFocus = up ? this.eTopGuard : this.eBottomGuard;\n this.activateTabGuards();\n this.skipTabGuardFocus = true;\n tabGuardToFocus.focus();\n }\n}\n__decorate([\n Autowired('focusService')\n], TabGuardCtrl.prototype, \"focusService\", void 0);\n__decorate([\n PostConstruct\n], TabGuardCtrl.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar FocusService_1;\nimport { Autowired, Bean, Optional, PostConstruct } from \"./context/context.mjs\";\nimport { BeanStub } from \"./context/beanStub.mjs\";\nimport { Events } from \"./events.mjs\";\nimport { ManagedFocusFeature } from \"./widgets/managedFocusFeature.mjs\";\nimport { getTabIndex } from './utils/browser.mjs';\nimport { makeNull } from './utils/generic.mjs';\nimport { RowCtrl } from \"./rendering/row/rowCtrl.mjs\";\nimport { AbstractHeaderCellCtrl } from \"./headerRendering/cells/abstractCell/abstractHeaderCellCtrl.mjs\";\nimport { last } from \"./utils/array.mjs\";\nimport { FOCUSABLE_EXCLUDE, FOCUSABLE_SELECTOR } from \"./utils/dom.mjs\";\nimport { TabGuardClassNames } from \"./widgets/tabGuardCtrl.mjs\";\nlet FocusService = FocusService_1 = class FocusService extends BeanStub {\n /**\n * Adds a gridCore to the list of the gridCores monitoring Keyboard Mode\n * in a specific HTMLDocument.\n *\n * @param doc {Document} - The Document containing the gridCore.\n * @param gridCore {GridComp} - The GridCore to be monitored.\n */\n static addKeyboardModeEvents(doc, controller) {\n const docControllers = FocusService_1.instancesMonitored.get(doc);\n if (docControllers && docControllers.length > 0) {\n if (docControllers.indexOf(controller) === -1) {\n docControllers.push(controller);\n }\n }\n else {\n FocusService_1.instancesMonitored.set(doc, [controller]);\n doc.addEventListener('keydown', FocusService_1.toggleKeyboardMode);\n doc.addEventListener('mousedown', FocusService_1.toggleKeyboardMode);\n }\n }\n /**\n * Removes a gridCore from the list of the gridCores monitoring Keyboard Mode\n * in a specific HTMLDocument.\n *\n * @param doc {Document} - The Document containing the gridCore.\n * @param gridCore {GridComp} - The GridCore to be removed.\n */\n static removeKeyboardModeEvents(doc, controller) {\n const docControllers = FocusService_1.instancesMonitored.get(doc);\n let newControllers = [];\n if (docControllers && docControllers.length) {\n newControllers = [...docControllers].filter(currentGridCore => currentGridCore !== controller);\n FocusService_1.instancesMonitored.set(doc, newControllers);\n }\n if (newControllers.length === 0) {\n doc.removeEventListener('keydown', FocusService_1.toggleKeyboardMode);\n doc.removeEventListener('mousedown', FocusService_1.toggleKeyboardMode);\n }\n }\n /**\n * This method will be called by `keydown` and `mousedown` events on all Documents monitoring\n * KeyboardMode. It will then fire a KEYBOARD_FOCUS, MOUSE_FOCUS on each gridCore present in\n * the Document allowing each gridCore to maintain a state for KeyboardMode.\n *\n * @param event {KeyboardEvent | MouseEvent | TouchEvent} - The event triggered.\n */\n static toggleKeyboardMode(event) {\n const isKeyboardActive = FocusService_1.keyboardModeActive;\n const isKeyboardEvent = event.type === 'keydown';\n if (isKeyboardEvent) {\n // the following keys should not toggle keyboard mode.\n if (event.ctrlKey || event.metaKey || event.altKey) {\n return;\n }\n }\n if (isKeyboardActive && isKeyboardEvent || !isKeyboardActive && !isKeyboardEvent) {\n return;\n }\n FocusService_1.keyboardModeActive = isKeyboardEvent;\n const doc = event.target.ownerDocument;\n if (!doc) {\n return;\n }\n const controllersForDoc = FocusService_1.instancesMonitored.get(doc);\n if (controllersForDoc) {\n controllersForDoc.forEach(controller => {\n controller.dispatchEvent({ type: isKeyboardEvent ? Events.EVENT_KEYBOARD_FOCUS : Events.EVENT_MOUSE_FOCUS });\n });\n }\n }\n init() {\n const clearFocusedCellListener = this.clearFocusedCell.bind(this);\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PIVOT_MODE_CHANGED, clearFocusedCellListener);\n this.addManagedListener(this.eventService, Events.EVENT_NEW_COLUMNS_LOADED, this.onColumnEverythingChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_GROUP_OPENED, clearFocusedCellListener);\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, clearFocusedCellListener);\n this.ctrlsService.whenReady(p => {\n this.gridCtrl = p.gridCtrl;\n const doc = this.gridOptionsService.getDocument();\n FocusService_1.addKeyboardModeEvents(doc, this.gridCtrl);\n this.addDestroyFunc(() => this.unregisterGridCompController(this.gridCtrl));\n });\n }\n unregisterGridCompController(gridCompController) {\n const doc = this.gridOptionsService.getDocument();\n FocusService_1.removeKeyboardModeEvents(doc, gridCompController);\n }\n onColumnEverythingChanged() {\n // if the columns change, check and see if this column still exists. if it does, then\n // we can keep the focused cell. if it doesn't, then we need to drop the focused cell.\n if (!this.focusedCellPosition) {\n return;\n }\n const col = this.focusedCellPosition.column;\n const colFromColumnModel = this.columnModel.getGridColumn(col.getId());\n if (col !== colFromColumnModel) {\n this.clearFocusedCell();\n }\n }\n isKeyboardMode() {\n return FocusService_1.keyboardModeActive;\n }\n // we check if the browser is focusing something, and if it is, and\n // it's the cell we think is focused, then return the cell. so this\n // methods returns the cell if a) we think it has focus and b) the\n // browser thinks it has focus. this then returns nothing if we\n // first focus a cell, then second click outside the grid, as then the\n // grid cell will still be focused as far as the grid is concerned,\n // however the browser focus will have moved somewhere else.\n getFocusCellToUseAfterRefresh() {\n const eDocument = this.gridOptionsService.getDocument();\n if (this.gridOptionsService.is('suppressFocusAfterRefresh') || !this.focusedCellPosition) {\n return null;\n }\n // we check that the browser is actually focusing on the grid, if it is not, then\n // we have nothing to worry about. we check for ROW data, as this covers both focused Rows (for Full Width Rows)\n // and Cells (covers cells as cells live in rows)\n if (this.isDomDataMissingInHierarchy(eDocument.activeElement, RowCtrl.DOM_DATA_KEY_ROW_CTRL)) {\n return null;\n }\n return this.focusedCellPosition;\n }\n getFocusHeaderToUseAfterRefresh() {\n const eDocument = this.gridOptionsService.getDocument();\n if (this.gridOptionsService.is('suppressFocusAfterRefresh') || !this.focusedHeaderPosition) {\n return null;\n }\n // we check that the browser is actually focusing on the grid, if it is not, then\n // we have nothing to worry about\n if (this.isDomDataMissingInHierarchy(eDocument.activeElement, AbstractHeaderCellCtrl.DOM_DATA_KEY_HEADER_CTRL)) {\n return null;\n }\n return this.focusedHeaderPosition;\n }\n isDomDataMissingInHierarchy(eBrowserCell, key) {\n let ePointer = eBrowserCell;\n while (ePointer) {\n const data = this.gridOptionsService.getDomData(ePointer, key);\n if (data) {\n return false;\n }\n ePointer = ePointer.parentNode;\n }\n return true;\n }\n getFocusedCell() {\n return this.focusedCellPosition;\n }\n shouldRestoreFocus(cell) {\n if (this.isCellRestoreFocused(cell)) {\n setTimeout(() => {\n // Clear the restore focused cell position after the timeout to avoid\n // the cell being focused again and stealing focus from another part of the app.\n this.restoredFocusedCellPosition = null;\n }, 0);\n return true;\n }\n return false;\n }\n isCellRestoreFocused(cellPosition) {\n if (this.restoredFocusedCellPosition == null) {\n return false;\n }\n return this.cellPositionUtils.equals(cellPosition, this.restoredFocusedCellPosition);\n }\n setRestoreFocusedCell(cellPosition) {\n if (this.getFrameworkOverrides().renderingEngine === 'react') {\n // The restoredFocusedCellPosition is used in the React Rendering engine as we have to be able\n // to support restoring focus after an async rendering.\n this.restoredFocusedCellPosition = cellPosition;\n }\n }\n getFocusEventParams() {\n const { rowIndex, rowPinned, column } = this.focusedCellPosition;\n const params = {\n rowIndex: rowIndex,\n rowPinned: rowPinned,\n column: column,\n isFullWidthCell: false\n };\n const rowCtrl = this.rowRenderer.getRowByPosition({ rowIndex, rowPinned });\n if (rowCtrl) {\n params.isFullWidthCell = rowCtrl.isFullWidth();\n }\n return params;\n }\n clearFocusedCell() {\n this.restoredFocusedCellPosition = null;\n if (this.focusedCellPosition == null) {\n return;\n }\n const event = Object.assign({ type: Events.EVENT_CELL_FOCUS_CLEARED }, this.getFocusEventParams());\n this.focusedCellPosition = null;\n this.eventService.dispatchEvent(event);\n }\n setFocusedCell(params) {\n const { column, rowIndex, rowPinned, forceBrowserFocus = false, preventScrollOnBrowserFocus = false } = params;\n const gridColumn = this.columnModel.getGridColumn(column);\n // if column doesn't exist, then blank the focused cell and return. this can happen when user sets new columns,\n // and the focused cell is in a column that no longer exists. after columns change, the grid refreshes and tries\n // to re-focus the focused cell.\n if (!gridColumn) {\n this.focusedCellPosition = null;\n return;\n }\n this.focusedCellPosition = gridColumn ? {\n rowIndex: rowIndex,\n rowPinned: makeNull(rowPinned),\n column: gridColumn\n } : null;\n const event = Object.assign(Object.assign({ type: Events.EVENT_CELL_FOCUSED }, this.getFocusEventParams()), { forceBrowserFocus,\n preventScrollOnBrowserFocus, floating: null });\n this.eventService.dispatchEvent(event);\n }\n isCellFocused(cellPosition) {\n if (this.focusedCellPosition == null) {\n return false;\n }\n return this.cellPositionUtils.equals(cellPosition, this.focusedCellPosition);\n }\n isRowNodeFocused(rowNode) {\n return this.isRowFocused(rowNode.rowIndex, rowNode.rowPinned);\n }\n isHeaderWrapperFocused(headerCtrl) {\n if (this.focusedHeaderPosition == null) {\n return false;\n }\n const column = headerCtrl.getColumnGroupChild();\n const headerRowIndex = headerCtrl.getRowIndex();\n const pinned = headerCtrl.getPinned();\n const { column: focusedColumn, headerRowIndex: focusedHeaderRowIndex } = this.focusedHeaderPosition;\n return column === focusedColumn &&\n headerRowIndex === focusedHeaderRowIndex &&\n pinned == focusedColumn.getPinned();\n }\n clearFocusedHeader() {\n this.focusedHeaderPosition = null;\n }\n getFocusedHeader() {\n return this.focusedHeaderPosition;\n }\n setFocusedHeader(headerRowIndex, column) {\n this.focusedHeaderPosition = { headerRowIndex, column };\n }\n focusHeaderPosition(params) {\n const { direction, fromTab, allowUserOverride, event, fromCell } = params;\n let { headerPosition } = params;\n if (fromCell && this.filterManager.isAdvancedFilterHeaderActive()) {\n return this.focusAdvancedFilter(headerPosition);\n }\n if (allowUserOverride) {\n const currentPosition = this.getFocusedHeader();\n const headerRowCount = this.headerNavigationService.getHeaderRowCount();\n if (fromTab) {\n const userFunc = this.gridOptionsService.getCallback('tabToNextHeader');\n if (userFunc) {\n const params = {\n backwards: direction === 'Before',\n previousHeaderPosition: currentPosition,\n nextHeaderPosition: headerPosition,\n headerRowCount,\n };\n headerPosition = userFunc(params);\n }\n }\n else {\n const userFunc = this.gridOptionsService.getCallback('navigateToNextHeader');\n if (userFunc && event) {\n const params = {\n key: event.key,\n previousHeaderPosition: currentPosition,\n nextHeaderPosition: headerPosition,\n headerRowCount,\n event,\n };\n headerPosition = userFunc(params);\n }\n }\n }\n if (!headerPosition) {\n return false;\n }\n if (headerPosition.headerRowIndex === -1) {\n if (this.filterManager.isAdvancedFilterHeaderActive()) {\n return this.focusAdvancedFilter(headerPosition);\n }\n else {\n return this.focusGridView(headerPosition.column);\n }\n }\n this.headerNavigationService.scrollToColumn(headerPosition.column, direction);\n const headerRowContainerCtrl = this.ctrlsService.getHeaderRowContainerCtrl(headerPosition.column.getPinned());\n // this will automatically call the setFocusedHeader method above\n const focusSuccess = headerRowContainerCtrl.focusHeader(headerPosition.headerRowIndex, headerPosition.column, event);\n return focusSuccess;\n }\n focusFirstHeader() {\n let firstColumn = this.columnModel.getAllDisplayedColumns()[0];\n if (!firstColumn) {\n return false;\n }\n if (firstColumn.getParent()) {\n firstColumn = this.columnModel.getColumnGroupAtLevel(firstColumn, 0);\n }\n return this.focusHeaderPosition({\n headerPosition: { headerRowIndex: 0, column: firstColumn }\n });\n }\n focusLastHeader(event) {\n const headerRowIndex = this.headerNavigationService.getHeaderRowCount() - 1;\n const column = last(this.columnModel.getAllDisplayedColumns());\n return this.focusHeaderPosition({\n headerPosition: { headerRowIndex, column },\n event\n });\n }\n focusPreviousFromFirstCell(event) {\n if (this.filterManager.isAdvancedFilterHeaderActive()) {\n return this.focusAdvancedFilter(null);\n }\n else {\n return this.focusLastHeader(event);\n }\n }\n isAnyCellFocused() {\n return !!this.focusedCellPosition;\n }\n isRowFocused(rowIndex, floating) {\n if (this.focusedCellPosition == null) {\n return false;\n }\n return this.focusedCellPosition.rowIndex === rowIndex && this.focusedCellPosition.rowPinned === makeNull(floating);\n }\n findFocusableElements(rootNode, exclude, onlyUnmanaged = false) {\n const focusableString = FOCUSABLE_SELECTOR;\n let excludeString = FOCUSABLE_EXCLUDE;\n if (exclude) {\n excludeString += ', ' + exclude;\n }\n if (onlyUnmanaged) {\n excludeString += ', [tabindex=\"-1\"]';\n }\n const nodes = Array.prototype.slice.apply(rootNode.querySelectorAll(focusableString));\n const excludeNodes = Array.prototype.slice.apply(rootNode.querySelectorAll(excludeString));\n if (!excludeNodes.length) {\n return nodes;\n }\n const diff = (a, b) => a.filter(element => b.indexOf(element) === -1);\n return diff(nodes, excludeNodes);\n }\n focusInto(rootNode, up = false, onlyUnmanaged = false) {\n const focusableElements = this.findFocusableElements(rootNode, null, onlyUnmanaged);\n const toFocus = up ? last(focusableElements) : focusableElements[0];\n if (toFocus) {\n toFocus.focus({ preventScroll: true });\n return true;\n }\n return false;\n }\n findFocusableElementBeforeTabGuard(rootNode, referenceElement) {\n if (!referenceElement) {\n return null;\n }\n const focusableElements = this.findFocusableElements(rootNode);\n const referenceIndex = focusableElements.indexOf(referenceElement);\n if (referenceIndex === -1) {\n return null;\n }\n let lastTabGuardIndex = -1;\n for (let i = referenceIndex - 1; i >= 0; i--) {\n if (focusableElements[i].classList.contains(TabGuardClassNames.TAB_GUARD_TOP)) {\n lastTabGuardIndex = i;\n break;\n }\n }\n if (lastTabGuardIndex <= 0) {\n return null;\n }\n return focusableElements[lastTabGuardIndex - 1];\n }\n findNextFocusableElement(rootNode = this.eGridDiv, onlyManaged, backwards) {\n const focusable = this.findFocusableElements(rootNode, onlyManaged ? ':not([tabindex=\"-1\"])' : null);\n const eDocument = this.gridOptionsService.getDocument();\n const activeEl = eDocument.activeElement;\n let currentIndex;\n if (onlyManaged) {\n currentIndex = focusable.findIndex(el => el.contains(activeEl));\n }\n else {\n currentIndex = focusable.indexOf(activeEl);\n }\n const nextIndex = currentIndex + (backwards ? -1 : 1);\n if (nextIndex < 0 || nextIndex >= focusable.length) {\n return null;\n }\n return focusable[nextIndex];\n }\n isTargetUnderManagedComponent(rootNode, target) {\n if (!target) {\n return false;\n }\n const managedContainers = rootNode.querySelectorAll(`.${ManagedFocusFeature.FOCUS_MANAGED_CLASS}`);\n if (!managedContainers.length) {\n return false;\n }\n for (let i = 0; i < managedContainers.length; i++) {\n if (managedContainers[i].contains(target)) {\n return true;\n }\n }\n return false;\n }\n findTabbableParent(node, limit = 5) {\n let counter = 0;\n while (node && getTabIndex(node) === null && ++counter <= limit) {\n node = node.parentElement;\n }\n if (getTabIndex(node) === null) {\n return null;\n }\n return node;\n }\n focusGridView(column, backwards) {\n // if suppressCellFocus is `true`, it means the user does not want to\n // navigate between the cells using tab. Instead, we put focus on either\n // the header or after the grid, depending on whether tab or shift-tab was pressed.\n if (this.gridOptionsService.is('suppressCellFocus')) {\n if (backwards) {\n return this.focusLastHeader();\n }\n return this.focusNextGridCoreContainer(false);\n }\n const nextRow = backwards\n ? this.rowPositionUtils.getLastRow()\n : this.rowPositionUtils.getFirstRow();\n if (!nextRow) {\n return false;\n }\n const { rowIndex, rowPinned } = nextRow;\n const focusedHeader = this.getFocusedHeader();\n if (!column && focusedHeader) {\n column = focusedHeader.column;\n }\n if (rowIndex == null || !column) {\n return false;\n }\n this.navigationService.ensureCellVisible({ rowIndex, column, rowPinned });\n this.setFocusedCell({\n rowIndex,\n column,\n rowPinned: makeNull(rowPinned),\n forceBrowserFocus: true\n });\n if (this.rangeService) {\n const cellPosition = { rowIndex, rowPinned, column };\n this.rangeService.setRangeToCell(cellPosition);\n }\n return true;\n }\n focusNextGridCoreContainer(backwards, forceOut = false) {\n if (!forceOut && this.gridCtrl.focusNextInnerContainer(backwards)) {\n return true;\n }\n if (forceOut || (!backwards && !this.gridCtrl.isDetailGrid())) {\n this.gridCtrl.forceFocusOutOfContainer(backwards);\n }\n return false;\n }\n focusAdvancedFilter(position) {\n this.advancedFilterFocusColumn = position === null || position === void 0 ? void 0 : position.column;\n return this.advancedFilterService.getCtrl().focusHeaderComp();\n }\n focusNextFromAdvancedFilter(backwards, forceFirstColumn) {\n var _a, _b;\n const column = (_a = (forceFirstColumn ? undefined : this.advancedFilterFocusColumn)) !== null && _a !== void 0 ? _a : (_b = this.columnModel.getAllDisplayedColumns()) === null || _b === void 0 ? void 0 : _b[0];\n if (backwards) {\n return this.focusHeaderPosition({\n headerPosition: {\n column: column,\n headerRowIndex: this.headerNavigationService.getHeaderRowCount() - 1\n }\n });\n }\n else {\n return this.focusGridView(column);\n }\n }\n clearAdvancedFilterColumn() {\n this.advancedFilterFocusColumn = undefined;\n }\n};\nFocusService.AG_KEYBOARD_FOCUS = 'ag-keyboard-focus';\nFocusService.keyboardModeActive = false;\nFocusService.instancesMonitored = new Map();\n__decorate([\n Autowired('eGridDiv')\n], FocusService.prototype, \"eGridDiv\", void 0);\n__decorate([\n Autowired('columnModel')\n], FocusService.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('headerNavigationService')\n], FocusService.prototype, \"headerNavigationService\", void 0);\n__decorate([\n Autowired('rowRenderer')\n], FocusService.prototype, \"rowRenderer\", void 0);\n__decorate([\n Autowired('rowPositionUtils')\n], FocusService.prototype, \"rowPositionUtils\", void 0);\n__decorate([\n Autowired('cellPositionUtils')\n], FocusService.prototype, \"cellPositionUtils\", void 0);\n__decorate([\n Optional('rangeService')\n], FocusService.prototype, \"rangeService\", void 0);\n__decorate([\n Autowired('navigationService')\n], FocusService.prototype, \"navigationService\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], FocusService.prototype, \"ctrlsService\", void 0);\n__decorate([\n Autowired('filterManager')\n], FocusService.prototype, \"filterManager\", void 0);\n__decorate([\n Optional('advancedFilterService')\n], FocusService.prototype, \"advancedFilterService\", void 0);\n__decorate([\n PostConstruct\n], FocusService.prototype, \"init\", null);\nFocusService = FocusService_1 = __decorate([\n Bean('focusService')\n], FocusService);\nexport { FocusService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { KeyCode } from '../../../constants/keyCode.mjs';\nimport { Autowired, PreDestroy } from \"../../../context/context.mjs\";\nimport { DragAndDropService, DragSourceType } from \"../../../dragAndDrop/dragAndDropService.mjs\";\nimport { Column } from \"../../../entities/column.mjs\";\nimport { Events } from \"../../../eventKeys.mjs\";\nimport { SetLeftFeature } from \"../../../rendering/features/setLeftFeature.mjs\";\nimport { getAriaSortState } from \"../../../utils/aria.mjs\";\nimport { ManagedFocusFeature } from \"../../../widgets/managedFocusFeature.mjs\";\nimport { TooltipFeature } from \"../../../widgets/tooltipFeature.mjs\";\nimport { AbstractHeaderCellCtrl } from \"../abstractCell/abstractHeaderCellCtrl.mjs\";\nimport { CssClassApplier } from \"../cssClassApplier.mjs\";\nimport { HoverFeature } from \"../hoverFeature.mjs\";\nimport { ResizeFeature } from \"./resizeFeature.mjs\";\nimport { SelectAllFeature } from \"./selectAllFeature.mjs\";\nimport { getElementSize } from \"../../../utils/dom.mjs\";\nimport { isBrowserSafari } from \"../../../utils/browser.mjs\";\nimport { FocusService } from \"../../../focusService.mjs\";\nexport class HeaderCellCtrl extends AbstractHeaderCellCtrl {\n constructor(column, parentRowCtrl) {\n super(column, parentRowCtrl);\n this.refreshFunctions = [];\n this.userHeaderClasses = new Set();\n this.ariaDescriptionProperties = new Map();\n this.column = column;\n }\n setComp(comp, eGui, eResize, eHeaderCompWrapper) {\n super.setGui(eGui);\n this.comp = comp;\n this.updateState();\n this.setupWidth();\n this.setupMovingCss();\n this.setupMenuClass();\n this.setupSortableClass();\n this.setupWrapTextClass();\n this.refreshSpanHeaderHeight();\n this.setupAutoHeight(eHeaderCompWrapper);\n this.addColumnHoverListener();\n this.setupFilterCss();\n this.setupClassesFromColDef();\n this.setupTooltip();\n this.addActiveHeaderMouseListeners();\n this.setupSelectAll();\n this.setupUserComp();\n this.refreshAria();\n this.createManagedBean(new ResizeFeature(this.getPinned(), this.column, eResize, comp, this));\n this.createManagedBean(new HoverFeature([this.column], eGui));\n this.createManagedBean(new SetLeftFeature(this.column, eGui, this.beans));\n this.createManagedBean(new ManagedFocusFeature(eGui, {\n shouldStopEventPropagation: e => this.shouldStopEventPropagation(e),\n onTabKeyDown: () => null,\n handleKeyDown: this.handleKeyDown.bind(this),\n onFocusIn: this.onFocusIn.bind(this),\n onFocusOut: this.onFocusOut.bind(this)\n }));\n this.addMouseDownListenerIfNeeded(eGui);\n this.addManagedListener(this.column, Column.EVENT_COL_DEF_CHANGED, this.onColDefChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_VALUE_CHANGED, this.onColumnValueChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, this.onColumnRowGroupChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PIVOT_CHANGED, this.onColumnPivotChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_HEADER_HEIGHT_CHANGED, this.onHeaderHeightChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, this.onHeaderHeightChanged.bind(this));\n }\n addMouseDownListenerIfNeeded(eGui) {\n // we add a preventDefault in the DragService for Safari only\n // so we need to make sure we don't prevent focus on mousedown\n if (!isBrowserSafari()) {\n return;\n }\n const events = ['mousedown', 'touchstart'];\n const eDocument = this.gridOptionsService.getDocument();\n events.forEach(eventName => {\n this.addManagedListener(eGui, eventName, (e) => {\n const activeEl = eDocument.activeElement;\n if (activeEl !== eGui && !eGui.contains(activeEl)) {\n eGui.focus();\n FocusService.toggleKeyboardMode(e);\n }\n });\n });\n }\n setupUserComp() {\n const compDetails = this.lookupUserCompDetails();\n this.setCompDetails(compDetails);\n }\n setCompDetails(compDetails) {\n this.userCompDetails = compDetails;\n this.comp.setUserCompDetails(compDetails);\n }\n lookupUserCompDetails() {\n const params = this.createParams();\n const colDef = this.column.getColDef();\n return this.userComponentFactory.getHeaderCompDetails(colDef, params);\n }\n createParams() {\n const colDef = this.column.getColDef();\n const params = {\n column: this.column,\n displayName: this.displayName,\n enableSorting: colDef.sortable,\n enableMenu: this.menuEnabled,\n showColumnMenu: (source) => {\n this.gridApi.showColumnMenuAfterButtonClick(this.column, source);\n },\n progressSort: (multiSort) => {\n this.sortController.progressSort(this.column, !!multiSort, \"uiColumnSorted\");\n },\n setSort: (sort, multiSort) => {\n this.sortController.setSortForColumn(this.column, sort, !!multiSort, \"uiColumnSorted\");\n },\n api: this.gridApi,\n columnApi: this.columnApi,\n context: this.gridOptionsService.context,\n eGridHeader: this.getGui()\n };\n return params;\n }\n setupSelectAll() {\n this.selectAllFeature = this.createManagedBean(new SelectAllFeature(this.column));\n this.selectAllFeature.setComp(this);\n }\n getSelectAllGui() {\n return this.selectAllFeature.getCheckboxGui();\n }\n handleKeyDown(e) {\n super.handleKeyDown(e);\n if (e.key === KeyCode.SPACE) {\n this.selectAllFeature.onSpaceKeyDown(e);\n }\n if (e.key === KeyCode.ENTER) {\n this.onEnterKeyDown(e);\n }\n }\n onEnterKeyDown(e) {\n /// THIS IS BAD - we are assuming the header is not a user provided comp\n const headerComp = this.comp.getUserCompInstance();\n if (!headerComp) {\n return;\n }\n if (e.ctrlKey || e.metaKey) {\n if (this.menuEnabled && headerComp.showMenu) {\n e.preventDefault();\n headerComp.showMenu();\n }\n }\n else if (this.sortable) {\n const multiSort = e.shiftKey;\n this.sortController.progressSort(this.column, multiSort, \"uiColumnSorted\");\n }\n }\n isMenuEnabled() {\n return this.menuEnabled;\n }\n onFocusIn(e) {\n if (!this.getGui().contains(e.relatedTarget)) {\n const rowIndex = this.getRowIndex();\n this.focusService.setFocusedHeader(rowIndex, this.column);\n }\n this.setActiveHeader(true);\n }\n onFocusOut(e) {\n if (this.getGui().contains(e.relatedTarget)) {\n return;\n }\n this.setActiveHeader(false);\n }\n setupTooltip() {\n const tooltipCtrl = {\n getColumn: () => this.column,\n getColDef: () => this.column.getColDef(),\n getGui: () => this.eGui,\n getLocation: () => 'header',\n getTooltipValue: () => {\n const res = this.column.getColDef().headerTooltip;\n return res;\n },\n };\n const tooltipFeature = this.createManagedBean(new TooltipFeature(tooltipCtrl, this.beans));\n tooltipFeature.setComp(this.eGui);\n this.refreshFunctions.push(() => tooltipFeature.refreshToolTip());\n }\n setupClassesFromColDef() {\n const refreshHeaderClasses = () => {\n const colDef = this.column.getColDef();\n const classes = CssClassApplier.getHeaderClassesFromColDef(colDef, this.gridOptionsService, this.column, null);\n const oldClasses = this.userHeaderClasses;\n this.userHeaderClasses = new Set(classes);\n classes.forEach(c => {\n if (oldClasses.has(c)) {\n // class already added, no need to apply it, but remove from old set\n oldClasses.delete(c);\n }\n else {\n // class new since last time, so apply it\n this.comp.addOrRemoveCssClass(c, true);\n }\n });\n // now old set only has classes that were applied last time, but not this time, so remove them\n oldClasses.forEach(c => this.comp.addOrRemoveCssClass(c, false));\n };\n this.refreshFunctions.push(refreshHeaderClasses);\n refreshHeaderClasses();\n }\n setDragSource(eSource) {\n this.dragSourceElement = eSource;\n this.removeDragSource();\n if (!eSource) {\n return;\n }\n if (!this.draggable) {\n return;\n }\n let hideColumnOnExit = !this.gridOptionsService.is('suppressDragLeaveHidesColumns');\n this.moveDragSource = {\n type: DragSourceType.HeaderCell,\n eElement: eSource,\n getDefaultIconName: () => hideColumnOnExit ? DragAndDropService.ICON_HIDE : DragAndDropService.ICON_NOT_ALLOWED,\n getDragItem: () => this.createDragItem(),\n dragItemName: this.displayName,\n onDragStarted: () => {\n hideColumnOnExit = !this.gridOptionsService.is('suppressDragLeaveHidesColumns');\n this.column.setMoving(true, \"uiColumnMoved\");\n },\n onDragStopped: () => this.column.setMoving(false, \"uiColumnMoved\"),\n onGridEnter: (dragItem) => {\n var _a;\n if (hideColumnOnExit) {\n const unlockedColumns = ((_a = dragItem === null || dragItem === void 0 ? void 0 : dragItem.columns) === null || _a === void 0 ? void 0 : _a.filter(col => !col.getColDef().lockVisible)) || [];\n this.columnModel.setColumnsVisible(unlockedColumns, true, \"uiColumnMoved\");\n }\n },\n onGridExit: (dragItem) => {\n var _a;\n if (hideColumnOnExit) {\n const unlockedColumns = ((_a = dragItem === null || dragItem === void 0 ? void 0 : dragItem.columns) === null || _a === void 0 ? void 0 : _a.filter(col => !col.getColDef().lockVisible)) || [];\n this.columnModel.setColumnsVisible(unlockedColumns, false, \"uiColumnMoved\");\n }\n },\n };\n this.dragAndDropService.addDragSource(this.moveDragSource, true);\n }\n createDragItem() {\n const visibleState = {};\n visibleState[this.column.getId()] = this.column.isVisible();\n return {\n columns: [this.column],\n visibleState: visibleState\n };\n }\n removeDragSource() {\n if (this.moveDragSource) {\n this.dragAndDropService.removeDragSource(this.moveDragSource);\n this.moveDragSource = undefined;\n }\n }\n onColDefChanged() {\n this.refresh();\n }\n updateState() {\n const colDef = this.column.getColDef();\n this.menuEnabled = this.menuFactory.isMenuEnabled(this.column) && !colDef.suppressMenu;\n this.sortable = colDef.sortable;\n this.displayName = this.calculateDisplayName();\n this.draggable = this.workOutDraggable();\n }\n addRefreshFunction(func) {\n this.refreshFunctions.push(func);\n }\n refresh() {\n this.updateState();\n this.refreshHeaderComp();\n this.refreshAria();\n this.refreshFunctions.forEach(f => f());\n }\n refreshHeaderComp() {\n const newCompDetails = this.lookupUserCompDetails();\n const compInstance = this.comp.getUserCompInstance();\n // only try refresh if old comp exists adn it is the correct type\n const attemptRefresh = compInstance != null && this.userCompDetails.componentClass == newCompDetails.componentClass;\n const headerCompRefreshed = attemptRefresh ? this.attemptHeaderCompRefresh(newCompDetails.params) : false;\n if (headerCompRefreshed) {\n // we do this as a refresh happens after colDefs change, and it's possible the column has had it's\n // draggable property toggled. no need to call this if not refreshing, as setDragSource is done\n // as part of appendHeaderComp\n this.setDragSource(this.dragSourceElement);\n }\n else {\n this.setCompDetails(newCompDetails);\n }\n }\n attemptHeaderCompRefresh(params) {\n const headerComp = this.comp.getUserCompInstance();\n if (!headerComp) {\n return false;\n }\n // if no refresh method, then we want to replace the headerComp\n if (!headerComp.refresh) {\n return false;\n }\n const res = headerComp.refresh(params);\n return res;\n }\n calculateDisplayName() {\n return this.columnModel.getDisplayNameForColumn(this.column, 'header', true);\n }\n checkDisplayName() {\n // display name can change if aggFunc different, eg sum(Gold) is now max(Gold)\n if (this.displayName !== this.calculateDisplayName()) {\n this.refresh();\n }\n }\n workOutDraggable() {\n const colDef = this.column.getColDef();\n const isSuppressMovableColumns = this.gridOptionsService.is('suppressMovableColumns');\n const colCanMove = !isSuppressMovableColumns && !colDef.suppressMovable && !colDef.lockPosition;\n // we should still be allowed drag the column, even if it can't be moved, if the column\n // can be dragged to a rowGroup or pivot drop zone\n return !!colCanMove || !!colDef.enableRowGroup || !!colDef.enablePivot;\n }\n onColumnRowGroupChanged() {\n this.checkDisplayName();\n }\n onColumnPivotChanged() {\n this.checkDisplayName();\n }\n onColumnValueChanged() {\n this.checkDisplayName();\n }\n setupWidth() {\n const listener = () => {\n const columnWidth = this.column.getActualWidth();\n this.comp.setWidth(`${columnWidth}px`);\n };\n this.addManagedListener(this.column, Column.EVENT_WIDTH_CHANGED, listener);\n listener();\n }\n setupMovingCss() {\n const listener = () => {\n // this is what makes the header go dark when it is been moved (gives impression to\n // user that the column was picked up).\n this.comp.addOrRemoveCssClass('ag-header-cell-moving', this.column.isMoving());\n };\n this.addManagedListener(this.column, Column.EVENT_MOVING_CHANGED, listener);\n listener();\n }\n setupMenuClass() {\n const listener = () => {\n this.comp.addOrRemoveCssClass('ag-column-menu-visible', this.column.isMenuVisible());\n };\n this.addManagedListener(this.column, Column.EVENT_MENU_VISIBLE_CHANGED, listener);\n listener();\n }\n setupSortableClass() {\n const updateSortableCssClass = () => {\n this.comp.addOrRemoveCssClass('ag-header-cell-sortable', !!this.sortable);\n };\n updateSortableCssClass();\n this.addRefreshFunction(updateSortableCssClass);\n this.addManagedListener(this.eventService, Column.EVENT_SORT_CHANGED, this.refreshAriaSort.bind(this));\n }\n setupWrapTextClass() {\n const listener = () => {\n const wrapText = !!this.column.getColDef().wrapHeaderText;\n this.comp.addOrRemoveCssClass('ag-header-cell-wrap-text', wrapText);\n };\n listener();\n this.addRefreshFunction(listener);\n }\n onHeaderHeightChanged() {\n this.refreshSpanHeaderHeight();\n }\n refreshSpanHeaderHeight() {\n const { eGui, column, comp, columnModel, gridOptionsService } = this;\n if (!column.isSpanHeaderHeight()) {\n return;\n }\n const { numberOfParents, isSpanningTotal } = this.getColumnGroupPaddingInfo();\n comp.addOrRemoveCssClass('ag-header-span-height', numberOfParents > 0);\n const headerHeight = columnModel.getColumnHeaderRowHeight();\n if (numberOfParents === 0) {\n // if spanning has stopped then need to reset these values.\n comp.addOrRemoveCssClass('ag-header-span-total', false);\n eGui.style.setProperty('top', `0px`);\n eGui.style.setProperty('height', `${headerHeight}px`);\n return;\n }\n comp.addOrRemoveCssClass('ag-header-span-total', isSpanningTotal);\n const pivotMode = gridOptionsService.is('pivotMode');\n const groupHeaderHeight = pivotMode\n ? columnModel.getPivotGroupHeaderHeight()\n : columnModel.getGroupHeaderHeight();\n const extraHeight = numberOfParents * groupHeaderHeight;\n eGui.style.setProperty('top', `${-extraHeight}px`);\n eGui.style.setProperty('height', `${headerHeight + extraHeight}px`);\n }\n getColumnGroupPaddingInfo() {\n let parent = this.column.getParent();\n if (!parent || !parent.isPadding()) {\n return { numberOfParents: 0, isSpanningTotal: false };\n }\n const numberOfParents = parent.getPaddingLevel() + 1;\n let isSpanningTotal = true;\n while (parent) {\n if (!parent.isPadding()) {\n isSpanningTotal = false;\n break;\n }\n parent = parent.getParent();\n }\n return { numberOfParents, isSpanningTotal };\n }\n setupAutoHeight(wrapperElement) {\n const measureHeight = (timesCalled) => {\n if (!this.isAlive()) {\n return;\n }\n const { paddingTop, paddingBottom, borderBottomWidth, borderTopWidth } = getElementSize(this.getGui());\n const extraHeight = paddingTop + paddingBottom + borderBottomWidth + borderTopWidth;\n const wrapperHeight = wrapperElement.offsetHeight;\n const autoHeight = wrapperHeight + extraHeight;\n if (timesCalled < 5) {\n // if not in doc yet, means framework not yet inserted, so wait for next VM turn,\n // maybe it will be ready next VM turn\n const doc = this.beans.gridOptionsService.getDocument();\n const notYetInDom = !doc || !doc.contains(wrapperElement);\n // this happens in React, where React hasn't put any content in. we say 'possibly'\n // as a) may not be React and b) the cell could be empty anyway\n const possiblyNoContentYet = autoHeight == 0;\n if (notYetInDom || possiblyNoContentYet) {\n this.beans.frameworkOverrides.setTimeout(() => measureHeight(timesCalled + 1), 0);\n return;\n }\n }\n this.columnModel.setColumnHeaderHeight(this.column, autoHeight);\n };\n let isMeasuring = false;\n let stopResizeObserver;\n const checkMeasuring = () => {\n const newValue = this.column.isAutoHeaderHeight();\n if (newValue && !isMeasuring) {\n startMeasuring();\n }\n if (!newValue && isMeasuring) {\n stopMeasuring();\n }\n };\n const startMeasuring = () => {\n isMeasuring = true;\n measureHeight(0);\n this.comp.addOrRemoveCssClass('ag-header-cell-auto-height', true);\n stopResizeObserver = this.resizeObserverService.observeResize(wrapperElement, () => measureHeight(0));\n };\n const stopMeasuring = () => {\n isMeasuring = false;\n if (stopResizeObserver) {\n stopResizeObserver();\n }\n this.comp.addOrRemoveCssClass('ag-header-cell-auto-height', false);\n stopResizeObserver = undefined;\n };\n checkMeasuring();\n this.addDestroyFunc(() => stopMeasuring());\n // In theory we could rely on the resize observer for everything - but since it's debounced\n // it can be a little janky for smooth movement. in this case its better to react to our own events\n // And unfortunately we cant _just_ rely on our own events, since custom components can change whenever\n this.addManagedListener(this.column, Column.EVENT_WIDTH_CHANGED, () => isMeasuring && measureHeight(0));\n // Displaying the sort icon changes the available area for text, so sort changes can affect height\n this.addManagedListener(this.eventService, Column.EVENT_SORT_CHANGED, () => {\n // Rendering changes for sort, happen after the event... not ideal\n if (isMeasuring) {\n this.beans.frameworkOverrides.setTimeout(() => measureHeight(0));\n }\n });\n this.addRefreshFunction(checkMeasuring);\n }\n refreshAriaSort() {\n if (this.sortable) {\n const translate = this.localeService.getLocaleTextFunc();\n const sort = this.sortController.getDisplaySortForColumn(this.column) || null;\n this.comp.setAriaSort(getAriaSortState(sort));\n this.setAriaDescriptionProperty('sort', translate('ariaSortableColumn', 'Press ENTER to sort.'));\n }\n else {\n this.comp.setAriaSort();\n this.setAriaDescriptionProperty('sort', null);\n }\n }\n refreshAriaMenu() {\n if (this.menuEnabled) {\n const translate = this.localeService.getLocaleTextFunc();\n this.setAriaDescriptionProperty('menu', translate('ariaMenuColumn', 'Press CTRL ENTER to open column menu.'));\n }\n else {\n this.setAriaDescriptionProperty('menu', null);\n }\n }\n setAriaDescriptionProperty(property, value) {\n if (value != null) {\n this.ariaDescriptionProperties.set(property, value);\n }\n else {\n this.ariaDescriptionProperties.delete(property);\n }\n }\n refreshAriaDescription() {\n const descriptionArray = Array.from(this.ariaDescriptionProperties.values());\n this.comp.setAriaDescription(descriptionArray.length ? descriptionArray.join(' ') : undefined);\n }\n refreshAria() {\n this.refreshAriaSort();\n this.refreshAriaMenu();\n this.refreshAriaDescription();\n }\n addColumnHoverListener() {\n const listener = () => {\n if (!this.gridOptionsService.is('columnHoverHighlight')) {\n return;\n }\n const isHovered = this.columnHoverService.isHovered(this.column);\n this.comp.addOrRemoveCssClass('ag-column-hover', isHovered);\n };\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_HOVER_CHANGED, listener);\n listener();\n }\n setupFilterCss() {\n const listener = () => {\n this.comp.addOrRemoveCssClass('ag-header-cell-filtered', this.column.isFilterActive());\n };\n this.addManagedListener(this.column, Column.EVENT_FILTER_ACTIVE_CHANGED, listener);\n listener();\n }\n getColId() {\n return this.column.getColId();\n }\n addActiveHeaderMouseListeners() {\n const listener = (e) => this.setActiveHeader(e.type === 'mouseenter');\n this.addManagedListener(this.getGui(), 'mouseenter', listener);\n this.addManagedListener(this.getGui(), 'mouseleave', listener);\n }\n setActiveHeader(active) {\n this.comp.addOrRemoveCssClass('ag-header-active', active);\n }\n}\n__decorate([\n Autowired('columnModel')\n], HeaderCellCtrl.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('columnHoverService')\n], HeaderCellCtrl.prototype, \"columnHoverService\", void 0);\n__decorate([\n Autowired('sortController')\n], HeaderCellCtrl.prototype, \"sortController\", void 0);\n__decorate([\n Autowired('menuFactory')\n], HeaderCellCtrl.prototype, \"menuFactory\", void 0);\n__decorate([\n Autowired('dragAndDropService')\n], HeaderCellCtrl.prototype, \"dragAndDropService\", void 0);\n__decorate([\n Autowired('resizeObserverService')\n], HeaderCellCtrl.prototype, \"resizeObserverService\", void 0);\n__decorate([\n Autowired('gridApi')\n], HeaderCellCtrl.prototype, \"gridApi\", void 0);\n__decorate([\n Autowired('columnApi')\n], HeaderCellCtrl.prototype, \"columnApi\", void 0);\n__decorate([\n PreDestroy\n], HeaderCellCtrl.prototype, \"removeDragSource\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../../context/beanStub.mjs\";\nimport { Autowired, PostConstruct } from \"../../../context/context.mjs\";\nexport class GroupResizeFeature extends BeanStub {\n constructor(comp, eResize, pinned, columnGroup) {\n super();\n this.eResize = eResize;\n this.comp = comp;\n this.pinned = pinned;\n this.columnGroup = columnGroup;\n }\n postConstruct() {\n if (!this.columnGroup.isResizable()) {\n this.comp.setResizableDisplayed(false);\n return;\n }\n const finishedWithResizeFunc = this.horizontalResizeService.addResizeBar({\n eResizeBar: this.eResize,\n onResizeStart: this.onResizeStart.bind(this),\n onResizing: this.onResizing.bind(this, false),\n onResizeEnd: this.onResizing.bind(this, true)\n });\n this.addDestroyFunc(finishedWithResizeFunc);\n if (!this.gridOptionsService.is('suppressAutoSize')) {\n const skipHeaderOnAutoSize = this.gridOptionsService.is('skipHeaderOnAutoSize');\n this.eResize.addEventListener('dblclick', () => {\n // get list of all the column keys we are responsible for\n const keys = [];\n const leafCols = this.columnGroup.getDisplayedLeafColumns();\n leafCols.forEach((column) => {\n // not all cols in the group may be participating with auto-resize\n if (!column.getColDef().suppressAutoSize) {\n keys.push(column.getColId());\n }\n });\n if (keys.length > 0) {\n this.columnModel.autoSizeColumns({\n columns: keys,\n skipHeader: skipHeaderOnAutoSize,\n stopAtGroup: this.columnGroup,\n source: 'uiColumnResized'\n });\n }\n this.resizeLeafColumnsToFit('uiColumnResized');\n });\n }\n }\n onResizeStart(shiftKey) {\n this.calculateInitialValues();\n let takeFromGroup = null;\n if (shiftKey) {\n takeFromGroup = this.columnModel.getDisplayedGroupAfter(this.columnGroup);\n }\n if (takeFromGroup) {\n const takeFromLeafCols = takeFromGroup.getDisplayedLeafColumns();\n this.resizeTakeFromCols = takeFromLeafCols.filter(col => col.isResizable());\n this.resizeTakeFromStartWidth = 0;\n this.resizeTakeFromCols.forEach(col => this.resizeTakeFromStartWidth += col.getActualWidth());\n this.resizeTakeFromRatios = [];\n this.resizeTakeFromCols.forEach(col => this.resizeTakeFromRatios.push(col.getActualWidth() / this.resizeTakeFromStartWidth));\n }\n else {\n this.resizeTakeFromCols = null;\n this.resizeTakeFromStartWidth = null;\n this.resizeTakeFromRatios = null;\n }\n this.comp.addOrRemoveCssClass('ag-column-resizing', true);\n }\n onResizing(finished, resizeAmount, source = 'uiColumnResized') {\n const resizeAmountNormalised = this.normaliseDragChange(resizeAmount);\n const width = this.resizeStartWidth + resizeAmountNormalised;\n this.resizeColumns(width, source, finished);\n }\n resizeLeafColumnsToFit(source) {\n const preferredSize = this.autoWidthCalculator.getPreferredWidthForColumnGroup(this.columnGroup);\n this.calculateInitialValues();\n if (preferredSize > this.resizeStartWidth) {\n this.resizeColumns(preferredSize, source, true);\n }\n }\n resizeColumns(totalWidth, source, finished = true) {\n const resizeSets = [];\n resizeSets.push({\n columns: this.resizeCols,\n ratios: this.resizeRatios,\n width: totalWidth\n });\n if (this.resizeTakeFromCols) {\n const diff = totalWidth - this.resizeStartWidth;\n resizeSets.push({\n columns: this.resizeTakeFromCols,\n ratios: this.resizeTakeFromRatios,\n width: this.resizeTakeFromStartWidth - diff\n });\n }\n this.columnModel.resizeColumnSets({\n resizeSets,\n finished,\n source: source\n });\n if (finished) {\n this.comp.addOrRemoveCssClass('ag-column-resizing', false);\n }\n }\n calculateInitialValues() {\n const leafCols = this.columnGroup.getDisplayedLeafColumns();\n this.resizeCols = leafCols.filter(col => col.isResizable());\n this.resizeStartWidth = 0;\n this.resizeCols.forEach(col => this.resizeStartWidth += col.getActualWidth());\n this.resizeRatios = [];\n this.resizeCols.forEach(col => this.resizeRatios.push(col.getActualWidth() / this.resizeStartWidth));\n }\n // optionally inverts the drag, depending on pinned and RTL\n // note - this method is duplicated in RenderedHeaderCell - should refactor out?\n normaliseDragChange(dragChange) {\n let result = dragChange;\n if (this.gridOptionsService.is('enableRtl')) {\n // for RTL, dragging left makes the col bigger, except when pinning left\n if (this.pinned !== 'left') {\n result *= -1;\n }\n }\n else if (this.pinned === 'right') {\n // for LTR (ie normal), dragging left makes the col smaller, except when pinning right\n result *= -1;\n }\n return result;\n }\n}\n__decorate([\n Autowired('horizontalResizeService')\n], GroupResizeFeature.prototype, \"horizontalResizeService\", void 0);\n__decorate([\n Autowired('autoWidthCalculator')\n], GroupResizeFeature.prototype, \"autoWidthCalculator\", void 0);\n__decorate([\n Autowired('columnModel')\n], GroupResizeFeature.prototype, \"columnModel\", void 0);\n__decorate([\n PostConstruct\n], GroupResizeFeature.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../../context/beanStub.mjs\";\nimport { PostConstruct } from \"../../../context/context.mjs\";\nimport { ColumnGroup } from \"../../../entities/columnGroup.mjs\";\nexport class GroupWidthFeature extends BeanStub {\n constructor(comp, columnGroup) {\n super();\n // the children can change, we keep destroy functions related to listening to the children here\n this.removeChildListenersFuncs = [];\n this.columnGroup = columnGroup;\n this.comp = comp;\n }\n postConstruct() {\n // we need to listen to changes in child columns, as they impact our width\n this.addListenersToChildrenColumns();\n // the children belonging to this group can change, so we need to add and remove listeners as they change\n this.addManagedListener(this.columnGroup, ColumnGroup.EVENT_DISPLAYED_CHILDREN_CHANGED, this.onDisplayedChildrenChanged.bind(this));\n this.onWidthChanged();\n // the child listeners are not tied to this components life-cycle, as children can get added and removed\n // to the group - hence they are on a different life-cycle. so we must make sure the existing children\n // listeners are removed when we finally get destroyed\n this.addDestroyFunc(this.removeListenersOnChildrenColumns.bind(this));\n }\n addListenersToChildrenColumns() {\n // first destroy any old listeners\n this.removeListenersOnChildrenColumns();\n // now add new listeners to the new set of children\n const widthChangedListener = this.onWidthChanged.bind(this);\n this.columnGroup.getLeafColumns().forEach(column => {\n column.addEventListener('widthChanged', widthChangedListener);\n column.addEventListener('visibleChanged', widthChangedListener);\n this.removeChildListenersFuncs.push(() => {\n column.removeEventListener('widthChanged', widthChangedListener);\n column.removeEventListener('visibleChanged', widthChangedListener);\n });\n });\n }\n removeListenersOnChildrenColumns() {\n this.removeChildListenersFuncs.forEach(func => func());\n this.removeChildListenersFuncs = [];\n }\n onDisplayedChildrenChanged() {\n this.addListenersToChildrenColumns();\n this.onWidthChanged();\n }\n onWidthChanged() {\n const columnWidth = this.columnGroup.getActualWidth();\n this.comp.setWidth(`${columnWidth}px`);\n this.comp.addOrRemoveCssClass('ag-hidden', columnWidth === 0);\n }\n}\n__decorate([\n PostConstruct\n], GroupWidthFeature.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { KeyCode } from '../../../constants/keyCode.mjs';\nimport { Autowired } from \"../../../context/context.mjs\";\nimport { DragAndDropService, DragSourceType } from \"../../../dragAndDrop/dragAndDropService.mjs\";\nimport { Column } from \"../../../entities/column.mjs\";\nimport { ProvidedColumnGroup } from \"../../../entities/providedColumnGroup.mjs\";\nimport { SetLeftFeature } from \"../../../rendering/features/setLeftFeature.mjs\";\nimport { removeFromArray } from \"../../../utils/array.mjs\";\nimport { ManagedFocusFeature } from \"../../../widgets/managedFocusFeature.mjs\";\nimport { TooltipFeature } from \"../../../widgets/tooltipFeature.mjs\";\nimport { AbstractHeaderCellCtrl } from \"../abstractCell/abstractHeaderCellCtrl.mjs\";\nimport { CssClassApplier } from \"../cssClassApplier.mjs\";\nimport { HoverFeature } from \"../hoverFeature.mjs\";\nimport { GroupResizeFeature } from \"./groupResizeFeature.mjs\";\nimport { GroupWidthFeature } from \"./groupWidthFeature.mjs\";\nexport class HeaderGroupCellCtrl extends AbstractHeaderCellCtrl {\n constructor(columnGroup, parentRowCtrl) {\n super(columnGroup, parentRowCtrl);\n this.columnGroup = columnGroup;\n }\n setComp(comp, eGui, eResize) {\n super.setGui(eGui);\n this.comp = comp;\n this.displayName = this.columnModel.getDisplayNameForColumnGroup(this.columnGroup, 'header');\n this.addClasses();\n this.setupMovingCss();\n this.setupExpandable();\n this.setupTooltip();\n this.setupUserComp();\n const pinned = this.getParentRowCtrl().getPinned();\n const leafCols = this.columnGroup.getProvidedColumnGroup().getLeafColumns();\n this.createManagedBean(new HoverFeature(leafCols, eGui));\n this.createManagedBean(new SetLeftFeature(this.columnGroup, eGui, this.beans));\n this.createManagedBean(new GroupWidthFeature(comp, this.columnGroup));\n this.groupResizeFeature = this.createManagedBean(new GroupResizeFeature(comp, eResize, pinned, this.columnGroup));\n this.createManagedBean(new ManagedFocusFeature(eGui, {\n shouldStopEventPropagation: this.shouldStopEventPropagation.bind(this),\n onTabKeyDown: () => undefined,\n handleKeyDown: this.handleKeyDown.bind(this),\n onFocusIn: this.onFocusIn.bind(this)\n }));\n }\n resizeLeafColumnsToFit(source) {\n // check to avoid throwing when a component has not been setup yet (React 18)\n if (!this.groupResizeFeature) {\n return;\n }\n this.groupResizeFeature.resizeLeafColumnsToFit(source);\n }\n setupUserComp() {\n let displayName = this.displayName;\n const params = {\n displayName: this.displayName,\n columnGroup: this.columnGroup,\n setExpanded: (expanded) => {\n this.columnModel.setColumnGroupOpened(this.columnGroup.getProvidedColumnGroup(), expanded, \"gridInitializing\");\n },\n api: this.gridApi,\n columnApi: this.columnApi,\n context: this.gridOptionsService.context\n };\n if (!displayName) {\n let columnGroup = this.columnGroup;\n const leafCols = columnGroup.getLeafColumns();\n // find the top most column group that represents the same columns. so if we are dragging a group, we also\n // want to visually show the parent groups dragging for the same column set. for example imaging 5 levels\n // of grouping, with each group only containing the next group, and the last group containing three columns,\n // then when you move any group (even the lowest level group) you are in-fact moving all the groups, as all\n // the groups represent the same column set.\n while (columnGroup.getParent() && columnGroup.getParent().getLeafColumns().length === leafCols.length) {\n columnGroup = columnGroup.getParent();\n }\n const colGroupDef = columnGroup.getColGroupDef();\n if (colGroupDef) {\n displayName = colGroupDef.headerName;\n }\n if (!displayName) {\n displayName = leafCols ? this.columnModel.getDisplayNameForColumn(leafCols[0], 'header', true) : '';\n }\n }\n const compDetails = this.userComponentFactory.getHeaderGroupCompDetails(params);\n this.comp.setUserCompDetails(compDetails);\n }\n setupTooltip() {\n const colGroupDef = this.columnGroup.getColGroupDef();\n const tooltipCtrl = {\n getColumn: () => this.columnGroup,\n getGui: () => this.eGui,\n getLocation: () => 'headerGroup',\n getTooltipValue: () => colGroupDef && colGroupDef.headerTooltip\n };\n if (colGroupDef) {\n tooltipCtrl.getColDef = () => colGroupDef;\n }\n const tooltipFeature = this.createManagedBean(new TooltipFeature(tooltipCtrl, this.beans));\n tooltipFeature.setComp(this.eGui);\n }\n setupExpandable() {\n const providedColGroup = this.columnGroup.getProvidedColumnGroup();\n this.refreshExpanded();\n this.addManagedListener(providedColGroup, ProvidedColumnGroup.EVENT_EXPANDABLE_CHANGED, this.refreshExpanded.bind(this));\n this.addManagedListener(providedColGroup, ProvidedColumnGroup.EVENT_EXPANDED_CHANGED, this.refreshExpanded.bind(this));\n }\n refreshExpanded() {\n const column = this.columnGroup;\n this.expandable = column.isExpandable();\n const expanded = column.isExpanded();\n if (this.expandable) {\n this.comp.setAriaExpanded(expanded ? 'true' : 'false');\n }\n else {\n this.comp.setAriaExpanded(undefined);\n }\n }\n getColId() {\n return this.columnGroup.getUniqueId();\n }\n addClasses() {\n const colGroupDef = this.columnGroup.getColGroupDef();\n const classes = CssClassApplier.getHeaderClassesFromColDef(colGroupDef, this.gridOptionsService, null, this.columnGroup);\n // having different classes below allows the style to not have a bottom border\n // on the group header, if no group is specified\n if (this.columnGroup.isPadding()) {\n classes.push('ag-header-group-cell-no-group');\n const leafCols = this.columnGroup.getLeafColumns();\n if (leafCols.every(col => col.isSpanHeaderHeight())) {\n classes.push('ag-header-span-height');\n }\n }\n else {\n classes.push('ag-header-group-cell-with-group');\n }\n classes.forEach(c => this.comp.addOrRemoveCssClass(c, true));\n }\n setupMovingCss() {\n const providedColumnGroup = this.columnGroup.getProvidedColumnGroup();\n const leafColumns = providedColumnGroup.getLeafColumns();\n // this function adds or removes the moving css, based on if the col is moving.\n // this is what makes the header go dark when it is been moved (gives impression to\n // user that the column was picked up).\n const listener = () => this.comp.addOrRemoveCssClass('ag-header-cell-moving', this.columnGroup.isMoving());\n leafColumns.forEach(col => {\n this.addManagedListener(col, Column.EVENT_MOVING_CHANGED, listener);\n });\n listener();\n }\n onFocusIn(e) {\n if (!this.eGui.contains(e.relatedTarget)) {\n const rowIndex = this.getRowIndex();\n this.beans.focusService.setFocusedHeader(rowIndex, this.columnGroup);\n }\n }\n handleKeyDown(e) {\n super.handleKeyDown(e);\n const wrapperHasFocus = this.getWrapperHasFocus();\n if (!this.expandable || !wrapperHasFocus) {\n return;\n }\n if (e.key === KeyCode.ENTER) {\n const column = this.columnGroup;\n const newExpandedValue = !column.isExpanded();\n this.columnModel.setColumnGroupOpened(column.getProvidedColumnGroup(), newExpandedValue, \"uiColumnExpanded\");\n }\n }\n // unlike columns, this will only get called once, as we don't react on props on column groups\n // (we will always destroy and recreate this comp if something changes)\n setDragSource(eHeaderGroup) {\n if (this.isSuppressMoving()) {\n return;\n }\n const allLeafColumns = this.columnGroup.getProvidedColumnGroup().getLeafColumns();\n let hideColumnOnExit = !this.gridOptionsService.is('suppressDragLeaveHidesColumns');\n const dragSource = {\n type: DragSourceType.HeaderCell,\n eElement: eHeaderGroup,\n getDefaultIconName: () => hideColumnOnExit ? DragAndDropService.ICON_HIDE : DragAndDropService.ICON_NOT_ALLOWED,\n dragItemName: this.displayName,\n // we add in the original group leaf columns, so we move both visible and non-visible items\n getDragItem: this.getDragItemForGroup.bind(this),\n onDragStarted: () => {\n hideColumnOnExit = !this.gridOptionsService.is('suppressDragLeaveHidesColumns');\n allLeafColumns.forEach(col => col.setMoving(true, \"uiColumnDragged\"));\n },\n onDragStopped: () => allLeafColumns.forEach(col => col.setMoving(false, \"uiColumnDragged\")),\n onGridEnter: (dragItem) => {\n var _a;\n if (hideColumnOnExit) {\n const unlockedColumns = ((_a = dragItem === null || dragItem === void 0 ? void 0 : dragItem.columns) === null || _a === void 0 ? void 0 : _a.filter(col => !col.getColDef().lockVisible)) || [];\n this.columnModel.setColumnsVisible(unlockedColumns, true, \"uiColumnMoved\");\n }\n },\n onGridExit: (dragItem) => {\n var _a;\n if (hideColumnOnExit) {\n const unlockedColumns = ((_a = dragItem === null || dragItem === void 0 ? void 0 : dragItem.columns) === null || _a === void 0 ? void 0 : _a.filter(col => !col.getColDef().lockVisible)) || [];\n this.columnModel.setColumnsVisible(unlockedColumns, false, \"uiColumnMoved\");\n }\n },\n };\n this.dragAndDropService.addDragSource(dragSource, true);\n this.addDestroyFunc(() => this.dragAndDropService.removeDragSource(dragSource));\n }\n // when moving the columns, we want to move all the columns (contained within the DragItem) in this group in one go,\n // and in the order they are currently in the screen.\n getDragItemForGroup() {\n const allColumnsOriginalOrder = this.columnGroup.getProvidedColumnGroup().getLeafColumns();\n // capture visible state, used when re-entering grid to dictate which columns should be visible\n const visibleState = {};\n allColumnsOriginalOrder.forEach(column => visibleState[column.getId()] = column.isVisible());\n const allColumnsCurrentOrder = [];\n this.columnModel.getAllDisplayedColumns().forEach(column => {\n if (allColumnsOriginalOrder.indexOf(column) >= 0) {\n allColumnsCurrentOrder.push(column);\n removeFromArray(allColumnsOriginalOrder, column);\n }\n });\n // we are left with non-visible columns, stick these in at the end\n allColumnsOriginalOrder.forEach(column => allColumnsCurrentOrder.push(column));\n // create and return dragItem\n return {\n columns: allColumnsCurrentOrder,\n visibleState: visibleState\n };\n }\n isSuppressMoving() {\n // if any child is fixed, then don't allow moving\n let childSuppressesMoving = false;\n this.columnGroup.getLeafColumns().forEach((column) => {\n if (column.getColDef().suppressMovable || column.getColDef().lockPosition) {\n childSuppressesMoving = true;\n }\n });\n const result = childSuppressesMoving || this.gridOptionsService.is('suppressMovableColumns');\n return result;\n }\n}\n__decorate([\n Autowired('columnModel')\n], HeaderGroupCellCtrl.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('dragAndDropService')\n], HeaderGroupCellCtrl.prototype, \"dragAndDropService\", void 0);\n__decorate([\n Autowired('gridApi')\n], HeaderGroupCellCtrl.prototype, \"gridApi\", void 0);\n__decorate([\n Autowired('columnApi')\n], HeaderGroupCellCtrl.prototype, \"columnApi\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nimport { Autowired, PostConstruct } from \"../../context/context.mjs\";\nimport { Events } from \"../../eventKeys.mjs\";\nimport { isBrowserSafari } from \"../../utils/browser.mjs\";\nimport { getAllValuesInObject, iterateObject } from \"../../utils/object.mjs\";\nimport { HeaderFilterCellCtrl } from \"../cells/floatingFilter/headerFilterCellCtrl.mjs\";\nimport { HeaderCellCtrl } from \"../cells/column/headerCellCtrl.mjs\";\nimport { HeaderGroupCellCtrl } from \"../cells/columnGroup/headerGroupCellCtrl.mjs\";\nimport { HeaderRowType } from \"./headerRowComp.mjs\";\nimport { values } from \"../../utils/generic.mjs\";\nlet instanceIdSequence = 0;\nexport class HeaderRowCtrl extends BeanStub {\n constructor(rowIndex, pinned, type) {\n super();\n this.instanceId = instanceIdSequence++;\n this.headerCellCtrls = {};\n this.rowIndex = rowIndex;\n this.pinned = pinned;\n this.type = type;\n const typeClass = type == HeaderRowType.COLUMN_GROUP ? `ag-header-row-column-group` :\n type == HeaderRowType.FLOATING_FILTER ? `ag-header-row-column-filter` : `ag-header-row-column`;\n this.headerRowClass = `ag-header-row ${typeClass}`;\n }\n postConstruct() {\n this.isPrintLayout = this.gridOptionsService.isDomLayout('print');\n this.isEnsureDomOrder = this.gridOptionsService.is('ensureDomOrder');\n }\n getInstanceId() {\n return this.instanceId;\n }\n /**\n *\n * @param comp Proxy to the actual component\n * @param initCompState Should the component be initialised with the current state of the controller. Default: true\n */\n setComp(comp, initCompState = true) {\n this.comp = comp;\n if (initCompState) {\n this.onRowHeightChanged();\n this.onVirtualColumnsChanged();\n }\n // width is managed directly regardless of framework and so is not included in initCompState\n this.setWidth();\n this.addEventListeners();\n }\n getHeaderRowClass() {\n return this.headerRowClass;\n }\n getAriaRowIndex() {\n return this.rowIndex + 1;\n }\n getTransform() {\n if (isBrowserSafari()) {\n // fix for a Safari rendering bug that caused the header to flicker above chart panels\n // as you move the mouse over the header\n return 'translateZ(0)';\n }\n }\n addEventListeners() {\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_RESIZED, this.onColumnResized.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_VIRTUAL_COLUMNS_CHANGED, (params) => this.onVirtualColumnsChanged(params.afterScroll));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_HEADER_HEIGHT_CHANGED, this.onRowHeightChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_GRID_STYLES_CHANGED, this.onRowHeightChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_ADVANCED_FILTER_ENABLED_CHANGED, this.onRowHeightChanged.bind(this));\n // when print layout changes, it changes what columns are in what section\n this.addManagedPropertyListener('domLayout', this.onDisplayedColumnsChanged.bind(this));\n this.addManagedPropertyListener('ensureDomOrder', (e) => this.isEnsureDomOrder = e.currentValue);\n this.addManagedPropertyListener('headerHeight', this.onRowHeightChanged.bind(this));\n this.addManagedPropertyListener('pivotHeaderHeight', this.onRowHeightChanged.bind(this));\n this.addManagedPropertyListener('groupHeaderHeight', this.onRowHeightChanged.bind(this));\n this.addManagedPropertyListener('pivotGroupHeaderHeight', this.onRowHeightChanged.bind(this));\n this.addManagedPropertyListener('floatingFiltersHeight', this.onRowHeightChanged.bind(this));\n }\n getHeaderCellCtrl(column) {\n return values(this.headerCellCtrls).find(cellCtrl => cellCtrl.getColumnGroupChild() === column);\n }\n onDisplayedColumnsChanged() {\n this.isPrintLayout = this.gridOptionsService.isDomLayout('print');\n this.onVirtualColumnsChanged();\n this.setWidth();\n this.onRowHeightChanged();\n }\n getType() {\n return this.type;\n }\n onColumnResized() {\n this.setWidth();\n }\n setWidth() {\n const width = this.getWidthForRow();\n this.comp.setWidth(`${width}px`);\n }\n getWidthForRow() {\n if (this.isPrintLayout) {\n const pinned = this.pinned != null;\n if (pinned) {\n return 0;\n }\n return this.columnModel.getContainerWidth('right')\n + this.columnModel.getContainerWidth('left')\n + this.columnModel.getContainerWidth(null);\n }\n // if not printing, just return the width as normal\n return this.columnModel.getContainerWidth(this.pinned);\n }\n onRowHeightChanged() {\n var { topOffset, rowHeight } = this.getTopAndHeight();\n this.comp.setTop(topOffset + 'px');\n this.comp.setHeight(rowHeight + 'px');\n }\n getTopAndHeight() {\n let headerRowCount = this.columnModel.getHeaderRowCount();\n const sizes = [];\n let numberOfFloating = 0;\n if (this.filterManager.hasFloatingFilters()) {\n headerRowCount++;\n numberOfFloating = 1;\n }\n const groupHeight = this.columnModel.getColumnGroupHeaderRowHeight();\n const headerHeight = this.columnModel.getColumnHeaderRowHeight();\n const numberOfNonGroups = 1 + numberOfFloating;\n const numberOfGroups = headerRowCount - numberOfNonGroups;\n for (let i = 0; i < numberOfGroups; i++) {\n sizes.push(groupHeight);\n }\n sizes.push(headerHeight);\n for (let i = 0; i < numberOfFloating; i++) {\n sizes.push(this.columnModel.getFloatingFiltersHeight());\n }\n let topOffset = 0;\n for (let i = 0; i < this.rowIndex; i++) {\n topOffset += sizes[i];\n }\n const rowHeight = sizes[this.rowIndex];\n return { topOffset, rowHeight };\n }\n getPinned() {\n return this.pinned;\n }\n getRowIndex() {\n return this.rowIndex;\n }\n onVirtualColumnsChanged(afterScroll = false) {\n const ctrlsToDisplay = this.getHeaderCtrls();\n const forceOrder = this.isEnsureDomOrder || this.isPrintLayout;\n this.comp.setHeaderCtrls(ctrlsToDisplay, forceOrder, afterScroll);\n }\n getHeaderCtrls() {\n const oldCtrls = this.headerCellCtrls;\n this.headerCellCtrls = {};\n const columns = this.getColumnsInViewport();\n columns.forEach(child => {\n // skip groups that have no displayed children. this can happen when the group is broken,\n // and this section happens to have nothing to display for the open / closed state.\n // (a broken group is one that is split, ie columns in the group have a non-group column\n // in between them)\n if (child.isEmptyGroup()) {\n return;\n }\n const idOfChild = child.getUniqueId();\n // if we already have this cell rendered, do nothing\n let headerCtrl = oldCtrls[idOfChild];\n delete oldCtrls[idOfChild];\n // it's possible there is a new Column with the same ID, but it's for a different Column.\n // this is common with pivoting, where the pivot cols change, but the id's are still pivot_0,\n // pivot_1 etc. so if new col but same ID, need to remove the old col here first as we are\n // about to replace it in the this.headerComps map.\n const forOldColumn = headerCtrl && headerCtrl.getColumnGroupChild() != child;\n if (forOldColumn) {\n this.destroyBean(headerCtrl);\n headerCtrl = undefined;\n }\n if (headerCtrl == null) {\n switch (this.type) {\n case HeaderRowType.FLOATING_FILTER:\n headerCtrl = this.createBean(new HeaderFilterCellCtrl(child, this));\n break;\n case HeaderRowType.COLUMN_GROUP:\n headerCtrl = this.createBean(new HeaderGroupCellCtrl(child, this));\n break;\n default:\n headerCtrl = this.createBean(new HeaderCellCtrl(child, this));\n break;\n }\n }\n this.headerCellCtrls[idOfChild] = headerCtrl;\n });\n // we want to keep columns that are focused, otherwise keyboard navigation breaks\n const isFocusedAndDisplayed = (ctrl) => {\n const isFocused = this.focusService.isHeaderWrapperFocused(ctrl);\n if (!isFocused) {\n return false;\n }\n const isDisplayed = this.columnModel.isDisplayed(ctrl.getColumnGroupChild());\n return isDisplayed;\n };\n iterateObject(oldCtrls, (id, oldCtrl) => {\n const keepCtrl = isFocusedAndDisplayed(oldCtrl);\n if (keepCtrl) {\n this.headerCellCtrls[id] = oldCtrl;\n }\n else {\n this.destroyBean(oldCtrl);\n }\n });\n const ctrlsToDisplay = getAllValuesInObject(this.headerCellCtrls);\n return ctrlsToDisplay;\n }\n getColumnsInViewport() {\n return this.isPrintLayout ? this.getColumnsInViewportPrintLayout() : this.getColumnsInViewportNormalLayout();\n }\n getColumnsInViewportPrintLayout() {\n // for print layout, we add all columns into the center\n if (this.pinned != null) {\n return [];\n }\n let viewportColumns = [];\n const actualDepth = this.getActualDepth();\n ['left', null, 'right'].forEach(pinned => {\n const items = this.columnModel.getVirtualHeaderGroupRow(pinned, actualDepth);\n viewportColumns = viewportColumns.concat(items);\n });\n return viewportColumns;\n }\n getActualDepth() {\n return this.type == HeaderRowType.FLOATING_FILTER ? this.rowIndex - 1 : this.rowIndex;\n }\n getColumnsInViewportNormalLayout() {\n // when in normal layout, we add the columns for that container only\n return this.columnModel.getVirtualHeaderGroupRow(this.pinned, this.getActualDepth());\n }\n focusHeader(column, event) {\n const allCtrls = getAllValuesInObject(this.headerCellCtrls);\n const ctrl = allCtrls.find(ctrl => ctrl.getColumnGroupChild() == column);\n if (!ctrl) {\n return false;\n }\n ctrl.focus(event);\n return true;\n }\n destroy() {\n iterateObject(this.headerCellCtrls, (key, ctrl) => {\n this.destroyBean(ctrl);\n });\n this.headerCellCtrls = {};\n super.destroy();\n }\n}\n__decorate([\n Autowired('columnModel')\n], HeaderRowCtrl.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('focusService')\n], HeaderRowCtrl.prototype, \"focusService\", void 0);\n__decorate([\n Autowired('filterManager')\n], HeaderRowCtrl.prototype, \"filterManager\", void 0);\n__decorate([\n PostConstruct\n], HeaderRowCtrl.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nimport { Autowired } from \"../../context/context.mjs\";\nimport { Column } from \"../../entities/column.mjs\";\nimport { Events } from \"../../eventKeys.mjs\";\nimport { CenterWidthFeature } from \"../../gridBodyComp/centerWidthFeature.mjs\";\nimport { NumberSequence } from \"../../utils/index.mjs\";\nimport { BodyDropTarget } from \"../columnDrag/bodyDropTarget.mjs\";\nimport { HeaderRowType } from \"../row/headerRowComp.mjs\";\nimport { HeaderRowCtrl } from \"../row/headerRowCtrl.mjs\";\nexport class HeaderRowContainerCtrl extends BeanStub {\n constructor(pinned) {\n super();\n this.hidden = false;\n this.includeFloatingFilter = false;\n this.groupsRowCtrls = [];\n this.pinned = pinned;\n }\n setComp(comp, eGui) {\n this.comp = comp;\n this.eViewport = eGui;\n this.setupCenterWidth();\n this.setupPinnedWidth();\n this.setupDragAndDrop(this.eViewport);\n this.addManagedListener(this.eventService, Events.EVENT_GRID_COLUMNS_CHANGED, this.onGridColumnsChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_ADVANCED_FILTER_ENABLED_CHANGED, this.onDisplayedColumnsChanged.bind(this));\n this.ctrlsService.registerHeaderContainer(this, this.pinned);\n if (this.columnModel.isReady()) {\n this.refresh();\n }\n }\n setupDragAndDrop(dropContainer) {\n const bodyDropTarget = new BodyDropTarget(this.pinned, dropContainer);\n this.createManagedBean(bodyDropTarget);\n }\n refresh(keepColumns = false) {\n const sequence = new NumberSequence();\n const focusedHeaderPosition = this.focusService.getFocusHeaderToUseAfterRefresh();\n const refreshColumnGroups = () => {\n const groupRowCount = this.columnModel.getHeaderRowCount() - 1;\n this.groupsRowCtrls = this.destroyBeans(this.groupsRowCtrls);\n for (let i = 0; i < groupRowCount; i++) {\n const ctrl = this.createBean(new HeaderRowCtrl(sequence.next(), this.pinned, HeaderRowType.COLUMN_GROUP));\n this.groupsRowCtrls.push(ctrl);\n }\n };\n const refreshColumns = () => {\n const rowIndex = sequence.next();\n const needNewInstance = !this.hidden && (this.columnsRowCtrl == null || !keepColumns || this.columnsRowCtrl.getRowIndex() !== rowIndex);\n const shouldDestroyInstance = needNewInstance || this.hidden;\n if (shouldDestroyInstance) {\n this.columnsRowCtrl = this.destroyBean(this.columnsRowCtrl);\n }\n if (needNewInstance) {\n this.columnsRowCtrl = this.createBean(new HeaderRowCtrl(rowIndex, this.pinned, HeaderRowType.COLUMN));\n }\n };\n const refreshFilters = () => {\n this.includeFloatingFilter = this.filterManager.hasFloatingFilters() && !this.hidden;\n const destroyPreviousComp = () => {\n this.filtersRowCtrl = this.destroyBean(this.filtersRowCtrl);\n };\n if (!this.includeFloatingFilter) {\n destroyPreviousComp();\n return;\n }\n const rowIndex = sequence.next();\n if (this.filtersRowCtrl) {\n const rowIndexMismatch = this.filtersRowCtrl.getRowIndex() !== rowIndex;\n if (!keepColumns || rowIndexMismatch) {\n destroyPreviousComp();\n }\n }\n if (!this.filtersRowCtrl) {\n this.filtersRowCtrl = this.createBean(new HeaderRowCtrl(rowIndex, this.pinned, HeaderRowType.FLOATING_FILTER));\n }\n };\n refreshColumnGroups();\n refreshColumns();\n refreshFilters();\n const allCtrls = this.getAllCtrls();\n this.comp.setCtrls(allCtrls);\n this.restoreFocusOnHeader(focusedHeaderPosition);\n }\n restoreFocusOnHeader(position) {\n if (position == null || position.column.getPinned() != this.pinned) {\n return;\n }\n this.focusService.focusHeaderPosition({ headerPosition: position });\n }\n getAllCtrls() {\n const res = [...this.groupsRowCtrls];\n if (this.columnsRowCtrl) {\n res.push(this.columnsRowCtrl);\n }\n if (this.filtersRowCtrl) {\n res.push(this.filtersRowCtrl);\n }\n return res;\n }\n // grid cols have changed - this also means the number of rows in the header can have\n // changed. so we remove all the old rows and insert new ones for a complete refresh\n onGridColumnsChanged() {\n this.refresh(true);\n }\n onDisplayedColumnsChanged() {\n const includeFloatingFilter = this.filterManager.hasFloatingFilters() && !this.hidden;\n if (this.includeFloatingFilter !== includeFloatingFilter) {\n this.refresh(true);\n }\n }\n setupCenterWidth() {\n if (this.pinned != null) {\n return;\n }\n this.createManagedBean(new CenterWidthFeature(width => this.comp.setCenterWidth(`${width}px`), true));\n }\n setHorizontalScroll(offset) {\n this.comp.setViewportScrollLeft(offset);\n }\n setupPinnedWidth() {\n if (this.pinned == null) {\n return;\n }\n const pinningLeft = this.pinned === 'left';\n const pinningRight = this.pinned === 'right';\n this.hidden = true;\n const listener = () => {\n const width = pinningLeft ? this.pinnedWidthService.getPinnedLeftWidth() : this.pinnedWidthService.getPinnedRightWidth();\n if (width == null) {\n return;\n } // can happen at initialisation, width not yet set\n const hidden = (width == 0);\n const hiddenChanged = this.hidden !== hidden;\n const isRtl = this.gridOptionsService.is('enableRtl');\n const scrollbarWidth = this.gridOptionsService.getScrollbarWidth();\n // if there is a scroll showing (and taking up space, so Windows, and not iOS)\n // in the body, then we add extra space to keep header aligned with the body,\n // as body width fits the cols and the scrollbar\n const addPaddingForScrollbar = this.scrollVisibleService.isVerticalScrollShowing() && ((isRtl && pinningLeft) || (!isRtl && pinningRight));\n const widthWithPadding = addPaddingForScrollbar ? width + scrollbarWidth : width;\n this.comp.setPinnedContainerWidth(`${widthWithPadding}px`);\n this.comp.setDisplayed(!hidden);\n if (hiddenChanged) {\n this.hidden = hidden;\n this.refresh();\n }\n };\n this.addManagedListener(this.eventService, Events.EVENT_LEFT_PINNED_WIDTH_CHANGED, listener);\n this.addManagedListener(this.eventService, Events.EVENT_RIGHT_PINNED_WIDTH_CHANGED, listener);\n this.addManagedListener(this.eventService, Events.EVENT_SCROLL_VISIBILITY_CHANGED, listener);\n this.addManagedListener(this.eventService, Events.EVENT_SCROLLBAR_WIDTH_CHANGED, listener);\n }\n getHeaderCtrlForColumn(column) {\n if (column instanceof Column) {\n if (!this.columnsRowCtrl) {\n return;\n }\n return this.columnsRowCtrl.getHeaderCellCtrl(column);\n }\n if (this.groupsRowCtrls.length === 0) {\n return;\n }\n for (let i = 0; i < this.groupsRowCtrls.length; i++) {\n const ctrl = this.groupsRowCtrls[i].getHeaderCellCtrl(column);\n if (ctrl) {\n return ctrl;\n }\n }\n }\n getHtmlElementForColumnHeader(column) {\n /* tslint:enable */\n const cellCtrl = this.getHeaderCtrlForColumn(column);\n if (!cellCtrl) {\n return null;\n }\n return cellCtrl.getGui();\n }\n getRowType(rowIndex) {\n const allCtrls = this.getAllCtrls();\n const ctrl = allCtrls[rowIndex];\n return ctrl ? ctrl.getType() : undefined;\n }\n focusHeader(rowIndex, column, event) {\n const allCtrls = this.getAllCtrls();\n const ctrl = allCtrls[rowIndex];\n if (!ctrl) {\n return false;\n }\n return ctrl.focusHeader(column, event);\n }\n getRowCount() {\n return this.groupsRowCtrls.length + (this.columnsRowCtrl ? 1 : 0) + (this.filtersRowCtrl ? 1 : 0);\n }\n destroy() {\n if (this.filtersRowCtrl) {\n this.filtersRowCtrl = this.destroyBean(this.filtersRowCtrl);\n }\n if (this.columnsRowCtrl) {\n this.columnsRowCtrl = this.destroyBean(this.columnsRowCtrl);\n }\n if (this.groupsRowCtrls && this.groupsRowCtrls.length) {\n this.groupsRowCtrls = this.destroyBeans(this.groupsRowCtrls);\n }\n super.destroy();\n }\n}\n__decorate([\n Autowired('ctrlsService')\n], HeaderRowContainerCtrl.prototype, \"ctrlsService\", void 0);\n__decorate([\n Autowired('scrollVisibleService')\n], HeaderRowContainerCtrl.prototype, \"scrollVisibleService\", void 0);\n__decorate([\n Autowired('pinnedWidthService')\n], HeaderRowContainerCtrl.prototype, \"pinnedWidthService\", void 0);\n__decorate([\n Autowired('columnModel')\n], HeaderRowContainerCtrl.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('focusService')\n], HeaderRowContainerCtrl.prototype, \"focusService\", void 0);\n__decorate([\n Autowired('filterManager')\n], HeaderRowContainerCtrl.prototype, \"filterManager\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PostConstruct, PreDestroy } from '../../context/context.mjs';\nimport { ensureDomOrder } from '../../utils/dom.mjs';\nimport { getAllValuesInObject } from '../../utils/object.mjs';\nimport { Component } from '../../widgets/component.mjs';\nimport { RefSelector } from '../../widgets/componentAnnotations.mjs';\nimport { HeaderRowComp } from '../row/headerRowComp.mjs';\nimport { HeaderRowContainerCtrl } from './headerRowContainerCtrl.mjs';\nexport class HeaderRowContainerComp extends Component {\n constructor(pinned) {\n super();\n this.headerRowComps = {};\n this.rowCompsList = [];\n this.pinned = pinned;\n }\n init() {\n this.selectAndSetTemplate();\n const compProxy = {\n setDisplayed: displayed => this.setDisplayed(displayed),\n setCtrls: ctrls => this.setCtrls(ctrls),\n // only gets called for center section\n setCenterWidth: width => this.eCenterContainer.style.width = width,\n setViewportScrollLeft: left => this.getGui().scrollLeft = left,\n // only gets called for pinned sections\n setPinnedContainerWidth: width => {\n const eGui = this.getGui();\n eGui.style.width = width;\n eGui.style.maxWidth = width;\n eGui.style.minWidth = width;\n }\n };\n const ctrl = this.createManagedBean(new HeaderRowContainerCtrl(this.pinned));\n ctrl.setComp(compProxy, this.getGui());\n }\n selectAndSetTemplate() {\n const pinnedLeft = this.pinned == 'left';\n const pinnedRight = this.pinned == 'right';\n const template = pinnedLeft ? HeaderRowContainerComp.PINNED_LEFT_TEMPLATE :\n pinnedRight ? HeaderRowContainerComp.PINNED_RIGHT_TEMPLATE : HeaderRowContainerComp.CENTER_TEMPLATE;\n this.setTemplate(template);\n // for left and right, we add rows directly to the root element,\n // but for center container we add elements to the child container.\n this.eRowContainer = this.eCenterContainer ? this.eCenterContainer : this.getGui();\n }\n destroyRowComps() {\n this.setCtrls([]);\n }\n destroyRowComp(rowComp) {\n this.destroyBean(rowComp);\n this.eRowContainer.removeChild(rowComp.getGui());\n }\n setCtrls(ctrls) {\n const oldRowComps = this.headerRowComps;\n this.headerRowComps = {};\n this.rowCompsList = [];\n let prevGui;\n const appendEnsuringDomOrder = (rowComp) => {\n const eGui = rowComp.getGui();\n const notAlreadyIn = eGui.parentElement != this.eRowContainer;\n if (notAlreadyIn) {\n this.eRowContainer.appendChild(eGui);\n }\n if (prevGui) {\n ensureDomOrder(this.eRowContainer, eGui, prevGui);\n }\n prevGui = eGui;\n };\n ctrls.forEach(ctrl => {\n const ctrlId = ctrl.getInstanceId();\n const existingComp = oldRowComps[ctrlId];\n delete oldRowComps[ctrlId];\n const rowComp = existingComp ? existingComp : this.createBean(new HeaderRowComp(ctrl));\n this.headerRowComps[ctrlId] = rowComp;\n this.rowCompsList.push(rowComp);\n appendEnsuringDomOrder(rowComp);\n });\n getAllValuesInObject(oldRowComps).forEach(c => this.destroyRowComp(c));\n }\n}\nHeaderRowContainerComp.PINNED_LEFT_TEMPLATE = `
`;\nHeaderRowContainerComp.PINNED_RIGHT_TEMPLATE = `
`;\nHeaderRowContainerComp.CENTER_TEMPLATE = `
\n
\n
`;\n__decorate([\n RefSelector('eCenterContainer')\n], HeaderRowContainerComp.prototype, \"eCenterContainer\", void 0);\n__decorate([\n PostConstruct\n], HeaderRowContainerComp.prototype, \"init\", null);\n__decorate([\n PreDestroy\n], HeaderRowContainerComp.prototype, \"destroyRowComps\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nimport { Autowired, Bean, PostConstruct } from \"../../context/context.mjs\";\nimport { ColumnGroup } from \"../../entities/columnGroup.mjs\";\nimport { last } from \"../../utils/array.mjs\";\nexport var HeaderNavigationDirection;\n(function (HeaderNavigationDirection) {\n HeaderNavigationDirection[HeaderNavigationDirection[\"UP\"] = 0] = \"UP\";\n HeaderNavigationDirection[HeaderNavigationDirection[\"DOWN\"] = 1] = \"DOWN\";\n HeaderNavigationDirection[HeaderNavigationDirection[\"LEFT\"] = 2] = \"LEFT\";\n HeaderNavigationDirection[HeaderNavigationDirection[\"RIGHT\"] = 3] = \"RIGHT\";\n})(HeaderNavigationDirection || (HeaderNavigationDirection = {}));\nlet HeaderNavigationService = class HeaderNavigationService extends BeanStub {\n postConstruct() {\n this.ctrlsService.whenReady(p => {\n this.gridBodyCon = p.gridBodyCtrl;\n });\n }\n getHeaderRowCount() {\n const centerHeaderContainer = this.ctrlsService.getHeaderRowContainerCtrl();\n return centerHeaderContainer ? centerHeaderContainer.getRowCount() : 0;\n }\n /*\n * This method navigates grid header vertically\n * @return {boolean} true to preventDefault on the event that caused this navigation.\n */\n navigateVertically(direction, fromHeader, event) {\n if (!fromHeader) {\n fromHeader = this.focusService.getFocusedHeader();\n }\n if (!fromHeader) {\n return false;\n }\n const { headerRowIndex, column } = fromHeader;\n const rowLen = this.getHeaderRowCount();\n const isUp = direction === HeaderNavigationDirection.UP;\n let { nextRow, nextFocusColumn } = isUp\n ? this.headerPositionUtils.getColumnVisibleParent(column, headerRowIndex)\n : this.headerPositionUtils.getColumnVisibleChild(column, headerRowIndex);\n let skipColumn = false;\n if (nextRow < 0) {\n nextRow = 0;\n nextFocusColumn = column;\n skipColumn = true;\n }\n if (nextRow >= rowLen) {\n nextRow = -1; // -1 indicates the focus should move to grid rows.\n }\n if (!skipColumn && !nextFocusColumn) {\n return false;\n }\n return this.focusService.focusHeaderPosition({\n headerPosition: { headerRowIndex: nextRow, column: nextFocusColumn },\n allowUserOverride: true,\n event\n });\n }\n /*\n * This method navigates grid header horizontally\n * @return {boolean} true to preventDefault on the event that caused this navigation.\n */\n navigateHorizontally(direction, fromTab = false, event) {\n const focusedHeader = this.focusService.getFocusedHeader();\n const isLeft = direction === HeaderNavigationDirection.LEFT;\n const isRtl = this.gridOptionsService.is('enableRtl');\n let nextHeader;\n let normalisedDirection;\n // either navigating to the left or isRtl (cannot be both)\n if (isLeft !== isRtl) {\n normalisedDirection = 'Before';\n nextHeader = this.headerPositionUtils.findHeader(focusedHeader, normalisedDirection);\n }\n else {\n normalisedDirection = 'After';\n nextHeader = this.headerPositionUtils.findHeader(focusedHeader, normalisedDirection);\n }\n if (nextHeader || !fromTab) {\n return this.focusService.focusHeaderPosition({\n headerPosition: nextHeader,\n direction: normalisedDirection,\n fromTab,\n allowUserOverride: true,\n event\n });\n }\n return this.focusNextHeaderRow(focusedHeader, normalisedDirection, event);\n }\n focusNextHeaderRow(focusedHeader, direction, event) {\n const currentIndex = focusedHeader.headerRowIndex;\n let nextPosition = null;\n let nextRowIndex;\n if (direction === 'Before') {\n if (currentIndex > 0) {\n nextRowIndex = currentIndex - 1;\n nextPosition = this.headerPositionUtils.findColAtEdgeForHeaderRow(nextRowIndex, 'end');\n }\n }\n else {\n nextRowIndex = currentIndex + 1;\n nextPosition = this.headerPositionUtils.findColAtEdgeForHeaderRow(nextRowIndex, 'start');\n }\n return this.focusService.focusHeaderPosition({\n headerPosition: nextPosition,\n direction,\n fromTab: true,\n allowUserOverride: true,\n event\n });\n }\n scrollToColumn(column, direction = 'After') {\n if (column.getPinned()) {\n return;\n }\n let columnToScrollTo;\n if (column instanceof ColumnGroup) {\n const columns = column.getDisplayedLeafColumns();\n columnToScrollTo = direction === 'Before' ? last(columns) : columns[0];\n }\n else {\n columnToScrollTo = column;\n }\n this.gridBodyCon.getScrollFeature().ensureColumnVisible(columnToScrollTo);\n }\n};\n__decorate([\n Autowired('focusService')\n], HeaderNavigationService.prototype, \"focusService\", void 0);\n__decorate([\n Autowired('headerPositionUtils')\n], HeaderNavigationService.prototype, \"headerPositionUtils\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], HeaderNavigationService.prototype, \"ctrlsService\", void 0);\n__decorate([\n PostConstruct\n], HeaderNavigationService.prototype, \"postConstruct\", null);\nHeaderNavigationService = __decorate([\n Bean('headerNavigationService')\n], HeaderNavigationService);\nexport { HeaderNavigationService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { KeyCode } from \"../constants/keyCode.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { Autowired } from \"../context/context.mjs\";\nimport { Events } from \"../eventKeys.mjs\";\nimport { exists } from \"../utils/generic.mjs\";\nimport { ManagedFocusFeature } from \"../widgets/managedFocusFeature.mjs\";\nimport { HeaderNavigationDirection } from \"./common/headerNavigationService.mjs\";\nexport class GridHeaderCtrl extends BeanStub {\n setComp(comp, eGui, eFocusableElement) {\n this.comp = comp;\n this.eGui = eGui;\n this.createManagedBean(new ManagedFocusFeature(eFocusableElement, {\n onTabKeyDown: this.onTabKeyDown.bind(this),\n handleKeyDown: this.handleKeyDown.bind(this),\n onFocusOut: this.onFocusOut.bind(this)\n }));\n // for setting ag-pivot-on / ag-pivot-off CSS classes\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PIVOT_MODE_CHANGED, this.onPivotModeChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this));\n this.onPivotModeChanged();\n this.setupHeaderHeight();\n this.ctrlsService.registerGridHeaderCtrl(this);\n }\n setupHeaderHeight() {\n const listener = this.setHeaderHeight.bind(this);\n listener();\n this.addManagedPropertyListener('headerHeight', listener);\n this.addManagedPropertyListener('pivotHeaderHeight', listener);\n this.addManagedPropertyListener('groupHeaderHeight', listener);\n this.addManagedPropertyListener('pivotGroupHeaderHeight', listener);\n this.addManagedPropertyListener('floatingFiltersHeight', listener);\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, listener);\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_HEADER_HEIGHT_CHANGED, listener);\n this.addManagedListener(this.eventService, Events.EVENT_GRID_STYLES_CHANGED, listener);\n this.addManagedListener(this.eventService, Events.EVENT_ADVANCED_FILTER_ENABLED_CHANGED, listener);\n }\n getHeaderHeight() {\n return this.headerHeight;\n }\n setHeaderHeight() {\n const { columnModel } = this;\n let numberOfFloating = 0;\n let headerRowCount = columnModel.getHeaderRowCount();\n let totalHeaderHeight;\n const hasFloatingFilters = this.filterManager.hasFloatingFilters();\n if (hasFloatingFilters) {\n headerRowCount++;\n numberOfFloating = 1;\n }\n const groupHeight = this.columnModel.getColumnGroupHeaderRowHeight();\n const headerHeight = this.columnModel.getColumnHeaderRowHeight();\n const numberOfNonGroups = 1 + numberOfFloating;\n const numberOfGroups = headerRowCount - numberOfNonGroups;\n totalHeaderHeight = numberOfFloating * columnModel.getFloatingFiltersHeight();\n totalHeaderHeight += numberOfGroups * groupHeight;\n totalHeaderHeight += headerHeight;\n if (this.headerHeight === totalHeaderHeight) {\n return;\n }\n this.headerHeight = totalHeaderHeight;\n // one extra pixel is needed here to account for the\n // height of the border\n const px = `${totalHeaderHeight + 1}px`;\n this.comp.setHeightAndMinHeight(px);\n this.eventService.dispatchEvent({\n type: Events.EVENT_HEADER_HEIGHT_CHANGED\n });\n }\n onPivotModeChanged() {\n const pivotMode = this.columnModel.isPivotMode();\n this.comp.addOrRemoveCssClass('ag-pivot-on', pivotMode);\n this.comp.addOrRemoveCssClass('ag-pivot-off', !pivotMode);\n }\n onDisplayedColumnsChanged() {\n const columns = this.columnModel.getAllDisplayedColumns();\n const shouldAllowOverflow = columns.some(col => col.isSpanHeaderHeight());\n this.comp.addOrRemoveCssClass('ag-header-allow-overflow', shouldAllowOverflow);\n }\n onTabKeyDown(e) {\n const isRtl = this.gridOptionsService.is('enableRtl');\n const direction = e.shiftKey !== isRtl\n ? HeaderNavigationDirection.LEFT\n : HeaderNavigationDirection.RIGHT;\n if (this.headerNavigationService.navigateHorizontally(direction, true, e) ||\n this.focusService.focusNextGridCoreContainer(e.shiftKey)) {\n e.preventDefault();\n }\n }\n handleKeyDown(e) {\n let direction = null;\n switch (e.key) {\n case KeyCode.LEFT:\n direction = HeaderNavigationDirection.LEFT;\n case KeyCode.RIGHT:\n if (!exists(direction)) {\n direction = HeaderNavigationDirection.RIGHT;\n }\n this.headerNavigationService.navigateHorizontally(direction, false, e);\n break;\n case KeyCode.UP:\n direction = HeaderNavigationDirection.UP;\n case KeyCode.DOWN:\n if (!exists(direction)) {\n direction = HeaderNavigationDirection.DOWN;\n }\n if (this.headerNavigationService.navigateVertically(direction, null, e)) {\n e.preventDefault();\n }\n break;\n default:\n return;\n }\n }\n onFocusOut(e) {\n const eDocument = this.gridOptionsService.getDocument();\n const { relatedTarget } = e;\n if (!relatedTarget && this.eGui.contains(eDocument.activeElement)) {\n return;\n }\n if (!this.eGui.contains(relatedTarget)) {\n this.focusService.clearFocusedHeader();\n }\n }\n}\n__decorate([\n Autowired('headerNavigationService')\n], GridHeaderCtrl.prototype, \"headerNavigationService\", void 0);\n__decorate([\n Autowired('focusService')\n], GridHeaderCtrl.prototype, \"focusService\", void 0);\n__decorate([\n Autowired('columnModel')\n], GridHeaderCtrl.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], GridHeaderCtrl.prototype, \"ctrlsService\", void 0);\n__decorate([\n Autowired('filterManager')\n], GridHeaderCtrl.prototype, \"filterManager\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PostConstruct } from '../context/context.mjs';\nimport { Component } from '../widgets/component.mjs';\nimport { GridHeaderCtrl } from './gridHeaderCtrl.mjs';\nimport { HeaderRowContainerComp } from './rowContainer/headerRowContainerComp.mjs';\nexport class GridHeaderComp extends Component {\n constructor() {\n super(GridHeaderComp.TEMPLATE);\n }\n postConstruct() {\n const compProxy = {\n addOrRemoveCssClass: (cssClassName, on) => this.addOrRemoveCssClass(cssClassName, on),\n setHeightAndMinHeight: height => {\n this.getGui().style.height = height;\n this.getGui().style.minHeight = height;\n }\n };\n const ctrl = this.createManagedBean(new GridHeaderCtrl());\n ctrl.setComp(compProxy, this.getGui(), this.getFocusableElement());\n const addContainer = (container) => {\n this.createManagedBean(container);\n this.appendChild(container);\n };\n addContainer(new HeaderRowContainerComp('left'));\n addContainer(new HeaderRowContainerComp(null));\n addContainer(new HeaderRowContainerComp('right'));\n }\n}\nGridHeaderComp.TEMPLATE = `
`;\n__decorate([\n PostConstruct\n], GridHeaderComp.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean } from \"../../context/context.mjs\";\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nlet HorizontalResizeService = class HorizontalResizeService extends BeanStub {\n addResizeBar(params) {\n const dragSource = {\n dragStartPixels: params.dragStartPixels || 0,\n eElement: params.eResizeBar,\n onDragStart: this.onDragStart.bind(this, params),\n onDragStop: this.onDragStop.bind(this, params),\n onDragging: this.onDragging.bind(this, params),\n includeTouch: true,\n stopPropagationForTouch: true\n };\n this.dragService.addDragSource(dragSource);\n // we pass remove func back to the caller, so call can tell us when they\n // are finished, and then we remove the listener from the drag source\n const finishedWithResizeFunc = () => this.dragService.removeDragSource(dragSource);\n return finishedWithResizeFunc;\n }\n onDragStart(params, mouseEvent) {\n this.dragStartX = mouseEvent.clientX;\n this.setResizeIcons();\n const shiftKey = mouseEvent instanceof MouseEvent && mouseEvent.shiftKey === true;\n params.onResizeStart(shiftKey);\n }\n setResizeIcons() {\n const ctrl = this.ctrlsService.getGridCtrl();\n // change the body cursor, so when drag moves out of the drag bar, the cursor is still 'resize' (or 'move'\n ctrl.setResizeCursor(true);\n // we don't want text selection outside the grid (otherwise it looks weird as text highlights when we move)\n ctrl.disableUserSelect(true);\n }\n onDragStop(params, mouseEvent) {\n params.onResizeEnd(this.resizeAmount);\n this.resetIcons();\n }\n resetIcons() {\n const ctrl = this.ctrlsService.getGridCtrl();\n ctrl.setResizeCursor(false);\n ctrl.disableUserSelect(false);\n }\n onDragging(params, mouseEvent) {\n this.resizeAmount = mouseEvent.clientX - this.dragStartX;\n params.onResizing(this.resizeAmount);\n }\n};\n__decorate([\n Autowired('dragService')\n], HorizontalResizeService.prototype, \"dragService\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], HorizontalResizeService.prototype, \"ctrlsService\", void 0);\nHorizontalResizeService = __decorate([\n Bean('horizontalResizeService')\n], HorizontalResizeService);\nexport { HorizontalResizeService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean } from '../../../context/context.mjs';\nimport { BeanStub } from \"../../../context/beanStub.mjs\";\nimport { isVisible } from '../../../utils/dom.mjs';\nimport { KeyCode } from '../../../constants/keyCode.mjs';\nimport { setAriaRole } from '../../../utils/aria.mjs';\nlet StandardMenuFactory = class StandardMenuFactory extends BeanStub {\n hideActiveMenu() {\n if (this.hidePopup) {\n this.hidePopup();\n }\n }\n showMenuAfterMouseEvent(column, mouseEvent) {\n this.showPopup(column, eMenu => {\n this.popupService.positionPopupUnderMouseEvent({\n column,\n type: 'columnMenu',\n mouseEvent,\n ePopup: eMenu\n });\n }, 'columnMenu', mouseEvent.target);\n }\n showMenuAfterButtonClick(column, eventSource, containerType) {\n this.showPopup(column, eMenu => {\n this.popupService.positionPopupByComponent({\n type: containerType,\n eventSource,\n ePopup: eMenu,\n keepWithinBounds: true,\n position: 'under',\n column,\n });\n }, containerType, eventSource);\n }\n showPopup(column, positionCallback, containerType, eventSource) {\n const filterWrapper = this.filterManager.getOrCreateFilterWrapper(column, 'COLUMN_MENU');\n if (!filterWrapper) {\n throw new Error('AG Grid - unable to show popup filter, filter instantiation failed');\n }\n const eMenu = document.createElement('div');\n setAriaRole(eMenu, 'presentation');\n eMenu.classList.add('ag-menu');\n this.tabListener = this.addManagedListener(eMenu, 'keydown', (e) => this.trapFocusWithin(e, eMenu));\n filterWrapper.guiPromise.then(gui => eMenu.appendChild(gui));\n let hidePopup;\n const afterGuiDetached = () => { var _a; return (_a = filterWrapper.filterPromise) === null || _a === void 0 ? void 0 : _a.then(filter => { var _a; return (_a = filter === null || filter === void 0 ? void 0 : filter.afterGuiDetached) === null || _a === void 0 ? void 0 : _a.call(filter); }); };\n const anchorToElement = eventSource || this.ctrlsService.getGridBodyCtrl().getGui();\n const closedCallback = (e) => {\n column.setMenuVisible(false, 'contextMenu');\n const isKeyboardEvent = e instanceof KeyboardEvent;\n if (this.tabListener) {\n this.tabListener = this.tabListener();\n }\n if (isKeyboardEvent && eventSource && isVisible(eventSource)) {\n const focusableEl = this.focusService.findTabbableParent(eventSource);\n if (focusableEl) {\n focusableEl.focus();\n }\n }\n afterGuiDetached();\n };\n const translate = this.localeService.getLocaleTextFunc();\n const addPopupRes = this.popupService.addPopup({\n modal: true,\n eChild: eMenu,\n closeOnEsc: true,\n closedCallback,\n positionCallback: () => positionCallback(eMenu),\n anchorToElement,\n ariaLabel: translate('ariaLabelColumnMenu', 'Column Menu')\n });\n if (addPopupRes) {\n this.hidePopup = hidePopup = addPopupRes.hideFunc;\n }\n filterWrapper.filterPromise.then(filter => {\n // need to make sure the filter is present before positioning, as only\n // after filter it is visible can we find out what the width of it is\n positionCallback(eMenu);\n if (filter.afterGuiAttached) {\n filter.afterGuiAttached({ container: containerType, hidePopup });\n }\n });\n column.setMenuVisible(true, 'contextMenu');\n }\n trapFocusWithin(e, menu) {\n if (e.key !== KeyCode.TAB ||\n e.defaultPrevented ||\n this.focusService.findNextFocusableElement(menu, false, e.shiftKey)) {\n return;\n }\n e.preventDefault();\n this.focusService.focusInto(menu, e.shiftKey);\n }\n isMenuEnabled(column) {\n // for standard, we show menu if filter is enabled, and the menu is not suppressed by passing an empty array\n return column.isFilterAllowed() && column.getMenuTabs(['filterMenuTab']).includes('filterMenuTab');\n }\n};\n__decorate([\n Autowired('filterManager')\n], StandardMenuFactory.prototype, \"filterManager\", void 0);\n__decorate([\n Autowired('popupService')\n], StandardMenuFactory.prototype, \"popupService\", void 0);\n__decorate([\n Autowired('focusService')\n], StandardMenuFactory.prototype, \"focusService\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], StandardMenuFactory.prototype, \"ctrlsService\", void 0);\nStandardMenuFactory = __decorate([\n Bean('menuFactory')\n], StandardMenuFactory);\nexport { StandardMenuFactory };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { RefSelector } from '../widgets/componentAnnotations.mjs';\nimport { ManagedFocusFeature } from '../widgets/managedFocusFeature.mjs';\nimport { clearElement } from '../utils/dom.mjs';\nimport { setAriaLabel, setAriaRole } from '../utils/aria.mjs';\nimport { callIfPresent } from '../utils/function.mjs';\nimport { KeyCode } from '../constants/keyCode.mjs';\nimport { Component } from '../widgets/component.mjs';\nimport { PostConstruct, Autowired } from '../context/context.mjs';\nexport class TabbedLayout extends Component {\n constructor(params) {\n super(TabbedLayout.getTemplate(params.cssClass));\n this.items = [];\n this.tabbedItemScrollMap = new Map();\n this.params = params;\n if (params.items) {\n params.items.forEach(item => this.addItem(item));\n }\n }\n postConstruct() {\n this.createManagedBean(new ManagedFocusFeature(this.getFocusableElement(), {\n onTabKeyDown: this.onTabKeyDown.bind(this),\n handleKeyDown: this.handleKeyDown.bind(this)\n }));\n this.addDestroyFunc(() => { var _a, _b, _c; return (_c = (_b = (_a = this.activeItem) === null || _a === void 0 ? void 0 : _a.tabbedItem) === null || _b === void 0 ? void 0 : _b.afterDetachedCallback) === null || _c === void 0 ? void 0 : _c.call(_b); });\n }\n static getTemplate(cssClass) {\n return /* html */ `
\n
\n
\n
`;\n }\n handleKeyDown(e) {\n const eDocument = this.gridOptionsService.getDocument();\n switch (e.key) {\n case KeyCode.RIGHT:\n case KeyCode.LEFT:\n if (!this.eHeader.contains(eDocument.activeElement)) {\n return;\n }\n const isRightKey = e.key === KeyCode.RIGHT;\n const isRtl = this.gridOptionsService.is('enableRtl');\n const currentPosition = this.items.indexOf(this.activeItem);\n const nextPosition = isRightKey !== isRtl ? Math.min(currentPosition + 1, this.items.length - 1) : Math.max(currentPosition - 1, 0);\n if (currentPosition === nextPosition) {\n return;\n }\n e.preventDefault();\n const nextItem = this.items[nextPosition];\n this.showItemWrapper(nextItem);\n nextItem.eHeaderButton.focus();\n break;\n case KeyCode.UP:\n case KeyCode.DOWN:\n e.stopPropagation();\n break;\n }\n }\n onTabKeyDown(e) {\n if (e.defaultPrevented) {\n return;\n }\n const { focusService, eHeader, eBody, activeItem } = this;\n const eDocument = this.gridOptionsService.getDocument();\n const activeElement = eDocument.activeElement;\n const target = e.target;\n e.preventDefault();\n if (eHeader.contains(activeElement)) {\n // focus is in header, move into body of popup\n focusService.focusInto(eBody, e.shiftKey);\n return;\n }\n let nextEl = null;\n if (focusService.isTargetUnderManagedComponent(eBody, target)) {\n if (e.shiftKey) {\n nextEl = this.focusService.findFocusableElementBeforeTabGuard(eBody, target);\n }\n if (!nextEl) {\n nextEl = activeItem.eHeaderButton;\n }\n }\n if (!nextEl && eBody.contains(activeElement)) {\n nextEl = focusService.findNextFocusableElement(eBody, false, e.shiftKey);\n if (!nextEl) {\n nextEl = activeItem.eHeaderButton;\n }\n }\n if (nextEl) {\n nextEl.focus();\n }\n }\n setAfterAttachedParams(params) {\n this.afterAttachedParams = params;\n }\n showFirstItem() {\n if (this.items.length > 0) {\n this.showItemWrapper(this.items[0]);\n }\n }\n addItem(item) {\n const eHeaderButton = document.createElement('span');\n setAriaRole(eHeaderButton, 'tab');\n eHeaderButton.setAttribute('tabindex', '-1');\n eHeaderButton.appendChild(item.title);\n eHeaderButton.classList.add('ag-tab');\n this.eHeader.appendChild(eHeaderButton);\n setAriaLabel(eHeaderButton, item.titleLabel);\n const wrapper = {\n tabbedItem: item,\n eHeaderButton: eHeaderButton\n };\n this.items.push(wrapper);\n eHeaderButton.addEventListener('click', this.showItemWrapper.bind(this, wrapper));\n }\n showItem(tabbedItem) {\n const itemWrapper = this.items.find(wrapper => wrapper.tabbedItem === tabbedItem);\n if (itemWrapper) {\n this.showItemWrapper(itemWrapper);\n }\n }\n showItemWrapper(wrapper) {\n var _a, _b;\n const { tabbedItem, eHeaderButton } = wrapper;\n if (this.params.onItemClicked) {\n this.params.onItemClicked({ item: tabbedItem });\n }\n if (this.activeItem === wrapper) {\n callIfPresent(this.params.onActiveItemClicked);\n return;\n }\n if (this.lastScrollListener) {\n this.lastScrollListener = this.lastScrollListener();\n }\n clearElement(this.eBody);\n tabbedItem.bodyPromise.then((body) => {\n this.eBody.appendChild(body);\n const onlyUnmanaged = !this.focusService.isKeyboardMode();\n this.focusService.focusInto(this.eBody, false, onlyUnmanaged);\n if (tabbedItem.afterAttachedCallback) {\n tabbedItem.afterAttachedCallback(this.afterAttachedParams);\n }\n if (this.params.keepScrollPosition) {\n const scrollableContainer = (tabbedItem.getScrollableContainer && tabbedItem.getScrollableContainer()) || body;\n this.lastScrollListener = this.addManagedListener(scrollableContainer, 'scroll', () => {\n this.tabbedItemScrollMap.set(tabbedItem.name, scrollableContainer.scrollTop);\n });\n const scrollPosition = this.tabbedItemScrollMap.get(tabbedItem.name);\n if (scrollPosition !== undefined) {\n // Safari needs a small timeout or it will fire a scroll event to position 0\n setTimeout(() => {\n scrollableContainer.scrollTop = scrollPosition;\n }, 0);\n }\n }\n });\n if (this.activeItem) {\n this.activeItem.eHeaderButton.classList.remove('ag-tab-selected');\n (_b = (_a = this.activeItem.tabbedItem).afterDetachedCallback) === null || _b === void 0 ? void 0 : _b.call(_a);\n }\n eHeaderButton.classList.add('ag-tab-selected');\n this.activeItem = wrapper;\n }\n}\n__decorate([\n Autowired('focusService')\n], TabbedLayout.prototype, \"focusService\", void 0);\n__decorate([\n RefSelector('eHeader')\n], TabbedLayout.prototype, \"eHeader\", void 0);\n__decorate([\n RefSelector('eBody')\n], TabbedLayout.prototype, \"eBody\", void 0);\n__decorate([\n PostConstruct\n], TabbedLayout.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { offsetHeight, offsetWidth } from \"../utils/dom.mjs\";\nconst DEBOUNCE_DELAY = 50;\nlet ResizeObserverService = class ResizeObserverService extends BeanStub {\n constructor() {\n super(...arguments);\n this.polyfillFunctions = [];\n }\n observeResize(element, callback) {\n const win = this.gridOptionsService.getWindow();\n const useBrowserResizeObserver = () => {\n const resizeObserver = new win.ResizeObserver(callback);\n resizeObserver.observe(element);\n return () => resizeObserver.disconnect();\n };\n const usePolyfill = () => {\n // initialise to the current width and height, so first call will have no changes\n let widthLastTime = offsetWidth(element);\n let heightLastTime = offsetHeight(element);\n // when finished, this gets turned to false.\n let running = true;\n const periodicallyCheckWidthAndHeight = () => {\n if (running) {\n const newWidth = offsetWidth(element);\n const newHeight = offsetHeight(element);\n const changed = newWidth !== widthLastTime || newHeight !== heightLastTime;\n if (changed) {\n widthLastTime = newWidth;\n heightLastTime = newHeight;\n callback();\n }\n this.doNextPolyfillTurn(periodicallyCheckWidthAndHeight);\n }\n };\n periodicallyCheckWidthAndHeight();\n // the callback function we return sets running to false\n return () => running = false;\n };\n const suppressResize = this.gridOptionsService.is('suppressBrowserResizeObserver');\n const resizeObserverExists = !!win.ResizeObserver;\n if (resizeObserverExists && !suppressResize) {\n return useBrowserResizeObserver();\n }\n return usePolyfill();\n }\n doNextPolyfillTurn(func) {\n this.polyfillFunctions.push(func);\n this.schedulePolyfill();\n }\n schedulePolyfill() {\n if (this.polyfillScheduled) {\n return;\n }\n const executeAllFuncs = () => {\n const funcs = this.polyfillFunctions;\n // make sure set scheduled to false and clear clear array\n // before executing the funcs, as the funcs could add more funcs\n this.polyfillScheduled = false;\n this.polyfillFunctions = [];\n funcs.forEach(f => f());\n };\n this.polyfillScheduled = true;\n this.getFrameworkOverrides().setTimeout(executeAllFuncs, DEBOUNCE_DELAY);\n }\n};\nResizeObserverService = __decorate([\n Bean('resizeObserverService')\n], ResizeObserverService);\nexport { ResizeObserverService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, PostConstruct } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nlet AnimationFrameService = class AnimationFrameService extends BeanStub {\n constructor() {\n super(...arguments);\n // p1 and p2 are create tasks are to do with row and cell creation.\n // for them we want to execute according to row order, so we use\n // TaskItem so we know what index the item is for.\n this.createTasksP1 = { list: [], sorted: false }; // eg drawing back-ground of rows\n this.createTasksP2 = { list: [], sorted: false }; // eg cell renderers, adding hover functionality\n // destroy tasks are to do with row removal. they are done after row creation as the user will need to see new\n // rows first (as blank is scrolled into view), when we remove the old rows (no longer in view) is not as\n // important.\n this.destroyTasks = [];\n this.ticking = false;\n // we need to know direction of scroll, to build up rows in the direction of\n // the scroll. eg if user scrolls down, we extend the rows by building down.\n this.scrollGoingDown = true;\n this.lastPage = 0;\n this.lastScrollTop = 0;\n this.taskCount = 0;\n this.cancelledTasks = new Set();\n }\n setScrollTop(scrollTop) {\n const isPaginationActive = this.gridOptionsService.is('pagination');\n this.scrollGoingDown = scrollTop >= this.lastScrollTop;\n if (isPaginationActive && scrollTop === 0) {\n const currentPage = this.paginationProxy.getCurrentPage();\n if (currentPage !== this.lastPage) {\n this.lastPage = currentPage;\n this.scrollGoingDown = true;\n }\n }\n this.lastScrollTop = scrollTop;\n }\n init() {\n this.useAnimationFrame = !this.gridOptionsService.is('suppressAnimationFrame');\n }\n isOn() {\n return this.useAnimationFrame;\n }\n // this method is for our AG Grid sanity only - if animation frames are turned off,\n // then no place in the code should be looking to add any work to be done in animation\n // frames. this stops bugs - where some code is asking for a frame to be executed\n // when it should not.\n verifyAnimationFrameOn(methodName) {\n if (this.useAnimationFrame === false) {\n console.warn(`AG Grid: AnimationFrameService.${methodName} called but animation frames are off`);\n }\n }\n createTask(task, index, list) {\n this.verifyAnimationFrameOn(list);\n const taskItem = { task, index, createOrder: ++this.taskCount };\n this.addTaskToList(this[list], taskItem);\n this.schedule();\n }\n cancelTask(task) {\n this.cancelledTasks.add(task);\n }\n addTaskToList(taskList, task) {\n taskList.list.push(task);\n taskList.sorted = false;\n }\n sortTaskList(taskList) {\n if (taskList.sorted) {\n return;\n }\n const sortDirection = this.scrollGoingDown ? 1 : -1;\n // sort first by row index (taking into account scroll direction), then by\n // order of task creation (always ascending, so cells will render left-to-right)\n taskList.list.sort((a, b) => a.index !== b.index ? sortDirection * (b.index - a.index) : b.createOrder - a.createOrder);\n taskList.sorted = true;\n }\n addDestroyTask(task) {\n this.verifyAnimationFrameOn('createTasksP3');\n this.destroyTasks.push(task);\n this.schedule();\n }\n executeFrame(millis) {\n this.verifyAnimationFrameOn('executeFrame');\n const p1TaskList = this.createTasksP1;\n const p1Tasks = p1TaskList.list;\n const p2TaskList = this.createTasksP2;\n const p2Tasks = p2TaskList.list;\n const destroyTasks = this.destroyTasks;\n const frameStart = new Date().getTime();\n let duration = (new Date().getTime()) - frameStart;\n // 16ms is 60 fps\n const noMaxMillis = millis <= 0;\n const gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n while (noMaxMillis || duration < millis) {\n const gridBodyDidSomething = gridBodyCon.getScrollFeature().scrollGridIfNeeded();\n if (!gridBodyDidSomething) {\n let task;\n if (p1Tasks.length) {\n this.sortTaskList(p1TaskList);\n task = p1Tasks.pop().task;\n }\n else if (p2Tasks.length) {\n this.sortTaskList(p2TaskList);\n task = p2Tasks.pop().task;\n }\n else if (destroyTasks.length) {\n task = destroyTasks.pop();\n }\n else {\n this.cancelledTasks.clear();\n break;\n }\n if (!this.cancelledTasks.has(task)) {\n task();\n }\n }\n duration = (new Date().getTime()) - frameStart;\n }\n if (p1Tasks.length || p2Tasks.length || destroyTasks.length) {\n this.requestFrame();\n }\n else {\n this.stopTicking();\n }\n }\n stopTicking() {\n this.ticking = false;\n }\n flushAllFrames() {\n if (!this.useAnimationFrame) {\n return;\n }\n this.executeFrame(-1);\n }\n schedule() {\n if (!this.useAnimationFrame) {\n return;\n }\n if (!this.ticking) {\n this.ticking = true;\n this.requestFrame();\n }\n }\n requestFrame() {\n // check for the existence of requestAnimationFrame, and if\n // it's missing, then we polyfill it with setTimeout()\n const callback = this.executeFrame.bind(this, 60);\n this.requestAnimationFrame(callback);\n }\n requestAnimationFrame(callback) {\n const win = this.gridOptionsService.getWindow();\n if (win.requestAnimationFrame) {\n win.requestAnimationFrame(callback);\n }\n else if (win.webkitRequestAnimationFrame) {\n win.webkitRequestAnimationFrame(callback);\n }\n else {\n win.setTimeout(callback, 0);\n }\n }\n isQueueEmpty() {\n return !this.ticking;\n }\n // a debounce utility used for parts of the app involved with rendering.\n // the advantage over normal debounce is the client can call flushAllFrames()\n // to make sure all rendering is complete. we don't wait any milliseconds,\n // as this is intended to batch calls in one VM turn.\n debounce(func) {\n let pending = false;\n return () => {\n if (!this.isOn()) {\n this.getFrameworkOverrides().setTimeout(func, 0);\n return;\n }\n if (pending) {\n return;\n }\n pending = true;\n this.addDestroyTask(() => {\n pending = false;\n func();\n });\n };\n }\n};\n__decorate([\n Autowired('ctrlsService')\n], AnimationFrameService.prototype, \"ctrlsService\", void 0);\n__decorate([\n Autowired('paginationProxy')\n], AnimationFrameService.prototype, \"paginationProxy\", void 0);\n__decorate([\n PostConstruct\n], AnimationFrameService.prototype, \"init\", null);\nAnimationFrameService = __decorate([\n Bean('animationFrameService')\n], AnimationFrameService);\nexport { AnimationFrameService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, PostConstruct } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nlet AutoWidthCalculator = class AutoWidthCalculator extends BeanStub {\n postConstruct() {\n this.ctrlsService.whenReady(p => {\n this.centerRowContainerCtrl = p.centerRowContainerCtrl;\n });\n }\n // this is the trick: we create a dummy container and clone all the cells\n // into the dummy, then check the dummy's width. then destroy the dummy\n // as we don't need it any more.\n // drawback: only the cells visible on the screen are considered\n getPreferredWidthForColumn(column, skipHeader) {\n const eHeaderCell = this.getHeaderCellForColumn(column);\n // cell isn't visible\n if (!eHeaderCell) {\n return -1;\n }\n const elements = this.rowRenderer.getAllCellsForColumn(column);\n if (!skipHeader) {\n // we only consider the lowest level cell, not the group cell. in 99% of the time, this\n // will be enough. if we consider groups, then it gets too complicated for what it's worth,\n // as the groups can span columns and this class only considers one column at a time.\n elements.push(eHeaderCell);\n }\n return this.addElementsToContainerAndGetWidth(elements);\n }\n getPreferredWidthForColumnGroup(columnGroup) {\n const eHeaderCell = this.getHeaderCellForColumn(columnGroup);\n if (!eHeaderCell) {\n return -1;\n }\n return this.addElementsToContainerAndGetWidth([eHeaderCell]);\n }\n addElementsToContainerAndGetWidth(elements) {\n // this element has to be a form, otherwise form elements within a cell\n // will be validated while being cloned. This can cause issues such as \n // radio buttons being reset and losing their values.\n const eDummyContainer = document.createElement('form');\n // position fixed, so it isn't restricted to the boundaries of the parent\n eDummyContainer.style.position = 'fixed';\n // we put the dummy into the body container, so it will inherit all the\n // css styles that the real cells are inheriting\n const eBodyContainer = this.centerRowContainerCtrl.getContainerElement();\n elements.forEach(el => this.cloneItemIntoDummy(el, eDummyContainer));\n // only append the dummyContainer to the DOM after it contains all the necessary items\n eBodyContainer.appendChild(eDummyContainer);\n // at this point, all the clones are lined up vertically with natural widths. the dummy\n // container will have a width wide enough just to fit the largest.\n const dummyContainerWidth = eDummyContainer.offsetWidth;\n // we are finished with the dummy container, so get rid of it\n eBodyContainer.removeChild(eDummyContainer);\n // we add padding as I found sometimes the gui still put '...' after some of the texts. so the\n // user can configure the grid to add a few more pixels after the calculated width\n const autoSizePadding = this.getAutoSizePadding();\n return dummyContainerWidth + autoSizePadding;\n }\n getAutoSizePadding() {\n const value = this.gridOptionsService.getNum('autoSizePadding');\n return value != null && value >= 0 ? value : 20;\n }\n getHeaderCellForColumn(column) {\n /* tslint:enable */\n let element = null;\n this.ctrlsService.getHeaderRowContainerCtrls().forEach(container => {\n const res = container.getHtmlElementForColumnHeader(column);\n if (res != null) {\n element = res;\n }\n });\n return element;\n }\n cloneItemIntoDummy(eCell, eDummyContainer) {\n // make a deep clone of the cell\n const eCellClone = eCell.cloneNode(true);\n // the original has a fixed width, we remove this to allow the natural width based on content\n eCellClone.style.width = '';\n // the original has position = absolute, we need to remove this so it's positioned normally\n eCellClone.style.position = 'static';\n eCellClone.style.left = '';\n // we put the cell into a containing div, as otherwise the cells would just line up\n // on the same line, standard flow layout, by putting them into divs, they are laid\n // out one per line\n const eCloneParent = document.createElement('div');\n const eCloneParentClassList = eCloneParent.classList;\n const isHeader = ['ag-header-cell', 'ag-header-group-cell'].some(cls => eCellClone.classList.contains(cls));\n if (isHeader) {\n eCloneParentClassList.add('ag-header', 'ag-header-row');\n eCloneParent.style.position = 'static';\n }\n else {\n eCloneParentClassList.add('ag-row');\n }\n // find parent using classes (headers have ag-header-cell, rows have ag-row), and copy classes from it.\n // if we didn't do this, things like ag-row-level-2 would be missing if present, which sets indents\n // onto group items.\n let pointer = eCell.parentElement;\n while (pointer) {\n const isRow = ['ag-header-row', 'ag-row'].some(cls => pointer.classList.contains(cls));\n if (isRow) {\n for (let i = 0; i < pointer.classList.length; i++) {\n const item = pointer.classList[i];\n // we skip ag-row-position-absolute, as this has structural CSS applied that stops the\n // element from fitting into it's parent, and we need the element to stretch the parent\n // as we are measuring the parents width\n if (item != 'ag-row-position-absolute') {\n eCloneParentClassList.add(item);\n }\n }\n break;\n }\n pointer = pointer.parentElement;\n }\n // the twig on the branch, the branch on the tree, the tree in the hole,\n // the hole in the bog, the bog in the clone, the clone in the parent,\n // the parent in the dummy, and the dummy down in the vall-e-ooo, OOOOOOOOO! Oh row the rattling bog....\n eCloneParent.appendChild(eCellClone);\n eDummyContainer.appendChild(eCloneParent);\n }\n};\n__decorate([\n Autowired('rowRenderer')\n], AutoWidthCalculator.prototype, \"rowRenderer\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], AutoWidthCalculator.prototype, \"ctrlsService\", void 0);\n__decorate([\n Autowired('rowCssClassCalculator')\n], AutoWidthCalculator.prototype, \"rowCssClassCalculator\", void 0);\n__decorate([\n PostConstruct\n], AutoWidthCalculator.prototype, \"postConstruct\", null);\nAutoWidthCalculator = __decorate([\n Bean('autoWidthCalculator')\n], AutoWidthCalculator);\nexport { AutoWidthCalculator };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nimport { Autowired, PostConstruct } from \"../../context/context.mjs\";\nimport { last } from \"../../utils/array.mjs\";\nexport class StickyRowFeature extends BeanStub {\n constructor(createRowCon, destroyRowCtrls) {\n super();\n this.createRowCon = createRowCon;\n this.destroyRowCtrls = destroyRowCtrls;\n this.stickyRowCtrls = [];\n this.containerHeight = 0;\n }\n postConstruct() {\n this.isClientSide = this.rowModel.getType() === 'clientSide';\n this.ctrlsService.whenReady(params => {\n this.gridBodyCtrl = params.gridBodyCtrl;\n });\n }\n getStickyRowCtrls() {\n return this.stickyRowCtrls;\n }\n checkStickyRows() {\n let height = 0;\n if (!this.gridOptionsService.isGroupRowsSticky()) {\n return this.refreshNodesAndContainerHeight([], height);\n }\n const stickyRows = [];\n const firstPixel = this.rowRenderer.getFirstVisibleVerticalPixel();\n const addStickyRow = (stickyRow) => {\n var _a, _b, _c;\n stickyRows.push(stickyRow);\n let lastChildBottom;\n if (this.isClientSide) {\n let lastAncestor = stickyRow;\n while (lastAncestor.expanded) {\n if (lastAncestor.master) {\n lastAncestor = lastAncestor.detailNode;\n }\n else if (lastAncestor.childrenAfterSort) {\n // Tree Data will have `childrenAfterSort` without any nodes, but\n // the current node will still be marked as expansible.\n if (lastAncestor.childrenAfterSort.length === 0) {\n break;\n }\n lastAncestor = last(lastAncestor.childrenAfterSort);\n }\n }\n lastChildBottom = lastAncestor.rowTop + lastAncestor.rowHeight;\n }\n // if the rowModel is `serverSide` as only `clientSide` and `serverSide` create this feature.\n else {\n if (stickyRow.master) {\n lastChildBottom = stickyRow.detailNode.rowTop + stickyRow.detailNode.rowHeight;\n }\n else {\n const storeBounds = (_a = stickyRow.childStore) === null || _a === void 0 ? void 0 : _a.getStoreBounds();\n lastChildBottom = ((_b = storeBounds === null || storeBounds === void 0 ? void 0 : storeBounds.heightPx) !== null && _b !== void 0 ? _b : 0) + ((_c = storeBounds === null || storeBounds === void 0 ? void 0 : storeBounds.topPx) !== null && _c !== void 0 ? _c : 0);\n }\n }\n const stickRowBottom = firstPixel + height + stickyRow.rowHeight;\n if (lastChildBottom < stickRowBottom) {\n stickyRow.stickyRowTop = height + (lastChildBottom - stickRowBottom);\n }\n else {\n stickyRow.stickyRowTop = height;\n }\n height = 0;\n stickyRows.forEach(rowNode => {\n const thisRowLastPx = rowNode.stickyRowTop + rowNode.rowHeight;\n if (height < thisRowLastPx) {\n height = thisRowLastPx;\n }\n });\n };\n while (true) {\n const firstPixelAfterStickyRows = firstPixel + height;\n const firstIndex = this.rowModel.getRowIndexAtPixel(firstPixelAfterStickyRows);\n const firstRow = this.rowModel.getRow(firstIndex);\n if (firstRow == null) {\n break;\n }\n // only happens when pivoting, and we are showing root node\n if (firstRow.level < 0) {\n break;\n }\n const parents = [];\n let p = firstRow.parent;\n while (p.level >= 0) {\n parents.push(p);\n p = p.parent;\n }\n const firstMissingParent = parents.reverse().find(parent => stickyRows.indexOf(parent) < 0 && parent.displayed);\n if (firstMissingParent) {\n addStickyRow(firstMissingParent);\n continue;\n }\n // if first row is an open group, and practically shown, it needs\n // to be stuck\n if (firstRow.isExpandable() && firstRow.expanded && firstRow.rowTop < firstPixelAfterStickyRows) {\n addStickyRow(firstRow);\n continue;\n }\n break;\n }\n return this.refreshNodesAndContainerHeight(stickyRows, height);\n }\n refreshStickyNode(stickRowNode) {\n const allStickyNodes = [];\n for (let i = 0; i < this.stickyRowCtrls.length; i++) {\n const currentNode = this.stickyRowCtrls[i].getRowNode();\n if (currentNode !== stickRowNode) {\n allStickyNodes.push(currentNode);\n }\n }\n if (this.refreshNodesAndContainerHeight(allStickyNodes, this.containerHeight)) {\n this.checkStickyRows();\n }\n }\n refreshNodesAndContainerHeight(allStickyNodes, height) {\n let stickyRowsChanged = false;\n const removedCtrls = this.stickyRowCtrls.filter(ctrl => allStickyNodes.indexOf(ctrl.getRowNode()) === -1);\n const addedNodes = allStickyNodes.filter(rowNode => this.stickyRowCtrls.findIndex(ctrl => ctrl.getRowNode() === rowNode) === -1);\n if (removedCtrls.length || addedNodes.length) {\n stickyRowsChanged = true;\n }\n const ctrlsToDestroy = {};\n removedCtrls.forEach(removedCtrl => {\n ctrlsToDestroy[removedCtrl.getRowNode().id] = removedCtrl;\n this.stickyRowCtrls = this.stickyRowCtrls.filter(ctrl => ctrl !== removedCtrl);\n });\n for (const ctrl of Object.values(ctrlsToDestroy)) {\n ctrl.getRowNode().sticky = false;\n }\n this.destroyRowCtrls(ctrlsToDestroy, false);\n const newCtrls = addedNodes.map(rowNode => {\n rowNode.sticky = true;\n return this.createRowCon(rowNode, false, false);\n });\n this.stickyRowCtrls.push(...newCtrls);\n this.stickyRowCtrls.forEach(ctrl => ctrl.setRowTop(ctrl.getRowNode().stickyRowTop));\n this.stickyRowCtrls.sort((a, b) => b.getRowNode().rowIndex - a.getRowNode().rowIndex);\n if (this.containerHeight !== height) {\n this.containerHeight = height;\n this.gridBodyCtrl.setStickyTopHeight(height);\n stickyRowsChanged = true;\n }\n return stickyRowsChanged;\n }\n}\n__decorate([\n Autowired(\"rowModel\")\n], StickyRowFeature.prototype, \"rowModel\", void 0);\n__decorate([\n Autowired(\"rowRenderer\")\n], StickyRowFeature.prototype, \"rowRenderer\", void 0);\n__decorate([\n Autowired(\"ctrlsService\")\n], StickyRowFeature.prototype, \"ctrlsService\", void 0);\n__decorate([\n PostConstruct\n], StickyRowFeature.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { RowCtrl } from \"./row/rowCtrl.mjs\";\nimport { Events } from \"../events.mjs\";\nimport { Autowired, Bean, PostConstruct } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { exists } from \"../utils/generic.mjs\";\nimport { getAllValuesInObject, iterateObject } from \"../utils/object.mjs\";\nimport { createArrayOfNumbers } from \"../utils/number.mjs\";\nimport { doOnce, executeInAWhile } from \"../utils/function.mjs\";\nimport { CellCtrl } from \"./cell/cellCtrl.mjs\";\nimport { removeFromArray } from \"../utils/array.mjs\";\nimport { StickyRowFeature } from \"./features/stickyRowFeature.mjs\";\nimport { browserSupportsPreventScroll } from \"../utils/browser.mjs\";\nconst DEFAULT_KEEP_DETAIL_ROW_COUNT = 10;\nlet RowRenderer = class RowRenderer extends BeanStub {\n constructor() {\n super(...arguments);\n this.destroyFuncsForColumnListeners = [];\n // map of row ids to row objects. keeps track of which elements\n // are rendered for which rows in the dom.\n this.rowCtrlsByRowIndex = {};\n this.zombieRowCtrls = {};\n this.allRowCtrls = [];\n this.topRowCtrls = [];\n this.bottomRowCtrls = [];\n // we only allow one refresh at a time, otherwise the internal memory structure here\n // will get messed up. this can happen if the user has a cellRenderer, and inside the\n // renderer they call an API method that results in another pass of the refresh,\n // then it will be trying to draw rows in the middle of a refresh.\n this.refreshInProgress = false;\n this.dataFirstRenderedFired = false;\n }\n postConstruct() {\n this.ctrlsService.whenReady(() => {\n this.gridBodyCtrl = this.ctrlsService.getGridBodyCtrl();\n this.initialise();\n });\n }\n initialise() {\n this.addManagedListener(this.eventService, Events.EVENT_PAGINATION_CHANGED, this.onPageLoaded.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_PINNED_ROW_DATA_CHANGED, this.onPinnedRowDataChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_BODY_SCROLL, this.onBodyScroll.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_BODY_HEIGHT_CHANGED, this.redraw.bind(this));\n this.addManagedPropertyListener('domLayout', this.onDomLayoutChanged.bind(this));\n this.addManagedPropertyListener('rowClass', this.redrawRows.bind(this));\n if (this.gridOptionsService.isGroupRowsSticky()) {\n const rowModelType = this.rowModel.getType();\n if (rowModelType === 'clientSide' || rowModelType === 'serverSide') {\n this.stickyRowFeature = this.createManagedBean(new StickyRowFeature(this.createRowCon.bind(this), this.destroyRowCtrls.bind(this)));\n }\n }\n this.registerCellEventListeners();\n this.initialiseCache();\n this.printLayout = this.gridOptionsService.isDomLayout('print');\n this.embedFullWidthRows = this.printLayout || this.gridOptionsService.is('embedFullWidthRows');\n this.redrawAfterModelUpdate();\n }\n initialiseCache() {\n if (this.gridOptionsService.is('keepDetailRows')) {\n const countProp = this.getKeepDetailRowsCount();\n const count = countProp != null ? countProp : 3;\n this.cachedRowCtrls = new RowCtrlCache(count);\n }\n }\n getKeepDetailRowsCount() {\n const keepDetailRowsCount = this.gridOptionsService.getNum('keepDetailRowsCount');\n if (exists(keepDetailRowsCount) && keepDetailRowsCount > 0) {\n return keepDetailRowsCount;\n }\n return DEFAULT_KEEP_DETAIL_ROW_COUNT;\n }\n getStickyTopRowCtrls() {\n if (!this.stickyRowFeature) {\n return [];\n }\n return this.stickyRowFeature.getStickyRowCtrls();\n }\n updateAllRowCtrls() {\n const liveList = getAllValuesInObject(this.rowCtrlsByRowIndex);\n const isEnsureDomOrder = this.gridOptionsService.is('ensureDomOrder');\n const isPrintLayout = this.gridOptionsService.isDomLayout('print');\n if (isEnsureDomOrder || isPrintLayout) {\n liveList.sort((a, b) => a.getRowNode().rowIndex - b.getRowNode.rowIndex);\n }\n const zombieList = getAllValuesInObject(this.zombieRowCtrls);\n const cachedList = this.cachedRowCtrls ? this.cachedRowCtrls.getEntries() : [];\n if (zombieList.length > 0 || cachedList.length > 0) {\n // Only spread if we need to.\n this.allRowCtrls = [...liveList, ...zombieList, ...cachedList];\n }\n else {\n this.allRowCtrls = liveList;\n }\n }\n onCellFocusChanged(event) {\n this.getAllCellCtrls().forEach(cellCtrl => cellCtrl.onCellFocused(event));\n this.getFullWidthRowCtrls().forEach(rowCtrl => rowCtrl.onFullWidthRowFocused(event));\n }\n // in a clean design, each cell would register for each of these events. however when scrolling, all the cells\n // registering and de-registering for events is a performance bottleneck. so we register here once and inform\n // all active cells.\n registerCellEventListeners() {\n this.addManagedListener(this.eventService, Events.EVENT_CELL_FOCUSED, (event) => {\n this.onCellFocusChanged(event);\n });\n this.addManagedListener(this.eventService, Events.EVENT_CELL_FOCUS_CLEARED, () => {\n this.onCellFocusChanged();\n });\n this.addManagedListener(this.eventService, Events.EVENT_FLASH_CELLS, event => {\n this.getAllCellCtrls().forEach(cellCtrl => cellCtrl.onFlashCells(event));\n });\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_HOVER_CHANGED, () => {\n this.getAllCellCtrls().forEach(cellCtrl => cellCtrl.onColumnHover());\n });\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, () => {\n this.getAllCellCtrls().forEach(cellCtrl => cellCtrl.onDisplayedColumnsChanged());\n });\n // only for printLayout - because we are rendering all the cells in the same row, regardless of pinned state,\n // then changing the width of the containers will impact left position. eg the center cols all have their\n // left position adjusted by the width of the left pinned column, so if the pinned left column width changes,\n // all the center cols need to be shifted to accommodate this. when in normal layout, the pinned cols are\n // in different containers so doesn't impact.\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, () => {\n if (this.printLayout) {\n this.getAllCellCtrls().forEach(cellCtrl => cellCtrl.onLeftChanged());\n }\n });\n const rangeSelectionEnabled = this.gridOptionsService.is('enableRangeSelection');\n if (rangeSelectionEnabled) {\n this.addManagedListener(this.eventService, Events.EVENT_RANGE_SELECTION_CHANGED, () => {\n this.getAllCellCtrls().forEach(cellCtrl => cellCtrl.onRangeSelectionChanged());\n });\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_MOVED, () => {\n this.getAllCellCtrls().forEach(cellCtrl => cellCtrl.updateRangeBordersIfRangeCount());\n });\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PINNED, () => {\n this.getAllCellCtrls().forEach(cellCtrl => cellCtrl.updateRangeBordersIfRangeCount());\n });\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_VISIBLE, () => {\n this.getAllCellCtrls().forEach(cellCtrl => cellCtrl.updateRangeBordersIfRangeCount());\n });\n }\n // add listeners to the grid columns\n this.refreshListenersToColumnsForCellComps();\n // if the grid columns change, then refresh the listeners again\n this.addManagedListener(this.eventService, Events.EVENT_GRID_COLUMNS_CHANGED, this.refreshListenersToColumnsForCellComps.bind(this));\n this.addDestroyFunc(this.removeGridColumnListeners.bind(this));\n }\n // executes all functions in destroyFuncsForColumnListeners and then clears the list\n removeGridColumnListeners() {\n this.destroyFuncsForColumnListeners.forEach(func => func());\n this.destroyFuncsForColumnListeners.length = 0;\n }\n // this function adds listeners onto all the grid columns, which are the column that we could have cellComps for.\n // when the grid columns change, we add listeners again. in an ideal design, each CellComp would just register to\n // the column it belongs to on creation, however this was a bottleneck with the number of cells, so do it here\n // once instead.\n refreshListenersToColumnsForCellComps() {\n this.removeGridColumnListeners();\n const cols = this.columnModel.getAllGridColumns();\n if (!cols) {\n return;\n }\n cols.forEach(col => {\n const forEachCellWithThisCol = (callback) => {\n this.getAllCellCtrls().forEach(cellCtrl => {\n if (cellCtrl.getColumn() === col) {\n callback(cellCtrl);\n }\n });\n };\n const leftChangedListener = () => {\n forEachCellWithThisCol(cellCtrl => cellCtrl.onLeftChanged());\n };\n const widthChangedListener = () => {\n forEachCellWithThisCol(cellCtrl => cellCtrl.onWidthChanged());\n };\n const firstRightPinnedChangedListener = () => {\n forEachCellWithThisCol(cellCtrl => cellCtrl.onFirstRightPinnedChanged());\n };\n const lastLeftPinnedChangedListener = () => {\n forEachCellWithThisCol(cellCtrl => cellCtrl.onLastLeftPinnedChanged());\n };\n const colDefChangedListener = () => {\n forEachCellWithThisCol(cellCtrl => cellCtrl.onColDefChanged());\n };\n col.addEventListener('leftChanged', leftChangedListener);\n col.addEventListener('widthChanged', widthChangedListener);\n col.addEventListener('firstRightPinnedChanged', firstRightPinnedChangedListener);\n col.addEventListener('lastLeftPinnedChanged', lastLeftPinnedChangedListener);\n col.addEventListener('colDefChanged', colDefChangedListener);\n this.destroyFuncsForColumnListeners.push(() => {\n col.removeEventListener('leftChanged', leftChangedListener);\n col.removeEventListener('widthChanged', widthChangedListener);\n col.removeEventListener('firstRightPinnedChanged', firstRightPinnedChangedListener);\n col.removeEventListener('lastLeftPinnedChanged', lastLeftPinnedChangedListener);\n col.removeEventListener('colDefChanged', colDefChangedListener);\n });\n });\n }\n onDomLayoutChanged() {\n const printLayout = this.gridOptionsService.isDomLayout('print');\n const embedFullWidthRows = printLayout || this.gridOptionsService.is('embedFullWidthRows');\n // if moving towards or away from print layout, means we need to destroy all rows, as rows are not laid\n // out using absolute positioning when doing print layout\n const destroyRows = embedFullWidthRows !== this.embedFullWidthRows || this.printLayout !== printLayout;\n this.printLayout = printLayout;\n this.embedFullWidthRows = embedFullWidthRows;\n if (destroyRows) {\n this.redrawAfterModelUpdate({ domLayoutChanged: true });\n }\n }\n // for row models that have datasources, when we update the datasource, we need to force the rowRenderer\n // to redraw all rows. otherwise the old rows from the old datasource will stay displayed.\n datasourceChanged() {\n this.firstRenderedRow = 0;\n this.lastRenderedRow = -1;\n const rowIndexesToRemove = Object.keys(this.rowCtrlsByRowIndex);\n this.removeRowCtrls(rowIndexesToRemove);\n }\n onPageLoaded(event) {\n const params = {\n recycleRows: event.keepRenderedRows,\n animate: event.animate,\n newData: event.newData,\n newPage: event.newPage,\n // because this is a model updated event (not pinned rows), we\n // can skip updating the pinned rows. this is needed so that if user\n // is doing transaction updates, the pinned rows are not getting constantly\n // trashed - or editing cells in pinned rows are not refreshed and put into read mode\n onlyBody: true\n };\n this.redrawAfterModelUpdate(params);\n }\n getAllCellsForColumn(column) {\n const res = [];\n this.getAllRowCtrls().forEach(rowCtrl => {\n const eCell = rowCtrl.getCellElement(column);\n if (eCell) {\n res.push(eCell);\n }\n });\n return res;\n }\n refreshFloatingRowComps() {\n this.refreshFloatingRows(this.topRowCtrls, this.pinnedRowModel.getPinnedTopRowData());\n this.refreshFloatingRows(this.bottomRowCtrls, this.pinnedRowModel.getPinnedBottomRowData());\n }\n getTopRowCtrls() {\n return this.topRowCtrls;\n }\n getCentreRowCtrls() {\n return this.allRowCtrls;\n }\n getBottomRowCtrls() {\n return this.bottomRowCtrls;\n }\n refreshFloatingRows(rowComps, rowNodes) {\n rowComps.forEach((row) => {\n row.destroyFirstPass();\n row.destroySecondPass();\n });\n rowComps.length = 0;\n if (!rowNodes) {\n return;\n }\n rowNodes.forEach(rowNode => {\n const rowCtrl = new RowCtrl(rowNode, this.beans, false, false, this.printLayout);\n rowComps.push(rowCtrl);\n });\n }\n onPinnedRowDataChanged() {\n // recycling rows in order to ensure cell editing is not cancelled\n const params = {\n recycleRows: true\n };\n this.redrawAfterModelUpdate(params);\n }\n redrawRow(rowNode, suppressEvent = false) {\n if (rowNode.sticky) {\n this.stickyRowFeature.refreshStickyNode(rowNode);\n }\n else {\n const destroyAndRecreateCtrl = (dataStruct) => {\n const ctrl = dataStruct[rowNode.rowIndex];\n if (!ctrl) {\n return;\n }\n if (ctrl.getRowNode() !== rowNode) {\n // if the node is in the wrong place, then the row model is responsible for triggering a full refresh.\n return;\n }\n ctrl.destroyFirstPass();\n ctrl.destroySecondPass();\n dataStruct[rowNode.rowIndex] = this.createRowCon(rowNode, false, false);\n };\n switch (rowNode.rowPinned) {\n case 'top':\n destroyAndRecreateCtrl(this.topRowCtrls);\n case 'bottom':\n destroyAndRecreateCtrl(this.bottomRowCtrls);\n default:\n destroyAndRecreateCtrl(this.rowCtrlsByRowIndex);\n this.updateAllRowCtrls();\n }\n }\n if (!suppressEvent) {\n this.dispatchDisplayedRowsChanged(false);\n }\n }\n redrawRows(rowNodes) {\n // if no row nodes provided, then refresh everything\n const partialRefresh = rowNodes != null;\n if (partialRefresh) {\n rowNodes === null || rowNodes === void 0 ? void 0 : rowNodes.forEach(node => this.redrawRow(node, true));\n this.dispatchDisplayedRowsChanged(false);\n return;\n }\n this.redrawAfterModelUpdate();\n }\n getCellToRestoreFocusToAfterRefresh(params) {\n const focusedCell = (params === null || params === void 0 ? void 0 : params.suppressKeepFocus) ? null : this.focusService.getFocusCellToUseAfterRefresh();\n if (focusedCell == null) {\n return null;\n }\n // if the dom is not actually focused on a cell, then we don't try to refocus. the problem this\n // solves is with editing - if the user is editing, eg focus is on a text field, and not on the\n // cell itself, then the cell can be registered as having focus, however it's the text field that\n // has the focus and not the cell div. therefore, when the refresh is finished, the grid will focus\n // the cell, and not the textfield. that means if the user is in a text field, and the grid refreshes,\n // the focus is lost from the text field. we do not want this.\n const eDocument = this.gridOptionsService.getDocument();\n const activeElement = eDocument.activeElement;\n const cellDomData = this.gridOptionsService.getDomData(activeElement, CellCtrl.DOM_DATA_KEY_CELL_CTRL);\n const rowDomData = this.gridOptionsService.getDomData(activeElement, RowCtrl.DOM_DATA_KEY_ROW_CTRL);\n const gridElementFocused = cellDomData || rowDomData;\n return gridElementFocused ? focusedCell : null;\n }\n // gets called from:\n // +) initialisation (in registerGridComp) params = null\n // +) onDomLayoutChanged, params = null\n // +) onPageLoaded, recycleRows, animate, newData, newPage from event, onlyBody=true\n // +) onPinnedRowDataChanged, recycleRows = true\n // +) redrawRows (from Grid API), recycleRows = true/false\n redrawAfterModelUpdate(params = {}) {\n this.getLockOnRefresh();\n const focusedCell = this.getCellToRestoreFocusToAfterRefresh(params);\n this.updateContainerHeights();\n this.scrollToTopIfNewData(params);\n // never recycle rows on layout change as rows could change from normal DOM layout\n // back to the grid's row positioning.\n const recycleRows = !params.domLayoutChanged && !!params.recycleRows;\n const animate = params.animate && this.gridOptionsService.isAnimateRows();\n // after modelUpdate, row indexes can change, so we clear out the rowsByIndex map,\n // however we can reuse the rows, so we keep them but index by rowNode.id\n const rowsToRecycle = recycleRows ? this.getRowsToRecycle() : null;\n if (!recycleRows) {\n this.removeAllRowComps();\n }\n this.workOutFirstAndLastRowsToRender();\n if (this.stickyRowFeature) {\n this.stickyRowFeature.checkStickyRows();\n }\n this.recycleRows(rowsToRecycle, animate);\n this.gridBodyCtrl.updateRowCount();\n if (!params.onlyBody) {\n this.refreshFloatingRowComps();\n }\n this.dispatchDisplayedRowsChanged();\n // if a cell was focused before, ensure focus now.\n if (focusedCell != null) {\n this.restoreFocusedCell(focusedCell);\n }\n this.releaseLockOnRefresh();\n }\n scrollToTopIfNewData(params) {\n const scrollToTop = params.newData || params.newPage;\n const suppressScrollToTop = this.gridOptionsService.is('suppressScrollOnNewData');\n if (scrollToTop && !suppressScrollToTop) {\n this.gridBodyCtrl.getScrollFeature().scrollToTop();\n }\n }\n updateContainerHeights() {\n // when doing print layout, we don't explicitly set height on the containers\n if (this.printLayout) {\n this.rowContainerHeightService.setModelHeight(null);\n return;\n }\n let containerHeight = this.paginationProxy.getCurrentPageHeight();\n // we need at least 1 pixel for the horizontal scroll to work. so if there are now rows,\n // we still want the scroll to be present, otherwise there would be no way to scroll the header\n // which might be needed us user wants to access columns\n // on the RHS - and if that was where the filter was that cause no rows to be presented, there\n // is no way to remove the filter.\n if (containerHeight === 0) {\n containerHeight = 1;\n }\n this.rowContainerHeightService.setModelHeight(containerHeight);\n }\n getLockOnRefresh() {\n if (this.refreshInProgress) {\n throw new Error(\"AG Grid: cannot get grid to draw rows when it is in the middle of drawing rows. \" +\n \"Your code probably called a grid API method while the grid was in the render stage. To overcome \" +\n \"this, put the API call into a timeout, e.g. instead of api.redrawRows(), \" +\n \"call setTimeout(function() { api.redrawRows(); }, 0). To see what part of your code \" +\n \"that caused the refresh check this stacktrace.\");\n }\n this.refreshInProgress = true;\n }\n releaseLockOnRefresh() {\n this.refreshInProgress = false;\n }\n isRefreshInProgress() {\n return this.refreshInProgress;\n }\n // sets the focus to the provided cell, if the cell is provided. this way, the user can call refresh without\n // worry about the focus been lost. this is important when the user is using keyboard navigation to do edits\n // and the cellEditor is calling 'refresh' to get other cells to update (as other cells might depend on the\n // edited cell).\n restoreFocusedCell(cellPosition) {\n if (cellPosition) {\n // we don't wish to dispatch an event as the rowRenderer is not capable of changing the selected cell,\n // so we mock a change event for the full width rows and cells to ensure they update to the newly selected\n // state\n this.focusService.setRestoreFocusedCell(cellPosition);\n this.onCellFocusChanged({\n rowIndex: cellPosition.rowIndex,\n column: cellPosition.column,\n rowPinned: cellPosition.rowPinned,\n forceBrowserFocus: true,\n preventScrollOnBrowserFocus: true,\n api: this.beans.gridApi,\n columnApi: this.beans.columnApi,\n context: this.beans.gridOptionsService.context,\n type: 'mock',\n });\n }\n }\n stopEditing(cancel = false) {\n this.getAllRowCtrls().forEach(rowCtrl => {\n rowCtrl.stopEditing(cancel);\n });\n }\n getAllCellCtrls() {\n const res = [];\n const rowCtrls = this.getAllRowCtrls();\n const rowCtrlsLength = rowCtrls.length;\n for (let i = 0; i < rowCtrlsLength; i++) {\n const cellCtrls = rowCtrls[i].getAllCellCtrls();\n const cellCtrlsLength = cellCtrls.length;\n for (let j = 0; j < cellCtrlsLength; j++) {\n res.push(cellCtrls[j]);\n }\n }\n return res;\n }\n getAllRowCtrls() {\n const stickyRowCtrls = (this.stickyRowFeature && this.stickyRowFeature.getStickyRowCtrls()) || [];\n const res = [...this.topRowCtrls, ...this.bottomRowCtrls, ...stickyRowCtrls];\n for (const key of Object.keys(this.rowCtrlsByRowIndex)) {\n res.push(this.rowCtrlsByRowIndex[key]);\n }\n return res;\n }\n addRenderedRowListener(eventName, rowIndex, callback) {\n const rowComp = this.rowCtrlsByRowIndex[rowIndex];\n if (rowComp) {\n rowComp.addEventListener(eventName, callback);\n }\n }\n flashCells(params = {}) {\n const { flashDelay, fadeDelay } = params;\n this.getCellCtrls(params.rowNodes, params.columns)\n .forEach(cellCtrl => cellCtrl.flashCell({ flashDelay, fadeDelay }));\n }\n refreshCells(params = {}) {\n const refreshCellParams = {\n forceRefresh: params.force,\n newData: false,\n suppressFlash: params.suppressFlash\n };\n this.getCellCtrls(params.rowNodes, params.columns)\n .forEach(cellCtrl => {\n if (cellCtrl.refreshShouldDestroy()) {\n const rowCtrl = cellCtrl.getRowCtrl();\n if (rowCtrl) {\n rowCtrl.refreshCell(cellCtrl);\n }\n }\n else {\n cellCtrl.refreshCell(refreshCellParams);\n }\n });\n if (params.rowNodes) {\n // refresh the full width rows too\n this.getRowCtrls(params.rowNodes).forEach(rowCtrl => {\n if (!rowCtrl.isFullWidth()) {\n return;\n }\n const refreshed = rowCtrl.refreshFullWidth();\n if (!refreshed) {\n this.redrawRow(rowCtrl.getRowNode(), true);\n }\n });\n this.dispatchDisplayedRowsChanged(false);\n }\n }\n getCellRendererInstances(params) {\n var _a;\n const cellRenderers = this.getCellCtrls(params.rowNodes, params.columns)\n .map(cellCtrl => cellCtrl.getCellRenderer())\n .filter(renderer => renderer != null);\n if ((_a = params.columns) === null || _a === void 0 ? void 0 : _a.length) {\n return cellRenderers;\n }\n const fullWidthRenderers = [];\n const rowIdMap = this.mapRowNodes(params.rowNodes);\n this.getAllRowCtrls().forEach(rowCtrl => {\n if (rowIdMap && !this.isRowInMap(rowCtrl.getRowNode(), rowIdMap)) {\n return;\n }\n if (!rowCtrl.isFullWidth()) {\n return;\n }\n const fullWidthRenderer = rowCtrl.getFullWidthCellRenderer();\n if (fullWidthRenderer) {\n fullWidthRenderers.push(fullWidthRenderer);\n }\n });\n return [...fullWidthRenderers, ...cellRenderers];\n }\n getCellEditorInstances(params) {\n const res = [];\n this.getCellCtrls(params.rowNodes, params.columns).forEach(cellCtrl => {\n const cellEditor = cellCtrl.getCellEditor();\n if (cellEditor) {\n res.push(cellEditor);\n }\n });\n return res;\n }\n getEditingCells() {\n const res = [];\n this.getAllCellCtrls().forEach(cellCtrl => {\n if (cellCtrl.isEditing()) {\n const cellPosition = cellCtrl.getCellPosition();\n res.push(cellPosition);\n }\n });\n return res;\n }\n mapRowNodes(rowNodes) {\n if (!rowNodes) {\n return;\n }\n const res = {\n top: {},\n bottom: {},\n normal: {}\n };\n rowNodes.forEach(rowNode => {\n const id = rowNode.id;\n if (rowNode.rowPinned === 'top') {\n res.top[id] = rowNode;\n }\n else if (rowNode.rowPinned === 'bottom') {\n res.bottom[id] = rowNode;\n }\n else {\n res.normal[id] = rowNode;\n }\n });\n return res;\n }\n isRowInMap(rowNode, rowIdsMap) {\n // skip this row if it is missing from the provided list\n const id = rowNode.id;\n const floating = rowNode.rowPinned;\n if (floating === 'bottom') {\n return rowIdsMap.bottom[id] != null;\n }\n if (floating === 'top') {\n return rowIdsMap.top[id] != null;\n }\n return rowIdsMap.normal[id] != null;\n }\n /**\n * @param rowNodes if provided, returns the RowCtrls for the provided rowNodes. otherwise returns all RowCtrls.\n */\n getRowCtrls(rowNodes) {\n const rowIdsMap = this.mapRowNodes(rowNodes);\n const allRowCtrls = this.getAllRowCtrls();\n if (!rowNodes || !rowIdsMap) {\n return allRowCtrls;\n }\n return allRowCtrls.filter(rowCtrl => {\n const rowNode = rowCtrl.getRowNode();\n return this.isRowInMap(rowNode, rowIdsMap);\n });\n }\n // returns CellCtrl's that match the provided rowNodes and columns. eg if one row node\n // and two columns provided, that identifies 4 cells, so 4 CellCtrl's returned.\n getCellCtrls(rowNodes, columns) {\n let colIdsMap;\n if (exists(columns)) {\n colIdsMap = {};\n columns.forEach((colKey) => {\n const column = this.columnModel.getGridColumn(colKey);\n if (exists(column)) {\n colIdsMap[column.getId()] = true;\n }\n });\n }\n const res = [];\n this.getRowCtrls(rowNodes).forEach(rowCtrl => {\n rowCtrl.getAllCellCtrls().forEach(cellCtrl => {\n const colId = cellCtrl.getColumn().getId();\n const excludeColFromRefresh = colIdsMap && !colIdsMap[colId];\n if (excludeColFromRefresh) {\n return;\n }\n res.push(cellCtrl);\n });\n });\n return res;\n }\n destroy() {\n this.removeAllRowComps();\n super.destroy();\n }\n removeAllRowComps() {\n const rowIndexesToRemove = Object.keys(this.rowCtrlsByRowIndex);\n this.removeRowCtrls(rowIndexesToRemove);\n }\n getRowsToRecycle() {\n // remove all stub nodes, they can't be reused, as no rowNode id\n const stubNodeIndexes = [];\n iterateObject(this.rowCtrlsByRowIndex, (index, rowComp) => {\n const stubNode = rowComp.getRowNode().id == null;\n if (stubNode) {\n stubNodeIndexes.push(index);\n }\n });\n this.removeRowCtrls(stubNodeIndexes);\n // then clear out rowCompsByIndex, but before that take a copy, but index by id, not rowIndex\n const ctrlsByIdMap = {};\n iterateObject(this.rowCtrlsByRowIndex, (index, rowComp) => {\n const rowNode = rowComp.getRowNode();\n ctrlsByIdMap[rowNode.id] = rowComp;\n });\n this.rowCtrlsByRowIndex = {};\n return ctrlsByIdMap;\n }\n // takes array of row indexes\n removeRowCtrls(rowsToRemove) {\n // if no fromIndex then set to -1, which will refresh everything\n // let realFromIndex = -1;\n rowsToRemove.forEach(indexToRemove => {\n const rowCtrl = this.rowCtrlsByRowIndex[indexToRemove];\n if (rowCtrl) {\n rowCtrl.destroyFirstPass();\n rowCtrl.destroySecondPass();\n }\n delete this.rowCtrlsByRowIndex[indexToRemove];\n });\n }\n onBodyScroll(e) {\n if (e.direction !== 'vertical') {\n return;\n }\n this.redraw({ afterScroll: true });\n }\n // gets called when rows don't change, but viewport does, so after:\n // 1) height of grid body changes, ie number of displayed rows has changed\n // 2) grid scrolled to new position\n // 3) ensure index visible (which is a scroll)\n redraw(params = {}) {\n const { afterScroll } = params;\n let cellFocused;\n // only try to refocus cells shifting in and out of sticky container\n // if the browser supports focus ({ preventScroll })\n if (this.stickyRowFeature && browserSupportsPreventScroll()) {\n cellFocused = this.getCellToRestoreFocusToAfterRefresh() || undefined;\n }\n const oldFirstRow = this.firstRenderedRow;\n const oldLastRow = this.lastRenderedRow;\n this.workOutFirstAndLastRowsToRender();\n let hasStickyRowChanges = false;\n if (this.stickyRowFeature) {\n hasStickyRowChanges = this.stickyRowFeature.checkStickyRows();\n }\n const rangeChanged = this.firstRenderedRow !== oldFirstRow || this.lastRenderedRow !== oldLastRow;\n if (afterScroll && !hasStickyRowChanges && !rangeChanged) {\n return;\n }\n this.getLockOnRefresh();\n this.recycleRows(null, false, afterScroll);\n this.releaseLockOnRefresh();\n this.dispatchDisplayedRowsChanged(afterScroll);\n if (cellFocused != null) {\n const newFocusedCell = this.getCellToRestoreFocusToAfterRefresh();\n if (cellFocused != null && newFocusedCell == null) {\n this.animationFrameService.flushAllFrames();\n this.restoreFocusedCell(cellFocused);\n }\n }\n }\n removeRowCompsNotToDraw(indexesToDraw) {\n // for speedy lookup, dump into map\n const indexesToDrawMap = {};\n indexesToDraw.forEach(index => (indexesToDrawMap[index] = true));\n const existingIndexes = Object.keys(this.rowCtrlsByRowIndex);\n const indexesNotToDraw = existingIndexes.filter(index => !indexesToDrawMap[index]);\n this.removeRowCtrls(indexesNotToDraw);\n }\n calculateIndexesToDraw(rowsToRecycle) {\n // all in all indexes in the viewport\n let indexesToDraw = createArrayOfNumbers(this.firstRenderedRow, this.lastRenderedRow);\n const checkRowToDraw = (indexStr, rowComp) => {\n const index = rowComp.getRowNode().rowIndex;\n if (index == null) {\n return;\n }\n if (index < this.firstRenderedRow || index > this.lastRenderedRow) {\n if (this.doNotUnVirtualiseRow(rowComp)) {\n indexesToDraw.push(index);\n }\n }\n };\n // if we are redrawing due to scrolling change, then old rows are in this.rowCompsByIndex\n iterateObject(this.rowCtrlsByRowIndex, checkRowToDraw);\n // if we are redrawing due to model update, then old rows are in rowsToRecycle\n iterateObject(rowsToRecycle, checkRowToDraw);\n indexesToDraw.sort((a, b) => a - b);\n const ret = [];\n for (let i = 0; i < indexesToDraw.length; i++) {\n const currRow = indexesToDraw[i];\n const rowNode = this.paginationProxy.getRow(currRow);\n if (rowNode && !rowNode.sticky) {\n ret.push(currRow);\n }\n }\n return ret;\n }\n recycleRows(rowsToRecycle, animate = false, afterScroll = false) {\n // the row can already exist and be in the following:\n // rowsToRecycle -> if model change, then the index may be different, however row may\n // exist here from previous time (mapped by id).\n // this.rowCompsByIndex -> if just a scroll, then this will contain what is currently in the viewport\n // this is all the indexes we want, including those that already exist, so this method\n // will end up going through each index and drawing only if the row doesn't already exist\n const indexesToDraw = this.calculateIndexesToDraw(rowsToRecycle);\n this.removeRowCompsNotToDraw(indexesToDraw);\n // never animate when doing print layout - as we want to get things ready to print as quickly as possible,\n // otherwise we risk the printer printing a row that's half faded (half way through fading in)\n if (this.printLayout) {\n animate = false;\n }\n // add in new rows\n const rowCtrls = [];\n indexesToDraw.forEach(rowIndex => {\n const rowCtrl = this.createOrUpdateRowCtrl(rowIndex, rowsToRecycle, animate, afterScroll);\n if (exists(rowCtrl)) {\n rowCtrls.push(rowCtrl);\n }\n });\n if (rowsToRecycle) {\n const useAnimationFrame = afterScroll && !this.gridOptionsService.is('suppressAnimationFrame') && !this.printLayout;\n if (useAnimationFrame) {\n this.beans.animationFrameService.addDestroyTask(() => {\n this.destroyRowCtrls(rowsToRecycle, animate);\n this.updateAllRowCtrls();\n this.dispatchDisplayedRowsChanged();\n });\n }\n else {\n this.destroyRowCtrls(rowsToRecycle, animate);\n }\n }\n this.updateAllRowCtrls();\n }\n dispatchDisplayedRowsChanged(afterScroll = false) {\n const event = { type: Events.EVENT_DISPLAYED_ROWS_CHANGED, afterScroll };\n this.eventService.dispatchEvent(event);\n }\n onDisplayedColumnsChanged() {\n const pinningLeft = this.columnModel.isPinningLeft();\n const pinningRight = this.columnModel.isPinningRight();\n const atLeastOneChanged = this.pinningLeft !== pinningLeft || pinningRight !== this.pinningRight;\n if (atLeastOneChanged) {\n this.pinningLeft = pinningLeft;\n this.pinningRight = pinningRight;\n if (this.embedFullWidthRows) {\n this.redrawFullWidthEmbeddedRows();\n }\n }\n }\n // when embedding, what gets showed in each section depends on what is pinned. eg if embedding group expand / collapse,\n // then it should go into the pinned left area if pinning left, or the center area if not pinning.\n redrawFullWidthEmbeddedRows() {\n // if either of the pinned panels has shown / hidden, then need to redraw the fullWidth bits when\n // embedded, as what appears in each section depends on whether we are pinned or not\n const rowsToRemove = [];\n this.getFullWidthRowCtrls().forEach(fullWidthCtrl => {\n const rowIndex = fullWidthCtrl.getRowNode().rowIndex;\n rowsToRemove.push(rowIndex.toString());\n });\n this.refreshFloatingRowComps();\n this.removeRowCtrls(rowsToRemove);\n this.redraw({ afterScroll: true });\n }\n getFullWidthRowCtrls(rowNodes) {\n const rowNodesMap = this.mapRowNodes(rowNodes);\n return this.getAllRowCtrls().filter((rowCtrl) => {\n // include just full width\n if (!rowCtrl.isFullWidth()) {\n return false;\n }\n // if Row Nodes provided, we exclude where Row Node is missing\n const rowNode = rowCtrl.getRowNode();\n if (rowNodesMap != null && !this.isRowInMap(rowNode, rowNodesMap)) {\n return false;\n }\n return true;\n });\n }\n createOrUpdateRowCtrl(rowIndex, rowsToRecycle, animate, afterScroll) {\n let rowNode;\n let rowCtrl = this.rowCtrlsByRowIndex[rowIndex];\n // if no row comp, see if we can get it from the previous rowComps\n if (!rowCtrl) {\n rowNode = this.paginationProxy.getRow(rowIndex);\n if (exists(rowNode) && exists(rowsToRecycle) && rowsToRecycle[rowNode.id] && rowNode.alreadyRendered) {\n rowCtrl = rowsToRecycle[rowNode.id];\n rowsToRecycle[rowNode.id] = null;\n }\n }\n const creatingNewRowCtrl = !rowCtrl;\n if (creatingNewRowCtrl) {\n // create a new one\n if (!rowNode) {\n rowNode = this.paginationProxy.getRow(rowIndex);\n }\n if (exists(rowNode)) {\n rowCtrl = this.createRowCon(rowNode, animate, afterScroll);\n }\n else {\n // this should never happen - if somehow we are trying to create\n // a row for a rowNode that does not exist.\n return;\n }\n }\n if (rowNode) {\n // set node as 'alreadyRendered' to ensure we only recycle rowComps that have been rendered, this ensures\n // we don't reuse rowComps that have been removed and then re-added in the same batch transaction.\n rowNode.alreadyRendered = true;\n }\n this.rowCtrlsByRowIndex[rowIndex] = rowCtrl;\n return rowCtrl;\n }\n destroyRowCtrls(rowCtrlsMap, animate) {\n const executeInAWhileFuncs = [];\n iterateObject(rowCtrlsMap, (nodeId, rowCtrl) => {\n // if row was used, then it's null\n if (!rowCtrl) {\n return;\n }\n if (this.cachedRowCtrls && rowCtrl.isCacheable()) {\n this.cachedRowCtrls.addRow(rowCtrl);\n return;\n }\n rowCtrl.destroyFirstPass();\n if (animate) {\n this.zombieRowCtrls[rowCtrl.getInstanceId()] = rowCtrl;\n executeInAWhileFuncs.push(() => {\n rowCtrl.destroySecondPass();\n delete this.zombieRowCtrls[rowCtrl.getInstanceId()];\n });\n }\n else {\n rowCtrl.destroySecondPass();\n }\n });\n if (animate) {\n // this ensures we fire displayedRowsChanged AFTER all the 'executeInAWhileFuncs' get\n // executed, as we added it to the end of the list.\n executeInAWhileFuncs.push(() => {\n this.updateAllRowCtrls();\n this.dispatchDisplayedRowsChanged();\n });\n executeInAWhile(executeInAWhileFuncs);\n }\n }\n getRowBuffer() {\n let rowBuffer = this.gridOptionsService.getNum('rowBuffer');\n if (typeof rowBuffer === 'number') {\n if (rowBuffer < 0) {\n doOnce(() => console.warn(`AG Grid: rowBuffer should not be negative`), 'warn rowBuffer negative');\n rowBuffer = 0;\n this.gridOptionsService.set('rowBuffer', 0);\n }\n }\n else {\n rowBuffer = 10;\n }\n return rowBuffer;\n }\n getRowBufferInPixels() {\n const rowsToBuffer = this.getRowBuffer();\n const defaultRowHeight = this.gridOptionsService.getRowHeightAsNumber();\n return rowsToBuffer * defaultRowHeight;\n }\n workOutFirstAndLastRowsToRender() {\n this.rowContainerHeightService.updateOffset();\n let newFirst;\n let newLast;\n if (!this.paginationProxy.isRowsToRender()) {\n newFirst = 0;\n newLast = -1; // setting to -1 means nothing in range\n }\n else if (this.printLayout) {\n this.environment.refreshRowHeightVariable();\n newFirst = this.paginationProxy.getPageFirstRow();\n newLast = this.paginationProxy.getPageLastRow();\n }\n else {\n const bufferPixels = this.getRowBufferInPixels();\n const gridBodyCtrl = this.ctrlsService.getGridBodyCtrl();\n const suppressRowVirtualisation = this.gridOptionsService.is('suppressRowVirtualisation');\n let rowHeightsChanged = false;\n let firstPixel;\n let lastPixel;\n do {\n const paginationOffset = this.paginationProxy.getPixelOffset();\n const { pageFirstPixel, pageLastPixel } = this.paginationProxy.getCurrentPagePixelRange();\n const divStretchOffset = this.rowContainerHeightService.getDivStretchOffset();\n const bodyVRange = gridBodyCtrl.getScrollFeature().getVScrollPosition();\n const bodyTopPixel = bodyVRange.top;\n const bodyBottomPixel = bodyVRange.bottom;\n if (suppressRowVirtualisation) {\n firstPixel = pageFirstPixel + divStretchOffset;\n lastPixel = pageLastPixel + divStretchOffset;\n }\n else {\n firstPixel = Math.max(bodyTopPixel + paginationOffset - bufferPixels, pageFirstPixel) + divStretchOffset;\n lastPixel = Math.min(bodyBottomPixel + paginationOffset + bufferPixels, pageLastPixel) + divStretchOffset;\n }\n this.firstVisibleVPixel = Math.max(bodyTopPixel + paginationOffset, pageFirstPixel) + divStretchOffset;\n // if the rows we are about to display get their heights changed, then that upsets the calcs from above.\n rowHeightsChanged = this.ensureAllRowsInRangeHaveHeightsCalculated(firstPixel, lastPixel);\n } while (rowHeightsChanged);\n let firstRowIndex = this.paginationProxy.getRowIndexAtPixel(firstPixel);\n let lastRowIndex = this.paginationProxy.getRowIndexAtPixel(lastPixel);\n const pageFirstRow = this.paginationProxy.getPageFirstRow();\n const pageLastRow = this.paginationProxy.getPageLastRow();\n // adjust, in case buffer extended actual size\n if (firstRowIndex < pageFirstRow) {\n firstRowIndex = pageFirstRow;\n }\n if (lastRowIndex > pageLastRow) {\n lastRowIndex = pageLastRow;\n }\n newFirst = firstRowIndex;\n newLast = lastRowIndex;\n }\n // sometimes user doesn't set CSS right and ends up with grid with no height and grid ends up\n // trying to render all the rows, eg 10,000+ rows. this will kill the browser. so instead of\n // killing the browser, we limit the number of rows. just in case some use case we didn't think\n // of, we also have a property to not do this operation.\n const rowLayoutNormal = this.gridOptionsService.isDomLayout('normal');\n const suppressRowCountRestriction = this.gridOptionsService.is('suppressMaxRenderedRowRestriction');\n const rowBufferMaxSize = Math.max(this.getRowBuffer(), 500);\n if (rowLayoutNormal && !suppressRowCountRestriction) {\n if (newLast - newFirst > rowBufferMaxSize) {\n newLast = newFirst + rowBufferMaxSize;\n }\n }\n const firstDiffers = newFirst !== this.firstRenderedRow;\n const lastDiffers = newLast !== this.lastRenderedRow;\n if (firstDiffers || lastDiffers) {\n this.firstRenderedRow = newFirst;\n this.lastRenderedRow = newLast;\n const event = {\n type: Events.EVENT_VIEWPORT_CHANGED,\n firstRow: newFirst,\n lastRow: newLast\n };\n this.eventService.dispatchEvent(event);\n }\n }\n /**\n * This event will only be fired once, and is queued until after the browser next renders.\n * This allows us to fire an event during the start of the render cycle, when we first see data being rendered\n * but not execute the event until all of the data has finished being rendered to the dom.\n */\n dispatchFirstDataRenderedEvent() {\n if (this.dataFirstRenderedFired) {\n return;\n }\n this.dataFirstRenderedFired = true;\n const event = {\n type: Events.EVENT_FIRST_DATA_RENDERED,\n firstRow: this.firstRenderedRow,\n lastRow: this.lastRenderedRow,\n };\n // See AG-7018\n window.requestAnimationFrame(() => {\n this.beans.eventService.dispatchEvent(event);\n });\n }\n ensureAllRowsInRangeHaveHeightsCalculated(topPixel, bottomPixel) {\n // ensureRowHeightsVisible only works with CSRM, as it's the only row model that allows lazy row height calcs.\n // all the other row models just hard code so the method just returns back false\n const res = this.paginationProxy.ensureRowHeightsValid(topPixel, bottomPixel, -1, -1);\n if (res) {\n this.updateContainerHeights();\n }\n return res;\n }\n getFirstVisibleVerticalPixel() {\n return this.firstVisibleVPixel;\n }\n getFirstVirtualRenderedRow() {\n return this.firstRenderedRow;\n }\n getLastVirtualRenderedRow() {\n return this.lastRenderedRow;\n }\n // check that none of the rows to remove are editing or focused as:\n // a) if editing, we want to keep them, otherwise the user will loose the context of the edit,\n // eg user starts editing, enters some text, then scrolls down and then up, next time row rendered\n // the edit is reset - so we want to keep it rendered.\n // b) if focused, we want ot keep keyboard focus, so if user ctrl+c, it goes to clipboard,\n // otherwise the user can range select and drag (with focus cell going out of the viewport)\n // and then ctrl+c, nothing will happen if cell is removed from dom.\n // c) if detail record of master detail, as users complained that the context of detail rows\n // was getting lost when detail row out of view. eg user expands to show detail row,\n // then manipulates the detail panel (eg sorts the detail grid), then context is lost\n // after detail panel is scrolled out of / into view.\n doNotUnVirtualiseRow(rowComp) {\n const REMOVE_ROW = false;\n const KEEP_ROW = true;\n const rowNode = rowComp.getRowNode();\n const rowHasFocus = this.focusService.isRowNodeFocused(rowNode);\n const rowIsEditing = rowComp.isEditing();\n const rowIsDetail = rowNode.detail;\n const mightWantToKeepRow = rowHasFocus || rowIsEditing || rowIsDetail;\n // if we deffo don't want to keep it,\n if (!mightWantToKeepRow) {\n return REMOVE_ROW;\n }\n // editing row, only remove if it is no longer rendered, eg filtered out or new data set.\n // the reason we want to keep is if user is scrolling up and down, we don't want to loose\n // the context of the editing in process.\n const rowNodePresent = this.paginationProxy.isRowPresent(rowNode);\n return rowNodePresent ? KEEP_ROW : REMOVE_ROW;\n }\n createRowCon(rowNode, animate, afterScroll) {\n const rowCtrlFromCache = this.cachedRowCtrls ? this.cachedRowCtrls.getRow(rowNode) : null;\n if (rowCtrlFromCache) {\n return rowCtrlFromCache;\n }\n // we don't use animations frames for printing, so the user can put the grid into print mode\n // and immediately print - otherwise the user would have to wait for the rows to draw in the background\n // (via the animation frames) which is awkward to do from code.\n // we only do the animation frames after scrolling, as this is where we want the smooth user experience.\n // having animation frames for other times makes the grid look 'jumpy'.\n const suppressAnimationFrame = this.gridOptionsService.is('suppressAnimationFrame');\n const useAnimationFrameForCreate = afterScroll && !suppressAnimationFrame && !this.printLayout;\n const res = new RowCtrl(rowNode, this.beans, animate, useAnimationFrameForCreate, this.printLayout);\n return res;\n }\n getRenderedNodes() {\n const renderedRows = this.rowCtrlsByRowIndex;\n return Object.keys(renderedRows).map(key => renderedRows[key].getRowNode());\n }\n getRowByPosition(rowPosition) {\n let rowCtrl;\n const { rowIndex } = rowPosition;\n switch (rowPosition.rowPinned) {\n case 'top':\n rowCtrl = this.topRowCtrls[rowIndex];\n break;\n case 'bottom':\n rowCtrl = this.bottomRowCtrls[rowIndex];\n break;\n default:\n rowCtrl = this.rowCtrlsByRowIndex[rowIndex];\n if (!rowCtrl) {\n rowCtrl = this.getStickyTopRowCtrls().find(ctrl => ctrl.getRowNode().rowIndex === rowIndex) || null;\n }\n break;\n }\n return rowCtrl;\n }\n getRowNode(gridRow) {\n switch (gridRow.rowPinned) {\n case 'top':\n return this.pinnedRowModel.getPinnedTopRowData()[gridRow.rowIndex];\n case 'bottom':\n return this.pinnedRowModel.getPinnedBottomRowData()[gridRow.rowIndex];\n default:\n return this.rowModel.getRow(gridRow.rowIndex);\n }\n }\n // returns true if any row between startIndex and endIndex is rendered. used by\n // SSRM or IRM, as they don't want to purge visible blocks from cache.\n isRangeInRenderedViewport(startIndex, endIndex) {\n // parent closed means the parent node is not expanded, thus these blocks are not visible\n const parentClosed = startIndex == null || endIndex == null;\n if (parentClosed) {\n return false;\n }\n const blockAfterViewport = startIndex > this.lastRenderedRow;\n const blockBeforeViewport = endIndex < this.firstRenderedRow;\n const blockInsideViewport = !blockBeforeViewport && !blockAfterViewport;\n return blockInsideViewport;\n }\n};\n__decorate([\n Autowired(\"animationFrameService\")\n], RowRenderer.prototype, \"animationFrameService\", void 0);\n__decorate([\n Autowired(\"paginationProxy\")\n], RowRenderer.prototype, \"paginationProxy\", void 0);\n__decorate([\n Autowired(\"columnModel\")\n], RowRenderer.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired(\"pinnedRowModel\")\n], RowRenderer.prototype, \"pinnedRowModel\", void 0);\n__decorate([\n Autowired(\"rowModel\")\n], RowRenderer.prototype, \"rowModel\", void 0);\n__decorate([\n Autowired(\"focusService\")\n], RowRenderer.prototype, \"focusService\", void 0);\n__decorate([\n Autowired(\"beans\")\n], RowRenderer.prototype, \"beans\", void 0);\n__decorate([\n Autowired(\"rowContainerHeightService\")\n], RowRenderer.prototype, \"rowContainerHeightService\", void 0);\n__decorate([\n Autowired(\"ctrlsService\")\n], RowRenderer.prototype, \"ctrlsService\", void 0);\n__decorate([\n PostConstruct\n], RowRenderer.prototype, \"postConstruct\", null);\nRowRenderer = __decorate([\n Bean(\"rowRenderer\")\n], RowRenderer);\nexport { RowRenderer };\nclass RowCtrlCache {\n constructor(maxCount) {\n // map for fast access\n this.entriesMap = {};\n // list for keeping order\n this.entriesList = [];\n this.maxCount = maxCount;\n }\n addRow(rowCtrl) {\n this.entriesMap[rowCtrl.getRowNode().id] = rowCtrl;\n this.entriesList.push(rowCtrl);\n rowCtrl.setCached(true);\n if (this.entriesList.length > this.maxCount) {\n const rowCtrlToDestroy = this.entriesList[0];\n rowCtrlToDestroy.destroyFirstPass();\n rowCtrlToDestroy.destroySecondPass();\n this.removeFromCache(rowCtrlToDestroy);\n }\n }\n getRow(rowNode) {\n if (rowNode == null || rowNode.id == null) {\n return null;\n }\n const res = this.entriesMap[rowNode.id];\n if (!res) {\n return null;\n }\n this.removeFromCache(res);\n res.setCached(false);\n // this can happen if user reloads data, and a new RowNode is reusing\n // the same ID as the old one\n const rowNodeMismatch = res.getRowNode() != rowNode;\n return rowNodeMismatch ? null : res;\n }\n removeFromCache(rowCtrl) {\n const rowNodeId = rowCtrl.getRowNode().id;\n delete this.entriesMap[rowNodeId];\n removeFromArray(this.entriesList, rowCtrl);\n }\n getEntries() {\n return this.entriesList;\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean, Autowired } from '../context/context.mjs';\nimport { BeanStub } from \"../context/beanStub.mjs\";\nlet ValueFormatterService = class ValueFormatterService extends BeanStub {\n formatValue(column, node, value, suppliedFormatter, useFormatterFromColumn = true) {\n let result = null;\n let formatter;\n const colDef = column.getColDef();\n if (suppliedFormatter) {\n // use supplied formatter if provided, e.g. set filter items can have their own value formatters\n formatter = suppliedFormatter;\n }\n else if (useFormatterFromColumn) {\n formatter = colDef.valueFormatter;\n }\n if (formatter) {\n const params = {\n value,\n node,\n data: node ? node.data : null,\n colDef,\n column,\n api: this.gridOptionsService.api,\n columnApi: this.gridOptionsService.columnApi,\n context: this.gridOptionsService.context\n };\n if (typeof formatter === 'function') {\n result = formatter(params);\n }\n else {\n result = this.expressionService.evaluate(formatter, params);\n }\n }\n else if (colDef.refData) {\n return colDef.refData[value] || '';\n }\n // if we don't do this, then arrays get displayed as 1,2,3, but we want 1, 2, 3 (i.e. with spaces)\n if (result == null && Array.isArray(value)) {\n result = value.join(', ');\n }\n return result;\n }\n};\n__decorate([\n Autowired('expressionService')\n], ValueFormatterService.prototype, \"expressionService\", void 0);\nValueFormatterService = __decorate([\n Bean('valueFormatterService')\n], ValueFormatterService);\nexport { ValueFormatterService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { RowNode } from \"../entities/rowNode.mjs\";\nimport { Autowired, Bean, PostConstruct } from \"../context/context.mjs\";\nimport { Events } from \"../events.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { missingOrEmpty } from \"../utils/generic.mjs\";\nimport { last } from \"../utils/array.mjs\";\nlet PinnedRowModel = class PinnedRowModel extends BeanStub {\n init() {\n this.setPinnedTopRowData(this.gridOptionsService.get('pinnedTopRowData'));\n this.setPinnedBottomRowData(this.gridOptionsService.get('pinnedBottomRowData'));\n }\n isEmpty(floating) {\n const rows = floating === 'top' ? this.pinnedTopRows : this.pinnedBottomRows;\n return missingOrEmpty(rows);\n }\n isRowsToRender(floating) {\n return !this.isEmpty(floating);\n }\n getRowAtPixel(pixel, floating) {\n const rows = floating === 'top' ? this.pinnedTopRows : this.pinnedBottomRows;\n if (missingOrEmpty(rows)) {\n return 0; // this should never happen, just in case, 0 is graceful failure\n }\n for (let i = 0; i < rows.length; i++) {\n const rowNode = rows[i];\n const rowTopPixel = rowNode.rowTop + rowNode.rowHeight - 1;\n // only need to range check against the top pixel, as we are going through the list\n // in order, first row to hit the pixel wins\n if (rowTopPixel >= pixel) {\n return i;\n }\n }\n return rows.length - 1;\n }\n setPinnedTopRowData(rowData) {\n this.pinnedTopRows = this.createNodesFromData(rowData, true);\n const event = {\n type: Events.EVENT_PINNED_ROW_DATA_CHANGED\n };\n this.eventService.dispatchEvent(event);\n }\n setPinnedBottomRowData(rowData) {\n this.pinnedBottomRows = this.createNodesFromData(rowData, false);\n const event = {\n type: Events.EVENT_PINNED_ROW_DATA_CHANGED\n };\n this.eventService.dispatchEvent(event);\n }\n createNodesFromData(allData, isTop) {\n const rowNodes = [];\n if (allData) {\n let nextRowTop = 0;\n allData.forEach((dataItem, index) => {\n const rowNode = new RowNode(this.beans);\n rowNode.data = dataItem;\n const idPrefix = isTop ? RowNode.ID_PREFIX_TOP_PINNED : RowNode.ID_PREFIX_BOTTOM_PINNED;\n rowNode.id = idPrefix + index;\n rowNode.rowPinned = isTop ? 'top' : 'bottom';\n rowNode.setRowTop(nextRowTop);\n rowNode.setRowHeight(this.gridOptionsService.getRowHeightForNode(rowNode).height);\n rowNode.setRowIndex(index);\n nextRowTop += rowNode.rowHeight;\n rowNodes.push(rowNode);\n });\n }\n return rowNodes;\n }\n getPinnedTopRowData() {\n return this.pinnedTopRows;\n }\n getPinnedBottomRowData() {\n return this.pinnedBottomRows;\n }\n getPinnedTopTotalHeight() {\n return this.getTotalHeight(this.pinnedTopRows);\n }\n getPinnedTopRowCount() {\n return this.pinnedTopRows ? this.pinnedTopRows.length : 0;\n }\n getPinnedBottomRowCount() {\n return this.pinnedBottomRows ? this.pinnedBottomRows.length : 0;\n }\n getPinnedTopRow(index) {\n return this.pinnedTopRows[index];\n }\n getPinnedBottomRow(index) {\n return this.pinnedBottomRows[index];\n }\n forEachPinnedTopRow(callback) {\n if (missingOrEmpty(this.pinnedTopRows)) {\n return;\n }\n this.pinnedTopRows.forEach(callback);\n }\n forEachPinnedBottomRow(callback) {\n if (missingOrEmpty(this.pinnedBottomRows)) {\n return;\n }\n this.pinnedBottomRows.forEach(callback);\n }\n getPinnedBottomTotalHeight() {\n return this.getTotalHeight(this.pinnedBottomRows);\n }\n getTotalHeight(rowNodes) {\n if (!rowNodes || rowNodes.length === 0) {\n return 0;\n }\n const lastNode = last(rowNodes);\n return lastNode.rowTop + lastNode.rowHeight;\n }\n};\n__decorate([\n Autowired('beans')\n], PinnedRowModel.prototype, \"beans\", void 0);\n__decorate([\n PostConstruct\n], PinnedRowModel.prototype, \"init\", null);\nPinnedRowModel = __decorate([\n Bean('pinnedRowModel')\n], PinnedRowModel);\nexport { PinnedRowModel };\n","export var ServerSideTransactionResultStatus;\n(function (ServerSideTransactionResultStatus) {\n /** Transaction was successfully applied */\n ServerSideTransactionResultStatus[\"Applied\"] = \"Applied\";\n /**\n * Store was not found, transaction not applied.\n * Either invalid route, or the parent row has not yet been expanded.\n */\n ServerSideTransactionResultStatus[\"StoreNotFound\"] = \"StoreNotFound\";\n /**\n * Store is loading, transaction not applied.\n */\n ServerSideTransactionResultStatus[\"StoreLoading\"] = \"StoreLoading\";\n /**\n * Store is loading (as max loads exceeded), transaction not applied.\n */\n ServerSideTransactionResultStatus[\"StoreWaitingToLoad\"] = \"StoreWaitingToLoad\";\n /**\n * Store load attempt failed, transaction not applied.\n */\n ServerSideTransactionResultStatus[\"StoreLoadingFailed\"] = \"StoreLoadingFailed\";\n /**\n * Store is type Partial, which doesn't accept transactions\n */\n ServerSideTransactionResultStatus[\"StoreWrongType\"] = \"StoreWrongType\";\n /**\n * Transaction was cancelled, due to grid.\n * Callback isApplyServerSideTransaction() returning false\n */\n ServerSideTransactionResultStatus[\"Cancelled\"] = \"Cancelled\";\n})(ServerSideTransactionResultStatus || (ServerSideTransactionResultStatus = {}));\n","// when doing transactions, or change detection, and grouping is present\n// in the data, there is no need for the ClientSideRowModel to update each\n// group after an update, ony parts that were impacted by the change.\n// this class keeps track of all groups that were impacted by a transaction.\n// the the different CSRM operations (filter, sort etc) use the forEach method\n// to visit each group that was changed.\nexport class ChangedPath {\n constructor(keepingColumns, rootNode) {\n // whether changed path is active of not. it is active when a) doing\n // a transaction update or b) doing change detection. if we are doing\n // a CSRM refresh for other reasons (after sort or filter, or user calling\n // setRowData() without delta mode) then we are not active. we are also\n // marked as not active if secondary columns change in pivot (as this impacts\n // aggregations)\n this.active = true;\n // for each node in the change path, we also store which columns need\n // to be re-aggregated.\n this.nodeIdsToColumns = {};\n // for quick lookup, all items in the change path are mapped by nodeId\n this.mapToItems = {};\n this.keepingColumns = keepingColumns;\n this.pathRoot = {\n rowNode: rootNode,\n children: null\n };\n this.mapToItems[rootNode.id] = this.pathRoot;\n }\n // can be set inactive by:\n // a) ClientSideRowModel, if no transactions or\n // b) PivotService, if secondary columns changed\n setInactive() {\n this.active = false;\n }\n isActive() {\n return this.active;\n }\n depthFirstSearchChangedPath(pathItem, callback) {\n if (pathItem.children) {\n for (let i = 0; i < pathItem.children.length; i++) {\n this.depthFirstSearchChangedPath(pathItem.children[i], callback);\n }\n }\n callback(pathItem.rowNode);\n }\n depthFirstSearchEverything(rowNode, callback, traverseEverything) {\n if (rowNode.childrenAfterGroup) {\n for (let i = 0; i < rowNode.childrenAfterGroup.length; i++) {\n const childNode = rowNode.childrenAfterGroup[i];\n if (childNode.childrenAfterGroup) {\n this.depthFirstSearchEverything(rowNode.childrenAfterGroup[i], callback, traverseEverything);\n }\n else if (traverseEverything) {\n callback(childNode);\n }\n }\n }\n callback(rowNode);\n }\n // traverseLeafNodes -> used when NOT doing changed path, ie traversing everything. the callback\n // will be called for child nodes in addition to parent nodes.\n forEachChangedNodeDepthFirst(callback, traverseLeafNodes = false, includeUnchangedNodes = false) {\n if (this.active && !includeUnchangedNodes) {\n // if we are active, then use the change path to callback\n // only for updated groups\n this.depthFirstSearchChangedPath(this.pathRoot, callback);\n }\n else {\n // we are not active, so callback for everything, walk the entire path\n this.depthFirstSearchEverything(this.pathRoot.rowNode, callback, traverseLeafNodes);\n }\n }\n executeFromRootNode(callback) {\n callback(this.pathRoot.rowNode);\n }\n createPathItems(rowNode) {\n let pointer = rowNode;\n let newEntryCount = 0;\n while (!this.mapToItems[pointer.id]) {\n const newEntry = {\n rowNode: pointer,\n children: null\n };\n this.mapToItems[pointer.id] = newEntry;\n newEntryCount++;\n pointer = pointer.parent;\n }\n return newEntryCount;\n }\n populateColumnsMap(rowNode, columns) {\n if (!this.keepingColumns || !columns) {\n return;\n }\n let pointer = rowNode;\n while (pointer) {\n // if columns, add the columns in all the way to parent, merging\n // in any other columns that might be there already\n if (!this.nodeIdsToColumns[pointer.id]) {\n this.nodeIdsToColumns[pointer.id] = {};\n }\n columns.forEach(col => this.nodeIdsToColumns[pointer.id][col.getId()] = true);\n pointer = pointer.parent;\n }\n }\n linkPathItems(rowNode, newEntryCount) {\n let pointer = rowNode;\n for (let i = 0; i < newEntryCount; i++) {\n const thisItem = this.mapToItems[pointer.id];\n const parentItem = this.mapToItems[pointer.parent.id];\n if (!parentItem.children) {\n parentItem.children = [];\n }\n parentItem.children.push(thisItem);\n pointer = pointer.parent;\n }\n }\n // called by\n // 1) change detection (provides cols) and\n // 2) groupStage if doing transaction update (doesn't provide cols)\n addParentNode(rowNode, columns) {\n if (!rowNode || rowNode.isRowPinned()) {\n return;\n }\n // we cannot do both steps below in the same loop as\n // the second loop has a dependency on the first loop.\n // ie the hierarchy cannot be stitched up yet because\n // we don't have it built yet\n // create the new PathItem objects.\n const newEntryCount = this.createPathItems(rowNode);\n // link in the node items\n this.linkPathItems(rowNode, newEntryCount);\n // update columns\n this.populateColumnsMap(rowNode, columns);\n }\n canSkip(rowNode) {\n return this.active && !this.mapToItems[rowNode.id];\n }\n getValueColumnsForNode(rowNode, valueColumns) {\n if (!this.keepingColumns) {\n return valueColumns;\n }\n const colsForThisNode = this.nodeIdsToColumns[rowNode.id];\n const result = valueColumns.filter(col => colsForThisNode[col.getId()]);\n return result;\n }\n getNotValueColumnsForNode(rowNode, valueColumns) {\n if (!this.keepingColumns) {\n return null;\n }\n const colsForThisNode = this.nodeIdsToColumns[rowNode.id];\n const result = valueColumns.filter(col => !colsForThisNode[col.getId()]);\n return result;\n }\n}\n","import { BeanStub } from \"../context/beanStub.mjs\";\nexport class RowNodeBlock extends BeanStub {\n constructor(id) {\n super();\n this.state = RowNodeBlock.STATE_WAITING_TO_LOAD;\n this.version = 0;\n this.id = id;\n }\n getId() {\n return this.id;\n }\n load() {\n this.state = RowNodeBlock.STATE_LOADING;\n this.loadFromDatasource();\n }\n getVersion() {\n return this.version;\n }\n setStateWaitingToLoad() {\n // in case any current loads in progress, this will have their results ignored\n this.version++;\n this.state = RowNodeBlock.STATE_WAITING_TO_LOAD;\n }\n getState() {\n return this.state;\n }\n pageLoadFailed(version) {\n const requestMostRecentAndLive = this.isRequestMostRecentAndLive(version);\n if (requestMostRecentAndLive) {\n this.state = RowNodeBlock.STATE_FAILED;\n this.processServerFail();\n }\n this.dispatchLoadCompleted(false);\n }\n success(version, params) {\n this.successCommon(version, params);\n }\n pageLoaded(version, rows, lastRow) {\n this.successCommon(version, { rowData: rows, rowCount: lastRow });\n }\n isRequestMostRecentAndLive(version) {\n // thisIsMostRecentRequest - if block was refreshed, then another request\n // could of been sent after this one.\n const thisIsMostRecentRequest = version === this.version;\n // weAreNotDestroyed - if InfiniteStore is purged, then blocks are destroyed\n // and new blocks created. so data loads of old blocks are discarded.\n const weAreNotDestroyed = this.isAlive();\n return thisIsMostRecentRequest && weAreNotDestroyed;\n }\n successCommon(version, params) {\n // need to dispatch load complete before processing the data, as PaginationComp checks\n // RowNodeBlockLoader to see if it is still loading, so the RowNodeBlockLoader needs to\n // be updated first (via LoadComplete event) before PaginationComp updates (via processServerResult method)\n this.dispatchLoadCompleted();\n const requestMostRecentAndLive = this.isRequestMostRecentAndLive(version);\n if (requestMostRecentAndLive) {\n this.state = RowNodeBlock.STATE_LOADED;\n this.processServerResult(params);\n }\n }\n dispatchLoadCompleted(success = true) {\n // we fire event regardless of processing data or now, as we want\n // the concurrentLoadRequests count to be reduced in BlockLoader\n const event = {\n type: RowNodeBlock.EVENT_LOAD_COMPLETE,\n success: success,\n block: this\n };\n this.dispatchEvent(event);\n }\n}\nRowNodeBlock.EVENT_LOAD_COMPLETE = 'loadComplete';\nRowNodeBlock.STATE_WAITING_TO_LOAD = 'needsLoading';\nRowNodeBlock.STATE_LOADING = 'loading';\nRowNodeBlock.STATE_LOADED = 'loaded';\nRowNodeBlock.STATE_FAILED = 'failed';\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n};\nvar RowNodeBlockLoader_1;\nimport { RowNodeBlock } from \"./rowNodeBlock.mjs\";\nimport { Autowired, Bean, PostConstruct, Qualifier } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { _ } from \"../utils/index.mjs\";\nlet RowNodeBlockLoader = RowNodeBlockLoader_1 = class RowNodeBlockLoader extends BeanStub {\n constructor() {\n super(...arguments);\n this.activeBlockLoadsCount = 0;\n this.blocks = [];\n this.active = true;\n }\n postConstruct() {\n this.maxConcurrentRequests = this.getMaxConcurrentDatasourceRequests();\n const blockLoadDebounceMillis = this.gridOptionsService.getNum('blockLoadDebounceMillis');\n if (blockLoadDebounceMillis && blockLoadDebounceMillis > 0) {\n this.checkBlockToLoadDebounce = _.debounce(this.performCheckBlocksToLoad.bind(this), blockLoadDebounceMillis);\n }\n }\n setBeans(loggerFactory) {\n this.logger = loggerFactory.create('RowNodeBlockLoader');\n }\n getMaxConcurrentDatasourceRequests() {\n const res = this.gridOptionsService.getNum('maxConcurrentDatasourceRequests');\n if (res == null) {\n return 2;\n } // 2 is the default\n if (res <= 0) {\n return;\n } // negative number, eg -1, means no max restriction\n return res;\n }\n addBlock(block) {\n this.blocks.push(block);\n // note that we do not remove this listener when removing the block. this is because the\n // cache can get destroyed (and containing blocks) when a block is loading. however the loading block\n // is still counted as an active loading block and we must decrement activeBlockLoadsCount when it finishes.\n block.addEventListener(RowNodeBlock.EVENT_LOAD_COMPLETE, this.loadComplete.bind(this));\n this.checkBlockToLoad();\n }\n removeBlock(block) {\n _.removeFromArray(this.blocks, block);\n }\n destroy() {\n super.destroy();\n this.active = false;\n }\n loadComplete() {\n this.activeBlockLoadsCount--;\n this.checkBlockToLoad();\n this.dispatchEvent({ type: RowNodeBlockLoader_1.BLOCK_LOADED_EVENT });\n if (this.activeBlockLoadsCount == 0) {\n this.dispatchEvent({ type: RowNodeBlockLoader_1.BLOCK_LOADER_FINISHED_EVENT });\n }\n }\n checkBlockToLoad() {\n if (this.checkBlockToLoadDebounce) {\n this.checkBlockToLoadDebounce();\n }\n else {\n this.performCheckBlocksToLoad();\n }\n }\n performCheckBlocksToLoad() {\n if (!this.active) {\n return;\n }\n this.printCacheStatus();\n if (this.maxConcurrentRequests != null && this.activeBlockLoadsCount >= this.maxConcurrentRequests) {\n this.logger.log(`checkBlockToLoad: max loads exceeded`);\n return;\n }\n const loadAvailability = this.getAvailableLoadingCount();\n const blocksToLoad = this.blocks.filter(block => (block.getState() === RowNodeBlock.STATE_WAITING_TO_LOAD)).slice(0, loadAvailability);\n this.registerLoads(blocksToLoad.length);\n blocksToLoad.forEach(block => block.load());\n this.printCacheStatus();\n }\n getBlockState() {\n if (this.gridOptionsService.isRowModelType('serverSide')) {\n const ssrm = this.rowModel;\n return ssrm.getBlockStates();\n }\n const result = {};\n this.blocks.forEach((block) => {\n const { id, state } = block.getBlockStateJson();\n result[id] = state;\n });\n return result;\n }\n printCacheStatus() {\n if (this.logger.isLogging()) {\n this.logger.log(`printCacheStatus: activePageLoadsCount = ${this.activeBlockLoadsCount},`\n + ` blocks = ${JSON.stringify(this.getBlockState())}`);\n }\n }\n isLoading() {\n return this.activeBlockLoadsCount > 0;\n }\n registerLoads(count) {\n this.activeBlockLoadsCount += count;\n }\n getAvailableLoadingCount() {\n return this.maxConcurrentRequests !== undefined ? this.maxConcurrentRequests - this.activeBlockLoadsCount : undefined;\n }\n};\nRowNodeBlockLoader.BLOCK_LOADED_EVENT = 'blockLoaded';\nRowNodeBlockLoader.BLOCK_LOADER_FINISHED_EVENT = 'blockLoaderFinished';\n__decorate([\n Autowired('rowModel')\n], RowNodeBlockLoader.prototype, \"rowModel\", void 0);\n__decorate([\n PostConstruct\n], RowNodeBlockLoader.prototype, \"postConstruct\", null);\n__decorate([\n __param(0, Qualifier('loggerFactory'))\n], RowNodeBlockLoader.prototype, \"setBeans\", null);\nRowNodeBlockLoader = RowNodeBlockLoader_1 = __decorate([\n Bean('rowNodeBlockLoader')\n], RowNodeBlockLoader);\nexport { RowNodeBlockLoader };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { Events } from \"../events.mjs\";\nimport { Autowired, Bean, PostConstruct } from \"../context/context.mjs\";\nimport { missing, exists } from \"../utils/generic.mjs\";\nlet PaginationProxy = class PaginationProxy extends BeanStub {\n constructor() {\n super(...arguments);\n this.currentPage = 0;\n this.topDisplayedRowIndex = 0;\n this.bottomDisplayedRowIndex = 0;\n this.pixelOffset = 0;\n this.masterRowCount = 0;\n }\n postConstruct() {\n this.active = this.gridOptionsService.is('pagination');\n this.paginateChildRows = this.isPaginateChildRows();\n this.addManagedListener(this.eventService, Events.EVENT_MODEL_UPDATED, this.onModelUpdated.bind(this));\n this.addManagedPropertyListener('pagination', this.onPaginationPageSizeChanged.bind(this));\n this.addManagedPropertyListener('paginationPageSize', this.onPaginationPageSizeChanged.bind(this));\n this.onModelUpdated();\n }\n ensureRowHeightsValid(startPixel, endPixel, startLimitIndex, endLimitIndex) {\n const res = this.rowModel.ensureRowHeightsValid(startPixel, endPixel, this.getPageFirstRow(), this.getPageLastRow());\n if (res) {\n this.calculatePages();\n }\n return res;\n }\n isPaginateChildRows() {\n const shouldPaginate = this.gridOptionsService.is('groupRemoveSingleChildren') || this.gridOptionsService.is('groupRemoveLowestSingleChildren');\n if (shouldPaginate) {\n return true;\n }\n return this.gridOptionsService.is('paginateChildRows');\n }\n onModelUpdated(modelUpdatedEvent) {\n this.calculatePages();\n const paginationChangedEvent = {\n type: Events.EVENT_PAGINATION_CHANGED,\n animate: modelUpdatedEvent ? modelUpdatedEvent.animate : false,\n newData: modelUpdatedEvent ? modelUpdatedEvent.newData : false,\n newPage: modelUpdatedEvent ? modelUpdatedEvent.newPage : false,\n keepRenderedRows: modelUpdatedEvent ? modelUpdatedEvent.keepRenderedRows : false\n };\n this.eventService.dispatchEvent(paginationChangedEvent);\n }\n onPaginationPageSizeChanged() {\n this.active = this.gridOptionsService.is('pagination');\n this.calculatePages();\n const paginationChangedEvent = {\n type: Events.EVENT_PAGINATION_CHANGED,\n animate: false,\n newData: false,\n newPage: false,\n // important to keep rendered rows, otherwise every time grid is resized,\n // we would destroy all the rows.\n keepRenderedRows: true\n };\n this.eventService.dispatchEvent(paginationChangedEvent);\n }\n goToPage(page) {\n if (!this.active || this.currentPage === page || typeof this.currentPage !== 'number') {\n return;\n }\n this.currentPage = page;\n const event = {\n type: Events.EVENT_MODEL_UPDATED,\n animate: false,\n keepRenderedRows: false,\n newData: false,\n newPage: true\n };\n this.onModelUpdated(event);\n }\n getPixelOffset() {\n return this.pixelOffset;\n }\n getRow(index) {\n return this.rowModel.getRow(index);\n }\n getRowNode(id) {\n return this.rowModel.getRowNode(id);\n }\n getRowIndexAtPixel(pixel) {\n return this.rowModel.getRowIndexAtPixel(pixel);\n }\n getCurrentPageHeight() {\n if (missing(this.topRowBounds) || missing(this.bottomRowBounds)) {\n return 0;\n }\n return Math.max(this.bottomRowBounds.rowTop + this.bottomRowBounds.rowHeight - this.topRowBounds.rowTop, 0);\n }\n getCurrentPagePixelRange() {\n const pageFirstPixel = this.topRowBounds ? this.topRowBounds.rowTop : 0;\n const pageLastPixel = this.bottomRowBounds ? this.bottomRowBounds.rowTop + this.bottomRowBounds.rowHeight : 0;\n return { pageFirstPixel, pageLastPixel };\n }\n isRowPresent(rowNode) {\n if (!this.rowModel.isRowPresent(rowNode)) {\n return false;\n }\n const nodeIsInPage = rowNode.rowIndex >= this.topDisplayedRowIndex && rowNode.rowIndex <= this.bottomDisplayedRowIndex;\n return nodeIsInPage;\n }\n isEmpty() {\n return this.rowModel.isEmpty();\n }\n isRowsToRender() {\n return this.rowModel.isRowsToRender();\n }\n forEachNode(callback) {\n return this.rowModel.forEachNode(callback);\n }\n forEachNodeOnPage(callback) {\n const firstRow = this.getPageFirstRow();\n const lastRow = this.getPageLastRow();\n for (let i = firstRow; i <= lastRow; i++) {\n const node = this.getRow(i);\n if (node) {\n callback(node);\n }\n }\n }\n getType() {\n return this.rowModel.getType();\n }\n getRowBounds(index) {\n const res = this.rowModel.getRowBounds(index);\n res.rowIndex = index;\n return res;\n }\n getPageFirstRow() {\n return this.topRowBounds ? this.topRowBounds.rowIndex : -1;\n }\n getPageLastRow() {\n return this.bottomRowBounds ? this.bottomRowBounds.rowIndex : -1;\n }\n getRowCount() {\n return this.rowModel.getRowCount();\n }\n getPageForIndex(index) {\n return Math.floor(index / this.pageSize);\n }\n goToPageWithIndex(index) {\n if (!this.active) {\n return;\n }\n const pageNumber = this.getPageForIndex(index);\n this.goToPage(pageNumber);\n }\n isRowInPage(row) {\n if (!this.active) {\n return true;\n }\n const rowPage = this.getPageForIndex(row.rowIndex);\n return rowPage === this.currentPage;\n }\n isLastPageFound() {\n return this.rowModel.isLastRowIndexKnown();\n }\n getCurrentPage() {\n return this.currentPage;\n }\n goToNextPage() {\n this.goToPage(this.currentPage + 1);\n }\n goToPreviousPage() {\n this.goToPage(this.currentPage - 1);\n }\n goToFirstPage() {\n this.goToPage(0);\n }\n goToLastPage() {\n const rowCount = this.rowModel.getRowCount();\n const lastPage = Math.floor(rowCount / this.pageSize);\n this.goToPage(lastPage);\n }\n getPageSize() {\n return this.pageSize;\n }\n getTotalPages() {\n return this.totalPages;\n }\n setPageSize() {\n // show put this into super class\n this.pageSize = this.gridOptionsService.getNum('paginationPageSize');\n if (this.pageSize == null || this.pageSize < 1) {\n this.pageSize = 100;\n }\n }\n calculatePages() {\n if (this.active) {\n this.setPageSize();\n if (this.paginateChildRows) {\n this.calculatePagesAllRows();\n }\n else {\n this.calculatePagesMasterRowsOnly();\n }\n }\n else {\n this.calculatedPagesNotActive();\n }\n this.topRowBounds = this.rowModel.getRowBounds(this.topDisplayedRowIndex);\n if (this.topRowBounds) {\n this.topRowBounds.rowIndex = this.topDisplayedRowIndex;\n }\n this.bottomRowBounds = this.rowModel.getRowBounds(this.bottomDisplayedRowIndex);\n if (this.bottomRowBounds) {\n this.bottomRowBounds.rowIndex = this.bottomDisplayedRowIndex;\n }\n this.setPixelOffset(exists(this.topRowBounds) ? this.topRowBounds.rowTop : 0);\n }\n setPixelOffset(value) {\n if (this.pixelOffset === value) {\n return;\n }\n this.pixelOffset = value;\n this.eventService.dispatchEvent({ type: Events.EVENT_PAGINATION_PIXEL_OFFSET_CHANGED });\n }\n setZeroRows() {\n this.masterRowCount = 0;\n this.topDisplayedRowIndex = 0;\n this.bottomDisplayedRowIndex = -1;\n this.currentPage = 0;\n this.totalPages = 0;\n }\n adjustCurrentPageIfInvalid() {\n if (this.currentPage >= this.totalPages) {\n this.currentPage = this.totalPages - 1;\n }\n if (!isFinite(this.currentPage) || isNaN(this.currentPage) || this.currentPage < 0) {\n this.currentPage = 0;\n }\n }\n calculatePagesMasterRowsOnly() {\n // const csrm = this.rowModel;\n // const rootNode = csrm.getRootNode();\n // const masterRows = rootNode.childrenAfterSort;\n this.masterRowCount = this.rowModel.getTopLevelRowCount();\n // we say <=0 (rather than =0) as viewport returns -1 when no rows\n if (this.masterRowCount <= 0) {\n this.setZeroRows();\n return;\n }\n const masterLastRowIndex = this.masterRowCount - 1;\n this.totalPages = Math.floor((masterLastRowIndex) / this.pageSize) + 1;\n this.adjustCurrentPageIfInvalid();\n const masterPageStartIndex = this.pageSize * this.currentPage;\n let masterPageEndIndex = (this.pageSize * (this.currentPage + 1)) - 1;\n if (masterPageEndIndex > masterLastRowIndex) {\n masterPageEndIndex = masterLastRowIndex;\n }\n this.topDisplayedRowIndex = this.rowModel.getTopLevelRowDisplayedIndex(masterPageStartIndex);\n // masterRows[masterPageStartIndex].rowIndex;\n if (masterPageEndIndex === masterLastRowIndex) {\n // if showing the last master row, then we want to show the very last row of the model\n this.bottomDisplayedRowIndex = this.rowModel.getRowCount() - 1;\n }\n else {\n const firstIndexNotToShow = this.rowModel.getTopLevelRowDisplayedIndex(masterPageEndIndex + 1);\n //masterRows[masterPageEndIndex + 1].rowIndex;\n // this gets the index of the last child - eg current row is open, we want to display all children,\n // the index of the last child is one less than the index of the next parent row.\n this.bottomDisplayedRowIndex = firstIndexNotToShow - 1;\n }\n }\n getMasterRowCount() {\n return this.masterRowCount;\n }\n calculatePagesAllRows() {\n this.masterRowCount = this.rowModel.getRowCount();\n if (this.masterRowCount === 0) {\n this.setZeroRows();\n return;\n }\n const maxRowIndex = this.masterRowCount - 1;\n this.totalPages = Math.floor((maxRowIndex) / this.pageSize) + 1;\n this.adjustCurrentPageIfInvalid();\n this.topDisplayedRowIndex = this.pageSize * this.currentPage;\n this.bottomDisplayedRowIndex = (this.pageSize * (this.currentPage + 1)) - 1;\n if (this.bottomDisplayedRowIndex > maxRowIndex) {\n this.bottomDisplayedRowIndex = maxRowIndex;\n }\n }\n calculatedPagesNotActive() {\n this.pageSize = this.rowModel.getRowCount();\n this.totalPages = 1;\n this.currentPage = 0;\n this.topDisplayedRowIndex = 0;\n this.bottomDisplayedRowIndex = this.rowModel.getRowCount() - 1;\n }\n};\n__decorate([\n Autowired('rowModel')\n], PaginationProxy.prototype, \"rowModel\", void 0);\n__decorate([\n PostConstruct\n], PaginationProxy.prototype, \"postConstruct\", null);\nPaginationProxy = __decorate([\n Bean('paginationProxy')\n], PaginationProxy);\nexport { PaginationProxy };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nlet StylingService = class StylingService extends BeanStub {\n processAllCellClasses(colDef, params, onApplicableClass, onNotApplicableClass) {\n this.processClassRules(colDef.cellClassRules, params, onApplicableClass, onNotApplicableClass);\n this.processStaticCellClasses(colDef, params, onApplicableClass);\n }\n processClassRules(classRules, params, onApplicableClass, onNotApplicableClass) {\n if (classRules == null) {\n return;\n }\n const classNames = Object.keys(classRules);\n const classesToApply = {};\n const classesToRemove = {};\n for (let i = 0; i < classNames.length; i++) {\n const className = classNames[i];\n const rule = classRules[className];\n let resultOfRule;\n if (typeof rule === 'string') {\n resultOfRule = this.expressionService.evaluate(rule, params);\n }\n else if (typeof rule === 'function') {\n resultOfRule = rule(params);\n }\n // in case className = 'my-class1 my-class2', we need to split into individual class names\n className.split(' ').forEach(singleClass => {\n if (singleClass == null || singleClass.trim() == '') {\n return;\n }\n resultOfRule ? classesToApply[singleClass] = true : classesToRemove[singleClass] = true;\n });\n }\n // we remove all classes first, then add all classes second,\n // in case a class appears in more than one rule, this means it will be added\n // if appears in at least one truthy rule\n if (onNotApplicableClass) {\n Object.keys(classesToRemove).forEach(onNotApplicableClass);\n }\n Object.keys(classesToApply).forEach(onApplicableClass);\n }\n getStaticCellClasses(colDef, params) {\n const { cellClass } = colDef;\n if (!cellClass) {\n return [];\n }\n let classOrClasses;\n if (typeof cellClass === 'function') {\n const cellClassFunc = cellClass;\n classOrClasses = cellClassFunc(params);\n }\n else {\n classOrClasses = cellClass;\n }\n if (typeof classOrClasses === 'string') {\n classOrClasses = [classOrClasses];\n }\n return classOrClasses || [];\n }\n processStaticCellClasses(colDef, params, onApplicableClass) {\n const classOrClasses = this.getStaticCellClasses(colDef, params);\n classOrClasses.forEach((cssClassItem) => {\n onApplicableClass(cssClassItem);\n });\n }\n};\n__decorate([\n Autowired('expressionService')\n], StylingService.prototype, \"expressionService\", void 0);\nStylingService = __decorate([\n Bean('stylingService')\n], StylingService);\nexport { StylingService };\n","import { AgCheckbox } from './agCheckbox.mjs';\nexport class AgToggleButton extends AgCheckbox {\n constructor(config) {\n super(config, 'ag-toggle-button');\n }\n setValue(value, silent) {\n super.setValue(value, silent);\n this.addOrRemoveCssClass('ag-selected', this.getValue());\n return this;\n }\n}\n","import { AgAbstractInputField } from \"./agAbstractInputField.mjs\";\nexport class AgInputTextArea extends AgAbstractInputField {\n constructor(config) {\n super(config, 'ag-text-area', null, 'textarea');\n }\n setValue(value, silent) {\n const ret = super.setValue(value, silent);\n this.eInput.value = value;\n return ret;\n }\n setCols(cols) {\n this.eInput.cols = cols;\n return this;\n }\n setRows(rows) {\n this.eInput.rows = rows;\n return this;\n }\n}\n","import { AgInputTextField } from \"./agInputTextField.mjs\";\nimport { addOrRemoveAttribute } from \"../utils/dom.mjs\";\nimport { parseDateTimeFromString, serialiseDate } from \"../utils/date.mjs\";\nimport { isBrowserSafari } from \"../utils/browser.mjs\";\nexport class AgInputDateField extends AgInputTextField {\n constructor(config) {\n super(config, 'ag-date-field', 'date');\n }\n postConstruct() {\n super.postConstruct();\n this.addManagedListener(this.eInput, 'wheel', this.onWheel.bind(this));\n // ensures that the input element is focussed when a clear button is clicked,\n // unless using safari as there is no clear button and focus does not work properly\n const usingSafari = isBrowserSafari();\n this.addManagedListener(this.eInput, 'mousedown', () => {\n if (this.isDisabled() || usingSafari) {\n return;\n }\n this.eInput.focus();\n });\n this.eInput.step = 'any';\n }\n onWheel(e) {\n // Prevent default scroll events from incrementing / decrementing the input, since its inconsistent between browsers\n if (document.activeElement === this.eInput) {\n e.preventDefault();\n }\n }\n setMin(minDate) {\n var _a;\n const min = minDate instanceof Date ? (_a = serialiseDate(minDate !== null && minDate !== void 0 ? minDate : null, false)) !== null && _a !== void 0 ? _a : undefined : minDate;\n if (this.min === min) {\n return this;\n }\n this.min = min;\n addOrRemoveAttribute(this.eInput, 'min', min);\n return this;\n }\n setMax(maxDate) {\n var _a;\n const max = maxDate instanceof Date ? (_a = serialiseDate(maxDate !== null && maxDate !== void 0 ? maxDate : null, false)) !== null && _a !== void 0 ? _a : undefined : maxDate;\n if (this.max === max) {\n return this;\n }\n this.max = max;\n addOrRemoveAttribute(this.eInput, 'max', max);\n return this;\n }\n setStep(step) {\n if (this.step === step) {\n return this;\n }\n this.step = step;\n addOrRemoveAttribute(this.eInput, 'step', step);\n return this;\n }\n getDate() {\n var _a;\n if (!this.eInput.validity.valid) {\n return undefined;\n }\n return (_a = parseDateTimeFromString(this.getValue())) !== null && _a !== void 0 ? _a : undefined;\n }\n setDate(date, silent) {\n this.setValue(serialiseDate(date !== null && date !== void 0 ? date : null, false), silent);\n }\n}\n","import { AgAbstractInputField } from \"./agAbstractInputField.mjs\";\nexport class AgInputRange extends AgAbstractInputField {\n constructor(config) {\n super(config, 'ag-range-field', 'range');\n }\n postConstruct() {\n super.postConstruct();\n const { min, max, step } = this.config;\n if (min != null) {\n this.setMinValue(min);\n }\n if (max != null) {\n this.setMaxValue(max);\n }\n this.setStep(step || 1);\n }\n addInputListeners() {\n this.addManagedListener(this.eInput, 'input', (e) => {\n const value = e.target.value;\n this.setValue(value);\n });\n }\n setMinValue(value) {\n this.min = value;\n this.eInput.setAttribute('min', value.toString());\n return this;\n }\n setMaxValue(value) {\n this.max = value;\n this.eInput.setAttribute('max', value.toString());\n return this;\n }\n setStep(value) {\n this.eInput.setAttribute('step', value.toString());\n return this;\n }\n setValue(value, silent) {\n if (this.min != null) {\n value = Math.max(parseFloat(value), this.min).toString();\n }\n if (this.max != null) {\n value = Math.min(parseFloat(value), this.max).toString();\n }\n const ret = super.setValue(value, silent);\n this.eInput.value = value;\n return ret;\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from \"../context/context.mjs\";\nimport { Events } from \"../eventKeys.mjs\";\nimport { bindCellRendererToHtmlElement } from \"../utils/dom.mjs\";\nimport { Component } from \"./component.mjs\";\nimport { escapeString } from \"../utils/string.mjs\";\nimport { exists } from \"../utils/generic.mjs\";\nimport { setAriaActiveDescendant, setAriaSelected } from \"../utils/aria.mjs\";\nexport class RichSelectRow extends Component {\n constructor(params, wrapperEl) {\n super(/* html */ `
`);\n this.params = params;\n this.wrapperEl = wrapperEl;\n }\n postConstruct() {\n this.addManagedListener(this.getGui(), 'mouseup', this.onMouseUp.bind(this));\n }\n setState(value) {\n let formattedValue = '';\n if (this.params.valueFormatter) {\n formattedValue = this.params.valueFormatter(value);\n }\n const rendererSuccessful = this.populateWithRenderer(value, formattedValue);\n if (!rendererSuccessful) {\n this.populateWithoutRenderer(value, formattedValue);\n }\n this.value = value;\n }\n highlightString(matchString) {\n const { parsedValue } = this;\n if (this.params.cellRenderer || !exists(parsedValue)) {\n return;\n }\n if (exists(matchString)) {\n const index = parsedValue === null || parsedValue === void 0 ? void 0 : parsedValue.toLocaleLowerCase().indexOf(matchString.toLocaleLowerCase());\n if (index >= 0) {\n const highlightEndIndex = index + matchString.length;\n const startPart = escapeString(parsedValue.slice(0, index), true);\n const highlightedPart = escapeString(parsedValue.slice(index, highlightEndIndex), true);\n const endPart = escapeString(parsedValue.slice(highlightEndIndex));\n this.renderValueWithoutRenderer(`${startPart}${highlightedPart}${endPart}`);\n }\n }\n else {\n this.renderValueWithoutRenderer(parsedValue);\n }\n }\n updateHighlighted(highlighted) {\n var _a;\n const eGui = this.getGui();\n const parentId = `ag-rich-select-row-${this.getCompId()}`;\n (_a = eGui.parentElement) === null || _a === void 0 ? void 0 : _a.setAttribute('id', parentId);\n if (highlighted) {\n const parentAriaEl = this.getParentComponent().getAriaElement();\n setAriaActiveDescendant(parentAriaEl, parentId);\n this.wrapperEl.setAttribute('data-active-option', parentId);\n }\n setAriaSelected(eGui.parentElement, highlighted);\n this.addOrRemoveCssClass('ag-rich-select-row-selected', highlighted);\n }\n populateWithoutRenderer(value, valueFormatted) {\n const eDocument = this.gridOptionsService.getDocument();\n const eGui = this.getGui();\n const span = eDocument.createElement('span');\n span.style.overflow = 'hidden';\n span.style.textOverflow = 'ellipsis';\n const parsedValue = escapeString(exists(valueFormatted) ? valueFormatted : value, true);\n this.parsedValue = exists(parsedValue) ? parsedValue : null;\n eGui.appendChild(span);\n this.renderValueWithoutRenderer(parsedValue);\n }\n renderValueWithoutRenderer(value) {\n const span = this.getGui().querySelector('span');\n if (!span) {\n return;\n }\n span.innerHTML = exists(value) ? value : ' ';\n }\n populateWithRenderer(value, valueFormatted) {\n // bad coder here - we are not populating all values of the cellRendererParams\n let cellRendererPromise;\n let userCompDetails;\n if (this.params.cellRenderer) {\n userCompDetails = this.userComponentFactory.getCellRendererDetails(this.params, {\n value,\n valueFormatted,\n api: this.gridOptionsService.api\n });\n }\n if (userCompDetails) {\n cellRendererPromise = userCompDetails.newAgStackInstance();\n }\n if (cellRendererPromise) {\n bindCellRendererToHtmlElement(cellRendererPromise, this.getGui());\n }\n if (cellRendererPromise) {\n cellRendererPromise.then(childComponent => {\n this.addDestroyFunc(() => {\n this.getContext().destroyBean(childComponent);\n });\n });\n return true;\n }\n return false;\n }\n onMouseUp() {\n const parent = this.getParentComponent();\n const event = {\n type: Events.EVENT_FIELD_PICKER_VALUE_SELECTED,\n fromEnterKey: false,\n value: this.value\n };\n parent === null || parent === void 0 ? void 0 : parent.dispatchEvent(event);\n }\n}\n__decorate([\n Autowired('userComponentFactory')\n], RichSelectRow.prototype, \"userComponentFactory\", void 0);\n__decorate([\n PostConstruct\n], RichSelectRow.prototype, \"postConstruct\", null);\n","import { Component } from \"./component.mjs\";\nimport { isNodeOrElement, clearElement } from \"../utils/dom.mjs\";\nimport { TabGuardCtrl, TabGuardClassNames } from \"./tabGuardCtrl.mjs\";\nimport { setAriaRole } from \"../utils/aria.mjs\";\nexport class TabGuardComp extends Component {\n initialiseTabGuard(params) {\n this.eTopGuard = this.createTabGuard('top');\n this.eBottomGuard = this.createTabGuard('bottom');\n this.eFocusableElement = this.getFocusableElement();\n const tabGuards = [this.eTopGuard, this.eBottomGuard];\n const compProxy = {\n setTabIndex: tabIndex => {\n tabGuards.forEach(tabGuard => tabIndex != null ? tabGuard.setAttribute('tabindex', tabIndex) : tabGuard.removeAttribute('tabindex'));\n }\n };\n this.addTabGuards(this.eTopGuard, this.eBottomGuard);\n this.tabGuardCtrl = this.createManagedBean(new TabGuardCtrl({\n comp: compProxy,\n eTopGuard: this.eTopGuard,\n eBottomGuard: this.eBottomGuard,\n eFocusableElement: this.eFocusableElement,\n onFocusIn: params.onFocusIn,\n onFocusOut: params.onFocusOut,\n focusInnerElement: params.focusInnerElement,\n handleKeyDown: params.handleKeyDown,\n onTabKeyDown: params.onTabKeyDown,\n shouldStopEventPropagation: params.shouldStopEventPropagation\n }));\n }\n createTabGuard(side) {\n const tabGuard = document.createElement('div');\n const cls = side === 'top' ? TabGuardClassNames.TAB_GUARD_TOP : TabGuardClassNames.TAB_GUARD_BOTTOM;\n tabGuard.classList.add(TabGuardClassNames.TAB_GUARD, cls);\n setAriaRole(tabGuard, 'presentation');\n return tabGuard;\n }\n addTabGuards(topTabGuard, bottomTabGuard) {\n this.eFocusableElement.insertAdjacentElement('afterbegin', topTabGuard);\n this.eFocusableElement.insertAdjacentElement('beforeend', bottomTabGuard);\n }\n removeAllChildrenExceptTabGuards() {\n const tabGuards = [this.eTopGuard, this.eBottomGuard];\n clearElement(this.getFocusableElement());\n this.addTabGuards(...tabGuards);\n }\n forceFocusOutOfContainer(up = false) {\n this.tabGuardCtrl.forceFocusOutOfContainer(up);\n }\n appendChild(newChild, container) {\n if (!isNodeOrElement(newChild)) {\n newChild = newChild.getGui();\n }\n const { eBottomGuard: bottomTabGuard } = this;\n if (bottomTabGuard) {\n bottomTabGuard.insertAdjacentElement('beforebegin', newChild);\n }\n else {\n super.appendChild(newChild, container);\n }\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from '../context/context.mjs';\nimport { RefSelector } from './componentAnnotations.mjs';\nimport { getAriaPosInSet, setAriaSetSize, setAriaPosInSet, setAriaSelected, setAriaChecked, setAriaRole, setAriaLabel } from '../utils/aria.mjs';\nimport { KeyCode } from '../constants/keyCode.mjs';\nimport { waitUntil } from '../utils/function.mjs';\nimport { TabGuardComp } from './tabGuardComp.mjs';\nimport { Events } from '../eventKeys.mjs';\nimport { stopPropagationForAgGrid } from '../utils/event.mjs';\nexport class VirtualList extends TabGuardComp {\n constructor(params) {\n super(VirtualList.getTemplate((params === null || params === void 0 ? void 0 : params.cssIdentifier) || 'default'));\n this.renderedRows = new Map();\n this.rowHeight = 20;\n const { cssIdentifier = 'default', ariaRole = 'listbox', listName } = params || {};\n this.cssIdentifier = cssIdentifier;\n this.ariaRole = ariaRole;\n this.listName = listName;\n }\n postConstruct() {\n this.addScrollListener();\n this.rowHeight = this.getItemHeight();\n this.addResizeObserver();\n this.initialiseTabGuard({\n onFocusIn: (e) => this.onFocusIn(e),\n onFocusOut: (e) => this.onFocusOut(e),\n focusInnerElement: (fromBottom) => this.focusInnerElement(fromBottom),\n onTabKeyDown: e => this.onTabKeyDown(e),\n handleKeyDown: e => this.handleKeyDown(e)\n });\n this.setAriaProperties();\n this.addManagedListener(this.eventService, Events.EVENT_GRID_STYLES_CHANGED, this.onGridStylesChanged.bind(this));\n }\n onGridStylesChanged() {\n this.rowHeight = this.getItemHeight();\n this.refresh();\n }\n setAriaProperties() {\n const translate = this.localeService.getLocaleTextFunc();\n const listName = translate('ariaDefaultListName', this.listName || 'List');\n const ariaEl = this.eContainer;\n setAriaRole(ariaEl, this.ariaRole);\n setAriaLabel(ariaEl, listName);\n }\n addResizeObserver() {\n // do this in an animation frame to prevent loops\n const listener = () => this.animationFrameService.requestAnimationFrame(() => this.drawVirtualRows());\n const destroyObserver = this.resizeObserverService.observeResize(this.getGui(), listener);\n this.addDestroyFunc(destroyObserver);\n }\n focusInnerElement(fromBottom) {\n this.focusRow(fromBottom ? this.model.getRowCount() - 1 : 0);\n }\n onFocusIn(e) {\n const target = e.target;\n if (target.classList.contains('ag-virtual-list-item')) {\n this.lastFocusedRowIndex = getAriaPosInSet(target) - 1;\n }\n return false;\n }\n onFocusOut(e) {\n if (!this.getFocusableElement().contains(e.relatedTarget)) {\n this.lastFocusedRowIndex = null;\n }\n return false;\n }\n handleKeyDown(e) {\n switch (e.key) {\n case KeyCode.UP:\n case KeyCode.DOWN:\n if (this.navigate(e.key === KeyCode.UP)) {\n e.preventDefault();\n }\n break;\n }\n }\n onTabKeyDown(e) {\n if (this.navigate(e.shiftKey)) {\n e.preventDefault();\n }\n else {\n stopPropagationForAgGrid(e);\n this.forceFocusOutOfContainer(e.shiftKey);\n }\n }\n navigate(up) {\n if (this.lastFocusedRowIndex == null) {\n return false;\n }\n const nextRow = this.lastFocusedRowIndex + (up ? -1 : 1);\n if (nextRow < 0 || nextRow >= this.model.getRowCount()) {\n return false;\n }\n this.focusRow(nextRow);\n return true;\n }\n getLastFocusedRow() {\n return this.lastFocusedRowIndex;\n }\n focusRow(rowNumber) {\n this.ensureIndexVisible(rowNumber);\n window.setTimeout(() => {\n if (!this.isAlive()) {\n return;\n }\n const renderedRow = this.renderedRows.get(rowNumber);\n if (renderedRow) {\n renderedRow.eDiv.focus();\n }\n }, 10);\n }\n getComponentAt(rowIndex) {\n const comp = this.renderedRows.get(rowIndex);\n return comp && comp.rowComponent;\n }\n forEachRenderedRow(func) {\n this.renderedRows.forEach((value, key) => func(value.rowComponent, key));\n }\n static getTemplate(cssIdentifier) {\n return ( /* html */`
\n
\n
`);\n }\n getItemHeight() {\n return this.environment.getListItemHeight();\n }\n /**\n * Returns true if the view had to be scrolled, otherwise, false.\n */\n ensureIndexVisible(index, scrollPartialIntoView = true) {\n const lastRow = this.model.getRowCount();\n if (typeof index !== 'number' || index < 0 || index >= lastRow) {\n console.warn('AG Grid: invalid row index for ensureIndexVisible: ' + index);\n return false;\n }\n const rowTopPixel = index * this.rowHeight;\n const rowBottomPixel = rowTopPixel + this.rowHeight;\n const eGui = this.getGui();\n const viewportTopPixel = eGui.scrollTop;\n const viewportHeight = eGui.offsetHeight;\n const viewportBottomPixel = viewportTopPixel + viewportHeight;\n const diff = scrollPartialIntoView ? 0 : this.rowHeight;\n const viewportScrolledPastRow = viewportTopPixel > rowTopPixel + diff;\n const viewportScrolledBeforeRow = viewportBottomPixel < rowBottomPixel - diff;\n if (viewportScrolledPastRow) {\n // if row is before, scroll up with row at top\n eGui.scrollTop = rowTopPixel;\n return true;\n }\n if (viewportScrolledBeforeRow) {\n // if row is below, scroll down with row at bottom\n const newScrollPosition = rowBottomPixel - viewportHeight;\n eGui.scrollTop = newScrollPosition;\n return true;\n }\n return false;\n }\n setComponentCreator(componentCreator) {\n this.componentCreator = componentCreator;\n }\n setComponentUpdater(componentUpdater) {\n this.componentUpdater = componentUpdater;\n }\n getRowHeight() {\n return this.rowHeight;\n }\n getScrollTop() {\n return this.getGui().scrollTop;\n }\n setRowHeight(rowHeight) {\n this.rowHeight = rowHeight;\n this.refresh();\n }\n refresh(softRefresh) {\n if (this.model == null || !this.isAlive()) {\n return;\n }\n const rowCount = this.model.getRowCount();\n this.eContainer.style.height = `${rowCount * this.rowHeight}px`;\n // ensure height is applied before attempting to redraw rows\n waitUntil(() => this.eContainer.clientHeight >= rowCount * this.rowHeight, () => {\n if (!this.isAlive()) {\n return;\n }\n if (this.canSoftRefresh(softRefresh)) {\n this.drawVirtualRows(true);\n }\n else {\n this.clearVirtualRows();\n this.drawVirtualRows();\n }\n });\n }\n canSoftRefresh(softRefresh) {\n return !!(softRefresh && this.renderedRows.size && typeof this.model.areRowsEqual === 'function' && this.componentUpdater);\n }\n clearVirtualRows() {\n this.renderedRows.forEach((_, rowIndex) => this.removeRow(rowIndex));\n }\n drawVirtualRows(softRefresh) {\n if (!this.isAlive() || !this.model) {\n return;\n }\n const gui = this.getGui();\n const topPixel = gui.scrollTop;\n const bottomPixel = topPixel + gui.offsetHeight;\n const firstRow = Math.floor(topPixel / this.rowHeight);\n const lastRow = Math.floor(bottomPixel / this.rowHeight);\n this.ensureRowsRendered(firstRow, lastRow, softRefresh);\n }\n ensureRowsRendered(start, finish, softRefresh) {\n // remove any rows that are no longer required\n this.renderedRows.forEach((_, rowIndex) => {\n if ((rowIndex < start || rowIndex > finish) && rowIndex !== this.lastFocusedRowIndex) {\n this.removeRow(rowIndex);\n }\n });\n if (softRefresh) {\n // refresh any existing rows\n this.refreshRows();\n }\n // insert any required new rows\n for (let rowIndex = start; rowIndex <= finish; rowIndex++) {\n if (this.renderedRows.has(rowIndex)) {\n continue;\n }\n // check this row actually exists (in case overflow buffer window exceeds real data)\n if (rowIndex < this.model.getRowCount()) {\n this.insertRow(rowIndex);\n }\n }\n }\n insertRow(rowIndex) {\n const value = this.model.getRow(rowIndex);\n const eDiv = document.createElement('div');\n eDiv.classList.add('ag-virtual-list-item', `ag-${this.cssIdentifier}-virtual-list-item`);\n setAriaRole(eDiv, this.ariaRole === 'tree' ? 'treeitem' : 'option');\n setAriaSetSize(eDiv, this.model.getRowCount());\n setAriaPosInSet(eDiv, rowIndex + 1);\n eDiv.setAttribute('tabindex', '-1');\n if (typeof this.model.isRowSelected === 'function') {\n const isSelected = this.model.isRowSelected(rowIndex);\n setAriaSelected(eDiv, !!isSelected);\n setAriaChecked(eDiv, isSelected);\n }\n eDiv.style.height = `${this.rowHeight}px`;\n eDiv.style.top = `${this.rowHeight * rowIndex}px`;\n const rowComponent = this.componentCreator(value, eDiv);\n rowComponent.addGuiEventListener('focusin', () => this.lastFocusedRowIndex = rowIndex);\n eDiv.appendChild(rowComponent.getGui());\n // keep the DOM order consistent with the order of the rows\n if (this.renderedRows.has(rowIndex - 1)) {\n this.renderedRows.get(rowIndex - 1).eDiv.insertAdjacentElement('afterend', eDiv);\n }\n else if (this.renderedRows.has(rowIndex + 1)) {\n this.renderedRows.get(rowIndex + 1).eDiv.insertAdjacentElement('beforebegin', eDiv);\n }\n else {\n this.eContainer.appendChild(eDiv);\n }\n this.renderedRows.set(rowIndex, { rowComponent, eDiv, value });\n }\n removeRow(rowIndex) {\n const component = this.renderedRows.get(rowIndex);\n this.eContainer.removeChild(component.eDiv);\n this.destroyBean(component.rowComponent);\n this.renderedRows.delete(rowIndex);\n }\n refreshRows() {\n const rowCount = this.model.getRowCount();\n this.renderedRows.forEach((row, rowIndex) => {\n var _a, _b;\n if (rowIndex >= rowCount) {\n this.removeRow(rowIndex);\n }\n else {\n const newValue = this.model.getRow(rowIndex);\n if ((_b = (_a = this.model).areRowsEqual) === null || _b === void 0 ? void 0 : _b.call(_a, row.value, newValue)) {\n this.componentUpdater(newValue, row.rowComponent);\n }\n else {\n // to be replaced later\n this.removeRow(rowIndex);\n }\n }\n });\n }\n addScrollListener() {\n this.addGuiEventListener('scroll', () => this.drawVirtualRows(), { passive: true });\n }\n setModel(model) {\n this.model = model;\n }\n getAriaElement() {\n return this.eContainer;\n }\n destroy() {\n if (!this.isAlive()) {\n return;\n }\n this.clearVirtualRows();\n super.destroy();\n }\n}\n__decorate([\n Autowired('resizeObserverService')\n], VirtualList.prototype, \"resizeObserverService\", void 0);\n__decorate([\n Autowired('animationFrameService')\n], VirtualList.prototype, \"animationFrameService\", void 0);\n__decorate([\n RefSelector('eContainer')\n], VirtualList.prototype, \"eContainer\", void 0);\n__decorate([\n PostConstruct\n], VirtualList.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { KeyCode } from \"../constants/keyCode.mjs\";\nimport { Autowired } from \"../context/context.mjs\";\nimport { Events } from \"../eventKeys.mjs\";\nimport { setAriaActiveDescendant, setAriaControls, setAriaLabel } from \"../utils/aria.mjs\";\nimport { bindCellRendererToHtmlElement, clearElement } from \"../utils/dom.mjs\";\nimport { stopPropagationForAgGrid } from \"../utils/event.mjs\";\nimport { debounce } from \"../utils/function.mjs\";\nimport { fuzzySuggestions } from \"../utils/fuzzyMatch.mjs\";\nimport { exists } from \"../utils/generic.mjs\";\nimport { isEventFromPrintableCharacter } from \"../utils/keyboard.mjs\";\nimport { escapeString } from \"../utils/string.mjs\";\nimport { AgPickerField } from \"./agPickerField.mjs\";\nimport { RichSelectRow } from \"./agRichSelectRow.mjs\";\nimport { RefSelector } from \"./componentAnnotations.mjs\";\nimport { VirtualList } from \"./virtualList.mjs\";\nconst TEMPLATE = /* html */ `\n
\n
\n
\n
\n \n
\n
\n
`;\nexport class AgRichSelect extends AgPickerField {\n constructor(config) {\n var _a, _b;\n super(Object.assign(Object.assign({ pickerAriaLabelKey: 'ariaLabelRichSelectField', pickerAriaLabelValue: 'Rich Select Field', pickerType: 'ag-list', className: 'ag-rich-select', pickerIcon: 'smallDown', ariaRole: 'combobox', template: (_a = config === null || config === void 0 ? void 0 : config.template) !== null && _a !== void 0 ? _a : TEMPLATE, modalPicker: false }, config), { \n // maxPickerHeight needs to be set after expanding `config`\n maxPickerHeight: (_b = config === null || config === void 0 ? void 0 : config.maxPickerHeight) !== null && _b !== void 0 ? _b : 'calc(var(--ag-row-height) * 6.5)' }));\n this.searchString = '';\n this.highlightedItem = -1;\n this.lastRowHovered = -1;\n this.searchStringCreator = null;\n const { cellRowHeight, value, valueList, searchStringCreator } = config || {};\n if (cellRowHeight != null) {\n this.cellRowHeight = cellRowHeight;\n }\n if (value !== undefined) {\n this.value = value;\n }\n if (valueList != null) {\n this.values = valueList;\n }\n if (searchStringCreator) {\n this.searchStringCreator = searchStringCreator;\n }\n }\n postConstruct() {\n var _a;\n super.postConstruct();\n this.createLoadingElement();\n this.createListComponent();\n const { allowTyping, placeholder } = this.config;\n if (allowTyping) {\n this.eInput\n .setAutoComplete(false)\n .setInputPlaceholder(placeholder);\n this.eDisplayField.classList.add('ag-hidden');\n }\n else {\n this.eInput.setDisplayed(false);\n }\n this.eWrapper.tabIndex = (_a = this.gridOptionsService.getNum('tabIndex')) !== null && _a !== void 0 ? _a : 0;\n const { searchDebounceDelay = 300 } = this.config;\n this.clearSearchString = debounce(this.clearSearchString, searchDebounceDelay);\n this.renderSelectedValue();\n if (allowTyping) {\n this.eInput.onValueChange(value => this.searchTextFromString(value));\n this.addManagedListener(this.eWrapper, 'focus', this.onWrapperFocus.bind(this));\n }\n this.addManagedListener(this.eWrapper, 'focusout', this.onWrapperFocusOut.bind(this));\n }\n createLoadingElement() {\n const eDocument = this.gridOptionsService.getDocument();\n const translate = this.localeService.getLocaleTextFunc();\n const el = eDocument.createElement('div');\n el.classList.add('ag-loading-text');\n el.innerText = translate('loadingOoo', 'Loading...');\n this.eLoading = el;\n }\n createListComponent() {\n this.listComponent = this.createBean(new VirtualList({ cssIdentifier: 'rich-select' }));\n this.listComponent.setComponentCreator(this.createRowComponent.bind(this));\n this.listComponent.setParentComponent(this);\n this.addManagedListener(this.listComponent, Events.EVENT_FIELD_PICKER_VALUE_SELECTED, (e) => {\n this.onListValueSelected(e.value, e.fromEnterKey);\n });\n const { cellRowHeight } = this;\n if (cellRowHeight) {\n this.listComponent.setRowHeight(cellRowHeight);\n }\n const eListGui = this.listComponent.getGui();\n const eListAriaEl = this.listComponent.getAriaElement();\n this.addManagedListener(eListGui, 'mousemove', this.onPickerMouseMove.bind(this));\n this.addManagedListener(eListGui, 'mousedown', e => e.preventDefault());\n eListGui.classList.add('ag-rich-select-list');\n const listId = `ag-rich-select-list-${this.listComponent.getCompId()}`;\n eListAriaEl.setAttribute('id', listId);\n const translate = this.localeService.getLocaleTextFunc();\n const ariaLabel = translate(this.config.pickerAriaLabelKey, this.config.pickerAriaLabelValue);\n setAriaLabel(eListAriaEl, ariaLabel);\n setAriaControls(this.eWrapper, eListAriaEl);\n }\n renderSelectedValue() {\n const { value, eDisplayField, config } = this;\n const valueFormatted = this.config.valueFormatter ? this.config.valueFormatter(value) : value;\n if (config.allowTyping) {\n this.eInput.setValue(valueFormatted);\n return;\n }\n let userCompDetails;\n if (config.cellRenderer) {\n userCompDetails = this.userComponentFactory.getCellRendererDetails(this.config, {\n value,\n valueFormatted,\n api: this.gridOptionsService.api\n });\n }\n let userCompDetailsPromise;\n if (userCompDetails) {\n userCompDetailsPromise = userCompDetails.newAgStackInstance();\n }\n if (userCompDetailsPromise) {\n clearElement(eDisplayField);\n bindCellRendererToHtmlElement(userCompDetailsPromise, eDisplayField);\n userCompDetailsPromise.then(renderer => {\n this.addDestroyFunc(() => this.getContext().destroyBean(renderer));\n });\n }\n else {\n if (exists(this.value)) {\n eDisplayField.innerText = valueFormatted;\n eDisplayField.classList.remove('ag-display-as-placeholder');\n }\n else {\n const { placeholder } = config;\n if (exists(placeholder)) {\n eDisplayField.innerHTML = `${escapeString(placeholder)}`;\n eDisplayField.classList.add('ag-display-as-placeholder');\n }\n else {\n clearElement(eDisplayField);\n }\n }\n }\n }\n getCurrentValueIndex() {\n const { currentList, value } = this;\n if (value == null) {\n return -1;\n }\n for (let i = 0; i < currentList.length; i++) {\n if (currentList[i] === value) {\n return i;\n }\n }\n return -1;\n }\n highlightFilterMatch() {\n var _a;\n (_a = this.listComponent) === null || _a === void 0 ? void 0 : _a.forEachRenderedRow((cmp, idx) => {\n cmp.highlightString(this.searchString);\n });\n }\n highlightSelectedValue(index) {\n var _a;\n if (index == null) {\n index = this.getCurrentValueIndex();\n }\n this.highlightedItem = index;\n (_a = this.listComponent) === null || _a === void 0 ? void 0 : _a.forEachRenderedRow((cmp, idx) => {\n const highlighted = index === -1 ? false : this.highlightedItem === idx;\n cmp.updateHighlighted(highlighted);\n });\n }\n setRowHeight(height) {\n if (height !== this.cellRowHeight) {\n this.cellRowHeight = height;\n }\n if (this.listComponent) {\n this.listComponent.setRowHeight(height);\n }\n }\n createPickerComponent() {\n const { values } = this;\n if (values) {\n this.setValueList({ valueList: values });\n }\n // do not create the picker every time to save state\n return this.listComponent;\n }\n setSearchStringCreator(searchStringFn) {\n this.searchStringCreator = searchStringFn;\n }\n setValueList(params) {\n const { valueList, refresh } = params;\n if (!this.listComponent) {\n return;\n }\n if (this.currentList === valueList) {\n return;\n }\n this.currentList = valueList;\n this.listComponent.setModel({\n getRowCount: () => valueList.length,\n getRow: (index) => valueList[index]\n });\n if (refresh) {\n // if `values` is not present, it means the valuesList was set asynchronously\n if (!this.values) {\n this.values = valueList;\n if (this.isPickerDisplayed) {\n this.showCurrentValueInPicker();\n }\n }\n else {\n this.listComponent.refresh();\n }\n }\n }\n showPicker() {\n super.showPicker();\n this.showCurrentValueInPicker();\n }\n showCurrentValueInPicker() {\n var _a, _b;\n if (!this.listComponent) {\n return;\n }\n if (!this.currentList) {\n if (this.isPickerDisplayed && this.eLoading) {\n this.listComponent.appendChild(this.eLoading);\n }\n return;\n }\n if ((_a = this.eLoading) === null || _a === void 0 ? void 0 : _a.offsetParent) {\n (_b = this.eLoading.parentElement) === null || _b === void 0 ? void 0 : _b.removeChild(this.eLoading);\n }\n const currentValueIndex = this.getCurrentValueIndex();\n if (currentValueIndex !== -1) {\n // make sure the virtual list has been sized correctly\n this.listComponent.refresh();\n this.listComponent.ensureIndexVisible(currentValueIndex);\n // this second call to refresh is necessary to force scrolled elements\n // to be rendered with the correct index info.\n this.listComponent.refresh(true);\n this.highlightSelectedValue(currentValueIndex);\n }\n else {\n this.listComponent.refresh();\n }\n }\n beforeHidePicker() {\n this.highlightedItem = -1;\n super.beforeHidePicker();\n }\n onWrapperFocus(e) {\n if (this.eInput) {\n this.eInput.getFocusableElement().focus();\n }\n }\n onWrapperFocusOut(e) {\n if (!this.eWrapper.contains(e.relatedTarget)) {\n this.hidePicker();\n }\n }\n buildSearchStringFromKeyboardEvent(searchKey) {\n let { key } = searchKey;\n if (key === KeyCode.BACKSPACE) {\n this.searchString = this.searchString.slice(0, -1);\n key = '';\n }\n else if (!isEventFromPrintableCharacter(searchKey)) {\n return;\n }\n searchKey.preventDefault();\n this.searchTextFromCharacter(key);\n }\n searchTextFromCharacter(char) {\n this.searchString += char;\n this.runSearch();\n this.clearSearchString();\n }\n searchTextFromString(str) {\n if (str == null) {\n str = '';\n }\n this.searchString = str;\n this.runSearch();\n }\n buildSearchStrings(values) {\n const { valueFormatter = (value => value) } = this.config;\n let searchStrings;\n if (typeof values[0] === 'number' || typeof values[0] === 'string') {\n searchStrings = values.map(v => valueFormatter(v));\n }\n else if (typeof values[0] === 'object' && this.searchStringCreator) {\n searchStrings = this.searchStringCreator(values);\n }\n return searchStrings;\n }\n getSuggestionsAndFilteredValues(searchValue, valueList) {\n let suggestions = [];\n let filteredValues = [];\n if (!searchValue.length) {\n return { suggestions, filteredValues };\n }\n ;\n const { allowTyping, searchType = 'fuzzy', filterList } = this.config;\n const shouldFilterList = filterList && allowTyping;\n if (searchType === 'fuzzy') {\n const fuzzySearchResult = fuzzySuggestions(this.searchString, valueList, true);\n suggestions = fuzzySearchResult.values;\n const indices = fuzzySearchResult.indices;\n if (shouldFilterList && indices.length) {\n for (let i = 0; i < indices.length; i++) {\n filteredValues.push(this.values[indices[i]]);\n }\n }\n }\n else {\n suggestions = valueList.filter((val, idx) => {\n const currentValue = val.toLocaleLowerCase();\n const valueToMatch = this.searchString.toLocaleLowerCase();\n const isMatch = searchType === 'match' ? currentValue.startsWith(valueToMatch) : currentValue.indexOf(valueToMatch) !== -1;\n if (shouldFilterList && isMatch) {\n filteredValues.push(this.values[idx]);\n }\n return isMatch;\n });\n }\n return { suggestions, filteredValues };\n }\n filterListModel(filteredValues) {\n const { allowTyping, filterList } = this.config;\n if (!allowTyping || !filterList) {\n return;\n }\n this.setValueList({ valueList: filteredValues, refresh: true });\n }\n runSearch() {\n var _a, _b, _c;\n const { values } = this;\n const searchStrings = this.buildSearchStrings(values);\n if (!searchStrings) {\n this.highlightSelectedValue(-1);\n return;\n }\n const { suggestions, filteredValues } = this.getSuggestionsAndFilteredValues(this.searchString, searchStrings);\n const { allowTyping, filterList, highlightMatch, searchType = 'fuzzy' } = this.config;\n const filterValueLen = filteredValues.length;\n const shouldFilter = !!(allowTyping && filterList && this.searchString !== '');\n if (shouldFilter) {\n this.filterListModel(shouldFilter ? filteredValues : values);\n }\n if (suggestions.length) {\n const topSuggestionIndex = shouldFilter ? 0 : searchStrings.indexOf(suggestions[0]);\n this.selectListItem(topSuggestionIndex);\n if (highlightMatch && searchType !== 'fuzzy') {\n this.highlightFilterMatch();\n }\n }\n else {\n this.highlightSelectedValue(-1);\n if (!shouldFilter || filterValueLen) {\n (_a = this.listComponent) === null || _a === void 0 ? void 0 : _a.ensureIndexVisible(0);\n }\n else if (shouldFilter) {\n this.getAriaElement().removeAttribute('data-active-option');\n const eListAriaEl = (_b = this.listComponent) === null || _b === void 0 ? void 0 : _b.getAriaElement();\n if (eListAriaEl) {\n setAriaActiveDescendant(eListAriaEl, null);\n }\n }\n }\n const eListGui = (_c = this.listComponent) === null || _c === void 0 ? void 0 : _c.getGui();\n eListGui === null || eListGui === void 0 ? void 0 : eListGui.classList.toggle('ag-hidden', shouldFilter && !filterValueLen);\n }\n clearSearchString() {\n this.searchString = '';\n }\n selectListItem(index, preventUnnecessaryScroll, skipRefresh) {\n if (!this.isPickerDisplayed || !this.listComponent || index < 0 || index >= this.currentList.length) {\n return;\n }\n const wasScrolled = this.listComponent.ensureIndexVisible(index, !preventUnnecessaryScroll);\n if (wasScrolled && !skipRefresh) {\n this.listComponent.refresh(true);\n }\n this.highlightSelectedValue(index);\n }\n setValue(value, silent, fromPicker) {\n const index = this.currentList.indexOf(value);\n if (index === -1) {\n return this;\n }\n this.value = value;\n if (!fromPicker) {\n this.selectListItem(index);\n }\n this.renderSelectedValue();\n return super.setValue(value, silent);\n }\n createRowComponent(value) {\n const row = new RichSelectRow(this.config, this.eWrapper);\n row.setParentComponent(this.listComponent);\n this.getContext().createBean(row);\n row.setState(value);\n const { highlightMatch, searchType = 'fuzzy' } = this.config;\n if (highlightMatch && searchType !== 'fuzzy') {\n row.highlightString(this.searchString);\n }\n return row;\n }\n getRowForMouseEvent(e) {\n const { listComponent } = this;\n if (!listComponent) {\n return -1;\n }\n const eGui = listComponent === null || listComponent === void 0 ? void 0 : listComponent.getGui();\n const rect = eGui.getBoundingClientRect();\n const scrollTop = listComponent.getScrollTop();\n const mouseY = e.clientY - rect.top + scrollTop;\n return Math.floor(mouseY / listComponent.getRowHeight());\n }\n onPickerMouseMove(e) {\n if (!this.listComponent) {\n return;\n }\n const row = this.getRowForMouseEvent(e);\n if (row !== -1 && row != this.lastRowHovered) {\n this.lastRowHovered = row;\n this.selectListItem(row, true, true);\n }\n }\n onNavigationKeyDown(event, key) {\n // if we don't preventDefault the page body and/or grid scroll will move.\n event.preventDefault();\n const isDown = key === KeyCode.DOWN;\n if (!this.isPickerDisplayed && isDown) {\n this.showPicker();\n return;\n }\n const oldIndex = this.highlightedItem;\n const diff = isDown ? 1 : -1;\n const newIndex = oldIndex === -1 ? 0 : oldIndex + diff;\n this.selectListItem(newIndex, false, true);\n }\n onEnterKeyDown(e) {\n if (!this.isPickerDisplayed) {\n return;\n }\n e.preventDefault();\n this.onListValueSelected(this.currentList[this.highlightedItem], true);\n }\n onTabKeyDown() {\n if (!this.isPickerDisplayed) {\n return;\n }\n this.setValue(this.currentList[this.highlightedItem], false, true);\n }\n onListValueSelected(value, fromEnterKey) {\n this.setValue(value, false, true);\n this.dispatchPickerEvent(value, fromEnterKey);\n this.hidePicker();\n }\n dispatchPickerEvent(value, fromEnterKey) {\n const event = {\n type: Events.EVENT_FIELD_PICKER_VALUE_SELECTED,\n fromEnterKey,\n value\n };\n this.dispatchEvent(event);\n }\n getFocusableElement() {\n const { allowTyping } = this.config;\n if (allowTyping) {\n return this.eInput.getFocusableElement();\n }\n return super.getFocusableElement();\n }\n onKeyDown(event) {\n const key = event.key;\n const { allowTyping } = this.config;\n switch (key) {\n case KeyCode.LEFT:\n case KeyCode.RIGHT:\n case KeyCode.PAGE_HOME:\n case KeyCode.PAGE_END:\n if (!allowTyping) {\n event.preventDefault();\n }\n break;\n case KeyCode.PAGE_UP:\n case KeyCode.PAGE_DOWN:\n event.preventDefault();\n break;\n case KeyCode.DOWN:\n case KeyCode.UP:\n this.onNavigationKeyDown(event, key);\n break;\n case KeyCode.ESCAPE:\n if (this.isPickerDisplayed) {\n event.preventDefault();\n stopPropagationForAgGrid(event);\n this.hidePicker();\n }\n break;\n case KeyCode.ENTER:\n this.onEnterKeyDown(event);\n break;\n case KeyCode.TAB:\n this.onTabKeyDown();\n break;\n default:\n if (!allowTyping) {\n this.buildSearchStringFromKeyboardEvent(event);\n }\n }\n }\n destroy() {\n if (this.listComponent) {\n this.destroyBean(this.listComponent);\n this.listComponent = undefined;\n }\n this.eLoading = undefined;\n super.destroy();\n }\n}\n__decorate([\n Autowired('userComponentFactory')\n], AgRichSelect.prototype, \"userComponentFactory\", void 0);\n__decorate([\n RefSelector('eInput')\n], AgRichSelect.prototype, \"eInput\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { RefSelector } from \"./componentAnnotations.mjs\";\nimport { AgAbstractLabel } from \"./agAbstractLabel.mjs\";\nimport { PostConstruct } from \"../context/context.mjs\";\nimport { Events } from \"../eventKeys.mjs\";\nexport class AgSlider extends AgAbstractLabel {\n constructor(config) {\n super(config, AgSlider.TEMPLATE);\n this.labelAlignment = 'top';\n }\n init() {\n this.eSlider.addCssClass('ag-slider-field');\n }\n onValueChange(callbackFn) {\n const eventChanged = Events.EVENT_FIELD_VALUE_CHANGED;\n this.addManagedListener(this.eText, eventChanged, () => {\n const textValue = parseFloat(this.eText.getValue());\n this.eSlider.setValue(textValue.toString(), true);\n callbackFn(textValue || 0);\n });\n this.addManagedListener(this.eSlider, eventChanged, () => {\n const sliderValue = this.eSlider.getValue();\n this.eText.setValue(sliderValue, true);\n callbackFn(parseFloat(sliderValue));\n });\n return this;\n }\n setSliderWidth(width) {\n this.eSlider.setWidth(width);\n return this;\n }\n setTextFieldWidth(width) {\n this.eText.setWidth(width);\n return this;\n }\n setMinValue(minValue) {\n this.eSlider.setMinValue(minValue);\n this.eText.setMin(minValue);\n return this;\n }\n setMaxValue(maxValue) {\n this.eSlider.setMaxValue(maxValue);\n this.eText.setMax(maxValue);\n return this;\n }\n getValue() {\n return this.eText.getValue();\n }\n setValue(value) {\n if (this.getValue() === value) {\n return this;\n }\n this.eText.setValue(value, true);\n this.eSlider.setValue(value, true);\n this.dispatchEvent({ type: Events.EVENT_FIELD_VALUE_CHANGED });\n return this;\n }\n setStep(step) {\n this.eSlider.setStep(step);\n this.eText.setStep(step);\n return this;\n }\n}\nAgSlider.TEMPLATE = `
\n \n
\n \n \n
\n
`;\n__decorate([\n RefSelector('eLabel')\n], AgSlider.prototype, \"eLabel\", void 0);\n__decorate([\n RefSelector('eSlider')\n], AgSlider.prototype, \"eSlider\", void 0);\n__decorate([\n RefSelector('eText')\n], AgSlider.prototype, \"eText\", void 0);\n__decorate([\n PostConstruct\n], AgSlider.prototype, \"init\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from './component.mjs';\nimport { RefSelector } from './componentAnnotations.mjs';\nimport { PostConstruct } from '../context/context.mjs';\nimport { createIcon } from '../utils/icon.mjs';\nimport { setDisplayed } from '../utils/dom.mjs';\nimport { KeyCode } from '../constants/keyCode.mjs';\nimport { setAriaExpanded } from '../utils/aria.mjs';\nexport class AgGroupComponent extends Component {\n constructor(params = {}) {\n super(AgGroupComponent.getTemplate(params));\n this.suppressEnabledCheckbox = true;\n this.suppressOpenCloseIcons = false;\n const { title, enabled, items, suppressEnabledCheckbox, suppressOpenCloseIcons } = params;\n this.title = title;\n this.cssIdentifier = params.cssIdentifier || 'default';\n this.enabled = enabled != null ? enabled : true;\n this.items = items || [];\n this.alignItems = params.alignItems || 'center';\n if (suppressEnabledCheckbox != null) {\n this.suppressEnabledCheckbox = suppressEnabledCheckbox;\n }\n if (suppressOpenCloseIcons != null) {\n this.suppressOpenCloseIcons = suppressOpenCloseIcons;\n }\n }\n static getTemplate(params) {\n const cssIdentifier = params.cssIdentifier || 'default';\n const direction = params.direction || 'vertical';\n return /* html */ `
\n
\n \n \n \n
\n
\n \n
\n
\n
`;\n }\n postConstruct() {\n if (this.items.length) {\n const initialItems = this.items;\n this.items = [];\n this.addItems(initialItems);\n }\n const localeTextFunc = this.localeService.getLocaleTextFunc();\n this.cbGroupEnabled.setLabel(localeTextFunc('enabled', 'Enabled'));\n if (this.title) {\n this.setTitle(this.title);\n }\n if (this.enabled) {\n this.setEnabled(this.enabled);\n }\n this.setAlignItems(this.alignItems);\n this.hideEnabledCheckbox(this.suppressEnabledCheckbox);\n this.hideOpenCloseIcons(this.suppressOpenCloseIcons);\n this.setupExpandContract();\n this.refreshAriaStatus();\n this.refreshChildDisplay();\n }\n setupExpandContract() {\n this.eGroupClosedIcon.appendChild(createIcon('columnSelectClosed', this.gridOptionsService, null));\n this.eGroupOpenedIcon.appendChild(createIcon('columnSelectOpen', this.gridOptionsService, null));\n this.addManagedListener(this.eTitleBar, 'click', () => this.toggleGroupExpand());\n this.addManagedListener(this.eTitleBar, 'keydown', (e) => {\n switch (e.key) {\n case KeyCode.ENTER:\n case KeyCode.SPACE:\n e.preventDefault();\n this.toggleGroupExpand();\n break;\n case KeyCode.RIGHT:\n case KeyCode.LEFT:\n e.preventDefault();\n this.toggleGroupExpand(e.key === KeyCode.RIGHT);\n break;\n }\n });\n }\n refreshAriaStatus() {\n if (!this.suppressOpenCloseIcons) {\n setAriaExpanded(this.eTitleBar, this.expanded);\n }\n }\n refreshChildDisplay() {\n const showIcon = !this.suppressOpenCloseIcons;\n setDisplayed(this.eToolbar, this.expanded && !this.suppressEnabledCheckbox);\n setDisplayed(this.eGroupOpenedIcon, showIcon && this.expanded);\n setDisplayed(this.eGroupClosedIcon, showIcon && !this.expanded);\n }\n isExpanded() {\n return this.expanded;\n }\n setAlignItems(alignment) {\n if (this.alignItems !== alignment) {\n this.removeCssClass(`ag-group-item-alignment-${this.alignItems}`);\n }\n this.alignItems = alignment;\n const newCls = `ag-group-item-alignment-${this.alignItems}`;\n this.addCssClass(newCls);\n return this;\n }\n toggleGroupExpand(expanded) {\n if (this.suppressOpenCloseIcons) {\n this.expanded = true;\n this.refreshChildDisplay();\n setDisplayed(this.eContainer, true);\n return this;\n }\n expanded = expanded != null ? expanded : !this.expanded;\n if (this.expanded === expanded) {\n return this;\n }\n this.expanded = expanded;\n this.refreshAriaStatus();\n this.refreshChildDisplay();\n setDisplayed(this.eContainer, expanded);\n this.dispatchEvent({ type: this.expanded ? AgGroupComponent.EVENT_EXPANDED : AgGroupComponent.EVENT_COLLAPSED });\n return this;\n }\n addItems(items) {\n items.forEach(item => this.addItem(item));\n }\n addItem(item) {\n const container = this.eContainer;\n const el = item instanceof Component ? item.getGui() : item;\n el.classList.add('ag-group-item', `ag-${this.cssIdentifier}-group-item`);\n container.appendChild(el);\n this.items.push(el);\n }\n hideItem(hide, index) {\n const itemToHide = this.items[index];\n setDisplayed(itemToHide, !hide);\n }\n setTitle(title) {\n this.eTitle.innerText = title;\n return this;\n }\n addCssClassToTitleBar(cssClass) {\n this.eTitleBar.classList.add(cssClass);\n }\n setEnabled(enabled, skipToggle) {\n this.enabled = enabled;\n this.refreshDisabledStyles();\n this.toggleGroupExpand(enabled);\n if (!skipToggle) {\n this.cbGroupEnabled.setValue(enabled);\n }\n return this;\n }\n isEnabled() {\n return this.enabled;\n }\n onEnableChange(callbackFn) {\n this.cbGroupEnabled.onValueChange((newSelection) => {\n this.setEnabled(newSelection, true);\n callbackFn(newSelection);\n });\n return this;\n }\n hideEnabledCheckbox(hide) {\n this.suppressEnabledCheckbox = hide;\n this.refreshChildDisplay();\n this.refreshDisabledStyles();\n return this;\n }\n hideOpenCloseIcons(hide) {\n this.suppressOpenCloseIcons = hide;\n if (hide) {\n this.toggleGroupExpand(true);\n }\n return this;\n }\n refreshDisabledStyles() {\n this.addOrRemoveCssClass('ag-disabled', !this.enabled);\n if (this.suppressEnabledCheckbox && !this.enabled) {\n this.eTitleBar.classList.add('ag-disabled-group-title-bar');\n this.eTitleBar.removeAttribute('tabindex');\n }\n else {\n this.eTitleBar.classList.remove('ag-disabled-group-title-bar');\n this.eTitleBar.setAttribute('tabindex', '0');\n }\n this.eContainer.classList.toggle('ag-disabled-group-container', !this.enabled);\n }\n}\nAgGroupComponent.EVENT_EXPANDED = 'expanded';\nAgGroupComponent.EVENT_COLLAPSED = 'collapsed';\n__decorate([\n RefSelector('eTitleBar')\n], AgGroupComponent.prototype, \"eTitleBar\", void 0);\n__decorate([\n RefSelector('eGroupOpenedIcon')\n], AgGroupComponent.prototype, \"eGroupOpenedIcon\", void 0);\n__decorate([\n RefSelector('eGroupClosedIcon')\n], AgGroupComponent.prototype, \"eGroupClosedIcon\", void 0);\n__decorate([\n RefSelector('eToolbar')\n], AgGroupComponent.prototype, \"eToolbar\", void 0);\n__decorate([\n RefSelector('cbGroupEnabled')\n], AgGroupComponent.prototype, \"cbGroupEnabled\", void 0);\n__decorate([\n RefSelector('eTitle')\n], AgGroupComponent.prototype, \"eTitle\", void 0);\n__decorate([\n RefSelector('eContainer')\n], AgGroupComponent.prototype, \"eContainer\", void 0);\n__decorate([\n PostConstruct\n], AgGroupComponent.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from \"../context/context.mjs\";\nimport { AgMenuItemComponent } from \"./agMenuItemComponent.mjs\";\nimport { TabGuardComp } from \"./tabGuardComp.mjs\";\nimport { KeyCode } from \"../constants/keyCode.mjs\";\nimport { loadTemplate } from \"../utils/dom.mjs\";\nimport { last } from \"../utils/array.mjs\";\nimport { setAriaLevel } from \"../utils/aria.mjs\";\nexport class AgMenuList extends TabGuardComp {\n constructor(level = 1) {\n super(/* html */ `
`);\n this.level = level;\n this.menuItems = [];\n }\n postConstruct() {\n this.initialiseTabGuard({\n onTabKeyDown: e => this.onTabKeyDown(e),\n handleKeyDown: e => this.handleKeyDown(e)\n });\n }\n onTabKeyDown(e) {\n const parent = this.getParentComponent();\n const parentGui = parent && parent.getGui();\n const isManaged = parentGui && parentGui.classList.contains('ag-focus-managed');\n if (!isManaged) {\n e.preventDefault();\n }\n if (e.shiftKey) {\n this.closeIfIsChild(e);\n }\n }\n handleKeyDown(e) {\n switch (e.key) {\n case KeyCode.UP:\n case KeyCode.RIGHT:\n case KeyCode.DOWN:\n case KeyCode.LEFT:\n e.preventDefault();\n this.handleNavKey(e.key);\n break;\n case KeyCode.ESCAPE:\n const topMenu = this.findTopMenu();\n if (topMenu) {\n this.focusService.focusInto(topMenu.getGui());\n }\n break;\n }\n }\n clearActiveItem() {\n if (this.activeMenuItem) {\n this.activeMenuItem.deactivate();\n this.activeMenuItem = null;\n }\n }\n addMenuItems(menuItems) {\n if (menuItems == null) {\n return;\n }\n menuItems.forEach(menuItemOrString => {\n if (menuItemOrString === 'separator') {\n this.addSeparator();\n }\n else if (typeof menuItemOrString === 'string') {\n console.warn(`AG Grid: unrecognised menu item ${menuItemOrString}`);\n }\n else {\n this.addItem(menuItemOrString);\n }\n });\n }\n addItem(menuItemDef) {\n const menuItem = this.createManagedBean(new AgMenuItemComponent(Object.assign(Object.assign({}, menuItemDef), { isAnotherSubMenuOpen: () => this.menuItems.some(m => m.isSubMenuOpen()) })));\n menuItem.setParentComponent(this);\n setAriaLevel(menuItem.getGui(), this.level);\n this.menuItems.push(menuItem);\n this.appendChild(menuItem.getGui());\n this.addManagedListener(menuItem, AgMenuItemComponent.EVENT_MENU_ITEM_SELECTED, (event) => {\n this.dispatchEvent(event);\n });\n this.addManagedListener(menuItem, AgMenuItemComponent.EVENT_MENU_ITEM_ACTIVATED, (event) => {\n if (this.activeMenuItem && this.activeMenuItem !== event.menuItem) {\n this.activeMenuItem.deactivate();\n }\n this.activeMenuItem = event.menuItem;\n });\n }\n activateFirstItem() {\n const item = this.menuItems.filter(currentItem => !currentItem.isDisabled())[0];\n if (!item) {\n return;\n }\n item.activate();\n }\n addSeparator() {\n const separatorHtml = /* html */ `\n
\n
\n
\n
\n
\n
`;\n this.appendChild(loadTemplate(separatorHtml));\n }\n findTopMenu() {\n let parent = this.getParentComponent();\n if (!parent && this instanceof AgMenuList) {\n return this;\n }\n while (true) {\n const nextParent = parent && parent.getParentComponent && parent.getParentComponent();\n if (!nextParent || (!(nextParent instanceof AgMenuList || nextParent instanceof AgMenuItemComponent))) {\n break;\n }\n parent = nextParent;\n }\n return parent instanceof AgMenuList ? parent : undefined;\n }\n handleNavKey(key) {\n switch (key) {\n case KeyCode.UP:\n case KeyCode.DOWN:\n const nextItem = this.findNextItem(key === KeyCode.UP);\n if (nextItem && nextItem !== this.activeMenuItem) {\n nextItem.activate();\n }\n return;\n }\n const left = this.gridOptionsService.is('enableRtl') ? KeyCode.RIGHT : KeyCode.LEFT;\n if (key === left) {\n this.closeIfIsChild();\n }\n else {\n this.openChild();\n }\n }\n closeIfIsChild(e) {\n const parentItem = this.getParentComponent();\n if (parentItem && parentItem instanceof AgMenuItemComponent) {\n if (e) {\n e.preventDefault();\n }\n parentItem.closeSubMenu();\n parentItem.getGui().focus();\n }\n }\n openChild() {\n if (this.activeMenuItem) {\n this.activeMenuItem.openSubMenu(true);\n }\n }\n findNextItem(up) {\n const items = this.menuItems.filter(item => !item.isDisabled());\n if (!items.length) {\n return;\n }\n if (!this.activeMenuItem) {\n return up ? last(items) : items[0];\n }\n if (up) {\n items.reverse();\n }\n let nextItem;\n let foundCurrent = false;\n for (let i = 0; i < items.length; i++) {\n const item = items[i];\n if (!foundCurrent) {\n if (item === this.activeMenuItem) {\n foundCurrent = true;\n }\n continue;\n }\n nextItem = item;\n break;\n }\n return nextItem || this.activeMenuItem;\n }\n destroy() {\n this.clearActiveItem();\n super.destroy();\n }\n}\n__decorate([\n Autowired('focusService')\n], AgMenuList.prototype, \"focusService\", void 0);\n__decorate([\n PostConstruct\n], AgMenuList.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PostConstruct } from '../context/context.mjs';\nimport { KeyCode } from '../constants/keyCode.mjs';\nimport { TabGuardComp } from './tabGuardComp.mjs';\nexport class AgMenuPanel extends TabGuardComp {\n constructor(wrappedComponent) {\n super();\n this.wrappedComponent = wrappedComponent;\n this.setTemplateFromElement(wrappedComponent.getGui());\n }\n postConstruct() {\n this.initialiseTabGuard({\n onTabKeyDown: e => this.onTabKeyDown(e),\n handleKeyDown: e => this.handleKeyDown(e)\n });\n }\n handleKeyDown(e) {\n if (e.key === KeyCode.ESCAPE) {\n this.closePanel();\n }\n }\n onTabKeyDown(e) {\n if (e.defaultPrevented) {\n return;\n }\n this.closePanel();\n e.preventDefault();\n }\n closePanel() {\n const menuItem = this.parentComponent;\n menuItem.closeSubMenu();\n setTimeout(() => menuItem.getGui().focus(), 0);\n }\n}\n__decorate([\n PostConstruct\n], AgMenuPanel.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired } from '../context/context.mjs';\nimport { AgMenuList } from './agMenuList.mjs';\nimport { AgMenuPanel } from './agMenuPanel.mjs';\nimport { Component } from './component.mjs';\nimport { KeyCode } from '../constants/keyCode.mjs';\nimport { PostConstruct } from '../context/context.mjs';\nimport { createIconNoSpan } from '../utils/icon.mjs';\nimport { isNodeOrElement, loadTemplate } from '../utils/dom.mjs';\nimport { CustomTooltipFeature } from './customTooltipFeature.mjs';\nimport { getAriaLevel, setAriaDisabled, setAriaExpanded } from '../utils/aria.mjs';\nexport class AgMenuItemComponent extends Component {\n constructor(params) {\n super();\n this.params = params;\n this.isActive = false;\n this.subMenuIsOpen = false;\n this.setTemplate(/* html */ `
`);\n }\n init() {\n this.addIcon();\n this.addName();\n this.addShortcut();\n this.addSubMenu();\n this.addTooltip();\n const eGui = this.getGui();\n if (this.params.disabled) {\n this.addCssClass(this.getClassName('disabled'));\n setAriaDisabled(eGui, true);\n }\n else {\n this.addGuiEventListener('click', e => this.onItemSelected(e));\n this.addGuiEventListener('keydown', (e) => {\n if (e.key === KeyCode.ENTER || e.key === KeyCode.SPACE) {\n e.preventDefault();\n this.onItemSelected(e);\n }\n });\n this.addGuiEventListener('mousedown', e => {\n // Prevent event bubbling to other event handlers such as PopupService triggering\n // premature closing of any open sub-menu popup.\n e.stopPropagation();\n e.preventDefault();\n });\n this.addGuiEventListener('mouseenter', () => this.onMouseEnter());\n this.addGuiEventListener('mouseleave', () => this.onMouseLeave());\n }\n if (this.params.cssClasses) {\n this.params.cssClasses.forEach(it => this.addCssClass(it));\n }\n }\n isDisabled() {\n return !!this.params.disabled;\n }\n openSubMenu(activateFirstItem = false) {\n this.closeSubMenu();\n if (!this.params.subMenu) {\n return;\n }\n const ePopup = loadTemplate(/* html */ `
`);\n let destroySubMenu;\n if (this.params.subMenu instanceof Array) {\n const currentLevel = getAriaLevel(this.getGui());\n const nextLevel = isNaN(currentLevel) ? 1 : (currentLevel + 1);\n const childMenu = this.createBean(new AgMenuList(nextLevel));\n childMenu.setParentComponent(this);\n childMenu.addMenuItems(this.params.subMenu);\n ePopup.appendChild(childMenu.getGui());\n // bubble menu item selected events\n this.addManagedListener(childMenu, AgMenuItemComponent.EVENT_MENU_ITEM_SELECTED, e => this.dispatchEvent(e));\n childMenu.addGuiEventListener('mouseenter', () => this.cancelDeactivate());\n destroySubMenu = () => this.destroyBean(childMenu);\n if (activateFirstItem) {\n setTimeout(() => childMenu.activateFirstItem(), 0);\n }\n }\n else {\n const { subMenu } = this.params;\n const menuPanel = this.createBean(new AgMenuPanel(subMenu));\n menuPanel.setParentComponent(this);\n const subMenuGui = menuPanel.getGui();\n const mouseEvent = 'mouseenter';\n const mouseEnterListener = () => this.cancelDeactivate();\n subMenuGui.addEventListener(mouseEvent, mouseEnterListener);\n destroySubMenu = () => subMenuGui.removeEventListener(mouseEvent, mouseEnterListener);\n ePopup.appendChild(subMenuGui);\n if (subMenu.afterGuiAttached) {\n setTimeout(() => subMenu.afterGuiAttached(), 0);\n }\n }\n const eGui = this.getGui();\n const positionCallback = this.popupService.positionPopupForMenu.bind(this.popupService, { eventSource: eGui, ePopup });\n const translate = this.localeService.getLocaleTextFunc();\n const addPopupRes = this.popupService.addPopup({\n modal: true,\n eChild: ePopup,\n positionCallback: positionCallback,\n anchorToElement: eGui,\n ariaLabel: translate('ariaLabelSubMenu', 'SubMenu')\n });\n this.subMenuIsOpen = true;\n setAriaExpanded(eGui, true);\n this.hideSubMenu = () => {\n if (addPopupRes) {\n addPopupRes.hideFunc();\n }\n this.subMenuIsOpen = false;\n setAriaExpanded(eGui, false);\n destroySubMenu();\n };\n }\n closeSubMenu() {\n if (!this.hideSubMenu) {\n return;\n }\n this.hideSubMenu();\n this.hideSubMenu = null;\n setAriaExpanded(this.getGui(), false);\n }\n isSubMenuOpen() {\n return this.subMenuIsOpen;\n }\n activate(openSubMenu) {\n this.cancelActivate();\n if (this.params.disabled) {\n return;\n }\n this.isActive = true;\n this.addCssClass(this.getClassName('active'));\n this.getGui().focus();\n if (openSubMenu && this.params.subMenu) {\n window.setTimeout(() => {\n if (this.isAlive() && this.isActive) {\n this.openSubMenu();\n }\n }, 300);\n }\n this.onItemActivated();\n }\n deactivate() {\n this.cancelDeactivate();\n this.removeCssClass(this.getClassName('active'));\n this.isActive = false;\n if (this.subMenuIsOpen) {\n this.hideSubMenu();\n }\n }\n addIcon() {\n if (!this.params.checked && !this.params.icon && this.params.isCompact) {\n return;\n }\n const icon = loadTemplate(/* html */ ``);\n if (this.params.checked) {\n icon.appendChild(createIconNoSpan('check', this.gridOptionsService));\n }\n else if (this.params.icon) {\n if (isNodeOrElement(this.params.icon)) {\n icon.appendChild(this.params.icon);\n }\n else if (typeof this.params.icon === 'string') {\n icon.innerHTML = this.params.icon;\n }\n else {\n console.warn('AG Grid: menu item icon must be DOM node or string');\n }\n }\n this.getGui().appendChild(icon);\n }\n addName() {\n if (!this.params.name && this.params.isCompact) {\n return;\n }\n const name = loadTemplate(/* html */ `${this.params.name || ''}`);\n this.getGui().appendChild(name);\n }\n addTooltip() {\n if (!this.params.tooltip) {\n return;\n }\n this.tooltip = this.params.tooltip;\n if (this.gridOptionsService.is('enableBrowserTooltips')) {\n this.getGui().setAttribute('title', this.tooltip);\n }\n else {\n this.createManagedBean(new CustomTooltipFeature(this));\n }\n }\n getTooltipParams() {\n return {\n location: 'menu',\n value: this.tooltip\n };\n }\n addShortcut() {\n if (!this.params.shortcut && this.params.isCompact) {\n return;\n }\n const shortcut = loadTemplate(/* html */ `${this.params.shortcut || ''}`);\n this.getGui().appendChild(shortcut);\n }\n addSubMenu() {\n if (!this.params.subMenu && this.params.isCompact) {\n return;\n }\n const pointer = loadTemplate(/* html */ ``);\n const eGui = this.getGui();\n if (this.params.subMenu) {\n const iconName = this.gridOptionsService.is('enableRtl') ? 'smallLeft' : 'smallRight';\n setAriaExpanded(eGui, false);\n pointer.appendChild(createIconNoSpan(iconName, this.gridOptionsService));\n }\n eGui.appendChild(pointer);\n }\n onItemSelected(event) {\n if (this.params.action) {\n this.params.action();\n }\n else {\n this.openSubMenu(event && event.type === 'keydown');\n }\n if (this.params.subMenu && !this.params.action) {\n return;\n }\n const e = {\n type: AgMenuItemComponent.EVENT_MENU_ITEM_SELECTED,\n action: this.params.action,\n checked: this.params.checked,\n cssClasses: this.params.cssClasses,\n disabled: this.params.disabled,\n icon: this.params.icon,\n name: this.params.name,\n shortcut: this.params.shortcut,\n subMenu: this.params.subMenu,\n tooltip: this.params.tooltip,\n event\n };\n this.dispatchEvent(e);\n }\n onItemActivated() {\n const event = {\n type: AgMenuItemComponent.EVENT_MENU_ITEM_ACTIVATED,\n menuItem: this,\n };\n this.dispatchEvent(event);\n }\n cancelActivate() {\n if (this.activateTimeoutId) {\n window.clearTimeout(this.activateTimeoutId);\n this.activateTimeoutId = 0;\n }\n }\n cancelDeactivate() {\n if (this.deactivateTimeoutId) {\n window.clearTimeout(this.deactivateTimeoutId);\n this.deactivateTimeoutId = 0;\n }\n }\n onMouseEnter() {\n this.cancelDeactivate();\n if (this.params.isAnotherSubMenuOpen()) {\n // wait to see if the user enters the open sub-menu\n this.activateTimeoutId = window.setTimeout(() => this.activate(true), AgMenuItemComponent.ACTIVATION_DELAY);\n }\n else {\n // activate immediately\n this.activate(true);\n }\n }\n onMouseLeave() {\n this.cancelActivate();\n if (this.isSubMenuOpen()) {\n // wait to see if the user enters the sub-menu\n this.deactivateTimeoutId = window.setTimeout(() => this.deactivate(), AgMenuItemComponent.ACTIVATION_DELAY);\n }\n else {\n // de-activate immediately\n this.deactivate();\n }\n }\n getClassName(suffix) {\n const prefix = this.params.isCompact ? 'ag-compact-menu-option' : 'ag-menu-option';\n return suffix ? `${prefix}-${suffix}` : prefix;\n }\n}\nAgMenuItemComponent.EVENT_MENU_ITEM_SELECTED = 'menuItemSelected';\nAgMenuItemComponent.EVENT_MENU_ITEM_ACTIVATED = 'menuItemActivated';\nAgMenuItemComponent.ACTIVATION_DELAY = 80;\n__decorate([\n Autowired('popupService')\n], AgMenuItemComponent.prototype, \"popupService\", void 0);\n__decorate([\n PostConstruct\n], AgMenuItemComponent.prototype, \"init\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { RefSelector } from \"./componentAnnotations.mjs\";\nimport { PostConstruct } from \"../context/context.mjs\";\nimport { Component } from \"./component.mjs\";\nimport { getInnerHeight, getInnerWidth, setDisplayed } from \"../utils/dom.mjs\";\nimport { createIconNoSpan } from \"../utils/icon.mjs\";\nimport { PositionableFeature } from \"../rendering/features/positionableFeature.mjs\";\nexport class AgPanel extends Component {\n constructor(config) {\n super(AgPanel.getTemplate(config));\n this.closable = true;\n this.config = config;\n }\n static getTemplate(config) {\n const cssIdentifier = (config && config.cssIdentifier) || 'default';\n return /* html */ `
\n
\n \n
\n
\n
\n
`;\n }\n postConstruct() {\n const { component, closable, hideTitleBar, title, minWidth = 250, width, minHeight = 250, height, centered, popup, x, y } = this.config;\n this.positionableFeature = new PositionableFeature(this.getGui(), {\n minWidth, width, minHeight, height, centered, x, y, popup,\n calculateTopBuffer: () => this.positionableFeature.getHeight() - this.getBodyHeight()\n });\n this.createManagedBean(this.positionableFeature);\n const eGui = this.getGui();\n if (component) {\n this.setBodyComponent(component);\n }\n if (!hideTitleBar) {\n if (title) {\n this.setTitle(title);\n }\n this.setClosable(closable != null ? closable : this.closable);\n }\n else {\n setDisplayed(this.eTitleBar, false);\n }\n this.addManagedListener(this.eTitleBar, 'mousedown', (e) => {\n const eDocument = this.gridOptionsService.getDocument();\n if (eGui.contains(e.relatedTarget) ||\n eGui.contains(eDocument.activeElement) ||\n this.eTitleBarButtons.contains(e.target)) {\n e.preventDefault();\n return;\n }\n const focusEl = this.eContentWrapper.querySelector('button, [href], input, select, textarea, [tabindex]');\n if (focusEl) {\n focusEl.focus();\n }\n });\n if (popup && this.positionableFeature.isPositioned()) {\n return;\n }\n if (this.renderComponent) {\n this.renderComponent();\n }\n this.positionableFeature.initialisePosition();\n this.eContentWrapper.style.height = '0';\n }\n renderComponent() {\n const eGui = this.getGui();\n eGui.focus();\n this.close = () => {\n eGui.parentElement.removeChild(eGui);\n this.destroy();\n };\n }\n getHeight() {\n return this.positionableFeature.getHeight();\n }\n setHeight(height) {\n this.positionableFeature.setHeight(height);\n }\n getWidth() {\n return this.positionableFeature.getWidth();\n }\n setWidth(width) {\n this.positionableFeature.setWidth(width);\n }\n setClosable(closable) {\n if (closable !== this.closable) {\n this.closable = closable;\n }\n if (closable) {\n const closeButtonComp = this.closeButtonComp = new Component(AgPanel.CLOSE_BTN_TEMPLATE);\n this.getContext().createBean(closeButtonComp);\n const eGui = closeButtonComp.getGui();\n const child = createIconNoSpan('close', this.gridOptionsService);\n child.classList.add('ag-panel-title-bar-button-icon');\n eGui.appendChild(child);\n this.addTitleBarButton(closeButtonComp);\n closeButtonComp.addManagedListener(eGui, 'click', this.onBtClose.bind(this));\n }\n else if (this.closeButtonComp) {\n const eGui = this.closeButtonComp.getGui();\n eGui.parentElement.removeChild(eGui);\n this.closeButtonComp = this.destroyBean(this.closeButtonComp);\n }\n }\n setBodyComponent(bodyComponent) {\n bodyComponent.setParentComponent(this);\n this.eContentWrapper.appendChild(bodyComponent.getGui());\n }\n addTitleBarButton(button, position) {\n const eTitleBarButtons = this.eTitleBarButtons;\n const buttons = eTitleBarButtons.children;\n const len = buttons.length;\n if (position == null) {\n position = len;\n }\n position = Math.max(0, Math.min(position, len));\n button.addCssClass('ag-panel-title-bar-button');\n const eGui = button.getGui();\n if (position === 0) {\n eTitleBarButtons.insertAdjacentElement('afterbegin', eGui);\n }\n else if (position === len) {\n eTitleBarButtons.insertAdjacentElement('beforeend', eGui);\n }\n else {\n buttons[position - 1].insertAdjacentElement('afterend', eGui);\n }\n button.setParentComponent(this);\n }\n getBodyHeight() {\n return getInnerHeight(this.eContentWrapper);\n }\n getBodyWidth() {\n return getInnerWidth(this.eContentWrapper);\n }\n setTitle(title) {\n this.eTitle.innerText = title;\n }\n // called when user hits the 'x' in the top right\n onBtClose() {\n this.close();\n }\n destroy() {\n if (this.closeButtonComp) {\n this.closeButtonComp = this.destroyBean(this.closeButtonComp);\n }\n const eGui = this.getGui();\n if (eGui && eGui.offsetParent) {\n this.close();\n }\n super.destroy();\n }\n}\nAgPanel.CLOSE_BTN_TEMPLATE = `
`;\n__decorate([\n RefSelector('eContentWrapper')\n], AgPanel.prototype, \"eContentWrapper\", void 0);\n__decorate([\n RefSelector('eTitleBar')\n], AgPanel.prototype, \"eTitleBar\", void 0);\n__decorate([\n RefSelector('eTitleBarButtons')\n], AgPanel.prototype, \"eTitleBarButtons\", void 0);\n__decorate([\n RefSelector('eTitle')\n], AgPanel.prototype, \"eTitle\", void 0);\n__decorate([\n PostConstruct\n], AgPanel.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired } from \"../context/context.mjs\";\nimport { AgPanel } from \"./agPanel.mjs\";\nimport { Component } from \"./component.mjs\";\nimport { setDisplayed } from \"../utils/dom.mjs\";\nimport { createIconNoSpan } from \"../utils/icon.mjs\";\nexport class AgDialog extends AgPanel {\n constructor(config) {\n super(Object.assign(Object.assign({}, config), { popup: true }));\n this.isMaximizable = false;\n this.isMaximized = false;\n this.maximizeListeners = [];\n this.resizeListenerDestroy = null;\n this.lastPosition = {\n x: 0,\n y: 0,\n width: 0,\n height: 0\n };\n }\n postConstruct() {\n const eGui = this.getGui();\n const { movable, resizable, maximizable } = this.config;\n this.addCssClass('ag-dialog');\n super.postConstruct();\n this.addManagedListener(eGui, 'focusin', (e) => {\n if (eGui.contains(e.relatedTarget)) {\n return;\n }\n this.popupService.bringPopupToFront(eGui);\n });\n if (movable) {\n this.setMovable(movable);\n }\n if (maximizable) {\n this.setMaximizable(maximizable);\n }\n if (resizable) {\n this.setResizable(resizable);\n }\n }\n renderComponent() {\n const eGui = this.getGui();\n const { alwaysOnTop, modal, title, afterGuiAttached } = this.config;\n const translate = this.localeService.getLocaleTextFunc();\n const addPopupRes = this.popupService.addPopup({\n modal,\n eChild: eGui,\n closeOnEsc: true,\n closedCallback: this.destroy.bind(this),\n alwaysOnTop,\n ariaLabel: title || translate('ariaLabelDialog', 'Dialog'),\n afterGuiAttached\n });\n if (addPopupRes) {\n this.close = addPopupRes.hideFunc;\n }\n }\n toggleMaximize() {\n const position = this.positionableFeature.getPosition();\n if (this.isMaximized) {\n const { x, y, width, height } = this.lastPosition;\n this.setWidth(width);\n this.setHeight(height);\n this.positionableFeature.offsetElement(x, y);\n }\n else {\n this.lastPosition.width = this.getWidth();\n this.lastPosition.height = this.getHeight();\n this.lastPosition.x = position.x;\n this.lastPosition.y = position.y;\n this.positionableFeature.offsetElement(0, 0);\n this.setHeight('100%');\n this.setWidth('100%');\n }\n this.isMaximized = !this.isMaximized;\n this.refreshMaximizeIcon();\n }\n refreshMaximizeIcon() {\n setDisplayed(this.maximizeIcon, !this.isMaximized);\n setDisplayed(this.minimizeIcon, this.isMaximized);\n }\n clearMaximizebleListeners() {\n if (this.maximizeListeners.length) {\n this.maximizeListeners.forEach(destroyListener => destroyListener());\n this.maximizeListeners.length = 0;\n }\n if (this.resizeListenerDestroy) {\n this.resizeListenerDestroy();\n this.resizeListenerDestroy = null;\n }\n }\n destroy() {\n this.maximizeButtonComp = this.destroyBean(this.maximizeButtonComp);\n this.clearMaximizebleListeners();\n super.destroy();\n }\n setResizable(resizable) {\n this.positionableFeature.setResizable(resizable);\n }\n setMovable(movable) {\n this.positionableFeature.setMovable(movable, this.eTitleBar);\n }\n setMaximizable(maximizable) {\n if (!maximizable) {\n this.clearMaximizebleListeners();\n if (this.maximizeButtonComp) {\n this.destroyBean(this.maximizeButtonComp);\n this.maximizeButtonComp = this.maximizeIcon = this.minimizeIcon = undefined;\n }\n return;\n }\n const eTitleBar = this.eTitleBar;\n if (!eTitleBar || maximizable === this.isMaximizable) {\n return;\n }\n const maximizeButtonComp = this.buildMaximizeAndMinimizeElements();\n this.refreshMaximizeIcon();\n maximizeButtonComp.addManagedListener(maximizeButtonComp.getGui(), 'click', this.toggleMaximize.bind(this));\n this.addTitleBarButton(maximizeButtonComp, 0);\n this.maximizeListeners.push(this.addManagedListener(eTitleBar, 'dblclick', this.toggleMaximize.bind(this)));\n this.resizeListenerDestroy = this.addManagedListener(this, 'resize', () => {\n this.isMaximized = false;\n this.refreshMaximizeIcon();\n });\n }\n buildMaximizeAndMinimizeElements() {\n const maximizeButtonComp = this.maximizeButtonComp =\n this.createBean(new Component(/* html */ `
`));\n const eGui = maximizeButtonComp.getGui();\n this.maximizeIcon = createIconNoSpan('maximize', this.gridOptionsService);\n eGui.appendChild(this.maximizeIcon);\n this.maximizeIcon.classList.add('ag-panel-title-bar-button-icon');\n this.minimizeIcon = createIconNoSpan('minimize', this.gridOptionsService);\n eGui.appendChild(this.minimizeIcon);\n this.minimizeIcon.classList.add('ag-panel-title-bar-button-icon');\n return maximizeButtonComp;\n }\n}\n__decorate([\n Autowired('popupService')\n], AgDialog.prototype, \"popupService\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar PopupService_1;\nimport { Autowired, Bean, PostConstruct } from \"../context/context.mjs\";\nimport { Events } from '../events.mjs';\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { getAbsoluteHeight, getAbsoluteWidth, getElementRectWithOffset } from '../utils/dom.mjs';\nimport { last } from '../utils/array.mjs';\nimport { isElementInEventPath, isStopPropagationForAgGrid } from '../utils/event.mjs';\nimport { KeyCode } from '../constants/keyCode.mjs';\nimport { FocusService } from \"../focusService.mjs\";\nimport { AgPromise } from \"../utils/index.mjs\";\nimport { setAriaLabel, setAriaRole } from \"../utils/aria.mjs\";\nimport { exists } from \"../utils/generic.mjs\";\nvar DIRECTION;\n(function (DIRECTION) {\n DIRECTION[DIRECTION[\"vertical\"] = 0] = \"vertical\";\n DIRECTION[DIRECTION[\"horizontal\"] = 1] = \"horizontal\";\n})(DIRECTION || (DIRECTION = {}));\nlet instanceIdSeq = 0;\nlet PopupService = PopupService_1 = class PopupService extends BeanStub {\n constructor() {\n super(...arguments);\n this.popupList = [];\n }\n postConstruct() {\n this.ctrlsService.whenReady(p => {\n this.gridCtrl = p.gridCtrl;\n this.addManagedListener(this.gridCtrl, Events.EVENT_KEYBOARD_FOCUS, () => {\n this.popupList.forEach(popup => popup.element.classList.add(FocusService.AG_KEYBOARD_FOCUS));\n });\n this.addManagedListener(this.gridCtrl, Events.EVENT_MOUSE_FOCUS, () => {\n this.popupList.forEach(popup => popup.element.classList.remove(FocusService.AG_KEYBOARD_FOCUS));\n });\n });\n }\n getPopupParent() {\n const ePopupParent = this.gridOptionsService.get('popupParent');\n if (ePopupParent) {\n return ePopupParent;\n }\n return this.gridCtrl.getGui();\n }\n positionPopupForMenu(params) {\n const { eventSource, ePopup } = params;\n const popupIdx = this.getPopupIndex(ePopup);\n if (popupIdx !== -1) {\n const popup = this.popupList[popupIdx];\n popup.alignedToElement = eventSource;\n }\n const sourceRect = eventSource.getBoundingClientRect();\n const parentRect = this.getParentRect();\n const y = this.keepXYWithinBounds(ePopup, sourceRect.top - parentRect.top, DIRECTION.vertical);\n const minWidth = (ePopup.clientWidth > 0) ? ePopup.clientWidth : 200;\n ePopup.style.minWidth = `${minWidth}px`;\n const widthOfParent = parentRect.right - parentRect.left;\n const maxX = widthOfParent - minWidth;\n // the x position of the popup depends on RTL or LTR. for normal cases, LTR, we put the child popup\n // to the right, unless it doesn't fit and we then put it to the left. for RTL it's the other way around,\n // we try place it first to the left, and then if not to the right.\n let x;\n if (this.gridOptionsService.is('enableRtl')) {\n // for RTL, try left first\n x = xLeftPosition();\n if (x < 0) {\n x = xRightPosition();\n this.setAlignedStyles(ePopup, 'left');\n }\n if (x > maxX) {\n x = 0;\n this.setAlignedStyles(ePopup, 'right');\n }\n }\n else {\n // for LTR, try right first\n x = xRightPosition();\n if (x > maxX) {\n x = xLeftPosition();\n this.setAlignedStyles(ePopup, 'right');\n }\n if (x < 0) {\n x = 0;\n this.setAlignedStyles(ePopup, 'left');\n }\n }\n ePopup.style.left = `${x}px`;\n ePopup.style.top = `${y}px`;\n function xRightPosition() {\n return sourceRect.right - parentRect.left - 2;\n }\n function xLeftPosition() {\n return sourceRect.left - parentRect.left - minWidth;\n }\n }\n positionPopupUnderMouseEvent(params) {\n const { ePopup, nudgeX, nudgeY, skipObserver } = params;\n this.positionPopup({\n ePopup: ePopup,\n nudgeX,\n nudgeY,\n keepWithinBounds: true,\n skipObserver,\n updatePosition: () => this.calculatePointerAlign(params.mouseEvent),\n postProcessCallback: () => this.callPostProcessPopup(params.type, params.ePopup, null, params.mouseEvent, params.column, params.rowNode)\n });\n }\n calculatePointerAlign(e) {\n const parentRect = this.getParentRect();\n return {\n x: e.clientX - parentRect.left,\n y: e.clientY - parentRect.top\n };\n }\n positionPopupByComponent(params) {\n const { ePopup, nudgeX, nudgeY, keepWithinBounds, eventSource, alignSide = 'left', position = 'over', column, rowNode, type } = params;\n const sourceRect = eventSource.getBoundingClientRect();\n const parentRect = this.getParentRect();\n const popupIdx = this.getPopupIndex(ePopup);\n if (popupIdx !== -1) {\n const popup = this.popupList[popupIdx];\n popup.alignedToElement = eventSource;\n }\n const updatePosition = () => {\n let x = sourceRect.left - parentRect.left;\n if (alignSide === 'right') {\n x -= (ePopup.offsetWidth - sourceRect.width);\n }\n let y;\n if (position === 'over') {\n y = (sourceRect.top - parentRect.top);\n this.setAlignedStyles(ePopup, 'over');\n }\n else {\n this.setAlignedStyles(ePopup, 'under');\n const alignSide = this.shouldRenderUnderOrAbove(ePopup, sourceRect, parentRect, params.nudgeY || 0);\n if (alignSide === 'under') {\n y = (sourceRect.top - parentRect.top + sourceRect.height);\n }\n else {\n y = (sourceRect.top - ePopup.offsetHeight - (nudgeY || 0) * 2) - parentRect.top;\n }\n }\n return { x, y };\n };\n this.positionPopup({\n ePopup,\n nudgeX,\n nudgeY,\n keepWithinBounds,\n updatePosition,\n postProcessCallback: () => this.callPostProcessPopup(type, ePopup, eventSource, null, column, rowNode)\n });\n }\n shouldRenderUnderOrAbove(ePopup, targetCompRect, parentRect, nudgeY) {\n const spaceAvailableUnder = parentRect.bottom - targetCompRect.bottom;\n const spaceAvailableAbove = targetCompRect.top - parentRect.top;\n const spaceRequired = ePopup.offsetHeight + nudgeY;\n if (spaceAvailableUnder > spaceRequired) {\n return 'under';\n }\n if (spaceAvailableAbove > spaceRequired || spaceAvailableAbove > spaceAvailableUnder) {\n return 'above';\n }\n return 'under';\n }\n setAlignedStyles(ePopup, positioned) {\n const popupIdx = this.getPopupIndex(ePopup);\n if (popupIdx === -1) {\n return;\n }\n const popup = this.popupList[popupIdx];\n const { alignedToElement } = popup;\n if (!alignedToElement) {\n return;\n }\n const positions = ['right', 'left', 'over', 'above', 'under'];\n positions.forEach(position => {\n alignedToElement.classList.remove(`ag-has-popup-positioned-${position}`);\n ePopup.classList.remove(`ag-popup-positioned-${position}`);\n });\n if (!positioned) {\n return;\n }\n alignedToElement.classList.add(`ag-has-popup-positioned-${positioned}`);\n ePopup.classList.add(`ag-popup-positioned-${positioned}`);\n }\n callPostProcessPopup(type, ePopup, eventSource, mouseEvent, column, rowNode) {\n const callback = this.gridOptionsService.getCallback('postProcessPopup');\n if (callback) {\n const params = {\n column: column,\n rowNode: rowNode,\n ePopup: ePopup,\n type: type,\n eventSource: eventSource,\n mouseEvent: mouseEvent\n };\n callback(params);\n }\n }\n positionPopup(params) {\n const { ePopup, keepWithinBounds, nudgeX, nudgeY, skipObserver, updatePosition } = params;\n const lastSize = { width: 0, height: 0 };\n const updatePopupPosition = (fromResizeObserver = false) => {\n let { x, y } = updatePosition();\n if (fromResizeObserver &&\n ePopup.clientWidth === lastSize.width &&\n ePopup.clientHeight === lastSize.height) {\n return;\n }\n lastSize.width = ePopup.clientWidth;\n lastSize.height = ePopup.clientHeight;\n if (nudgeX) {\n x += nudgeX;\n }\n if (nudgeY) {\n y += nudgeY;\n }\n // if popup is overflowing to the bottom, move it up\n if (keepWithinBounds) {\n x = this.keepXYWithinBounds(ePopup, x, DIRECTION.horizontal);\n y = this.keepXYWithinBounds(ePopup, y, DIRECTION.vertical);\n }\n ePopup.style.left = `${x}px`;\n ePopup.style.top = `${y}px`;\n if (params.postProcessCallback) {\n params.postProcessCallback();\n }\n };\n updatePopupPosition();\n // Mouse tracking will recalculate positioning when moving, so won't need to recalculate here\n if (!skipObserver) {\n // Since rendering popup contents can be asynchronous, use a resize observer to\n // reposition the popup after initial updates to the size of the contents\n const resizeObserverDestroyFunc = this.resizeObserverService.observeResize(ePopup, () => updatePopupPosition(true));\n // Only need to reposition when first open, so can clean up after a bit of time\n setTimeout(() => resizeObserverDestroyFunc(), PopupService_1.WAIT_FOR_POPUP_CONTENT_RESIZE);\n }\n }\n getActivePopups() {\n return this.popupList.map((popup) => popup.element);\n }\n getPopupList() {\n return this.popupList;\n }\n getParentRect() {\n // subtract the popup parent borders, because popupParent.getBoundingClientRect\n // returns the rect outside the borders, but the 0,0 coordinate for absolute\n // positioning is inside the border, leading the popup to be off by the width\n // of the border\n const eDocument = this.gridOptionsService.getDocument();\n let popupParent = this.getPopupParent();\n if (popupParent === eDocument.body) {\n popupParent = eDocument.documentElement;\n }\n else if (getComputedStyle(popupParent).position === 'static') {\n popupParent = popupParent.offsetParent;\n }\n return getElementRectWithOffset(popupParent);\n }\n keepXYWithinBounds(ePopup, position, direction) {\n const isVertical = direction === DIRECTION.vertical;\n const sizeProperty = isVertical ? 'clientHeight' : 'clientWidth';\n const anchorProperty = isVertical ? 'top' : 'left';\n const offsetProperty = isVertical ? 'offsetHeight' : 'offsetWidth';\n const scrollPositionProperty = isVertical ? 'scrollTop' : 'scrollLeft';\n const eDocument = this.gridOptionsService.getDocument();\n const docElement = eDocument.documentElement;\n const popupParent = this.getPopupParent();\n const parentRect = popupParent.getBoundingClientRect();\n const documentRect = eDocument.documentElement.getBoundingClientRect();\n const isBody = popupParent === eDocument.body;\n const offsetSize = ePopup[offsetProperty];\n const getSize = isVertical ? getAbsoluteHeight : getAbsoluteWidth;\n let sizeOfParent = isBody ? (getSize(docElement) + docElement[scrollPositionProperty]) : popupParent[sizeProperty];\n if (isBody) {\n sizeOfParent -= Math.abs(documentRect[anchorProperty] - parentRect[anchorProperty]);\n }\n const max = sizeOfParent - offsetSize;\n return Math.min(Math.max(position, 0), Math.abs(max));\n }\n addPopup(params) {\n const eDocument = this.gridOptionsService.getDocument();\n const { eChild, ariaLabel, alwaysOnTop, positionCallback, anchorToElement } = params;\n if (!eDocument) {\n console.warn('AG Grid: could not find the document, document is empty');\n return { hideFunc: () => { } };\n }\n const pos = this.getPopupIndex(eChild);\n if (pos !== -1) {\n const popup = this.popupList[pos];\n return { hideFunc: popup.hideFunc };\n }\n this.initialisePopupPosition(eChild);\n const wrapperEl = this.createPopupWrapper(eChild, ariaLabel, !!alwaysOnTop);\n const removeListeners = this.addEventListenersToPopup(Object.assign(Object.assign({}, params), { wrapperEl }));\n if (positionCallback) {\n positionCallback();\n }\n this.addPopupToPopupList(eChild, wrapperEl, removeListeners, anchorToElement);\n return {\n hideFunc: removeListeners\n };\n }\n initialisePopupPosition(element) {\n const ePopupParent = this.getPopupParent();\n const ePopupParentRect = ePopupParent.getBoundingClientRect();\n if (!exists(element.style.top)) {\n element.style.top = `${ePopupParentRect.top * -1}px`;\n }\n if (!exists(element.style.left)) {\n element.style.left = `${ePopupParentRect.left * -1}px`;\n }\n }\n createPopupWrapper(element, ariaLabel, alwaysOnTop) {\n const ePopupParent = this.getPopupParent();\n // add env CSS class to child, in case user provided a popup parent, which means\n // theme class may be missing\n const eWrapper = document.createElement('div');\n const { allThemes } = this.environment.getTheme();\n if (allThemes.length) {\n eWrapper.classList.add(...allThemes);\n }\n eWrapper.classList.add('ag-popup');\n element.classList.add(this.gridOptionsService.is('enableRtl') ? 'ag-rtl' : 'ag-ltr', 'ag-popup-child');\n if (!element.hasAttribute('role')) {\n setAriaRole(element, 'dialog');\n }\n setAriaLabel(element, ariaLabel);\n if (this.focusService.isKeyboardMode()) {\n element.classList.add(FocusService.AG_KEYBOARD_FOCUS);\n }\n eWrapper.appendChild(element);\n ePopupParent.appendChild(eWrapper);\n if (alwaysOnTop) {\n this.setAlwaysOnTop(element, true);\n }\n else {\n this.bringPopupToFront(element);\n }\n return eWrapper;\n }\n addEventListenersToPopup(params) {\n const eDocument = this.gridOptionsService.getDocument();\n const ePopupParent = this.getPopupParent();\n const { wrapperEl, eChild: popupEl, click: pointerEvent, closedCallback, afterGuiAttached, closeOnEsc, modal } = params;\n let popupHidden = false;\n const hidePopupOnKeyboardEvent = (event) => {\n if (!wrapperEl.contains(eDocument.activeElement)) {\n return;\n }\n const key = event.key;\n if (key === KeyCode.ESCAPE && !isStopPropagationForAgGrid(event)) {\n removeListeners({ keyboardEvent: event });\n }\n };\n const hidePopupOnMouseEvent = (event) => removeListeners({ mouseEvent: event });\n const hidePopupOnTouchEvent = (event) => removeListeners({ touchEvent: event });\n const removeListeners = (popupParams = {}) => {\n const { mouseEvent, touchEvent, keyboardEvent } = popupParams;\n if (\n // we don't hide popup if the event was on the child, or any\n // children of this child\n this.isEventFromCurrentPopup({ mouseEvent, touchEvent }, popupEl) ||\n // this method should only be called once. the client can have different\n // paths, each one wanting to close, so this method may be called multiple times.\n popupHidden) {\n return;\n }\n popupHidden = true;\n ePopupParent.removeChild(wrapperEl);\n eDocument.removeEventListener('keydown', hidePopupOnKeyboardEvent);\n eDocument.removeEventListener('mousedown', hidePopupOnMouseEvent);\n eDocument.removeEventListener('touchstart', hidePopupOnTouchEvent);\n eDocument.removeEventListener('contextmenu', hidePopupOnMouseEvent);\n this.eventService.removeEventListener(Events.EVENT_DRAG_STARTED, hidePopupOnMouseEvent);\n if (closedCallback) {\n closedCallback(mouseEvent || touchEvent || keyboardEvent);\n }\n this.removePopupFromPopupList(popupEl);\n };\n if (afterGuiAttached) {\n afterGuiAttached({ hidePopup: removeListeners });\n }\n // if we add these listeners now, then the current mouse\n // click will be included, which we don't want\n window.setTimeout(() => {\n if (closeOnEsc) {\n eDocument.addEventListener('keydown', hidePopupOnKeyboardEvent);\n }\n if (modal) {\n eDocument.addEventListener('mousedown', hidePopupOnMouseEvent);\n this.eventService.addEventListener(Events.EVENT_DRAG_STARTED, hidePopupOnMouseEvent);\n eDocument.addEventListener('touchstart', hidePopupOnTouchEvent);\n eDocument.addEventListener('contextmenu', hidePopupOnMouseEvent);\n }\n }, 0);\n return removeListeners;\n }\n addPopupToPopupList(element, wrapperEl, removeListeners, anchorToElement) {\n this.popupList.push({\n element: element,\n wrapper: wrapperEl,\n hideFunc: removeListeners,\n instanceId: instanceIdSeq++,\n isAnchored: !!anchorToElement\n });\n if (anchorToElement) {\n this.setPopupPositionRelatedToElement(element, anchorToElement);\n }\n }\n getPopupIndex(el) {\n return this.popupList.findIndex(p => p.element === el);\n }\n setPopupPositionRelatedToElement(popupEl, relativeElement) {\n const popupIndex = this.getPopupIndex(popupEl);\n if (popupIndex === -1) {\n return;\n }\n const popup = this.popupList[popupIndex];\n if (popup.stopAnchoringPromise) {\n popup.stopAnchoringPromise.then(destroyFunc => destroyFunc && destroyFunc());\n }\n popup.stopAnchoringPromise = undefined;\n popup.isAnchored = false;\n if (!relativeElement) {\n return;\n }\n // keeps popup positioned under created, eg if context menu, if user scrolls\n // using touchpad and the cell moves, it moves the popup to keep it with the cell.\n const destroyPositionTracker = this.keepPopupPositionedRelativeTo({\n element: relativeElement,\n ePopup: popupEl,\n hidePopup: popup.hideFunc\n });\n popup.stopAnchoringPromise = destroyPositionTracker;\n popup.isAnchored = true;\n return destroyPositionTracker;\n }\n removePopupFromPopupList(element) {\n this.setAlignedStyles(element, null);\n this.setPopupPositionRelatedToElement(element, null);\n this.popupList = this.popupList.filter(p => p.element !== element);\n }\n keepPopupPositionedRelativeTo(params) {\n const eParent = this.getPopupParent();\n const parentRect = eParent.getBoundingClientRect();\n const { element, ePopup } = params;\n const sourceRect = element.getBoundingClientRect();\n const initialDiffTop = parentRect.top - sourceRect.top;\n const initialDiffLeft = parentRect.left - sourceRect.left;\n let lastDiffTop = initialDiffTop;\n let lastDiffLeft = initialDiffLeft;\n const topPx = ePopup.style.top;\n const top = parseInt(topPx.substring(0, topPx.length - 1), 10);\n const leftPx = ePopup.style.left;\n const left = parseInt(leftPx.substring(0, leftPx.length - 1), 10);\n return new AgPromise(resolve => {\n this.getFrameworkOverrides().setInterval(() => {\n const pRect = eParent.getBoundingClientRect();\n const sRect = element.getBoundingClientRect();\n const elementNotInDom = sRect.top == 0 && sRect.left == 0 && sRect.height == 0 && sRect.width == 0;\n if (elementNotInDom) {\n params.hidePopup();\n return;\n }\n const currentDiffTop = pRect.top - sRect.top;\n if (currentDiffTop != lastDiffTop) {\n const newTop = this.keepXYWithinBounds(ePopup, top + initialDiffTop - currentDiffTop, DIRECTION.vertical);\n ePopup.style.top = `${newTop}px`;\n }\n lastDiffTop = currentDiffTop;\n const currentDiffLeft = pRect.left - sRect.left;\n if (currentDiffLeft != lastDiffLeft) {\n const newLeft = this.keepXYWithinBounds(ePopup, left + initialDiffLeft - currentDiffLeft, DIRECTION.horizontal);\n ePopup.style.left = `${newLeft}px`;\n }\n lastDiffLeft = currentDiffLeft;\n }, 200).then(intervalId => {\n const result = () => {\n if (intervalId != null) {\n window.clearInterval(intervalId);\n }\n };\n resolve(result);\n });\n });\n }\n hasAnchoredPopup() {\n return this.popupList.some(popup => popup.isAnchored);\n }\n isEventFromCurrentPopup(params, target) {\n const { mouseEvent, touchEvent } = params;\n const event = mouseEvent ? mouseEvent : touchEvent;\n if (!event) {\n return false;\n }\n const indexOfThisChild = this.getPopupIndex(target);\n if (indexOfThisChild === -1) {\n return false;\n }\n for (let i = indexOfThisChild; i < this.popupList.length; i++) {\n const popup = this.popupList[i];\n if (isElementInEventPath(popup.element, event)) {\n return true;\n }\n }\n // if the user did not write their own Custom Element to be rendered as popup\n // and this component has an additional popup element, they should have the\n // `ag-custom-component-popup` class to be detected as part of the Custom Component\n return this.isElementWithinCustomPopup(event.target);\n }\n isElementWithinCustomPopup(el) {\n const eDocument = this.gridOptionsService.getDocument();\n while (el && el !== eDocument.body) {\n if (el.classList.contains('ag-custom-component-popup') || el.parentElement === null) {\n return true;\n }\n el = el.parentElement;\n }\n return false;\n }\n getWrapper(ePopup) {\n while (!ePopup.classList.contains('ag-popup') && ePopup.parentElement) {\n ePopup = ePopup.parentElement;\n }\n return ePopup.classList.contains('ag-popup') ? ePopup : null;\n }\n setAlwaysOnTop(ePopup, alwaysOnTop) {\n const eWrapper = this.getWrapper(ePopup);\n if (!eWrapper) {\n return;\n }\n eWrapper.classList.toggle('ag-always-on-top', !!alwaysOnTop);\n if (alwaysOnTop) {\n this.bringPopupToFront(eWrapper);\n }\n }\n bringPopupToFront(ePopup) {\n const parent = this.getPopupParent();\n const popupList = Array.prototype.slice.call(parent.querySelectorAll('.ag-popup'));\n const popupLen = popupList.length;\n const alwaysOnTopList = Array.prototype.slice.call(parent.querySelectorAll('.ag-popup.ag-always-on-top'));\n const onTopLength = alwaysOnTopList.length;\n const eWrapper = this.getWrapper(ePopup);\n if (!eWrapper || popupLen <= 1 || !parent.contains(ePopup)) {\n return;\n }\n const pos = popupList.indexOf(eWrapper);\n const innerEls = eWrapper.querySelectorAll('div');\n const innerElsScrollMap = [];\n innerEls.forEach(el => {\n if (el.scrollTop !== 0) {\n innerElsScrollMap.push([el, el.scrollTop]);\n }\n });\n if (onTopLength) {\n const isPopupAlwaysOnTop = eWrapper.classList.contains('ag-always-on-top');\n if (isPopupAlwaysOnTop) {\n if (pos !== popupLen - 1) {\n last(alwaysOnTopList).insertAdjacentElement('afterend', eWrapper);\n }\n }\n else if (pos !== popupLen - onTopLength - 1) {\n alwaysOnTopList[0].insertAdjacentElement('beforebegin', eWrapper);\n }\n }\n else if (pos !== popupLen - 1) {\n last(popupList).insertAdjacentElement('afterend', eWrapper);\n }\n while (innerElsScrollMap.length) {\n const currentEl = innerElsScrollMap.pop();\n currentEl[0].scrollTop = currentEl[1];\n }\n const params = {\n type: 'popupToFront',\n api: this.gridOptionsService.api,\n columnApi: this.gridOptionsService.columnApi,\n eWrapper\n };\n this.eventService.dispatchEvent(params);\n }\n};\nPopupService.WAIT_FOR_POPUP_CONTENT_RESIZE = 200;\n__decorate([\n Autowired('focusService')\n], PopupService.prototype, \"focusService\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], PopupService.prototype, \"ctrlsService\", void 0);\n__decorate([\n Autowired('resizeObserverService')\n], PopupService.prototype, \"resizeObserverService\", void 0);\n__decorate([\n PostConstruct\n], PopupService.prototype, \"postConstruct\", null);\nPopupService = PopupService_1 = __decorate([\n Bean('popupService')\n], PopupService);\nexport { PopupService };\n","import { escapeString } from \"../utils/string.mjs\";\nimport { exists } from \"../utils/generic.mjs\";\nimport { Component } from \"./component.mjs\";\nexport class AgAutocompleteRow extends Component {\n constructor() {\n super(/* html */ `\n
\n
\n
`);\n this.hasHighlighting = false;\n }\n setState(value, selected) {\n this.value = value;\n this.render();\n this.updateSelected(selected);\n }\n updateSelected(selected) {\n this.addOrRemoveCssClass('ag-autocomplete-row-selected', selected);\n }\n setSearchString(searchString) {\n var _a;\n let keepHighlighting = false;\n if (exists(searchString)) {\n const index = (_a = this.value) === null || _a === void 0 ? void 0 : _a.toLocaleLowerCase().indexOf(searchString.toLocaleLowerCase());\n if (index >= 0) {\n keepHighlighting = true;\n this.hasHighlighting = true;\n const highlightEndIndex = index + searchString.length;\n const startPart = escapeString(this.value.slice(0, index));\n const highlightedPart = escapeString(this.value.slice(index, highlightEndIndex));\n const endPart = escapeString(this.value.slice(highlightEndIndex));\n this.getGui().lastElementChild.innerHTML = `${startPart}${highlightedPart}${endPart}`;\n }\n }\n if (!keepHighlighting && this.hasHighlighting) {\n this.hasHighlighting = false;\n this.render();\n }\n }\n render() {\n var _a;\n // putting in blank if missing, so at least the user can click on it\n this.getGui().lastElementChild.innerHTML = (_a = escapeString(this.value)) !== null && _a !== void 0 ? _a : ' ';\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { RefSelector } from \"./componentAnnotations.mjs\";\nimport { VirtualList } from \"./virtualList.mjs\";\nimport { KeyCode } from \"../constants/keyCode.mjs\";\nimport { AgAutocompleteRow } from \"./agAutocompleteRow.mjs\";\nimport { fuzzySuggestions } from \"../utils/fuzzyMatch.mjs\";\nimport { PopupComponent } from \"./popupComponent.mjs\";\nimport { PostConstruct } from \"../context/context.mjs\";\nimport { exists } from \"../utils/generic.mjs\";\nexport class AgAutocompleteList extends PopupComponent {\n constructor(params) {\n super(AgAutocompleteList.TEMPLATE);\n this.params = params;\n this.searchString = '';\n }\n destroy() {\n super.destroy();\n }\n init() {\n this.autocompleteEntries = this.params.autocompleteEntries;\n this.virtualList = this.createManagedBean(new VirtualList({ cssIdentifier: 'autocomplete' }));\n this.virtualList.setComponentCreator(this.createRowComponent.bind(this));\n this.eList.appendChild(this.virtualList.getGui());\n this.virtualList.setModel({\n getRowCount: () => this.autocompleteEntries.length,\n getRow: (index) => this.autocompleteEntries[index]\n });\n const virtualListGui = this.virtualList.getGui();\n this.addManagedListener(virtualListGui, 'click', () => this.params.onConfirmed());\n this.addManagedListener(virtualListGui, 'mousemove', this.onMouseMove.bind(this));\n this.addManagedListener(virtualListGui, 'mousedown', (e) => e.preventDefault());\n this.setSelectedValue(0);\n }\n onNavigationKeyDown(event, key) {\n // if we don't preventDefault the page body and/or grid scroll will move.\n event.preventDefault();\n const oldIndex = this.autocompleteEntries.indexOf(this.selectedValue);\n const newIndex = key === KeyCode.UP ? oldIndex - 1 : oldIndex + 1;\n this.checkSetSelectedValue(newIndex);\n }\n setSearch(searchString) {\n this.searchString = searchString;\n if (exists(searchString)) {\n this.runSearch();\n }\n else {\n // reset\n this.autocompleteEntries = this.params.autocompleteEntries;\n this.virtualList.refresh();\n this.checkSetSelectedValue(0);\n }\n this.updateSearchInList();\n }\n runContainsSearch(searchString, searchStrings) {\n let topMatch;\n let topMatchStartsWithSearchString = false;\n const lowerCaseSearchString = searchString.toLocaleLowerCase();\n const allMatches = searchStrings.filter(string => {\n const lowerCaseString = string.toLocaleLowerCase();\n const index = lowerCaseString.indexOf(lowerCaseSearchString);\n const startsWithSearchString = index === 0;\n const isMatch = index >= 0;\n // top match is shortest value that starts with the search string, otherwise shortest value that includes the search string\n if (isMatch && (!topMatch ||\n (!topMatchStartsWithSearchString && startsWithSearchString) ||\n (topMatchStartsWithSearchString === startsWithSearchString && string.length < topMatch.length))) {\n topMatch = string;\n topMatchStartsWithSearchString = startsWithSearchString;\n }\n return isMatch;\n });\n if (!topMatch && allMatches.length) {\n topMatch = allMatches[0];\n }\n return { topMatch, allMatches };\n }\n runSearch() {\n var _a, _b;\n const { autocompleteEntries } = this.params;\n const searchStrings = autocompleteEntries.map(v => { var _a; return (_a = v.displayValue) !== null && _a !== void 0 ? _a : v.key; });\n let matchingStrings;\n let topSuggestion;\n if (this.params.useFuzzySearch) {\n matchingStrings = fuzzySuggestions(this.searchString, searchStrings, true).values;\n topSuggestion = matchingStrings.length ? matchingStrings[0] : undefined;\n }\n else {\n const containsMatches = this.runContainsSearch(this.searchString, searchStrings);\n matchingStrings = containsMatches.allMatches;\n topSuggestion = containsMatches.topMatch;\n }\n let filteredEntries = autocompleteEntries.filter(({ key, displayValue }) => matchingStrings.includes(displayValue !== null && displayValue !== void 0 ? displayValue : key));\n if (!filteredEntries.length && this.selectedValue && ((_b = (_a = this.params) === null || _a === void 0 ? void 0 : _a.forceLastSelection) === null || _b === void 0 ? void 0 : _b.call(_a, this.selectedValue, this.searchString))) {\n filteredEntries = [this.selectedValue];\n }\n this.autocompleteEntries = filteredEntries;\n this.virtualList.refresh();\n if (!topSuggestion) {\n return;\n }\n const topSuggestionIndex = matchingStrings.indexOf(topSuggestion);\n this.checkSetSelectedValue(topSuggestionIndex);\n }\n updateSearchInList() {\n this.virtualList.forEachRenderedRow((row) => row.setSearchString(this.searchString));\n }\n checkSetSelectedValue(index) {\n if (index >= 0 && index < this.autocompleteEntries.length) {\n this.setSelectedValue(index);\n }\n }\n setSelectedValue(index) {\n const value = this.autocompleteEntries[index];\n if (this.selectedValue === value) {\n return;\n }\n this.selectedValue = value;\n this.virtualList.ensureIndexVisible(index);\n this.virtualList.forEachRenderedRow((cmp, idx) => {\n cmp.updateSelected(index === idx);\n });\n }\n createRowComponent(value) {\n var _a;\n const row = new AgAutocompleteRow();\n this.getContext().createBean(row);\n row.setState((_a = value.displayValue) !== null && _a !== void 0 ? _a : value.key, value === this.selectedValue);\n return row;\n }\n onMouseMove(mouseEvent) {\n const rect = this.virtualList.getGui().getBoundingClientRect();\n const scrollTop = this.virtualList.getScrollTop();\n const mouseY = mouseEvent.clientY - rect.top + scrollTop;\n const row = Math.floor(mouseY / this.virtualList.getRowHeight());\n this.checkSetSelectedValue(row);\n }\n afterGuiAttached() {\n this.virtualList.refresh();\n }\n getSelectedValue() {\n var _a;\n if (!this.autocompleteEntries.length) {\n return null;\n }\n ;\n return (_a = this.selectedValue) !== null && _a !== void 0 ? _a : null;\n }\n}\nAgAutocompleteList.TEMPLATE = `
\n
\n
`;\n__decorate([\n RefSelector('eList')\n], AgAutocompleteList.prototype, \"eList\", void 0);\n__decorate([\n PostConstruct\n], AgAutocompleteList.prototype, \"init\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from \"./component.mjs\";\nimport { RefSelector } from \"./componentAnnotations.mjs\";\nimport { Autowired, PostConstruct } from \"../context/context.mjs\";\nimport { AgAutocompleteList } from \"./agAutocompleteList.mjs\";\nimport { KeyCode } from \"../constants/keyCode.mjs\";\nimport { makeNull } from \"../utils/generic.mjs\";\nexport class AgAutocomplete extends Component {\n constructor() {\n super(/* html */ `\n
\n \n
`);\n this.isListOpen = false;\n this.lastPosition = 0;\n this.valid = true;\n }\n postConstruct() {\n this.eAutocompleteInput.onValueChange(value => this.onValueChanged(value));\n this.eAutocompleteInput.getInputElement().setAttribute('autocomplete', 'off');\n this.addGuiEventListener('keydown', this.onKeyDown.bind(this));\n this.addGuiEventListener('click', this.updatePositionAndList.bind(this));\n this.addDestroyFunc(() => {\n this.destroyBean(this.autocompleteList);\n });\n this.addGuiEventListener('focusout', () => this.onFocusOut());\n }\n onValueChanged(value) {\n const parsedValue = makeNull(value);\n this.updateValue(parsedValue);\n this.updateAutocompleteList(parsedValue);\n }\n updateValue(value) {\n this.updateLastPosition();\n this.dispatchEvent({\n type: AgAutocomplete.EVENT_VALUE_CHANGED,\n value\n });\n this.validate(value);\n }\n updateAutocompleteList(value) {\n var _a, _b, _c, _d;\n const autocompleteListParams = (_b = (_a = this.listGenerator) === null || _a === void 0 ? void 0 : _a.call(this, value, this.lastPosition)) !== null && _b !== void 0 ? _b : { enabled: false };\n if (!autocompleteListParams.type || autocompleteListParams.type !== ((_c = this.autocompleteListParams) === null || _c === void 0 ? void 0 : _c.type)) {\n if (this.isListOpen) {\n this.closeList();\n }\n }\n this.autocompleteListParams = autocompleteListParams;\n if ((_d = this.autocompleteListParams) === null || _d === void 0 ? void 0 : _d.enabled) {\n if (!this.isListOpen) {\n this.openList();\n }\n const { searchString } = this.autocompleteListParams;\n this.autocompleteList.setSearch(searchString !== null && searchString !== void 0 ? searchString : '');\n }\n else {\n if (this.isListOpen) {\n this.closeList();\n }\n }\n }\n onKeyDown(event) {\n const key = event.key;\n this.updateLastPosition();\n switch (key) {\n case KeyCode.ENTER:\n this.onEnterKeyDown(event);\n break;\n case KeyCode.TAB:\n this.onTabKeyDown(event);\n break;\n case KeyCode.DOWN:\n case KeyCode.UP:\n this.onUpDownKeyDown(event, key);\n break;\n case KeyCode.LEFT:\n case KeyCode.RIGHT:\n case KeyCode.PAGE_HOME:\n case KeyCode.PAGE_END:\n // input position is updated after this is called, so do async\n setTimeout(() => {\n this.updatePositionAndList();\n });\n break;\n case KeyCode.ESCAPE:\n this.onEscapeKeyDown(event);\n break;\n case KeyCode.SPACE:\n if (event.ctrlKey && !this.isListOpen) {\n event.preventDefault();\n this.forceOpenList();\n }\n break;\n }\n }\n confirmSelection() {\n var _a;\n const selectedValue = (_a = this.autocompleteList) === null || _a === void 0 ? void 0 : _a.getSelectedValue();\n if (selectedValue) {\n this.closeList();\n this.dispatchEvent({\n type: AgAutocomplete.EVENT_OPTION_SELECTED,\n value: this.getValue(),\n position: this.lastPosition,\n updateEntry: selectedValue,\n autocompleteType: this.autocompleteListParams.type\n });\n }\n }\n onTabKeyDown(event) {\n if (this.isListOpen) {\n event.preventDefault();\n event.stopPropagation();\n this.confirmSelection();\n }\n }\n onEnterKeyDown(event) {\n event.preventDefault();\n if (this.isListOpen) {\n this.confirmSelection();\n }\n else {\n this.onCompleted();\n }\n }\n onUpDownKeyDown(event, key) {\n var _a;\n event.preventDefault();\n if (!this.isListOpen) {\n this.forceOpenList();\n }\n else {\n (_a = this.autocompleteList) === null || _a === void 0 ? void 0 : _a.onNavigationKeyDown(event, key);\n }\n }\n onEscapeKeyDown(event) {\n if (this.isListOpen) {\n event.preventDefault();\n event.stopPropagation();\n this.closeList();\n this.setCaret(this.lastPosition, true);\n }\n }\n onFocusOut() {\n if (this.isListOpen) {\n this.closeList();\n }\n }\n updatePositionAndList() {\n var _a;\n this.updateLastPosition();\n this.updateAutocompleteList((_a = this.eAutocompleteInput.getValue()) !== null && _a !== void 0 ? _a : null);\n }\n setCaret(position, setFocus) {\n const eDocument = this.gridOptionsService.getDocument();\n if (setFocus && eDocument.activeElement === eDocument.body) {\n // clicking on the list loses focus, so restore\n this.eAutocompleteInput.getFocusableElement().focus();\n }\n this.eAutocompleteInput.getInputElement().setSelectionRange(position, position);\n }\n forceOpenList() {\n this.onValueChanged(this.eAutocompleteInput.getValue());\n }\n updateLastPosition() {\n var _a;\n this.lastPosition = (_a = this.eAutocompleteInput.getInputElement().selectionStart) !== null && _a !== void 0 ? _a : 0;\n }\n validate(value) {\n var _a;\n if (!this.validator) {\n return;\n }\n this.validationMessage = this.validator(value);\n this.eAutocompleteInput.getInputElement().setCustomValidity((_a = this.validationMessage) !== null && _a !== void 0 ? _a : '');\n this.valid = !this.validationMessage;\n this.dispatchEvent({\n type: AgAutocomplete.EVENT_VALID_CHANGED,\n isValid: this.valid,\n validationMessage: this.validationMessage\n });\n }\n openList() {\n this.isListOpen = true;\n // this is unmanaged as it gets destroyed/created each time it is opened\n this.autocompleteList = this.createBean(new AgAutocompleteList({\n autocompleteEntries: this.autocompleteListParams.entries,\n onConfirmed: () => this.confirmSelection(),\n forceLastSelection: this.forceLastSelection\n }));\n const ePopupGui = this.autocompleteList.getGui();\n const positionParams = {\n ePopup: ePopupGui,\n type: 'autocomplete',\n eventSource: this.getGui(),\n position: 'under',\n alignSide: this.gridOptionsService.is('enableRtl') ? 'right' : 'left',\n keepWithinBounds: true\n };\n const addPopupRes = this.popupService.addPopup({\n eChild: ePopupGui,\n anchorToElement: this.getGui(),\n positionCallback: () => this.popupService.positionPopupByComponent(positionParams),\n ariaLabel: this.listAriaLabel\n });\n this.hidePopup = addPopupRes.hideFunc;\n this.autocompleteList.afterGuiAttached();\n }\n closeList() {\n this.isListOpen = false;\n this.hidePopup();\n this.destroyBean(this.autocompleteList);\n this.autocompleteList = null;\n }\n onCompleted() {\n if (this.isListOpen) {\n this.closeList();\n }\n this.dispatchEvent({\n type: AgAutocomplete.EVENT_VALUE_CONFIRMED,\n value: this.getValue(),\n isValid: this.isValid()\n });\n }\n getValue() {\n return makeNull(this.eAutocompleteInput.getValue());\n }\n setInputPlaceholder(placeholder) {\n this.eAutocompleteInput.setInputPlaceholder(placeholder);\n return this;\n }\n setInputAriaLabel(label) {\n this.eAutocompleteInput.setInputAriaLabel(label);\n return this;\n }\n setListAriaLabel(label) {\n this.listAriaLabel = label;\n return this;\n }\n setListGenerator(listGenerator) {\n this.listGenerator = listGenerator;\n return this;\n }\n setValidator(validator) {\n this.validator = validator;\n return this;\n }\n isValid() {\n return this.valid;\n }\n setValue(params) {\n const { value, position, silent, updateListOnlyIfOpen, restoreFocus } = params;\n this.eAutocompleteInput.setValue(value, true);\n this.setCaret(position !== null && position !== void 0 ? position : this.lastPosition, restoreFocus);\n if (!silent) {\n this.updateValue(value);\n }\n if (!updateListOnlyIfOpen || this.isListOpen) {\n this.updateAutocompleteList(value);\n }\n }\n setForceLastSelection(forceLastSelection) {\n this.forceLastSelection = forceLastSelection;\n return this;\n }\n setInputDisabled(disabled) {\n this.eAutocompleteInput.setDisabled(disabled);\n return this;\n }\n}\nAgAutocomplete.EVENT_VALUE_CHANGED = 'eventValueChanged';\nAgAutocomplete.EVENT_VALUE_CONFIRMED = 'eventValueConfirmed';\nAgAutocomplete.EVENT_OPTION_SELECTED = 'eventOptionSelected';\nAgAutocomplete.EVENT_VALID_CHANGED = 'eventValidChanged';\n__decorate([\n Autowired('popupService')\n], AgAutocomplete.prototype, \"popupService\", void 0);\n__decorate([\n RefSelector('eAutocompleteInput')\n], AgAutocomplete.prototype, \"eAutocompleteInput\", void 0);\n__decorate([\n PostConstruct\n], AgAutocomplete.prototype, \"postConstruct\", null);\n","import { includes } from \"./utils/array.mjs\";\nimport { AgPromise } from \"./utils/index.mjs\";\nconst OUTSIDE_ANGULAR_EVENTS = ['mouseover', 'mouseout', 'mouseenter', 'mouseleave', 'mousemove'];\nconst PASSIVE_EVENTS = ['touchstart', 'touchend', 'touchmove', 'touchcancel'];\n/** The base frameworks, eg React & Angular, override this bean with implementations specific to their requirement. */\nexport class VanillaFrameworkOverrides {\n constructor() {\n this.renderingEngine = \"vanilla\";\n this.isOutsideAngular = (eventType) => includes(OUTSIDE_ANGULAR_EVENTS, eventType);\n }\n // for Vanilla JS, we use simple timeout\n setTimeout(action, timeout) {\n window.setTimeout(action, timeout);\n }\n setInterval(action, timeout) {\n return new AgPromise(resolve => {\n resolve(window.setInterval(action, timeout));\n });\n }\n // for Vanilla JS, we just add the event to the element\n addEventListener(element, type, listener, useCapture) {\n const isPassive = includes(PASSIVE_EVENTS, type);\n element.addEventListener(type, listener, { capture: !!useCapture, passive: isPassive });\n }\n // for Vanilla JS, we just execute the listener\n dispatchEvent(eventType, listener, global = false) {\n listener();\n }\n frameworkComponent(name) {\n return null;\n }\n isFrameworkComponent(comp) {\n return false;\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean } from \"./context/context.mjs\";\nimport { BeanStub } from \"./context/beanStub.mjs\";\nimport { missing } from \"./utils/generic.mjs\";\nimport { last } from \"./utils/array.mjs\";\nimport { KeyCode } from './constants/keyCode.mjs';\nlet CellNavigationService = class CellNavigationService extends BeanStub {\n // returns null if no cell to focus on, ie at the end of the grid\n getNextCellToFocus(key, focusedCell, ctrlPressed = false) {\n if (ctrlPressed) {\n return this.getNextCellToFocusWithCtrlPressed(key, focusedCell);\n }\n return this.getNextCellToFocusWithoutCtrlPressed(key, focusedCell);\n }\n getNextCellToFocusWithCtrlPressed(key, focusedCell) {\n const upKey = key === KeyCode.UP;\n const downKey = key === KeyCode.DOWN;\n const leftKey = key === KeyCode.LEFT;\n let column;\n let rowIndex;\n if (upKey || downKey) {\n rowIndex = upKey ? this.paginationProxy.getPageFirstRow() : this.paginationProxy.getPageLastRow();\n column = focusedCell.column;\n }\n else {\n const allColumns = this.columnModel.getAllDisplayedColumns();\n const isRtl = this.gridOptionsService.is('enableRtl');\n rowIndex = focusedCell.rowIndex;\n column = leftKey !== isRtl ? allColumns[0] : last(allColumns);\n }\n return {\n rowIndex,\n rowPinned: null,\n column\n };\n }\n getNextCellToFocusWithoutCtrlPressed(key, focusedCell) {\n // starting with the provided cell, we keep moving until we find a cell we can\n // focus on.\n let pointer = focusedCell;\n let finished = false;\n // finished will be true when either:\n // a) cell found that we can focus on\n // b) run out of cells (ie the method returns null)\n while (!finished) {\n switch (key) {\n case KeyCode.UP:\n pointer = this.getCellAbove(pointer);\n break;\n case KeyCode.DOWN:\n pointer = this.getCellBelow(pointer);\n break;\n case KeyCode.RIGHT:\n if (this.gridOptionsService.is('enableRtl')) {\n pointer = this.getCellToLeft(pointer);\n }\n else {\n pointer = this.getCellToRight(pointer);\n }\n break;\n case KeyCode.LEFT:\n if (this.gridOptionsService.is('enableRtl')) {\n pointer = this.getCellToRight(pointer);\n }\n else {\n pointer = this.getCellToLeft(pointer);\n }\n break;\n default:\n pointer = null;\n console.warn('AG Grid: unknown key for navigation ' + key);\n break;\n }\n if (pointer) {\n finished = this.isCellGoodToFocusOn(pointer);\n }\n else {\n finished = true;\n }\n }\n return pointer;\n }\n isCellGoodToFocusOn(gridCell) {\n const column = gridCell.column;\n let rowNode;\n switch (gridCell.rowPinned) {\n case 'top':\n rowNode = this.pinnedRowModel.getPinnedTopRow(gridCell.rowIndex);\n break;\n case 'bottom':\n rowNode = this.pinnedRowModel.getPinnedBottomRow(gridCell.rowIndex);\n break;\n default:\n rowNode = this.rowModel.getRow(gridCell.rowIndex);\n break;\n }\n if (!rowNode) {\n return false;\n }\n const suppressNavigable = column.isSuppressNavigable(rowNode);\n return !suppressNavigable;\n }\n getCellToLeft(lastCell) {\n if (!lastCell) {\n return null;\n }\n const colToLeft = this.columnModel.getDisplayedColBefore(lastCell.column);\n if (!colToLeft) {\n return null;\n }\n return {\n rowIndex: lastCell.rowIndex,\n column: colToLeft,\n rowPinned: lastCell.rowPinned\n };\n }\n getCellToRight(lastCell) {\n if (!lastCell) {\n return null;\n }\n const colToRight = this.columnModel.getDisplayedColAfter(lastCell.column);\n // if already on right, do nothing\n if (!colToRight) {\n return null;\n }\n return {\n rowIndex: lastCell.rowIndex,\n column: colToRight,\n rowPinned: lastCell.rowPinned\n };\n }\n getRowBelow(rowPosition) {\n // if already on top row, do nothing\n const index = rowPosition.rowIndex;\n const pinned = rowPosition.rowPinned;\n if (this.isLastRowInContainer(rowPosition)) {\n switch (pinned) {\n case 'bottom':\n // never any rows after pinned bottom\n return null;\n case 'top':\n // if on last row of pinned top, then next row is main body (if rows exist),\n // otherwise it's the pinned bottom\n if (this.rowModel.isRowsToRender()) {\n return { rowIndex: this.paginationProxy.getPageFirstRow(), rowPinned: null };\n }\n if (this.pinnedRowModel.isRowsToRender('bottom')) {\n return { rowIndex: 0, rowPinned: 'bottom' };\n }\n return null;\n default:\n // if in the main body, then try pinned bottom, otherwise return nothing\n if (this.pinnedRowModel.isRowsToRender('bottom')) {\n return { rowIndex: 0, rowPinned: 'bottom' };\n }\n return null;\n }\n }\n const rowNode = this.rowModel.getRow(rowPosition.rowIndex);\n const nextStickyPosition = this.getNextStickyPosition(rowNode);\n if (nextStickyPosition) {\n return nextStickyPosition;\n }\n return { rowIndex: index + 1, rowPinned: pinned };\n }\n getNextStickyPosition(rowNode, up) {\n if (!this.gridOptionsService.isGroupRowsSticky() || !rowNode || !rowNode.sticky) {\n return;\n }\n const stickyRowCtrls = [...this.rowRenderer.getStickyTopRowCtrls()].sort((a, b) => a.getRowNode().rowIndex - b.getRowNode().rowIndex);\n const diff = up ? -1 : 1;\n const idx = stickyRowCtrls.findIndex(ctrl => ctrl.getRowNode().rowIndex === rowNode.rowIndex);\n const nextCtrl = stickyRowCtrls[idx + diff];\n if (nextCtrl) {\n return { rowIndex: nextCtrl.getRowNode().rowIndex, rowPinned: null };\n }\n }\n getCellBelow(lastCell) {\n if (!lastCell) {\n return null;\n }\n const rowBelow = this.getRowBelow(lastCell);\n if (rowBelow) {\n return {\n rowIndex: rowBelow.rowIndex,\n column: lastCell.column,\n rowPinned: rowBelow.rowPinned\n };\n }\n return null;\n }\n isLastRowInContainer(rowPosition) {\n const pinned = rowPosition.rowPinned;\n const index = rowPosition.rowIndex;\n if (pinned === 'top') {\n const lastTopIndex = this.pinnedRowModel.getPinnedTopRowData().length - 1;\n return lastTopIndex <= index;\n }\n if (pinned === 'bottom') {\n const lastBottomIndex = this.pinnedRowModel.getPinnedBottomRowData().length - 1;\n return lastBottomIndex <= index;\n }\n const lastBodyIndex = this.paginationProxy.getPageLastRow();\n return lastBodyIndex <= index;\n }\n getRowAbove(rowPosition) {\n // if already on top row, do nothing\n const index = rowPosition.rowIndex;\n const pinned = rowPosition.rowPinned;\n const isFirstRow = pinned ? index === 0 : index === this.paginationProxy.getPageFirstRow();\n // if already on top row, do nothing\n if (isFirstRow) {\n if (pinned === 'top') {\n return null;\n }\n if (!pinned) {\n if (this.pinnedRowModel.isRowsToRender('top')) {\n return this.getLastFloatingTopRow();\n }\n return null;\n }\n // last floating bottom\n if (this.rowModel.isRowsToRender()) {\n return this.getLastBodyCell();\n }\n if (this.pinnedRowModel.isRowsToRender('top')) {\n return this.getLastFloatingTopRow();\n }\n return null;\n }\n const rowNode = this.rowModel.getRow(rowPosition.rowIndex);\n const nextStickyPosition = this.getNextStickyPosition(rowNode, true);\n if (nextStickyPosition) {\n return nextStickyPosition;\n }\n return { rowIndex: index - 1, rowPinned: pinned };\n }\n getCellAbove(lastCell) {\n if (!lastCell) {\n return null;\n }\n const rowAbove = this.getRowAbove({ rowIndex: lastCell.rowIndex, rowPinned: lastCell.rowPinned });\n if (rowAbove) {\n return {\n rowIndex: rowAbove.rowIndex,\n column: lastCell.column,\n rowPinned: rowAbove.rowPinned\n };\n }\n return null;\n }\n getLastBodyCell() {\n const lastBodyRow = this.paginationProxy.getPageLastRow();\n return { rowIndex: lastBodyRow, rowPinned: null };\n }\n getLastFloatingTopRow() {\n const lastFloatingRow = this.pinnedRowModel.getPinnedTopRowData().length - 1;\n return { rowIndex: lastFloatingRow, rowPinned: 'top' };\n }\n getNextTabbedCell(gridCell, backwards) {\n if (backwards) {\n return this.getNextTabbedCellBackwards(gridCell);\n }\n return this.getNextTabbedCellForwards(gridCell);\n }\n getNextTabbedCellForwards(gridCell) {\n const displayedColumns = this.columnModel.getAllDisplayedColumns();\n let newRowIndex = gridCell.rowIndex;\n let newFloating = gridCell.rowPinned;\n // move along to the next cell\n let newColumn = this.columnModel.getDisplayedColAfter(gridCell.column);\n // check if end of the row, and if so, go forward a row\n if (!newColumn) {\n newColumn = displayedColumns[0];\n const rowBelow = this.getRowBelow(gridCell);\n if (missing(rowBelow)) {\n return null;\n }\n // If we are tabbing and there is a paging panel present, tabbing should go\n // to the paging panel instead of loading the next page.\n if (!rowBelow.rowPinned && !this.paginationProxy.isRowInPage(rowBelow)) {\n return null;\n }\n newRowIndex = rowBelow ? rowBelow.rowIndex : null;\n newFloating = rowBelow ? rowBelow.rowPinned : null;\n }\n return { rowIndex: newRowIndex, column: newColumn, rowPinned: newFloating };\n }\n getNextTabbedCellBackwards(gridCell) {\n const displayedColumns = this.columnModel.getAllDisplayedColumns();\n let newRowIndex = gridCell.rowIndex;\n let newFloating = gridCell.rowPinned;\n // move along to the next cell\n let newColumn = this.columnModel.getDisplayedColBefore(gridCell.column);\n // check if end of the row, and if so, go forward a row\n if (!newColumn) {\n newColumn = last(displayedColumns);\n const rowAbove = this.getRowAbove({ rowIndex: gridCell.rowIndex, rowPinned: gridCell.rowPinned });\n if (missing(rowAbove)) {\n return null;\n }\n // If we are tabbing and there is a paging panel present, tabbing should go\n // to the paging panel instead of loading the next page.\n if (!rowAbove.rowPinned && !this.paginationProxy.isRowInPage(rowAbove)) {\n return null;\n }\n newRowIndex = rowAbove ? rowAbove.rowIndex : null;\n newFloating = rowAbove ? rowAbove.rowPinned : null;\n }\n return { rowIndex: newRowIndex, column: newColumn, rowPinned: newFloating };\n }\n};\n__decorate([\n Autowired('columnModel')\n], CellNavigationService.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('rowModel')\n], CellNavigationService.prototype, \"rowModel\", void 0);\n__decorate([\n Autowired('rowRenderer')\n], CellNavigationService.prototype, \"rowRenderer\", void 0);\n__decorate([\n Autowired('pinnedRowModel')\n], CellNavigationService.prototype, \"pinnedRowModel\", void 0);\n__decorate([\n Autowired('paginationProxy')\n], CellNavigationService.prototype, \"paginationProxy\", void 0);\nCellNavigationService = __decorate([\n Bean('cellNavigationService')\n], CellNavigationService);\nexport { CellNavigationService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n};\nimport { Events } from \"./events.mjs\";\nimport { Bean } from \"./context/context.mjs\";\nimport { Qualifier } from \"./context/context.mjs\";\nimport { Autowired } from \"./context/context.mjs\";\nimport { PostConstruct } from \"./context/context.mjs\";\nimport { BeanStub } from \"./context/beanStub.mjs\";\nlet AlignedGridsService = class AlignedGridsService extends BeanStub {\n constructor() {\n super(...arguments);\n // flag to mark if we are consuming. to avoid cyclic events (ie other grid firing back to master\n // while processing a master event) we mark this if consuming an event, and if we are, then\n // we don't fire back any events.\n this.consuming = false;\n }\n setBeans(loggerFactory) {\n this.logger = loggerFactory.create('AlignedGridsService');\n }\n init() {\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_MOVED, this.fireColumnEvent.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_VISIBLE, this.fireColumnEvent.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PINNED, this.fireColumnEvent.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_GROUP_OPENED, this.fireColumnEvent.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_RESIZED, this.fireColumnEvent.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_BODY_SCROLL, this.fireScrollEvent.bind(this));\n }\n // common logic across all the fire methods\n fireEvent(callback) {\n // if we are already consuming, then we are acting on an event from a master,\n // so we don't cause a cyclic firing of events\n if (this.consuming) {\n return;\n }\n // iterate through the aligned grids, and pass each aligned grid service to the callback\n const otherGrids = this.gridOptionsService.get('alignedGrids');\n if (otherGrids) {\n otherGrids.forEach((otherGridOptions) => {\n if (otherGridOptions.api) {\n const alignedGridService = otherGridOptions.api.__getAlignedGridService();\n callback(alignedGridService);\n }\n });\n }\n }\n // common logic across all consume methods. very little common logic, however extracting\n // guarantees consistency across the methods.\n onEvent(callback) {\n this.consuming = true;\n callback();\n this.consuming = false;\n }\n fireColumnEvent(event) {\n this.fireEvent(alignedGridsService => {\n alignedGridsService.onColumnEvent(event);\n });\n }\n fireScrollEvent(event) {\n if (event.direction !== 'horizontal') {\n return;\n }\n this.fireEvent(alignedGridsService => {\n alignedGridsService.onScrollEvent(event);\n });\n }\n onScrollEvent(event) {\n this.onEvent(() => {\n const gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n gridBodyCon.getScrollFeature().setHorizontalScrollPosition(event.left, true);\n });\n }\n getMasterColumns(event) {\n const result = [];\n if (event.columns) {\n event.columns.forEach((column) => {\n result.push(column);\n });\n }\n else if (event.column) {\n result.push(event.column);\n }\n return result;\n }\n getColumnIds(event) {\n const result = [];\n if (event.columns) {\n event.columns.forEach(column => {\n result.push(column.getColId());\n });\n }\n else if (event.column) {\n result.push(event.column.getColId());\n }\n return result;\n }\n onColumnEvent(event) {\n this.onEvent(() => {\n switch (event.type) {\n case Events.EVENT_COLUMN_MOVED:\n case Events.EVENT_COLUMN_VISIBLE:\n case Events.EVENT_COLUMN_PINNED:\n case Events.EVENT_COLUMN_RESIZED:\n const colEvent = event;\n this.processColumnEvent(colEvent);\n break;\n case Events.EVENT_COLUMN_GROUP_OPENED:\n const groupOpenedEvent = event;\n this.processGroupOpenedEvent(groupOpenedEvent);\n break;\n case Events.EVENT_COLUMN_PIVOT_CHANGED:\n // we cannot support pivoting with aligned grids as the columns will be out of sync as the\n // grids will have columns created based on the row data of the grid.\n console.warn('AG Grid: pivoting is not supported with aligned grids. ' +\n 'You can only use one of these features at a time in a grid.');\n break;\n }\n });\n }\n processGroupOpenedEvent(groupOpenedEvent) {\n // likewise for column group\n const masterColumnGroup = groupOpenedEvent.columnGroup;\n let otherColumnGroup = null;\n if (masterColumnGroup) {\n const groupId = masterColumnGroup.getGroupId();\n otherColumnGroup = this.columnModel.getProvidedColumnGroup(groupId);\n }\n if (masterColumnGroup && !otherColumnGroup) {\n return;\n }\n this.logger.log('onColumnEvent-> processing ' + groupOpenedEvent + ' expanded = ' + masterColumnGroup.isExpanded());\n this.columnModel.setColumnGroupOpened(otherColumnGroup, masterColumnGroup.isExpanded(), \"alignedGridChanged\");\n }\n processColumnEvent(colEvent) {\n var _a;\n // the column in the event is from the master grid. need to\n // look up the equivalent from this (other) grid\n const masterColumn = colEvent.column;\n let otherColumn = null;\n if (masterColumn) {\n otherColumn = this.columnModel.getPrimaryColumn(masterColumn.getColId());\n }\n // if event was with respect to a master column, that is not present in this\n // grid, then we ignore the event\n if (masterColumn && !otherColumn) {\n return;\n }\n // in time, all the methods below should use the column ids, it's a more generic way\n // of handling columns, and also allows for single or multi column events\n const masterColumns = this.getMasterColumns(colEvent);\n switch (colEvent.type) {\n case Events.EVENT_COLUMN_MOVED:\n // when the user moves columns via applyColumnState, we can't depend on moving specific columns\n // to an index, as there maybe be many indexes columns moved to (as wasn't result of a mouse drag).\n // so only way to be sure is match the order of all columns using Column State.\n {\n const movedEvent = colEvent;\n const srcColState = colEvent.columnApi.getColumnState();\n const destColState = srcColState.map(s => ({ colId: s.colId }));\n this.columnModel.applyColumnState({ state: destColState, applyOrder: true }, \"alignedGridChanged\");\n this.logger.log(`onColumnEvent-> processing ${colEvent.type} toIndex = ${movedEvent.toIndex}`);\n }\n break;\n case Events.EVENT_COLUMN_VISIBLE:\n // when the user changes visibility via applyColumnState, we can't depend on visibility flag in event\n // as there maybe be mix of true/false (as wasn't result of a mouse click to set visiblity).\n // so only way to be sure is match the visibility of all columns using Column State.\n {\n const visibleEvent = colEvent;\n const srcColState = colEvent.columnApi.getColumnState();\n const destColState = srcColState.map(s => ({ colId: s.colId, hide: s.hide }));\n this.columnModel.applyColumnState({ state: destColState }, \"alignedGridChanged\");\n this.logger.log(`onColumnEvent-> processing ${colEvent.type} visible = ${visibleEvent.visible}`);\n }\n break;\n case Events.EVENT_COLUMN_PINNED:\n {\n const pinnedEvent = colEvent;\n const srcColState = colEvent.columnApi.getColumnState();\n const destColState = srcColState.map(s => ({ colId: s.colId, pinned: s.pinned }));\n this.columnModel.applyColumnState({ state: destColState }, \"alignedGridChanged\");\n this.logger.log(`onColumnEvent-> processing ${colEvent.type} pinned = ${pinnedEvent.pinned}`);\n }\n break;\n case Events.EVENT_COLUMN_RESIZED:\n const resizedEvent = colEvent;\n const columnWidths = {};\n masterColumns.forEach((column) => {\n this.logger.log(`onColumnEvent-> processing ${colEvent.type} actualWidth = ${column.getActualWidth()}`);\n columnWidths[column.getId()] = { key: column.getColId(), newWidth: column.getActualWidth() };\n });\n // don't set flex columns width\n (_a = resizedEvent.flexColumns) === null || _a === void 0 ? void 0 : _a.forEach(col => {\n if (columnWidths[col.getId()]) {\n delete columnWidths[col.getId()];\n }\n });\n this.columnModel.setColumnWidths(Object.values(columnWidths), false, resizedEvent.finished, \"alignedGridChanged\");\n break;\n }\n const gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n const isVerticalScrollShowing = gridBodyCon.isVerticalScrollShowing();\n const alignedGrids = this.gridOptionsService.get('alignedGrids');\n if (alignedGrids) {\n alignedGrids.forEach((grid) => {\n if (grid.api) {\n grid.api.setAlwaysShowVerticalScroll(isVerticalScrollShowing);\n }\n });\n }\n }\n};\n__decorate([\n Autowired('columnModel')\n], AlignedGridsService.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], AlignedGridsService.prototype, \"ctrlsService\", void 0);\n__decorate([\n __param(0, Qualifier('loggerFactory'))\n], AlignedGridsService.prototype, \"setBeans\", null);\n__decorate([\n PostConstruct\n], AlignedGridsService.prototype, \"init\", null);\nAlignedGridsService = __decorate([\n Bean('alignedGridsService')\n], AlignedGridsService);\nexport { AlignedGridsService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n};\nimport { Bean } from \"./context/context.mjs\";\nimport { BeanStub } from \"./context/beanStub.mjs\";\nimport { Qualifier } from \"./context/context.mjs\";\nimport { Events } from \"./events.mjs\";\nimport { Autowired } from \"./context/context.mjs\";\nimport { PostConstruct } from \"./context/context.mjs\";\nimport { ChangedPath } from \"./utils/changedPath.mjs\";\nimport { iterateObject } from \"./utils/object.mjs\";\nimport { exists } from \"./utils/generic.mjs\";\nimport { _ } from \"./utils/index.mjs\";\nlet SelectionService = class SelectionService extends BeanStub {\n setBeans(loggerFactory) {\n this.logger = loggerFactory.create('selectionService');\n this.reset();\n }\n init() {\n this.groupSelectsChildren = this.gridOptionsService.is('groupSelectsChildren');\n this.addManagedPropertyListener('groupSelectsChildren', (propChange) => this.groupSelectsChildren = propChange.currentValue);\n this.rowSelection = this.gridOptionsService.get('rowSelection');\n this.addManagedPropertyListener('rowSelection', (propChange) => this.rowSelection = propChange.currentValue);\n this.addManagedListener(this.eventService, Events.EVENT_ROW_SELECTED, this.onRowSelected.bind(this));\n }\n isMultiselect() {\n return this.rowSelection === 'multiple';\n }\n setNodesSelected(params) {\n var _a;\n if (params.nodes.length === 0)\n return 0;\n const { newValue, clearSelection, suppressFinishActions, rangeSelect, event, source = 'api', } = params;\n if (params.nodes.length > 1 && !this.isMultiselect()) {\n console.warn(`AG Grid: cannot multi select while rowSelection='single'`);\n return 0;\n }\n // groupSelectsFiltered only makes sense when group selects children\n const groupSelectsFiltered = this.groupSelectsChildren && (params.groupSelectsFiltered === true);\n // if node is a footer, we don't do selection, just pass the info\n // to the sibling (the parent of the group)\n const nodes = params.nodes.map(node => node.footer ? node.sibling : node);\n if (rangeSelect) {\n if (params.nodes.length > 1) {\n console.warn('AG Grid: cannot range select while selecting multiple rows');\n return 0;\n }\n const lastSelectedNode = this.getLastSelectedNode();\n if (lastSelectedNode) {\n // if node is a footer, we don't do selection, just pass the info\n // to the sibling (the parent of the group)\n const node = nodes[0];\n const newRowClicked = lastSelectedNode !== node;\n if (newRowClicked && this.isMultiselect()) {\n const nodesChanged = this.selectRange(node, lastSelectedNode, params.newValue, source);\n this.setLastSelectedNode(node);\n return nodesChanged;\n }\n }\n }\n let updatedCount = 0;\n for (let i = 0; i < nodes.length; i++) {\n const node = nodes[i];\n // when groupSelectsFiltered, then this node may end up intermediate despite\n // trying to set it to true / false. this group will be calculated further on\n // down when we call calculatedSelectedForAllGroupNodes(). we need to skip it\n // here, otherwise the updatedCount would include it.\n const skipThisNode = groupSelectsFiltered && node.group;\n if (!skipThisNode) {\n const thisNodeWasSelected = node.selectThisNode(newValue, params.event, source);\n if (thisNodeWasSelected) {\n updatedCount++;\n }\n }\n if (this.groupSelectsChildren && ((_a = node.childrenAfterGroup) === null || _a === void 0 ? void 0 : _a.length)) {\n updatedCount += this.selectChildren(node, newValue, groupSelectsFiltered, source);\n }\n }\n // clear other nodes if not doing multi select\n if (!suppressFinishActions) {\n const clearOtherNodes = newValue && (clearSelection || !this.isMultiselect());\n if (clearOtherNodes) {\n updatedCount += this.clearOtherNodes(nodes[0], source);\n }\n // only if we selected something, then update groups and fire events\n if (updatedCount > 0) {\n this.updateGroupsFromChildrenSelections(source);\n // this is the very end of the 'action node', so we are finished all the updates,\n // include any parent / child changes that this method caused\n const event = {\n type: Events.EVENT_SELECTION_CHANGED,\n source\n };\n this.eventService.dispatchEvent(event);\n }\n // so if user next does shift-select, we know where to start the selection from\n if (newValue) {\n this.setLastSelectedNode(nodes[nodes.length - 1]);\n }\n }\n return updatedCount;\n }\n // selects all rows between this node and the last selected node (or the top if this is the first selection).\n // not to be mixed up with 'cell range selection' where you drag the mouse, this is row range selection, by\n // holding down 'shift'.\n selectRange(fromNode, toNode, value = true, source) {\n const nodesToSelect = this.rowModel.getNodesInRangeForSelection(fromNode, toNode);\n let updatedCount = 0;\n nodesToSelect.forEach(rowNode => {\n if (rowNode.group && this.groupSelectsChildren || (value === false && fromNode === rowNode)) {\n return;\n }\n const nodeWasSelected = rowNode.selectThisNode(value, undefined, source);\n if (nodeWasSelected) {\n updatedCount++;\n }\n });\n this.updateGroupsFromChildrenSelections(source);\n const event = {\n type: Events.EVENT_SELECTION_CHANGED,\n source\n };\n this.eventService.dispatchEvent(event);\n return updatedCount;\n }\n selectChildren(node, newValue, groupSelectsFiltered, source) {\n const children = groupSelectsFiltered ? node.childrenAfterAggFilter : node.childrenAfterGroup;\n if (_.missing(children)) {\n return 0;\n }\n return this.setNodesSelected({\n newValue: newValue,\n clearSelection: false,\n suppressFinishActions: true,\n groupSelectsFiltered,\n source,\n nodes: children,\n });\n }\n setLastSelectedNode(rowNode) {\n this.lastSelectedNode = rowNode;\n }\n getLastSelectedNode() {\n return this.lastSelectedNode;\n }\n getSelectedNodes() {\n const selectedNodes = [];\n iterateObject(this.selectedNodes, (key, rowNode) => {\n if (rowNode) {\n selectedNodes.push(rowNode);\n }\n });\n return selectedNodes;\n }\n getSelectedRows() {\n const selectedRows = [];\n iterateObject(this.selectedNodes, (key, rowNode) => {\n if (rowNode && rowNode.data) {\n selectedRows.push(rowNode.data);\n }\n });\n return selectedRows;\n }\n getSelectionCount() {\n return Object.values(this.selectedNodes).length;\n }\n /**\n * This method is used by the CSRM to remove groups which are being disposed of,\n * events do not need fired in this case\n */\n filterFromSelection(predicate) {\n const newSelectedNodes = {};\n Object.entries(this.selectedNodes).forEach(([key, node]) => {\n const passesPredicate = node && predicate(node);\n if (passesPredicate) {\n newSelectedNodes[key] = node;\n }\n });\n this.selectedNodes = newSelectedNodes;\n }\n // should only be called if groupSelectsChildren=true\n updateGroupsFromChildrenSelections(source, changedPath) {\n // we only do this when group selection state depends on selected children\n if (!this.groupSelectsChildren) {\n return false;\n }\n // also only do it if CSRM (code should never allow this anyway)\n if (this.rowModel.getType() !== 'clientSide') {\n return false;\n }\n const clientSideRowModel = this.rowModel;\n const rootNode = clientSideRowModel.getRootNode();\n if (!changedPath) {\n changedPath = new ChangedPath(true, rootNode);\n changedPath.setInactive();\n }\n let selectionChanged = false;\n changedPath.forEachChangedNodeDepthFirst(rowNode => {\n if (rowNode !== rootNode) {\n const selected = rowNode.calculateSelectedFromChildren();\n selectionChanged = rowNode.selectThisNode(selected === null ? false : selected, undefined, source) || selectionChanged;\n }\n });\n return selectionChanged;\n }\n clearOtherNodes(rowNodeToKeepSelected, source) {\n const groupsToRefresh = {};\n let updatedCount = 0;\n iterateObject(this.selectedNodes, (key, otherRowNode) => {\n if (otherRowNode && otherRowNode.id !== rowNodeToKeepSelected.id) {\n const rowNode = this.selectedNodes[otherRowNode.id];\n updatedCount += rowNode.setSelectedParams({\n newValue: false,\n clearSelection: false,\n suppressFinishActions: true,\n source,\n });\n if (this.groupSelectsChildren && otherRowNode.parent) {\n groupsToRefresh[otherRowNode.parent.id] = otherRowNode.parent;\n }\n }\n });\n iterateObject(groupsToRefresh, (key, group) => {\n const selected = group.calculateSelectedFromChildren();\n group.selectThisNode(selected === null ? false : selected, undefined, source);\n });\n return updatedCount;\n }\n onRowSelected(event) {\n const rowNode = event.node;\n // we do not store the group rows when the groups select children\n if (this.groupSelectsChildren && rowNode.group) {\n return;\n }\n if (rowNode.isSelected()) {\n this.selectedNodes[rowNode.id] = rowNode;\n }\n else {\n delete this.selectedNodes[rowNode.id];\n }\n }\n syncInRowNode(rowNode, oldNode) {\n this.syncInOldRowNode(rowNode, oldNode);\n this.syncInNewRowNode(rowNode);\n }\n // if the id has changed for the node, then this means the rowNode\n // is getting used for a different data item, which breaks\n // our selectedNodes, as the node now is mapped by the old id\n // which is inconsistent. so to keep the old node as selected,\n // we swap in the clone (with the old id and old data). this means\n // the oldNode is effectively a daemon we keep a reference to,\n // so if client calls api.getSelectedNodes(), it gets the daemon\n // in the result. when the client un-selects, the reference to the\n // daemon is removed. the daemon, because it's an oldNode, is not\n // used by the grid for rendering, it's a copy of what the node used\n // to be like before the id was changed.\n syncInOldRowNode(rowNode, oldNode) {\n const oldNodeHasDifferentId = exists(oldNode) && (rowNode.id !== oldNode.id);\n if (oldNodeHasDifferentId && oldNode) {\n const id = oldNode.id;\n const oldNodeSelected = this.selectedNodes[id] == rowNode;\n if (oldNodeSelected) {\n this.selectedNodes[oldNode.id] = oldNode;\n }\n }\n }\n syncInNewRowNode(rowNode) {\n if (exists(this.selectedNodes[rowNode.id])) {\n rowNode.setSelectedInitialValue(true);\n this.selectedNodes[rowNode.id] = rowNode;\n }\n else {\n rowNode.setSelectedInitialValue(false);\n }\n }\n reset() {\n this.logger.log('reset');\n this.selectedNodes = {};\n this.lastSelectedNode = null;\n }\n // returns a list of all nodes at 'best cost' - a feature to be used\n // with groups / trees. if a group has all it's children selected,\n // then the group appears in the result, but not the children.\n // Designed for use with 'children' as the group selection type,\n // where groups don't actually appear in the selection normally.\n getBestCostNodeSelection() {\n if (this.rowModel.getType() !== 'clientSide') {\n // Error logged as part of gridApi as that is only call point for this method.\n return;\n }\n const clientSideRowModel = this.rowModel;\n const topLevelNodes = clientSideRowModel.getTopLevelNodes();\n if (topLevelNodes === null) {\n return;\n }\n const result = [];\n // recursive function, to find the selected nodes\n function traverse(nodes) {\n for (let i = 0, l = nodes.length; i < l; i++) {\n const node = nodes[i];\n if (node.isSelected()) {\n result.push(node);\n }\n else {\n // if not selected, then if it's a group, and the group\n // has children, continue to search for selections\n const maybeGroup = node;\n if (maybeGroup.group && maybeGroup.children) {\n traverse(maybeGroup.children);\n }\n }\n }\n }\n traverse(topLevelNodes);\n return result;\n }\n isEmpty() {\n let count = 0;\n iterateObject(this.selectedNodes, (nodeId, rowNode) => {\n if (rowNode) {\n count++;\n }\n });\n return count === 0;\n }\n deselectAllRowNodes(params) {\n const callback = (rowNode) => rowNode.selectThisNode(false, undefined, source);\n const rowModelClientSide = this.rowModel.getType() === 'clientSide';\n const { source, justFiltered, justCurrentPage } = params;\n if (justCurrentPage || justFiltered) {\n if (!rowModelClientSide) {\n console.error(\"AG Grid: selecting just filtered only works when gridOptions.rowModelType='clientSide'\");\n return;\n }\n this.getNodesToSelect(justFiltered, justCurrentPage).forEach(callback);\n }\n else {\n iterateObject(this.selectedNodes, (id, rowNode) => {\n // remember the reference can be to null, as we never 'delete' from the map\n if (rowNode) {\n callback(rowNode);\n }\n });\n // this clears down the map (whereas above only sets the items in map to 'undefined')\n this.reset();\n }\n // the above does not clean up the parent rows if they are selected\n if (rowModelClientSide && this.groupSelectsChildren) {\n this.updateGroupsFromChildrenSelections(source);\n }\n const event = {\n type: Events.EVENT_SELECTION_CHANGED,\n source\n };\n this.eventService.dispatchEvent(event);\n }\n getSelectAllState(justFiltered, justCurrentPage) {\n let selectedCount = 0;\n let notSelectedCount = 0;\n const callback = (node) => {\n if (this.groupSelectsChildren && node.group) {\n return;\n }\n if (node.isSelected()) {\n selectedCount++;\n }\n else if (!node.selectable) {\n // don't count non-selectable nodes!\n }\n else {\n notSelectedCount++;\n }\n };\n this.getNodesToSelect(justFiltered, justCurrentPage).forEach(callback);\n // if no rows, always have it unselected\n if (selectedCount === 0 && notSelectedCount === 0) {\n return false;\n }\n // if mix of selected and unselected, this is indeterminate\n if (selectedCount > 0 && notSelectedCount > 0) {\n return null;\n }\n // only selected\n return selectedCount > 0;\n }\n /**\n * @param justFiltered whether to just include nodes which have passed the filter\n * @param justCurrentPage whether to just include nodes on the current page\n * @returns all nodes including unselectable nodes which are the target of this selection attempt\n */\n getNodesToSelect(justFiltered = false, justCurrentPage = false) {\n if (this.rowModel.getType() !== 'clientSide') {\n throw new Error(`selectAll only available when rowModelType='clientSide', ie not ${this.rowModel.getType()}`);\n }\n const nodes = [];\n if (justCurrentPage) {\n this.paginationProxy.forEachNodeOnPage((node) => {\n if (!node.group) {\n nodes.push(node);\n return;\n }\n if (!node.expanded) {\n // even with groupSelectsChildren, do this recursively as only the filtered children\n // are considered as the current page\n const recursivelyAddChildren = (child) => {\n var _a;\n nodes.push(child);\n if ((_a = child.childrenAfterFilter) === null || _a === void 0 ? void 0 : _a.length) {\n child.childrenAfterFilter.forEach(recursivelyAddChildren);\n }\n };\n recursivelyAddChildren(node);\n return;\n }\n // if the group node is expanded, the pagination proxy will include the visible nodes to select\n if (!this.groupSelectsChildren) {\n nodes.push(node);\n }\n });\n return nodes;\n }\n const clientSideRowModel = this.rowModel;\n if (justFiltered) {\n clientSideRowModel.forEachNodeAfterFilter(node => {\n nodes.push(node);\n });\n return nodes;\n }\n clientSideRowModel.forEachNode(node => {\n nodes.push(node);\n });\n return nodes;\n }\n selectAllRowNodes(params) {\n if (this.rowModel.getType() !== 'clientSide') {\n throw new Error(`selectAll only available when rowModelType='clientSide', ie not ${this.rowModel.getType()}`);\n }\n const { source, justFiltered, justCurrentPage } = params;\n const callback = (rowNode) => rowNode.selectThisNode(true, undefined, source);\n this.getNodesToSelect(justFiltered, justCurrentPage).forEach(callback);\n // the above does not clean up the parent rows if they are selected\n if (this.rowModel.getType() === 'clientSide' && this.groupSelectsChildren) {\n this.updateGroupsFromChildrenSelections(source);\n }\n const event = {\n type: Events.EVENT_SELECTION_CHANGED,\n source\n };\n this.eventService.dispatchEvent(event);\n }\n // Used by SSRM\n getServerSideSelectionState() {\n return null;\n }\n setServerSideSelectionState(state) { }\n};\n__decorate([\n Autowired('rowModel')\n], SelectionService.prototype, \"rowModel\", void 0);\n__decorate([\n Autowired('paginationProxy')\n], SelectionService.prototype, \"paginationProxy\", void 0);\n__decorate([\n __param(0, Qualifier('loggerFactory'))\n], SelectionService.prototype, \"setBeans\", null);\n__decorate([\n PostConstruct\n], SelectionService.prototype, \"init\", null);\nSelectionService = __decorate([\n Bean('selectionService')\n], SelectionService);\nexport { SelectionService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, PreDestroy } from \"../context/context.mjs\";\nimport { _ } from \"../utils/index.mjs\";\nimport { logDeprecation } from \"../gridOptionsValidator.mjs\";\nlet ColumnApi = class ColumnApi {\n /**\n * Gets the grid to size the columns to the specified width in pixels, e.g. `sizeColumnsToFit(900)`.\n * To have the grid fit the columns to the grid's width, use the Grid API `gridApi.sizeColumnsToFit()` instead.\n * If inferring cell data types with custom column types and row data is provided asynchronously,\n * the column sizing will happen asynchronously when row data is added.\n * To always perform this synchronously, set `cellDataType = false` on the default column definition.\n */\n sizeColumnsToFit(gridWidth) {\n // AG-3403 validate that gridWidth is provided because this method has the same name as\n // a method on the grid API that takes no arguments, and it's easy to confuse the two\n if (typeof gridWidth === \"undefined\") {\n console.error('AG Grid: missing parameter to columnApi.sizeColumnsToFit(gridWidth)');\n }\n this.columnModel.sizeColumnsToFit(gridWidth, 'api');\n }\n /** Call this if you want to open or close a column group. */\n setColumnGroupOpened(group, newValue) { this.columnModel.setColumnGroupOpened(group, newValue, 'api'); }\n /** Returns the column group with the given name. */\n getColumnGroup(name, instanceId) { return this.columnModel.getColumnGroup(name, instanceId); }\n /** Returns the provided column group with the given name. */\n getProvidedColumnGroup(name) { return this.columnModel.getProvidedColumnGroup(name); }\n /** Returns the display name for a column. Useful if you are doing your own header rendering and want the grid to work out if `headerValueGetter` is used, or if you are doing your own column management GUI, to know what to show as the column name. */\n getDisplayNameForColumn(column, location) { return this.columnModel.getDisplayNameForColumn(column, location) || ''; }\n /** Returns the display name for a column group (when grouping columns). */\n getDisplayNameForColumnGroup(columnGroup, location) { return this.columnModel.getDisplayNameForColumnGroup(columnGroup, location) || ''; }\n /** Returns the column with the given `colKey`, which can either be the `colId` (a string) or the `colDef` (an object). */\n getColumn(key) { return this.columnModel.getPrimaryColumn(key); }\n /** Returns all the columns, regardless of visible or not. */\n getColumns() { return this.columnModel.getAllPrimaryColumns(); }\n /** Applies the state of the columns from a previous state. Returns `false` if one or more columns could not be found. */\n applyColumnState(params) { return this.columnModel.applyColumnState(params, 'api'); }\n /** Gets the state of the columns. Typically used when saving column state. */\n getColumnState() { return this.columnModel.getColumnState(); }\n /** Sets the state back to match the originally provided column definitions. */\n resetColumnState() { this.columnModel.resetColumnState('api'); }\n /** Gets the state of the column groups. Typically used when saving column group state. */\n getColumnGroupState() { return this.columnModel.getColumnGroupState(); }\n /** Sets the state of the column group state from a previous state. */\n setColumnGroupState(stateItems) { this.columnModel.setColumnGroupState(stateItems, 'api'); }\n /** Sets the state back to match the originally provided column definitions. */\n resetColumnGroupState() { this.columnModel.resetColumnGroupState('api'); }\n /** Returns `true` if pinning left or right, otherwise `false`. */\n isPinning() { return this.columnModel.isPinningLeft() || this.columnModel.isPinningRight(); }\n /** Returns `true` if pinning left, otherwise `false`. */\n isPinningLeft() { return this.columnModel.isPinningLeft(); }\n /** Returns `true` if pinning right, otherwise `false`. */\n isPinningRight() { return this.columnModel.isPinningRight(); }\n /** Returns the column to the right of the provided column, taking into consideration open / closed column groups and visible columns. This is useful if you need to know what column is beside yours e.g. if implementing your own cell navigation. */\n getDisplayedColAfter(col) { return this.columnModel.getDisplayedColAfter(col); }\n /** Same as `getVisibleColAfter` except gives column to the left. */\n getDisplayedColBefore(col) { return this.columnModel.getDisplayedColBefore(col); }\n /** Sets the visibility of a column. Key can be the column ID or `Column` object. */\n setColumnVisible(key, visible) { this.columnModel.setColumnVisible(key, visible, 'api'); }\n /** Same as `setColumnVisible`, but provide a list of column keys. */\n setColumnsVisible(keys, visible) { this.columnModel.setColumnsVisible(keys, visible, 'api'); }\n /** Sets the column pinned / unpinned. Key can be the column ID, field, `ColDef` object or `Column` object. */\n setColumnPinned(key, pinned) { this.columnModel.setColumnPinned(key, pinned, 'api'); }\n /** Same as `setColumnPinned`, but provide a list of column keys. */\n setColumnsPinned(keys, pinned) { this.columnModel.setColumnsPinned(keys, pinned, 'api'); }\n /**\n * Returns all the grid columns, same as `getColumns()`, except\n *\n * a) it has the order of the columns that are presented in the grid\n *\n * b) it's after the 'pivot' step, so if pivoting, has the value columns for the pivot.\n */\n getAllGridColumns() { return this.columnModel.getAllGridColumns(); }\n /** Same as `getAllDisplayedColumns` but just for the pinned left portion of the grid. */\n getDisplayedLeftColumns() { return this.columnModel.getDisplayedLeftColumns(); }\n /** Same as `getAllDisplayedColumns` but just for the center portion of the grid. */\n getDisplayedCenterColumns() { return this.columnModel.getDisplayedCenterColumns(); }\n /** Same as `getAllDisplayedColumns` but just for the pinned right portion of the grid. */\n getDisplayedRightColumns() { return this.columnModel.getDisplayedRightColumns(); }\n /** Returns all columns currently displayed (e.g. are visible and if in a group, the group is showing the columns) for the pinned left, centre and pinned right portions of the grid. */\n getAllDisplayedColumns() { return this.columnModel.getAllDisplayedColumns(); }\n /** Same as `getAllGridColumns()`, except only returns rendered columns, i.e. columns that are not within the viewport and therefore not rendered, due to column virtualisation, are not displayed. */\n getAllDisplayedVirtualColumns() { return this.columnModel.getViewportColumns(); }\n /** Moves a column to `toIndex`. The column is first removed, then added at the `toIndex` location, thus index locations will change to the right of the column after the removal. */\n moveColumn(key, toIndex) {\n this.columnModel.moveColumn(key, toIndex, 'api');\n }\n /** Same as `moveColumn` but works on index locations. */\n moveColumnByIndex(fromIndex, toIndex) { this.columnModel.moveColumnByIndex(fromIndex, toIndex, 'api'); }\n /** Same as `moveColumn` but works on list. */\n moveColumns(columnsToMoveKeys, toIndex) { this.columnModel.moveColumns(columnsToMoveKeys, toIndex, 'api'); }\n /** Move the column to a new position in the row grouping order. */\n moveRowGroupColumn(fromIndex, toIndex) { this.columnModel.moveRowGroupColumn(fromIndex, toIndex); }\n /** Sets the agg function for a column. `aggFunc` can be one of the built-in aggregations or a custom aggregation by name or direct function. */\n setColumnAggFunc(key, aggFunc) { this.columnModel.setColumnAggFunc(key, aggFunc); }\n /** Sets the column width on a single column. The finished flag gets included in the resulting event and not used internally by the grid. The finished flag is intended for dragging, where a dragging action will produce many `columnWidth` events, so the consumer of events knows when it receives the last event in a stream. The finished parameter is optional, and defaults to `true`. */\n setColumnWidth(key, newWidth, finished = true, source) {\n this.columnModel.setColumnWidths([{ key, newWidth }], false, finished, source);\n }\n /** Sets the column widths on multiple columns. This method offers better performance than calling `setColumnWidth` multiple times. The finished flag gets included in the resulting event and not used internally by the grid. The finished flag is intended for dragging, where a dragging action will produce many `columnWidth` events, so the consumer of events knows when it receives the last event in a stream. The finished parameter is optional, and defaults to `true`. */\n setColumnWidths(columnWidths, finished = true, source) {\n this.columnModel.setColumnWidths(columnWidths, false, finished, source);\n }\n /** Set the pivot mode. */\n setPivotMode(pivotMode) { this.columnModel.setPivotMode(pivotMode); }\n /** Get the pivot mode. */\n isPivotMode() { return this.columnModel.isPivotMode(); }\n /** Returns the pivot result column for the given `pivotKeys` and `valueColId`. Useful to then call operations on the pivot column. */\n getPivotResultColumn(pivotKeys, valueColKey) { return this.columnModel.getSecondaryPivotColumn(pivotKeys, valueColKey); }\n /** Set the value columns to the provided list of columns. */\n setValueColumns(colKeys) { this.columnModel.setValueColumns(colKeys, 'api'); }\n /** Get a list of the existing value columns. */\n getValueColumns() { return this.columnModel.getValueColumns(); }\n /** Remove the given column from the existing set of value columns. */\n removeValueColumn(colKey) { this.columnModel.removeValueColumn(colKey, 'api'); }\n /** Like `removeValueColumn` but remove the given list of columns from the existing set of value columns. */\n removeValueColumns(colKeys) { this.columnModel.removeValueColumns(colKeys, 'api'); }\n /** Add the given column to the set of existing value columns. */\n addValueColumn(colKey) { this.columnModel.addValueColumn(colKey, 'api'); }\n /** Like `addValueColumn` but add the given list of columns to the existing set of value columns. */\n addValueColumns(colKeys) { this.columnModel.addValueColumns(colKeys, 'api'); }\n /** Set the row group columns. */\n setRowGroupColumns(colKeys) { this.columnModel.setRowGroupColumns(colKeys, 'api'); }\n /** Remove a column from the row groups. */\n removeRowGroupColumn(colKey) { this.columnModel.removeRowGroupColumn(colKey, 'api'); }\n /** Same as `removeRowGroupColumn` but provide a list of columns. */\n removeRowGroupColumns(colKeys) { this.columnModel.removeRowGroupColumns(colKeys, 'api'); }\n /** Add a column to the row groups. */\n addRowGroupColumn(colKey) { this.columnModel.addRowGroupColumn(colKey, 'api'); }\n /** Same as `addRowGroupColumn` but provide a list of columns. */\n addRowGroupColumns(colKeys) { this.columnModel.addRowGroupColumns(colKeys, 'api'); }\n /** Get row group columns. */\n getRowGroupColumns() { return this.columnModel.getRowGroupColumns(); }\n /** Set the pivot columns. */\n setPivotColumns(colKeys) { this.columnModel.setPivotColumns(colKeys, 'api'); }\n /** Remove a pivot column. */\n removePivotColumn(colKey) { this.columnModel.removePivotColumn(colKey, 'api'); }\n /** Same as `removePivotColumn` but provide a list of columns. */\n removePivotColumns(colKeys) { this.columnModel.removePivotColumns(colKeys, 'api'); }\n /** Add a pivot column. */\n addPivotColumn(colKey) { this.columnModel.addPivotColumn(colKey, 'api'); }\n /** Same as `addPivotColumn` but provide a list of columns. */\n addPivotColumns(colKeys) { this.columnModel.addPivotColumns(colKeys, 'api'); }\n /** Get the pivot columns. */\n getPivotColumns() { return this.columnModel.getPivotColumns(); }\n /** Same as `getAllDisplayedColumnGroups` but just for the pinned left portion of the grid. */\n getLeftDisplayedColumnGroups() { return this.columnModel.getDisplayedTreeLeft(); }\n /** Same as `getAllDisplayedColumnGroups` but just for the center portion of the grid. */\n getCenterDisplayedColumnGroups() { return this.columnModel.getDisplayedTreeCentre(); }\n /** Same as `getAllDisplayedColumnGroups` but just for the pinned right portion of the grid. */\n getRightDisplayedColumnGroups() { return this.columnModel.getDisplayedTreeRight(); }\n /** Returns all 'root' column headers. If you are not grouping columns, these return the columns. If you are grouping, these return the top level groups - you can navigate down through each one to get the other lower level headers and finally the columns at the bottom. */\n getAllDisplayedColumnGroups() { return this.columnModel.getAllDisplayedTrees(); }\n /**\n * Auto-sizes a column based on its contents. If inferring cell data types with custom column types and row data is provided asynchronously,\n * the column sizing will happen asynchronously when row data is added. To always perform this synchronously,\n * set `cellDataType = false` on the default column definition.\n */\n autoSizeColumn(key, skipHeader) { return this.columnModel.autoSizeColumn(key, skipHeader, 'api'); }\n /**\n * Same as `autoSizeColumn`, but provide a list of column keys. If inferring cell data types with custom column types\n * and row data is provided asynchronously, the column sizing will happen asynchronously when row data is added.\n * To always perform this synchronously, set `cellDataType = false` on the default column definition.\n */\n autoSizeColumns(keys, skipHeader) {\n this.columnModel.autoSizeColumns({ columns: keys, skipHeader: skipHeader });\n }\n /**\n * Calls `autoSizeColumns` on all displayed columns. If inferring cell data types with custom column types\n * and row data is provided asynchronously, the column sizing will happen asynchronously when row data is added.\n * To always perform this synchronously, set `cellDataType = false` on the default column definition.\n */\n autoSizeAllColumns(skipHeader) { this.columnModel.autoSizeAllColumns(skipHeader, 'api'); }\n /** Set the pivot result columns. */\n setPivotResultColumns(colDefs) { this.columnModel.setSecondaryColumns(colDefs, 'api'); }\n /** Returns the grid's pivot result columns. */\n getPivotResultColumns() { return this.columnModel.getSecondaryColumns(); }\n cleanDownReferencesToAvoidMemoryLeakInCaseApplicationIsKeepingReferenceToDestroyedGrid() {\n // some users were raising support issues with regards memory leaks. the problem was the customers applications\n // were keeping references to the API. trying to educate them all would be difficult, easier to just remove\n // all references in the API so at least the core grid can be garbage collected.\n //\n // wait about 100ms before clearing down the references, in case user has some cleanup to do,\n // and needs to deference the API first\n setTimeout(_.removeAllReferences.bind(window, this, 'Column API'), 100);\n }\n /** @deprecated v28 Use `getColumns` instead */\n getAllColumns() {\n logDeprecation('28.0', 'getAllColumns', 'getColumns');\n return this.getColumns();\n }\n /** @deprecated v28 Use `getColumns` instead. */\n getPrimaryColumns() {\n logDeprecation('28.0', 'getPrimaryColumns', 'getColumns');\n return this.getColumns();\n }\n /** @deprecated v28 Use `getPivotResultColumns` instead. */\n getSecondaryColumns() {\n logDeprecation('28.0', 'getSecondaryColumns', 'getPivotResultColumns');\n return this.getPivotResultColumns();\n }\n /** @deprecated v28 Use `setPivotResultColumns` instead. */\n setSecondaryColumns(colDefs) {\n logDeprecation('28.0', 'setSecondaryColumns', 'setPivotResultColumns');\n this.setPivotResultColumns(colDefs);\n }\n /** @deprecated v28 Use `getPivotResultColumn` instead */\n getSecondaryPivotColumn(pivotKeys, valueColKey) {\n logDeprecation('28.0', 'getSecondaryPivotColumn', 'getPivotResultColumn');\n return this.getPivotResultColumn(pivotKeys, valueColKey);\n }\n};\n__decorate([\n Autowired('columnModel')\n], ColumnApi.prototype, \"columnModel\", void 0);\n__decorate([\n PreDestroy\n], ColumnApi.prototype, \"cleanDownReferencesToAvoidMemoryLeakInCaseApplicationIsKeepingReferenceToDestroyedGrid\", null);\nColumnApi = __decorate([\n Bean('columnApi')\n], ColumnApi);\nexport { ColumnApi };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, PostConstruct } from \"../context/context.mjs\";\nimport { Events } from \"../events.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { getValueUsingField } from \"../utils/object.mjs\";\nimport { missing, exists } from \"../utils/generic.mjs\";\nimport { doOnce } from \"../utils/function.mjs\";\nlet ValueService = class ValueService extends BeanStub {\n constructor() {\n super(...arguments);\n this.initialised = false;\n this.isSsrm = false;\n }\n init() {\n this.isSsrm = this.gridOptionsService.isRowModelType('serverSide');\n this.cellExpressions = this.gridOptionsService.is('enableCellExpressions');\n this.isTreeData = this.gridOptionsService.is('treeData');\n this.initialised = true;\n // We listen to our own event and use it to call the columnSpecific callback,\n // this way the handler calls are correctly interleaved with other global events\n this.eventService.addEventListener(Events.EVENT_CELL_VALUE_CHANGED, (event) => this.callColumnCellValueChangedHandler(event), this.gridOptionsService.useAsyncEvents());\n this.addManagedPropertyListener('treeData', (propChange) => this.isTreeData = propChange.currentValue);\n }\n getValue(column, rowNode, forFilter = false, ignoreAggData = false) {\n // hack - the grid is getting refreshed before this bean gets initialised, race condition.\n // really should have a way so they get initialised in the right order???\n if (!this.initialised) {\n this.init();\n }\n if (!rowNode) {\n return;\n }\n // pull these out to make code below easier to read\n const colDef = column.getColDef();\n const field = colDef.field;\n const colId = column.getColId();\n const data = rowNode.data;\n let result;\n // if there is a value getter, this gets precedence over a field\n const groupDataExists = rowNode.groupData && rowNode.groupData[colId] !== undefined;\n const aggDataExists = !ignoreAggData && rowNode.aggData && rowNode.aggData[colId] !== undefined;\n // SSRM agg data comes from the data attribute, so ignore that instead\n const ignoreSsrmAggData = this.isSsrm && ignoreAggData && !!column.getColDef().aggFunc;\n const ssrmFooterGroupCol = this.isSsrm && rowNode.footer && rowNode.field && (column.getColDef().showRowGroup === true || column.getColDef().showRowGroup === rowNode.field);\n if (forFilter && colDef.filterValueGetter) {\n result = this.executeFilterValueGetter(colDef.filterValueGetter, data, column, rowNode);\n }\n else if (this.isTreeData && aggDataExists) {\n result = rowNode.aggData[colId];\n }\n else if (this.isTreeData && colDef.valueGetter) {\n result = this.executeValueGetter(colDef.valueGetter, data, column, rowNode);\n }\n else if (this.isTreeData && (field && data)) {\n result = getValueUsingField(data, field, column.isFieldContainsDots());\n }\n else if (groupDataExists) {\n result = rowNode.groupData[colId];\n }\n else if (aggDataExists) {\n result = rowNode.aggData[colId];\n }\n else if (colDef.valueGetter) {\n result = this.executeValueGetter(colDef.valueGetter, data, column, rowNode);\n }\n else if (ssrmFooterGroupCol) {\n // this is for group footers in SSRM, as the SSRM row won't have groupData, need to extract\n // the group value from the data using the row field\n result = getValueUsingField(data, rowNode.field, column.isFieldContainsDots());\n }\n else if (field && data && !ignoreSsrmAggData) {\n result = getValueUsingField(data, field, column.isFieldContainsDots());\n }\n // the result could be an expression itself, if we are allowing cell values to be expressions\n if (this.cellExpressions && (typeof result === 'string') && result.indexOf('=') === 0) {\n const cellValueGetter = result.substring(1);\n result = this.executeValueGetter(cellValueGetter, data, column, rowNode);\n }\n if (result == null) {\n const openedGroup = this.getOpenedGroup(rowNode, column);\n if (openedGroup != null) {\n return openedGroup;\n }\n }\n return result;\n }\n getOpenedGroup(rowNode, column) {\n if (!this.gridOptionsService.is('showOpenedGroup')) {\n return;\n }\n const colDef = column.getColDef();\n if (!colDef.showRowGroup) {\n return;\n }\n const showRowGroup = column.getColDef().showRowGroup;\n let pointer = rowNode.parent;\n while (pointer != null) {\n if (pointer.rowGroupColumn && (showRowGroup === true || showRowGroup === pointer.rowGroupColumn.getColId())) {\n return pointer.key;\n }\n pointer = pointer.parent;\n }\n return undefined;\n }\n /**\n * Sets the value of a GridCell\n * @param rowNode The `RowNode` to be updated\n * @param colKey The `Column` to be updated\n * @param newValue The new value to be set\n * @param eventSource The event source\n * @returns `True` if the value has been updated, otherwise`False`.\n */\n setValue(rowNode, colKey, newValue, eventSource) {\n const column = this.columnModel.getPrimaryColumn(colKey);\n if (!rowNode || !column) {\n return false;\n }\n // this will only happen if user is trying to paste into a group row, which doesn't make sense\n // the user should not be trying to paste into group rows\n if (missing(rowNode.data)) {\n rowNode.data = {};\n }\n const { field, valueSetter } = column.getColDef();\n if (missing(field) && missing(valueSetter)) {\n console.warn(`AG Grid: you need either field or valueSetter set on colDef for editing to work`);\n return false;\n }\n if (!this.dataTypeService.checkType(column, newValue)) {\n console.warn(`AG Grid: Data type of the new value does not match the cell data type of the column`);\n return false;\n }\n const params = {\n node: rowNode,\n data: rowNode.data,\n oldValue: this.getValue(column, rowNode),\n newValue: newValue,\n colDef: column.getColDef(),\n column: column,\n api: this.gridOptionsService.api,\n columnApi: this.gridOptionsService.columnApi,\n context: this.gridOptionsService.context\n };\n params.newValue = newValue;\n let valueWasDifferent;\n if (exists(valueSetter)) {\n if (typeof valueSetter === 'function') {\n valueWasDifferent = valueSetter(params);\n }\n else {\n valueWasDifferent = this.expressionService.evaluate(valueSetter, params);\n }\n }\n else {\n valueWasDifferent = this.setValueUsingField(rowNode.data, field, newValue, column.isFieldContainsDots());\n }\n // in case user forgot to return something (possible if they are not using TypeScript\n // and just forgot we default the return value to true, so we always refresh.\n if (valueWasDifferent === undefined) {\n valueWasDifferent = true;\n }\n // if no change to the value, then no need to do the updating, or notifying via events.\n // otherwise the user could be tabbing around the grid, and cellValueChange would get called\n // all the time.\n if (!valueWasDifferent) {\n return false;\n }\n // reset quick filter on this row\n rowNode.resetQuickFilterAggregateText();\n this.valueCache.onDataChanged();\n params.newValue = this.getValue(column, rowNode);\n const event = {\n type: Events.EVENT_CELL_VALUE_CHANGED,\n event: null,\n rowIndex: rowNode.rowIndex,\n rowPinned: rowNode.rowPinned,\n column: params.column,\n api: params.api,\n columnApi: params.columnApi,\n colDef: params.colDef,\n context: params.context,\n data: rowNode.data,\n node: rowNode,\n oldValue: params.oldValue,\n newValue: params.newValue,\n value: params.newValue,\n source: eventSource\n };\n this.eventService.dispatchEvent(event);\n return true;\n }\n callColumnCellValueChangedHandler(event) {\n const onCellValueChanged = event.colDef.onCellValueChanged;\n if (typeof onCellValueChanged === 'function') {\n onCellValueChanged({\n node: event.node,\n data: event.data,\n oldValue: event.oldValue,\n newValue: event.newValue,\n colDef: event.colDef,\n column: event.column,\n api: event.api,\n columnApi: event.columnApi,\n context: event.context\n });\n }\n }\n setValueUsingField(data, field, newValue, isFieldContainsDots) {\n if (!field) {\n return false;\n }\n // if no '.', then it's not a deep value\n let valuesAreSame = false;\n if (!isFieldContainsDots) {\n valuesAreSame = data[field] === newValue;\n if (!valuesAreSame) {\n data[field] = newValue;\n }\n }\n else {\n // otherwise it is a deep value, so need to dig for it\n const fieldPieces = field.split('.');\n let currentObject = data;\n while (fieldPieces.length > 0 && currentObject) {\n const fieldPiece = fieldPieces.shift();\n if (fieldPieces.length === 0) {\n valuesAreSame = currentObject[fieldPiece] === newValue;\n if (!valuesAreSame) {\n currentObject[fieldPiece] = newValue;\n }\n }\n else {\n currentObject = currentObject[fieldPiece];\n }\n }\n }\n return !valuesAreSame;\n }\n executeFilterValueGetter(valueGetter, data, column, rowNode) {\n const params = {\n data: data,\n node: rowNode,\n column: column,\n colDef: column.getColDef(),\n api: this.gridOptionsService.api,\n columnApi: this.gridOptionsService.columnApi,\n context: this.gridOptionsService.context,\n getValue: this.getValueCallback.bind(this, rowNode)\n };\n if (typeof valueGetter === 'function') {\n return valueGetter(params);\n }\n return this.expressionService.evaluate(valueGetter, params);\n }\n executeValueGetter(valueGetter, data, column, rowNode) {\n const colId = column.getColId();\n // if inside the same turn, just return back the value we got last time\n const valueFromCache = this.valueCache.getValue(rowNode, colId);\n if (valueFromCache !== undefined) {\n return valueFromCache;\n }\n const params = {\n data: data,\n node: rowNode,\n column: column,\n colDef: column.getColDef(),\n api: this.gridOptionsService.api,\n columnApi: this.gridOptionsService.columnApi,\n context: this.gridOptionsService.context,\n getValue: this.getValueCallback.bind(this, rowNode)\n };\n let result;\n if (typeof valueGetter === 'function') {\n result = valueGetter(params);\n }\n else {\n result = this.expressionService.evaluate(valueGetter, params);\n }\n // if a turn is active, store the value in case the grid asks for it again\n this.valueCache.setValue(rowNode, colId, result);\n return result;\n }\n getValueCallback(node, field) {\n const otherColumn = this.columnModel.getPrimaryColumn(field);\n if (otherColumn) {\n return this.getValue(otherColumn, node);\n }\n return null;\n }\n // used by row grouping and pivot, to get key for a row. col can be a pivot col or a row grouping col\n getKeyForNode(col, rowNode) {\n const value = this.getValue(col, rowNode);\n const keyCreator = col.getColDef().keyCreator;\n let result = value;\n if (keyCreator) {\n const keyParams = {\n value: value,\n colDef: col.getColDef(),\n column: col,\n node: rowNode,\n data: rowNode.data,\n api: this.gridOptionsService.api,\n columnApi: this.gridOptionsService.columnApi,\n context: this.gridOptionsService.context\n };\n result = keyCreator(keyParams);\n }\n // if already a string, or missing, just return it\n if (typeof result === 'string' || result == null) {\n return result;\n }\n result = String(result);\n if (result === '[object Object]') {\n doOnce(() => {\n console.warn('AG Grid: a column you are grouping or pivoting by has objects as values. If you want to group by complex objects then either a) use a colDef.keyCreator (se AG Grid docs) or b) to toString() on the object to return a key');\n }, 'getKeyForNode - warn about [object,object]');\n }\n return result;\n }\n};\n__decorate([\n Autowired('expressionService')\n], ValueService.prototype, \"expressionService\", void 0);\n__decorate([\n Autowired('columnModel')\n], ValueService.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('valueCache')\n], ValueService.prototype, \"valueCache\", void 0);\n__decorate([\n Autowired('dataTypeService')\n], ValueService.prototype, \"dataTypeService\", void 0);\n__decorate([\n PostConstruct\n], ValueService.prototype, \"init\", null);\nValueService = __decorate([\n Bean('valueService')\n], ValueService);\nexport { ValueService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n};\nimport { Bean } from \"../context/context.mjs\";\nimport { Qualifier } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nlet ExpressionService = class ExpressionService extends BeanStub {\n constructor() {\n super(...arguments);\n this.expressionToFunctionCache = {};\n }\n setBeans(loggerFactory) {\n this.logger = loggerFactory.create('ExpressionService');\n }\n evaluate(expression, params) {\n if (typeof expression === 'string') {\n // valueGetter is an expression, so execute the expression\n return this.evaluateExpression(expression, params);\n }\n else {\n console.error('AG Grid: value should be either a string or a function', expression);\n }\n }\n evaluateExpression(expression, params) {\n try {\n const javaScriptFunction = this.createExpressionFunction(expression);\n // the params don't have all these values, rather we add every possible\n // value a params can have, which makes whatever is in the params available.\n const result = javaScriptFunction(params.value, params.context, params.oldValue, params.newValue, params.value, params.node, params.data, params.colDef, params.rowIndex, params.api, params.columnApi, params.getValue, params.column, params.columnGroup);\n return result;\n }\n catch (e) {\n // the expression failed, which can happen, as it's the client that\n // provides the expression. so print a nice message\n // tslint:disable-next-line\n console.log('Processing of the expression failed');\n // tslint:disable-next-line\n console.log('Expression = ' + expression);\n // tslint:disable-next-line\n console.log('Params =', params);\n // tslint:disable-next-line\n console.log('Exception = ' + e);\n return null;\n }\n }\n createExpressionFunction(expression) {\n // check cache first\n if (this.expressionToFunctionCache[expression]) {\n return this.expressionToFunctionCache[expression];\n }\n // if not found in cache, return the function\n const functionBody = this.createFunctionBody(expression);\n const theFunction = new Function('x, ctx, oldValue, newValue, value, node, data, colDef, rowIndex, api, columnApi, getValue, column, columnGroup', functionBody);\n // store in cache\n this.expressionToFunctionCache[expression] = theFunction;\n return theFunction;\n }\n createFunctionBody(expression) {\n // if the expression has the 'return' word in it, then use as is,\n // if not, then wrap it with return and ';' to make a function\n if (expression.indexOf('return') >= 0) {\n return expression;\n }\n else {\n return 'return ' + expression + ';';\n }\n }\n};\n__decorate([\n __param(0, Qualifier('loggerFactory'))\n], ExpressionService.prototype, \"setBeans\", null);\nExpressionService = __decorate([\n Bean('expressionService')\n], ExpressionService);\nexport { ExpressionService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean } from \"./context/context.mjs\";\nimport { BeanStub } from \"./context/beanStub.mjs\";\nlet TemplateService = class TemplateService extends BeanStub {\n constructor() {\n super(...arguments);\n this.templateCache = {};\n this.waitingCallbacks = {};\n }\n // returns the template if it is loaded, or null if it is not loaded\n // but will call the callback when it is loaded\n getTemplate(url, callback) {\n const templateFromCache = this.templateCache[url];\n if (templateFromCache) {\n return templateFromCache;\n }\n let callbackList = this.waitingCallbacks[url];\n const that = this;\n if (!callbackList) {\n // first time this was called, so need a new list for callbacks\n callbackList = [];\n this.waitingCallbacks[url] = callbackList;\n // and also need to do the http request\n const client = new XMLHttpRequest();\n client.onload = function () {\n that.handleHttpResult(this, url);\n };\n client.open(\"GET\", url);\n client.send();\n }\n // add this callback\n if (callback) {\n callbackList.push(callback);\n }\n // caller needs to wait for template to load, so return null\n return null;\n }\n handleHttpResult(httpResult, url) {\n if (httpResult.status !== 200 || httpResult.response === null) {\n console.warn(`AG Grid: Unable to get template error ${httpResult.status} - ${url}`);\n return;\n }\n // response success, so process it\n // in IE9 the response is in - responseText\n this.templateCache[url] = httpResult.response || httpResult.responseText;\n // inform all listeners that this is now in the cache\n const callbacks = this.waitingCallbacks[url];\n for (let i = 0; i < callbacks.length; i++) {\n const callback = callbacks[i];\n // we could pass the callback the response, however we know the client of this code\n // is the cell renderer, and it passes the 'cellRefresh' method in as the callback\n // which doesn't take any parameters.\n callback();\n }\n }\n};\nTemplateService = __decorate([\n Bean('templateService')\n], TemplateService);\nexport { TemplateService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n};\nimport { Bean } from \"./context/context.mjs\";\nimport { Qualifier } from \"./context/context.mjs\";\nimport { BeanStub } from \"./context/beanStub.mjs\";\nlet LoggerFactory = class LoggerFactory extends BeanStub {\n setBeans(gridOptionsService) {\n this.logging = gridOptionsService.is('debug');\n }\n create(name) {\n return new Logger(name, this.isLogging.bind(this));\n }\n isLogging() {\n return this.logging;\n }\n};\n__decorate([\n __param(0, Qualifier('gridOptionsService'))\n], LoggerFactory.prototype, \"setBeans\", null);\nLoggerFactory = __decorate([\n Bean('loggerFactory')\n], LoggerFactory);\nexport { LoggerFactory };\nexport class Logger {\n constructor(name, isLoggingFunc) {\n this.name = name;\n this.isLoggingFunc = isLoggingFunc;\n }\n isLogging() {\n return this.isLoggingFunc();\n }\n log(message) {\n if (this.isLoggingFunc()) {\n // tslint:disable-next-line\n console.log('AG Grid.' + this.name + ': ' + message);\n }\n }\n}\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { ModuleRegistry } from \"../modules/moduleRegistry.mjs\";\nimport { ModuleNames } from \"../modules/moduleNames.mjs\";\nimport { LayoutFeature } from \"../styling/layoutFeature.mjs\";\nimport { Events } from \"../eventKeys.mjs\";\nimport { last } from \"../utils/array.mjs\";\nimport { DragAndDropService, DragSourceType } from \"../dragAndDrop/dragAndDropService.mjs\";\nexport class GridCtrl extends BeanStub {\n setComp(view, eGridDiv, eGui) {\n this.view = view;\n this.eGridHostDiv = eGridDiv;\n this.eGui = eGui;\n this.eGui.setAttribute('grid-id', this.context.getGridId());\n // this drop target is just used to see if the drop event is inside the grid\n this.dragAndDropService.addDropTarget({\n getContainer: () => this.eGui,\n isInterestedIn: (type) => type === DragSourceType.HeaderCell || type === DragSourceType.ToolPanel,\n getIconName: () => DragAndDropService.ICON_NOT_ALLOWED,\n });\n this.mouseEventService.stampTopLevelGridCompWithGridInstance(eGridDiv);\n this.createManagedBean(new LayoutFeature(this.view));\n this.addRtlSupport();\n this.addManagedListener(this, Events.EVENT_KEYBOARD_FOCUS, () => {\n this.view.addOrRemoveKeyboardFocusClass(true);\n });\n this.addManagedListener(this, Events.EVENT_MOUSE_FOCUS, () => {\n this.view.addOrRemoveKeyboardFocusClass(false);\n });\n const unsubscribeFromResize = this.resizeObserverService.observeResize(this.eGridHostDiv, this.onGridSizeChanged.bind(this));\n this.addDestroyFunc(() => unsubscribeFromResize());\n this.ctrlsService.registerGridCtrl(this);\n }\n isDetailGrid() {\n var _a;\n const el = this.focusService.findTabbableParent(this.getGui());\n return ((_a = el === null || el === void 0 ? void 0 : el.getAttribute('row-id')) === null || _a === void 0 ? void 0 : _a.startsWith('detail')) || false;\n }\n showDropZones() {\n return ModuleRegistry.__isRegistered(ModuleNames.RowGroupingModule, this.context.getGridId());\n }\n showSideBar() {\n return ModuleRegistry.__isRegistered(ModuleNames.SideBarModule, this.context.getGridId());\n }\n showStatusBar() {\n return ModuleRegistry.__isRegistered(ModuleNames.StatusBarModule, this.context.getGridId());\n }\n showWatermark() {\n return ModuleRegistry.__isRegistered(ModuleNames.EnterpriseCoreModule, this.context.getGridId());\n }\n onGridSizeChanged() {\n const event = {\n type: Events.EVENT_GRID_SIZE_CHANGED,\n clientWidth: this.eGridHostDiv.clientWidth,\n clientHeight: this.eGridHostDiv.clientHeight\n };\n this.eventService.dispatchEvent(event);\n }\n addRtlSupport() {\n const cssClass = this.gridOptionsService.is('enableRtl') ? 'ag-rtl' : 'ag-ltr';\n this.view.setRtlClass(cssClass);\n }\n destroyGridUi() {\n this.view.destroyGridUi();\n }\n getGui() {\n return this.eGui;\n }\n setResizeCursor(on) {\n this.view.setCursor(on ? 'ew-resize' : null);\n }\n disableUserSelect(on) {\n this.view.setUserSelect(on ? 'none' : null);\n }\n focusNextInnerContainer(backwards) {\n const eDocument = this.gridOptionsService.getDocument();\n const focusableContainers = this.view.getFocusableContainers();\n const idxWithFocus = focusableContainers.findIndex(container => container.contains(eDocument.activeElement));\n const nextIdx = idxWithFocus + (backwards ? -1 : 1);\n if (nextIdx <= 0 || nextIdx >= focusableContainers.length) {\n return false;\n }\n return this.focusService.focusInto(focusableContainers[nextIdx]);\n }\n focusInnerElement(fromBottom) {\n const focusableContainers = this.view.getFocusableContainers();\n const allColumns = this.columnModel.getAllDisplayedColumns();\n if (fromBottom) {\n if (focusableContainers.length > 1) {\n return this.focusService.focusInto(last(focusableContainers), true);\n }\n const lastColumn = last(allColumns);\n if (this.focusService.focusGridView(lastColumn, true)) {\n return true;\n }\n }\n if (this.gridOptionsService.getNum('headerHeight') === 0) {\n return this.focusService.focusGridView(allColumns[0]);\n }\n return this.focusService.focusFirstHeader();\n }\n forceFocusOutOfContainer(up = false) {\n this.view.forceFocusOutOfContainer(up);\n }\n}\n__decorate([\n Autowired('focusService')\n], GridCtrl.prototype, \"focusService\", void 0);\n__decorate([\n Autowired('resizeObserverService')\n], GridCtrl.prototype, \"resizeObserverService\", void 0);\n__decorate([\n Autowired('columnModel')\n], GridCtrl.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], GridCtrl.prototype, \"ctrlsService\", void 0);\n__decorate([\n Autowired('mouseEventService')\n], GridCtrl.prototype, \"mouseEventService\", void 0);\n__decorate([\n Autowired('dragAndDropService')\n], GridCtrl.prototype, \"dragAndDropService\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from \"../context/context.mjs\";\nimport { RefSelector } from \"../widgets/componentAnnotations.mjs\";\nimport { isVisible } from \"../utils/dom.mjs\";\nimport { FocusService } from \"../focusService.mjs\";\nimport { GridCtrl } from \"./gridCtrl.mjs\";\nimport { LayoutCssClasses } from \"../styling/layoutFeature.mjs\";\nimport { TabGuardComp } from \"../widgets/tabGuardComp.mjs\";\nexport class GridComp extends TabGuardComp {\n constructor(eGridDiv) {\n super();\n this.eGridDiv = eGridDiv;\n }\n postConstruct() {\n this.logger = this.loggerFactory.create('GridComp');\n const compProxy = {\n destroyGridUi: () => this.destroyBean(this),\n setRtlClass: (cssClass) => this.addCssClass(cssClass),\n addOrRemoveKeyboardFocusClass: (addOrRemove) => this.addOrRemoveCssClass(FocusService.AG_KEYBOARD_FOCUS, addOrRemove),\n forceFocusOutOfContainer: this.forceFocusOutOfContainer.bind(this),\n updateLayoutClasses: this.updateLayoutClasses.bind(this),\n getFocusableContainers: this.getFocusableContainers.bind(this),\n setUserSelect: value => {\n this.getGui().style.userSelect = value != null ? value : '';\n this.getGui().style.webkitUserSelect = value != null ? value : '';\n },\n setCursor: value => {\n this.getGui().style.cursor = value != null ? value : '';\n }\n };\n this.ctrl = this.createManagedBean(new GridCtrl());\n const template = this.createTemplate();\n this.setTemplate(template);\n this.ctrl.setComp(compProxy, this.eGridDiv, this.getGui());\n this.insertGridIntoDom();\n this.initialiseTabGuard({\n // we want to override the default behaviour to do nothing for onTabKeyDown\n onTabKeyDown: () => undefined,\n focusInnerElement: fromBottom => this.ctrl.focusInnerElement(fromBottom)\n });\n }\n insertGridIntoDom() {\n const eGui = this.getGui();\n this.eGridDiv.appendChild(eGui);\n this.addDestroyFunc(() => {\n this.eGridDiv.removeChild(eGui);\n this.logger.log('Grid removed from DOM');\n });\n }\n updateLayoutClasses(cssClass, params) {\n const eRootWrapperBodyClassList = this.eRootWrapperBody.classList;\n eRootWrapperBodyClassList.toggle(LayoutCssClasses.AUTO_HEIGHT, params.autoHeight);\n eRootWrapperBodyClassList.toggle(LayoutCssClasses.NORMAL, params.normal);\n eRootWrapperBodyClassList.toggle(LayoutCssClasses.PRINT, params.print);\n this.addOrRemoveCssClass(LayoutCssClasses.AUTO_HEIGHT, params.autoHeight);\n this.addOrRemoveCssClass(LayoutCssClasses.NORMAL, params.normal);\n this.addOrRemoveCssClass(LayoutCssClasses.PRINT, params.print);\n }\n createTemplate() {\n const dropZones = this.ctrl.showDropZones() ? '' : '';\n const sideBar = this.ctrl.showSideBar() ? '' : '';\n const statusBar = this.ctrl.showStatusBar() ? '' : '';\n const watermark = this.ctrl.showWatermark() ? '' : '';\n const template = /* html */ `
\n ${dropZones}\n
\n \n ${sideBar}\n
\n ${statusBar}\n \n ${watermark}\n
`;\n return template;\n }\n getFocusableElement() {\n return this.eRootWrapperBody;\n }\n getFocusableContainers() {\n const focusableContainers = [\n this.gridBodyComp.getGui()\n ];\n if (this.sideBarComp) {\n focusableContainers.push(this.sideBarComp.getGui());\n }\n return focusableContainers.filter(el => isVisible(el));\n }\n}\n__decorate([\n Autowired('loggerFactory')\n], GridComp.prototype, \"loggerFactory\", void 0);\n__decorate([\n RefSelector('gridBody')\n], GridComp.prototype, \"gridBodyComp\", void 0);\n__decorate([\n RefSelector('sideBar')\n], GridComp.prototype, \"sideBarComp\", void 0);\n__decorate([\n RefSelector('rootWrapperBody')\n], GridComp.prototype, \"eRootWrapperBody\", void 0);\n__decorate([\n PostConstruct\n], GridComp.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar SortController_1;\nimport { Autowired, Bean } from \"./context/context.mjs\";\nimport { BeanStub } from \"./context/beanStub.mjs\";\nimport { Events } from \"./events.mjs\";\nlet SortController = SortController_1 = class SortController extends BeanStub {\n progressSort(column, multiSort, source) {\n const nextDirection = this.getNextSortDirection(column);\n this.setSortForColumn(column, nextDirection, multiSort, source);\n }\n setSortForColumn(column, sort, multiSort, source) {\n // auto correct - if sort not legal value, then set it to 'no sort' (which is null)\n if (sort !== 'asc' && sort !== 'desc') {\n sort = null;\n }\n const isColumnsSortingCoupledToGroup = this.gridOptionsService.isColumnsSortingCoupledToGroup();\n let columnsToUpdate = [column];\n if (isColumnsSortingCoupledToGroup) {\n if (column.getColDef().showRowGroup) {\n const rowGroupColumns = this.columnModel.getSourceColumnsForGroupColumn(column);\n const sortableRowGroupColumns = rowGroupColumns === null || rowGroupColumns === void 0 ? void 0 : rowGroupColumns.filter(col => col.getColDef().sortable);\n if (sortableRowGroupColumns) {\n columnsToUpdate = [column, ...sortableRowGroupColumns];\n }\n }\n }\n columnsToUpdate.forEach(col => col.setSort(sort, source));\n const doingMultiSort = (multiSort || this.gridOptionsService.is('alwaysMultiSort')) && !this.gridOptionsService.is('suppressMultiSort');\n // clear sort on all columns except those changed, and update the icons\n if (!doingMultiSort) {\n this.clearSortBarTheseColumns(columnsToUpdate, source);\n }\n // sortIndex used for knowing order of cols when multi-col sort\n this.updateSortIndex(column);\n this.dispatchSortChangedEvents(source);\n }\n updateSortIndex(lastColToChange) {\n const isCoupled = this.gridOptionsService.isColumnsSortingCoupledToGroup();\n const groupParent = this.columnModel.getGroupDisplayColumnForGroup(lastColToChange.getId());\n const lastSortIndexCol = isCoupled ? groupParent || lastColToChange : lastColToChange;\n const allSortedCols = this.getColumnsWithSortingOrdered();\n // reset sort index on everything\n this.columnModel.getPrimaryAndSecondaryAndAutoColumns().forEach(col => col.setSortIndex(null));\n const allSortedColsWithoutChanges = allSortedCols.filter(col => col !== lastSortIndexCol);\n const sortedColsWithIndices = !!lastSortIndexCol.getSort() ? [...allSortedColsWithoutChanges, lastSortIndexCol] : allSortedColsWithoutChanges;\n sortedColsWithIndices.forEach((col, idx) => (col.setSortIndex(idx)));\n }\n // gets called by API, so if data changes, use can call this, which will end up\n // working out the sort order again of the rows.\n onSortChanged(source) {\n this.dispatchSortChangedEvents(source);\n }\n isSortActive() {\n // pull out all the columns that have sorting set\n const allCols = this.columnModel.getPrimaryAndSecondaryAndAutoColumns();\n const sortedCols = allCols.filter(column => !!column.getSort());\n return sortedCols && sortedCols.length > 0;\n }\n dispatchSortChangedEvents(source) {\n const event = {\n type: Events.EVENT_SORT_CHANGED,\n source\n };\n this.eventService.dispatchEvent(event);\n }\n clearSortBarTheseColumns(columnsToSkip, source) {\n this.columnModel.getPrimaryAndSecondaryAndAutoColumns().forEach((columnToClear) => {\n // Do not clear if either holding shift, or if column in question was clicked\n if (!columnsToSkip.includes(columnToClear)) {\n // setting to 'undefined' as null means 'none' rather than cleared, otherwise issue will arise\n // if sort order is: ['desc', null , 'asc'], as it will start at null rather than 'desc'.\n columnToClear.setSort(undefined, source);\n }\n });\n }\n getNextSortDirection(column) {\n let sortingOrder;\n if (column.getColDef().sortingOrder) {\n sortingOrder = column.getColDef().sortingOrder;\n }\n else if (this.gridOptionsService.get('sortingOrder')) {\n sortingOrder = this.gridOptionsService.get('sortingOrder');\n }\n else {\n sortingOrder = SortController_1.DEFAULT_SORTING_ORDER;\n }\n if (!Array.isArray(sortingOrder) || sortingOrder.length <= 0) {\n console.warn(`AG Grid: sortingOrder must be an array with at least one element, currently it\\'s ${sortingOrder}`);\n return null;\n }\n const currentIndex = sortingOrder.indexOf(column.getSort());\n const notInArray = currentIndex < 0;\n const lastItemInArray = currentIndex == sortingOrder.length - 1;\n let result;\n if (notInArray || lastItemInArray) {\n result = sortingOrder[0];\n }\n else {\n result = sortingOrder[currentIndex + 1];\n }\n // verify the sort type exists, as the user could provide the sortingOrder, need to make sure it's valid\n if (SortController_1.DEFAULT_SORTING_ORDER.indexOf(result) < 0) {\n console.warn('AG Grid: invalid sort type ' + result);\n return null;\n }\n return result;\n }\n /**\n * @returns a map of sort indexes for every sorted column, if groups sort primaries then they will have equivalent indices\n */\n getIndexedSortMap() {\n // pull out all the columns that have sorting set\n let allSortedCols = this.columnModel.getPrimaryAndSecondaryAndAutoColumns()\n .filter(col => !!col.getSort());\n if (this.columnModel.isPivotMode()) {\n const isSortingLinked = this.gridOptionsService.isColumnsSortingCoupledToGroup();\n allSortedCols = allSortedCols.filter(col => {\n const isAggregated = !!col.getAggFunc();\n const isSecondary = !col.isPrimary();\n const isGroup = isSortingLinked ? this.columnModel.getGroupDisplayColumnForGroup(col.getId()) : col.getColDef().showRowGroup;\n return isAggregated || isSecondary || isGroup;\n });\n }\n const sortedRowGroupCols = this.columnModel.getRowGroupColumns()\n .filter(col => !!col.getSort());\n const isSortLinked = this.gridOptionsService.isColumnsSortingCoupledToGroup() && !!sortedRowGroupCols.length;\n if (isSortLinked) {\n allSortedCols = [\n ...new Set(\n // if linked sorting, replace all columns with the display group column for index purposes, and ensure uniqueness\n allSortedCols.map(col => { var _a; return (_a = this.columnModel.getGroupDisplayColumnForGroup(col.getId())) !== null && _a !== void 0 ? _a : col; }))\n ];\n }\n // when both cols are missing sortIndex, we use the position of the col in all cols list.\n // this means if colDefs only have sort, but no sortIndex, we deterministically pick which\n // cols is sorted by first.\n const allColsIndexes = {};\n allSortedCols.forEach((col, index) => allColsIndexes[col.getId()] = index);\n // put the columns in order of which one got sorted first\n allSortedCols.sort((a, b) => {\n const iA = a.getSortIndex();\n const iB = b.getSortIndex();\n if (iA != null && iB != null) {\n return iA - iB; // both present, normal comparison\n }\n else if (iA == null && iB == null) {\n // both missing, compare using column positions\n const posA = allColsIndexes[a.getId()];\n const posB = allColsIndexes[b.getId()];\n return posA > posB ? 1 : -1;\n }\n else if (iB == null) {\n return -1; // iB missing\n }\n else {\n return 1; // iA missing\n }\n });\n const indexMap = new Map();\n allSortedCols.forEach((col, idx) => indexMap.set(col, idx));\n // add the row group cols back\n if (isSortLinked) {\n sortedRowGroupCols.forEach(col => {\n const groupDisplayCol = this.columnModel.getGroupDisplayColumnForGroup(col.getId());\n indexMap.set(col, indexMap.get(groupDisplayCol));\n });\n }\n return indexMap;\n }\n getColumnsWithSortingOrdered() {\n // pull out all the columns that have sorting set\n return [...this.getIndexedSortMap().entries()]\n .sort(([col1, idx1], [col2, idx2]) => idx1 - idx2)\n .map(([col]) => col);\n }\n // used by server side row models, to sent sort to server\n getSortModel() {\n return this.getColumnsWithSortingOrdered()\n .filter(column => column.getSort())\n .map(column => ({\n sort: column.getSort(),\n colId: column.getId()\n }));\n }\n getSortOptions() {\n return this.getColumnsWithSortingOrdered()\n .filter(column => column.getSort())\n .map(column => ({\n sort: column.getSort(),\n column\n }));\n }\n canColumnDisplayMixedSort(column) {\n const isColumnSortCouplingActive = this.gridOptionsService.isColumnsSortingCoupledToGroup();\n const isGroupDisplayColumn = !!column.getColDef().showRowGroup;\n return isColumnSortCouplingActive && isGroupDisplayColumn;\n }\n getDisplaySortForColumn(column) {\n const linkedColumns = this.columnModel.getSourceColumnsForGroupColumn(column);\n if (!this.canColumnDisplayMixedSort(column) || !(linkedColumns === null || linkedColumns === void 0 ? void 0 : linkedColumns.length)) {\n return column.getSort();\n }\n // if column has unique data, its sorting is independent - but can still be mixed\n const columnHasUniqueData = column.getColDef().field != null || !!column.getColDef().valueGetter;\n const sortableColumns = columnHasUniqueData ? [column, ...linkedColumns] : linkedColumns;\n const firstSort = sortableColumns[0].getSort();\n // the == is intentional, as null and undefined both represent no sort, which means they are equivalent\n const allMatch = sortableColumns.every(col => col.getSort() == firstSort);\n if (!allMatch) {\n return 'mixed';\n }\n return firstSort;\n }\n getDisplaySortIndexForColumn(column) {\n return this.getIndexedSortMap().get(column);\n }\n};\nSortController.DEFAULT_SORTING_ORDER = ['asc', 'desc', null];\n__decorate([\n Autowired('columnModel')\n], SortController.prototype, \"columnModel\", void 0);\nSortController = SortController_1 = __decorate([\n Bean('sortController')\n], SortController);\nexport { SortController };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { Bean } from \"../context/context.mjs\";\nimport { Events } from \"../events.mjs\";\nlet ColumnHoverService = class ColumnHoverService extends BeanStub {\n setMouseOver(columns) {\n this.selectedColumns = columns;\n const event = {\n type: Events.EVENT_COLUMN_HOVER_CHANGED\n };\n this.eventService.dispatchEvent(event);\n }\n clearMouseOver() {\n this.selectedColumns = null;\n const event = {\n type: Events.EVENT_COLUMN_HOVER_CHANGED\n };\n this.eventService.dispatchEvent(event);\n }\n isHovered(column) {\n return !!this.selectedColumns && this.selectedColumns.indexOf(column) >= 0;\n }\n};\nColumnHoverService = __decorate([\n Bean('columnHoverService')\n], ColumnHoverService);\nexport { ColumnHoverService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, PostConstruct } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nlet ColumnAnimationService = class ColumnAnimationService extends BeanStub {\n constructor() {\n super(...arguments);\n this.executeNextFuncs = [];\n this.executeLaterFuncs = [];\n this.active = false;\n this.animationThreadCount = 0;\n }\n postConstruct() {\n this.ctrlsService.whenReady(p => this.gridBodyCtrl = p.gridBodyCtrl);\n }\n isActive() {\n return this.active;\n }\n start() {\n if (this.active) {\n return;\n }\n if (this.gridOptionsService.is('suppressColumnMoveAnimation')) {\n return;\n }\n // if doing RTL, we don't animate open / close as due to how the pixels are inverted,\n // the animation moves all the row the the right rather than to the left (ie it's the static\n // columns that actually get their coordinates updated)\n if (this.gridOptionsService.is('enableRtl')) {\n return;\n }\n this.ensureAnimationCssClassPresent();\n this.active = true;\n }\n finish() {\n if (!this.active) {\n return;\n }\n this.flush();\n this.active = false;\n }\n executeNextVMTurn(func) {\n if (this.active) {\n this.executeNextFuncs.push(func);\n }\n else {\n func();\n }\n }\n executeLaterVMTurn(func) {\n if (this.active) {\n this.executeLaterFuncs.push(func);\n }\n else {\n func();\n }\n }\n ensureAnimationCssClassPresent() {\n // up the count, so we can tell if someone else has updated the count\n // by the time the 'wait' func executes\n this.animationThreadCount++;\n const animationThreadCountCopy = this.animationThreadCount;\n this.gridBodyCtrl.setColumnMovingCss(true);\n this.executeLaterFuncs.push(() => {\n // only remove the class if this thread was the last one to update it\n if (this.animationThreadCount === animationThreadCountCopy) {\n this.gridBodyCtrl.setColumnMovingCss(false);\n }\n });\n }\n flush() {\n const nowFuncs = this.executeNextFuncs;\n this.executeNextFuncs = [];\n const waitFuncs = this.executeLaterFuncs;\n this.executeLaterFuncs = [];\n if (nowFuncs.length === 0 && waitFuncs.length === 0) {\n return;\n }\n window.setTimeout(() => nowFuncs.forEach(func => func()), 0);\n window.setTimeout(() => waitFuncs.forEach(func => func()), 300);\n }\n};\n__decorate([\n Autowired('ctrlsService')\n], ColumnAnimationService.prototype, \"ctrlsService\", void 0);\n__decorate([\n PostConstruct\n], ColumnAnimationService.prototype, \"postConstruct\", null);\nColumnAnimationService = __decorate([\n Bean('columnAnimationService')\n], ColumnAnimationService);\nexport { ColumnAnimationService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { Events } from \"../events.mjs\";\nimport { Autowired, Bean, PostConstruct } from \"../context/context.mjs\";\nimport { debounce } from \"../utils/function.mjs\";\nlet PaginationAutoPageSizeService = class PaginationAutoPageSizeService extends BeanStub {\n postConstruct() {\n this.ctrlsService.whenReady(p => {\n this.centerRowContainerCon = p.centerRowContainerCtrl;\n this.addManagedListener(this.eventService, Events.EVENT_BODY_HEIGHT_CHANGED, this.checkPageSize.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_SCROLL_VISIBILITY_CHANGED, this.checkPageSize.bind(this));\n this.checkPageSize();\n });\n }\n notActive() {\n return !this.gridOptionsService.is('paginationAutoPageSize') || this.centerRowContainerCon == null;\n }\n checkPageSize() {\n if (this.notActive()) {\n return;\n }\n const bodyHeight = this.centerRowContainerCon.getViewportSizeFeature().getBodyHeight();\n if (bodyHeight > 0) {\n const update = () => {\n const rowHeight = this.gridOptionsService.getRowHeightAsNumber();\n const newPageSize = Math.floor(bodyHeight / rowHeight);\n this.gridOptionsService.set('paginationPageSize', newPageSize);\n };\n if (!this.isBodyRendered) {\n update();\n this.isBodyRendered = true;\n }\n else {\n debounce(() => update(), 50)();\n }\n }\n else {\n this.isBodyRendered = false;\n }\n }\n};\n__decorate([\n Autowired('ctrlsService')\n], PaginationAutoPageSizeService.prototype, \"ctrlsService\", void 0);\n__decorate([\n PostConstruct\n], PaginationAutoPageSizeService.prototype, \"postConstruct\", null);\nPaginationAutoPageSizeService = __decorate([\n Bean('paginationAutoPageSizeService')\n], PaginationAutoPageSizeService);\nexport { PaginationAutoPageSizeService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean, PostConstruct } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nlet ValueCache = class ValueCache extends BeanStub {\n constructor() {\n super(...arguments);\n this.cacheVersion = 0;\n }\n init() {\n this.active = this.gridOptionsService.is('valueCache');\n this.neverExpires = this.gridOptionsService.is('valueCacheNeverExpires');\n }\n onDataChanged() {\n if (this.neverExpires) {\n return;\n }\n this.expire();\n }\n expire() {\n this.cacheVersion++;\n }\n setValue(rowNode, colId, value) {\n if (this.active) {\n if (rowNode.__cacheVersion !== this.cacheVersion) {\n rowNode.__cacheVersion = this.cacheVersion;\n rowNode.__cacheData = {};\n }\n rowNode.__cacheData[colId] = value;\n }\n }\n getValue(rowNode, colId) {\n if (!this.active || rowNode.__cacheVersion !== this.cacheVersion) {\n return undefined;\n }\n return rowNode.__cacheData[colId];\n }\n};\n__decorate([\n PostConstruct\n], ValueCache.prototype, \"init\", null);\nValueCache = __decorate([\n Bean('valueCache')\n], ValueCache);\nexport { ValueCache };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { Autowired, Bean, PostConstruct } from \"../context/context.mjs\";\nimport { ChangedPath } from \"../utils/changedPath.mjs\";\nimport { Events } from \"../events.mjs\";\n// Matches value in clipboard module\nconst SOURCE_PASTE = 'paste';\nlet ChangeDetectionService = class ChangeDetectionService extends BeanStub {\n init() {\n if (this.rowModel.getType() === 'clientSide') {\n this.clientSideRowModel = this.rowModel;\n }\n this.addManagedListener(this.eventService, Events.EVENT_CELL_VALUE_CHANGED, this.onCellValueChanged.bind(this));\n }\n onCellValueChanged(event) {\n // Clipboard service manages its own change detection, so no need to do it here.\n // The clipboard manages its own as otherwise this would happen once for every cell\n // that got updated as part of a paste operation, so e.g. if 100 cells in a paste operation,\n // this doChangeDetection would get called 100 times (once for each cell), instead clipboard\n // service executes the logic we have here once (in essence batching up all cell changes\n // into one change detection).\n if (event.source === SOURCE_PASTE) {\n return;\n }\n this.doChangeDetection(event.node, event.column);\n }\n doChangeDetection(rowNode, column) {\n if (this.gridOptionsService.is('suppressChangeDetection')) {\n return;\n }\n const nodesToRefresh = [rowNode];\n // step 1 of change detection is to update the aggregated values\n if (this.clientSideRowModel && !rowNode.isRowPinned()) {\n const onlyChangedColumns = this.gridOptionsService.is('aggregateOnlyChangedColumns');\n const changedPath = new ChangedPath(onlyChangedColumns, this.clientSideRowModel.getRootNode());\n changedPath.addParentNode(rowNode.parent, [column]);\n this.clientSideRowModel.doAggregate(changedPath);\n // add all nodes impacted by aggregation, as they need refreshed also.\n changedPath.forEachChangedNodeDepthFirst(rowNode => {\n nodesToRefresh.push(rowNode);\n });\n }\n // step 2 of change detection is to refresh the cells\n this.rowRenderer.refreshCells({ rowNodes: nodesToRefresh });\n }\n};\n__decorate([\n Autowired('rowModel')\n], ChangeDetectionService.prototype, \"rowModel\", void 0);\n__decorate([\n Autowired('rowRenderer')\n], ChangeDetectionService.prototype, \"rowRenderer\", void 0);\n__decorate([\n PostConstruct\n], ChangeDetectionService.prototype, \"init\", null);\nChangeDetectionService = __decorate([\n Bean('changeDetectionService')\n], ChangeDetectionService);\nexport { ChangeDetectionService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean } from \"../../context/context.mjs\";\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nimport { loadTemplate } from \"../../utils/dom.mjs\";\nlet AgComponentUtils = class AgComponentUtils extends BeanStub {\n adaptFunction(propertyName, jsCompFunc) {\n const metadata = this.componentMetadataProvider.retrieve(propertyName);\n if (metadata && metadata.functionAdapter) {\n return metadata.functionAdapter(jsCompFunc);\n }\n return null;\n }\n adaptCellRendererFunction(callback) {\n class Adapter {\n refresh(params) {\n return false;\n }\n getGui() {\n return this.eGui;\n }\n init(params) {\n const callbackResult = callback(params);\n const type = typeof callbackResult;\n if (type === 'string' || type === 'number' || type === 'boolean') {\n this.eGui = loadTemplate('' + callbackResult + '');\n return;\n }\n if (callbackResult == null) {\n this.eGui = loadTemplate('');\n return;\n }\n this.eGui = callbackResult;\n }\n }\n return Adapter;\n }\n doesImplementIComponent(candidate) {\n if (!candidate) {\n return false;\n }\n return candidate.prototype && 'getGui' in candidate.prototype;\n }\n};\n__decorate([\n Autowired(\"componentMetadataProvider\")\n], AgComponentUtils.prototype, \"componentMetadataProvider\", void 0);\nAgComponentUtils = __decorate([\n Bean(\"agComponentUtils\")\n], AgComponentUtils);\nexport { AgComponentUtils };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, PostConstruct } from \"../../context/context.mjs\";\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nlet ComponentMetadataProvider = class ComponentMetadataProvider extends BeanStub {\n postConstruct() {\n this.componentMetaData = {\n dateComponent: {\n mandatoryMethodList: ['getDate', 'setDate'],\n optionalMethodList: ['afterGuiAttached', 'setInputPlaceholder', 'setInputAriaLabel']\n },\n detailCellRenderer: {\n mandatoryMethodList: [],\n optionalMethodList: ['refresh'],\n functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)\n },\n headerComponent: {\n mandatoryMethodList: [],\n optionalMethodList: ['refresh']\n },\n headerGroupComponent: {\n mandatoryMethodList: [],\n optionalMethodList: []\n },\n loadingCellRenderer: {\n mandatoryMethodList: [],\n optionalMethodList: []\n },\n loadingOverlayComponent: {\n mandatoryMethodList: [],\n optionalMethodList: []\n },\n noRowsOverlayComponent: {\n mandatoryMethodList: [],\n optionalMethodList: []\n },\n floatingFilterComponent: {\n mandatoryMethodList: ['onParentModelChanged'],\n optionalMethodList: ['afterGuiAttached']\n },\n floatingFilterWrapperComponent: {\n mandatoryMethodList: [],\n optionalMethodList: []\n },\n cellRenderer: {\n mandatoryMethodList: [],\n optionalMethodList: ['refresh', 'afterGuiAttached'],\n functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)\n },\n cellEditor: {\n mandatoryMethodList: ['getValue'],\n optionalMethodList: ['isPopup', 'isCancelBeforeStart', 'isCancelAfterEnd', 'getPopupPosition', 'focusIn', 'focusOut', 'afterGuiAttached']\n },\n innerRenderer: {\n mandatoryMethodList: [],\n optionalMethodList: ['afterGuiAttached'],\n functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)\n },\n fullWidthCellRenderer: {\n mandatoryMethodList: [],\n optionalMethodList: ['refresh', 'afterGuiAttached'],\n functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)\n },\n groupRowRenderer: {\n mandatoryMethodList: [],\n optionalMethodList: ['afterGuiAttached'],\n functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)\n },\n filter: {\n mandatoryMethodList: ['isFilterActive', 'doesFilterPass', 'getModel', 'setModel'],\n optionalMethodList: ['afterGuiAttached', 'afterGuiDetached', 'onNewRowsLoaded', 'getModelAsString', 'onFloatingFilterChanged', 'onAnyFilterChanged']\n },\n filterComponent: {\n mandatoryMethodList: ['isFilterActive', 'doesFilterPass', 'getModel', 'setModel'],\n optionalMethodList: ['afterGuiAttached', 'afterGuiDetached', 'onNewRowsLoaded', 'getModelAsString', 'onFloatingFilterChanged', 'onAnyFilterChanged']\n },\n statusPanel: {\n mandatoryMethodList: [],\n optionalMethodList: ['afterGuiAttached'],\n },\n toolPanel: {\n mandatoryMethodList: [],\n optionalMethodList: ['refresh', 'afterGuiAttached']\n },\n tooltipComponent: {\n mandatoryMethodList: [],\n optionalMethodList: []\n }\n };\n }\n retrieve(name) {\n return this.componentMetaData[name];\n }\n};\n__decorate([\n Autowired(\"agComponentUtils\")\n], ComponentMetadataProvider.prototype, \"agComponentUtils\", void 0);\n__decorate([\n PostConstruct\n], ComponentMetadataProvider.prototype, \"postConstruct\", null);\nComponentMetadataProvider = __decorate([\n Bean(\"componentMetadataProvider\")\n], ComponentMetadataProvider);\nexport { ComponentMetadataProvider };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean, Autowired, PostConstruct } from './context/context.mjs';\nimport { BeanStub } from \"./context/beanStub.mjs\";\nimport { exists } from './utils/generic.mjs';\nimport { Events } from './eventKeys.mjs';\nconst DEFAULT_ROW_HEIGHT = 25;\nconst MIN_COL_WIDTH = 10;\nconst MAT_GRID_SIZE = 8;\nconst BASE_GRID_SIZE = 4;\nconst BALHAM_GRID_SIZE = 4;\nconst ALPINE_GRID_SIZE = 6;\nconst HARD_CODED_SIZES = {\n // this item is required for custom themes\n 'ag-theme-custom': {\n headerHeight: 25,\n headerCellMinWidth: 24,\n listItemHeight: BASE_GRID_SIZE * 5,\n rowHeight: 25,\n chartMenuPanelWidth: 220\n },\n 'ag-theme-material': {\n headerHeight: MAT_GRID_SIZE * 7,\n headerCellMinWidth: 48,\n listItemHeight: MAT_GRID_SIZE * 4,\n rowHeight: MAT_GRID_SIZE * 6,\n chartMenuPanelWidth: 240\n },\n 'ag-theme-balham': {\n headerHeight: BALHAM_GRID_SIZE * 8,\n headerCellMinWidth: 24,\n listItemHeight: BALHAM_GRID_SIZE * 6,\n rowHeight: BALHAM_GRID_SIZE * 7,\n chartMenuPanelWidth: 220\n },\n 'ag-theme-alpine': {\n headerHeight: ALPINE_GRID_SIZE * 8,\n headerCellMinWidth: 36,\n listItemHeight: ALPINE_GRID_SIZE * 4,\n rowHeight: ALPINE_GRID_SIZE * 7,\n chartMenuPanelWidth: 240\n }\n};\n/**\n * this object contains a list of Sass variables and an array\n * of CSS styles required to get the correct value.\n * eg. $virtual-item-height requires a structure, so we can get its height.\n *
\n *
\n *
\n *
\n *
\n */\nconst SASS_PROPERTY_BUILDER = {\n headerHeight: ['ag-header-row'],\n headerCellMinWidth: ['ag-header-cell'],\n listItemHeight: ['ag-virtual-list-item'],\n rowHeight: ['ag-row'],\n chartMenuPanelWidth: ['ag-chart-docked-container']\n};\nlet Environment = class Environment extends BeanStub {\n constructor() {\n super(...arguments);\n this.calculatedSizes = {};\n }\n postConstruct() {\n var _a;\n const el = (_a = this.getTheme().el) !== null && _a !== void 0 ? _a : this.eGridDiv;\n this.mutationObserver = new MutationObserver(() => {\n this.calculatedSizes = {};\n this.fireGridStylesChangedEvent();\n });\n this.mutationObserver.observe(el || this.eGridDiv, {\n attributes: true,\n attributeFilter: ['class']\n });\n }\n fireGridStylesChangedEvent() {\n const event = {\n type: Events.EVENT_GRID_STYLES_CHANGED\n };\n this.eventService.dispatchEvent(event);\n }\n getSassVariable(key) {\n const { themeFamily, el } = this.getTheme();\n if (!themeFamily || themeFamily.indexOf('ag-theme') !== 0) {\n return;\n }\n if (!this.calculatedSizes) {\n this.calculatedSizes = {};\n }\n if (!this.calculatedSizes[themeFamily]) {\n this.calculatedSizes[themeFamily] = {};\n }\n const size = this.calculatedSizes[themeFamily][key];\n if (size != null) {\n return size;\n }\n this.calculatedSizes[themeFamily][key] = this.calculateValueForSassProperty(key, themeFamily, el);\n return this.calculatedSizes[themeFamily][key];\n }\n calculateValueForSassProperty(property, theme, themeElement) {\n const useTheme = 'ag-theme-' + (theme.match('material') ? 'material' : theme.match('balham') ? 'balham' : theme.match('alpine') ? 'alpine' : 'custom');\n const defaultValue = HARD_CODED_SIZES[useTheme][property];\n const eDocument = this.gridOptionsService.getDocument();\n if (!themeElement) {\n themeElement = this.eGridDiv;\n }\n if (!SASS_PROPERTY_BUILDER[property]) {\n return defaultValue;\n }\n const classList = SASS_PROPERTY_BUILDER[property];\n const div = eDocument.createElement('div');\n // this will apply SASS variables that were manually added to the current theme\n const classesFromThemeElement = Array.from(themeElement.classList);\n div.classList.add(theme, ...classesFromThemeElement);\n div.style.position = 'absolute';\n const el = classList.reduce((prevEl, currentClass) => {\n const currentDiv = eDocument.createElement('div');\n currentDiv.style.position = 'static';\n currentDiv.classList.add(currentClass);\n prevEl.appendChild(currentDiv);\n return currentDiv;\n }, div);\n let calculatedValue = 0;\n if (eDocument.body) {\n eDocument.body.appendChild(div);\n const sizeName = property.toLowerCase().indexOf('height') !== -1 ? 'height' : 'width';\n calculatedValue = parseInt(window.getComputedStyle(el)[sizeName], 10);\n eDocument.body.removeChild(div);\n }\n return calculatedValue || defaultValue;\n }\n isThemeDark() {\n const { theme } = this.getTheme();\n return !!theme && theme.indexOf('dark') >= 0;\n }\n chartMenuPanelWidth() {\n return this.getSassVariable('chartMenuPanelWidth');\n }\n getTheme() {\n const reg = /\\bag-(material|(?:theme-([\\w\\-]*)))\\b/g;\n let el = this.eGridDiv;\n let themeMatch = null;\n let allThemes = [];\n while (el) {\n themeMatch = reg.exec(el.className);\n if (!themeMatch) {\n el = el.parentElement || undefined;\n }\n else {\n const matched = el.className.match(reg);\n if (matched) {\n allThemes = matched;\n }\n break;\n }\n }\n if (!themeMatch) {\n return { allThemes };\n }\n const theme = themeMatch[0];\n return { theme, el, themeFamily: theme.replace(/-dark$/, ''), allThemes };\n }\n getFromTheme(defaultValue, sassVariableName) {\n var _a;\n return (_a = this.getSassVariable(sassVariableName)) !== null && _a !== void 0 ? _a : defaultValue;\n }\n getDefaultRowHeight() {\n return this.getFromTheme(DEFAULT_ROW_HEIGHT, 'rowHeight');\n }\n getListItemHeight() {\n return this.getFromTheme(20, 'listItemHeight');\n }\n refreshRowHeightVariable() {\n const oldRowHeight = this.eGridDiv.style.getPropertyValue('--ag-line-height').trim();\n const height = this.gridOptionsService.getNum('rowHeight');\n if (height == null || isNaN(height) || !isFinite(height)) {\n return -1;\n }\n const newRowHeight = `${height}px`;\n if (oldRowHeight != newRowHeight) {\n this.eGridDiv.style.setProperty('--ag-line-height', newRowHeight);\n return height;\n }\n return oldRowHeight != '' ? parseFloat(oldRowHeight) : -1;\n }\n getMinColWidth() {\n const measuredMin = this.getFromTheme(null, 'headerCellMinWidth');\n return exists(measuredMin) ? Math.max(measuredMin, MIN_COL_WIDTH) : MIN_COL_WIDTH;\n }\n destroy() {\n this.calculatedSizes = null;\n if (this.mutationObserver) {\n this.mutationObserver.disconnect();\n }\n super.destroy();\n }\n};\n__decorate([\n Autowired('eGridDiv')\n], Environment.prototype, \"eGridDiv\", void 0);\n__decorate([\n PostConstruct\n], Environment.prototype, \"postConstruct\", null);\nEnvironment = __decorate([\n Bean('environment')\n], Environment);\nexport { Environment };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n};\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { Autowired, Bean, PostConstruct, Qualifier } from \"../context/context.mjs\";\nimport { Events } from \"../eventKeys.mjs\";\nimport { getMaxDivHeight } from \"../utils/browser.mjs\";\n/**\n * This class solves the 'max height' problem, where the user might want to show more data than\n * the max div height actually allows.\n */\nlet RowContainerHeightService = class RowContainerHeightService extends BeanStub {\n constructor() {\n super(...arguments);\n // the scrollY position\n this.scrollY = 0;\n // how tall the body is\n this.uiBodyHeight = 0;\n }\n agWire(loggerFactory) {\n this.logger = loggerFactory.create(\"RowContainerHeightService\");\n }\n postConstruct() {\n this.addManagedListener(this.eventService, Events.EVENT_BODY_HEIGHT_CHANGED, this.updateOffset.bind(this));\n this.maxDivHeight = getMaxDivHeight();\n this.logger.log('maxDivHeight = ' + this.maxDivHeight);\n }\n isStretching() {\n return this.stretching;\n }\n getDivStretchOffset() {\n return this.divStretchOffset;\n }\n updateOffset() {\n if (!this.stretching) {\n return;\n }\n const gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n const newScrollY = gridBodyCon.getScrollFeature().getVScrollPosition().top;\n const newBodyHeight = this.getUiBodyHeight();\n const atLeastOneChanged = newScrollY !== this.scrollY || newBodyHeight !== this.uiBodyHeight;\n if (atLeastOneChanged) {\n this.scrollY = newScrollY;\n this.uiBodyHeight = newBodyHeight;\n this.calculateOffset();\n }\n }\n calculateOffset() {\n this.setUiContainerHeight(this.maxDivHeight);\n this.pixelsToShave = this.modelHeight - this.uiContainerHeight;\n this.maxScrollY = this.uiContainerHeight - this.uiBodyHeight;\n const scrollPercent = this.scrollY / this.maxScrollY;\n const divStretchOffset = scrollPercent * this.pixelsToShave;\n this.logger.log(`Div Stretch Offset = ${divStretchOffset} (${this.pixelsToShave} * ${scrollPercent})`);\n this.setDivStretchOffset(divStretchOffset);\n }\n setUiContainerHeight(height) {\n if (height !== this.uiContainerHeight) {\n this.uiContainerHeight = height;\n this.eventService.dispatchEvent({ type: Events.EVENT_ROW_CONTAINER_HEIGHT_CHANGED });\n }\n }\n clearOffset() {\n this.setUiContainerHeight(this.modelHeight);\n this.pixelsToShave = 0;\n this.setDivStretchOffset(0);\n }\n setDivStretchOffset(newOffset) {\n // because we are talking pixels, no point in confusing things with half numbers\n const newOffsetFloor = typeof newOffset === 'number' ? Math.floor(newOffset) : null;\n if (this.divStretchOffset === newOffsetFloor) {\n return;\n }\n this.divStretchOffset = newOffsetFloor;\n this.eventService.dispatchEvent({ type: Events.EVENT_HEIGHT_SCALE_CHANGED });\n }\n setModelHeight(modelHeight) {\n this.modelHeight = modelHeight;\n this.stretching = modelHeight != null // null happens when in print layout\n && this.maxDivHeight > 0\n && modelHeight > this.maxDivHeight;\n if (this.stretching) {\n this.calculateOffset();\n }\n else {\n this.clearOffset();\n }\n }\n getUiContainerHeight() {\n return this.uiContainerHeight;\n }\n getRealPixelPosition(modelPixel) {\n return modelPixel - this.divStretchOffset;\n }\n getUiBodyHeight() {\n const gridBodyCon = this.ctrlsService.getGridBodyCtrl();\n const pos = gridBodyCon.getScrollFeature().getVScrollPosition();\n return pos.bottom - pos.top;\n }\n getScrollPositionForPixel(rowTop) {\n if (this.pixelsToShave <= 0) {\n return rowTop;\n }\n const modelMaxScroll = this.modelHeight - this.getUiBodyHeight();\n const scrollPercent = rowTop / modelMaxScroll;\n const scrollPixel = this.maxScrollY * scrollPercent;\n return scrollPixel;\n }\n};\n__decorate([\n Autowired('ctrlsService')\n], RowContainerHeightService.prototype, \"ctrlsService\", void 0);\n__decorate([\n __param(0, Qualifier(\"loggerFactory\"))\n], RowContainerHeightService.prototype, \"agWire\", null);\n__decorate([\n PostConstruct\n], RowContainerHeightService.prototype, \"postConstruct\", null);\nRowContainerHeightService = __decorate([\n Bean('rowContainerHeightService')\n], RowContainerHeightService);\nexport { RowContainerHeightService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean, PostConstruct } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { exists } from \"../utils/generic.mjs\";\nlet SelectableService = class SelectableService extends BeanStub {\n init() {\n this.groupSelectsChildren = this.gridOptionsService.is('groupSelectsChildren');\n this.isRowSelectableFunc = this.gridOptionsService.get('isRowSelectable');\n }\n updateSelectableAfterGrouping(rowNode) {\n if (this.isRowSelectableFunc) {\n const nextChildrenFunc = (node) => node.childrenAfterGroup;\n this.recurseDown(rowNode.childrenAfterGroup, nextChildrenFunc);\n }\n }\n recurseDown(children, nextChildrenFunc) {\n if (!children) {\n return;\n }\n children.forEach((child) => {\n if (!child.group) {\n return;\n } // only interested in groups\n if (child.hasChildren()) {\n this.recurseDown(nextChildrenFunc(child), nextChildrenFunc);\n }\n let rowSelectable;\n if (this.groupSelectsChildren) {\n // have this group selectable if at least one direct child is selectable\n const firstSelectable = (nextChildrenFunc(child) || []).find(rowNode => rowNode.selectable === true);\n rowSelectable = exists(firstSelectable);\n }\n else {\n // directly retrieve selectable value from user callback\n rowSelectable = this.isRowSelectableFunc ? this.isRowSelectableFunc(child) : false;\n }\n child.setRowSelectable(rowSelectable);\n });\n }\n};\n__decorate([\n PostConstruct\n], SelectableService.prototype, \"init\", null);\nSelectableService = __decorate([\n Bean('selectableService')\n], SelectableService);\nexport { SelectableService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component } from \"../widgets/component.mjs\";\nimport { Autowired, PostConstruct } from \"../context/context.mjs\";\nimport { RefSelector } from \"../widgets/componentAnnotations.mjs\";\nimport { Events } from \"../events.mjs\";\nimport { createIconNoSpan } from \"../utils/icon.mjs\";\nimport { formatNumberCommas } from \"../utils/number.mjs\";\nimport { setAriaDisabled } from \"../utils/aria.mjs\";\nimport { KeyCode } from '../constants/keyCode.mjs';\nexport class PaginationComp extends Component {\n constructor() {\n super();\n this.previousAndFirstButtonsDisabled = false;\n this.nextButtonDisabled = false;\n this.lastButtonDisabled = false;\n this.areListenersSetup = false;\n }\n postConstruct() {\n const isRtl = this.gridOptionsService.is('enableRtl');\n this.setTemplate(this.getTemplate());\n const { btFirst, btPrevious, btNext, btLast } = this;\n this.activateTabIndex([btFirst, btPrevious, btNext, btLast]);\n btFirst.insertAdjacentElement('afterbegin', createIconNoSpan(isRtl ? 'last' : 'first', this.gridOptionsService));\n btPrevious.insertAdjacentElement('afterbegin', createIconNoSpan(isRtl ? 'next' : 'previous', this.gridOptionsService));\n btNext.insertAdjacentElement('afterbegin', createIconNoSpan(isRtl ? 'previous' : 'next', this.gridOptionsService));\n btLast.insertAdjacentElement('afterbegin', createIconNoSpan(isRtl ? 'first' : 'last', this.gridOptionsService));\n this.addManagedPropertyListener('pagination', this.onPaginationChanged.bind(this));\n this.addManagedPropertyListener('suppressPaginationPanel', this.onPaginationChanged.bind(this));\n this.onPaginationChanged();\n }\n onPaginationChanged() {\n const isPaging = this.gridOptionsService.is('pagination');\n const paginationPanelEnabled = isPaging && !this.gridOptionsService.is('suppressPaginationPanel');\n this.setDisplayed(paginationPanelEnabled);\n if (!paginationPanelEnabled) {\n return;\n }\n this.setupListeners();\n this.enableOrDisableButtons();\n this.updateRowLabels();\n this.setCurrentPageLabel();\n this.setTotalLabels();\n }\n setupListeners() {\n if (!this.areListenersSetup) {\n this.addManagedListener(this.eventService, Events.EVENT_PAGINATION_CHANGED, this.onPaginationChanged.bind(this));\n [\n { el: this.btFirst, fn: this.onBtFirst.bind(this) },\n { el: this.btPrevious, fn: this.onBtPrevious.bind(this) },\n { el: this.btNext, fn: this.onBtNext.bind(this) },\n { el: this.btLast, fn: this.onBtLast.bind(this) }\n ].forEach(item => {\n const { el, fn } = item;\n this.addManagedListener(el, 'click', fn);\n this.addManagedListener(el, 'keydown', (e) => {\n if (e.key === KeyCode.ENTER || e.key === KeyCode.SPACE) {\n e.preventDefault();\n fn();\n }\n });\n });\n this.areListenersSetup = true;\n }\n }\n onBtFirst() {\n if (!this.previousAndFirstButtonsDisabled) {\n this.paginationProxy.goToFirstPage();\n }\n }\n setCurrentPageLabel() {\n const pagesExist = this.paginationProxy.getTotalPages() > 0;\n const currentPage = this.paginationProxy.getCurrentPage();\n const toDisplay = pagesExist ? currentPage + 1 : 0;\n this.lbCurrent.innerHTML = this.formatNumber(toDisplay);\n }\n formatNumber(value) {\n const userFunc = this.gridOptionsService.getCallback('paginationNumberFormatter');\n if (userFunc) {\n const params = { value: value };\n return userFunc(params);\n }\n const localeTextFunc = this.localeService.getLocaleTextFunc();\n const thousandSeparator = localeTextFunc('thousandSeparator', ',');\n const decimalSeparator = localeTextFunc('decimalSeparator', '.');\n return formatNumberCommas(value, thousandSeparator, decimalSeparator);\n }\n getTemplate() {\n const localeTextFunc = this.localeService.getLocaleTextFunc();\n const strPage = localeTextFunc('page', 'Page');\n const strTo = localeTextFunc('to', 'to');\n const strOf = localeTextFunc('of', 'of');\n const strFirst = localeTextFunc('firstPage', 'First Page');\n const strPrevious = localeTextFunc('previousPage', 'Previous Page');\n const strNext = localeTextFunc('nextPage', 'Next Page');\n const strLast = localeTextFunc('lastPage', 'Last Page');\n const compId = this.getCompId();\n return /* html */ `
\n \n \n ${strTo}\n \n ${strOf}\n \n \n \n
\n
\n \n ${strPage}\n \n ${strOf}\n \n \n
\n
\n
\n
`;\n }\n onBtNext() {\n if (!this.nextButtonDisabled) {\n this.paginationProxy.goToNextPage();\n }\n }\n onBtPrevious() {\n if (!this.previousAndFirstButtonsDisabled) {\n this.paginationProxy.goToPreviousPage();\n }\n }\n onBtLast() {\n if (!this.lastButtonDisabled) {\n this.paginationProxy.goToLastPage();\n }\n }\n enableOrDisableButtons() {\n const currentPage = this.paginationProxy.getCurrentPage();\n const maxRowFound = this.paginationProxy.isLastPageFound();\n const totalPages = this.paginationProxy.getTotalPages();\n this.previousAndFirstButtonsDisabled = currentPage === 0;\n this.toggleButtonDisabled(this.btFirst, this.previousAndFirstButtonsDisabled);\n this.toggleButtonDisabled(this.btPrevious, this.previousAndFirstButtonsDisabled);\n const zeroPagesToDisplay = this.isZeroPagesToDisplay();\n const onLastPage = maxRowFound && currentPage === (totalPages - 1);\n this.nextButtonDisabled = onLastPage || zeroPagesToDisplay;\n this.lastButtonDisabled = !maxRowFound || zeroPagesToDisplay || currentPage === (totalPages - 1);\n this.toggleButtonDisabled(this.btNext, this.nextButtonDisabled);\n this.toggleButtonDisabled(this.btLast, this.lastButtonDisabled);\n }\n toggleButtonDisabled(button, disabled) {\n setAriaDisabled(button, disabled);\n button.classList.toggle('ag-disabled', disabled);\n }\n updateRowLabels() {\n const currentPage = this.paginationProxy.getCurrentPage();\n const pageSize = this.paginationProxy.getPageSize();\n const maxRowFound = this.paginationProxy.isLastPageFound();\n const rowCount = this.paginationProxy.isLastPageFound() ?\n this.paginationProxy.getMasterRowCount() : null;\n let startRow;\n let endRow;\n if (this.isZeroPagesToDisplay()) {\n startRow = endRow = 0;\n }\n else {\n startRow = (pageSize * currentPage) + 1;\n endRow = startRow + pageSize - 1;\n if (maxRowFound && endRow > rowCount) {\n endRow = rowCount;\n }\n }\n this.lbFirstRowOnPage.innerHTML = this.formatNumber(startRow);\n if (this.rowNodeBlockLoader.isLoading()) {\n const translate = this.localeService.getLocaleTextFunc();\n this.lbLastRowOnPage.innerHTML = translate('pageLastRowUnknown', '?');\n }\n else {\n this.lbLastRowOnPage.innerHTML = this.formatNumber(endRow);\n }\n }\n isZeroPagesToDisplay() {\n const maxRowFound = this.paginationProxy.isLastPageFound();\n const totalPages = this.paginationProxy.getTotalPages();\n return maxRowFound && totalPages === 0;\n }\n setTotalLabels() {\n const lastPageFound = this.paginationProxy.isLastPageFound();\n const totalPages = this.paginationProxy.getTotalPages();\n const rowCount = lastPageFound ? this.paginationProxy.getMasterRowCount() : null;\n // When `pivotMode=true` and no grouping or value columns exist, a single 'hidden' group row (root node) is in\n // the grid and the pagination totals will correctly display total = 1. However this is confusing to users as\n // they can't see it. To address this UX issue we simply set the totals to zero in the pagination panel.\n if (rowCount === 1) {\n const firstRow = this.paginationProxy.getRow(0);\n // a group node with no group or agg data will not be visible to users\n const hiddenGroupRow = firstRow && firstRow.group && !(firstRow.groupData || firstRow.aggData);\n if (hiddenGroupRow) {\n this.setTotalLabelsToZero();\n return;\n }\n }\n if (lastPageFound) {\n this.lbTotal.innerHTML = this.formatNumber(totalPages);\n this.lbRecordCount.innerHTML = this.formatNumber(rowCount);\n }\n else {\n const moreText = this.localeService.getLocaleTextFunc()('more', 'more');\n this.lbTotal.innerHTML = moreText;\n this.lbRecordCount.innerHTML = moreText;\n }\n }\n setTotalLabelsToZero() {\n this.lbFirstRowOnPage.innerHTML = this.formatNumber(0);\n this.lbCurrent.innerHTML = this.formatNumber(0);\n this.lbLastRowOnPage.innerHTML = this.formatNumber(0);\n this.lbTotal.innerHTML = this.formatNumber(0);\n this.lbRecordCount.innerHTML = this.formatNumber(0);\n }\n}\n__decorate([\n Autowired('paginationProxy')\n], PaginationComp.prototype, \"paginationProxy\", void 0);\n__decorate([\n Autowired('rowNodeBlockLoader')\n], PaginationComp.prototype, \"rowNodeBlockLoader\", void 0);\n__decorate([\n RefSelector('btFirst')\n], PaginationComp.prototype, \"btFirst\", void 0);\n__decorate([\n RefSelector('btPrevious')\n], PaginationComp.prototype, \"btPrevious\", void 0);\n__decorate([\n RefSelector('btNext')\n], PaginationComp.prototype, \"btNext\", void 0);\n__decorate([\n RefSelector('btLast')\n], PaginationComp.prototype, \"btLast\", void 0);\n__decorate([\n RefSelector('lbRecordCount')\n], PaginationComp.prototype, \"lbRecordCount\", void 0);\n__decorate([\n RefSelector('lbFirstRowOnPage')\n], PaginationComp.prototype, \"lbFirstRowOnPage\", void 0);\n__decorate([\n RefSelector('lbLastRowOnPage')\n], PaginationComp.prototype, \"lbLastRowOnPage\", void 0);\n__decorate([\n RefSelector('lbCurrent')\n], PaginationComp.prototype, \"lbCurrent\", void 0);\n__decorate([\n RefSelector('lbTotal')\n], PaginationComp.prototype, \"lbTotal\", void 0);\n__decorate([\n PostConstruct\n], PaginationComp.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from '../../context/context.mjs';\nimport { Component } from '../../widgets/component.mjs';\nimport { RefSelector } from '../../widgets/componentAnnotations.mjs';\nimport { clearElement } from '../../utils/dom.mjs';\nimport { LayoutCssClasses, LayoutFeature } from \"../../styling/layoutFeature.mjs\";\nimport { Events } from \"../../eventKeys.mjs\";\nvar LoadingType;\n(function (LoadingType) {\n LoadingType[LoadingType[\"Loading\"] = 0] = \"Loading\";\n LoadingType[LoadingType[\"NoRows\"] = 1] = \"NoRows\";\n})(LoadingType || (LoadingType = {}));\nexport class OverlayWrapperComponent extends Component {\n constructor() {\n super(OverlayWrapperComponent.TEMPLATE);\n this.inProgress = false;\n this.destroyRequested = false;\n this.manuallyDisplayed = false;\n }\n updateLayoutClasses(cssClass, params) {\n const overlayWrapperClassList = this.eOverlayWrapper.classList;\n overlayWrapperClassList.toggle(LayoutCssClasses.AUTO_HEIGHT, params.autoHeight);\n overlayWrapperClassList.toggle(LayoutCssClasses.NORMAL, params.normal);\n overlayWrapperClassList.toggle(LayoutCssClasses.PRINT, params.print);\n }\n postConstruct() {\n this.createManagedBean(new LayoutFeature(this));\n this.setDisplayed(false, { skipAriaHidden: true });\n this.addManagedListener(this.eventService, Events.EVENT_ROW_DATA_UPDATED, this.onRowDataUpdated.bind(this));\n this.addManagedListener(this.eventService, Events.EVENT_NEW_COLUMNS_LOADED, this.onNewColumnsLoaded.bind(this));\n if (this.gridOptionsService.isRowModelType('clientSide') && !this.gridOptionsService.get('rowData')) {\n this.showLoadingOverlay();\n }\n this.gridApi.registerOverlayWrapperComp(this);\n }\n setWrapperTypeClass(loadingType) {\n const overlayWrapperClassList = this.eOverlayWrapper.classList;\n overlayWrapperClassList.toggle('ag-overlay-loading-wrapper', loadingType === LoadingType.Loading);\n overlayWrapperClassList.toggle('ag-overlay-no-rows-wrapper', loadingType === LoadingType.NoRows);\n }\n showLoadingOverlay() {\n if (this.gridOptionsService.is('suppressLoadingOverlay')) {\n return;\n }\n const params = {};\n const compDetails = this.userComponentFactory.getLoadingOverlayCompDetails(params);\n const promise = compDetails.newAgStackInstance();\n this.showOverlay(promise, LoadingType.Loading);\n }\n showNoRowsOverlay() {\n if (this.gridOptionsService.is('suppressNoRowsOverlay')) {\n return;\n }\n const params = {};\n const compDetails = this.userComponentFactory.getNoRowsOverlayCompDetails(params);\n const promise = compDetails.newAgStackInstance();\n this.showOverlay(promise, LoadingType.NoRows);\n }\n showOverlay(workItem, type) {\n if (this.inProgress) {\n return;\n }\n this.setWrapperTypeClass(type);\n this.destroyActiveOverlay();\n this.inProgress = true;\n if (workItem) {\n workItem.then(comp => {\n this.inProgress = false;\n this.eOverlayWrapper.appendChild(comp.getGui());\n this.activeOverlay = comp;\n if (this.destroyRequested) {\n this.destroyRequested = false;\n this.destroyActiveOverlay();\n }\n });\n }\n this.manuallyDisplayed = this.columnModel.isReady() && !this.paginationProxy.isEmpty();\n this.setDisplayed(true, { skipAriaHidden: true });\n }\n destroyActiveOverlay() {\n if (this.inProgress) {\n this.destroyRequested = true;\n return;\n }\n if (!this.activeOverlay) {\n return;\n }\n this.activeOverlay = this.getContext().destroyBean(this.activeOverlay);\n clearElement(this.eOverlayWrapper);\n }\n hideOverlay() {\n this.manuallyDisplayed = false;\n this.destroyActiveOverlay();\n this.setDisplayed(false, { skipAriaHidden: true });\n }\n destroy() {\n this.destroyActiveOverlay();\n super.destroy();\n }\n showOrHideOverlay() {\n const isEmpty = this.paginationProxy.isEmpty();\n const isSuppressNoRowsOverlay = this.gridOptionsService.is('suppressNoRowsOverlay');\n if (isEmpty && !isSuppressNoRowsOverlay) {\n this.showNoRowsOverlay();\n }\n else {\n this.hideOverlay();\n }\n }\n onRowDataUpdated() {\n this.showOrHideOverlay();\n }\n onNewColumnsLoaded() {\n // hide overlay if columns and rows exist, this can happen if columns are loaded after data.\n // this problem exists before of the race condition between the services (column controller in this case)\n // and the view (grid panel). if the model beans were all initialised first, and then the view beans second,\n // this race condition would not happen.\n if (this.columnModel.isReady() && !this.paginationProxy.isEmpty() && !this.manuallyDisplayed) {\n this.hideOverlay();\n }\n }\n}\n// wrapping in outer div, and wrapper, is needed to center the loading icon\nOverlayWrapperComponent.TEMPLATE = `\n
\n
\n
\n
\n
`;\n__decorate([\n Autowired('userComponentFactory')\n], OverlayWrapperComponent.prototype, \"userComponentFactory\", void 0);\n__decorate([\n Autowired('paginationProxy')\n], OverlayWrapperComponent.prototype, \"paginationProxy\", void 0);\n__decorate([\n Autowired('gridApi')\n], OverlayWrapperComponent.prototype, \"gridApi\", void 0);\n__decorate([\n Autowired('columnModel')\n], OverlayWrapperComponent.prototype, \"columnModel\", void 0);\n__decorate([\n RefSelector('eOverlayWrapper')\n], OverlayWrapperComponent.prototype, \"eOverlayWrapper\", void 0);\n__decorate([\n PostConstruct\n], OverlayWrapperComponent.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { exists } from \"../utils/generic.mjs\";\nlet RowPositionUtils = class RowPositionUtils extends BeanStub {\n getFirstRow() {\n let rowIndex = 0;\n let rowPinned;\n if (this.pinnedRowModel.getPinnedTopRowCount()) {\n rowPinned = 'top';\n }\n else if (this.rowModel.getRowCount()) {\n rowPinned = null;\n rowIndex = this.paginationProxy.getPageFirstRow();\n }\n else if (this.pinnedRowModel.getPinnedBottomRowCount()) {\n rowPinned = 'bottom';\n }\n return rowPinned === undefined ? null : { rowIndex, rowPinned };\n }\n getLastRow() {\n let rowIndex;\n let rowPinned = null;\n const pinnedBottomCount = this.pinnedRowModel.getPinnedBottomRowCount();\n const pinnedTopCount = this.pinnedRowModel.getPinnedTopRowCount();\n if (pinnedBottomCount) {\n rowPinned = 'bottom';\n rowIndex = pinnedBottomCount - 1;\n }\n else if (this.rowModel.getRowCount()) {\n rowPinned = null;\n rowIndex = this.paginationProxy.getPageLastRow();\n }\n else if (pinnedTopCount) {\n rowPinned = 'top';\n rowIndex = pinnedTopCount - 1;\n }\n return rowIndex === undefined ? null : { rowIndex, rowPinned };\n }\n getRowNode(gridRow) {\n switch (gridRow.rowPinned) {\n case 'top':\n return this.pinnedRowModel.getPinnedTopRowData()[gridRow.rowIndex];\n case 'bottom':\n return this.pinnedRowModel.getPinnedBottomRowData()[gridRow.rowIndex];\n default:\n return this.rowModel.getRow(gridRow.rowIndex);\n }\n }\n sameRow(rowA, rowB) {\n // if both missing\n if (!rowA && !rowB) {\n return true;\n }\n // if only one missing\n if ((rowA && !rowB) || (!rowA && rowB)) {\n return false;\n }\n // otherwise compare (use == to compare rowPinned because it can be null or undefined)\n return rowA.rowIndex === rowB.rowIndex && rowA.rowPinned == rowB.rowPinned;\n }\n // tests if this row selection is before the other row selection\n before(rowA, rowB) {\n switch (rowA.rowPinned) {\n case 'top':\n // we we are floating top, and other isn't, then we are always before\n if (rowB.rowPinned !== 'top') {\n return true;\n }\n break;\n case 'bottom':\n // if we are floating bottom, and the other isn't, then we are never before\n if (rowB.rowPinned !== 'bottom') {\n return false;\n }\n break;\n default:\n // if we are not floating, but the other one is floating...\n if (exists(rowB.rowPinned)) {\n return rowB.rowPinned !== 'top';\n }\n break;\n }\n return rowA.rowIndex < rowB.rowIndex;\n }\n rowMax(rows) {\n let max;\n rows.forEach((row) => {\n if (max === undefined || this.before(max, row)) {\n max = row;\n }\n });\n return max;\n }\n rowMin(rows) {\n let min;\n rows.forEach((row) => {\n if (min === undefined || this.before(row, min)) {\n min = row;\n }\n });\n return min;\n }\n};\n__decorate([\n Autowired('rowModel')\n], RowPositionUtils.prototype, \"rowModel\", void 0);\n__decorate([\n Autowired('pinnedRowModel')\n], RowPositionUtils.prototype, \"pinnedRowModel\", void 0);\n__decorate([\n Autowired('paginationProxy')\n], RowPositionUtils.prototype, \"paginationProxy\", void 0);\nRowPositionUtils = __decorate([\n Bean('rowPositionUtils')\n], RowPositionUtils);\nexport { RowPositionUtils };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean } from \"../context/context.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nlet CellPositionUtils = class CellPositionUtils extends BeanStub {\n createId(cellPosition) {\n const { rowIndex, rowPinned, column } = cellPosition;\n return this.createIdFromValues({ rowIndex, column, rowPinned });\n }\n createIdFromValues(cellPosition) {\n const { rowIndex, rowPinned, column } = cellPosition;\n return `${rowIndex}.${rowPinned == null ? 'null' : rowPinned}.${column.getId()}`;\n }\n equals(cellA, cellB) {\n const colsMatch = cellA.column === cellB.column;\n const floatingMatch = cellA.rowPinned === cellB.rowPinned;\n const indexMatch = cellA.rowIndex === cellB.rowIndex;\n return colsMatch && floatingMatch && indexMatch;\n }\n};\nCellPositionUtils = __decorate([\n Bean('cellPositionUtils')\n], CellPositionUtils);\nexport { CellPositionUtils };\n","export class UndoRedoAction {\n constructor(cellValueChanges) {\n this.cellValueChanges = cellValueChanges;\n }\n}\nexport class RangeUndoRedoAction extends UndoRedoAction {\n constructor(cellValueChanges, initialRange, finalRange, ranges) {\n super(cellValueChanges);\n this.initialRange = initialRange;\n this.finalRange = finalRange;\n this.ranges = ranges;\n }\n}\nexport class UndoRedoStack {\n constructor(maxStackSize) {\n this.actionStack = [];\n this.maxStackSize = maxStackSize ? maxStackSize : UndoRedoStack.DEFAULT_STACK_SIZE;\n this.actionStack = new Array(this.maxStackSize);\n }\n pop() {\n return this.actionStack.pop();\n }\n push(item) {\n const shouldAddActions = item.cellValueChanges && item.cellValueChanges.length > 0;\n if (!shouldAddActions) {\n return;\n }\n if (this.actionStack.length === this.maxStackSize) {\n this.actionStack.shift();\n }\n this.actionStack.push(item);\n }\n clear() {\n this.actionStack = [];\n }\n getCurrentStackSize() {\n return this.actionStack.length;\n }\n}\nUndoRedoStack.DEFAULT_STACK_SIZE = 10;\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, Optional, PostConstruct } from \"../context/context.mjs\";\nimport { Events } from \"../eventKeys.mjs\";\nimport { RangeUndoRedoAction, UndoRedoAction, UndoRedoStack } from \"./undoRedoStack.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\nlet UndoRedoService = class UndoRedoService extends BeanStub {\n constructor() {\n super(...arguments);\n this.cellValueChanges = [];\n this.activeCellEdit = null;\n this.activeRowEdit = null;\n this.isPasting = false;\n this.isRangeInAction = false;\n this.onCellValueChanged = (event) => {\n const eventCell = { column: event.column, rowIndex: event.rowIndex, rowPinned: event.rowPinned };\n const isCellEditing = this.activeCellEdit !== null && this.cellPositionUtils.equals(this.activeCellEdit, eventCell);\n const isRowEditing = this.activeRowEdit !== null && this.rowPositionUtils.sameRow(this.activeRowEdit, eventCell);\n const shouldCaptureAction = isCellEditing || isRowEditing || this.isPasting || this.isRangeInAction;\n if (!shouldCaptureAction) {\n return;\n }\n const { rowPinned, rowIndex, column, oldValue, value } = event;\n const cellValueChange = {\n rowPinned,\n rowIndex: rowIndex,\n columnId: column.getColId(),\n newValue: value,\n oldValue\n };\n this.cellValueChanges.push(cellValueChange);\n };\n this.clearStacks = () => {\n this.undoStack.clear();\n this.redoStack.clear();\n };\n }\n init() {\n if (!this.gridOptionsService.is('undoRedoCellEditing')) {\n return;\n }\n const undoRedoLimit = this.gridOptionsService.getNum('undoRedoCellEditingLimit');\n if (undoRedoLimit <= 0) {\n return;\n }\n this.undoStack = new UndoRedoStack(undoRedoLimit);\n this.redoStack = new UndoRedoStack(undoRedoLimit);\n this.addRowEditingListeners();\n this.addCellEditingListeners();\n this.addPasteListeners();\n this.addFillListeners();\n this.addCellKeyListeners();\n this.addManagedListener(this.eventService, Events.EVENT_CELL_VALUE_CHANGED, this.onCellValueChanged);\n // undo / redo is restricted to actual editing so we clear the stacks when other operations are\n // performed that change the order of the row / cols.\n this.addManagedListener(this.eventService, Events.EVENT_MODEL_UPDATED, e => {\n if (!e.keepUndoRedoStack) {\n this.clearStacks();\n }\n });\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PIVOT_MODE_CHANGED, this.clearStacks);\n this.addManagedListener(this.eventService, Events.EVENT_NEW_COLUMNS_LOADED, this.clearStacks);\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_GROUP_OPENED, this.clearStacks);\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_ROW_GROUP_CHANGED, this.clearStacks);\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_MOVED, this.clearStacks);\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_PINNED, this.clearStacks);\n this.addManagedListener(this.eventService, Events.EVENT_COLUMN_VISIBLE, this.clearStacks);\n this.addManagedListener(this.eventService, Events.EVENT_ROW_DRAG_END, this.clearStacks);\n this.ctrlsService.whenReady(() => {\n this.gridBodyCtrl = this.ctrlsService.getGridBodyCtrl();\n });\n }\n getCurrentUndoStackSize() {\n return this.undoStack ? this.undoStack.getCurrentStackSize() : 0;\n }\n getCurrentRedoStackSize() {\n return this.redoStack ? this.redoStack.getCurrentStackSize() : 0;\n }\n undo(source) {\n const startEvent = {\n type: Events.EVENT_UNDO_STARTED,\n source\n };\n this.eventService.dispatchEvent(startEvent);\n const operationPerformed = this.undoRedo(this.undoStack, this.redoStack, 'initialRange', 'oldValue', 'undo');\n const endEvent = {\n type: Events.EVENT_UNDO_ENDED,\n source,\n operationPerformed\n };\n this.eventService.dispatchEvent(endEvent);\n }\n redo(source) {\n const startEvent = {\n type: Events.EVENT_REDO_STARTED,\n source\n };\n this.eventService.dispatchEvent(startEvent);\n const operationPerformed = this.undoRedo(this.redoStack, this.undoStack, 'finalRange', 'newValue', 'redo');\n const endEvent = {\n type: Events.EVENT_REDO_ENDED,\n source,\n operationPerformed\n };\n this.eventService.dispatchEvent(endEvent);\n }\n undoRedo(undoRedoStack, opposingUndoRedoStack, rangeProperty, cellValueChangeProperty, source) {\n if (!undoRedoStack) {\n return false;\n }\n const undoRedoAction = undoRedoStack.pop();\n if (!undoRedoAction || !undoRedoAction.cellValueChanges) {\n return false;\n }\n this.processAction(undoRedoAction, (cellValueChange) => cellValueChange[cellValueChangeProperty], source);\n if (undoRedoAction instanceof RangeUndoRedoAction) {\n this.processRange(undoRedoAction.ranges || [undoRedoAction[rangeProperty]]);\n }\n else {\n this.processCell(undoRedoAction.cellValueChanges);\n }\n opposingUndoRedoStack.push(undoRedoAction);\n return true;\n }\n processAction(action, valueExtractor, source) {\n action.cellValueChanges.forEach(cellValueChange => {\n const { rowIndex, rowPinned, columnId } = cellValueChange;\n const rowPosition = { rowIndex, rowPinned };\n const currentRow = this.getRowNode(rowPosition);\n // checks if the row has been filtered out\n if (!currentRow.displayed) {\n return;\n }\n currentRow.setDataValue(columnId, valueExtractor(cellValueChange), source);\n });\n }\n processRange(ranges) {\n let lastFocusedCell;\n this.rangeService.removeAllCellRanges(true);\n ranges.forEach((range, idx) => {\n if (!range) {\n return;\n }\n const startRow = range.startRow;\n const endRow = range.endRow;\n if (idx === ranges.length - 1) {\n lastFocusedCell = {\n rowPinned: startRow.rowPinned,\n rowIndex: startRow.rowIndex,\n columnId: range.startColumn.getColId()\n };\n this.setLastFocusedCell(lastFocusedCell);\n }\n const cellRangeParams = {\n rowStartIndex: startRow.rowIndex,\n rowStartPinned: startRow.rowPinned,\n rowEndIndex: endRow.rowIndex,\n rowEndPinned: endRow.rowPinned,\n columnStart: range.startColumn,\n columns: range.columns\n };\n this.rangeService.addCellRange(cellRangeParams);\n });\n }\n processCell(cellValueChanges) {\n const cellValueChange = cellValueChanges[0];\n const { rowIndex, rowPinned } = cellValueChange;\n const rowPosition = { rowIndex, rowPinned };\n const row = this.getRowNode(rowPosition);\n const lastFocusedCell = {\n rowPinned: cellValueChange.rowPinned,\n rowIndex: row.rowIndex,\n columnId: cellValueChange.columnId\n };\n // when single cells are being processed, they should be considered\n // as ranges when the rangeService is present (singleCellRanges).\n // otherwise focus will be restore but the range will not.\n this.setLastFocusedCell(lastFocusedCell, !!this.rangeService);\n }\n setLastFocusedCell(lastFocusedCell, setRangeToCell) {\n const { rowIndex, columnId, rowPinned } = lastFocusedCell;\n const scrollFeature = this.gridBodyCtrl.getScrollFeature();\n const column = this.columnModel.getGridColumn(columnId);\n if (!column) {\n return;\n }\n scrollFeature.ensureIndexVisible(rowIndex);\n scrollFeature.ensureColumnVisible(column);\n const cellPosition = { rowIndex, column, rowPinned };\n this.focusService.setFocusedCell(Object.assign(Object.assign({}, cellPosition), { forceBrowserFocus: true }));\n if (setRangeToCell) {\n this.rangeService.setRangeToCell(cellPosition);\n }\n }\n addRowEditingListeners() {\n this.addManagedListener(this.eventService, Events.EVENT_ROW_EDITING_STARTED, (e) => {\n this.activeRowEdit = { rowIndex: e.rowIndex, rowPinned: e.rowPinned };\n });\n this.addManagedListener(this.eventService, Events.EVENT_ROW_EDITING_STOPPED, () => {\n const action = new UndoRedoAction(this.cellValueChanges);\n this.pushActionsToUndoStack(action);\n this.activeRowEdit = null;\n });\n }\n addCellEditingListeners() {\n this.addManagedListener(this.eventService, Events.EVENT_CELL_EDITING_STARTED, (e) => {\n this.activeCellEdit = { column: e.column, rowIndex: e.rowIndex, rowPinned: e.rowPinned };\n });\n this.addManagedListener(this.eventService, Events.EVENT_CELL_EDITING_STOPPED, (e) => {\n this.activeCellEdit = null;\n const shouldPushAction = e.valueChanged && !this.activeRowEdit && !this.isPasting && !this.isRangeInAction;\n if (shouldPushAction) {\n const action = new UndoRedoAction(this.cellValueChanges);\n this.pushActionsToUndoStack(action);\n }\n });\n }\n addPasteListeners() {\n this.addManagedListener(this.eventService, Events.EVENT_PASTE_START, () => {\n this.isPasting = true;\n });\n this.addManagedListener(this.eventService, Events.EVENT_PASTE_END, () => {\n const action = new UndoRedoAction(this.cellValueChanges);\n this.pushActionsToUndoStack(action);\n this.isPasting = false;\n });\n }\n addFillListeners() {\n this.addManagedListener(this.eventService, Events.EVENT_FILL_START, () => {\n this.isRangeInAction = true;\n });\n this.addManagedListener(this.eventService, Events.EVENT_FILL_END, (event) => {\n const action = new RangeUndoRedoAction(this.cellValueChanges, event.initialRange, event.finalRange);\n this.pushActionsToUndoStack(action);\n this.isRangeInAction = false;\n });\n }\n addCellKeyListeners() {\n this.addManagedListener(this.eventService, Events.EVENT_KEY_SHORTCUT_CHANGED_CELL_START, () => {\n this.isRangeInAction = true;\n });\n this.addManagedListener(this.eventService, Events.EVENT_KEY_SHORTCUT_CHANGED_CELL_END, () => {\n let action;\n if (this.rangeService && this.gridOptionsService.is('enableRangeSelection')) {\n action = new RangeUndoRedoAction(this.cellValueChanges, undefined, undefined, [...this.rangeService.getCellRanges()]);\n }\n else {\n action = new UndoRedoAction(this.cellValueChanges);\n }\n this.pushActionsToUndoStack(action);\n this.isRangeInAction = false;\n });\n }\n pushActionsToUndoStack(action) {\n this.undoStack.push(action);\n this.cellValueChanges = [];\n this.redoStack.clear();\n }\n getRowNode(gridRow) {\n switch (gridRow.rowPinned) {\n case 'top':\n return this.pinnedRowModel.getPinnedTopRowData()[gridRow.rowIndex];\n case 'bottom':\n return this.pinnedRowModel.getPinnedBottomRowData()[gridRow.rowIndex];\n default:\n return this.rowModel.getRow(gridRow.rowIndex);\n }\n }\n};\n__decorate([\n Autowired('focusService')\n], UndoRedoService.prototype, \"focusService\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], UndoRedoService.prototype, \"ctrlsService\", void 0);\n__decorate([\n Autowired('rowModel')\n], UndoRedoService.prototype, \"rowModel\", void 0);\n__decorate([\n Autowired('pinnedRowModel')\n], UndoRedoService.prototype, \"pinnedRowModel\", void 0);\n__decorate([\n Autowired('cellPositionUtils')\n], UndoRedoService.prototype, \"cellPositionUtils\", void 0);\n__decorate([\n Autowired('rowPositionUtils')\n], UndoRedoService.prototype, \"rowPositionUtils\", void 0);\n__decorate([\n Autowired('columnModel')\n], UndoRedoService.prototype, \"columnModel\", void 0);\n__decorate([\n Optional('rangeService')\n], UndoRedoService.prototype, \"rangeService\", void 0);\n__decorate([\n PostConstruct\n], UndoRedoService.prototype, \"init\", null);\nUndoRedoService = __decorate([\n Bean('undoRedoService')\n], UndoRedoService);\nexport { UndoRedoService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean } from \"../../context/context.mjs\";\nimport { BeanStub } from \"../../context/beanStub.mjs\";\nimport { ColumnGroup } from \"../../entities/columnGroup.mjs\";\nimport { HeaderRowType } from \"../row/headerRowComp.mjs\";\nimport { last } from \"../../utils/array.mjs\";\nlet HeaderPositionUtils = class HeaderPositionUtils extends BeanStub {\n findHeader(focusedHeader, direction) {\n let nextColumn;\n let getGroupMethod;\n let getColMethod;\n if (focusedHeader.column instanceof ColumnGroup) {\n getGroupMethod = `getDisplayedGroup${direction}`;\n nextColumn = this.columnModel[getGroupMethod](focusedHeader.column);\n }\n else {\n getColMethod = `getDisplayedCol${direction}`;\n nextColumn = this.columnModel[getColMethod](focusedHeader.column);\n }\n if (!nextColumn) {\n return;\n }\n let { headerRowIndex } = focusedHeader;\n const currentRowType = this.getHeaderRowType(headerRowIndex);\n if (currentRowType === HeaderRowType.COLUMN_GROUP) {\n const columnGroup = nextColumn;\n if (columnGroup.isPadding() && this.isAnyChildSpanningHeaderHeight(columnGroup)) {\n const { nextFocusColumn, nextRow } = this.getColumnVisibleChild(columnGroup, headerRowIndex, direction);\n if (nextFocusColumn) {\n nextColumn = nextFocusColumn;\n headerRowIndex = nextRow;\n }\n }\n }\n return {\n column: nextColumn,\n headerRowIndex\n };\n }\n isAnyChildSpanningHeaderHeight(columnGroup) {\n if (!columnGroup) {\n return false;\n }\n return columnGroup.getLeafColumns().some(col => col.isSpanHeaderHeight());\n }\n getColumnVisibleParent(currentColumn, currentIndex) {\n const currentRowType = this.getHeaderRowType(currentIndex);\n const isFloatingFilter = currentRowType === HeaderRowType.FLOATING_FILTER;\n const isColumn = currentRowType === HeaderRowType.COLUMN;\n let nextFocusColumn = isFloatingFilter ? currentColumn : currentColumn.getParent();\n let nextRow = currentIndex - 1;\n if (isColumn && this.isAnyChildSpanningHeaderHeight(currentColumn.getParent())) {\n while (nextFocusColumn && nextFocusColumn.isPadding()) {\n nextFocusColumn = nextFocusColumn.getParent();\n nextRow--;\n }\n if (nextRow < 0) {\n nextFocusColumn = currentColumn;\n nextRow = currentIndex;\n }\n }\n return { nextFocusColumn: nextFocusColumn, nextRow };\n }\n getColumnVisibleChild(column, currentIndex, direction = 'After') {\n const currentRowType = this.getHeaderRowType(currentIndex);\n let nextFocusColumn = column;\n let nextRow = currentIndex + 1;\n if (currentRowType === HeaderRowType.COLUMN_GROUP) {\n const leafColumns = column.getLeafColumns();\n const leafChild = direction === 'After' ? leafColumns[0] : last(leafColumns);\n if (this.isAnyChildSpanningHeaderHeight(leafChild.getParent())) {\n nextFocusColumn = leafChild;\n let currentColumn = leafChild.getParent();\n while (currentColumn && currentColumn !== column) {\n currentColumn = currentColumn.getParent();\n nextRow++;\n }\n }\n else {\n nextFocusColumn = column.getDisplayedChildren()[0];\n }\n }\n return { nextFocusColumn, nextRow };\n }\n getHeaderRowType(rowIndex) {\n const centerHeaderContainer = this.ctrlsService.getHeaderRowContainerCtrl();\n if (centerHeaderContainer) {\n return centerHeaderContainer.getRowType(rowIndex);\n }\n }\n findColAtEdgeForHeaderRow(level, position) {\n const displayedColumns = this.columnModel.getAllDisplayedColumns();\n const column = displayedColumns[position === 'start' ? 0 : displayedColumns.length - 1];\n if (!column) {\n return;\n }\n const childContainer = this.ctrlsService.getHeaderRowContainerCtrl(column.getPinned());\n const type = childContainer.getRowType(level);\n if (type == HeaderRowType.COLUMN_GROUP) {\n const columnGroup = this.columnModel.getColumnGroupAtLevel(column, level);\n return {\n headerRowIndex: level,\n column: columnGroup\n };\n }\n return {\n // if type==null, means the header level didn't exist\n headerRowIndex: type == null ? -1 : level,\n column\n };\n }\n};\n__decorate([\n Autowired('columnModel')\n], HeaderPositionUtils.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], HeaderPositionUtils.prototype, \"ctrlsService\", void 0);\nHeaderPositionUtils = __decorate([\n Bean('headerPositionUtils')\n], HeaderPositionUtils);\nexport { HeaderPositionUtils };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean } from \"../context/context.mjs\";\nimport { deepCloneDefinition } from \"../utils/object.mjs\";\nlet ColumnDefFactory = class ColumnDefFactory {\n buildColumnDefs(cols, rowGroupColumns, pivotColumns) {\n const res = [];\n const colGroupDefs = {};\n cols.forEach(col => {\n const colDef = this.createDefFromColumn(col, rowGroupColumns, pivotColumns);\n let addToResult = true;\n let childDef = colDef;\n let pointer = col.getOriginalParent();\n let lastPointer = null;\n while (pointer) {\n let parentDef = null;\n // we don't include padding groups, as the column groups provided\n // by application didn't have these. the whole point of padding groups\n // is to balance the column tree that the user provided.\n if (pointer.isPadding()) {\n pointer = pointer.getOriginalParent();\n continue;\n }\n // if colDef for this group already exists, use it\n const existingParentDef = colGroupDefs[pointer.getGroupId()];\n if (existingParentDef) {\n existingParentDef.children.push(childDef);\n // if we added to result, it would be the second time we did it\n addToResult = false;\n // we don't want to continue up the tree, as it has already been\n // done for this group\n break;\n }\n parentDef = this.createDefFromGroup(pointer);\n if (parentDef) {\n parentDef.children = [childDef];\n colGroupDefs[parentDef.groupId] = parentDef;\n childDef = parentDef;\n pointer = pointer.getOriginalParent();\n }\n if (pointer != null && lastPointer === pointer) {\n addToResult = false;\n break;\n }\n // Ensure we don't get stuck in an infinite loop\n lastPointer = pointer;\n }\n if (addToResult) {\n res.push(childDef);\n }\n });\n return res;\n }\n createDefFromGroup(group) {\n const defCloned = deepCloneDefinition(group.getColGroupDef(), ['children']);\n if (defCloned) {\n defCloned.groupId = group.getGroupId();\n }\n return defCloned;\n }\n createDefFromColumn(col, rowGroupColumns, pivotColumns) {\n const colDefCloned = deepCloneDefinition(col.getColDef());\n colDefCloned.colId = col.getColId();\n colDefCloned.width = col.getActualWidth();\n colDefCloned.rowGroup = col.isRowGroupActive();\n colDefCloned.rowGroupIndex = col.isRowGroupActive() ? rowGroupColumns.indexOf(col) : null;\n colDefCloned.pivot = col.isPivotActive();\n colDefCloned.pivotIndex = col.isPivotActive() ? pivotColumns.indexOf(col) : null;\n colDefCloned.aggFunc = col.isValueActive() ? col.getAggFunc() : null;\n colDefCloned.hide = col.isVisible() ? undefined : true;\n colDefCloned.pinned = col.isPinned() ? col.getPinned() : null;\n colDefCloned.sort = col.getSort() ? col.getSort() : null;\n colDefCloned.sortIndex = col.getSortIndex() != null ? col.getSortIndex() : null;\n return colDefCloned;\n }\n};\nColumnDefFactory = __decorate([\n Bean('columnDefFactory')\n], ColumnDefFactory);\nexport { ColumnDefFactory };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { exists } from \"../../utils/generic.mjs\";\nimport { pushAll } from \"../../utils/array.mjs\";\nimport { Autowired, Bean } from \"../../context/context.mjs\";\nlet RowCssClassCalculator = class RowCssClassCalculator {\n getInitialRowClasses(params) {\n const classes = [];\n if (exists(params.extraCssClass)) {\n classes.push(params.extraCssClass);\n }\n classes.push('ag-row');\n classes.push(params.rowFocused ? 'ag-row-focus' : 'ag-row-no-focus');\n if (params.fadeRowIn) {\n classes.push('ag-opacity-zero');\n }\n classes.push(params.rowIsEven ? 'ag-row-even' : 'ag-row-odd');\n if (params.rowNode.isRowPinned()) {\n classes.push('ag-row-pinned');\n }\n if (params.rowNode.isSelected()) {\n classes.push('ag-row-selected');\n }\n if (params.rowNode.footer) {\n classes.push('ag-row-footer');\n }\n classes.push('ag-row-level-' + params.rowLevel);\n if (params.rowNode.stub) {\n classes.push('ag-row-loading');\n }\n if (params.fullWidthRow) {\n classes.push('ag-full-width-row');\n }\n if (params.expandable) {\n classes.push('ag-row-group');\n classes.push(params.rowNode.expanded ? 'ag-row-group-expanded' : 'ag-row-group-contracted');\n }\n if (params.rowNode.dragging) {\n classes.push('ag-row-dragging');\n }\n pushAll(classes, this.processClassesFromGridOptions(params.rowNode));\n pushAll(classes, this.preProcessRowClassRules(params.rowNode));\n // we use absolute position unless we are doing print layout\n classes.push(params.printLayout ? 'ag-row-position-relative' : 'ag-row-position-absolute');\n if (params.firstRowOnPage) {\n classes.push('ag-row-first');\n }\n if (params.lastRowOnPage) {\n classes.push('ag-row-last');\n }\n if (params.fullWidthRow) {\n if (params.pinned === 'left') {\n classes.push('ag-cell-last-left-pinned');\n }\n if (params.pinned === 'right') {\n classes.push('ag-cell-first-right-pinned');\n }\n }\n return classes;\n }\n processClassesFromGridOptions(rowNode) {\n const res = [];\n const process = (rowCls) => {\n if (typeof rowCls === 'string') {\n res.push(rowCls);\n }\n else if (Array.isArray(rowCls)) {\n rowCls.forEach(e => res.push(e));\n }\n };\n // part 1 - rowClass\n const rowClass = this.gridOptionsService.get('rowClass');\n if (rowClass) {\n if (typeof rowClass === 'function') {\n console.warn('AG Grid: rowClass should not be a function, please use getRowClass instead');\n return [];\n }\n process(rowClass);\n }\n // part 2 - rowClassFunc\n const rowClassFunc = this.gridOptionsService.getCallback('getRowClass');\n if (rowClassFunc) {\n const params = {\n data: rowNode.data,\n node: rowNode,\n rowIndex: rowNode.rowIndex\n };\n const rowClassFuncResult = rowClassFunc(params);\n process(rowClassFuncResult);\n }\n return res;\n }\n preProcessRowClassRules(rowNode) {\n const res = [];\n this.processRowClassRules(rowNode, (className) => {\n res.push(className);\n }, (className) => {\n // not catered for, if creating, no need\n // to remove class as it was never there\n });\n return res;\n }\n processRowClassRules(rowNode, onApplicableClass, onNotApplicableClass) {\n const rowClassParams = {\n data: rowNode.data,\n node: rowNode,\n rowIndex: rowNode.rowIndex,\n api: this.gridOptionsService.api,\n columnApi: this.gridOptionsService.columnApi,\n context: this.gridOptionsService.context\n };\n this.stylingService.processClassRules(this.gridOptionsService.get('rowClassRules'), rowClassParams, onApplicableClass, onNotApplicableClass);\n }\n calculateRowLevel(rowNode) {\n if (rowNode.group) {\n return rowNode.level;\n }\n // if a leaf, and a parent exists, put a level of the parent, else put level of 0 for top level item\n return rowNode.parent ? (rowNode.parent.level + 1) : 0;\n }\n};\n__decorate([\n Autowired('stylingService')\n], RowCssClassCalculator.prototype, \"stylingService\", void 0);\n__decorate([\n Autowired('gridOptionsService')\n], RowCssClassCalculator.prototype, \"gridOptionsService\", void 0);\nRowCssClassCalculator = __decorate([\n Bean('rowCssClassCalculator')\n], RowCssClassCalculator);\nexport { RowCssClassCalculator };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, PostConstruct } from \"../context/context.mjs\";\nimport { _ } from \"../utils/index.mjs\";\nimport { BeanStub } from \"../context/beanStub.mjs\";\n// this logic is used by both SSRM and CSRM\nlet RowNodeSorter = class RowNodeSorter extends BeanStub {\n init() {\n this.isAccentedSort = this.gridOptionsService.is('accentedSort');\n this.primaryColumnsSortGroups = this.gridOptionsService.isColumnsSortingCoupledToGroup();\n this.addManagedPropertyListener('accentedSort', (propChange) => this.isAccentedSort = propChange.currentValue);\n this.addManagedPropertyListener('autoGroupColumnDef', () => this.primaryColumnsSortGroups = this.gridOptionsService.isColumnsSortingCoupledToGroup());\n }\n doFullSort(rowNodes, sortOptions) {\n const mapper = (rowNode, pos) => ({ currentPos: pos, rowNode: rowNode });\n const sortedRowNodes = rowNodes.map(mapper);\n sortedRowNodes.sort(this.compareRowNodes.bind(this, sortOptions));\n return sortedRowNodes.map(item => item.rowNode);\n }\n compareRowNodes(sortOptions, sortedNodeA, sortedNodeB) {\n const nodeA = sortedNodeA.rowNode;\n const nodeB = sortedNodeB.rowNode;\n // Iterate columns, return the first that doesn't match\n for (let i = 0, len = sortOptions.length; i < len; i++) {\n const sortOption = sortOptions[i];\n const isDescending = sortOption.sort === 'desc';\n const valueA = this.getValue(nodeA, sortOption.column);\n const valueB = this.getValue(nodeB, sortOption.column);\n let comparatorResult;\n const providedComparator = this.getComparator(sortOption, nodeA);\n if (providedComparator) {\n //if comparator provided, use it\n comparatorResult = providedComparator(valueA, valueB, nodeA, nodeB, isDescending);\n }\n else {\n //otherwise do our own comparison\n comparatorResult = _.defaultComparator(valueA, valueB, this.isAccentedSort);\n }\n // user provided comparators can return 'NaN' if they don't correctly handle 'undefined' values, this\n // typically occurs when the comparator is used on a group row\n const validResult = !isNaN(comparatorResult);\n if (validResult && comparatorResult !== 0) {\n return sortOption.sort === 'asc' ? comparatorResult : comparatorResult * -1;\n }\n }\n // All matched, we make is so that the original sort order is kept:\n return sortedNodeA.currentPos - sortedNodeB.currentPos;\n }\n getComparator(sortOption, rowNode) {\n const column = sortOption.column;\n // comparator on col get preference over everything else\n const comparatorOnCol = column.getColDef().comparator;\n if (comparatorOnCol != null) {\n return comparatorOnCol;\n }\n if (!column.getColDef().showRowGroup) {\n return;\n }\n // if a 'field' is supplied on the autoGroupColumnDef we need to use the associated column comparator\n const groupLeafField = !rowNode.group && column.getColDef().field;\n if (!groupLeafField) {\n return;\n }\n const primaryColumn = this.columnModel.getPrimaryColumn(groupLeafField);\n if (!primaryColumn) {\n return;\n }\n return primaryColumn.getColDef().comparator;\n }\n getValue(node, column) {\n var _a, _b;\n if (!this.primaryColumnsSortGroups) {\n return this.valueService.getValue(column, node, false, false);\n }\n const isNodeGroupedAtLevel = node.rowGroupColumn === column;\n if (isNodeGroupedAtLevel) {\n const isGroupRows = this.gridOptionsService.isGroupUseEntireRow(this.columnModel.isPivotActive());\n if (isGroupRows) {\n // if the column has a provided a keyCreator, we have to use the key, as the group could be\n // irrelevant to the column value\n const keyCreator = column.getColDef().keyCreator;\n if (keyCreator) {\n return node.key;\n }\n // if the group was generated from the column data, all the leaf children should return the same\n // value\n const leafChild = (_a = node.allLeafChildren) === null || _a === void 0 ? void 0 : _a[0];\n if (leafChild) {\n return this.valueService.getValue(column, leafChild, false, false);\n }\n return undefined;\n }\n const displayCol = this.columnModel.getGroupDisplayColumnForGroup(column.getId());\n if (!displayCol) {\n return undefined;\n }\n return (_b = node.groupData) === null || _b === void 0 ? void 0 : _b[displayCol.getId()];\n }\n if (node.group && column.getColDef().showRowGroup) {\n return undefined;\n }\n return this.valueService.getValue(column, node, false, false);\n }\n};\n__decorate([\n Autowired('valueService')\n], RowNodeSorter.prototype, \"valueService\", void 0);\n__decorate([\n Autowired('columnModel')\n], RowNodeSorter.prototype, \"columnModel\", void 0);\n__decorate([\n PostConstruct\n], RowNodeSorter.prototype, \"init\", null);\nRowNodeSorter = __decorate([\n Bean('rowNodeSorter')\n], RowNodeSorter);\nexport { RowNodeSorter };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar CtrlsService_1;\nimport { Bean } from \"./context/context.mjs\";\nimport { BeanStub } from \"./context/beanStub.mjs\";\nlet CtrlsService = CtrlsService_1 = class CtrlsService extends BeanStub {\n constructor() {\n super(...arguments);\n this.ready = false;\n this.readyCallbacks = [];\n }\n checkReady() {\n this.ready =\n this.gridCtrl != null\n && this.gridBodyCtrl != null\n && this.centerRowContainerCtrl != null\n && this.leftRowContainerCtrl != null\n && this.rightRowContainerCtrl != null\n && this.bottomCenterRowContainerCtrl != null\n && this.bottomLeftRowContainerCtrl != null\n && this.bottomRightRowContainerCtrl != null\n && this.topCenterRowContainerCtrl != null\n && this.topLeftRowContainerCtrl != null\n && this.topRightRowContainerCtrl != null\n && this.stickyTopCenterRowContainerCtrl != null\n && this.stickyTopLeftRowContainerCtrl != null\n && this.stickyTopRightRowContainerCtrl != null\n && this.centerHeaderRowContainerCtrl != null\n && this.leftHeaderRowContainerCtrl != null\n && this.rightHeaderRowContainerCtrl != null\n && this.fakeHScrollComp != null\n && this.fakeVScrollComp != null\n && this.gridHeaderCtrl != null;\n if (this.ready) {\n const p = this.createReadyParams();\n this.readyCallbacks.forEach(c => c(p));\n this.readyCallbacks.length = 0;\n }\n }\n whenReady(callback) {\n if (this.ready) {\n callback(this.createReadyParams());\n }\n else {\n this.readyCallbacks.push(callback);\n }\n }\n createReadyParams() {\n return {\n centerRowContainerCtrl: this.centerRowContainerCtrl,\n leftRowContainerCtrl: this.leftRowContainerCtrl,\n rightRowContainerCtrl: this.rightRowContainerCtrl,\n bottomCenterRowContainerCtrl: this.bottomCenterRowContainerCtrl,\n bottomLeftRowContainerCtrl: this.bottomLeftRowContainerCtrl,\n bottomRightRowContainerCtrl: this.bottomRightRowContainerCtrl,\n topCenterRowContainerCtrl: this.topCenterRowContainerCtrl,\n topLeftRowContainerCtrl: this.topLeftRowContainerCtrl,\n topRightRowContainerCtrl: this.topRightRowContainerCtrl,\n stickyTopCenterRowContainerCtrl: this.stickyTopCenterRowContainerCtrl,\n stickyTopLeftRowContainerCtrl: this.stickyTopLeftRowContainerCtrl,\n stickyTopRightRowContainerCtrl: this.stickyTopRightRowContainerCtrl,\n centerHeaderRowContainerCtrl: this.centerHeaderRowContainerCtrl,\n leftHeaderRowContainerCtrl: this.leftHeaderRowContainerCtrl,\n rightHeaderRowContainerCtrl: this.rightHeaderRowContainerCtrl,\n fakeHScrollComp: this.fakeHScrollComp,\n fakeVScrollComp: this.fakeVScrollComp,\n gridBodyCtrl: this.gridBodyCtrl,\n gridCtrl: this.gridCtrl,\n gridHeaderCtrl: this.gridHeaderCtrl,\n };\n }\n registerFakeHScrollComp(comp) {\n this.fakeHScrollComp = comp;\n this.checkReady();\n }\n registerFakeVScrollComp(comp) {\n this.fakeVScrollComp = comp;\n this.checkReady();\n }\n registerGridHeaderCtrl(gridHeaderCtrl) {\n this.gridHeaderCtrl = gridHeaderCtrl;\n this.checkReady();\n }\n registerCenterRowContainerCtrl(ctrl) {\n this.centerRowContainerCtrl = ctrl;\n this.checkReady();\n }\n registerLeftRowContainerCtrl(ctrl) {\n this.leftRowContainerCtrl = ctrl;\n this.checkReady();\n }\n registerRightRowContainerCtrl(ctrl) {\n this.rightRowContainerCtrl = ctrl;\n this.checkReady();\n }\n registerTopCenterRowContainerCtrl(ctrl) {\n this.topCenterRowContainerCtrl = ctrl;\n this.checkReady();\n }\n registerTopLeftRowContainerCon(ctrl) {\n this.topLeftRowContainerCtrl = ctrl;\n this.checkReady();\n }\n registerTopRightRowContainerCtrl(ctrl) {\n this.topRightRowContainerCtrl = ctrl;\n this.checkReady();\n }\n registerStickyTopCenterRowContainerCtrl(ctrl) {\n this.stickyTopCenterRowContainerCtrl = ctrl;\n this.checkReady();\n }\n registerStickyTopLeftRowContainerCon(ctrl) {\n this.stickyTopLeftRowContainerCtrl = ctrl;\n this.checkReady();\n }\n registerStickyTopRightRowContainerCtrl(ctrl) {\n this.stickyTopRightRowContainerCtrl = ctrl;\n this.checkReady();\n }\n registerBottomCenterRowContainerCtrl(ctrl) {\n this.bottomCenterRowContainerCtrl = ctrl;\n this.checkReady();\n }\n registerBottomLeftRowContainerCtrl(ctrl) {\n this.bottomLeftRowContainerCtrl = ctrl;\n this.checkReady();\n }\n registerBottomRightRowContainerCtrl(ctrl) {\n this.bottomRightRowContainerCtrl = ctrl;\n this.checkReady();\n }\n registerHeaderContainer(ctrl, pinned) {\n switch (pinned) {\n case 'left':\n this.leftHeaderRowContainerCtrl = ctrl;\n break;\n case 'right':\n this.rightHeaderRowContainerCtrl = ctrl;\n break;\n default:\n this.centerHeaderRowContainerCtrl = ctrl;\n break;\n }\n this.checkReady();\n }\n registerGridBodyCtrl(ctrl) {\n this.gridBodyCtrl = ctrl;\n this.checkReady();\n }\n registerGridCtrl(ctrl) {\n this.gridCtrl = ctrl;\n this.checkReady();\n }\n getFakeHScrollComp() {\n return this.fakeHScrollComp;\n }\n getFakeVScrollComp() {\n return this.fakeVScrollComp;\n }\n getGridHeaderCtrl() {\n return this.gridHeaderCtrl;\n }\n getGridCtrl() {\n return this.gridCtrl;\n }\n getCenterRowContainerCtrl() {\n return this.centerRowContainerCtrl;\n }\n getTopCenterRowContainerCtrl() {\n return this.topCenterRowContainerCtrl;\n }\n getBottomCenterRowContainerCtrl() {\n return this.bottomCenterRowContainerCtrl;\n }\n getStickyTopCenterRowContainerCtrl() {\n return this.stickyTopCenterRowContainerCtrl;\n }\n getGridBodyCtrl() {\n return this.gridBodyCtrl;\n }\n getHeaderRowContainerCtrls() {\n return [this.leftHeaderRowContainerCtrl, this.rightHeaderRowContainerCtrl, this.centerHeaderRowContainerCtrl];\n }\n getHeaderRowContainerCtrl(pinned) {\n switch (pinned) {\n case 'left': return this.leftHeaderRowContainerCtrl;\n case 'right': return this.rightHeaderRowContainerCtrl;\n default: return this.centerHeaderRowContainerCtrl;\n }\n }\n};\nCtrlsService.NAME = 'ctrlsService';\nCtrlsService = CtrlsService_1 = __decorate([\n Bean(CtrlsService_1.NAME)\n], CtrlsService);\nexport { CtrlsService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"./context/beanStub.mjs\";\nimport { Bean } from \"./context/context.mjs\";\nlet CtrlsFactory = class CtrlsFactory extends BeanStub {\n constructor() {\n super(...arguments);\n this.registry = {};\n }\n register(meta) {\n this.registry[meta.controllerName] = meta.controllerClass;\n }\n getInstance(name) {\n const ControllerClass = this.registry[name];\n if (ControllerClass == null) {\n return undefined;\n }\n return new ControllerClass();\n }\n};\nCtrlsFactory = __decorate([\n Bean('ctrlsFactory')\n], CtrlsFactory);\nexport { CtrlsFactory };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired } from \"../context/context.mjs\";\nimport { Events } from \"../eventKeys.mjs\";\nimport { isInvisibleScrollbar, isIOSUserAgent, isMacOsUserAgent } from \"../utils/browser.mjs\";\nimport { isVisible } from \"../utils/dom.mjs\";\nimport { waitUntil } from \"../utils/function.mjs\";\nimport { Component } from \"../widgets/component.mjs\";\nimport { RefSelector } from \"../widgets/componentAnnotations.mjs\";\nexport class AbstractFakeScrollComp extends Component {\n constructor(template, direction) {\n super(template);\n this.direction = direction;\n this.hideTimeout = null;\n }\n postConstruct() {\n this.addManagedListener(this.eventService, Events.EVENT_SCROLL_VISIBILITY_CHANGED, this.onScrollVisibilityChanged.bind(this));\n this.onScrollVisibilityChanged();\n this.addOrRemoveCssClass('ag-apple-scrollbar', isMacOsUserAgent() || isIOSUserAgent());\n }\n initialiseInvisibleScrollbar() {\n if (this.invisibleScrollbar !== undefined) {\n return;\n }\n this.invisibleScrollbar = isInvisibleScrollbar();\n if (this.invisibleScrollbar) {\n this.hideAndShowInvisibleScrollAsNeeded();\n this.addActiveListenerToggles();\n }\n }\n addActiveListenerToggles() {\n const activateEvents = ['mouseenter', 'mousedown', 'touchstart'];\n const deactivateEvents = ['mouseleave', 'touchend'];\n const eGui = this.getGui();\n activateEvents.forEach(eventName => this.addManagedListener(eGui, eventName, () => this.addOrRemoveCssClass('ag-scrollbar-active', true)));\n deactivateEvents.forEach(eventName => this.addManagedListener(eGui, eventName, () => this.addOrRemoveCssClass('ag-scrollbar-active', false)));\n }\n onScrollVisibilityChanged() {\n // initialiseInvisibleScrollbar should only be called once, but the reason\n // this can't be inside `setComp` or `PostConstruct` is the DOM might not\n // be ready, so we call it until eventually, it gets calculated.\n if (this.invisibleScrollbar === undefined) {\n this.initialiseInvisibleScrollbar();\n }\n this.animationFrameService.requestAnimationFrame(() => this.setScrollVisible());\n }\n hideAndShowInvisibleScrollAsNeeded() {\n this.addManagedListener(this.eventService, Events.EVENT_BODY_SCROLL, (params) => {\n if (params.direction === this.direction) {\n if (this.hideTimeout !== null) {\n window.clearTimeout(this.hideTimeout);\n this.hideTimeout = null;\n }\n this.addOrRemoveCssClass('ag-scrollbar-scrolling', true);\n }\n });\n this.addManagedListener(this.eventService, Events.EVENT_BODY_SCROLL_END, () => {\n this.hideTimeout = window.setTimeout(() => {\n this.addOrRemoveCssClass('ag-scrollbar-scrolling', false);\n this.hideTimeout = null;\n }, 400);\n });\n }\n attemptSettingScrollPosition(value) {\n const viewport = this.getViewport();\n waitUntil(() => isVisible(viewport), () => this.setScrollPosition(value), 100);\n }\n getViewport() {\n return this.eViewport;\n }\n getContainer() {\n return this.eContainer;\n }\n onScrollCallback(fn) {\n this.addManagedListener(this.getViewport(), 'scroll', fn);\n }\n}\n__decorate([\n RefSelector('eViewport')\n], AbstractFakeScrollComp.prototype, \"eViewport\", void 0);\n__decorate([\n RefSelector('eContainer')\n], AbstractFakeScrollComp.prototype, \"eContainer\", void 0);\n__decorate([\n Autowired('scrollVisibleService')\n], AbstractFakeScrollComp.prototype, \"scrollVisibleService\", void 0);\n__decorate([\n Autowired('ctrlsService')\n], AbstractFakeScrollComp.prototype, \"ctrlsService\", void 0);\n__decorate([\n Autowired('animationFrameService')\n], AbstractFakeScrollComp.prototype, \"animationFrameService\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, PostConstruct } from \"../context/context.mjs\";\nimport { AbstractFakeScrollComp } from \"./abstractFakeScrollComp.mjs\";\nimport { getScrollLeft, isVisible, setFixedHeight, setFixedWidth, setScrollLeft } from \"../utils/dom.mjs\";\nimport { Events } from \"../eventKeys.mjs\";\nimport { RefSelector } from \"../widgets/componentAnnotations.mjs\";\nimport { CenterWidthFeature } from \"./centerWidthFeature.mjs\";\nexport class FakeHScrollComp extends AbstractFakeScrollComp {\n constructor() {\n super(FakeHScrollComp.TEMPLATE, 'horizontal');\n }\n postConstruct() {\n super.postConstruct();\n // When doing printing, this changes whether cols are pinned or not\n const spacerWidthsListener = this.setFakeHScrollSpacerWidths.bind(this);\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, spacerWidthsListener);\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, spacerWidthsListener);\n this.addManagedListener(this.eventService, Events.EVENT_PINNED_ROW_DATA_CHANGED, this.onPinnedRowDataChanged.bind(this));\n this.addManagedPropertyListener('domLayout', spacerWidthsListener);\n this.ctrlsService.registerFakeHScrollComp(this);\n this.createManagedBean(new CenterWidthFeature(width => this.eContainer.style.width = `${width}px`));\n }\n initialiseInvisibleScrollbar() {\n if (this.invisibleScrollbar !== undefined) {\n return;\n }\n this.enableRtl = this.gridOptionsService.is('enableRtl');\n super.initialiseInvisibleScrollbar();\n if (this.invisibleScrollbar) {\n this.refreshCompBottom();\n }\n }\n onPinnedRowDataChanged() {\n this.refreshCompBottom();\n }\n refreshCompBottom() {\n if (!this.invisibleScrollbar) {\n return;\n }\n const bottomPinnedHeight = this.pinnedRowModel.getPinnedBottomTotalHeight();\n this.getGui().style.bottom = `${bottomPinnedHeight}px`;\n }\n onScrollVisibilityChanged() {\n super.onScrollVisibilityChanged();\n this.setFakeHScrollSpacerWidths();\n }\n setFakeHScrollSpacerWidths() {\n const vScrollShowing = this.scrollVisibleService.isVerticalScrollShowing();\n // we pad the right based on a) if cols are pinned to the right and\n // b) if v scroll is showing on the right (normal position of scroll)\n let rightSpacing = this.columnModel.getDisplayedColumnsRightWidth();\n const scrollOnRight = !this.enableRtl && vScrollShowing;\n const scrollbarWidth = this.gridOptionsService.getScrollbarWidth();\n if (scrollOnRight) {\n rightSpacing += scrollbarWidth;\n }\n setFixedWidth(this.eRightSpacer, rightSpacing);\n this.eRightSpacer.classList.toggle('ag-scroller-corner', rightSpacing <= scrollbarWidth);\n // we pad the left based on a) if cols are pinned to the left and\n // b) if v scroll is showing on the left (happens in LTR layout only)\n let leftSpacing = this.columnModel.getDisplayedColumnsLeftWidth();\n const scrollOnLeft = this.enableRtl && vScrollShowing;\n if (scrollOnLeft) {\n leftSpacing += scrollbarWidth;\n }\n setFixedWidth(this.eLeftSpacer, leftSpacing);\n this.eLeftSpacer.classList.toggle('ag-scroller-corner', leftSpacing <= scrollbarWidth);\n }\n setScrollVisible() {\n const hScrollShowing = this.scrollVisibleService.isHorizontalScrollShowing();\n const invisibleScrollbar = this.invisibleScrollbar;\n const isSuppressHorizontalScroll = this.gridOptionsService.is('suppressHorizontalScroll');\n const scrollbarWidth = hScrollShowing ? (this.gridOptionsService.getScrollbarWidth() || 0) : 0;\n const adjustedScrollbarWidth = (scrollbarWidth === 0 && invisibleScrollbar) ? 16 : scrollbarWidth;\n const scrollContainerSize = !isSuppressHorizontalScroll ? adjustedScrollbarWidth : 0;\n this.addOrRemoveCssClass('ag-scrollbar-invisible', invisibleScrollbar);\n setFixedHeight(this.getGui(), scrollContainerSize);\n setFixedHeight(this.eViewport, scrollContainerSize);\n setFixedHeight(this.eContainer, scrollContainerSize);\n this.setDisplayed(hScrollShowing, { skipAriaHidden: true });\n }\n getScrollPosition() {\n return getScrollLeft(this.getViewport(), this.enableRtl);\n }\n setScrollPosition(value) {\n if (!isVisible(this.getViewport())) {\n this.attemptSettingScrollPosition(value);\n }\n setScrollLeft(this.getViewport(), value, this.enableRtl);\n }\n}\nFakeHScrollComp.TEMPLATE = `
\n
\n
\n
\n
\n
\n
`;\n__decorate([\n RefSelector('eLeftSpacer')\n], FakeHScrollComp.prototype, \"eLeftSpacer\", void 0);\n__decorate([\n RefSelector('eRightSpacer')\n], FakeHScrollComp.prototype, \"eRightSpacer\", void 0);\n__decorate([\n Autowired('columnModel')\n], FakeHScrollComp.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('pinnedRowModel')\n], FakeHScrollComp.prototype, \"pinnedRowModel\", void 0);\n__decorate([\n PostConstruct\n], FakeHScrollComp.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { Autowired, Bean, PostConstruct } from \"../context/context.mjs\";\nimport { Events } from \"../eventKeys.mjs\";\nlet PinnedWidthService = class PinnedWidthService extends BeanStub {\n postConstruct() {\n const listener = this.checkContainerWidths.bind(this);\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_CHANGED, listener);\n this.addManagedListener(this.eventService, Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, listener);\n this.addManagedPropertyListener('domLayout', listener);\n }\n checkContainerWidths() {\n const printLayout = this.gridOptionsService.isDomLayout('print');\n const newLeftWidth = printLayout ? 0 : this.columnModel.getDisplayedColumnsLeftWidth();\n const newRightWidth = printLayout ? 0 : this.columnModel.getDisplayedColumnsRightWidth();\n if (newLeftWidth != this.leftWidth) {\n this.leftWidth = newLeftWidth;\n this.eventService.dispatchEvent({ type: Events.EVENT_LEFT_PINNED_WIDTH_CHANGED });\n }\n if (newRightWidth != this.rightWidth) {\n this.rightWidth = newRightWidth;\n this.eventService.dispatchEvent({ type: Events.EVENT_RIGHT_PINNED_WIDTH_CHANGED });\n }\n }\n getPinnedRightWidth() {\n return this.rightWidth;\n }\n getPinnedLeftWidth() {\n return this.leftWidth;\n }\n};\n__decorate([\n Autowired('columnModel')\n], PinnedWidthService.prototype, \"columnModel\", void 0);\n__decorate([\n PostConstruct\n], PinnedWidthService.prototype, \"postConstruct\", null);\nPinnedWidthService = __decorate([\n Bean('pinnedWidthService')\n], PinnedWidthService);\nexport { PinnedWidthService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { BeanStub } from \"../context/beanStub.mjs\";\nimport { Autowired, Bean, PostConstruct } from \"../context/context.mjs\";\nlet RowNodeEventThrottle = class RowNodeEventThrottle extends BeanStub {\n constructor() {\n super(...arguments);\n this.events = [];\n }\n postConstruct() {\n if (this.rowModel.getType() == 'clientSide') {\n this.clientSideRowModel = this.rowModel;\n }\n }\n // because the user can call rowNode.setExpanded() many times in one VM turn,\n // we throttle the calls to ClientSideRowModel using animationFrameService. this means for 100\n // row nodes getting expanded, we only update the CSRM once, and then we fire all events after\n // CSRM has updated.\n //\n // if we did not do this, then the user could call setExpanded on 100+ rows, causing the grid\n // to re-render 100+ times, which would be a performance lag.\n //\n // we use animationFrameService\n // rather than _.debounce() so this will get done if anyone flushes the animationFrameService\n // (eg user calls api.ensureRowVisible(), which in turn flushes ).\n dispatchExpanded(event) {\n // if not using CSRM, we don't debounce. otherwise this breaks the SSRM.\n if (this.clientSideRowModel == null) {\n this.eventService.dispatchEvent(event);\n return;\n }\n this.events.push(event);\n const func = () => {\n if (this.clientSideRowModel) {\n this.clientSideRowModel.onRowGroupOpened();\n }\n this.events.forEach(e => this.eventService.dispatchEvent(e));\n this.events = [];\n };\n if (this.dispatchExpandedDebounced == null) {\n this.dispatchExpandedDebounced = this.animationFrameService.debounce(func);\n }\n this.dispatchExpandedDebounced();\n }\n};\n__decorate([\n Autowired('animationFrameService')\n], RowNodeEventThrottle.prototype, \"animationFrameService\", void 0);\n__decorate([\n Autowired('rowModel')\n], RowNodeEventThrottle.prototype, \"rowModel\", void 0);\n__decorate([\n PostConstruct\n], RowNodeEventThrottle.prototype, \"postConstruct\", null);\nRowNodeEventThrottle = __decorate([\n Bean('rowNodeEventThrottle')\n], RowNodeEventThrottle);\nexport { RowNodeEventThrottle };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nvar __param = (this && this.__param) || function (paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n};\nvar GridOptionsService_1;\nimport { ComponentUtil } from \"./components/componentUtil.mjs\";\nimport { Autowired, Bean, PostConstruct, PreDestroy, Qualifier } from \"./context/context.mjs\";\nimport { Events } from \"./events.mjs\";\nimport { EventService } from \"./eventService.mjs\";\nimport { doOnce } from \"./utils/function.mjs\";\nimport { exists, missing } from \"./utils/generic.mjs\";\nimport { getScrollbarWidth } from './utils/browser.mjs';\nimport { matchesGroupDisplayType } from \"./gridOptionsValidator.mjs\";\nfunction toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (typeof value == 'string') {\n return parseInt(value, 10);\n }\n}\nfunction isTrue(value) {\n return value === true || value === 'true';\n}\nlet GridOptionsService = GridOptionsService_1 = class GridOptionsService {\n constructor() {\n this.destroyed = false;\n this.domDataKey = '__AG_' + Math.random().toString();\n this.propertyEventService = new EventService();\n // responsible for calling the onXXX functions on gridOptions\n // It forces events defined in GridOptionsService.alwaysSyncGlobalEvents to be fired synchronously.\n // This is required for events such as GridPreDestroyed.\n // Other events can be fired asynchronously or synchronously depending on config.\n this.globalEventHandlerFactory = (restrictToSyncOnly) => {\n return (eventName, event) => {\n // prevent events from being fired _after_ the grid has been destroyed\n if (this.destroyed) {\n return;\n }\n const alwaysSync = GridOptionsService_1.alwaysSyncGlobalEvents.has(eventName);\n if ((alwaysSync && !restrictToSyncOnly) || (!alwaysSync && restrictToSyncOnly)) {\n return;\n }\n const callbackMethodName = ComponentUtil.getCallbackForEvent(eventName);\n if (typeof this.gridOptions[callbackMethodName] === 'function') {\n this.gridOptions[callbackMethodName](event);\n }\n };\n };\n }\n // This is quicker then having code call gridOptionsService.get('context')\n get context() {\n return this.gridOptions['context'];\n }\n agWire(gridApi, columnApi) {\n this.gridOptions.api = gridApi;\n this.gridOptions.columnApi = columnApi;\n this.api = gridApi;\n this.columnApi = columnApi;\n }\n init() {\n this.gridOptionLookup = new Set([...ComponentUtil.ALL_PROPERTIES, ...ComponentUtil.EVENT_CALLBACKS]);\n const async = !this.is('suppressAsyncEvents');\n this.eventService.addGlobalListener(this.globalEventHandlerFactory().bind(this), async);\n this.eventService.addGlobalListener(this.globalEventHandlerFactory(true).bind(this), false);\n // sets an initial calculation for the scrollbar width\n this.getScrollbarWidth();\n }\n destroy() {\n // need to remove these, as we don't own the lifecycle of the gridOptions, we need to\n // remove the references in case the user keeps the grid options, we want the rest\n // of the grid to be picked up by the garbage collector\n this.gridOptions.api = null;\n this.gridOptions.columnApi = null;\n this.destroyed = true;\n }\n /**\n * Is the given GridOption property set to true.\n * @param property GridOption property that has the type `boolean | undefined`\n */\n is(property) {\n return isTrue(this.gridOptions[property]);\n }\n /**\n * Get the raw value of the GridOptions property provided.\n * @param property\n */\n get(property) {\n return this.gridOptions[property];\n }\n /**\n * Get the GridOption property as a number, raw value is returned via a toNumber coercion function.\n * @param property GridOption property that has the type `number | undefined`\n */\n getNum(property) {\n return toNumber(this.gridOptions[property]);\n }\n /**\n * Get the GridOption callback but wrapped so that the common params of api,columnApi and context are automatically applied to the params.\n * @param property GridOption callback properties based on the fact that this property has a callback with params extending AgGridCommon\n */\n getCallback(property) {\n return this.mergeGridCommonParams(this.gridOptions[property]);\n }\n /**\n * Returns `true` if a value has been specified for this GridOption.\n * @param property GridOption property\n */\n exists(property) {\n return exists(this.gridOptions[property]);\n }\n /**\n * Wrap the user callback and attach the api, columnApi and context to the params object on the way through.\n * @param callback User provided callback\n * @returns Wrapped callback where the params object not require api, columnApi and context\n */\n mergeGridCommonParams(callback) {\n if (callback) {\n const wrapped = (callbackParams) => {\n const mergedParams = callbackParams;\n mergedParams.api = this.api;\n mergedParams.columnApi = this.columnApi;\n mergedParams.context = this.context;\n return callback(mergedParams);\n };\n return wrapped;\n }\n return callback;\n }\n /**\n * DO NOT USE - only for use for ComponentUtil applyChanges via GridApi.\n * Use `set` method instead.\n * Only update the property value, don't fire any events. This enables all properties\n * that have been updated together to be updated before any events get triggered to avoid\n * out of sync issues.\n * @param key - key of the GridOption property to update\n * @param newValue - new value for this property\n * @returns The `true` if the previous value is not equal to the new value.\n */\n __setPropertyOnly(key, newValue) {\n const previousValue = this.gridOptions[key];\n if (this.gridOptionLookup.has(key)) {\n this.gridOptions[key] = newValue;\n }\n return previousValue !== newValue;\n }\n /**\n *\n * @param key - key of the GridOption property to update\n * @param newValue - new value for this property\n * @param force - force the property change Event to be fired even if the value has not changed\n * @param eventParams - additional params to merge into the property changed event\n * @param changeSetId - Change set id used to identify keys that have been updated in the same framework lifecycle update.\n */\n set(key, newValue, force = false, eventParams = {}, changeSet = undefined) {\n if (this.gridOptionLookup.has(key)) {\n const previousValue = this.gridOptions[key];\n if (force || previousValue !== newValue) {\n this.gridOptions[key] = newValue;\n const event = Object.assign({ type: key, currentValue: newValue, previousValue,\n changeSet }, eventParams);\n this.propertyEventService.dispatchEvent(event);\n }\n }\n }\n addEventListener(key, listener) {\n this.propertyEventService.addEventListener(key, listener);\n }\n removeEventListener(key, listener) {\n this.propertyEventService.removeEventListener(key, listener);\n }\n // *************** Helper methods ************************** //\n // Methods to share common GridOptions related logic that goes above accessing a single property\n getGridId() {\n return this.api.getGridId();\n }\n // the user might be using some non-standard scrollbar, eg a scrollbar that has zero\n // width and overlays (like the Safari scrollbar, but presented in Chrome). so we\n // allow the user to provide the scroll width before we work it out.\n getScrollbarWidth() {\n if (this.scrollbarWidth == null) {\n const useGridOptions = typeof this.gridOptions.scrollbarWidth === 'number' && this.gridOptions.scrollbarWidth >= 0;\n const scrollbarWidth = useGridOptions ? this.gridOptions.scrollbarWidth : getScrollbarWidth();\n if (scrollbarWidth != null) {\n this.scrollbarWidth = scrollbarWidth;\n this.eventService.dispatchEvent({\n type: Events.EVENT_SCROLLBAR_WIDTH_CHANGED\n });\n }\n }\n return this.scrollbarWidth;\n }\n isRowModelType(rowModelType) {\n return this.gridOptions.rowModelType === rowModelType ||\n (rowModelType === 'clientSide' && missing(this.gridOptions.rowModelType));\n }\n isDomLayout(domLayout) {\n var _a;\n const gridLayout = (_a = this.gridOptions.domLayout) !== null && _a !== void 0 ? _a : 'normal';\n return gridLayout === domLayout;\n }\n isRowSelection() {\n return this.gridOptions.rowSelection === 'single' || this.gridOptions.rowSelection === 'multiple';\n }\n useAsyncEvents() {\n return !this.is('suppressAsyncEvents');\n }\n isGetRowHeightFunction() {\n return typeof this.gridOptions.getRowHeight === 'function';\n }\n getRowHeightForNode(rowNode, allowEstimate = false, defaultRowHeight) {\n if (defaultRowHeight == null) {\n defaultRowHeight = this.environment.getDefaultRowHeight();\n }\n // check the function first, in case use set both function and\n // number, when using virtual pagination then function can be\n // used for pinned rows and the number for the body rows.\n if (this.isGetRowHeightFunction()) {\n if (allowEstimate) {\n return { height: defaultRowHeight, estimated: true };\n }\n const params = {\n node: rowNode,\n data: rowNode.data\n };\n const height = this.getCallback('getRowHeight')(params);\n if (this.isNumeric(height)) {\n if (height === 0) {\n doOnce(() => console.warn('AG Grid: The return of `getRowHeight` cannot be zero. If the intention is to hide rows, use a filter instead.'), 'invalidRowHeight');\n }\n return { height: Math.max(1, height), estimated: false };\n }\n }\n if (rowNode.detail && this.is('masterDetail')) {\n return this.getMasterDetailRowHeight();\n }\n const rowHeight = this.gridOptions.rowHeight && this.isNumeric(this.gridOptions.rowHeight) ? this.gridOptions.rowHeight : defaultRowHeight;\n return { height: rowHeight, estimated: false };\n }\n getMasterDetailRowHeight() {\n // if autoHeight, we want the height to grow to the new height starting at 1, as otherwise a flicker would happen,\n // as the detail goes to the default (eg 200px) and then immediately shrink up/down to the new measured height\n // (due to auto height) which looks bad, especially if doing row animation.\n if (this.is('detailRowAutoHeight')) {\n return { height: 1, estimated: false };\n }\n if (this.isNumeric(this.gridOptions.detailRowHeight)) {\n return { height: this.gridOptions.detailRowHeight, estimated: false };\n }\n return { height: 300, estimated: false };\n }\n // we don't allow dynamic row height for virtual paging\n getRowHeightAsNumber() {\n if (!this.gridOptions.rowHeight || missing(this.gridOptions.rowHeight)) {\n return this.environment.getDefaultRowHeight();\n }\n const rowHeight = this.environment.refreshRowHeightVariable();\n if (rowHeight !== -1) {\n return rowHeight;\n }\n console.warn('AG Grid row height must be a number if not using standard row model');\n return this.environment.getDefaultRowHeight();\n }\n isNumeric(value) {\n return !isNaN(value) && typeof value === 'number' && isFinite(value);\n }\n getDomDataKey() {\n return this.domDataKey;\n }\n // returns the dom data, or undefined if not found\n getDomData(element, key) {\n const domData = element[this.getDomDataKey()];\n return domData ? domData[key] : undefined;\n }\n setDomData(element, key, value) {\n const domDataKey = this.getDomDataKey();\n let domData = element[domDataKey];\n if (missing(domData)) {\n domData = {};\n element[domDataKey] = domData;\n }\n domData[key] = value;\n }\n getDocument() {\n // if user is providing document, we use the users one,\n // otherwise we use the document on the global namespace.\n let result = null;\n if (this.gridOptions.getDocument && exists(this.gridOptions.getDocument)) {\n result = this.gridOptions.getDocument();\n }\n else if (this.eGridDiv) {\n result = this.eGridDiv.ownerDocument;\n }\n if (result && exists(result)) {\n return result;\n }\n return document;\n }\n getWindow() {\n const eDocument = this.getDocument();\n return eDocument.defaultView || window;\n }\n getRootNode() {\n return this.eGridDiv.getRootNode();\n }\n getAsyncTransactionWaitMillis() {\n return exists(this.gridOptions.asyncTransactionWaitMillis) ? this.gridOptions.asyncTransactionWaitMillis : 50;\n }\n isAnimateRows() {\n // never allow animating if enforcing the row order\n if (this.is('ensureDomOrder')) {\n return false;\n }\n return this.is('animateRows');\n }\n isGroupRowsSticky() {\n if (this.is('suppressGroupRowsSticky') ||\n this.is('paginateChildRows') ||\n this.is('groupHideOpenParents')) {\n return false;\n }\n return true;\n }\n isColumnsSortingCoupledToGroup() {\n const autoGroupColumnDef = this.gridOptions.autoGroupColumnDef;\n const isClientSideRowModel = this.isRowModelType('clientSide');\n return isClientSideRowModel && !(autoGroupColumnDef === null || autoGroupColumnDef === void 0 ? void 0 : autoGroupColumnDef.comparator) && !this.is('treeData');\n }\n getGroupAggFiltering() {\n const userValue = this.gridOptions.groupAggFiltering;\n if (typeof userValue === 'function') {\n return this.getCallback('groupAggFiltering');\n }\n if (isTrue(userValue)) {\n return () => true;\n }\n return undefined;\n }\n isGroupIncludeFooterTrueOrCallback() {\n const userValue = this.gridOptions.groupIncludeFooter;\n return isTrue(userValue) || typeof userValue === 'function';\n }\n getGroupIncludeFooter() {\n const userValue = this.gridOptions.groupIncludeFooter;\n if (typeof userValue === 'function') {\n return this.getCallback('groupIncludeFooter');\n }\n if (isTrue(userValue)) {\n return () => true;\n }\n return () => false;\n }\n isGroupMultiAutoColumn() {\n if (this.gridOptions.groupDisplayType) {\n return matchesGroupDisplayType('multipleColumns', this.gridOptions.groupDisplayType);\n }\n // if we are doing hideOpenParents we also show multiple columns, otherwise hideOpenParents would not work\n return this.is('groupHideOpenParents');\n }\n isGroupUseEntireRow(pivotMode) {\n // we never allow groupDisplayType = 'groupRows' if in pivot mode, otherwise we won't see the pivot values.\n if (pivotMode) {\n return false;\n }\n return this.gridOptions.groupDisplayType ? matchesGroupDisplayType('groupRows', this.gridOptions.groupDisplayType) : false;\n }\n};\nGridOptionsService.alwaysSyncGlobalEvents = new Set([Events.EVENT_GRID_PRE_DESTROYED]);\n__decorate([\n Autowired('gridOptions')\n], GridOptionsService.prototype, \"gridOptions\", void 0);\n__decorate([\n Autowired('eventService')\n], GridOptionsService.prototype, \"eventService\", void 0);\n__decorate([\n Autowired('environment')\n], GridOptionsService.prototype, \"environment\", void 0);\n__decorate([\n Autowired('eGridDiv')\n], GridOptionsService.prototype, \"eGridDiv\", void 0);\n__decorate([\n __param(0, Qualifier('gridApi')),\n __param(1, Qualifier('columnApi'))\n], GridOptionsService.prototype, \"agWire\", null);\n__decorate([\n PostConstruct\n], GridOptionsService.prototype, \"init\", null);\n__decorate([\n PreDestroy\n], GridOptionsService.prototype, \"destroy\", null);\nGridOptionsService = GridOptionsService_1 = __decorate([\n Bean('gridOptionsService')\n], GridOptionsService);\nexport { GridOptionsService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean } from \"./context/context.mjs\";\nimport { BeanStub } from \"./context/beanStub.mjs\";\nlet LocaleService = class LocaleService extends BeanStub {\n getLocaleTextFunc() {\n const getLocaleText = this.gridOptionsService.getCallback('getLocaleText');\n if (getLocaleText) {\n //key: string, defaultValue: string, variableValues?: string[]\n return (key, defaultValue, variableValues) => {\n const params = {\n key,\n defaultValue,\n variableValues\n };\n return getLocaleText(params);\n };\n }\n const localeText = this.gridOptionsService.get('localeText');\n return (key, defaultValue, variableValues) => {\n let localisedText = localeText && localeText[key];\n if (localisedText && variableValues && variableValues.length) {\n let found = 0;\n while (true) {\n if (found >= variableValues.length) {\n break;\n }\n const idx = localisedText.indexOf('${variable}');\n if (idx === -1) {\n break;\n }\n localisedText = localisedText.replace('${variable}', variableValues[found++]);\n }\n }\n return localisedText !== null && localisedText !== void 0 ? localisedText : defaultValue;\n };\n }\n};\nLocaleService = __decorate([\n Bean('localeService')\n], LocaleService);\nexport { LocaleService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { PostConstruct } from \"../context/context.mjs\";\nimport { AbstractFakeScrollComp } from \"./abstractFakeScrollComp.mjs\";\nimport { isVisible, setFixedWidth } from \"../utils/dom.mjs\";\nimport { SetHeightFeature } from \"./rowContainer/setHeightFeature.mjs\";\nimport { Events } from \"../eventKeys.mjs\";\nexport class FakeVScrollComp extends AbstractFakeScrollComp {\n constructor() {\n super(FakeVScrollComp.TEMPLATE, 'vertical');\n }\n postConstruct() {\n super.postConstruct();\n this.createManagedBean(new SetHeightFeature(this.eContainer));\n this.ctrlsService.registerFakeVScrollComp(this);\n this.addManagedListener(this.eventService, Events.EVENT_ROW_CONTAINER_HEIGHT_CHANGED, this.onRowContainerHeightChanged.bind(this));\n }\n setScrollVisible() {\n const vScrollShowing = this.scrollVisibleService.isVerticalScrollShowing();\n const invisibleScrollbar = this.invisibleScrollbar;\n const scrollbarWidth = vScrollShowing ? (this.gridOptionsService.getScrollbarWidth() || 0) : 0;\n const adjustedScrollbarWidth = (scrollbarWidth === 0 && invisibleScrollbar) ? 16 : scrollbarWidth;\n this.addOrRemoveCssClass('ag-scrollbar-invisible', invisibleScrollbar);\n setFixedWidth(this.getGui(), adjustedScrollbarWidth);\n setFixedWidth(this.eViewport, adjustedScrollbarWidth);\n setFixedWidth(this.eContainer, adjustedScrollbarWidth);\n this.setDisplayed(vScrollShowing, { skipAriaHidden: true });\n }\n onRowContainerHeightChanged() {\n const gridBodyCtrl = this.ctrlsService.getGridBodyCtrl();\n const gridBodyViewportEl = gridBodyCtrl.getBodyViewportElement();\n if (this.eViewport.scrollTop != gridBodyViewportEl.scrollTop) {\n this.eViewport.scrollTop = gridBodyViewportEl.scrollTop;\n }\n }\n getScrollPosition() {\n return this.getViewport().scrollTop;\n }\n setScrollPosition(value) {\n if (!isVisible(this.getViewport())) {\n this.attemptSettingScrollPosition(value);\n }\n this.getViewport().scrollTop = value;\n }\n}\nFakeVScrollComp.TEMPLATE = `
\n
\n
\n
\n
`;\n__decorate([\n PostConstruct\n], FakeVScrollComp.prototype, \"postConstruct\", null);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Bean, PostConstruct } from '../context/context.mjs';\nimport { BeanStub } from '../context/beanStub.mjs';\nimport { Events } from '../eventKeys.mjs';\nimport { getValueUsingField } from '../utils/object.mjs';\nimport { ModuleRegistry } from '../modules/moduleRegistry.mjs';\nimport { ModuleNames } from '../modules/moduleNames.mjs';\nimport { Column } from '../entities/column.mjs';\nimport { doOnce } from '../utils/function.mjs';\nimport { KeyCode } from '../constants/keyCode.mjs';\nimport { exists, toStringOrNull } from '../utils/generic.mjs';\nimport { parseDateTimeFromString, serialiseDate } from '../utils/date.mjs';\nconst MONTH_LOCALE_TEXT = {\n january: 'January',\n february: 'February',\n march: 'March',\n april: 'April',\n may: 'May',\n june: 'June',\n july: 'July',\n august: 'August',\n september: 'September',\n october: 'October',\n november: 'November',\n december: 'December'\n};\nconst MONTH_KEYS = ['january', 'february', 'march', 'april', 'may', 'june', 'july', 'august', 'september', 'october', 'november', 'december'];\nlet DataTypeService = class DataTypeService extends BeanStub {\n constructor() {\n super(...arguments);\n this.dataTypeDefinitions = {};\n this.isWaitingForRowData = false;\n this.isColumnTypeOverrideInDataTypeDefinitions = false;\n // keep track of any column state updates whilst waiting for data types to be inferred\n this.columnStateUpdatesPendingInference = {};\n this.columnStateUpdateListenerDestroyFuncs = [];\n }\n init() {\n this.groupHideOpenParents = this.gridOptionsService.is('groupHideOpenParents');\n this.addManagedPropertyListener('groupHideOpenParents', () => {\n this.groupHideOpenParents = this.gridOptionsService.is('groupHideOpenParents');\n });\n this.processDataTypeDefinitions();\n this.addManagedPropertyListener('dataTypeDefinitions', () => {\n this.processDataTypeDefinitions();\n this.columnModel.recreateColumnDefs('gridOptionsChanged');\n });\n }\n processDataTypeDefinitions() {\n var _a;\n const defaultDataTypes = this.getDefaultDataTypes();\n this.dataTypeDefinitions = {};\n Object.entries(defaultDataTypes).forEach(([cellDataType, dataTypeDefinition]) => {\n this.dataTypeDefinitions[cellDataType] = Object.assign(Object.assign({}, dataTypeDefinition), { groupSafeValueFormatter: this.createGroupSafeValueFormatter(dataTypeDefinition) });\n });\n const dataTypeDefinitions = (_a = this.gridOptionsService.get('dataTypeDefinitions')) !== null && _a !== void 0 ? _a : {};\n this.dataTypeMatchers = {};\n Object.entries(dataTypeDefinitions).forEach(([cellDataType, dataTypeDefinition]) => {\n const mergedDataTypeDefinition = this.processDataTypeDefinition(dataTypeDefinition, dataTypeDefinitions, [cellDataType], defaultDataTypes);\n if (mergedDataTypeDefinition) {\n this.dataTypeDefinitions[cellDataType] = mergedDataTypeDefinition;\n if (dataTypeDefinition.dataTypeMatcher) {\n this.dataTypeMatchers[cellDataType] = dataTypeDefinition.dataTypeMatcher;\n }\n }\n });\n this.checkObjectValueHandlers(defaultDataTypes);\n ['dateString', 'text', 'number', 'boolean', 'date'].forEach((cellDataType) => {\n const overriddenDataTypeMatcher = this.dataTypeMatchers[cellDataType];\n if (overriddenDataTypeMatcher) {\n // remove to maintain correct ordering\n delete this.dataTypeMatchers[cellDataType];\n }\n this.dataTypeMatchers[cellDataType] = overriddenDataTypeMatcher !== null && overriddenDataTypeMatcher !== void 0 ? overriddenDataTypeMatcher : defaultDataTypes[cellDataType].dataTypeMatcher;\n });\n }\n mergeDataTypeDefinitions(parentDataTypeDefinition, childDataTypeDefinition) {\n const mergedDataTypeDefinition = Object.assign(Object.assign({}, parentDataTypeDefinition), childDataTypeDefinition);\n if (parentDataTypeDefinition.columnTypes &&\n childDataTypeDefinition.columnTypes &&\n childDataTypeDefinition.appendColumnTypes) {\n mergedDataTypeDefinition.columnTypes = [\n ...this.convertColumnTypes(parentDataTypeDefinition.columnTypes),\n ...this.convertColumnTypes(childDataTypeDefinition.columnTypes),\n ];\n }\n return mergedDataTypeDefinition;\n }\n processDataTypeDefinition(dataTypeDefinition, dataTypeDefinitions, alreadyProcessedDataTypes, defaultDataTypes) {\n let mergedDataTypeDefinition;\n const extendsCellDataType = dataTypeDefinition.extendsDataType;\n if (dataTypeDefinition.columnTypes) {\n this.isColumnTypeOverrideInDataTypeDefinitions = true;\n }\n if (dataTypeDefinition.extendsDataType === dataTypeDefinition.baseDataType) {\n const baseDataTypeDefinition = defaultDataTypes[extendsCellDataType];\n if (!this.validateDataTypeDefinition(dataTypeDefinition, baseDataTypeDefinition, extendsCellDataType)) {\n return undefined;\n }\n mergedDataTypeDefinition = this.mergeDataTypeDefinitions(baseDataTypeDefinition, dataTypeDefinition);\n }\n else {\n if (alreadyProcessedDataTypes.includes(extendsCellDataType)) {\n doOnce(() => console.warn('AG Grid: Data type definition hierarchies (via the \"extendsDataType\" property) cannot contain circular references.'), 'dataTypeExtendsCircularRef');\n return undefined;\n }\n const extendedDataTypeDefinition = dataTypeDefinitions[extendsCellDataType];\n if (!this.validateDataTypeDefinition(dataTypeDefinition, extendedDataTypeDefinition, extendsCellDataType)) {\n return undefined;\n }\n const mergedExtendedDataTypeDefinition = this.processDataTypeDefinition(extendedDataTypeDefinition, dataTypeDefinitions, [...alreadyProcessedDataTypes, extendsCellDataType], defaultDataTypes);\n if (!mergedExtendedDataTypeDefinition) {\n return undefined;\n }\n mergedDataTypeDefinition = this.mergeDataTypeDefinitions(mergedExtendedDataTypeDefinition, dataTypeDefinition);\n }\n return Object.assign(Object.assign({}, mergedDataTypeDefinition), { groupSafeValueFormatter: this.createGroupSafeValueFormatter(mergedDataTypeDefinition) });\n }\n validateDataTypeDefinition(dataTypeDefinition, parentDataTypeDefinition, parentCellDataType) {\n if (!parentDataTypeDefinition) {\n doOnce(() => console.warn(`AG Grid: The data type definition ${parentCellDataType} does not exist.`), 'dataTypeDefMissing' + parentCellDataType);\n return false;\n }\n if (parentDataTypeDefinition.baseDataType !== dataTypeDefinition.baseDataType) {\n doOnce(() => console.warn('AG Grid: The \"baseDataType\" property of a data type definition must match that of its parent.'), 'dataTypeBaseTypesMatch');\n return false;\n }\n return true;\n }\n createGroupSafeValueFormatter(dataTypeDefinition) {\n if (!dataTypeDefinition.valueFormatter) {\n return undefined;\n }\n return (params) => {\n var _a, _b;\n if ((_a = params.node) === null || _a === void 0 ? void 0 : _a.group) {\n const aggFunc = params.column.getAggFunc();\n if (aggFunc) {\n // the resulting type of these will be the same, so we call valueFormatter anyway\n if (aggFunc === 'first' || aggFunc === 'last') {\n return dataTypeDefinition.valueFormatter(params);\n }\n if (dataTypeDefinition.baseDataType === 'number' && aggFunc !== 'count') {\n if (typeof params.value === 'number') {\n return dataTypeDefinition.valueFormatter(params);\n }\n if (typeof params.value === 'object') {\n if (!params.value) {\n return undefined;\n }\n if ('toNumber' in params.value) {\n return dataTypeDefinition.valueFormatter(Object.assign(Object.assign({}, params), { value: params.value.toNumber() }));\n }\n if ('value' in params.value) {\n return dataTypeDefinition.valueFormatter(Object.assign(Object.assign({}, params), { value: params.value.value }));\n }\n }\n }\n }\n return undefined;\n }\n else if (this.groupHideOpenParents && params.column.isRowGroupActive()) {\n // `groupHideOpenParents` passes leaf values in the group column, so need to format still.\n // If it's not a string, we know it hasn't been formatted. Otherwise check the data type matcher.\n if (typeof params.value !== 'string' || ((_b = dataTypeDefinition.dataTypeMatcher) === null || _b === void 0 ? void 0 : _b.call(dataTypeDefinition, params.value))) {\n return dataTypeDefinition.valueFormatter(params);\n }\n return undefined;\n }\n return dataTypeDefinition.valueFormatter(params);\n };\n }\n updateColDefAndGetDataTypeDefinitionColumnType(colDef, userColDef, colId) {\n let { cellDataType } = userColDef;\n const { field } = userColDef;\n if (cellDataType === undefined) {\n cellDataType = colDef.cellDataType;\n }\n if ((cellDataType == null || cellDataType === true)) {\n cellDataType = this.canInferCellDataType(colDef, userColDef) ? this.inferCellDataType(field, colId) : false;\n }\n if (!cellDataType) {\n colDef.cellDataType = false;\n return undefined;\n }\n const dataTypeDefinition = this.dataTypeDefinitions[cellDataType];\n if (!dataTypeDefinition) {\n doOnce(() => console.warn(`AG Grid: Missing data type definition - \"${cellDataType}\"`), 'dataTypeMissing' + cellDataType);\n return undefined;\n }\n colDef.cellDataType = cellDataType;\n if (dataTypeDefinition.groupSafeValueFormatter) {\n colDef.valueFormatter = dataTypeDefinition.groupSafeValueFormatter;\n }\n if (dataTypeDefinition.valueParser) {\n colDef.valueParser = dataTypeDefinition.valueParser;\n }\n if (!dataTypeDefinition.suppressDefaultProperties) {\n this.setColDefPropertiesForBaseDataType(colDef, dataTypeDefinition, colId);\n }\n return dataTypeDefinition.columnTypes;\n }\n updateColDefAndGetColumnType(colDef, userColDef, colId) {\n var _a, _b;\n const dataTypeDefinitionColumnType = this.updateColDefAndGetDataTypeDefinitionColumnType(colDef, userColDef, colId);\n const columnTypes = (_b = (_a = userColDef.type) !== null && _a !== void 0 ? _a : dataTypeDefinitionColumnType) !== null && _b !== void 0 ? _b : colDef.type;\n colDef.type = columnTypes;\n return columnTypes ? this.convertColumnTypes(columnTypes) : undefined;\n }\n addColumnListeners(column) {\n if (!this.isWaitingForRowData) {\n return;\n }\n const columnStateUpdates = this.columnStateUpdatesPendingInference[column.getColId()];\n if (!columnStateUpdates) {\n return;\n }\n const columnListener = (event) => {\n columnStateUpdates.add(event.key);\n };\n column.addEventListener(Column.EVENT_STATE_UPDATED, columnListener);\n this.columnStateUpdateListenerDestroyFuncs.push(() => column.removeEventListener(Column.EVENT_STATE_UPDATED, columnListener));\n }\n canInferCellDataType(colDef, userColDef) {\n var _a;\n if (this.rowModel.getType() !== 'clientSide') {\n return false;\n }\n const propsToCheckForInference = { cellRenderer: true, valueGetter: true, valueParser: true, refData: true };\n if (this.doColDefPropsPreventInference(userColDef, propsToCheckForInference)) {\n return false;\n }\n const columnTypes = userColDef.type === null ? colDef.type : userColDef.type;\n if (columnTypes) {\n const columnTypeDefs = (_a = this.gridOptionsService.get('columnTypes')) !== null && _a !== void 0 ? _a : {};\n const hasPropsPreventingInference = this.convertColumnTypes(columnTypes).some(columnType => {\n const columnTypeDef = columnTypeDefs[columnType.trim()];\n return columnTypeDef && this.doColDefPropsPreventInference(columnTypeDef, propsToCheckForInference);\n });\n if (hasPropsPreventingInference) {\n return false;\n }\n }\n return !this.doColDefPropsPreventInference(colDef, propsToCheckForInference);\n }\n doColDefPropsPreventInference(colDef, propsToCheckForInference) {\n return [\n ['cellRenderer', 'agSparklineCellRenderer'], ['valueGetter', undefined], ['valueParser', undefined], ['refData', undefined]\n ].some(([prop, comparisonValue]) => this.doesColDefPropPreventInference(colDef, propsToCheckForInference, prop, comparisonValue));\n }\n doesColDefPropPreventInference(colDef, checkProps, prop, comparisonValue) {\n if (!checkProps[prop]) {\n return false;\n }\n const value = colDef[prop];\n if (value === null) {\n checkProps[prop] = false;\n return false;\n }\n else {\n return comparisonValue === undefined ? !!value : value === comparisonValue;\n }\n }\n inferCellDataType(field, colId) {\n var _a;\n if (!field) {\n return undefined;\n }\n let value;\n const initialData = this.getInitialData();\n if (initialData) {\n const fieldContainsDots = field.indexOf('.') >= 0 && !this.gridOptionsService.is('suppressFieldDotNotation');\n value = getValueUsingField(initialData, field, fieldContainsDots);\n }\n else {\n this.initWaitForRowData(colId);\n }\n if (value == null) {\n return undefined;\n }\n const [cellDataType] = (_a = Object.entries(this.dataTypeMatchers).find(([_cellDataType, dataTypeMatcher]) => dataTypeMatcher(value))) !== null && _a !== void 0 ? _a : ['object'];\n return cellDataType;\n }\n getInitialData() {\n const rowData = this.gridOptionsService.get('rowData');\n if (rowData === null || rowData === void 0 ? void 0 : rowData.length) {\n return rowData[0];\n }\n else if (this.initialData) {\n return this.initialData;\n }\n else {\n const rowNodes = this.rowModel\n .getRootNode()\n .allLeafChildren;\n if (rowNodes === null || rowNodes === void 0 ? void 0 : rowNodes.length) {\n return rowNodes[0].data;\n }\n }\n return null;\n }\n initWaitForRowData(colId) {\n this.columnStateUpdatesPendingInference[colId] = new Set();\n if (this.isWaitingForRowData) {\n return;\n }\n this.isWaitingForRowData = true;\n const columnTypeOverridesExist = this.isColumnTypeOverrideInDataTypeDefinitions;\n if (columnTypeOverridesExist) {\n this.columnModel.queueResizeOperations();\n }\n const destroyFunc = this.addManagedListener(this.eventService, Events.EVENT_ROW_DATA_UPDATE_STARTED, (event) => {\n const { firstRowData } = event;\n if (!firstRowData) {\n return;\n }\n destroyFunc === null || destroyFunc === void 0 ? void 0 : destroyFunc();\n this.isWaitingForRowData = false;\n this.processColumnsPendingInference(firstRowData, columnTypeOverridesExist);\n this.columnStateUpdatesPendingInference = {};\n if (columnTypeOverridesExist) {\n this.columnModel.processResizeOperations();\n }\n const dataTypesInferredEvent = {\n type: Events.EVENT_DATA_TYPES_INFERRED\n };\n this.eventService.dispatchEvent(dataTypesInferredEvent);\n });\n }\n isPendingInference() {\n return this.isWaitingForRowData;\n }\n processColumnsPendingInference(firstRowData, columnTypeOverridesExist) {\n this.initialData = firstRowData;\n const state = [];\n this.columnStateUpdateListenerDestroyFuncs.forEach(destroyFunc => destroyFunc());\n this.columnStateUpdateListenerDestroyFuncs = [];\n const newRowGroupColumnStateWithoutIndex = {};\n const newPivotColumnStateWithoutIndex = {};\n Object.entries(this.columnStateUpdatesPendingInference).forEach(([colId, columnStateUpdates]) => {\n const column = this.columnModel.getGridColumn(colId);\n if (!column) {\n return;\n }\n const oldColDef = column.getColDef();\n if (!this.columnModel.resetColumnDefIntoColumn(column)) {\n return;\n }\n const newColDef = column.getColDef();\n if (columnTypeOverridesExist && newColDef.type && newColDef.type !== oldColDef.type) {\n const updatedColumnState = this.getUpdatedColumnState(column, columnStateUpdates);\n if (updatedColumnState.rowGroup && updatedColumnState.rowGroupIndex == null) {\n newRowGroupColumnStateWithoutIndex[colId] = updatedColumnState;\n }\n if (updatedColumnState.pivot && updatedColumnState.pivotIndex == null) {\n newPivotColumnStateWithoutIndex[colId] = updatedColumnState;\n }\n state.push(updatedColumnState);\n }\n });\n if (columnTypeOverridesExist) {\n state.push(...this.columnModel.generateColumnStateForRowGroupAndPivotIndexes(newRowGroupColumnStateWithoutIndex, newPivotColumnStateWithoutIndex));\n }\n if (state.length) {\n this.columnModel.applyColumnState({ state }, 'cellDataTypeInferred');\n }\n this.initialData = null;\n }\n getUpdatedColumnState(column, columnStateUpdates) {\n const columnState = this.columnModel.getColumnStateFromColDef(column);\n columnStateUpdates.forEach(key => {\n // if the column state has been updated, don't update again\n delete columnState[key];\n if (key === 'rowGroup') {\n delete columnState.rowGroupIndex;\n }\n else if (key === 'pivot') {\n delete columnState.pivotIndex;\n }\n });\n return columnState;\n }\n checkObjectValueHandlers(defaultDataTypes) {\n const resolvedObjectDataTypeDefinition = this.dataTypeDefinitions.object;\n const defaultObjectDataTypeDefinition = defaultDataTypes.object;\n this.hasObjectValueParser = resolvedObjectDataTypeDefinition.valueParser !== defaultObjectDataTypeDefinition.valueParser;\n this.hasObjectValueFormatter = resolvedObjectDataTypeDefinition.valueFormatter !== defaultObjectDataTypeDefinition.valueFormatter;\n }\n convertColumnTypes(type) {\n let typeKeys = [];\n if (type instanceof Array) {\n const invalidArray = type.some((a) => typeof a !== 'string');\n if (invalidArray) {\n console.warn(\"AG Grid: if colDef.type is supplied an array it should be of type 'string[]'\");\n }\n else {\n typeKeys = type;\n }\n }\n else if (typeof type === 'string') {\n typeKeys = type.split(',');\n }\n else {\n console.warn(\"AG Grid: colDef.type should be of type 'string' | 'string[]'\");\n }\n return typeKeys;\n }\n getDateStringTypeDefinition() {\n return this.dataTypeDefinitions.dateString;\n }\n getDateParserFunction() {\n return this.getDateStringTypeDefinition().dateParser;\n }\n getDateFormatterFunction() {\n return this.getDateStringTypeDefinition().dateFormatter;\n }\n getDataTypeDefinition(column) {\n const colDef = column.getColDef();\n if (!colDef.cellDataType) {\n return undefined;\n }\n return this.dataTypeDefinitions[colDef.cellDataType];\n }\n getBaseDataType(column) {\n var _a;\n return (_a = this.getDataTypeDefinition(column)) === null || _a === void 0 ? void 0 : _a.baseDataType;\n }\n checkType(column, value) {\n var _a;\n if (value == null) {\n return true;\n }\n const dataTypeMatcher = (_a = this.getDataTypeDefinition(column)) === null || _a === void 0 ? void 0 : _a.dataTypeMatcher;\n if (!dataTypeMatcher) {\n return true;\n }\n return dataTypeMatcher(value);\n }\n validateColDef(colDef) {\n if (colDef.cellDataType === 'object') {\n if (colDef.valueFormatter === this.dataTypeDefinitions.object.groupSafeValueFormatter && !this.hasObjectValueFormatter) {\n doOnce(() => console.warn('AG Grid: Cell data type is \"object\" but no value formatter has been provided. Please either provide an object data type definition with a value formatter, or set \"colDef.valueFormatter\"'), 'dataTypeObjectValueFormatter');\n }\n if (colDef.editable && colDef.valueParser === this.dataTypeDefinitions.object.valueParser && !this.hasObjectValueParser) {\n doOnce(() => console.warn('AG Grid: Cell data type is \"object\" but no value parser has been provided. Please either provide an object data type definition with a value parser, or set \"colDef.valueParser\"'), 'dataTypeObjectValueParser');\n }\n }\n }\n setColDefPropertiesForBaseDataType(colDef, dataTypeDefinition, colId) {\n const formatValue = (column, node, value) => {\n let valueFormatter = column.getColDef().valueFormatter;\n if (valueFormatter === dataTypeDefinition.groupSafeValueFormatter) {\n valueFormatter = dataTypeDefinition.valueFormatter;\n }\n return this.valueFormatterService.formatValue(column, node, value, valueFormatter);\n };\n const usingSetFilter = ModuleRegistry.__isRegistered(ModuleNames.SetFilterModule, this.context.getGridId());\n const translate = this.localeService.getLocaleTextFunc();\n const mergeFilterParams = (params) => {\n const { filterParams } = colDef;\n colDef.filterParams = typeof filterParams === 'object' ? Object.assign(Object.assign({}, filterParams), params) : params;\n };\n colDef.useValueFormatterForExport = true;\n colDef.useValueParserForImport = true;\n switch (dataTypeDefinition.baseDataType) {\n case 'number': {\n colDef.cellEditor = 'agNumberCellEditor';\n if (usingSetFilter) {\n mergeFilterParams({\n comparator: (a, b) => {\n const valA = a == null ? 0 : parseInt(a);\n const valB = b == null ? 0 : parseInt(b);\n if (valA === valB)\n return 0;\n return valA > valB ? 1 : -1;\n },\n });\n }\n break;\n }\n case 'boolean': {\n colDef.cellEditor = 'agCheckboxCellEditor';\n colDef.cellRenderer = 'agCheckboxCellRenderer';\n colDef.suppressKeyboardEvent = (params) => !!params.colDef.editable && params.event.key === KeyCode.SPACE;\n if (usingSetFilter) {\n mergeFilterParams({\n valueFormatter: (params) => {\n if (!exists(params.value)) {\n return translate('blanks', '(Blanks)');\n }\n return translate(String(params.value), params.value ? 'True' : 'False');\n }\n });\n }\n else {\n mergeFilterParams({\n maxNumConditions: 1,\n filterOptions: [\n 'empty',\n {\n displayKey: 'true',\n displayName: 'True',\n predicate: (_filterValues, cellValue) => cellValue,\n numberOfInputs: 0,\n },\n {\n displayKey: 'false',\n displayName: 'False',\n predicate: (_filterValues, cellValue) => cellValue === false,\n numberOfInputs: 0,\n },\n ]\n });\n }\n break;\n }\n case 'date': {\n colDef.cellEditor = 'agDateCellEditor';\n colDef.keyCreator = (params) => formatValue(params.column, params.node, params.value);\n if (usingSetFilter) {\n mergeFilterParams({\n valueFormatter: (params) => {\n const valueFormatted = formatValue(params.column, params.node, params.value);\n return exists(valueFormatted) ? valueFormatted : translate('blanks', '(Blanks)');\n },\n treeList: true,\n treeListFormatter: (pathKey, level) => {\n if (level === 1 && pathKey != null) {\n const monthKey = MONTH_KEYS[Number(pathKey) - 1];\n return translate(monthKey, MONTH_LOCALE_TEXT[monthKey]);\n }\n return pathKey !== null && pathKey !== void 0 ? pathKey : translate('blanks', '(Blanks)');\n }\n });\n }\n break;\n }\n case 'dateString': {\n colDef.cellEditor = 'agDateStringCellEditor';\n colDef.keyCreator = (params) => formatValue(params.column, params.node, params.value);\n const convertToDate = this.getDateParserFunction();\n if (usingSetFilter) {\n mergeFilterParams({\n valueFormatter: (params) => {\n const valueFormatted = formatValue(params.column, params.node, params.value);\n return exists(valueFormatted) ? valueFormatted : translate('blanks', '(Blanks)');\n },\n treeList: true,\n treeListPathGetter: (value) => {\n const date = convertToDate(value !== null && value !== void 0 ? value : undefined);\n return date ? [String(date.getFullYear()), String(date.getMonth() + 1), String(date.getDate())] : null;\n },\n treeListFormatter: (pathKey, level) => {\n if (level === 1 && pathKey != null) {\n const monthKey = MONTH_KEYS[Number(pathKey) - 1];\n return translate(monthKey, MONTH_LOCALE_TEXT[monthKey]);\n }\n return pathKey !== null && pathKey !== void 0 ? pathKey : translate('blanks', '(Blanks)');\n }\n });\n }\n else {\n mergeFilterParams({\n comparator: (filterDate, cellValue) => {\n const cellAsDate = convertToDate(cellValue);\n if (cellValue == null || cellAsDate < filterDate) {\n return -1;\n }\n if (cellAsDate > filterDate) {\n return 1;\n }\n return 0;\n }\n });\n }\n break;\n }\n case 'object': {\n colDef.cellEditorParams = {\n useFormatter: true,\n };\n colDef.comparator = (a, b) => {\n const column = this.columnModel.getPrimaryColumn(colId);\n const colDef = column === null || column === void 0 ? void 0 : column.getColDef();\n if (!column || !colDef) {\n return 0;\n }\n const valA = a == null ? '' : formatValue(column, null, a);\n const valB = b == null ? '' : formatValue(column, null, b);\n if (valA === valB)\n return 0;\n return valA > valB ? 1 : -1;\n };\n colDef.keyCreator = (params) => formatValue(params.column, params.node, params.value);\n if (usingSetFilter) {\n mergeFilterParams({\n valueFormatter: (params) => {\n const valueFormatted = formatValue(params.column, params.node, params.value);\n return exists(valueFormatted) ? valueFormatted : translate('blanks', '(Blanks)');\n }\n });\n }\n else {\n colDef.filterValueGetter = (params) => formatValue(params.column, params.node, this.valueService.getValue(params.column, params.node));\n }\n break;\n }\n }\n }\n getDefaultDataTypes() {\n const defaultDateFormatMatcher = (value) => !!value.match('^\\\\d{4}-\\\\d{2}-\\\\d{2}$');\n const translate = this.localeService.getLocaleTextFunc();\n return {\n number: {\n baseDataType: 'number',\n valueParser: (params) => params.newValue === '' ? null : Number(params.newValue),\n valueFormatter: (params) => {\n if (params.value == null) {\n return '';\n }\n if (typeof params.value !== 'number' || isNaN(params.value)) {\n return translate('invalidNumber', 'Invalid Number');\n }\n return String(params.value);\n },\n dataTypeMatcher: (value) => typeof value === 'number',\n },\n text: {\n baseDataType: 'text',\n valueParser: (params) => params.newValue === '' ? null : toStringOrNull(params.newValue),\n dataTypeMatcher: (value) => typeof value === 'string',\n },\n boolean: {\n baseDataType: 'boolean',\n valueParser: (params) => params.newValue === '' ? null : String(params.newValue).toLowerCase() === 'true',\n valueFormatter: (params) => params.value == null ? '' : String(params.value),\n dataTypeMatcher: (value) => typeof value === 'boolean',\n },\n date: {\n baseDataType: 'date',\n valueParser: (params) => parseDateTimeFromString(params.newValue == null ? null : String(params.newValue)),\n valueFormatter: (params) => {\n var _a;\n if (params.value == null) {\n return '';\n }\n if (!(params.value instanceof Date) || isNaN(params.value.getTime())) {\n return translate('invalidDate', 'Invalid Date');\n }\n return (_a = serialiseDate(params.value, false)) !== null && _a !== void 0 ? _a : '';\n },\n dataTypeMatcher: (value) => value instanceof Date,\n },\n dateString: {\n baseDataType: 'dateString',\n dateParser: (value) => { var _a; return (_a = parseDateTimeFromString(value)) !== null && _a !== void 0 ? _a : undefined; },\n dateFormatter: (value) => { var _a; return (_a = serialiseDate(value !== null && value !== void 0 ? value : null, false)) !== null && _a !== void 0 ? _a : undefined; },\n valueParser: (params) => defaultDateFormatMatcher(String(params.newValue)) ? params.newValue : null,\n valueFormatter: (params) => defaultDateFormatMatcher(String(params.value)) ? params.value : '',\n dataTypeMatcher: (value) => typeof value === 'string' && defaultDateFormatMatcher(value),\n },\n object: {\n baseDataType: 'object',\n valueParser: () => null,\n valueFormatter: (params) => { var _a; return (_a = toStringOrNull(params.value)) !== null && _a !== void 0 ? _a : ''; },\n }\n };\n }\n};\n__decorate([\n Autowired('rowModel')\n], DataTypeService.prototype, \"rowModel\", void 0);\n__decorate([\n Autowired('columnModel')\n], DataTypeService.prototype, \"columnModel\", void 0);\n__decorate([\n Autowired('columnUtils')\n], DataTypeService.prototype, \"columnUtils\", void 0);\n__decorate([\n Autowired('valueService')\n], DataTypeService.prototype, \"valueService\", void 0);\n__decorate([\n Autowired('valueFormatterService')\n], DataTypeService.prototype, \"valueFormatterService\", void 0);\n__decorate([\n PostConstruct\n], DataTypeService.prototype, \"init\", null);\nDataTypeService = __decorate([\n Bean('dataTypeService')\n], DataTypeService);\nexport { DataTypeService };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean, Autowired } from '../context/context.mjs';\nimport { BeanStub } from '../context/beanStub.mjs';\nimport { exists } from '../utils/generic.mjs';\nlet ValueParserService = class ValueParserService extends BeanStub {\n parseValue(column, rowNode, newValue, oldValue) {\n const colDef = column.getColDef();\n const params = {\n node: rowNode,\n data: rowNode === null || rowNode === void 0 ? void 0 : rowNode.data,\n oldValue,\n newValue,\n colDef,\n column,\n api: this.gridOptionsService.api,\n columnApi: this.gridOptionsService.columnApi,\n context: this.gridOptionsService.context\n };\n const valueParser = colDef.valueParser;\n if (exists(valueParser)) {\n if (typeof valueParser === 'function') {\n return valueParser(params);\n }\n return this.expressionService.evaluate(valueParser, params);\n }\n return newValue;\n }\n};\n__decorate([\n Autowired('expressionService')\n], ValueParserService.prototype, \"expressionService\", void 0);\nValueParserService = __decorate([\n Bean('valueParserService')\n], ValueParserService);\nexport { ValueParserService };\n","import { SelectionService } from \"./selectionService.mjs\";\nimport { ColumnApi } from \"./columns/columnApi.mjs\";\nimport { ColumnModel } from \"./columns/columnModel.mjs\";\nimport { RowRenderer } from \"./rendering/rowRenderer.mjs\";\nimport { GridHeaderComp } from \"./headerRendering/gridHeaderComp.mjs\";\nimport { FilterManager } from \"./filter/filterManager.mjs\";\nimport { ValueService } from \"./valueService/valueService.mjs\";\nimport { EventService } from \"./eventService.mjs\";\nimport { GridBodyComp } from \"./gridBodyComp/gridBodyComp.mjs\";\nimport { GridApi } from \"./gridApi.mjs\";\nimport { ColumnFactory } from \"./columns/columnFactory.mjs\";\nimport { DisplayedGroupCreator } from \"./columns/displayedGroupCreator.mjs\";\nimport { ExpressionService } from \"./valueService/expressionService.mjs\";\nimport { TemplateService } from \"./templateService.mjs\";\nimport { PopupService } from \"./widgets/popupService.mjs\";\nimport { Logger, LoggerFactory } from \"./logger.mjs\";\nimport { ColumnUtils } from \"./columns/columnUtils.mjs\";\nimport { AutoWidthCalculator } from \"./rendering/autoWidthCalculator.mjs\";\nimport { HorizontalResizeService } from \"./headerRendering/common/horizontalResizeService.mjs\";\nimport { Context } from \"./context/context.mjs\";\nimport { GridComp } from \"./gridComp/gridComp.mjs\";\nimport { DragAndDropService } from \"./dragAndDrop/dragAndDropService.mjs\";\nimport { DragService } from \"./dragAndDrop/dragService.mjs\";\nimport { SortController } from \"./sortController.mjs\";\nimport { FocusService } from \"./focusService.mjs\";\nimport { MouseEventService } from \"./gridBodyComp/mouseEventService.mjs\";\nimport { CellNavigationService } from \"./cellNavigationService.mjs\";\nimport { Events } from \"./events.mjs\";\nimport { ValueFormatterService } from \"./rendering/valueFormatterService.mjs\";\nimport { AgCheckbox } from \"./widgets/agCheckbox.mjs\";\nimport { AgRadioButton } from \"./widgets/agRadioButton.mjs\";\nimport { VanillaFrameworkOverrides } from \"./vanillaFrameworkOverrides.mjs\";\nimport { ScrollVisibleService } from \"./gridBodyComp/scrollVisibleService.mjs\";\nimport { StylingService } from \"./styling/stylingService.mjs\";\nimport { ColumnHoverService } from \"./rendering/columnHoverService.mjs\";\nimport { ColumnAnimationService } from \"./rendering/columnAnimationService.mjs\";\nimport { AutoGroupColService } from \"./columns/autoGroupColService.mjs\";\nimport { PaginationProxy } from \"./pagination/paginationProxy.mjs\";\nimport { PaginationAutoPageSizeService } from \"./pagination/paginationAutoPageSizeService.mjs\";\nimport { ValueCache } from \"./valueService/valueCache.mjs\";\nimport { ChangeDetectionService } from \"./valueService/changeDetectionService.mjs\";\nimport { AlignedGridsService } from \"./alignedGridsService.mjs\";\nimport { UserComponentFactory } from \"./components/framework/userComponentFactory.mjs\";\nimport { UserComponentRegistry } from \"./components/framework/userComponentRegistry.mjs\";\nimport { AgComponentUtils } from \"./components/framework/agComponentUtils.mjs\";\nimport { ComponentMetadataProvider } from \"./components/framework/componentMetadataProvider.mjs\";\nimport { Beans } from \"./rendering/beans.mjs\";\nimport { Environment } from \"./environment.mjs\";\nimport { AnimationFrameService } from \"./misc/animationFrameService.mjs\";\nimport { NavigationService } from \"./gridBodyComp/navigationService.mjs\";\nimport { RowContainerHeightService } from \"./rendering/rowContainerHeightService.mjs\";\nimport { SelectableService } from \"./rowNodes/selectableService.mjs\";\nimport { PaginationComp } from \"./pagination/paginationComp.mjs\";\nimport { ResizeObserverService } from \"./misc/resizeObserverService.mjs\";\nimport { OverlayWrapperComponent } from \"./rendering/overlays/overlayWrapperComponent.mjs\";\nimport { AgGroupComponent } from \"./widgets/agGroupComponent.mjs\";\nimport { AgDialog } from \"./widgets/agDialog.mjs\";\nimport { AgPanel } from \"./widgets/agPanel.mjs\";\nimport { AgInputTextField } from \"./widgets/agInputTextField.mjs\";\nimport { AgInputTextArea } from \"./widgets/agInputTextArea.mjs\";\nimport { AgSlider } from \"./widgets/agSlider.mjs\";\nimport { AgInputNumberField } from \"./widgets/agInputNumberField.mjs\";\nimport { AgInputRange } from \"./widgets/agInputRange.mjs\";\nimport { AgSelect } from \"./widgets/agSelect.mjs\";\nimport { AgRichSelect } from \"./widgets/agRichSelect.mjs\";\nimport { AgToggleButton } from \"./widgets/agToggleButton.mjs\";\nimport { RowPositionUtils } from \"./entities/rowPositionUtils.mjs\";\nimport { CellPositionUtils } from \"./entities/cellPositionUtils.mjs\";\nimport { PinnedRowModel } from \"./pinnedRowModel/pinnedRowModel.mjs\";\nimport { ModuleRegistry } from \"./modules/moduleRegistry.mjs\";\nimport { ModuleNames } from \"./modules/moduleNames.mjs\";\nimport { UndoRedoService } from \"./undoRedo/undoRedoService.mjs\";\nimport { AgStackComponentsRegistry } from \"./components/agStackComponentsRegistry.mjs\";\nimport { HeaderPositionUtils } from \"./headerRendering/common/headerPosition.mjs\";\nimport { HeaderNavigationService } from \"./headerRendering/common/headerNavigationService.mjs\";\nimport { missing } from \"./utils/generic.mjs\";\nimport { ColumnDefFactory } from \"./columns/columnDefFactory.mjs\";\nimport { RowCssClassCalculator } from \"./rendering/row/rowCssClassCalculator.mjs\";\nimport { RowNodeBlockLoader } from \"./rowNodeCache/rowNodeBlockLoader.mjs\";\nimport { RowNodeSorter } from \"./rowNodes/rowNodeSorter.mjs\";\nimport { CtrlsService } from \"./ctrlsService.mjs\";\nimport { CtrlsFactory } from \"./ctrlsFactory.mjs\";\nimport { FakeHScrollComp } from \"./gridBodyComp/fakeHScrollComp.mjs\";\nimport { PinnedWidthService } from \"./gridBodyComp/pinnedWidthService.mjs\";\nimport { RowContainerComp } from \"./gridBodyComp/rowContainer/rowContainerComp.mjs\";\nimport { RowNodeEventThrottle } from \"./entities/rowNodeEventThrottle.mjs\";\nimport { StandardMenuFactory } from \"./headerRendering/cells/column/standardMenu.mjs\";\nimport { SortIndicatorComp } from \"./headerRendering/cells/column/sortIndicatorComp.mjs\";\nimport { GridOptionsService } from \"./gridOptionsService.mjs\";\nimport { LocaleService } from \"./localeService.mjs\";\nimport { GridOptionsValidator } from \"./gridOptionsValidator.mjs\";\nimport { FakeVScrollComp } from \"./gridBodyComp/fakeVScrollComp.mjs\";\nimport { DataTypeService } from \"./columns/dataTypeService.mjs\";\nimport { AgInputDateField } from \"./widgets/agInputDateField.mjs\";\nimport { ValueParserService } from \"./valueService/valueParserService.mjs\";\nimport { AgAutocomplete } from \"./widgets/agAutocomplete.mjs\";\nimport { QuickFilterService } from \"./filter/quickFilterService.mjs\";\n// creates JavaScript vanilla Grid, including JavaScript (ag-stack) components, which can\n// be wrapped by the framework wrappers\nexport class Grid {\n constructor(eGridDiv, gridOptions, params) {\n if (!gridOptions) {\n console.error('AG Grid: no gridOptions provided to the grid');\n return;\n }\n this.gridOptions = gridOptions;\n new GridCoreCreator().create(eGridDiv, gridOptions, context => {\n const gridComp = new GridComp(eGridDiv);\n context.createBean(gridComp);\n }, undefined, params);\n }\n destroy() {\n if (this.gridOptions && this.gridOptions.api) {\n this.gridOptions.api.destroy();\n }\n }\n}\nlet nextGridId = 1;\n// creates services of grid only, no UI, so frameworks can use this if providing\n// their own UI\nexport class GridCoreCreator {\n create(eGridDiv, gridOptions, createUi, acceptChanges, params) {\n var _a;\n const debug = !!gridOptions.debug;\n const gridId = (_a = gridOptions.gridId) !== null && _a !== void 0 ? _a : String(nextGridId++);\n const registeredModules = this.getRegisteredModules(params, gridId);\n const beanClasses = this.createBeansList(gridOptions.rowModelType, registeredModules, gridId);\n const providedBeanInstances = this.createProvidedBeans(eGridDiv, gridOptions, params);\n if (!beanClasses) {\n return;\n } // happens when no row model found\n const contextParams = {\n providedBeanInstances: providedBeanInstances,\n beanClasses: beanClasses,\n debug: debug,\n gridId: gridId,\n };\n const logger = new Logger('AG Grid', () => gridOptions.debug);\n const contextLogger = new Logger('Context', () => contextParams.debug);\n const context = new Context(contextParams, contextLogger);\n const beans = context.getBean('beans');\n this.registerModuleUserComponents(beans, registeredModules);\n this.registerStackComponents(beans, registeredModules);\n this.registerControllers(beans, registeredModules);\n createUi(context);\n // we wait until the UI has finished initialising before setting in columns and rows\n beans.ctrlsService.whenReady(() => {\n this.setColumnsAndData(beans);\n this.dispatchGridReadyEvent(beans);\n const isEnterprise = ModuleRegistry.__isRegistered(ModuleNames.EnterpriseCoreModule, gridId);\n logger.log(`initialised successfully, enterprise = ${isEnterprise}`);\n });\n if (acceptChanges) {\n acceptChanges(context);\n }\n }\n registerControllers(beans, registeredModules) {\n registeredModules.forEach(module => {\n if (module.controllers) {\n module.controllers.forEach(meta => beans.ctrlsFactory.register(meta));\n }\n });\n }\n registerStackComponents(beans, registeredModules) {\n const agStackComponents = this.createAgStackComponentsList(registeredModules);\n beans.agStackComponentsRegistry.setupComponents(agStackComponents);\n }\n getRegisteredModules(params, gridId) {\n const passedViaConstructor = params ? params.modules : null;\n const registered = ModuleRegistry.__getRegisteredModules(gridId);\n const allModules = [];\n const mapNames = {};\n // adds to list and removes duplicates\n const addModule = (moduleBased, mod, gridId) => {\n const addIndividualModule = (currentModule) => {\n if (!mapNames[currentModule.moduleName]) {\n mapNames[currentModule.moduleName] = true;\n allModules.push(currentModule);\n ModuleRegistry.__register(currentModule, moduleBased, gridId);\n }\n };\n addIndividualModule(mod);\n if (mod.dependantModules) {\n mod.dependantModules.forEach(m => addModule(moduleBased, m, gridId));\n }\n };\n if (passedViaConstructor) {\n passedViaConstructor.forEach(m => addModule(true, m, gridId));\n }\n if (registered) {\n registered.forEach(m => addModule(!ModuleRegistry.__isPackageBased(), m, undefined));\n }\n return allModules;\n }\n registerModuleUserComponents(beans, registeredModules) {\n const moduleUserComps = this.extractModuleEntity(registeredModules, (module) => module.userComponents ? module.userComponents : []);\n moduleUserComps.forEach(compMeta => {\n beans.userComponentRegistry.registerDefaultComponent(compMeta.componentName, compMeta.componentClass);\n });\n }\n createProvidedBeans(eGridDiv, gridOptions, params) {\n let frameworkOverrides = params ? params.frameworkOverrides : null;\n if (missing(frameworkOverrides)) {\n frameworkOverrides = new VanillaFrameworkOverrides();\n }\n const seed = {\n gridOptions: gridOptions,\n eGridDiv: eGridDiv,\n globalEventListener: params ? params.globalEventListener : null,\n globalSyncEventListener: params ? params.globalSyncEventListener : null,\n frameworkOverrides: frameworkOverrides\n };\n if (params && params.providedBeanInstances) {\n Object.assign(seed, params.providedBeanInstances);\n }\n return seed;\n }\n createAgStackComponentsList(registeredModules) {\n let components = [\n { componentName: 'AgCheckbox', componentClass: AgCheckbox },\n { componentName: 'AgRadioButton', componentClass: AgRadioButton },\n { componentName: 'AgToggleButton', componentClass: AgToggleButton },\n { componentName: 'AgInputTextField', componentClass: AgInputTextField },\n { componentName: 'AgInputTextArea', componentClass: AgInputTextArea },\n { componentName: 'AgInputNumberField', componentClass: AgInputNumberField },\n { componentName: 'AgInputDateField', componentClass: AgInputDateField },\n { componentName: 'AgInputRange', componentClass: AgInputRange },\n { componentName: 'AgRichSelect', componentClass: AgRichSelect },\n { componentName: 'AgSelect', componentClass: AgSelect },\n { componentName: 'AgSlider', componentClass: AgSlider },\n { componentName: 'AgGridBody', componentClass: GridBodyComp },\n { componentName: 'AgHeaderRoot', componentClass: GridHeaderComp },\n { componentName: 'AgSortIndicator', componentClass: SortIndicatorComp },\n { componentName: 'AgPagination', componentClass: PaginationComp },\n { componentName: 'AgOverlayWrapper', componentClass: OverlayWrapperComponent },\n { componentName: 'AgGroupComponent', componentClass: AgGroupComponent },\n { componentName: 'AgPanel', componentClass: AgPanel },\n { componentName: 'AgDialog', componentClass: AgDialog },\n { componentName: 'AgRowContainer', componentClass: RowContainerComp },\n { componentName: 'AgFakeHorizontalScroll', componentClass: FakeHScrollComp },\n { componentName: 'AgFakeVerticalScroll', componentClass: FakeVScrollComp },\n { componentName: 'AgAutocomplete', componentClass: AgAutocomplete },\n ];\n const moduleAgStackComps = this.extractModuleEntity(registeredModules, (module) => module.agStackComponents ? module.agStackComponents : []);\n components = components.concat(moduleAgStackComps);\n return components;\n }\n createBeansList(rowModelType = 'clientSide', registeredModules, gridId) {\n // only load beans matching the required row model\n const rowModelModules = registeredModules.filter(module => !module.rowModel || module.rowModel === rowModelType);\n // assert that the relevant module has been loaded\n const rowModelModuleNames = {\n clientSide: ModuleNames.ClientSideRowModelModule,\n infinite: ModuleNames.InfiniteRowModelModule,\n serverSide: ModuleNames.ServerSideRowModelModule,\n viewport: ModuleNames.ViewportRowModelModule\n };\n if (!rowModelModuleNames[rowModelType]) {\n console.error('AG Grid: could not find row model for rowModelType = ' + rowModelType);\n return;\n }\n if (!ModuleRegistry.__assertRegistered(rowModelModuleNames[rowModelType], `rowModelType = '${rowModelType}'`, gridId)) {\n return;\n }\n // beans should only contain SERVICES, it should NEVER contain COMPONENTS\n const beans = [\n Beans, RowPositionUtils, CellPositionUtils, HeaderPositionUtils,\n PaginationAutoPageSizeService, GridApi, UserComponentRegistry, AgComponentUtils,\n ComponentMetadataProvider, ResizeObserverService, UserComponentFactory,\n RowContainerHeightService, HorizontalResizeService, LocaleService, GridOptionsValidator,\n PinnedRowModel, DragService, DisplayedGroupCreator, EventService, GridOptionsService,\n PopupService, SelectionService, FilterManager, ColumnModel, HeaderNavigationService,\n PaginationProxy, RowRenderer, ExpressionService, ColumnFactory, TemplateService,\n AlignedGridsService, NavigationService, ValueCache, ValueService, LoggerFactory,\n ColumnUtils, AutoWidthCalculator, StandardMenuFactory, DragAndDropService, ColumnApi,\n FocusService, MouseEventService, Environment, CellNavigationService, ValueFormatterService,\n StylingService, ScrollVisibleService, SortController, ColumnHoverService, ColumnAnimationService,\n SelectableService, AutoGroupColService, ChangeDetectionService, AnimationFrameService,\n UndoRedoService, AgStackComponentsRegistry, ColumnDefFactory,\n RowCssClassCalculator, RowNodeBlockLoader, RowNodeSorter, CtrlsService,\n PinnedWidthService, RowNodeEventThrottle, CtrlsFactory, DataTypeService, ValueParserService,\n QuickFilterService\n ];\n const moduleBeans = this.extractModuleEntity(rowModelModules, (module) => module.beans ? module.beans : []);\n beans.push(...moduleBeans);\n // check for duplicates, as different modules could include the same beans that\n // they depend on, eg ClientSideRowModel in enterprise, and ClientSideRowModel in community\n const beansNoDuplicates = [];\n beans.forEach(bean => {\n if (beansNoDuplicates.indexOf(bean) < 0) {\n beansNoDuplicates.push(bean);\n }\n });\n return beansNoDuplicates;\n }\n extractModuleEntity(moduleEntities, extractor) {\n return [].concat(...moduleEntities.map(extractor));\n }\n setColumnsAndData(beans) {\n const columnDefs = beans.gridOptionsService.get('columnDefs');\n beans.columnModel.setColumnDefs(columnDefs || [], \"gridInitializing\");\n beans.rowModel.start();\n }\n dispatchGridReadyEvent(beans) {\n const readyEvent = {\n type: Events.EVENT_GRID_READY,\n };\n beans.eventService.dispatchEvent(readyEvent);\n }\n}\n","export var BarColumnLabelPlacement;\n(function (BarColumnLabelPlacement) {\n BarColumnLabelPlacement[\"InsideBase\"] = \"insideBase\";\n BarColumnLabelPlacement[\"InsideEnd\"] = \"insideEnd\";\n BarColumnLabelPlacement[\"Center\"] = \"center\";\n BarColumnLabelPlacement[\"OutsideEnd\"] = \"outsideEnd\";\n})(BarColumnLabelPlacement || (BarColumnLabelPlacement = {}));\n","/**\n * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / Typescript / React / Angular / Vue\n * @version v30.2.1\n * @link https://www.ag-grid.com/\n * @license MIT\n */\nconst globalObj = typeof global === 'undefined' ? {} : global;\nglobalObj.HTMLElement = typeof HTMLElement === 'undefined' ? {} : HTMLElement;\nglobalObj.HTMLButtonElement = typeof HTMLButtonElement === 'undefined' ? {} : HTMLButtonElement;\nglobalObj.HTMLSelectElement = typeof HTMLSelectElement === 'undefined' ? {} : HTMLSelectElement;\nglobalObj.HTMLInputElement = typeof HTMLInputElement === 'undefined' ? {} : HTMLInputElement;\nglobalObj.Node = typeof Node === 'undefined' ? {} : Node;\nglobalObj.MouseEvent = typeof MouseEvent === 'undefined' ? {} : MouseEvent;\n// columns\nexport { ColumnFactory } from \"./columns/columnFactory.mjs\";\nexport { ColumnModel } from \"./columns/columnModel.mjs\";\nexport { ColumnKeyCreator } from \"./columns/columnKeyCreator.mjs\";\nexport { ColumnUtils } from \"./columns/columnUtils.mjs\";\nexport { DisplayedGroupCreator } from \"./columns/displayedGroupCreator.mjs\";\nexport { GroupInstanceIdCreator } from \"./columns/groupInstanceIdCreator.mjs\";\nexport { GROUP_AUTO_COLUMN_ID } from \"./columns/autoGroupColService.mjs\";\n// components\nexport { ComponentUtil } from \"./components/componentUtil.mjs\";\nexport { AgStackComponentsRegistry } from \"./components/agStackComponentsRegistry.mjs\";\nexport { UserComponentRegistry } from \"./components/framework/userComponentRegistry.mjs\";\nexport { UserComponentFactory } from \"./components/framework/userComponentFactory.mjs\";\nexport { ColDefUtil } from \"./components/colDefUtil.mjs\";\n// context\nexport { BeanStub } from \"./context/beanStub.mjs\";\nexport { Context, Autowired, PostConstruct, PreConstruct, Optional, Bean, Qualifier, PreDestroy } from \"./context/context.mjs\";\nexport { QuerySelector, RefSelector } from \"./widgets/componentAnnotations.mjs\";\n// excel\nexport { ExcelFactoryMode } from \"./interfaces/iExcelCreator.mjs\";\n// dragAndDrop\nexport { DragAndDropService, DragSourceType, HorizontalDirection, VerticalDirection } from \"./dragAndDrop/dragAndDropService.mjs\";\nexport { DragService } from \"./dragAndDrop/dragService.mjs\";\nexport { VirtualListDragFeature } from \"./dragAndDrop/virtualListDragFeature.mjs\";\n// entities\nexport { Column } from \"./entities/column.mjs\";\nexport { ColumnGroup } from \"./entities/columnGroup.mjs\";\nexport { ProvidedColumnGroup } from \"./entities/providedColumnGroup.mjs\";\nexport { RowNode } from \"./entities/rowNode.mjs\";\nexport { RowHighlightPosition } from \"./interfaces/iRowNode.mjs\";\nexport { FilterManager } from \"./filter/filterManager.mjs\";\nexport { ProvidedFilter } from \"./filter/provided/providedFilter.mjs\";\nexport { SimpleFilter } from \"./filter/provided/simpleFilter.mjs\";\nexport { ScalarFilter } from \"./filter/provided/scalarFilter.mjs\";\nexport { NumberFilter } from \"./filter/provided/number/numberFilter.mjs\";\nexport { TextFilter } from \"./filter/provided/text/textFilter.mjs\";\nexport { DateFilter } from \"./filter/provided/date/dateFilter.mjs\";\nexport { TextFloatingFilter } from './filter/provided/text/textFloatingFilter.mjs';\nexport { HeaderFilterCellComp } from './headerRendering/cells/floatingFilter/headerFilterCellComp.mjs';\nexport { FloatingFilterMapper } from './filter/floating/floatingFilterMapper.mjs';\n// gridPanel\nexport { GridBodyComp } from \"./gridBodyComp/gridBodyComp.mjs\";\nexport { GridBodyCtrl, RowAnimationCssClasses } from \"./gridBodyComp/gridBodyCtrl.mjs\";\nexport { ScrollVisibleService } from \"./gridBodyComp/scrollVisibleService.mjs\";\nexport { MouseEventService } from \"./gridBodyComp/mouseEventService.mjs\";\nexport { NavigationService } from \"./gridBodyComp/navigationService.mjs\";\n// rowContainer\nexport { RowContainerComp } from \"./gridBodyComp/rowContainer/rowContainerComp.mjs\";\nexport { RowContainerName, RowContainerCtrl, RowContainerType, getRowContainerTypeForName } from \"./gridBodyComp/rowContainer/rowContainerCtrl.mjs\";\n// headerRendering\nexport { BodyDropPivotTarget } from \"./headerRendering/columnDrag/bodyDropPivotTarget.mjs\";\nexport { BodyDropTarget } from \"./headerRendering/columnDrag/bodyDropTarget.mjs\";\nexport { CssClassApplier } from \"./headerRendering/cells/cssClassApplier.mjs\";\nexport { HeaderRowContainerComp } from \"./headerRendering/rowContainer/headerRowContainerComp.mjs\";\nexport { GridHeaderComp } from \"./headerRendering/gridHeaderComp.mjs\";\nexport { GridHeaderCtrl } from \"./headerRendering/gridHeaderCtrl.mjs\";\nexport { HeaderRowComp, HeaderRowType } from \"./headerRendering/row/headerRowComp.mjs\";\nexport { HeaderRowCtrl } from \"./headerRendering/row/headerRowCtrl.mjs\";\nexport { HeaderCellCtrl } from \"./headerRendering/cells/column/headerCellCtrl.mjs\";\nexport { SortIndicatorComp } from \"./headerRendering/cells/column/sortIndicatorComp.mjs\";\nexport { HeaderFilterCellCtrl } from \"./headerRendering/cells/floatingFilter/headerFilterCellCtrl.mjs\";\nexport { HeaderGroupCellCtrl } from \"./headerRendering/cells/columnGroup/headerGroupCellCtrl.mjs\";\nexport { AbstractHeaderCellCtrl } from \"./headerRendering/cells/abstractCell/abstractHeaderCellCtrl.mjs\";\nexport { HeaderRowContainerCtrl } from \"./headerRendering/rowContainer/headerRowContainerCtrl.mjs\";\nexport { HorizontalResizeService } from \"./headerRendering/common/horizontalResizeService.mjs\";\nexport { MoveColumnFeature } from \"./headerRendering/columnDrag/moveColumnFeature.mjs\";\nexport { StandardMenuFactory } from \"./headerRendering/cells/column/standardMenu.mjs\";\n// layout\nexport { TabbedLayout } from \"./layout/tabbedLayout.mjs\";\n// misc\nexport { simpleHttpRequest } from \"./misc/simpleHttpRequest.mjs\";\nexport { ResizeObserverService } from \"./misc/resizeObserverService.mjs\";\nexport { AnimationFrameService } from \"./misc/animationFrameService.mjs\";\nexport { LargeTextCellEditor } from \"./rendering/cellEditors/largeTextCellEditor.mjs\";\nexport { PopupEditorWrapper } from \"./rendering/cellEditors/popupEditorWrapper.mjs\";\nexport { SelectCellEditor } from \"./rendering/cellEditors/selectCellEditor.mjs\";\nexport { TextCellEditor } from \"./rendering/cellEditors/textCellEditor.mjs\";\nexport { NumberCellEditor } from \"./rendering/cellEditors/numberCellEditor.mjs\";\nexport { DateCellEditor } from \"./rendering/cellEditors/dateCellEditor.mjs\";\nexport { DateStringCellEditor } from \"./rendering/cellEditors/dateStringCellEditor.mjs\";\nexport { CheckboxCellEditor } from \"./rendering/cellEditors/checkboxCellEditor.mjs\";\n// rendering / cellRenderers\nexport { Beans } from \"./rendering/beans.mjs\";\nexport { AnimateShowChangeCellRenderer } from \"./rendering/cellRenderers/animateShowChangeCellRenderer.mjs\";\nexport { AnimateSlideCellRenderer } from \"./rendering/cellRenderers/animateSlideCellRenderer.mjs\";\nexport { GroupCellRenderer, } from \"./rendering/cellRenderers/groupCellRenderer.mjs\";\nexport { GroupCellRendererCtrl } from \"./rendering/cellRenderers/groupCellRendererCtrl.mjs\";\n// features\nexport { SetLeftFeature } from \"./rendering/features/setLeftFeature.mjs\";\nexport { PositionableFeature } from \"./rendering/features/positionableFeature.mjs\";\n// rendering\nexport { AutoWidthCalculator } from \"./rendering/autoWidthCalculator.mjs\";\nexport { CheckboxSelectionComponent } from \"./rendering/checkboxSelectionComponent.mjs\";\nexport { CellComp } from \"./rendering/cell/cellComp.mjs\";\nexport { CellCtrl } from \"./rendering/cell/cellCtrl.mjs\";\nexport { RowCtrl } from \"./rendering/row/rowCtrl.mjs\";\nexport { RowRenderer } from \"./rendering/rowRenderer.mjs\";\nexport { ValueFormatterService } from \"./rendering/valueFormatterService.mjs\";\nexport { CssClassManager } from \"./rendering/cssClassManager.mjs\";\nexport { CheckboxCellRenderer } from \"./rendering/cellRenderers/checkboxCellRenderer.mjs\";\n// row models\nexport { PinnedRowModel } from \"./pinnedRowModel/pinnedRowModel.mjs\";\nexport { ServerSideTransactionResultStatus } from \"./interfaces/serverSideTransaction.mjs\";\nexport { ChangedPath } from \"./utils/changedPath.mjs\";\nexport { RowNodeBlock } from \"./rowNodeCache/rowNodeBlock.mjs\";\nexport { RowNodeBlockLoader } from \"./rowNodeCache/rowNodeBlockLoader.mjs\";\nexport { PaginationProxy } from \"./pagination/paginationProxy.mjs\";\nexport { ClientSideRowModelSteps } from \"./interfaces/iClientSideRowModel.mjs\";\n//styling\nexport { StylingService } from \"./styling/stylingService.mjs\";\nexport { LayoutCssClasses } from \"./styling/layoutFeature.mjs\";\n// widgets\nexport { AgAbstractField } from \"./widgets/agAbstractField.mjs\";\nexport { AgCheckbox } from \"./widgets/agCheckbox.mjs\";\nexport { AgRadioButton } from \"./widgets/agRadioButton.mjs\";\nexport { AgToggleButton } from \"./widgets/agToggleButton.mjs\";\nexport { AgInputTextField } from \"./widgets/agInputTextField.mjs\";\nexport { AgInputTextArea } from \"./widgets/agInputTextArea.mjs\";\nexport { AgInputNumberField } from \"./widgets/agInputNumberField.mjs\";\nexport { AgInputDateField } from \"./widgets/agInputDateField.mjs\";\nexport { AgInputRange } from \"./widgets/agInputRange.mjs\";\nexport { AgRichSelect } from \"./widgets/agRichSelect.mjs\";\nexport { AgSelect } from \"./widgets/agSelect.mjs\";\nexport { AgSlider } from \"./widgets/agSlider.mjs\";\nexport { AgGroupComponent } from \"./widgets/agGroupComponent.mjs\";\nexport { AgMenuItemComponent } from \"./widgets/agMenuItemComponent.mjs\";\nexport { AgMenuList } from \"./widgets/agMenuList.mjs\";\nexport { AgMenuPanel } from \"./widgets/agMenuPanel.mjs\";\nexport { AgDialog } from \"./widgets/agDialog.mjs\";\nexport { AgPanel } from \"./widgets/agPanel.mjs\";\nexport { Component } from \"./widgets/component.mjs\";\nexport { ManagedFocusFeature } from \"./widgets/managedFocusFeature.mjs\";\nexport { TabGuardComp } from \"./widgets/tabGuardComp.mjs\";\nexport { TabGuardCtrl, TabGuardClassNames } from \"./widgets/tabGuardCtrl.mjs\";\nexport { PopupComponent } from \"./widgets/popupComponent.mjs\";\nexport { PopupService } from \"./widgets/popupService.mjs\";\nexport { TouchListener } from \"./widgets/touchListener.mjs\";\nexport { VirtualList } from \"./widgets/virtualList.mjs\";\nexport { AgAbstractLabel } from \"./widgets/agAbstractLabel.mjs\";\nexport { AgPickerField } from \"./widgets/agPickerField.mjs\";\nexport { AgAutocomplete } from \"./widgets/agAutocomplete.mjs\";\n// range\nexport { CellRangeType, SelectionHandleType } from \"./interfaces/IRangeService.mjs\";\n// root\nexport { AutoScrollService } from './autoScrollService.mjs';\nexport { VanillaFrameworkOverrides } from \"./vanillaFrameworkOverrides.mjs\";\nexport { CellNavigationService } from \"./cellNavigationService.mjs\";\nexport { AlignedGridsService } from \"./alignedGridsService.mjs\";\nexport { KeyCode } from \"./constants/keyCode.mjs\";\nexport { Grid, GridCoreCreator } from \"./grid.mjs\";\nexport { GridApi } from \"./gridApi.mjs\";\nexport { Events } from \"./eventKeys.mjs\";\nexport { FocusService } from \"./focusService.mjs\";\nexport { GridOptionsService } from \"./gridOptionsService.mjs\";\nexport { EventService } from \"./eventService.mjs\";\nexport { SelectableService } from \"./rowNodes/selectableService.mjs\";\nexport { RowNodeSorter } from \"./rowNodes/rowNodeSorter.mjs\";\nexport { CtrlsService } from \"./ctrlsService.mjs\";\nexport { GridComp } from \"./gridComp/gridComp.mjs\";\nexport { GridCtrl } from \"./gridComp/gridCtrl.mjs\";\nexport { Logger, LoggerFactory } from \"./logger.mjs\";\nexport { SortController } from \"./sortController.mjs\";\nexport { TemplateService } from \"./templateService.mjs\";\nexport { LocaleService } from './localeService.mjs';\nexport * from \"./utils/index.mjs\"; // please leave this as is - we want it to be explicit for build reasons\nexport { ValueService } from \"./valueService/valueService.mjs\";\nexport { ValueCache } from \"./valueService/valueCache.mjs\";\nexport { ExpressionService } from \"./valueService/expressionService.mjs\";\nexport { ValueParserService } from \"./valueService/valueParserService.mjs\";\nexport { CellPositionUtils } from \"./entities/cellPositionUtils.mjs\";\nexport { RowPositionUtils } from \"./entities/rowPositionUtils.mjs\";\nexport { HeaderPositionUtils } from \"./headerRendering/common/headerPosition.mjs\";\nexport { HeaderNavigationService, HeaderNavigationDirection } from \"./headerRendering/common/headerNavigationService.mjs\";\nexport { DataTypeService } from \"./columns/dataTypeService.mjs\";\nexport * from \"./propertyKeys.mjs\";\nexport { ColumnApi } from \"./columns/columnApi.mjs\";\nexport { BaseComponentWrapper } from \"./components/framework/frameworkComponentWrapper.mjs\";\nexport { Environment } from \"./environment.mjs\";\nexport { TooltipFeature } from \"./widgets/tooltipFeature.mjs\";\nexport { CustomTooltipFeature } from \"./widgets/customTooltipFeature.mjs\";\n// charts\nexport * from \"./interfaces/iChartOptions.mjs\";\nexport * from \"./interfaces/iAgChartOptions.mjs\";\n// sparklines\nexport * from \"./interfaces/iSparklineCellRendererParams.mjs\";\nexport { ModuleNames } from \"./modules/moduleNames.mjs\";\nexport { ModuleRegistry } from \"./modules/moduleRegistry.mjs\";\n// events\nexport * from \"./events.mjs\";\n","export class MD5 {\n constructor() {\n this.ieCompatibility = false;\n }\n init() {\n this.ieCompatibility = (this.md5('hello') != '5d41402abc4b2a76b9719d911017c592');\n }\n md5cycle(x, k) {\n let a = x[0], b = x[1], c = x[2], d = x[3];\n a = this.ff(a, b, c, d, k[0], 7, -680876936);\n d = this.ff(d, a, b, c, k[1], 12, -389564586);\n c = this.ff(c, d, a, b, k[2], 17, 606105819);\n b = this.ff(b, c, d, a, k[3], 22, -1044525330);\n a = this.ff(a, b, c, d, k[4], 7, -176418897);\n d = this.ff(d, a, b, c, k[5], 12, 1200080426);\n c = this.ff(c, d, a, b, k[6], 17, -1473231341);\n b = this.ff(b, c, d, a, k[7], 22, -45705983);\n a = this.ff(a, b, c, d, k[8], 7, 1770035416);\n d = this.ff(d, a, b, c, k[9], 12, -1958414417);\n c = this.ff(c, d, a, b, k[10], 17, -42063);\n b = this.ff(b, c, d, a, k[11], 22, -1990404162);\n a = this.ff(a, b, c, d, k[12], 7, 1804603682);\n d = this.ff(d, a, b, c, k[13], 12, -40341101);\n c = this.ff(c, d, a, b, k[14], 17, -1502002290);\n b = this.ff(b, c, d, a, k[15], 22, 1236535329);\n a = this.gg(a, b, c, d, k[1], 5, -165796510);\n d = this.gg(d, a, b, c, k[6], 9, -1069501632);\n c = this.gg(c, d, a, b, k[11], 14, 643717713);\n b = this.gg(b, c, d, a, k[0], 20, -373897302);\n a = this.gg(a, b, c, d, k[5], 5, -701558691);\n d = this.gg(d, a, b, c, k[10], 9, 38016083);\n c = this.gg(c, d, a, b, k[15], 14, -660478335);\n b = this.gg(b, c, d, a, k[4], 20, -405537848);\n a = this.gg(a, b, c, d, k[9], 5, 568446438);\n d = this.gg(d, a, b, c, k[14], 9, -1019803690);\n c = this.gg(c, d, a, b, k[3], 14, -187363961);\n b = this.gg(b, c, d, a, k[8], 20, 1163531501);\n a = this.gg(a, b, c, d, k[13], 5, -1444681467);\n d = this.gg(d, a, b, c, k[2], 9, -51403784);\n c = this.gg(c, d, a, b, k[7], 14, 1735328473);\n b = this.gg(b, c, d, a, k[12], 20, -1926607734);\n a = this.hh(a, b, c, d, k[5], 4, -378558);\n d = this.hh(d, a, b, c, k[8], 11, -2022574463);\n c = this.hh(c, d, a, b, k[11], 16, 1839030562);\n b = this.hh(b, c, d, a, k[14], 23, -35309556);\n a = this.hh(a, b, c, d, k[1], 4, -1530992060);\n d = this.hh(d, a, b, c, k[4], 11, 1272893353);\n c = this.hh(c, d, a, b, k[7], 16, -155497632);\n b = this.hh(b, c, d, a, k[10], 23, -1094730640);\n a = this.hh(a, b, c, d, k[13], 4, 681279174);\n d = this.hh(d, a, b, c, k[0], 11, -358537222);\n c = this.hh(c, d, a, b, k[3], 16, -722521979);\n b = this.hh(b, c, d, a, k[6], 23, 76029189);\n a = this.hh(a, b, c, d, k[9], 4, -640364487);\n d = this.hh(d, a, b, c, k[12], 11, -421815835);\n c = this.hh(c, d, a, b, k[15], 16, 530742520);\n b = this.hh(b, c, d, a, k[2], 23, -995338651);\n a = this.ii(a, b, c, d, k[0], 6, -198630844);\n d = this.ii(d, a, b, c, k[7], 10, 1126891415);\n c = this.ii(c, d, a, b, k[14], 15, -1416354905);\n b = this.ii(b, c, d, a, k[5], 21, -57434055);\n a = this.ii(a, b, c, d, k[12], 6, 1700485571);\n d = this.ii(d, a, b, c, k[3], 10, -1894986606);\n c = this.ii(c, d, a, b, k[10], 15, -1051523);\n b = this.ii(b, c, d, a, k[1], 21, -2054922799);\n a = this.ii(a, b, c, d, k[8], 6, 1873313359);\n d = this.ii(d, a, b, c, k[15], 10, -30611744);\n c = this.ii(c, d, a, b, k[6], 15, -1560198380);\n b = this.ii(b, c, d, a, k[13], 21, 1309151649);\n a = this.ii(a, b, c, d, k[4], 6, -145523070);\n d = this.ii(d, a, b, c, k[11], 10, -1120210379);\n c = this.ii(c, d, a, b, k[2], 15, 718787259);\n b = this.ii(b, c, d, a, k[9], 21, -343485551);\n x[0] = this.add32(a, x[0]);\n x[1] = this.add32(b, x[1]);\n x[2] = this.add32(c, x[2]);\n x[3] = this.add32(d, x[3]);\n }\n cmn(q, a, b, x, s, t) {\n a = this.add32(this.add32(a, q), this.add32(x, t));\n return this.add32((a << s) | (a >>> (32 - s)), b);\n }\n ff(a, b, c, d, x, s, t) {\n return this.cmn((b & c) | ((~b) & d), a, b, x, s, t);\n }\n gg(a, b, c, d, x, s, t) {\n return this.cmn((b & d) | (c & (~d)), a, b, x, s, t);\n }\n hh(a, b, c, d, x, s, t) {\n return this.cmn(b ^ c ^ d, a, b, x, s, t);\n }\n ii(a, b, c, d, x, s, t) {\n return this.cmn(c ^ (b | (~d)), a, b, x, s, t);\n }\n md51(s) {\n const n = s.length;\n const state = [1732584193, -271733879, -1732584194, 271733878];\n let i;\n for (i = 64; i <= s.length; i += 64) {\n this.md5cycle(state, this.md5blk(s.substring(i - 64, i)));\n }\n s = s.substring(i - 64);\n const tail = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0];\n for (i = 0; i < s.length; i++) {\n tail[i >> 2] |= s.charCodeAt(i) << ((i % 4) << 3);\n }\n tail[i >> 2] |= 0x80 << ((i % 4) << 3);\n if (i > 55) {\n this.md5cycle(state, tail);\n for (i = 0; i < 16; i++) {\n tail[i] = 0;\n }\n }\n tail[14] = n * 8;\n this.md5cycle(state, tail);\n return state;\n }\n /* there needs to be support for Unicode here, * unless we pretend that we can redefine the MD-5\n * algorithm for multi-byte characters (perhaps by adding every four 16-bit characters and\n * shortening the sum to 32 bits). Otherwise I suthis.ggest performing MD-5 as if every character\n * was two bytes--e.g., 0040 0025 = @%--but then how will an ordinary MD-5 sum be matched?\n * There is no way to standardize text to something like UTF-8 before transformation; speed cost is\n * utterly prohibitive. The JavaScript standard itself needs to look at this: it should start\n * providing access to strings as preformed UTF-8 8-bit unsigned value arrays.\n */\n md5blk(s) {\n const md5blks = [];\n /* Andy King said do it this way. */\n for (let i = 0; i < 64; i += 4) {\n md5blks[i >> 2] = s.charCodeAt(i)\n + (s.charCodeAt(i + 1) << 8)\n + (s.charCodeAt(i + 2) << 16)\n + (s.charCodeAt(i + 3) << 24);\n }\n return md5blks;\n }\n rhex(n) {\n const hex_chr = '0123456789abcdef'.split('');\n let s = '', j = 0;\n for (; j < 4; j++) {\n s += hex_chr[(n >> (j * 8 + 4)) & 0x0F]\n + hex_chr[(n >> (j * 8)) & 0x0F];\n }\n return s;\n }\n hex(x) {\n for (let i = 0; i < x.length; i++) {\n x[i] = this.rhex(x[i]);\n }\n return x.join('');\n }\n md5(s) {\n return this.hex(this.md51(s));\n }\n add32(a, b) {\n return this.ieCompatibility ? this.add32Compat(a, b) : this.add32Std(a, b);\n }\n /* this function is much faster, so if possible we use it. Some IEs are the only ones I know of that\n need the idiotic second function, generated by an if clause. */\n add32Std(a, b) {\n return (a + b) & 0xFFFFFFFF;\n }\n add32Compat(x, y) {\n const lsw = (x & 0xFFFF) + (y & 0xFFFF), msw = (x >> 16) + (y >> 16) + (lsw >> 16);\n return (msw << 16) | (lsw & 0xFFFF);\n }\n}\n","import { MD5 } from './md5.mjs';\n// move to general utils\nfunction missingOrEmpty(value) {\n return value == null || value.length === 0;\n}\nfunction exists(value, allowEmptyString = false) {\n return value != null && (value !== '' || allowEmptyString);\n}\nexport class LicenseManager {\n constructor(document) {\n this.watermarkMessage = undefined;\n this.document = document;\n this.md5 = new MD5();\n this.md5.init();\n }\n validateLicense() {\n if (missingOrEmpty(LicenseManager.licenseKey)) {\n if (!this.isWebsiteUrl() || this.isForceWatermark()) {\n this.outputMissingLicenseKey();\n }\n }\n else if (LicenseManager.licenseKey.length > 32) {\n if (LicenseManager.licenseKey.indexOf(\"For_Trialing_ag-Grid_Only\") !== -1) {\n this.outputInvalidLicenseKey();\n }\n else {\n const { md5, license, version, isTrial } = LicenseManager.extractLicenseComponents(LicenseManager.licenseKey);\n if (md5 === this.md5.md5(license)) {\n if (exists(version) && version) {\n this.validateLicenseKeyForVersion(version, !!isTrial, license);\n }\n else {\n this.validateLegacyKey(license);\n }\n }\n else {\n this.outputInvalidLicenseKey();\n }\n }\n }\n else {\n this.outputInvalidLicenseKey();\n }\n }\n static extractExpiry(license) {\n const restrictionHashed = license.substring(license.lastIndexOf('_') + 1, license.length);\n return new Date(parseInt(LicenseManager.decode(restrictionHashed), 10));\n }\n static extractLicenseComponents(licenseKey) {\n // when users copy the license key from a PDF extra zero width characters are sometimes copied too\n // carriage returns and line feeds are problematic too\n // all of which causes license key validation to fail - strip these out\n let cleanedLicenseKey = licenseKey.replace(/[\\u200B-\\u200D\\uFEFF]/g, '');\n cleanedLicenseKey = cleanedLicenseKey.replace(/\\r?\\n|\\r/g, '');\n const hashStart = cleanedLicenseKey.length - 32;\n const md5 = cleanedLicenseKey.substring(hashStart);\n const license = cleanedLicenseKey.substring(0, hashStart);\n const [version, isTrial] = LicenseManager.extractBracketedInformation(cleanedLicenseKey);\n return { md5, license, version, isTrial };\n }\n getLicenseDetails(licenseKey) {\n const { md5, license, version, isTrial } = LicenseManager.extractLicenseComponents(licenseKey);\n let valid = (md5 === this.md5.md5(license)) && licenseKey.indexOf(\"For_Trialing_ag-Grid_Only\") === -1;\n let trialExpired = null;\n let expiry = null;\n if (valid) {\n expiry = LicenseManager.extractExpiry(license);\n valid = !isNaN(expiry.getTime());\n if (isTrial) {\n const now = new Date();\n trialExpired = (expiry < now);\n }\n }\n return {\n licenseKey,\n valid,\n expiry: valid ? LicenseManager.formatDate(expiry) : null,\n version: version ? version : 'legacy',\n isTrial,\n trialExpired\n };\n }\n isDisplayWatermark() {\n return this.isForceWatermark() || (!this.isLocalhost() && !this.isWebsiteUrl() && !missingOrEmpty(this.watermarkMessage));\n }\n getWatermarkMessage() {\n return this.watermarkMessage || '';\n }\n getHostname() {\n const win = (this.document.defaultView || window);\n const loc = win.location;\n const { hostname = '' } = loc;\n return hostname;\n }\n isForceWatermark() {\n const win = (this.document.defaultView || window);\n const loc = win.location;\n const { pathname } = loc;\n return pathname ? pathname.indexOf('forceWatermark') !== -1 : false;\n }\n isWebsiteUrl() {\n const hostname = this.getHostname();\n return hostname.match(/^((?:\\w+\\.)?ag-grid\\.com)$/) !== null;\n }\n isLocalhost() {\n const hostname = this.getHostname();\n return hostname.match(/^(?:127\\.0\\.0\\.1|localhost)$/) !== null;\n }\n static formatDate(date) {\n const monthNames = [\n 'January', 'February', 'March',\n 'April', 'May', 'June', 'July',\n 'August', 'September', 'October',\n 'November', 'December'\n ];\n const day = date.getDate();\n const monthIndex = date.getMonth();\n const year = date.getFullYear();\n return day + ' ' + monthNames[monthIndex] + ' ' + year;\n }\n static getGridReleaseDate() {\n return new Date(parseInt(LicenseManager.decode(LicenseManager.RELEASE_INFORMATION), 10));\n }\n static decode(input) {\n const keystr = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=';\n let t = '';\n let n, r, i;\n let s, o, u, a;\n let f = 0;\n const e = input.replace(/[^A-Za-z0-9+/=]/g, '');\n while (f < e.length) {\n s = keystr.indexOf(e.charAt(f++));\n o = keystr.indexOf(e.charAt(f++));\n u = keystr.indexOf(e.charAt(f++));\n a = keystr.indexOf(e.charAt(f++));\n n = s << 2 | o >> 4;\n r = (o & 15) << 4 | u >> 2;\n i = (u & 3) << 6 | a;\n t = t + String.fromCharCode(n);\n if (u != 64) {\n t = t + String.fromCharCode(r);\n }\n if (a != 64) {\n t = t + String.fromCharCode(i);\n }\n }\n t = LicenseManager.utf8_decode(t);\n return t;\n }\n static utf8_decode(input) {\n input = input.replace(/rn/g, 'n');\n let t = '';\n for (let n = 0; n < input.length; n++) {\n const r = input.charCodeAt(n);\n if (r < 128) {\n t += String.fromCharCode(r);\n }\n else if (r > 127 && r < 2048) {\n t += String.fromCharCode(r >> 6 | 192);\n t += String.fromCharCode(r & 63 | 128);\n }\n else {\n t += String.fromCharCode(r >> 12 | 224);\n t += String.fromCharCode(r >> 6 & 63 | 128);\n t += String.fromCharCode(r & 63 | 128);\n }\n }\n return t;\n }\n static setLicenseKey(licenseKey) {\n this.licenseKey = licenseKey;\n }\n static extractBracketedInformation(licenseKey) {\n const matches = licenseKey.split('[')\n .filter(function (v) {\n return v.indexOf(']') > -1;\n })\n .map(function (value) {\n return value.split(']')[0];\n });\n if (!matches || matches.length === 0) {\n return [null, null];\n }\n const isTrial = matches.filter(match => match === 'TRIAL').length === 1;\n const version = matches.filter(match => match.indexOf(\"v\") === 0).map(match => match.replace(/^v/, \"\"))[0];\n return [version, isTrial];\n }\n validateLicenseKeyForVersion(version, isTrial, license) {\n if (version !== '2') {\n return;\n }\n if (isTrial) {\n this.validateForTrial(license);\n }\n else {\n this.validateLegacyKey(license);\n }\n }\n validateLegacyKey(license) {\n const gridReleaseDate = LicenseManager.getGridReleaseDate();\n const expiry = LicenseManager.extractExpiry(license);\n let valid = false;\n let current = false;\n if (!isNaN(expiry.getTime())) {\n valid = true;\n current = (gridReleaseDate < expiry);\n }\n if (!valid) {\n this.outputInvalidLicenseKey();\n }\n else if (!current) {\n const formattedExpiryDate = LicenseManager.formatDate(expiry);\n const formattedReleaseDate = LicenseManager.formatDate(gridReleaseDate);\n this.outputIncompatibleVersion(formattedExpiryDate, formattedReleaseDate);\n }\n }\n validateForTrial(license) {\n const expiry = LicenseManager.extractExpiry(license);\n const now = new Date();\n let valid = false;\n let current = false;\n if (!isNaN(expiry.getTime())) {\n valid = true;\n current = (expiry > now);\n }\n if (!valid) {\n this.outputInvalidLicenseKey();\n }\n else if (!current) {\n const formattedExpiryDate = LicenseManager.formatDate(expiry);\n this.outputExpiredTrialKey(formattedExpiryDate);\n }\n }\n outputInvalidLicenseKey() {\n console.error('*****************************************************************************************************************');\n console.error('***************************************** AG Grid Enterprise License ********************************************');\n console.error('********************************************* Invalid License ***************************************************');\n console.error('* Your license for AG Grid Enterprise is not valid - please contact info@ag-grid.com to obtain a valid license. *');\n console.error('*****************************************************************************************************************');\n console.error('*****************************************************************************************************************');\n this.watermarkMessage = \"Invalid License\";\n }\n outputExpiredTrialKey(formattedExpiryDate) {\n console.error('****************************************************************************************************************');\n console.error('***************************************** AG Grid Enterprise License *******************************************');\n console.error('***************************************** Trial Period Expired. *******************************************');\n console.error(`* Your license for AG Grid Enterprise expired on ${formattedExpiryDate}. *`);\n console.error('* Please email info@ag-grid.com to purchase a license. *');\n console.error('****************************************************************************************************************');\n console.error('****************************************************************************************************************');\n this.watermarkMessage = \"Trial Period Expired\";\n }\n outputMissingLicenseKey() {\n console.error('****************************************************************************************************************');\n console.error('***************************************** AG Grid Enterprise License *******************************************');\n console.error('****************************************** License Key Not Found ***********************************************');\n console.error('* All AG Grid Enterprise features are unlocked. *');\n console.error('* This is an evaluation only version, it is not licensed for development projects intended for production. *');\n console.error('* If you want to hide the watermark, please email info@ag-grid.com for a trial license. *');\n console.error('****************************************************************************************************************');\n console.error('****************************************************************************************************************');\n this.watermarkMessage = \"For Trial Use Only\";\n }\n outputIncompatibleVersion(formattedExpiryDate, formattedReleaseDate) {\n console.error('****************************************************************************************************************************');\n console.error('****************************************************************************************************************************');\n console.error('* AG Grid Enterprise License *');\n console.error('* License not compatible with installed version of AG Grid Enterprise. *');\n console.error('* *');\n console.error(`* Your AG Grid License entitles you to all versions of AG Grid that we release within the time covered by your license *`);\n console.error(`* - typically we provide one year licenses which entitles you to all releases / updates of AG Grid within that year. *`);\n console.error(`* Your license has an end (expiry) date which stops the license key working with versions of AG Grid released after the *`);\n console.error(`* license end date. The license key that you have expires on ${formattedExpiryDate}, however the version of AG Grid you *`);\n console.error(`* are trying to use was released on ${formattedReleaseDate}. *`);\n console.error('* *');\n console.error('* Please contact info@ag-grid.com to renew your subscription to new versions and get a new license key to work with this *');\n console.error('* version of AG Grid. *');\n console.error('****************************************************************************************************************************');\n console.error('****************************************************************************************************************************');\n this.watermarkMessage = \"License Expired\";\n }\n}\nLicenseManager.RELEASE_INFORMATION = 'MTY5ODkxNzc1MzgxNA==';\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Bean, BeanStub, PreConstruct } from '@ag-grid-community/core';\nimport { LicenseManager } from \"./shared/licenseManager.mjs\";\nlet GridLicenseManager = class GridLicenseManager extends BeanStub {\n validateLicense() {\n this.licenseManager = new LicenseManager(this.gridOptionsService.getDocument());\n this.licenseManager.validateLicense();\n }\n static getLicenseDetails(licenseKey) {\n return new LicenseManager(null).getLicenseDetails(licenseKey);\n }\n isDisplayWatermark() {\n return this.licenseManager.isDisplayWatermark();\n }\n getWatermarkMessage() {\n return this.licenseManager.getWatermarkMessage();\n }\n static setLicenseKey(licenseKey) {\n LicenseManager.setLicenseKey(licenseKey);\n }\n};\n__decorate([\n PreConstruct\n], GridLicenseManager.prototype, \"validateLicense\", null);\nGridLicenseManager = __decorate([\n Bean('licenseManager')\n], GridLicenseManager);\nexport { GridLicenseManager };\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, Component, PostConstruct, RefSelector } from '@ag-grid-community/core';\nexport class WatermarkComp extends Component {\n constructor() {\n super(/* html*/ `
\n
\n
`);\n }\n postConstruct() {\n const show = this.shouldDisplayWatermark();\n this.setDisplayed(show);\n if (show) {\n this.eLicenseTextRef.innerText = this.licenseManager.getWatermarkMessage();\n window.setTimeout(() => this.addCssClass('ag-opacity-zero'), 0);\n window.setTimeout(() => this.setDisplayed(false), 5000);\n }\n }\n shouldDisplayWatermark() {\n return this.licenseManager.isDisplayWatermark();\n }\n}\n__decorate([\n Autowired('licenseManager')\n], WatermarkComp.prototype, \"licenseManager\", void 0);\n__decorate([\n RefSelector('eLicenseTextRef')\n], WatermarkComp.prototype, \"eLicenseTextRef\", void 0);\n__decorate([\n PostConstruct\n], WatermarkComp.prototype, \"postConstruct\", null);\n","// DO NOT UPDATE MANUALLY: Generated from script during build time\nexport const VERSION = '30.2.1';\n","import { ModuleNames } from \"@ag-grid-community/core\";\nimport { GridLicenseManager as LicenseManager } from \"./license/gridLicenseManager.mjs\";\nimport { WatermarkComp } from \"./license/watermark.mjs\";\nexport { WatermarkComp } from \"./license/watermark.mjs\";\nimport { VERSION } from \"./version.mjs\";\nexport const EnterpriseCoreModule = {\n version: VERSION,\n moduleName: ModuleNames.EnterpriseCoreModule,\n beans: [LicenseManager],\n agStackComponents: [\n { componentName: 'AgWatermark', componentClass: WatermarkComp }\n ]\n};\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Autowired, BeanStub, Events, _ } from \"@ag-grid-community/core\";\nexport class DetailCellRendererCtrl extends BeanStub {\n constructor() {\n super(...arguments);\n this.loadRowDataVersion = 0;\n }\n init(comp, params) {\n this.params = params;\n this.comp = comp;\n const doNothingBecauseInsidePinnedSection = params.pinned != null;\n if (doNothingBecauseInsidePinnedSection) {\n return;\n }\n this.setAutoHeightClasses();\n this.setupRefreshStrategy();\n this.addThemeToDetailGrid();\n this.createDetailGrid();\n this.loadRowData();\n this.addManagedListener(this.eventService, Events.EVENT_FULL_WIDTH_ROW_FOCUSED, this.onFullWidthRowFocused.bind(this));\n }\n onFullWidthRowFocused(e) {\n const params = this.params;\n const row = { rowIndex: params.node.rowIndex, rowPinned: params.node.rowPinned };\n const eventRow = { rowIndex: e.rowIndex, rowPinned: e.rowPinned };\n const isSameRow = this.rowPositionUtils.sameRow(row, eventRow);\n if (!isSameRow) {\n return;\n }\n this.focusService.focusInto(this.comp.getGui(), e.fromBelow);\n }\n setAutoHeightClasses() {\n const autoHeight = this.gridOptionsService.is('detailRowAutoHeight');\n const parentClass = autoHeight ? 'ag-details-row-auto-height' : 'ag-details-row-fixed-height';\n const detailClass = autoHeight ? 'ag-details-grid-auto-height' : 'ag-details-grid-fixed-height';\n this.comp.addOrRemoveCssClass(parentClass, true);\n this.comp.addOrRemoveDetailGridCssClass(detailClass, true);\n }\n setupRefreshStrategy() {\n const providedStrategy = this.params.refreshStrategy;\n const validSelection = providedStrategy == 'everything' || providedStrategy == 'nothing' || providedStrategy == 'rows';\n if (validSelection) {\n this.refreshStrategy = providedStrategy;\n return;\n }\n if (providedStrategy != null) {\n console.warn(\"AG Grid: invalid cellRendererParams.refreshStrategy = '\" + providedStrategy +\n \"' supplied, defaulting to refreshStrategy = 'rows'.\");\n }\n this.refreshStrategy = 'rows';\n }\n addThemeToDetailGrid() {\n // this is needed by environment service of the child grid, the class needs to be on\n // the grid div itself - the browser's CSS on the other hand just inherits from the parent grid theme.\n const { theme } = this.environment.getTheme();\n if (theme) {\n this.comp.addOrRemoveDetailGridCssClass(theme, true);\n }\n }\n createDetailGrid() {\n if (_.missing(this.params.detailGridOptions)) {\n console.warn('AG Grid: could not find detail grid options for master detail, ' +\n 'please set gridOptions.detailCellRendererParams.detailGridOptions');\n return;\n }\n const autoHeight = this.gridOptionsService.is('detailRowAutoHeight');\n // we clone the detail grid options, as otherwise it would be shared\n // across many instances, and that would be a problem because we set\n // api and columnApi into gridOptions\n const gridOptions = Object.assign({}, this.params.detailGridOptions);\n if (autoHeight) {\n gridOptions.domLayout = 'autoHeight';\n }\n this.comp.setDetailGrid(gridOptions);\n }\n registerDetailWithMaster(api, columnApi) {\n const rowId = this.params.node.id;\n const masterGridApi = this.params.api;\n const gridInfo = {\n id: rowId,\n api: api,\n columnApi: columnApi\n };\n const rowNode = this.params.node;\n // register with api\n masterGridApi.addDetailGridInfo(rowId, gridInfo);\n // register with node\n rowNode.detailGridInfo = gridInfo;\n this.addDestroyFunc(() => {\n // the gridInfo can be stale if a refresh happens and\n // a new row is created before the old one is destroyed.\n if (rowNode.detailGridInfo !== gridInfo) {\n return;\n }\n masterGridApi.removeDetailGridInfo(rowId); // unregister from api\n rowNode.detailGridInfo = null; // unregister from node\n });\n }\n loadRowData() {\n // in case a refresh happens before the last refresh completes (as we depend on async\n // application logic) we keep track on what the latest call was.\n this.loadRowDataVersion++;\n const versionThisCall = this.loadRowDataVersion;\n const userFunc = this.params.getDetailRowData;\n if (!userFunc) {\n console.warn('AG Grid: could not find getDetailRowData for master / detail, ' +\n 'please set gridOptions.detailCellRendererParams.getDetailRowData');\n return;\n }\n const successCallback = (rowData) => {\n const mostRecentCall = this.loadRowDataVersion === versionThisCall;\n if (mostRecentCall) {\n this.comp.setRowData(rowData);\n }\n };\n const funcParams = {\n node: this.params.node,\n // we take data from node, rather than params.data\n // as the data could have been updated with new instance\n data: this.params.node.data,\n successCallback: successCallback,\n context: this.gridOptionsService.context\n };\n userFunc(funcParams);\n }\n refresh() {\n const GET_GRID_TO_REFRESH = false;\n const GET_GRID_TO_DO_NOTHING = true;\n switch (this.refreshStrategy) {\n // ignore this refresh, make grid think we've refreshed but do nothing\n case 'nothing': return GET_GRID_TO_DO_NOTHING;\n // grid will destroy and recreate the cell\n case 'everything': return GET_GRID_TO_REFRESH;\n }\n // do the refresh here, and tell the grid to do nothing\n this.loadRowData();\n return GET_GRID_TO_DO_NOTHING;\n }\n}\n__decorate([\n Autowired('rowPositionUtils')\n], DetailCellRendererCtrl.prototype, \"rowPositionUtils\", void 0);\n__decorate([\n Autowired('focusService')\n], DetailCellRendererCtrl.prototype, \"focusService\", void 0);\n","var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n};\nimport { Component, Grid, RefSelector, _, ModuleRegistry } from \"@ag-grid-community/core\";\nimport { DetailCellRendererCtrl } from \"./detailCellRendererCtrl.mjs\";\nexport class DetailCellRenderer extends Component {\n init(params) {\n this.params = params;\n this.selectAndSetTemplate();\n const compProxy = {\n addOrRemoveCssClass: (cssClassName, on) => this.addOrRemoveCssClass(cssClassName, on),\n addOrRemoveDetailGridCssClass: (cssClassName, on) => this.eDetailGrid.classList.toggle(cssClassName, on),\n setDetailGrid: gridOptions => this.setDetailGrid(gridOptions),\n setRowData: rowData => this.setRowData(rowData),\n getGui: () => this.eDetailGrid\n };\n this.ctrl = this.createManagedBean(new DetailCellRendererCtrl());\n this.ctrl.init(compProxy, params);\n }\n refresh() {\n return this.ctrl && this.ctrl.refresh();\n }\n // this is a user component, and IComponent has \"public destroy()\" as part of the interface.\n // so we need to override destroy() just to make the method public.\n destroy() {\n super.destroy();\n }\n selectAndSetTemplate() {\n if (this.params.pinned) {\n this.setTemplate('
');\n return;\n }\n const setDefaultTemplate = () => {\n this.setTemplate(DetailCellRenderer.TEMPLATE);\n };\n if (_.missing(this.params.template)) {\n // use default template\n setDefaultTemplate();\n }\n else {\n // use user provided template\n if (typeof this.params.template === 'string') {\n this.setTemplate(this.params.template);\n }\n else if (typeof this.params.template === 'function') {\n const templateFunc = this.params.template;\n const template = templateFunc(this.params);\n this.setTemplate(template);\n }\n else {\n console.warn('AG Grid: detailCellRendererParams.template should be function or string');\n setDefaultTemplate();\n }\n }\n if (this.eDetailGrid == null) {\n console.warn('AG Grid: reference to eDetailGrid was missing from the details template. ' +\n 'Please add ref=\"eDetailGrid\" to the template.');\n }\n }\n setDetailGrid(gridOptions) {\n if (!this.eDetailGrid) {\n return;\n }\n // AG-1715\n // this is only needed when suppressReactUi=true, once we remove the old way\n // of doing react, and Master / Details is all native React, then we\n // can remove this code.\n const agGridReact = this.context.getBean('agGridReact');\n const agGridReactCloned = agGridReact ? _.cloneObject(agGridReact) : undefined;\n // when we create detail grid, the detail grid needs frameworkComponentWrapper so that\n // it created child components correctly, ie Angular detail grid can have Angular cell renderer.\n // this is only used by Angular and Vue, as React uses native React AG Grid detail grids\n const frameworkComponentWrapper = this.context.getBean('frameworkComponentWrapper');\n const frameworkOverrides = this.getFrameworkOverrides();\n // tslint:disable-next-line\n new Grid(this.eDetailGrid, gridOptions, {\n frameworkOverrides,\n providedBeanInstances: {\n agGridReact: agGridReactCloned,\n frameworkComponentWrapper: frameworkComponentWrapper\n },\n modules: ModuleRegistry.__getGridRegisteredModules(this.params.api.getGridId())\n });\n this.detailApi = gridOptions.api;\n this.ctrl.registerDetailWithMaster(gridOptions.api, gridOptions.columnApi);\n this.addDestroyFunc(() => {\n if (gridOptions.api) {\n gridOptions.api.destroy();\n }\n });\n }\n setRowData(rowData) {\n // ensure detail grid api still exists (grid may be destroyed when async call tries to set data)\n this.detailApi && this.detailApi.setRowData(rowData);\n }\n}\nDetailCellRenderer.TEMPLATE = `
\n
\n
`;\n__decorate([\n RefSelector('eDetailGrid')\n], DetailCellRenderer.prototype, \"eDetailGrid\", void 0);\n","// DO NOT UPDATE MANUALLY: Generated from script during build time\nexport const VERSION = '30.2.1';\n","import { ModuleNames } from \"@ag-grid-community/core\";\nimport { EnterpriseCoreModule } from \"@ag-grid-enterprise/core\";\nimport { DetailCellRenderer } from \"./masterDetail/detailCellRenderer.mjs\";\nimport { DetailCellRendererCtrl } from \"./masterDetail/detailCellRendererCtrl.mjs\";\nimport { VERSION } from \"./version.mjs\";\nexport const MasterDetailModule = {\n version: VERSION,\n moduleName: ModuleNames.MasterDetailModule,\n beans: [],\n userComponents: [\n { componentName: 'agDetailCellRenderer', componentClass: DetailCellRenderer }\n ],\n controllers: [\n { controllerName: 'detailCellRenderer', controllerClass: DetailCellRendererCtrl }\n ],\n dependantModules: [\n EnterpriseCoreModule\n ]\n};\n","import type { VNode } from \"vue\";\nimport Vue, { h } from \"vue\";\n\nexport const DetailCellRendererWrapper = Vue.extend({\n name: \"DetailCellRendererWrapper\",\n render(): VNode {\n const params = (this as any).params;\n return h(\n \"div\",\n params.renderFn({\n item: params.data,\n })\n );\n },\n});\n","import type { PropType, Ref, Data } from \"vue\";\nimport {\n computed,\n defineComponent,\n getCurrentInstance,\n h,\n onMounted,\n toRef,\n ref,\n watch,\n} from \"vue\";\nimport type {\n BmGridColumnConfiguration,\n BmGridConfiguration,\n BmGridState,\n GroupSummaryValueExtractor,\n} from \"@/components/controls/grid/BmGridData\";\nimport type { VuetifyPropertyArg } from \"@/components/utils/vuetifyHelpers\";\nimport { getPropertyFromItem } from \"@/components/utils/vuetifyHelpers\";\nimport { AgGridVue } from \"@ag-grid-community/vue\";\nimport type {\n CellClassParams,\n ColDef,\n GetQuickFilterTextParams,\n} from \"@ag-grid-community/core/dist/cjs/es5/entities/colDef\";\nimport type {\n ColumnApi,\n ColumnState,\n GetRowIdParams,\n GridApi,\n GridOptions,\n GridReadyEvent,\n RowGroupOpenedEvent,\n RowNode,\n SortChangedEvent,\n} from \"@ag-grid-community/core\";\nimport { ModuleRegistry } from \"@ag-grid-community/core\";\nimport { ClientSideRowModelModule } from \"@ag-grid-community/client-side-row-model\";\nimport { pushRouteOrNewWindow } from \"@/router/router\";\nimport \"@ag-grid-community/core/dist/styles/ag-grid.css\";\nimport \"@ag-grid-community/core/dist/styles/ag-theme-alpine.css\";\nimport \"@ag-grid-community/core/dist/styles/ag-theme-alpine-dark.css\";\nimport \"@/components/controls/grid/agGrid.sass\";\nimport { BmGridCellRendererWrapper } from \"@/components/controls/grid/BmGridCellRendererWrapper\";\nimport { makeDeepRef } from \"@/components/composables/componentTools\";\nimport { isNotNullOrUndefined } from \"@/app/apiutils\";\nimport type {\n DragStoppedEvent,\n CellClickedEvent,\n FirstDataRenderedEvent,\n GridSizeChangedEvent,\n AgGridEvent,\n ColumnResizedEvent,\n RowDragMoveEvent,\n RowDragEndEvent,\n RowDragEnterEvent,\n RowDragLeaveEvent,\n SelectionChangedEvent,\n} from \"@ag-grid-community/core/dist/cjs/es5/events\";\nimport { useMediaPrintingEvents } from \"@/components/composables/mediaPrintingEvents\";\nimport { isMacOs } from \"@/app/ui/utilities\";\nimport { indexedKeyComparer } from \"@/components/controls/grid/BmGridComparers\";\nimport { tenantService } from \"@/app/services/extensions/tenantServiceExtended\";\nimport type { GridDragDropEvent } from \"@/components/controls/grid/BmGrid.vue\";\nimport { RowGroupingModule } from \"@ag-grid-enterprise/row-grouping\";\nimport { LicenseManager } from \"@ag-grid-enterprise/core\";\nimport environment from \"@/environment\";\nimport { MasterDetailModule } from \"@ag-grid-enterprise/master-detail\";\nimport { DetailCellRendererWrapper } from \"@/components/controls/grid/DetailCellRendererWrapper\";\nimport appStore from \"@/store/modules/appStore\";\nimport type { Location } from \"vue-router/types/router\";\n\nLicenseManager.setLicenseKey(environment.agGridEnterpriseKey);\n\nModuleRegistry.registerModules([\n ClientSideRowModelModule,\n RowGroupingModule,\n MasterDetailModule,\n]);\n\nexport interface AgGridInterface {\n getSortedAndFilteredRows: () => RowNode[];\n}\n\nexport default defineComponent({\n name: \"AgGrid\",\n components: { BmGridCellRendererWrapper, DetailCellRendererWrapper },\n model: {\n prop: \"selectedItemKeys\",\n event: \"update:selected-item-keys\",\n },\n props: {\n items: { type: Array as PropType, required: true },\n itemKey: {\n type: [String, Array, Function] as PropType,\n required: true,\n },\n itemNoun: {\n type: String,\n required: false,\n default: () => \"\",\n },\n gridConfiguration: {\n type: Object as () => BmGridConfiguration,\n required: true,\n },\n gridState: {\n type: Object as () => BmGridState,\n required: true,\n },\n rowClickRoute: {\n type: [Function, Object] as PropType<\n ((item: any) => Location | null) | null\n >,\n default: null,\n required: false,\n },\n rowClasses: {\n type: Function as PropType<(row: any) => string[]>,\n default: (row: any) => [],\n required: false,\n },\n allowSelect: {\n type: Boolean,\n default: false,\n },\n selectedItemKeys: {\n type: Array as PropType,\n default: () => [],\n },\n rowSelectable: {\n type: Function as PropType<(item: any) => boolean>,\n default: (item: any) => true,\n },\n allowDrag: {\n type: Boolean,\n default: false,\n },\n allowDrop: {\n type: Boolean,\n default: false,\n },\n rowDraggable: {\n type: Function as PropType<(item: any) => boolean>,\n default: (item: any) => true,\n },\n // The height of the grid when the number of rows exceed the predetermined\n // maximum count\n height: {\n type: [Number, String],\n required: false,\n },\n // The height of the grid, regardless of the number of rows\n overrideHeight: {\n type: [Number, String],\n required: false,\n },\n isLoading: {\n type: Boolean,\n required: false,\n default: false,\n },\n allowSort: {\n type: Boolean,\n required: false,\n default: true,\n },\n defaultExpandGroups: {\n type: Boolean,\n required: false,\n default: true,\n },\n defaultExpandExpandable: {\n type: Boolean,\n required: false,\n default: false,\n },\n expandSlotRenderFn: {\n type: Function,\n required: false,\n },\n allowExpand: {\n type: Boolean,\n required: false,\n default: false,\n },\n rowExpandable: {\n type: Function as PropType<(opts: { item: any }) => boolean>,\n required: false,\n },\n isFixedShapeReport: {\n type: Boolean,\n required: false,\n default: false,\n },\n includeIds: {\n type: Boolean,\n required: false,\n default: false,\n },\n },\n methods: {\n getSortedAndFilteredRows() {\n let rowData: RowNode[] = [];\n if (this.gridApi) {\n this.gridApi.forEachNodeAfterFilterAndSort((node) => {\n rowData.push(node);\n });\n }\n return rowData;\n },\n },\n data: () => ({\n gridApi: null as GridApi | null,\n }),\n setup(props, context) {\n const agGridRef = ref(null);\n const GRID_OVERFLOW_SPACER = 4;\n useMediaPrintingEvents(\n () => {\n setPrinterMode(true);\n },\n () => {\n setPrinterMode(false);\n }\n );\n const localApp: Ref = ref(null);\n onMounted(() => {\n // Get local app instance to expose functions\n // @TODO: [BREW-5793] use expose endpoint to expose data collection functions\n localApp.value = getCurrentInstance()?.proxy.$data ?? null;\n });\n\n // The number of rows displayed on first render of the grid (with data),\n // including grouped rows\n const initialDisplayedRowCount = ref(null);\n\n const maxRowCountForAutoHeight = 15;\n\n const shouldUseFullHeight = computed(() => {\n const rowCount = initialDisplayedRowCount.value ?? props.items.length;\n return rowCount > maxRowCountForAutoHeight;\n });\n\n const gridApi = makeDeepRef(null);\n const gridColumnApi = makeDeepRef(null);\n\n const items = toRef(props, \"items\");\n const columnDefs = makeDeepRef([]);\n\n const selectedItemKeys = computed({\n get: () => props.selectedItemKeys,\n set: (keys: any[]) => context.emit(\"update:selected-item-keys\", keys),\n });\n\n let dragStartedDataSnapshot: any[] = [];\n\n const internalRowSelectColId = \"internalRowSelect\";\n\n const updateAgGridStateFromBmGridState = (\n gridState: BmGridState = props.gridState\n ) => {\n if (gridApi.value && gridColumnApi.value) {\n // Set quick filter text\n gridApi.value.setQuickFilter(gridState.gridSearchFilter);\n\n //External Sorting\n const gridSortState = (gridApi.value.getColumnDefs() ?? [])\n .map((columnDef: ColDef) => {\n const isHidden = props.gridState.removedColumnKeys.includes(\n columnDef.colId!\n );\n if (columnDef.sortable) {\n let sortByIndex = props.gridState.sortBy.findIndex(\n (x) => x.columnKey === columnDef.colId\n );\n let sortItem = props.gridState.sortBy[sortByIndex];\n columnDef.sortable;\n if (sortItem) {\n return {\n colId: columnDef.colId!,\n sort: sortItem.descending ? \"desc\" : \"asc\",\n sortIndex: sortByIndex,\n hide: isHidden,\n } as ColumnState;\n }\n }\n return {\n colId: columnDef.colId!,\n sort: null,\n sortIndex: null,\n hide: isHidden,\n } as ColumnState;\n })\n .filter(isNotNullOrUndefined);\n\n // Sort our defs by our gridState order\n columnDefs.value.sort(\n indexedKeyComparer(\n props.gridState.columnOrder,\n (x: ColumnState) => x.colId\n )\n );\n\n gridColumnApi.value.applyColumnState({\n state: gridSortState,\n applyOrder: false,\n });\n\n gridApi.value.onFilterChanged();\n }\n };\n\n watch(\n () => [\n props.gridConfiguration.columns,\n props.gridConfiguration.summaries,\n props.gridConfiguration.defaultGridState,\n props.gridState,\n ],\n (_, oldValue) => {\n const columnKeysToGroupBy = new Set(\n props.gridConfiguration.defaultGridState?.groupBy ?? []\n );\n\n const columnKeyToAggregator: Record<\n string,\n GroupSummaryValueExtractor\n > = Object.fromEntries(\n props.gridConfiguration.summaries.map((summary) => [\n summary.columnKey,\n summary.groupSummaryValueExtractor,\n ])\n );\n\n let groupedCellRendererAssigned = false;\n\n const defs = Object.entries(props.gridConfiguration.columns).map(\n ([columnKey, value], index) => {\n const headerClass = `text-${value.align}`;\n\n const columnIsGroup = columnKeysToGroupBy.has(columnKey);\n\n let columnDef: ColDef = {\n colId: columnKey,\n headerName: value.headingText,\n valueGetter: (item) => {\n // Value is set by aggregator function if cell is in an\n // aggregated row\n if (!item?.data || item.node?.group) {\n return undefined;\n }\n\n return value.extractor(item.data);\n },\n valueFormatter: (item) => {\n // If we're formatting an autoGroup column, prepend the\n // column heading\n if (item.colDef.rowGroup) {\n return `${item.colDef.headerName}: ${item.value}`;\n }\n\n // Formatting is handled by BmGridCellRendererWrapper if cell is\n // in an aggregated row\n if (!item?.data || item.node?.group) {\n return undefined;\n }\n\n return value.formatter(item.value, item.data);\n },\n sortable: props.allowSort && value.sortableAndFilterable,\n comparator: value.comparer,\n cellClass: (cellClassParams: CellClassParams) => {\n // Don't apply classes to grouped rows as they contain no data\n if (!cellClassParams.data || cellClassParams.node.group) {\n return undefined;\n }\n\n const cellClasses = props.rowClasses({\n item: cellClassParams.data,\n });\n\n cellClasses.push(value.classExtractor(cellClassParams.data));\n\n return cellClasses;\n },\n headerClass,\n rowGroup: columnIsGroup,\n // Permanently hide grouped columns (we currently don't support\n // reactively changing which grid columns to group by). If a column\n // isn't grouped, keep the default value of undefined, not false.\n // Grid column state will override this value depending on bm grid\n // state, but cannot if the value is set to false here.\n hide: columnIsGroup || undefined,\n suppressMovable: columnIsGroup,\n };\n\n /**\n * Recursively extract row keys of the given row node and all of\n * its parent row nodes\n */\n const extractAllParentRowKeys = (rowNode: RowNode): string[] => {\n if (!rowNode.parent || !rowNode.key) {\n return [];\n }\n\n return [...extractAllParentRowKeys(rowNode.parent), rowNode.key];\n };\n\n if (columnKeyToAggregator[columnKey]) {\n columnDef.aggFunc = (param) => {\n const aggregatorFunction = columnKeyToAggregator[columnKey];\n\n if (!props.isFixedShapeReport) {\n return aggregatorFunction(param.values);\n }\n\n const parentGroupValues = extractAllParentRowKeys(\n param.rowNode\n );\n\n const groupRowValue = parentGroupValues.pop() ?? \"\";\n\n return aggregatorFunction(\n param.values,\n groupRowValue,\n parentGroupValues\n );\n };\n }\n\n if (value.rendererMetadata.actions) {\n columnDef.headerName = \"\";\n columnDef.lockPinned = true;\n columnDef.pinned = \"right\";\n columnDef.width = 36;\n columnDef.maxWidth = 36;\n columnDef.resizable = false;\n columnDef.suppressAutoSize = true;\n\n columnDef.cellClass = \"no-padding\";\n columnDef.cellStyle = {\n textAlign: \"center\",\n };\n }\n columnDef.cellStyle = {\n textAlign: value.align,\n };\n\n if (value.matcher.name === \"dateMatcher\") {\n columnDef.getQuickFilterText = (\n params: GetQuickFilterTextParams\n ): string =>\n params.value ? tenantService.formatDate(params.value) : \"\";\n }\n\n // Only use our custom cell renderer if we're not rendering a\n // grouped column. Otherwise use AG Grid's default grouped column\n // renderer\n if (!columnDef.rowGroup) {\n columnDef.cellRenderer = \"BmGridCellRendererWrapper\";\n\n columnDef.cellRendererParams = {\n context: {\n value,\n items: props.items,\n },\n };\n }\n\n value.rendererMetadata.isAgTruncated =\n !!value.rendererMetadata.textTruncationOptions;\n\n if (\n props.allowExpand &&\n !columnDef.rowGroup &&\n !groupedCellRendererAssigned &&\n !columnKeyToAggregator[columnKey] &&\n !props.gridState.removedColumnKeys.includes(columnDef.colId!)\n ) {\n groupedCellRendererAssigned = true;\n columnDef.cellRenderer = \"agGroupCellRenderer\";\n columnDef.cellRendererParams = {\n innerRenderer: \"BmGridCellRendererWrapper\",\n innerRendererParams: {\n context: {\n value,\n items: props.items,\n },\n },\n };\n }\n\n return columnDef;\n }\n );\n\n if (props.allowSelect) {\n defs.unshift({\n colId: internalRowSelectColId,\n headerName: \"\",\n width: 36,\n maxWidth: 36,\n lockPinned: true,\n resizable: false,\n suppressAutoSize: true,\n cellStyle: {\n textAlign: \"center\",\n paddingLeft: \"8px\",\n },\n checkboxSelection: true,\n headerCheckboxSelection: true,\n headerClass: \"checkbox\",\n showDisabledCheckboxes: true,\n headerCheckboxSelectionFilteredOnly: true,\n lockPosition: \"left\",\n });\n }\n\n if (props.allowDrag) {\n defs.unshift({\n colId: \"internalDragHandle\",\n headerName: \"\",\n width: 36,\n maxWidth: 36,\n lockPinned: true,\n pinned: \"left\",\n resizable: false,\n suppressAutoSize: true,\n cellStyle: {\n textAlign: \"center\",\n paddingLeft: \"8px\",\n },\n rowDrag: true,\n });\n }\n\n columnDefs.value = defs;\n updateAgGridStateFromBmGridState();\n },\n { immediate: true, deep: true }\n );\n\n watch(() => props.gridState, updateAgGridStateFromBmGridState, {\n deep: true,\n });\n\n const columnMap = computed(() => {\n const columns = gridColumnApi.value?.getColumns() ?? [];\n\n // get all configurations for the visible columns\n return columns.reduce((acc, column) => {\n const colId = column.getColId();\n const columnConfiguration = props.gridConfiguration.columns[colId];\n if (columnConfiguration) {\n acc.set(colId, columnConfiguration);\n }\n return acc;\n }, new Map());\n });\n\n const doesExternalFilterPass = (node: RowNode) => {\n // get all filters from gridState\n const filters = props.gridState.columnFilters;\n\n for (const filterColumnId of Object.keys(filters)) {\n const columnConfiguration = columnMap.value.get(filterColumnId);\n if (columnConfiguration) {\n const filterFunction = columnConfiguration.columnFilter?.buildApply(\n filters[filterColumnId]\n );\n if (filterFunction) {\n if (\n !filterFunction(\n columnConfiguration.extractor(node.data),\n columnConfiguration.extractAndFormat(node.data)\n )\n ) {\n return false;\n }\n }\n }\n }\n // if no filters are set, return true\n // if all filters pass, return true\n return true;\n };\n\n /**\n * Intelligently resizes ag grid columns.\n *\n * 'autoSizeAllColumns' achieves 90% of the goal using 'excel double click' widths. However if the content is too\n * small for the width then it creates a slightly ugly gap after the last column to our pinned action column.\n *\n * This code stretches the last column to fill the remaining space in the grid.\n *\n * TODO: this doesn't work nicely with row grouping enabled\n */\n const resizeColumns = (params: AgGridEvent) => {\n let refreshColumnDefs = false;\n // Applies auto sizing to all columns which sizes using \"excel double click\" logic on the visible rows.\n params.columnApi.autoSizeAllColumns();\n\n const clientWidth = agGridRef.value?.$el.clientWidth;\n // if we know the full width then we look to fill remaining space.\n if (!clientWidth) {\n return;\n }\n\n const displayedColumns = params.columnApi.getAllDisplayedColumns();\n\n if (displayedColumns.length <= 1) {\n return;\n }\n\n const colDefs =\n (params.api.getColumnDefs() as ColDef[] | undefined) ?? [];\n\n // Set all of our saved widths before all of our calculations\n colDefs.forEach((colDef) => {\n if (!colDef.colId) {\n return;\n }\n\n const savedWidth = props.gridState.columnPixelWidthMap.get(\n colDef.colId\n );\n\n if (savedWidth === undefined) {\n return;\n }\n\n if (colDef.width !== savedWidth) {\n colDef.width = savedWidth;\n refreshColumnDefs = true;\n }\n });\n\n let totalRenderedWidths = displayedColumns?.reduce(\n (sum, col) => (sum += col.getActualWidth()),\n 0\n );\n\n const columnDefMap = displayedColumns.reduce((acc, col) => {\n const colDef = colDefs.find((x) => x.colId === col.getColId());\n if (colDef) {\n acc.set(col.getColId(), colDef);\n }\n return acc;\n }, new Map());\n\n // AdjustableColumnsCount is the number of columns we can adjust the width of minus any pinned columns.\n // Note: internal row select is \"pinned\" but we don't set it as pinned in the column definition (for styling\n // reasons), so exclude it from the adjustableColumnsCount too\n const adjustableColumnsCount = displayedColumns.filter(\n (x) => !x.isPinned() && x.getColId() !== internalRowSelectColId\n ).length;\n\n // if overflow then remove space from truncated columns\n\n if (clientWidth < totalRenderedWidths + GRID_OVERFLOW_SPACER) {\n const truncatedCols = displayedColumns.filter((col) => {\n const colDef = columnDefMap.get(col.getColId());\n return colDef ? isAgTruncated(colDef) : false;\n });\n if (truncatedCols.length) {\n const truncationInitialMinSize = 250; // initial min size for all truncatable columns\n const truncationInitialMaxSize =\n (clientWidth / (displayedColumns.length ?? 1)) * 2; // initial max size is the min size multiplied by 2\n\n const delta =\n clientWidth - totalRenderedWidths - GRID_OVERFLOW_SPACER;\n const deltaPerColumn = Math.floor(delta / truncatedCols.length);\n\n // Adjust the width of the truncated columns\n truncatedCols.forEach((col) => {\n // Ignore truncation if we're a saved width\n if (props.gridState.columnPixelWidthMap.get(col.getColId())) {\n return;\n }\n const colWidth = col.getActualWidth();\n let newColWidth = colWidth + deltaPerColumn;\n\n if (newColWidth < truncationInitialMinSize) {\n newColWidth = truncationInitialMinSize;\n } else if (newColWidth > truncationInitialMaxSize) {\n newColWidth = truncationInitialMaxSize;\n }\n\n const colDef = columnDefMap.get(col.getColId());\n if (colDef) {\n colDef.width = newColWidth;\n totalRenderedWidths += newColWidth - colWidth;\n }\n });\n refreshColumnDefs = true;\n }\n }\n\n // Is there currently a visible gap\n if (clientWidth > totalRenderedWidths) {\n // is there a pinned right column?\n const delta = clientWidth - totalRenderedWidths - GRID_OVERFLOW_SPACER;\n\n // apply delta to all columns evenly\n let deltaPerColumn = Math.floor(delta / adjustableColumnsCount);\n let remainder = delta % adjustableColumnsCount;\n displayedColumns.forEach((col, index) => {\n const colDef = columnDefMap.get(col.getColId());\n\n // Ignore resizing if we're a saved width\n if (props.gridState.columnPixelWidthMap.get(col.getColId())) {\n return;\n }\n\n // if not actions column and is displayed then apply delta\n if (colDef && colDef.width && !colDef.pinned) {\n if (index === adjustableColumnsCount - 1) {\n // bump up the last row with any remaining delta\n colDef.width = colDef.width + remainder + deltaPerColumn;\n } else {\n colDef.width = colDef.width + deltaPerColumn;\n }\n }\n });\n refreshColumnDefs = true;\n }\n\n if (refreshColumnDefs) {\n params.api.setColumnDefs(colDefs); // A full def set is needed to re-layout the columns\n }\n };\n\n const getFilteredRowData = () => {\n let rowData: any[] = [];\n if (gridApi.value) {\n gridApi.value.forEachNodeAfterFilter((node) => rowData.push(node.data));\n }\n return rowData;\n };\n\n const onRowDragEnter = (event: RowDragEnterEvent) => {\n // Fired on dragStart and reEnter\n // Take a snapshot of the data before the drag starts\n if (dragStartedDataSnapshot.length === 0) {\n dragStartedDataSnapshot = [...getFilteredRowData()];\n }\n };\n\n const onRowDragLeave = (event: RowDragLeaveEvent) => {\n // Drag left the grid, reset state as we don't know if the drag will end or not\n gridApi.value?.setRowData(dragStartedDataSnapshot);\n dragStartedDataSnapshot = [];\n };\n\n const onRowDragEnd = (event: RowDragEndEvent) => {\n // Drag ended - Not fired if dropped outside of grid\n\n const draggedRowKey = getRowKey(event.node.data);\n const fromIndex = dragStartedDataSnapshot.findIndex(\n (x) => getRowKey(x) === draggedRowKey\n );\n\n if (fromIndex < 0 || fromIndex === event.overIndex) {\n return;\n }\n // Get the index of the item to drop under. Adjust for the fact that the dragged item has been removed from the list\n const toIndex = event.overIndex - (event.overIndex > fromIndex ? 0 : 1);\n\n context.emit(\"drag-drop\", {\n draggedRowKeys: [draggedRowKey],\n droppedOnRowKey: getRowKey(dragStartedDataSnapshot[toIndex]),\n } as GridDragDropEvent);\n\n dragStartedDataSnapshot = [];\n };\n\n const onRowDragMove = (event: RowDragMoveEvent) => {\n // Drag moving (only on the current grid)\n const movingNode = event.node;\n const overNode = event.overNode;\n const rowNeedsToMove = movingNode !== overNode;\n\n if (\n rowNeedsToMove &&\n event.overIndex !== undefined &&\n dragStartedDataSnapshot.length\n ) {\n const gridItems = [...dragStartedDataSnapshot];\n\n const fromIndex = gridItems.indexOf(movingNode.data);\n const toIndex = event.overIndex;\n\n // Move item in array for ag-grid to pick up and show movement\n const element = gridItems[fromIndex];\n gridItems.splice(fromIndex, 1);\n gridItems.splice(toIndex, 0, element);\n\n gridApi.value?.setRowData(gridItems);\n gridApi.value?.clearFocusedCell();\n }\n };\n\n watch(shouldUseFullHeight, () => {\n if (gridApi.value) {\n if (shouldUseFullHeight.value) {\n gridApi.value.setDomLayout(\"normal\");\n } else {\n gridApi.value.setDomLayout(\"autoHeight\");\n }\n }\n });\n\n const setPrinterMode = (printerMode: boolean) => {\n if (gridApi.value) {\n gridApi.value.setDomLayout(printerMode ? \"print\" : \"normal\");\n }\n };\n\n const updateFilterSummary = (displayedRowCount?: number) => {\n if (gridApi.value) {\n context.emit(\n \"filter-summary\",\n `${displayedRowCount ?? gridApi.value.getDisplayedRowCount()} / ${\n props.items.length\n } ${props.itemNoun}`\n );\n }\n };\n\n /**\n * Expand or collapse all grouped rows and master detail rows (expandable\n * rows).\n *\n * Note: there may be a noticeable performance hit if async calls are made\n * on row expansion.\n */\n const applyExpandCollapseAll = (opts: {\n expand: boolean;\n onlyExpandGroups?: boolean;\n }) => {\n if (opts.onlyExpandGroups) {\n opts.expand ? gridApi.value?.expandAll() : gridApi.value?.collapseAll();\n } else {\n gridApi.value?.forEachNode((node) => {\n node.setExpanded(opts.expand);\n });\n }\n };\n\n watch(\n () => props.defaultExpandGroups,\n (defaultExpandGroups) => {\n applyExpandCollapseAll({\n expand: defaultExpandGroups,\n onlyExpandGroups: true,\n });\n }\n );\n\n watch(\n () => props.defaultExpandExpandable,\n (defaultExpandExpandable) => {\n applyExpandCollapseAll({\n expand: defaultExpandExpandable,\n });\n }\n );\n\n const getRowId = (params: GetRowIdParams | RowNode) => {\n return getRowKey(params.data);\n };\n\n const getRowKey = (rowData: any) =>\n getPropertyFromItem(rowData, props.itemKey);\n\n watch(\n () => props.isLoading,\n () => {\n if (props.isLoading) {\n gridApi.value?.showLoadingOverlay();\n } else {\n gridApi.value?.hideOverlay();\n }\n }\n );\n\n const isAgTruncated = (column: ColDef) =>\n column.cellRendererParams?.context?.value?.rendererMetadata\n ?.isAgTruncated ?? false;\n\n const gridHeight = computed(\n () =>\n props.overrideHeight ||\n (shouldUseFullHeight.value ? props.height || \"70vh\" : \"\")\n );\n\n return () => {\n const propArgs: GridOptions = {\n rowData: props.items,\n defaultColDef: {\n resizable: true,\n },\n columnDefs: columnDefs.value,\n headerHeight: 36,\n doesExternalFilterPass,\n isExternalFilterPresent: () => true,\n suppressDragLeaveHidesColumns: true,\n suppressScrollOnNewData: true,\n alwaysShowHorizontalScroll: true,\n maintainColumnOrder: false,\n enableCellTextSelection: true,\n animateRows: true,\n // Some of our grids have had non-unique row Ids in the past, and these break when provided to AgGrid\n // so only provide row ids if requested to do so.\n getRowId: props.includeIds ? getRowId : undefined,\n rowSelection: \"multiple\",\n suppressRowClickSelection: true,\n isRowSelectable: (node) => props.rowSelectable({ item: node.data }), // @TODO: This matches our current grids layout, will need to be updated\n\n // fix for scrollbar overlapping / not easily draggable on Mac OS\n // https://github.com/ag-grid/ag-grid/issues/2962#issuecomment-674006902\n scrollbarWidth: isMacOs.value ? 15 : undefined,\n autoGroupColumnDef: {\n cellRendererParams: { suppressCount: true },\n },\n suppressAggFuncInHeader: true,\n masterDetail: props.allowExpand,\n detailCellRenderer: \"DetailCellRendererWrapper\",\n detailCellRendererParams: {\n renderFn: props.expandSlotRenderFn,\n },\n detailRowAutoHeight: true,\n isRowMaster: (rowData) => {\n return props.rowExpandable?.({ item: rowData }) ?? false;\n },\n groupDefaultExpanded: 0,\n };\n\n let onArgs: { [key: string]: Function | Function[] } = {};\n\n onArgs.cellClicked = async (event: CellClickedEvent) => {\n if (window.getSelection()?.type === \"Range\") {\n // text has been selected, so do not perform the click action.\n // Useful if the user is trying to select text out of the grid.\n // https://stackoverflow.com/questions/63453752/ag-grid-how-disable-cell-click-event-when-enablecelltextselection-is-used-and-t\n return;\n }\n\n if (event.colDef.colId === internalRowSelectColId) {\n // Toggle row selected state if the cell is selected so\n // the user doesn't have to click directly on the checkbox\n event.node.setSelected(!event.node.isSelected());\n return;\n }\n\n if (event.node.group) {\n // Prevent trying to evaluate rowClickRoute if a grouped row is\n // clicked (a grouped row has no data)\n return;\n }\n\n if (event.colDef.cellRenderer === \"agGroupCellRenderer\") {\n // Prevent trying to evaluate rowClickRoute if an expandable\n // cell is clicked\n return;\n }\n\n // Inner renderer params are used when BmGridCellRendererWrapper is\n // wrapped by a DetailCellRendererWrapper (cell that allows master\n // detail row to be expanded)\n const cellRendererParamsContext =\n event.colDef.cellRendererParams?.context ??\n event.colDef.cellRendererParams?.innerRendererParams.context;\n\n if (props.rowClickRoute) {\n const isEmailAddressCell =\n !!cellRendererParamsContext?.value.rendererMetadata.emailExtractor;\n\n const isPhoneNumberCell =\n !!cellRendererParamsContext?.value.rendererMetadata.phoneExtractor;\n\n const rowHasLocation =\n !!cellRendererParamsContext?.value.rendererMetadata\n .locationExtractor;\n\n const rowHasExternalLink =\n !!cellRendererParamsContext?.value.rendererMetadata\n .externalLinkExtractor;\n\n if (\n isEmailAddressCell ||\n isPhoneNumberCell ||\n rowHasLocation ||\n rowHasExternalLink\n ) {\n return;\n }\n\n const route = props.rowClickRoute(event.data);\n\n if (!route) {\n return;\n }\n\n await pushRouteOrNewWindow(route, event.event as any);\n return;\n }\n\n context.emit(\"row-click\", event.data);\n };\n\n onArgs.dragStopped = (e: DragStoppedEvent) => {\n const newColumnOrder = e.columnApi.getColumnState().map((c) => c.colId);\n props.gridState.applyColumnOrder(newColumnOrder);\n };\n\n onArgs.gridReady = async (params: GridReadyEvent) => {\n gridApi.value = params.api;\n gridColumnApi.value = params.columnApi;\n\n // Force update of current grid state\n updateAgGridStateFromBmGridState(props.gridState);\n if (localApp.value) {\n localApp.value.gridApi = gridApi.value;\n }\n };\n\n // AGGrid recommends performing column resizing after some data has been loaded.\n onArgs.firstDataRendered = (params: FirstDataRenderedEvent) => {\n initialDisplayedRowCount.value = params.api.getDisplayedRowCount();\n\n // ensure filter summary has correct row count on first load\n updateFilterSummary(initialDisplayedRowCount.value);\n resizeColumns(params);\n\n // set checkboxes as selected if the row key is selected\n params.api.forEachNode((node) => {\n if (props.selectedItemKeys.length) {\n node.setSelected(\n props.selectedItemKeys.includes(getRowKey(node.data))\n );\n }\n });\n\n applyExpandCollapseAll({\n expand: props.defaultExpandGroups || props.defaultExpandExpandable,\n onlyExpandGroups:\n props.defaultExpandGroups && !props.defaultExpandExpandable,\n });\n };\n\n onArgs.gridSizeChanged = (params: GridSizeChangedEvent) => {\n // @FIXME: [BREW-4824] Causes updates when grid overflows for the first time leading to grid trying to fit but unpredictable results\n resizeColumns(params);\n };\n\n onArgs.sortChanged = (params: SortChangedEvent) => {\n const agSortStatus = (params.columnApi?.getColumns() ?? [])\n .filter((column) => column.getSort())\n // sort by sort index asc desc or null\n .sort((a, b) => {\n if (a.getSortIndex() && b.getSortIndex()) {\n return 0;\n } else if (a.getSortIndex()) {\n return 1;\n } else if (b.getSortIndex()) {\n return -1;\n } else {\n return a.getSortIndex()! - b.getSortIndex()!;\n }\n })\n .map((column) => {\n const sort = column.getSort();\n return {\n columnKey: column.getColId(),\n descending: sort === \"desc\",\n };\n });\n\n // don't allow drag drop if we're sorting\n gridApi.value?.setSuppressRowDrag(agSortStatus.length > 0);\n props.gridState.applyExternalSorting(agSortStatus);\n };\n\n onArgs.filterChanged = () => {\n updateFilterSummary();\n };\n\n onArgs.rowDataUpdated = () => {\n updateFilterSummary();\n };\n\n onArgs.columnResized = (e: ColumnResizedEvent) => {\n // prevent persisting default auto-sized column widths if the\n // grid isn't visible\n if (!e.column || !agGridRef.value?.$el.clientWidth) {\n return;\n }\n\n props.gridState.setColumnPixelWidth(\n e.column.getColId(),\n e.column.getActualWidth()\n );\n };\n\n watch(selectedItemKeys, (newKeys, oldKeys) => {\n if (!newKeys || !oldKeys) {\n return;\n }\n\n // if deselecting all keys, ensure that ag grid performs deselection\n if (oldKeys.length > 0 && newKeys.length === 0) {\n gridApi.value?.deselectAll();\n }\n });\n\n onArgs.selectionChanged = (e: SelectionChangedEvent) => {\n const selectedRows = e.api.getSelectedRows();\n selectedItemKeys.value = selectedRows.map((row) => getRowKey(row));\n };\n\n onArgs.rowDragMove = onRowDragMove;\n onArgs.rowDragEnd = onRowDragEnd;\n onArgs.rowDragEnter = onRowDragEnter;\n onArgs.rowDragLeave = onRowDragLeave;\n\n onArgs.rowGroupOpened = (event: RowGroupOpenedEvent) => {\n if (event.data) {\n context.emit(\"expand-row\", { item: event.data });\n }\n };\n\n return h(AgGridVue, {\n class:\n appStore.state.theme === \"dark\"\n ? \"ag-theme-alpine-dark\"\n : \"ag-theme-alpine\",\n style: {\n width: \"100%\",\n height: gridHeight.value, // Allow AG grid to size automatically when not clipped\n },\n props: propArgs,\n on: onArgs, // Remove \"On\" Prefix from all events\n ref: agGridRef,\n });\n };\n },\n});\n","\n\n\n","\n\n\n\n\n\n\n","\n\n\n\n\n","\n\n\n\n\n","import type BaseEnumType from \"@/app/services/baseEnumType\";\n\nexport type FilterValue = BaseEnumType | string | number | null;\n\nexport type FilterType = {\n type: string;\n values: number;\n\n /**\n * Function should return true if the value is to be included (visible) otherwise false.\n * @param itemValue the raw item value can be null/object/etc.\n * @param formattedItemValue the formatted value can also be any type (depends on column type).\n * @param filterValue The value from the fitler state - will be string and not empty\n */\n applyFunc: (\n itemValue: any,\n formattedItemValue: any,\n filterValue: any\n ) => boolean;\n};\n\nexport type FilterState = {\n filter1: {\n type: string;\n value: FilterValue;\n };\n filter2?: {\n type: string;\n value: FilterValue;\n operator: \"and\" | \"or\";\n };\n};\n\nexport type FilterFunc = (itemValue: any, formattedItemValue: any) => boolean;\n\nfunction buildSingleApply(\n filterTypes: FilterType[],\n filterType: string,\n filterValue: FilterValue\n): FilterFunc {\n let filter = filterTypes.find((ft) => ft.type === filterType);\n if (filter === undefined) {\n return () => true;\n } else {\n return (itemValue: any, formattedItemValue: any) =>\n filter?.applyFunc(itemValue, formattedItemValue, filterValue) ?? false;\n }\n}\n\n/** Builds a function to evaluate the filter given a filter value and filter state **/\nexport function buildApplyFilter(\n state: FilterState,\n filterTypes: FilterType[]\n): FilterFunc {\n if (state?.filter1?.type && state.filter1.value !== \"\") {\n const applyFilter1 = buildSingleApply(\n filterTypes,\n state.filter1.type,\n state.filter1.value\n );\n if (\n state?.filter2?.type &&\n state?.filter2?.value &&\n state?.filter2?.operator\n ) {\n const applyFilter2 = buildSingleApply(\n filterTypes,\n state.filter2.type,\n state.filter2.value\n );\n if (state.filter2.operator === \"and\") {\n return (itemValue: any, formattedItemValue: any) =>\n applyFilter1(itemValue, formattedItemValue) &&\n applyFilter2(itemValue, formattedItemValue);\n }\n\n // or\n return (itemValue: any, formattedItemValue: any) =>\n applyFilter1(itemValue, formattedItemValue) ||\n applyFilter2(itemValue, formattedItemValue);\n } else {\n return applyFilter1;\n }\n } else {\n return () => true;\n }\n}\n","import type { VNode } from \"vue\";\nimport Vue from \"vue\";\nimport ColumnFilterComponent from \"@/components/controls/grid/columnfilters/ColumnFilterComponent.vue\";\nimport type { CreateElement } from \"vue/types/vue\";\nimport type {\n FilterFunc,\n FilterState,\n FilterType,\n} from \"@/components/controls/grid/columnfilters/ColumnFilters\";\nimport { buildApplyFilter } from \"@/components/controls/grid/columnfilters/ColumnFilters\";\nimport BmNumber from \"@/components/controls/input/BmNumber.vue\";\n\nconst numberFilterTypes: FilterType[] = [\n {\n type: \"filter_equals\",\n values: 1,\n applyFunc: (\n itemValue: any,\n formattedItemValue: any,\n filterValue: number | null\n ) =>\n filterValue != null\n ? !isNaN(Number(itemValue)) && Number(itemValue) === filterValue\n : true,\n },\n {\n type: \"filter_not_equals\",\n values: 1,\n applyFunc: (\n itemValue: any,\n formattedItemValue: any,\n filterValue: number | null\n ) =>\n filterValue != null\n ? !isNaN(Number(itemValue)) && Number(itemValue) !== filterValue\n : true,\n },\n {\n type: \"filter_greater_than\",\n values: 1,\n applyFunc: (\n itemValue: any,\n formattedItemValue: any,\n filterValue: number | null\n ) =>\n filterValue != null\n ? !isNaN(Number(itemValue)) && Number(itemValue) > filterValue\n : true,\n },\n {\n type: \"filter_less_than\",\n values: 1,\n applyFunc: (\n itemValue: any,\n formattedItemValue: any,\n filterValue: number | null\n ) =>\n filterValue != null\n ? !isNaN(Number(itemValue)) && Number(itemValue) < filterValue\n : true,\n },\n];\n\nexport function buildApplyNumberFilter(state: FilterState): FilterFunc {\n return buildApplyFilter(state, numberFilterTypes);\n}\n\nexport default Vue.extend({\n name: \"NumberFilterComponent\",\n components: { ColumnFilterComponent },\n render(h: CreateElement): VNode {\n return h(ColumnFilterComponent, {\n attrs: { ...this.$attrs },\n props: { filterTypes: numberFilterTypes },\n scopedSlots: {\n control1: (props: any) => {\n return h(BmNumber, {\n props: {\n defaultValue: null,\n value: props.value !== null ? Number(props.value) : null,\n },\n on: {\n input: (event: string | null) => {\n props.setValue(event);\n },\n },\n });\n },\n control2: (props: any) => {\n return h(BmNumber, {\n props: {\n defaultValue: null,\n value: props.value !== null ? Number(props.value) : null,\n },\n on: {\n input: (event: string | null) => {\n props.setValue(event);\n },\n },\n });\n },\n },\n });\n },\n});\n","\n\n\n","\n\n\n","import type {\n ColumnAlignment,\n ColumnFilter,\n ColumnFooterRenderer,\n Comparer,\n Matcher,\n Renderer,\n RowAction,\n} from \"@/components/controls/grid/BmGridData\";\nimport {\n BmGridColumnConfiguration,\n componentToRenderer,\n} from \"@/components/controls/grid/BmGridData\";\nimport DataCellActions from \"@/components/controls/grid/renderers/DataCellActions.vue\";\nimport type { EditableRendererMetadata } from \"@/components/controls/grid/renderers/editors/types\";\nimport type { VueConstructor } from \"vue\";\nimport DataCellControl from \"@/components/controls/grid/renderers/DataCellControl.vue\";\nimport type { Location } from \"vue-router\";\nimport { tenantService } from \"@/app/services/extensions/tenantServiceExtended\";\nimport NumberFilterComponent, {\n buildApplyNumberFilter,\n} from \"@/components/controls/grid/columnfilters/NumberColumnFilter\";\nimport Key from \"@/app/types/common/key\";\nimport type { BmEnumType } from \"@/app/services/baseEnumType\";\nimport type BaseEnumType from \"@/app/services/baseEnumType\";\nimport DataCellTextInfo from \"@/components/controls/grid/renderers/info/DataCellTextInfo.vue\";\nimport type { TruncateOptions } from \"lodash\";\nimport type { ComponentPublicInstanceConstructor } from \"vue/types/v3-component-public-instance\";\nimport messages, { translate } from \"@/plugins/i18n\";\n\nfunction isVueComponent(\n renderer: VueConstructor | Renderer\n): renderer is VueConstructor {\n return \"component\" in renderer;\n}\n\nexport interface ColumnBuilderDefaultState {\n hidden?: boolean;\n groupByIndex?: number;\n sortByIndex?: number;\n sortByDescending?: boolean;\n filterState?: {};\n}\n\nexport interface TextTruncationOptions extends TruncateOptions {\n title: string;\n props: any;\n width: number;\n extractor: (item: T) => any;\n}\n\nexport type ColumnKey = Key | { id: string; headingText: string };\n\nexport class ColumnBuilder {\n protected readonly _gridConfiguration: BmGridColumnConfiguration;\n protected readonly _defaultState: ColumnBuilderDefaultState = {};\n private readonly _columnKey: string;\n\n constructor(columnKey: ColumnKey, itemValue: (item: T) => any) {\n this._columnKey = columnKey instanceof Key ? columnKey.value : columnKey.id;\n\n this._gridConfiguration = new BmGridColumnConfiguration(\n columnKey instanceof Key ? translate(columnKey) : columnKey.headingText,\n itemValue,\n {\n groupable: true,\n sortableAndFilterable: true,\n }\n );\n }\n\n public build(): [string, BmGridColumnConfiguration] {\n return [this._columnKey, this._gridConfiguration];\n }\n\n public getDefaultState(): [string, ColumnBuilderDefaultState] {\n return [this._columnKey, this._defaultState];\n }\n\n public withHeadingText(headingText: string) {\n this._gridConfiguration.headingText = headingText;\n return this;\n }\n\n public withAlignment(alignment: ColumnAlignment) {\n this._gridConfiguration.align = alignment;\n return this;\n }\n\n public withCardColumnSpan(cardColumnSpan: number) {\n this._gridConfiguration.cardColumnSpan = cardColumnSpan;\n return this;\n }\n\n public withRenderer(renderer: Renderer) {\n this._gridConfiguration.renderer = renderer;\n return this;\n }\n\n public withComparer(comparer: Comparer) {\n this._gridConfiguration.comparer = comparer;\n return this;\n }\n\n public withMatcher(matcher: Matcher) {\n this._gridConfiguration.matcher = matcher;\n return this;\n }\n\n public withEnumType(enumType: BmEnumType) {\n this._gridConfiguration.enumType = enumType;\n return this;\n }\n\n public withEnumFilter(enumFilter: (item: BaseEnumType) => boolean) {\n this._gridConfiguration.enumFilter = enumFilter;\n return this;\n }\n\n public allowGrouping(allow: boolean = true) {\n this._gridConfiguration.groupable = allow;\n return this;\n }\n\n public setRemovable(removable: boolean) {\n this._gridConfiguration.removable = removable;\n return this;\n }\n\n public allowSortingAndFiltering(allow: boolean = true) {\n this._gridConfiguration.sortableAndFilterable = allow;\n return this;\n }\n\n public showInGridControls(showInGridControls: boolean = true) {\n this._gridConfiguration.showInGridControls = showInGridControls;\n return this;\n }\n\n public withSuffixExtractor(suffixExtractor: (item: T, value: any) => any) {\n this._gridConfiguration.rendererMetadata.suffixExtractor = suffixExtractor;\n return this;\n }\n\n public withPrefixExtractor(prefixExtractor: (item: T, value: any) => any) {\n this._gridConfiguration.rendererMetadata.prefixExtractor = prefixExtractor;\n return this;\n }\n\n public withClassExtractor(classExtractor: (item: T) => string) {\n this._gridConfiguration.classExtractor = classExtractor;\n return this;\n }\n\n public withFormatter(formatter: (value: any, item: T | undefined) => any) {\n this._gridConfiguration.formatter = formatter;\n return this;\n }\n\n public withIconSuffix(iconSuffixExtractor: (item: T, value: any) => any) {\n this._gridConfiguration.rendererMetadata.iconSuffixExtractor =\n iconSuffixExtractor;\n return this;\n }\n\n public withCsvFormatter(\n formatter: (\n value: any,\n item: T | undefined,\n stringFormatter: (s: string) => string\n ) => string\n ) {\n this._gridConfiguration.csvformatter = formatter;\n return this;\n }\n\n /**\n * Allows for router-links inside grids, does not work inconjunction with @row-click behaviours, or non-text fields.\n *\n * @param locationExtractor To return a router route definition to redirect to\n * @param openInNewTab Open link in a new tab\n */\n public withRoutingLink(\n locationExtractor: (item: T, value: any) => Location | null,\n opts: { openInNewTab?: boolean } = { openInNewTab: true }\n ) {\n this._gridConfiguration.rendererMetadata.locationExtractor =\n locationExtractor;\n this._gridConfiguration.rendererMetadata.newTab = opts.openInNewTab;\n return this;\n }\n\n public withExternalLink(\n externalLinkExtractor: (item: T, value: any) => string | null,\n openInNewTab: boolean = true\n ) {\n this._gridConfiguration.rendererMetadata.externalLinkExtractor =\n externalLinkExtractor;\n this._gridConfiguration.rendererMetadata.newTab = openInNewTab;\n return this;\n }\n\n public withEmailLink(itemExtractor: (item: T, value: any) => string | null) {\n this._gridConfiguration.rendererMetadata.emailExtractor = itemExtractor;\n return this;\n }\n\n public withPhoneLink(itemExtractor: (item: T, value: any) => string | null) {\n this._gridConfiguration.rendererMetadata.phoneExtractor = itemExtractor;\n return this;\n }\n\n public defaultSort(sortRankIndex: number = 0, isDecending = false) {\n this._defaultState.sortByIndex = sortRankIndex;\n this._defaultState.sortByDescending = isDecending;\n return this;\n }\n\n public defaultHide(hide: boolean = true) {\n this._defaultState.hidden = true;\n return this;\n }\n\n public defaultGroupBy(groupRankIndex: number = 0) {\n this._defaultState.groupByIndex = groupRankIndex;\n return this;\n }\n\n public defaultApplyFilter(filter: any) {\n this._defaultState.filterState = filter;\n return this;\n }\n\n public defaultApplyShowBooleanFalseFilter() {\n this._defaultState.filterState = {\n filter1: {\n type: \"filter_equals\",\n value: false,\n },\n // We need to provide both filters, otherwise it seems to break\n filter2: {\n type: \"filter_show_all\",\n value: \"\",\n operator: \"and\",\n },\n };\n return this;\n }\n\n public showNarrow(narrow = true) {\n this._gridConfiguration.shrink = narrow;\n return this;\n }\n\n /**\n * Add editing capabilities (via popup dialog) to the values within a column.\n *\n * @param renderer The renderer that will render the cell and provide an editing GUI.\n * @param editInserter Function to insert the modified data back into the row item.\n * @param editControlProps Object of properties to assign to the edit control. For example you can add validation\n * rules via the 'rules' property or set any property that is suitable to the underlying control.\n * @param editDialogTitle A custom title to add to the dialog. Defaults to the column heading text.\n * @param editItemValue A custom extractor for the edit control. Defaults to the column extractor (with no formatter).\n * @param dialogWidth A custom width for the dialog in pixels. Defaults to 200px.\n * @param rowEditable A custom extractor to determine if a row is editable or not.\n */\n public withEditDialog(\n renderer: Renderer | VueConstructor,\n editInserter: (item: T, value: any) => void,\n editControlProps: object | ((item: T) => object) = {},\n editDialogTitle?: string,\n editItemValue?: (item: T) => any,\n dialogWidth: number = 200,\n rowEditable?: (item: T) => boolean\n ) {\n this._gridConfiguration.renderer = isVueComponent(renderer)\n ? componentToRenderer(renderer)\n : renderer;\n this._gridConfiguration.rendererMetadata.editRenderer = {\n editDialogTitle:\n editDialogTitle !== undefined\n ? editDialogTitle\n : this._gridConfiguration.headingText,\n editItemValue: editItemValue || this._gridConfiguration.extractor,\n editInserter,\n editControlProps,\n dialogWidth,\n rowEditable: rowEditable || (() => true),\n } as EditableRendererMetadata;\n return this;\n }\n\n /**\n * Truncates text if it is over a given length and allows for a dialog to replace\n * Defaults to length 30\n * @TODO: Parameters are not used for AG grid. Update when BM Grid is updated.\n *\n * @param options Customize how the text truncations behaves\n */\n\n public withTextTruncation(options?: Partial>) {\n this._gridConfiguration.renderer = componentToRenderer(DataCellTextInfo);\n\n this._gridConfiguration.rendererMetadata.textTruncationOptions = {\n length: options?.length ?? 30,\n title: options?.title ?? this._gridConfiguration.headingText,\n props: options?.props,\n width: options?.width ?? 800,\n separator: options?.separator ?? \" \",\n omission: options?.omission ?? \"...\",\n extractor: this._gridConfiguration.extractor,\n } as TextTruncationOptions;\n\n return this;\n }\n\n /** Adds a per-column footer\n * NB This is only used in table-view, as a per-column footer does not make sense for cards.\n * Use the Summary section for a footer under the card view\n * @param renderer\n */\n public withFooter(renderer: ColumnFooterRenderer) {\n this._gridConfiguration.footer = renderer;\n return this;\n }\n\n public withColumnFilter(columnFilter: ColumnFilter) {\n this._gridConfiguration.columnFilter = columnFilter;\n return this;\n }\n}\n\nexport class ActionColumnBuilder extends ColumnBuilder {\n constructor(columnKey: ColumnKey) {\n super(columnKey, () => undefined);\n this.allowSortingAndFiltering(false).withRenderer(\n componentToRenderer(DataCellActions)\n );\n }\n\n public withAction(\n translation: string | ((item: T) => string),\n onClick: (item: T) => void,\n isActive: (item: T) => boolean = (): boolean => true\n ) {\n this._gridConfiguration.rendererMetadata.actions =\n this._gridConfiguration.rendererMetadata.actions || [];\n\n this._gridConfiguration.rendererMetadata.actions.push({\n translation:\n translation instanceof Function ? translation : () => translation,\n onClick,\n isActive,\n });\n\n return this;\n }\n\n public withHideUnhide(\n itemIsHidden: (item: T) => boolean,\n performToggle: (item: T) => void,\n isActive: (item: T) => boolean = (): boolean => true\n ) {\n return this.withAction(\n (item) => (itemIsHidden(item) ? messages.unhide : messages.hide),\n performToggle,\n isActive\n );\n }\n\n /**\n * @deprecated Use withAction instead, passing text not key.\n */\n public withActionByKey(\n translationKeyOrFn: Key | ((item: T) => Key),\n onClick: (item: T) => void,\n isActive: (item: T) => boolean = (): boolean => true\n ) {\n this._gridConfiguration.rendererMetadata.actions =\n this._gridConfiguration.rendererMetadata.actions || [];\n\n this._gridConfiguration.rendererMetadata.actions.push({\n translation:\n translationKeyOrFn instanceof Function\n ? (item: T) => translate(translationKeyOrFn(item))\n : () => translate(translationKeyOrFn),\n onClick,\n isActive,\n });\n\n return this;\n }\n\n public withRoutingAction(\n translation: string | ((item: T) => string),\n route: ((item: T) => Location) | Location,\n isActive: (item: T) => boolean = (): boolean => true\n ) {\n this._gridConfiguration.rendererMetadata.actions =\n this._gridConfiguration.rendererMetadata.actions || [];\n\n this._gridConfiguration.rendererMetadata.actions.push({\n translation:\n translation instanceof Function ? translation : () => translation,\n route,\n isActive,\n });\n\n return this;\n }\n\n /**\n * @deprecated Use withRoutingAction instead, passing text not key.\n */\n public withRoutingActionByKey(\n translationKeyOrFn: Key | ((item: T) => Key),\n route: ((item: T) => Location) | Location,\n isActive: (item: T) => boolean = (): boolean => true\n ) {\n this._gridConfiguration.rendererMetadata.actions =\n this._gridConfiguration.rendererMetadata.actions || [];\n\n this._gridConfiguration.rendererMetadata.actions.push({\n translation:\n translationKeyOrFn instanceof Function\n ? (item: T) => translate(translationKeyOrFn(item))\n : () => translate(translationKeyOrFn),\n route,\n isActive,\n });\n\n return this;\n }\n\n public withActions(actionBuilder: (item: T) => RowAction[]) {\n this._gridConfiguration.rendererMetadata.actions =\n this._gridConfiguration.rendererMetadata.actions || [];\n\n this._gridConfiguration.rendererMetadata.actions.push(actionBuilder);\n return this;\n }\n}\n\nexport class NumberColumnBuilder extends ColumnBuilder {\n constructor(\n columnKey: ColumnKey,\n itemValue: (item: T) => number | null,\n integral: boolean,\n maxDecimalPlaces?: number\n ) {\n super(columnKey, itemValue);\n\n this.withFormatter((itemValue: number | null) => {\n if (itemValue == null) {\n return \"-\";\n }\n\n if (integral) {\n return itemValue.toFixed(0);\n } else {\n return tenantService.formatNumber(\n itemValue,\n undefined,\n maxDecimalPlaces\n );\n }\n });\n\n this.withCsvFormatter((value: number | null) => {\n if (value == null) {\n return \"\";\n }\n if (integral) {\n return value.toFixed(0);\n } else {\n return value.toString(10);\n }\n });\n\n this.withColumnFilter({\n columnFilterComponent: NumberFilterComponent,\n buildApply: buildApplyNumberFilter,\n });\n }\n}\n\nexport class ControlColumnBuilder extends ColumnBuilder {\n constructor(\n columnKey: ColumnKey,\n itemValue: (item: T) => any = () => undefined\n ) {\n super(columnKey, itemValue);\n this.withRenderer(componentToRenderer(DataCellControl));\n }\n\n /**\n * Define the control to render in the column.\n *\n * @param component The component constructor.\n * @param propBinder function that configures the properties to bind. https://vuejs.org/v2/api/#v-bind\n * @param eventBinder function that configures the events to bind. Look at object syntax for v-on: https://vuejs.org/v2/api/#v-on\n * @param contentBinder function that provides the content to render as a child of the control.\n */\n withControl(\n component: VueConstructor | ComponentPublicInstanceConstructor,\n propBinder?: (item: any) => any,\n eventBinder?: (item: any) => any,\n contentBinder?: (item: any) => any\n ) {\n this._gridConfiguration.rendererMetadata.control = {\n component,\n propBinder,\n eventBinder,\n contentBinder,\n };\n return this;\n }\n}\n","import type {\n GroupSummaryValueExtractor,\n Renderer,\n SummaryExtractor,\n} from \"@/components/controls/grid/BmGridData\";\nimport {\n BmGridSummaryConfiguration,\n SummaryPlacement,\n} from \"@/components/controls/grid/BmGridData\";\n\nexport class SummaryBuilder {\n protected readonly _summary: BmGridSummaryConfiguration;\n\n constructor(\n extractor: SummaryExtractor,\n aggregator: GroupSummaryValueExtractor\n ) {\n this._summary = new BmGridSummaryConfiguration(extractor, aggregator, {});\n }\n\n public build(): BmGridSummaryConfiguration {\n return this._summary;\n }\n\n public alignWithGroupedColumn(columnKey: string) {\n this._summary.placement = SummaryPlacement.Column;\n this._summary.columnKey = columnKey;\n return this;\n }\n\n public withRenderer(renderer: Renderer) {\n this._summary.renderer = renderer;\n return this;\n }\n\n public withSuffixExtractor(suffixExtractor: (item: any, value: any) => any) {\n this._summary.rendererMetadata.suffixExtractor = suffixExtractor;\n return this;\n }\n}\n\nexport class NumberSummaryBuilder extends SummaryBuilder {\n constructor(\n extractor: SummaryExtractor,\n aggregator: GroupSummaryValueExtractor\n ) {\n super(extractor, aggregator);\n }\n}\n\nexport class IconSummaryBuilder extends SummaryBuilder {\n constructor(\n extractor: SummaryExtractor,\n aggregator: GroupSummaryValueExtractor\n ) {\n super(extractor, aggregator);\n }\n}\n","\n\n\n","import type { VNode } from \"vue\";\nimport Vue from \"vue\";\nimport ColumnFilterComponent from \"@/components/controls/grid/columnfilters/ColumnFilterComponent.vue\";\nimport type { CreateElement } from \"vue/types/vue\";\nimport type {\n FilterFunc,\n FilterState,\n FilterType,\n} from \"@/components/controls/grid/columnfilters/ColumnFilters\";\nimport { buildApplyFilter } from \"@/components/controls/grid/columnfilters/ColumnFilters\";\n\n/**\n * Performs filtering with text. Note. these are not taking into account locales differences.\n */\nconst textFilterTypes: FilterType[] = [\n {\n type: \"filter_contains\",\n values: 1,\n applyFunc: (itemValue: any, formattedItemValue: any, filterValue: string) =>\n !!formattedItemValue &&\n formattedItemValue\n .toString()\n .toUpperCase()\n .indexOf(filterValue.toUpperCase()) !== -1,\n },\n {\n type: \"filter_not_contains\",\n values: 1,\n applyFunc: (itemValue: any, formattedItemValue: any, filterValue: string) =>\n !!formattedItemValue &&\n formattedItemValue\n .toString()\n .toUpperCase()\n .indexOf(filterValue.toUpperCase()) === -1,\n },\n {\n type: \"filter_starts_with\",\n values: 1,\n applyFunc: (itemValue: any, formattedItemValue: any, filterValue: string) =>\n !!formattedItemValue &&\n formattedItemValue\n .toString()\n .toUpperCase()\n .startsWith(filterValue.toUpperCase()),\n },\n {\n type: \"filter_ends_with\",\n values: 1,\n applyFunc: (itemValue: any, formattedItemValue: any, filterValue: string) =>\n !!formattedItemValue &&\n formattedItemValue\n .toString()\n .toUpperCase()\n .endsWith(filterValue.toUpperCase()),\n },\n {\n type: \"filter_equals\",\n values: 1,\n applyFunc: (itemValue: any, formattedItemValue: any, filterValue: string) =>\n !!formattedItemValue &&\n formattedItemValue.toString().toUpperCase() === filterValue.toUpperCase(),\n },\n {\n type: \"filter_not_equals\",\n values: 1,\n applyFunc: (itemValue: any, formattedItemValue: any, filterValue: string) =>\n !!formattedItemValue &&\n formattedItemValue.toString().toUpperCase() !== filterValue.toUpperCase(),\n },\n];\n\nexport function buildApplyTextFilter(state: FilterState): FilterFunc {\n return buildApplyFilter(state, textFilterTypes);\n}\n\nexport default Vue.extend({\n name: \"TextFilterComponent\",\n components: { ColumnFilterComponent },\n render(h: CreateElement): VNode {\n return h(ColumnFilterComponent, {\n attrs: { ...this.$attrs },\n props: { filterTypes: textFilterTypes },\n });\n },\n});\n","import type { VNode } from \"vue\";\nimport Vue from \"vue\";\nimport ColumnFilterComponent from \"@/components/controls/grid/columnfilters/ColumnFilterComponent.vue\";\nimport type { CreateElement } from \"vue/types/vue\";\nimport type {\n FilterFunc,\n FilterState,\n FilterType,\n} from \"@/components/controls/grid/columnfilters/ColumnFilters\";\nimport { buildApplyFilter } from \"@/components/controls/grid/columnfilters/ColumnFilters\";\nimport { LocalDate } from \"@js-joda/core\";\nimport BmDate from \"@/components/controls/input/BmDate.vue\";\n\nfunction isLocalDate(toTest: any): toTest is LocalDate {\n return (toTest as LocalDate)?.chronology !== undefined;\n}\n\nconst dateFilterTypes: FilterType[] = [\n {\n type: \"filter_equals\",\n values: 1,\n applyFunc: (itemValue: any, formattedItemValue: any, filterValue: any) => {\n return filterValue\n ? isLocalDate(itemValue) &&\n itemValue.isEqual(LocalDate.parse(filterValue))\n : true;\n },\n },\n {\n type: \"filter_not_equals\",\n values: 1,\n applyFunc: (itemValue: any, formattedItemValue: any, filterValue: any) => {\n return filterValue\n ? isLocalDate(itemValue) &&\n !itemValue.isEqual(LocalDate.parse(filterValue))\n : true;\n },\n },\n {\n type: \"filter_after\",\n values: 1,\n applyFunc: (itemValue: any, formattedItemValue: any, filterValue: any) => {\n return filterValue\n ? isLocalDate(itemValue) &&\n itemValue.isAfter(LocalDate.parse(filterValue))\n : true;\n },\n },\n {\n type: \"filter_before\",\n values: 1,\n applyFunc: (itemValue: any, formattedItemValue: any, filterValue: any) => {\n return filterValue\n ? isLocalDate(itemValue) &&\n itemValue.isBefore(LocalDate.parse(filterValue))\n : true;\n },\n },\n];\n\nfunction createControlSlot(createElement: CreateElement): any {\n return function (props: any) {\n return createElement(BmDate, {\n props: {\n clearable: true,\n value: props.value ? LocalDate.parse(props.value) : null,\n },\n on: {\n input: function (event: LocalDate) {\n props.setValue(event?.toString() ?? \"\"); // ISO-8601\n },\n },\n });\n };\n}\n\nexport function buildApplyDateFilter(state: FilterState): FilterFunc {\n return buildApplyFilter(state, dateFilterTypes);\n}\n\nexport default Vue.extend({\n name: \"DateFilterComponent\",\n components: { ColumnFilterComponent },\n render(createElement: CreateElement): VNode {\n return createElement(ColumnFilterComponent, {\n attrs: { ...this.$attrs },\n props: { filterTypes: dateFilterTypes },\n scopedSlots: {\n control1: function (props: any) {\n return createElement(BmDate, {\n props: {\n clearable: true,\n value: props.value ? LocalDate.parse(props.value) : null,\n },\n on: {\n input: function (event: LocalDate) {\n props.setValue(event?.toString() ?? \"\"); // ISO-8601\n },\n },\n });\n },\n control2: function (props: any) {\n return createElement(BmDate, {\n props: {\n clearable: true,\n value: props.value ? LocalDate.parse(props.value) : null,\n },\n on: {\n input: function (event: LocalDate) {\n props.setValue(event?.toString() ?? \"\"); // ISO-8601\n },\n },\n });\n },\n },\n });\n },\n});\n","import type { VNode } from \"vue\";\nimport Vue from \"vue\";\nimport ColumnFilterComponent from \"@/components/controls/grid/columnfilters/ColumnFilterComponent.vue\";\nimport type { CreateElement } from \"vue/types/vue\";\nimport type {\n FilterFunc,\n FilterState,\n FilterType,\n} from \"@/components/controls/grid/columnfilters/ColumnFilters\";\nimport { buildApplyFilter } from \"@/components/controls/grid/columnfilters/ColumnFilters\";\nimport { Instant } from \"@js-joda/core\";\nimport BmDateTime from \"@/components/controls/input/BmDateTime.vue\";\nimport { tenantService } from \"@/app/services/extensions/tenantServiceExtended\";\n\nfunction isInstant(toTest: any): toTest is Instant {\n return (toTest as Instant)?.epochSecond !== undefined;\n}\n\nconst dateTimeFilterTypes: FilterType[] = [\n {\n type: \"filter_after\",\n values: 1,\n applyFunc: (itemValue: any, formattedItemValue: any, filterValue: any) => {\n if (!filterValue) {\n return true;\n }\n\n return (\n isInstant(itemValue) && itemValue.isAfter(Instant.parse(filterValue))\n );\n },\n },\n {\n type: \"filter_before\",\n values: 1,\n applyFunc: (itemValue: any, formattedItemValue: any, filterValue: any) => {\n if (!filterValue) {\n return true;\n }\n\n return (\n isInstant(itemValue) && itemValue.isBefore(Instant.parse(filterValue))\n );\n },\n },\n {\n type: \"filter_on_date\",\n values: 1,\n applyFunc: (itemValue: any, formattedItemValue: any, filterValue: any) => {\n if (!filterValue) {\n return true;\n }\n\n const itemDate = tenantService.instantToDate(itemValue);\n const filterDate = tenantService.instantToDate(\n Instant.parse(filterValue)\n );\n\n return isInstant(itemValue) && itemDate.equals(filterDate);\n },\n },\n];\n\nexport function buildApplyDateTimeFilter(state: FilterState): FilterFunc {\n return buildApplyFilter(state, dateTimeFilterTypes);\n}\n\nexport default Vue.extend({\n name: \"DateTimeColumnFilter\",\n components: { ColumnFilterComponent },\n render(createElement: CreateElement): VNode {\n return createElement(ColumnFilterComponent, {\n attrs: { ...this.$attrs },\n props: { filterTypes: dateTimeFilterTypes },\n scopedSlots: {\n control1: function (props: any) {\n return createElement(BmDateTime, {\n props: {\n clearable: true,\n value: props.value ? Instant.parse(props.value) : null,\n },\n on: {\n input: function (event: Instant) {\n props.setValue(event?.toString() ?? \"\"); // ISO-8601\n },\n },\n });\n },\n control2: function (props: any) {\n return createElement(BmDateTime, {\n props: {\n clearable: true,\n value: props.value ? Instant.parse(props.value) : null,\n },\n on: {\n input: function (event: Instant) {\n props.setValue(event?.toString() ?? \"\"); // ISO-8601\n },\n },\n });\n },\n },\n });\n },\n});\n","import type { VNode } from \"vue\";\nimport Vue from \"vue\";\nimport ColumnFilterComponent from \"@/components/controls/grid/columnfilters/ColumnFilterComponent.vue\";\nimport type { CreateElement } from \"vue/types/vue\";\nimport type {\n FilterFunc,\n FilterState,\n FilterType,\n} from \"@/components/controls/grid/columnfilters/ColumnFilters\";\nimport { buildApplyFilter } from \"@/components/controls/grid/columnfilters/ColumnFilters\";\nimport BmEnumDdl from \"@/components/controls/input/BmEnumDdl.vue\";\nimport type BaseEnumType from \"@/app/services/baseEnumType\";\nimport { translate } from \"@/plugins/i18n\";\nimport Key from \"@/app/types/common/key\";\n\nconst enumFilterTypes: FilterType[] = [\n {\n type: \"filter_equals\",\n values: 1,\n applyFunc: (\n itemValue: any,\n formattedItemValue: any,\n filterValue: BaseEnumType\n ) => {\n // We have to get the translated value, as that's what's used on the enum.\n const enumTranslatedValue = translate(\n Key.fromString(filterValue.translationKey!)\n );\n\n return itemValue === enumTranslatedValue;\n },\n },\n {\n type: \"filter_not_equals\",\n values: 1,\n applyFunc: (\n itemValue: any,\n formattedItemValue: any,\n filterValue: BaseEnumType\n ) => {\n // We have to get the translated value, as that's what's used on the enum.\n const enumTranslatedValue = translate(\n Key.fromString(filterValue.translationKey!)\n );\n\n return itemValue !== enumTranslatedValue;\n },\n },\n];\n\nexport function buildApplyEnumFilter(state: FilterState): FilterFunc {\n return buildApplyFilter(state, enumFilterTypes);\n}\n\nexport default Vue.extend({\n name: \"EnumFilterComponent\",\n components: { ColumnFilterComponent },\n render(createElement: CreateElement): VNode {\n return createElement(ColumnFilterComponent, {\n attrs: { ...this.$attrs },\n props: { filterTypes: enumFilterTypes },\n scopedSlots: {\n control1: function (props: any) {\n return createElement(BmEnumDdl, {\n attrs: {\n clearable: true,\n },\n props: {\n value: props.value ? (props.value as BaseEnumType) : null,\n enumType: props.enumType,\n enumFilter: props.enumFilter,\n },\n on: {\n input: function (event: BaseEnumType) {\n props.setValue(event ?? \"\"); // ISO-8601\n },\n },\n });\n },\n control2: function (props: any) {\n return createElement(BmEnumDdl, {\n attrs: {\n clearable: true,\n },\n props: {\n value: props.value ? (props.value as BaseEnumType) : null,\n enumType: props.enumType,\n enumFilter: props.enumFilter,\n },\n on: {\n input: function (event: BaseEnumType) {\n props.setValue(event ?? \"\"); // ISO-8601\n },\n },\n });\n },\n },\n });\n },\n});\n","import type { VNode } from \"vue\";\nimport Vue from \"vue\";\nimport ColumnFilterComponent from \"@/components/controls/grid/columnfilters/ColumnFilterComponent.vue\";\nimport type { CreateElement } from \"vue/types/vue\";\nimport type {\n FilterFunc,\n FilterState,\n FilterType,\n} from \"@/components/controls/grid/columnfilters/ColumnFilters\";\nimport { buildApplyFilter } from \"@/components/controls/grid/columnfilters/ColumnFilters\";\nimport BmSwitch from \"@/components/controls/input/BmSwitch.vue\";\n\nconst booleanFilterTypes: FilterType[] = [\n {\n type: \"filter_show_all\",\n values: 1,\n applyFunc: () => true,\n },\n {\n type: \"filter_equals\",\n values: 1,\n applyFunc: (\n itemValue: boolean,\n formattedItemValue: any,\n filterValue: boolean\n ) => itemValue === filterValue,\n },\n];\n\nexport function buildApplyBooleanFilter(state: FilterState): FilterFunc {\n return buildApplyFilter(state, booleanFilterTypes);\n}\n\nexport default Vue.extend({\n name: \"BooleanFilterComponent\",\n components: { ColumnFilterComponent },\n render(createElement: CreateElement): VNode {\n return createElement(ColumnFilterComponent, {\n attrs: { ...this.$attrs },\n props: { filterTypes: booleanFilterTypes, useTwoFilters: false },\n scopedSlots: {\n control1: (props: any) => {\n return createElement(BmSwitch, {\n attrs: {\n disabled: props.filterType === \"filter_show_all\",\n },\n props: {\n value: props.value,\n },\n on: {\n input: (event: boolean) => {\n props.setValue(event);\n },\n },\n });\n },\n },\n });\n },\n});\n","\n\n\n","import type {\n GroupSummaryValueExtractor,\n BmGridColumnSortState,\n BmGridConfiguration,\n} from \"@/components/controls/grid/BmGridData\";\nimport {\n BmGridState,\n componentToRenderer,\n} from \"@/components/controls/grid/BmGridData\";\nimport type { Instant, LocalTime } from \"@js-joda/core\";\nimport { LocalDate, DateTimeFormatter } from \"@js-joda/core\";\nimport type { ColumnKey } from \"@/components/controls/grid/builder/ColumnBuilders\";\nimport {\n ActionColumnBuilder,\n ColumnBuilder,\n ControlColumnBuilder,\n NumberColumnBuilder,\n} from \"@/components/controls/grid/builder/ColumnBuilders\";\nimport {\n IconSummaryBuilder,\n NumberSummaryBuilder,\n SummaryBuilder,\n} from \"@/components/controls/grid/builder/SummaryBuilders\";\nimport type { BmEnumType } from \"@/app/services/baseEnumType\";\nimport type BaseEnumType from \"@/app/services/baseEnumType\";\nimport DataCellIcon from \"@/components/controls/grid/renderers/DataCellIcon.vue\";\nimport type { VueConstructor } from \"vue\";\nimport DataCellControl from \"@/components/controls/grid/renderers/DataCellControl.vue\";\nimport TextFilterComponent, {\n buildApplyTextFilter,\n} from \"@/components/controls/grid/columnfilters/TextColumnFilter\";\nimport NumberFilterComponent, {\n buildApplyNumberFilter,\n} from \"@/components/controls/grid/columnfilters/NumberColumnFilter\";\nimport DateFilterComponent, {\n buildApplyDateFilter,\n} from \"@/components/controls/grid/columnfilters/DateColumnFilter\";\nimport DateTimeColumnFilter, {\n buildApplyDateTimeFilter,\n} from \"@/components/controls/grid/columnfilters/DateTimeColumnFilter\";\nimport type {\n VolumeUnitPreference,\n WeightUnitPreference,\n} from \"@/app/services/extensions/tenantServiceExtended\";\nimport {\n resolveVolumeUnitPreference,\n resolveWeightUnitPreference,\n tenantService,\n} from \"@/app/services/extensions/tenantServiceExtended\";\nimport type { UnitOfMeasure } from \"@/app/services/generated/unitofmeasureService\";\nimport EnumFilterComponent, {\n buildApplyEnumFilter,\n} from \"@/components/controls/grid/columnfilters/EnumColumnFilter\";\nimport BooleanFilterComponent, {\n buildApplyBooleanFilter,\n} from \"../columnfilters/BooleanColumnFilter\";\nimport { useVuetify } from \"@/plugins/vuetify\";\nimport Key from \"@/app/types/common/key\";\nimport DataCellBoolean from \"@/components/controls/grid/renderers/DataCellBoolean.vue\";\nimport type { TruncateOptions } from \"lodash\";\nimport { dateMatcher } from \"@/components/controls/grid/BmGridMatchers\";\nimport type { ComponentPublicInstanceConstructor } from \"vue/types/v3-component-public-instance\";\nimport { keys, translate } from \"@/plugins/i18n\";\nimport type { StringableId } from \"@/components/utils/typeHelpers\";\n\nexport default class GridConfigurationBuilder {\n private readonly _columnBuilders: ColumnBuilder[] = [];\n private readonly _summaryBuilders: SummaryBuilder[] = [];\n private readonly _itemKey?: (item: T) => string;\n private readonly _title?: string;\n\n // Will mostly get Guid Ids but can deal with anything resolving to a string.\n constructor(opts?: { itemId: (item: T) => StringableId; title?: string }) {\n this._itemKey = opts ? (item) => opts.itemId(item).toString() : undefined;\n this._title = opts?.title;\n }\n\n private readonly vuetify = useVuetify().$vuetify;\n\n addTextColumn(\n columnKey: ColumnKey,\n itemValue: (item: T) => string | null\n ): ColumnBuilder {\n const builder = new ColumnBuilder(columnKey, itemValue);\n builder.withColumnFilter({\n columnFilterComponent: TextFilterComponent,\n buildApply: buildApplyTextFilter,\n });\n\n this._columnBuilders.push(builder);\n return builder;\n }\n\n addEnumColumn(\n columnKey: ColumnKey,\n itemValue: (item: T) => BaseEnumType | null,\n showZeros: boolean = false,\n enumType: BmEnumType,\n enumFilter?: (item: BaseEnumType) => boolean\n ): ColumnBuilder {\n const builder = new ColumnBuilder(columnKey, (item) => {\n const enumValue = itemValue(item);\n if (!enumValue || (!showZeros && enumValue.key === 0)) {\n return \"\";\n }\n return enumValue.translationKey\n ? translate(Key.fromString(enumValue.translationKey)).toString()\n : enumValue.value;\n }).withAlignment(\"start\");\n builder.withColumnFilter({\n columnFilterComponent: EnumFilterComponent,\n buildApply: buildApplyEnumFilter,\n });\n\n builder.withEnumType(enumType);\n\n if (enumFilter) {\n builder.withEnumFilter(enumFilter);\n }\n\n this._columnBuilders.push(builder);\n return builder;\n }\n\n addMobileOnlyTextInfoDialogColumn(\n translationKey: Key,\n itemValue: (item: T) => string | null,\n truncateOptions: TruncateOptions = { length: 100 },\n allowSortingAndFiltering = false\n ): ColumnBuilder {\n const column = this.addTextColumn(translationKey, (item) =>\n itemValue(item)\n ).allowSortingAndFiltering(allowSortingAndFiltering);\n\n if (this.vuetify.breakpoint.xsOnly) {\n column.withTextTruncation({ length: truncateOptions.length });\n }\n\n this._columnBuilders.push(column);\n return column;\n }\n\n addIconColumn(\n columnKey: ColumnKey,\n itemValue: (item: T) => any,\n itemToIconName: (item: any) => string\n ): ColumnBuilder {\n const builder = new ColumnBuilder(columnKey, itemValue)\n .withFormatter(itemToIconName)\n .withRenderer(componentToRenderer(DataCellIcon));\n builder.withColumnFilter({\n columnFilterComponent: BooleanFilterComponent,\n buildApply: buildApplyBooleanFilter,\n });\n builder.withAlignment(this.vuetify.breakpoint.xs ? \"start\" : \"center\");\n this._columnBuilders.push(builder);\n return builder;\n }\n\n addBooleanCheckMarkColumn(\n columnKey: ColumnKey,\n itemValue: (item: T) => boolean | null\n ): ColumnBuilder {\n const builder = new ColumnBuilder(columnKey, itemValue)\n .withRenderer(componentToRenderer(DataCellBoolean))\n .withColumnFilter({\n columnFilterComponent: BooleanFilterComponent,\n buildApply: buildApplyBooleanFilter,\n })\n .withAlignment(this.vuetify.breakpoint.xs ? \"start\" : \"center\")\n .withCsvFormatter((value: boolean, item, stringRenderer) =>\n value ? stringRenderer(\"True\") : stringRenderer(\"False\")\n );\n this._columnBuilders.push(builder);\n return builder;\n }\n\n addDateColumn(\n columnKey: ColumnKey,\n itemValue: (item: T) => LocalDate | null\n ): ColumnBuilder {\n // Some non-nullable Date fields contain an erroneous 01/01/1970\n // Which we will treat as null.\n const itemValWithEpochAsNull = (item: T) => {\n const basic = itemValue(item);\n return basic?.equals(LocalDate.EPOCH_0) ? null : basic;\n };\n\n const builder = new ColumnBuilder(\n columnKey,\n itemValWithEpochAsNull\n )\n .withFormatter(\n (localDate) => localDate && tenantService.formatDate(localDate)\n )\n .withCsvFormatter((value: LocalDate | null) => {\n return value\n ? DateTimeFormatter.ofPattern(\"yyyy-MM-dd\").format(value)\n : \"\";\n })\n .withMatcher(dateMatcher);\n builder.withColumnFilter({\n columnFilterComponent: DateFilterComponent,\n buildApply: buildApplyDateFilter,\n });\n this._columnBuilders.push(builder);\n return builder;\n }\n\n addTimeColumn(\n columnKey: Key,\n itemValue: (item: T) => LocalTime | null\n ): ColumnBuilder {\n const builder = new ColumnBuilder(columnKey, itemValue)\n .withFormatter(\n (localTime: LocalTime | null) =>\n localTime && tenantService.formatTime(localTime)\n )\n .withCsvFormatter((value: LocalTime) => {\n return value\n ? DateTimeFormatter.ofPattern(\"HH:mm:ss\").format(value)\n : \"\";\n });\n this._columnBuilders.push(builder);\n return builder;\n }\n\n addDateTimeColumn(\n columnKey: ColumnKey,\n itemValue: (item: T) => Instant | null\n ): ColumnBuilder {\n const builder = new ColumnBuilder(columnKey, itemValue)\n .withFormatter(\n (dateTime) => dateTime && tenantService.formatDateTime(dateTime)\n )\n .withCsvFormatter((value: Instant) => {\n return value\n ? DateTimeFormatter.ofPattern(\"yyyy-MM-dd HH:mm:ss\").format(\n tenantService.instantToDateTime(value)\n )\n : \"\";\n });\n builder.withColumnFilter({\n columnFilterComponent: DateTimeColumnFilter,\n buildApply: buildApplyDateTimeFilter,\n });\n this._columnBuilders.push(builder);\n return builder;\n }\n\n addNumberColumn(\n columnKey: ColumnKey,\n itemValue: (item: T) => number | null,\n integral: boolean = false,\n maxDecimalPlaces?: number\n ): NumberColumnBuilder {\n const builder = new NumberColumnBuilder(\n columnKey,\n itemValue,\n integral,\n maxDecimalPlaces\n );\n builder.withAlignment(this.vuetify.breakpoint.xs ? \"start\" : \"end\");\n this._columnBuilders.push(builder);\n return builder;\n }\n\n addIntegerColumn(\n columnKey: ColumnKey,\n itemValue: (item: T) => number | null\n ): NumberColumnBuilder {\n return this.addNumberColumn(columnKey, itemValue, true);\n }\n\n addCurrencyColumn(\n columnKey: ColumnKey,\n itemValue: (item: T) => number | null,\n quantise: boolean = false\n ): ColumnBuilder {\n const builder = new ColumnBuilder(columnKey, itemValue);\n builder.withFormatter((item) =>\n // null/undefined is empty whereas 0 is explicitly 0.\n item != null ? tenantService.formatCurrency(item, quantise) : \"\"\n );\n builder.withColumnFilter({\n columnFilterComponent: NumberFilterComponent,\n buildApply: buildApplyNumberFilter,\n });\n\n builder.withAlignment(this.vuetify.breakpoint.xs ? \"start\" : \"end\");\n\n this._columnBuilders.push(builder);\n return builder;\n }\n\n addMeasureColumn(\n columnKey: ColumnKey,\n itemValue: (item: T) => number | null,\n unitOfMeasureExtractor: (item: T) => Readonly | null\n ): NumberColumnBuilder {\n const builder = new NumberColumnBuilder(columnKey, itemValue, false);\n builder.withColumnFilter({\n columnFilterComponent: NumberFilterComponent,\n buildApply: buildApplyNumberFilter,\n });\n\n builder.withSuffixExtractor((item) => {\n return unitOfMeasureExtractor(item)?.name || \"\";\n });\n\n this._columnBuilders.push(builder);\n return builder;\n }\n\n addWeightColumn(\n columnKey: ColumnKey,\n itemValue: (item: T) => number | null,\n maxDecimalPlaces?: number,\n context: WeightUnitPreference = tenantService.settings\n .displayUnitPreferences.generalWeights\n ): NumberColumnBuilder {\n const unitPreferences = resolveWeightUnitPreference(context);\n\n const builder = new NumberColumnBuilder(\n columnKey,\n (val: T) => {\n const value = itemValue(val);\n return value != null\n ? tenantService.toDisplayPreferenceWeight(value, maxDecimalPlaces)\n : null;\n },\n false,\n maxDecimalPlaces ?? unitPreferences.maxDecimalPlaces\n );\n builder.withColumnFilter({\n columnFilterComponent: NumberFilterComponent,\n buildApply: buildApplyNumberFilter,\n });\n\n builder.withSuffixExtractor((item) => unitPreferences.suffix);\n\n this._columnBuilders.push(builder);\n return builder;\n }\n\n addVolumeColumn(\n columnKey: ColumnKey,\n itemValue: (item: T) => number | null,\n context: VolumeUnitPreference,\n maxDecimalPlaces?: number\n ): NumberColumnBuilder {\n const unitPreferences = resolveVolumeUnitPreference(context);\n\n const builder = new NumberColumnBuilder(\n columnKey,\n (val: T) => {\n const value = itemValue(val);\n return value != null\n ? tenantService.toDisplayPreferenceVolume(\n value,\n context,\n maxDecimalPlaces\n )\n : null;\n },\n false,\n maxDecimalPlaces ?? unitPreferences.maxDecimalPlaces\n );\n\n builder.withColumnFilter({\n columnFilterComponent: NumberFilterComponent,\n buildApply: buildApplyNumberFilter,\n });\n\n builder.withSuffixExtractor((item) => unitPreferences.suffix);\n\n this._columnBuilders.push(builder);\n return builder;\n }\n\n addActionsColumn(columnKey: Key = keys.grid_actions): ActionColumnBuilder {\n const builder = new ActionColumnBuilder(columnKey).showNarrow();\n this._columnBuilders.push(builder);\n return builder;\n }\n\n addControlColumn(\n columnKey: ColumnKey,\n component: VueConstructor | ComponentPublicInstanceConstructor,\n propBinder?: (item: T) => any,\n eventBinder?: (item: T) => any,\n contentBinder?: (item: T) => any,\n itemValue?: (item: T) => any\n ): ControlColumnBuilder {\n const builder = new ControlColumnBuilder(columnKey, itemValue);\n builder.withRenderer(componentToRenderer(DataCellControl));\n // Don't output anything to csv by default: Caller has to specify this\n builder.withCsvFormatter(() => \"\");\n builder.withControl(component, propBinder, eventBinder, contentBinder);\n this._columnBuilders.push(builder);\n return builder;\n }\n\n // Summaries\n addColumnAlignedTextSummary(\n columnKey: Key,\n aggregator: GroupSummaryValueExtractor\n ): SummaryBuilder {\n const summary = new SummaryBuilder(\n (item, col) => col[columnKey.value].extractor(item),\n aggregator\n ).alignWithGroupedColumn(columnKey.value);\n this._summaryBuilders.push(summary);\n return summary;\n }\n\n addColumnAlignedNumberSummary(\n columnKey: Key,\n aggregator: GroupSummaryValueExtractor\n ): NumberSummaryBuilder {\n const summary = new NumberSummaryBuilder(\n (item, col) => col[columnKey.value].extractor(item),\n aggregator\n ).alignWithGroupedColumn(columnKey.value);\n this._summaryBuilders.push(summary);\n return summary;\n }\n\n addColumnAlignedIconSummary(\n columnKey: Key,\n aggregator: GroupSummaryValueExtractor\n ): IconSummaryBuilder {\n const summary = new IconSummaryBuilder(\n (item, col) => col[columnKey.value].extractor(item),\n aggregator\n )\n .alignWithGroupedColumn(columnKey.value)\n .withRenderer(componentToRenderer(DataCellIcon));\n this._summaryBuilders.push(summary);\n return summary;\n }\n\n build(): BmGridConfiguration {\n const columnStates = this._columnBuilders.map((cb) => cb.getDefaultState());\n\n const defaultState: Partial = {\n sortBy: columnStates\n .filter((kv) => kv[1].sortByIndex !== undefined)\n .sort((v1, v2) => v1[1].sortByIndex! - v2[1].sortByIndex!)\n .map((kv) => ({\n columnKey: kv[0],\n descending: kv[1].sortByDescending ?? false,\n })),\n\n groupBy: columnStates\n .filter((kv) => kv[1].groupByIndex !== undefined)\n .sort((v1, v2) => v1[1].groupByIndex! - v2[1].groupByIndex!)\n .map((kv) => kv[0]),\n\n removedColumnKeys: columnStates\n .filter((kv) => kv[1].hidden)\n .map((kv) => kv[0]),\n\n columnFilters: Object.fromEntries(\n columnStates\n .filter((kv) => kv[1].filterState)\n .map((kv) => [kv[0], kv[1].filterState])\n ),\n };\n\n return {\n defaultGridState: new BmGridState(defaultState),\n columns: Object.fromEntries(this._columnBuilders.map((cb) => cb.build())),\n summaries: this._summaryBuilders.map((sb) => sb.build()),\n itemKey: this._itemKey,\n title: this._title,\n };\n }\n}\n","\n\n\n\n\n","\n\n\n","export function mergeConfiguration(\n target: T,\n source: Partial\n): T {\n return Object.assign(target, source);\n}\n","import { isNotNullOrUndefined } from \"@/app/apiutils\";\nimport type { ModelObject } from \"@/app/services/modelObject\";\nimport type { ReadonlyEntityArray } from \"@/components/composables/reactivityTypes\";\nimport type { GridDragDropEvent } from \"@/components/controls/grid/BmGrid.vue\";\nimport { mergeConfiguration } from \"@/components/platform/common/configurationUtils\";\nimport type { ComputedRef, Ref } from \"vue\";\n\nexport interface DragDropOptions {\n allowMultipleSelection?: boolean;\n}\n\nexport interface DragDropKeysOptions {\n allowMultipleSelection?: boolean;\n removeInvalidRows?: boolean;\n}\n\nexport interface DragDropItemsOptions {\n allowMultipleSelection?: boolean;\n sequenceUpdater?: (item: T, index: number) => void;\n}\n\nconst dragDropDefaults: DragDropOptions = {\n allowMultipleSelection: true,\n};\n\n/**\n * Provides drag and drop functionality and sorts keys in the order they are dropped.\n * Supports inter grid drag and drop.\n */\nexport const useGridKeysDragDrop = (\n keys: ComputedRef,\n updateKeysCallback: (updatedKeyOrder: string[]) => Promise | void,\n options: DragDropKeysOptions = {}\n) => {\n const dragDropOptions = mergeConfiguration(dragDropDefaults, options);\n const onDrop = (event: GridDragDropEvent) => {\n const targetKey = event.droppedOnRowKey;\n let movedKeys = event.draggedRowKeys;\n if (!validateDragDropEvent(event, dragDropOptions)) {\n return;\n }\n\n if (options.removeInvalidRows) {\n const validKeys = movedKeys.filter((key) => keys.value.includes(key));\n if (validKeys.length !== movedKeys.length) {\n movedKeys = validKeys;\n }\n }\n\n const orderedKeys = addRowsAtItemPosition(\n keys.value,\n movedKeys,\n targetKey,\n (key) => key\n );\n\n updateKeysCallback(orderedKeys);\n };\n\n return { onDrop };\n};\n\n/**\n * Provides a drag and drop handler that returns the new order of the items post drag and drop.\n * Does not support inter grid drag and drop.\n */\nexport const useGridItemsDragDrop = (\n items: Ref | T[]>,\n rowKeyExtractor: (item: T) => string,\n updateItemsCallback: (updatedItemsOrder: T[]) => Promise | void,\n options: DragDropItemsOptions = {}\n) => {\n const dragDropOptions: DragDropItemsOptions = mergeConfiguration(\n options,\n dragDropDefaults\n );\n const onDrop = async (event: GridDragDropEvent) => {\n const orderedItems = evaluateDragDropResequence(\n items.value,\n rowKeyExtractor,\n event,\n dragDropOptions\n );\n\n if (!orderedItems) {\n // Invalid Drag-Drop\n return;\n }\n\n if (dragDropOptions.sequenceUpdater) {\n updateSequence(orderedItems);\n }\n\n await updateItemsCallback(orderedItems);\n };\n\n const updateSequence = (itemsToSequence: T[]) => {\n if (!dragDropOptions.sequenceUpdater) {\n return;\n }\n itemsToSequence.forEach((item, index) =>\n dragDropOptions.sequenceUpdater!(item, index)\n );\n };\n\n return {\n onDrop,\n };\n};\n\nconst addRowsAtItemPosition = (\n existingItems: ReadonlyEntityArray | T[],\n rowsToAdd: T[],\n targetKey: string | undefined,\n rowKeyExtractor: (item: T) => string\n) => {\n const rowsToAddKeys = rowsToAdd.map(rowKeyExtractor);\n const newItemsOrdered: T[] = [];\n\n if (targetKey === undefined || existingItems.length === 0) {\n // add the moved keys before the first row\n newItemsOrdered.push(...rowsToAdd);\n }\n // Reorder the items by moving all of the moved keys to below the target key.\n existingItems.forEach((row) => {\n const currentKey = rowKeyExtractor(row);\n\n if (!rowsToAddKeys.includes(currentKey)) {\n // If unchanged, add the row\n newItemsOrdered.push(row);\n }\n\n if (currentKey === targetKey) {\n // add the moved keys below the target key. Will include target if it was moved.\n newItemsOrdered.push(...rowsToAdd);\n }\n });\n return newItemsOrdered;\n};\n\nconst validateDragDropEvent = (\n event: GridDragDropEvent,\n options: DragDropOptions\n) => {\n if (\n // No items to move.\n !event.draggedRowKeys.length ||\n // Dropped on the same row.\n (event.draggedRowKeys.length === 1 &&\n event.draggedRowKeys[0] === event.droppedOnRowKey) ||\n // Dragged multiple items when not allowed.\n (!options.allowMultipleSelection && event.draggedRowKeys.length !== 1)\n ) {\n return false;\n }\n return true;\n};\n\nexport const evaluateDragDropResequence = (\n itemsInPreviousSequence: readonly T[],\n rowKeyExtractor: (item: T) => string,\n event: GridDragDropEvent,\n options: DragDropOptions = {}\n): T[] | null => {\n if (!validateDragDropEvent(event, options)) {\n return null;\n }\n\n const movedKeys = event.draggedRowKeys;\n const targetKey = event.droppedOnRowKey;\n\n const movedRows = movedKeys\n .map((key) => {\n return itemsInPreviousSequence.find((i) => rowKeyExtractor(i) === key);\n })\n .filter(isNotNullOrUndefined);\n\n return addRowsAtItemPosition(\n itemsInPreviousSequence,\n movedRows,\n targetKey,\n rowKeyExtractor\n );\n};\n\nexport const cloneItemsForNewSequence = >(\n itemsInPreviousSequence: T[],\n extractSequence: (item: T) => number,\n setSequence: (item: T, sequence: number) => void\n) => {\n return itemsInPreviousSequence\n .map((item, idx) => ({\n item: item,\n idx: idx,\n }))\n .filter((x) => extractSequence(x.item) != x.idx)\n .map((x) => {\n const clone = x.item.clone();\n setSequence(clone, x.idx);\n return clone;\n });\n};\n","\n\n\n","\n\n\n\n\n","import type { IModelObject } from \"@/app/services/modelObject\";\nimport { makeRef } from \"@/components/composables/reactivityTypes\";\nimport type { Maybe } from \"@/components/utils/typeHelpers\";\n\n//\n// ModelObjects USED to contain their own dirtyState and it was automatically initialised\n// on API response deserialisation. However, that approach was resource intensive (in particular\n// causing slowness on mobile devices handling large payloads) so we have moved to finer control.\n// The old approach can be used on a type by code-genning it with \"WithTsDirtyCheck()\".\n// The new approach here pulls Dirty Checking out to this class, which can be invoked and\n// used exactly where needed to check for dirtiness of a specific object, thus only using resources\n// for the specific dirtiness being checked, not all uses of that object type.\n//\nexport class DirtyChecker {\n private _item = makeRef(null);\n private _checkpoint = makeRef(\"\");\n\n constructor(item?: T) {\n this._item.value = item || null;\n this.resetCheckpoint();\n }\n\n public setItem(item: T) {\n this._item.value = item;\n this.resetCheckpoint();\n }\n\n public resetCheckpoint() {\n this._checkpoint.value = this.evaluateCheckpoint(this._item.value);\n }\n\n public isDirty() {\n return this._checkpoint.value !== this.evaluateCheckpoint(this._item.value);\n }\n\n private evaluateCheckpoint(item: T | null) {\n return item ? JSON.stringify(item.toProto()) : \"\";\n }\n}\n\nexport function dirtyCheck(\n checkPoint: Maybe,\n testVal: Maybe\n) {\n return (\n (checkPoint ? JSON.stringify(checkPoint.toProto()) : \"\") !==\n (testVal ? JSON.stringify(testVal.toProto()) : \"\")\n );\n}\n","\n\n\n","import Guid from \"@/app/types/common/guid\";\nimport { Instant, LocalDate, LocalTime } from \"@js-joda/core\";\nimport {ModelObject, BaseModelObject, ValidationRule} from \"@/app/services/modelObject\";\nimport ServiceBase from \"@/app/services/serviceBase\";\nimport converters from \"@/app/services/converters\"\nimport { EnumFileType } from \"./enums/enumFileType.generated\";\n\n// Model Objects\n\nexport class FileBase64 extends ModelObject {\n\n public id: Guid = Guid.createEmpty();\n /**\n * The original name of the file\n * Not Nullable\n * Not Empty\n * Max Length : 1000\n */\n public fileName: string = \"\";\n /**\n * The type of file.\n */\n public fileType: EnumFileType = EnumFileType.image;\n public fileContentsBase64: string = \"\";\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.id = Guid.fromString(jsonSerializedObject.id);\n this.fileName = jsonSerializedObject.fileName;\n this.fileType = EnumFileType.getByValue(jsonSerializedObject.fileType, this.fileType);\n this.fileContentsBase64 = jsonSerializedObject.fileContentsBase64;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.id = this.id.toString();\n toRet.fileName = this.fileName;\n toRet.fileType = this.fileType.value;\n toRet.fileContentsBase64 = this.fileContentsBase64;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \"FileBase64.Id cannot be empty\"},\n {field: \"fileName\", rule: (v: any) => v == null || v.length !== 0 || \"FileName cannot be empty\"},\n {field: \"fileName\", rule: (v: any) => v == null || v.length <= 1000 || \"FileName has too many characters (1000)\"},\n ];\n}\n\n\nexport class GetFileBase64Request extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public id: Guid = Guid.createEmpty();\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.id = Guid.fromString(jsonSerializedObject.id);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.id = this.id.toString();\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"id\", rule: (v: any) => !v.isEmpty() || \".Id cannot be empty\"},\n ];\n}\n\n\nexport class GetFileBase64Response extends ModelObject {\n\n private _file: FileBase64 | null = null;\n public get file(): FileBase64 | null { return this._file }\n public set file(value: FileBase64 | null) {\n this._file = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.file = jsonSerializedObject.file == null ? null : new FileBase64(jsonSerializedObject.file);\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.file = this.file == null ? null : this.file?.toJsonSerializedObject() ?? null;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"file\", rule: (v: any) => (v === null) || v.validate()},\n ];\n}\n\n\nexport class SaveFileBase64Request extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public file: FileBase64 = new FileBase64();\n private _resizeMaxFileSizeBytes: number | null = null;\n /**\n * If exists, will be used for resizing images.\n */\n public get resizeMaxFileSizeBytes(): number | null { return this._resizeMaxFileSizeBytes }\n public set resizeMaxFileSizeBytes(value: number | null) {\n this._resizeMaxFileSizeBytes = value === undefined ? null : value;\n }\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.file = new FileBase64(jsonSerializedObject.file);\n this.resizeMaxFileSizeBytes = jsonSerializedObject.resizeMaxFileSizeBytes == null ? null : jsonSerializedObject.resizeMaxFileSizeBytes;\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.file = this.file.toJsonSerializedObject();\n toRet.resizeMaxFileSizeBytes = this.resizeMaxFileSizeBytes == null ? null : this.resizeMaxFileSizeBytes;\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n {field: \"file\", rule: (v: any) => !!v || \"file is required\"},\n {field: \"file\", rule: (v: any) => v.validate()},\n {field: \"resizeMaxFileSizeBytes\", rule: (v: any) => v == null || v >= -2147483648 || \"ResizeMaxFileSizeBytes is not greater than minimum allowed value: -2147483648\"},\n {field: \"resizeMaxFileSizeBytes\", rule: (v: any) => v == null || v <= 2147483647 || \"ResizeMaxFileSizeBytes is above maximum allowed value: 2147483647\"},\n ];\n}\n\n\nexport class GetFilesBase64Request extends ModelObject {\n\n public tenantId: Guid = Guid.createEmpty();\n public ids: readonly Guid[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.tenantId = Guid.fromString(jsonSerializedObject.tenantId);\n this.ids = jsonSerializedObject.ids.map((v: any) => Guid.fromString(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.tenantId = this.tenantId.toString();\n toRet.ids = this.ids.map(v => v.toString());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"tenantId\", rule: (v: any) => !v.isEmpty() || \".TenantId cannot be empty\"},\n ];\n}\n\n\nexport class GetFilesBase64Response extends ModelObject {\n\n public files: FileBase64[] = [];\n\n public constructor(jsonSerializedObject?: any) {\n super();\n if (jsonSerializedObject) {\n this.files = jsonSerializedObject.files.map((v: any) => new FileBase64(v));\n }\n\n }\n\n public toJsonSerializedObject(): any {\n const toRet = {} as any;\n toRet.files = this.files.map(v => v.toJsonSerializedObject());\n return toRet;\n }\n\n public toProto(): any {\n return this.toJsonSerializedObject();\n }\n\n public toBinary(): Uint8Array {\n return new TextEncoder().encode(JSON.stringify(this.toJsonSerializedObject()));\n }\n\n public validationRules: ValidationRule = [\n {field: \"files\", rule: (v: any) => !!v || \"files is required\"},\n {field: \"files\", rule: (v: any) => {\n if (v === null) {\n return true;\n }\n\n return (v as FileBase64[]).reduce((acc: Array, curr: FileBase64) => acc.concat(curr.validate()), new Array());\n }},\n ];\n}\n\n\nexport class FileService extends ServiceBase {\n\n public async getFileBase64(tenantId: Guid, id: Guid, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetFileBase64Request();\n req.tenantId = tenantId;\n req.id = id;\n const extractor = (response:any) => new GetFileBase64Response(response).file;\n return this.makeJsonRequest(\"file/v1/getFileBase64\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async saveFileBase64(tenantId: Guid, file: FileBase64, resizeMaxFileSizeBytes: number | null, opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new SaveFileBase64Request();\n req.tenantId = tenantId;\n req.file = file;\n req.resizeMaxFileSizeBytes = resizeMaxFileSizeBytes;\n const extractor = null;\n return this.makeJsonRequest(\"file/v1/saveFileBase64\", req.toJsonSerializedObject(), extractor, opts);\n };\n\n public async getFilesBase64(tenantId: Guid, ids: readonly Guid[], opts?: {requestTimeoutMs?: number, sessionToken?: string}): Promise {\n const req = new GetFilesBase64Request();\n req.tenantId = tenantId;\n req.ids = ids;\n const extractor = (response:any) => new GetFilesBase64Response(response).files;\n return this.makeJsonRequest(\"file/v1/getFilesBase64\", req.toJsonSerializedObject(), extractor, opts);\n };\n}\n\nexport const fileService = new FileService();","import appStore from \"@/store/modules/appStore\";\n\nexport type AcceptedImageTypes = (typeof acceptedImageTypes)[number];\n\nexport interface DownscaleImageConfig {\n newWidthPixels: number;\n imageType: AcceptedImageTypes;\n quality: number;\n}\n\nexport type CameraCaptureMode = \"user\" | \"environment\";\n\nexport const acceptedImageTypes = [\"image/jpeg\", \"image/png\"];\n\n/**\n * Downscale an image to a new width in pixels and a lower quality.\n */\nexport const downscaleBase64Image = async (\n base64Image: string,\n downscaleImageConfig: DownscaleImageConfig = {\n newWidthPixels: 800,\n imageType: \"image/jpeg\",\n quality: 0.5,\n }\n) => {\n const { newWidthPixels, imageType, quality } = downscaleImageConfig;\n\n // Create a temporary image so that we can compute the height of the downscaled image.\n const image = new Image();\n image.src = base64ImageToDataUrl(base64Image, downscaleImageConfig.imageType);\n await image.decode();\n // wait till the image loads\n\n const oldWidth = image.width;\n const oldHeight = image.height;\n const newHeight = Math.floor((oldHeight / oldWidth) * newWidthPixels);\n\n // Create a temporary canvas to draw the downscaled image on.\n const canvas = document.createElement(\"canvas\");\n canvas.width = newWidthPixels;\n canvas.height = newHeight;\n\n // Draw the downscaled image on the canvas and return the new image\n const ctx = canvas.getContext(\"2d\");\n ctx?.drawImage(image, 0, 0, newWidthPixels, newHeight);\n return stripImagePrefixFromBase64DataUrl(\n canvas.toDataURL(imageType, quality)\n );\n};\n\n/**\n * @desc initiates download of a file from a base64 data URL\n * @param {string} base64ImageDataUrl dataUrl of base64 image\n * @param {string} fileExtension with prefixed dot (.png | .jpg | .jpeg)\n * @param {string} fileName Name without extensions or dots\n */\nexport const initiateDownloadOfBase64DataUrl = (\n base64ImageDataUrl: string,\n fileExtension: string = \".jpeg\",\n fileName: string = \"Image\"\n) => {\n appStore.pushSnackbarConfig({ text: \"Downloading image\" });\n const a = document.createElement(\"a\");\n a.href = base64ImageDataUrl;\n a.download = fileName + fileExtension;\n a.click(); //Download file\n};\n\n/**\n * @desc initiates download of a file from a base64 string\n * @param {string} base64Image Base64 image\n * @param {string} fileExtension with prefixed dot (.png | .jpg | .jpeg)\n * @param {string} fileName Name without extensions or dots\n * @param {AcceptedImageTypes} imageType eg. image/jpeg (default)\n */\nexport const initiateDownloadOfBase64Image = (\n base64Image: string,\n fileExtension: string = \".jpeg\",\n fileName: string = \"Image\",\n imageType: AcceptedImageTypes = \"image/jpeg\"\n) => {\n initiateDownloadOfBase64DataUrl(\n base64ImageToDataUrl(base64Image, imageType),\n fileExtension,\n fileName\n );\n};\n\n/**\n *\n * @desc Converts base64 image to dataUrl by adding image type prefix\n * @param base64Image to be converted to dataUrl\n * @returns {string} base64 Image as dataUrl\n */\nexport const base64ImageToDataUrl = (\n base64Image: string,\n imageType: AcceptedImageTypes = \"image/jpeg\"\n) => {\n return `data:${imageType};base64,${base64Image}`;\n};\n\n/**\n *\n * @param dataUrl Data url with ImageStringPrefix (eg data:image/jpeg;base64,)\n * @returns dataUrl without ImageStringPrefix\n */\nexport const stripImagePrefixFromBase64DataUrl = (dataUrl: string) => {\n /* eslint-disable no-useless-escape */\n return dataUrl.replace(/^data:([\\w\\/\\+]+);(charset=[\\w-]+|base64).*,/, \"\");\n};\n","\n\n\n\n\n","\n\n\n","\n \n \n \n \n arrow_back_ios\n {{ returnLabel }}\n
\n \n \n \n \n\n\n\n\n\n","\n\n\n\n\n","\n\n\n","// Events sent to the Wizard to request a change (e.g. by Footer)\nexport enum WizardInputEventType {\n Close = \"BmWizardClose\",\n PreviousStep = \"BmWizardPreviousStep\",\n NextStep = \"BmWizardNextStep\",\n Finished = \"BmWizardFinished\",\n}\n","import type Guid from \"@/app/types/common/guid\";\nimport { reactive, readonly } from \"vue\";\n\nlet hintStack: Guid[] = [];\n\ninterface WizardStoreState {\n numberOfSteps: number;\n stepNumber: number;\n atLastRequiredStep: boolean;\n activeHint: Guid | null;\n}\n\nconst state = reactive({\n numberOfSteps: 0,\n stepNumber: 0,\n atLastRequiredStep: false,\n activeHint: null,\n});\n\nexport default {\n state: readonly(state),\n setNumberOfSteps: (numberOfSteps: number) =>\n (state.numberOfSteps = numberOfSteps),\n updateStep: (stepNumber: number, atLastRequiredStep: boolean) => {\n state.stepNumber = stepNumber;\n state.atLastRequiredStep = atLastRequiredStep;\n },\n pushHint: (hintId: Guid) => {\n hintStack = hintStack.filter((h) => !h.equals(hintId));\n hintStack.push(hintId);\n state.activeHint = hintStack.slice(-1)[0] ?? null;\n },\n popHint: (hintId: Guid) => {\n hintStack = hintStack.filter((h) => !h.equals(hintId));\n state.activeHint = hintStack.slice(-1)[0] ?? null;\n },\n};\n","\n\n\n\n\n","